Skip to content

Commit

Permalink
feat: add doc display meta extension
Browse files Browse the repository at this point in the history
  • Loading branch information
fundon committed Dec 13, 2024
1 parent 541f254 commit 1587f1a
Show file tree
Hide file tree
Showing 21 changed files with 314 additions and 172 deletions.
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
import { cloneReferenceInfoWithoutAliases } from '@blocksuite/affine-components/rich-text';
import {
EMBED_CARD_HEIGHT,
EMBED_CARD_WIDTH,
} from '@blocksuite/affine-shared/consts';
import { cloneReferenceInfoWithoutAliases } from '@blocksuite/affine-shared/utils';
import { Bound } from '@blocksuite/global/utils';

import { toEdgelessEmbedBlock } from '../common/to-edgeless-embed-block.js';
Expand Down Expand Up @@ -39,7 +39,7 @@ export class EmbedEdgelessLinkedDocBlockComponent extends toEdgelessEmbedBlock(
{
xywh: bound.serialize(),
caption,
...cloneReferenceInfoWithoutAliases(this.referenceInfo),
...cloneReferenceInfoWithoutAliases(this.referenceInfo$.peek()),
},
// @ts-expect-error TODO: fix after edgeless refactor
edgelessService.surface
Expand All @@ -65,7 +65,7 @@ export class EmbedEdgelessLinkedDocBlockComponent extends toEdgelessEmbedBlock(

protected override _handleClick(evt: MouseEvent): void {
if (this.config.handleClick) {
this.config.handleClick(evt, this.host, this.referenceInfo);
this.config.handleClick(evt, this.host, this.referenceInfo$.peek());
return;
}
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -5,27 +5,29 @@ import type {
ReferenceInfo,
} from '@blocksuite/affine-model';

import { BlockLinkIcon } from '@blocksuite/affine-components/icons';
import { isPeekable, Peekable } from '@blocksuite/affine-components/peek';
import {
cloneReferenceInfo,
cloneReferenceInfoWithoutAliases,
REFERENCE_NODE,
referenceToNode,
RefNodeSlotsProvider,
} from '@blocksuite/affine-components/rich-text';
import {
EMBED_CARD_HEIGHT,
EMBED_CARD_WIDTH,
} from '@blocksuite/affine-shared/consts';
import {
DocDisplayMetaProvider,
DocModeProvider,
ThemeProvider,
} from '@blocksuite/affine-shared/services';
import { matchFlavours } from '@blocksuite/affine-shared/utils';
import {
cloneReferenceInfo,
cloneReferenceInfoWithoutAliases,
matchFlavours,
referenceToNode,
} from '@blocksuite/affine-shared/utils';
import { Bound } from '@blocksuite/global/utils';
import { AliasIcon } from '@blocksuite/icons/lit';
import { DocCollection } from '@blocksuite/store';
import { computed } from '@preact/signals-core';
import { html, nothing } from 'lit';
import { property, queryAsync, state } from 'lit/decorators.js';
import { classMap } from 'lit/directives/class-map.js';
Expand Down Expand Up @@ -142,7 +144,10 @@ export class EmbedLinkedDocBlockComponent extends EmbedBlockComponent<EmbedLinke

doc.addBlock(
'affine:embed-synced-doc',
{ caption, ...cloneReferenceInfoWithoutAliases(this.referenceInfo) },
{
caption,
...cloneReferenceInfoWithoutAliases(this.referenceInfo$.peek()),
},
parent,
index
);
Expand All @@ -164,7 +169,7 @@ export class EmbedLinkedDocBlockComponent extends EmbedBlockComponent<EmbedLinke
yText.format(0, REFERENCE_NODE.length, {
reference: {
type: 'LinkedPage',
...this.referenceInfo,
...this.referenceInfo$.value,
},
});
const text = new doc.Text(yText);
Expand All @@ -181,10 +186,27 @@ export class EmbedLinkedDocBlockComponent extends EmbedBlockComponent<EmbedLinke
doc.deleteBlock(this.model);
};

referenceInfo$ = computed<ReferenceInfo>(() => {
const { pageId, params, title$, description$ } = this.model;
return cloneReferenceInfo({
pageId,
params,
title: title$.value,
description: description$.value,
});
});

icon$ = computed(() => {
const { pageId, params, title } = this.referenceInfo$.value;
return this.std
.getOptional(DocDisplayMetaProvider)
?.icon(pageId, { params, title, referenced: true }).value;
});

open = () => {
this.std
.getOptional(RefNodeSlotsProvider)
?.docLinkClicked.emit(this.referenceInfo);
?.docLinkClicked.emit(this.referenceInfo$.peek());
};

refreshData = () => {
Expand All @@ -194,6 +216,16 @@ export class EmbedLinkedDocBlockComponent extends EmbedBlockComponent<EmbedLinke
});
};

