@ctoweb/plugin-mark-range
TypeScript icon, indicating that this package has built-in type declarations

3.5.3 • Public • Published

@ctoweb/plugin-mark-range

光标区域标记插件

可用来配合开发类似于批注、划线评论

安装

$ yarn add @ctoweb/plugin-mark-range

添加到引擎

import Engine, { EngineInterface } from '@ctoweb/engine';
import MarkRange from '@ctoweb/plugin-mark-range';

new Engine(...,{ plugins:[MarkRange] })

可选项

//使用配置
new Engine(...,{
    config:{
        "mark-range":{
            //修改快捷键
            hotkey:...,
            //其它可选项
            ...
        }
    }
 })

标记类型集合

必须为标记插件指定至少一个类型。如果有多种标记可指定多个类型

keys: Array<string>

//例如评论 keys = ["comment"]

快捷键

默认无快捷键

//快捷键,key 组合键,args,执行参数,[mode?: string, value?: string] 语言模式:可选,代码文本:可选
hotkey?:string | {key:string,args:Array<string>};//默认无

插件方法

所有命令都需要指定在可选项中 keys 中传入的指定 key

engine.command.executeMethod('mark-range', 'action', '标记key');

预览

对一个标记或当前做在光标位置进行效果预览

如果不传入编辑 id 参数,那么就对当前光标所选进行效果预览

此操作不会参与协同同步

此操作不会产生历史记录,无法做 撤销 和 重做 操作

光标改变时,将自动取消当前预览效果

如果是对光标进行效果预览,命令将返回光标选中区域的所有文本拼接。卡片将使用 [card:卡片名称,卡片编号] 这种格式拼接,需要转换则要自行处理

engine.command.executeMethod('mark-range', 'action', key: string, 'preview', id?:string): string | undefined;

将预览效果应用到编辑器

将预览效果应用到编辑器,并同步到协同服务器

此操作不会产生历史记录,无法做 撤销 和 重做 操作

必须传入一个标记编号,可以是字符串。编号相对于 key 应是唯一的

engine.command.executeMethod('mark-range', 'action', key: string, 'apply', id:string);

取消预览效果

如果不传入标记编号,则取消所有的当前正在进行的预览项

engine.command.executeMethod('mark-range', 'action', key: string, 'revoke', id?:string);

查找节点

根据标记编号找出其在编辑器中所有相对应的 dom 节点对象

engine.command.executeMethod('mark-range', 'action', key: string, 'find', id: string): Array<NodeInterface>;

移除标记效果

移除指定标记编号的标记效果

此操作不会产生历史记录,无法做 撤销 和 重做 操作

engine.command.executeMethod('mark-range', 'action', key: string, 'remove', id: string)

过滤标记

对编辑器值中的所有标记过滤,并返回过滤后的值和所有标记的编号和对应路径

value 默认获取当前编辑器根节点中的 html 作为值

在我们需要将标记和编辑器值分开存储或有条件展现标记时很有用

engine.command.executeMethod('mark-range', 'action', key: string, 'filter', value?: string): { value: string, paths: Array<{ id: Array<string>, path: Array<Path>}>}

还原标记

使用标记路径和过滤后的编辑器值进行标记还原

value 默认获取当前编辑器根节点中的 html 作为值

engine.command.executeMethod('mark-range', 'action', key: string, 'wrap', paths: Array<{ id: Array<string>, path: Array<Path>}>, value?: string): string

事件

标记节点改变回调

在协同编辑时,其它作者添加标记后,或者在编辑、删除一些节点中包含标记节点时都会触发此回调

在使用 撤销、重做 相关操作时,也会触发此回调

addIds: 新增的标记节点编号集合

removeIds: 删除的标记节点编号集合

ids: 所有有效的标记节点编号集合

engine.on('mark-range:change', (addIds: { [key: string]: Array<string>},removeIds: { [key: string]: Array<string>},ids: { [key:string] : Array<string> }) => {
	...
})

选中标记节时点回调

在光标改变时触发,selectInfo 有值的情况下将携带光标所在最近,如果是嵌套关系,那么就返回最里层的标记编号

engine.on('mark-range:select', (range: RangeInterface, selectInfo?: { key: string, id: string}) => {
	...
})

样式定义

/** 编辑器中标记样式 -comment- 中的 comment 都是代指标记中配置的 key ---- 开始 **/
[data-comment-preview],
[data-comment-id] {
	position: relative;
}

span[data-comment-preview],
span[data-comment-id] {
	display: inline-block;
}

[data-comment-preview]::before,
[data-comment-id]::before {
	content: '';
	position: absolute;
	width: 100%;
	bottom: 0px;
	left: 0;
	height: 2px;
	border-bottom: 2px solid #f8e1a1 !important;
}

[data-comment-preview] {
	background: rgb(250, 241, 209) !important;
}

[data-card-key][data-comment-id]::before,
[data-card-key][data-comment-preview]::before {
	bottom: -2px;
}
/** 编辑器中标记样式 ---- 结束 **/

Readme

Keywords

none

Package Sidebar

Install

npm i @ctoweb/plugin-mark-range

Weekly Downloads

2

Version

3.5.3

License

MIT

Unpacked Size

105 kB

Total Files

6

Last publish

Collaborators

  • ctoweb