chore: track doc create action in bs editor (#6915)

fix TOV-855

added shape element create & doc create event tracking in blocksuite editor.
What's still missing:
the control (source) that triggered whiteboard element creation, i.e., from canvas dbclick, dnd or pasting.
This commit is contained in:
pengx17 2024-05-14 05:35:08 +00:00
parent 48de982a6b
commit dd45c80cc4
No known key found for this signature in database
GPG Key ID: 23F23D9E8B3971ED

View File

@ -1,12 +1,16 @@
import type { ElementOrFactory } from '@affine/component'; import type { ElementOrFactory } from '@affine/component';
import { mixpanel } from '@affine/core/utils';
import type { BlockSpec } from '@blocksuite/block-std'; import type { BlockSpec } from '@blocksuite/block-std';
import type { ParagraphService, RootService } from '@blocksuite/blocks'; import type { ParagraphService, RootService } from '@blocksuite/blocks';
import { import {
AffineLinkedDocWidget,
AffineSlashMenuWidget,
AttachmentService, AttachmentService,
CanvasTextFonts, CanvasTextFonts,
EdgelessRootService, EdgelessRootService,
PageRootService, PageRootService,
} from '@blocksuite/blocks'; } from '@blocksuite/blocks';
import type { BlockModel } from '@blocksuite/store';
import bytes from 'bytes'; import bytes from 'bytes';
import type { TemplateResult } from 'lit'; import type { TemplateResult } from 'lit';
@ -48,6 +52,37 @@ class CustomEdgelessPageService extends EdgelessRootService {
override loadFonts(): void { override loadFonts(): void {
customLoadFonts(this); customLoadFonts(this);
} }
override addElement<T = Record<string, unknown>>(type: string, props: T) {
const res = super.addElement(type, props);
mixpanel.track('WhiteboardObjectCreated', {
page: 'whiteboard editor',
module: 'whiteboard',
segment: 'canvas',
// control:
type: 'whiteboard object',
category: type,
});
return res;
}
override addBlock(
flavour: string,
props: Record<string, unknown>,
parent?: string | BlockModel,
parentIndex?: number
) {
const res = super.addBlock(flavour, props, parent, parentIndex);
mixpanel.track('WhiteboardObjectCreated', {
page: 'whiteboard editor',
module: 'whiteboard',
segment: 'canvas',
// control:
type: 'whiteboard object',
category: flavour.split(':')[1], // affine:paragraph -> paragraph
});
return res;
}
} }
type AffineReference = HTMLElementTagNameMap['affine-reference']; type AffineReference = HTMLElementTagNameMap['affine-reference'];
@ -85,6 +120,63 @@ function patchSpecsWithReferenceRenderer(
}); });
} }
function patchSlashMenuWidget() {
const menuGroup = AffineSlashMenuWidget.DEFAULT_OPTIONS.menus.find(group => {
return group.name === 'Docs';
});
if (Array.isArray(menuGroup?.items)) {
const newDocItem = menuGroup.items.find(item => {
return item.name === 'New Doc';
});
if (newDocItem) {
const oldAction = newDocItem.action;
newDocItem.action = async (...props) => {
await oldAction(...props);
mixpanel.track('DocCreated', {
segment: 'doc',
module: 'command menu',
control: 'new doc command',
type: 'doc',
category: 'doc',
});
};
}
}
}
function patchLinkedDocPopover() {
const oldGetMenus = AffineLinkedDocWidget.DEFAULT_OPTIONS.getMenus;
AffineLinkedDocWidget.DEFAULT_OPTIONS.getMenus = ctx => {
const menus = oldGetMenus(ctx);
const newDocGroup = menus.find(group => group.name === 'New Doc');
const newDocItem = newDocGroup?.items.find(item => item.key === 'create');
// todo: patch import doc/workspace action
// const importItem = newDocGroup?.items.find(item => item.key === 'import');
if (newDocItem) {
const oldAction = newDocItem.action;
newDocItem.action = async () => {
await oldAction();
mixpanel.track('DocCreated', {
segment: 'doc',
module: 'linked doc popover',
control: 'new doc command',
type: 'doc',
category: 'doc',
});
};
}
return menus;
};
}
patchSlashMenuWidget();
patchLinkedDocPopover();
/** /**
* Patch the block specs with custom renderers. * Patch the block specs with custom renderers.
*/ */