title$ = computed(() => {
const { pageId, params, title } = this.referenceInfo$.value;
return (
title ??
this.std
.getOptional(DocDisplayMetaProvider)
?.title(pageId, { params, title, referenced: true })
);
});

get config(): EmbedLinkedDocBlockConfig {
return (
this.std.provider.getOptional(EmbedLinkedDocBlockConfigIdentifier) || {}
Expand All @@ -212,13 +244,13 @@ export class EmbedLinkedDocBlockComponent extends EmbedBlockComponent<EmbedLinke
return this.std.collection.getDoc(this.model.pageId);
}

get referenceInfo(): ReferenceInfo {
return cloneReferenceInfo(this.model);
}

private _handleDoubleClick(event: MouseEvent) {
if (this.config.handleDoubleClick) {
this.config.handleDoubleClick(event, this.host, this.referenceInfo);
this.config.handleDoubleClick(
event,
this.host,
this.referenceInfo$.peek()
);
if (event.defaultPrevented) {
return;
}
Expand All @@ -241,7 +273,7 @@ export class EmbedLinkedDocBlockComponent extends EmbedBlockComponent<EmbedLinke

protected _handleClick(event: MouseEvent) {
if (this.config.handleClick) {
this.config.handleClick(event, this.host, this.referenceInfo);
this.config.handleClick(event, this.host, this.referenceInfo$.peek());
if (event.defaultPrevented) {
return;
}
Expand Down Expand Up @@ -358,36 +390,19 @@ export class EmbedLinkedDocBlockComponent extends EmbedBlockComponent<EmbedLinke
const {
LoadingIcon,
ReloadIcon,
LinkedDocIcon,
LinkedDocDeletedIcon,
LinkedDocDeletedBanner,
LinkedDocEmptyBanner,
SyncedDocErrorBanner,
} = getEmbedLinkedDocIcons(theme, this._linkedDocMode, this._cardStyle);

const titleIcon = isError
const icon = isError
? SyncedDocErrorIcon
: isLoading
? LoadingIcon
: isDeleted
? LinkedDocDeletedIcon
: this.model.title
? AliasIcon({ width: '16px', height: '16pc' })
: this._referenceToNode
? BlockLinkIcon
: LinkedDocIcon;

const title = this.docTitle;
: this.icon$.value;
const title = isLoading ? 'Loading...' : this.title$.value;
const description = this.model.description;

const titleText = isError
? title
: isLoading
? 'Loading...'
: isDeleted
? `Deleted doc`
: title;

const showDefaultNoteContent = isError || isLoading || isDeleted || isEmpty;
const defaultNoteContent = isError
? 'This linked doc failed to load.'
Expand Down Expand Up @@ -430,11 +445,11 @@ export class EmbedLinkedDocBlockComponent extends EmbedBlockComponent<EmbedLinke
<div class="affine-embed-linked-doc-content">
<div class="affine-embed-linked-doc-content-title">
<div class="affine-embed-linked-doc-content-title-icon">
${titleIcon}
${icon}
</div>
<div class="affine-embed-linked-doc-content-title-text">
${titleText}
${title}
</div>
</div>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -139,30 +139,19 @@ export class EmbedSyncedDocCard extends WithDisposable(ShadowlessElement) {
const theme = this.std.get(ThemeProvider).theme;
const {
LoadingIcon,
SyncedDocIcon,
SyncedDocErrorIcon,
SyncedDocDeletedIcon,
ReloadIcon,
SyncedDocEmptyBanner,
SyncedDocErrorBanner,
SyncedDocDeletedBanner,
} = getSyncedDocIcons(theme, this.editorMode);

const titleIcon = error
const icon = error
? SyncedDocErrorIcon
: isLoading
? LoadingIcon
: isDeleted
? SyncedDocDeletedIcon
: SyncedDocIcon;

const titleText = error
? this.block.docTitle
: isLoading
? 'Loading...'
: isDeleted
? `Deleted doc`
: this.block.docTitle;
: this.block.icon$.value;
const title = isLoading ? 'Loading...' : this.block.title$.value;

const showDefaultNoteContent = isLoading || error || isDeleted || isEmpty;
const defaultNoteContent = error
Expand Down Expand Up @@ -195,11 +184,11 @@ export class EmbedSyncedDocCard extends WithDisposable(ShadowlessElement) {
<div class="affine-embed-synced-doc-card-content">
<div class="affine-embed-synced-doc-card-content-title">
<div class="affine-embed-synced-doc-card-content-title-icon">
${titleIcon}
${icon}
</div>
<div class="affine-embed-synced-doc-card-content-title-text">
${titleText}
${title}
</div>
</div>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,6 @@ import {
} from '@blocksuite/affine-components/icons';
import { Peekable } from '@blocksuite/affine-components/peek';
import {
cloneReferenceInfo,
REFERENCE_NODE,
RefNodeSlotsProvider,
} from '@blocksuite/affine-components/rich-text';
Expand All @@ -16,11 +15,15 @@ import {
type ReferenceInfo,
} from '@blocksuite/affine-model';
import {
DocDisplayMetaProvider,
DocModeProvider,
ThemeExtensionIdentifier,
ThemeProvider,
} from '@blocksuite/affine-shared/services';
import { SpecProvider } from '@blocksuite/affine-shared/utils';
import {
cloneReferenceInfo,
SpecProvider,
} from '@blocksuite/affine-shared/utils';
import {
BlockServiceWatcher,
BlockStdScope,
Expand All @@ -34,6 +37,7 @@ import {
type GetDocOptions,
type Query,
} from '@blocksuite/store';
import { computed } from '@preact/signals-core';
import { html, type PropertyValues } from 'lit';
import { query, state } from 'lit/decorators.js';
import { choose } from 'lit/directives/choose.js';
Expand Down Expand Up @@ -303,6 +307,13 @@ export class EmbedSyncedDocBlockComponent extends EmbedBlockComponent<EmbedSynce
height: 'unset',
};

icon$ = computed(() => {
const { pageId, params } = this.model;
return this.std
.getOptional(DocDisplayMetaProvider)
?.icon(pageId, { params, referenced: true }).value;
});

open = () => {
const pageId = this.model.pageId;
if (pageId === this.doc.id) return;
Expand All @@ -317,6 +328,13 @@ export class EmbedSyncedDocBlockComponent extends EmbedBlockComponent<EmbedSynce
});
};

title$ = computed(() => {
const { pageId, params } = this.model;
return this.std
.getOptional(DocDisplayMetaProvider)
?.title(pageId, { params, referenced: true });
});

private get _rootService() {
return this.std.getService('affine:page');
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -121,15 +121,6 @@ export const ReferenceInlineSpecExtension = InlineSpecExtension(
const std = provider.get(StdIdentifier);
const configProvider = new ReferenceNodeConfigProvider(std);
const config = provider.getOptional(ReferenceNodeConfigIdentifier) ?? {};
if (config.customContent) {
configProvider.setCustomContent(config.customContent);
}
if (config.customIcon) {
configProvider.setCustomIcon(config.customIcon);
}
if (config.customTitle) {
configProvider.setCustomTitle(config.customTitle);
}
if (config.interactable !== undefined) {
configProvider.setInteractable(config.interactable);
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,8 +4,3 @@ export * from './reference-node/reference-config.js';

export { AffineReference } from './reference-node/reference-node.js';
export type { RefNodeSlots } from './reference-node/types.js';
export {
cloneReferenceInfo,
cloneReferenceInfoWithoutAliases,
referenceToNode,
} from './reference-node/utils.js';
Loading

0 comments on commit 1587f1a

Please sign in to comment.