Files
uai-editor/src/components/menus/common/AlignDistributed.ts
2025-02-21 23:26:20 +08:00

88 lines
2.6 KiB
TypeScript

// Copyright (c) 2024-present AI-Labs
// @ ts-nocheck
import { EditorEvents } from "@tiptap/core";
import { t } from "i18next";
import { UAIEditorEventListener, UAIEditorOptions } from "../../../core/UAIEditor.ts";
import { MenuButton, MenuButtonOptions } from "../MenuButton.ts";
import icon from "../../../assets/icons/align-distributed.svg";
/**
* 公共菜单:分散对齐
*/
export class AlignDistributed extends HTMLElement implements UAIEditorEventListener {
// 按钮选项
menuButtonOptions: MenuButtonOptions = {
menuType: "button",
enable: true,
icon: icon,
hideText: true,
text: t('base.align.distributed'),
tooltip: t('base.align.distributed'),
shortcut: "Ctrl+Shift+D",
}
// 功能按钮
menuButton: MenuButton;
constructor(options: MenuButtonOptions) {
super();
// 初始化功能按钮选项
this.menuButtonOptions = { ...this.menuButtonOptions, ...options };
// 创建功能按钮
this.menuButton = new MenuButton(this.menuButtonOptions);
}
/**
* 定义创建方法
* @param event
* @param options
*/
onCreate(event: EditorEvents["create"], options: UAIEditorOptions) {
this.menuButton.onCreate(event, options);
this.appendChild(this.menuButton);
// 定义按钮点击事件,内容分散对齐
this.addEventListener("click", () => {
if (this.menuButtonOptions.enable) {
event.editor.chain().focus().setTextAlign('distributed').run();
}
})
}
/**
* 定义Transaction监听方法
* @param event
* @param options
*/
onTransaction(event: EditorEvents["transaction"], options: UAIEditorOptions) {
this.menuButton.onTransaction(event, options);
if (this.menuButton.menuButton) {
var disable = event.editor.can().chain().focus().setTextAlign('distributed').run();
this.onEditableChange(disable);
if (this.menuButtonOptions.enable) {
// 如果所选内容是分散对齐的,分散对齐按钮成激活状态,否则是非激活状态
var active = event.editor.isActive({ textAlign: 'distributed' });
if (active) {
this.menuButton.menuButton.classList.add("active");
} else {
this.menuButton.menuButton.classList.remove("active");
}
}
}
}
onEditableChange(editable: boolean) {
this.menuButtonOptions.enable = editable;
this.menuButton.onEditableChange(editable);
}
}