Research
Security News
Kill Switch Hidden in npm Packages Typosquatting Chalk and Chokidar
Socket researchers found several malicious npm packages typosquatting Chalk and Chokidar, targeting Node.js developers with kill switches and data theft.
braft-extensions
Advanced tools
npm install braft-extensions --save
# 或者
yarn add braft-extensions
需要分别import本模块包下面的各个模块,参见下方各模块的基本使用介绍
如果在使用扩展模块时,指定了includeEditors或excludeEditors属性,则通过BraftEditor.createEditorState创建初始化内的时候,需要传入一个editorId属性来指明创建的editorState是给哪个BraftEditor组件用的:
// 以使用表格扩展为例
BraftEditor.use(Table({
includeEditors: ['editor-1']
}))
// 使用BraftEditor.createEditorState创建编辑器数据
const initialValue = BraftEditor.createEditorState('xxxxxx', { editorId: 'editor-1' })
// 将数据传入编辑器
<BraftEditor value={initialValue} id="editor-1"/>
支持添加/删除行列、合并/拆分单元格等基本操作
import 'braft-editor/dist/index.css'
import 'braft-extensions/dist/table.css'
import BraftEditor from 'braft-editor'
import Table from 'braft-extensions/dist/table'
const options = {
defaultColumns: 3, // 默认列数
defaultRows: 3, // 默认行数
withDropdown: false, // 插入表格前是否弹出下拉菜单
columnResizable: false, // 是否允许拖动调整列宽,默认false
exportAttrString: '', // 指定输出HTML时附加到table标签上的属性字符串
includeEditors: ['editor-id-1'], // 指定该模块对哪些BraftEditor生效,不传此属性则对所有BraftEditor有效
excludeEditors: ['editor-id-2'] // 指定该模块对哪些BraftEditor无效
}
BraftEditor.use(Table(options))
exportAttrString
为'border="1" style="border-collapse: collapse"'
即可移植自draft-js-markdown-shortcuts-plugin,可以在编辑器中使用markdown语法快捷输入内容
import 'braft-editor/dist/index.css'
import BraftEditor from 'braft-editor'
import Markdown from 'braft-extensions/dist/markdown'
const options = {
includeEditors: ['editor-id-1'], // 指定该模块对哪些BraftEditor生效,不传此属性则对所有BraftEditor有效
excludeEditors: ['editor-id-2'] // 指定该模块对哪些BraftEditor无效
}
BraftEditor.use(Markdown(options))
使用prismjs和draft-js-prism开发的一个代码高亮模块,能在编辑器中实现代码高亮编辑功能,内置html、js和css语言支持,可扩展更多语言,在线演示
npm install prismjs draft-js-prism --save
# 或者
yarn add prismjs draft-js-prism
import 'braft-editor/dist/index.css'
import 'braft-extensions/dist/code-highlighter.css'
import BraftEditor from 'braft-editor'
import CodeHighlighter from 'braft-extensions/dist/code-highlighter'
const options = {
includeEditors: ['editor-id-1'], // 指定该模块对哪些BraftEditor生效,不传此属性则对所有BraftEditor有效
excludeEditors: ['editor-id-2'] // 指定该模块对哪些BraftEditor无效
}
BraftEditor.use(CodeHighlighter(options))
请访问PrismJs官网查看全部支持的语言
// 首先需要从prismjs中引入需要扩展的语言库
import 'prismjs/components/prism-java'
import 'prismjs/components/prism-php'
// 通过opitons.
const options = {
syntaxs: [
{
name: 'JavaScript',
syntax: 'javascript'
}, {
name: 'HTML',
syntax: 'html'
}, {
name: 'CSS',
syntax: 'css'
}, {
name: 'Java',
syntax: 'java',
}, {
name: 'PHP',
syntax: 'php'
}
]
}
BraftEditor.use(CodeHighlighter(options))
该功能将在后续版本中支持
使用react-color来替换编辑器自身的颜色选择模块,设置颜色更自由!在线演示
npm install react-color --save
# 或者
yarn add react-color
import 'braft-editor/dist/index.css'
import 'braft-extensions/dist/color-picker.css'
import BraftEditor from 'braft-editor'
import ColorPicker from 'braft-extensions/dist/color-picker'
const options = {
includeEditors: ['editor-id-1'], // 指定该模块对哪些BraftEditor生效,不传此属性则对所有BraftEditor有效
excludeEditors: ['editor-id-2'], // 指定该模块对哪些BraftEditor无效
theme: 'light', // 指定取色器样式主题,支持dark和light两种样式
}
BraftEditor.use(ColorPicker(options))
替换内置的emoji组件,可以插入图片形式的表情,在线演示
import 'braft-editor/dist/index.css'
import BraftEditor from 'braft-editor'
// 引入表情包扩展模块样式文件
import 'braft-extensions/dist/emoticon.css'
// 引入表情包扩展模块和默认表情包列表
import Emoticon, { defaultEmoticons } from 'braft-extensions/dist/emoticon'
// 转换默认表情包列表,让webpack可以正确加载到默认表情包中的图片,请确保已对png格式的文件配置了loader
// 如果你使用的webpack版本不支持动态require,或者使用的其他打包工具,请勿使用此写法
const emoticons = defaultEmoticons.map(item => require(`braft-extensions/dist/assets/${item}`))
// 也可以使用自己的表情包资源,不受打包工具限制
// const emoticons = ['http://path/to/emoticon-1.png', 'http://path/to/emoticon-2.png', 'http://path/to/emoticon-3.png', 'http://path/to/emoticon-4.png', ...]
const options = {
includeEditors: ['editor-id-1'], // 指定该模块对哪些BraftEditor生效,不传此属性则对所有BraftEditor有效
excludeEditors: ['editor-id-2'], // 指定该模块对哪些BraftEditor无效
emoticons: emoticons, // 指定可用表情图片列表,默认为空
closeOnBlur: false, // 指定是否在点击表情选择器之外的地方时关闭表情选择器,默认false
closeOnSelect: false // 指定是否在选择表情后关闭表情选择器,默认false
}
BraftEditor.use(Emoticon(options))
为编辑器增加mention(提及)功能
import 'braft-editor/dist/index.css'
import BraftEditor from 'braft-editor'
// 引入Mention扩展模块
import Mention, { defaultSuggestionsFilter } from 'braft-extensions/dist/mention'
// 取出Mention扩展和Mention列表组件
const [mentionExtension, MentionSuggestions] = Mention()
// 使用扩展
BraftEditor.use(mentionExtension)
class MentionDemo extends React.Component {
state = {
editorState: BraftEditor.createEditorState(),
// 在state中维护一个mention列表(这个数据可以从外部获取)
mentions: [
{
id: 'Matthew Russell',
name: 'Matthew Russell',
link: 'https://twitter.com/mrussell247',
avatar: 'https://pbs.twimg.com/profile_images/517863945/mattsailing_400x400.jpg'
},
{
id: 'Julian Krispel-Samsel',
name: 'Julian Krispel-Samsel',
link: 'https://twitter.com/juliandoesstuff',
avatar: 'https://avatars2.githubusercontent.com/u/1188186?v=3&s=400'
},
{
id: 'Jyoti Puri',
name: 'Jyoti Puri',
link: 'https://twitter.com/jyopur',
avatar: 'https://avatars0.githubusercontent.com/u/2182307?v=3&s=400'
},
{
id: 'Max Stoiber',
name: 'Max Stoiber',
link: 'https://twitter.com/mxstbr',
avatar: 'https://pbs.twimg.com/profile_images/763033229993574400/6frGyDyA_400x400.jpg'
}
],
// 再维护一个mention列表搜索关键字
mentionKeyword: null
}
// 定义mention列表的搜索处理函数
handleMentionFilter = ({ value: mentionKeyword }) => {
this.setState({ mentionKeyword })
}
handleChange = (editorState) => {
this.setState({ editorState })
}
render () {
const { mentionKeyword, editorState, mentions } = this.state
return (
<div>
<BraftEditor value={editorState} onChange={this.handleChange} />
{/**MentionSuggestions组件需要单独渲染,并传入正确的属性**/}
<MentionSuggestions
onSearchChange={this.handleMentionFilter}
suggestions={defaultSuggestionsFilter(mentionKeyword, mentions)}
/>
</div>
)
}
}
为编辑器增加maxLength和onReachMaxLength属性,用于限制输入字数
import 'braft-editor/dist/index.css'
import BraftEditor from 'braft-editor'
import MaxLength from 'braft-extensions/dist/max-length'
const options = {
defaultValue: 100, // 指定默认限制数,如不指定则为Infinity(无限)
includeEditors: ['editor-id-1'], // 指定该模块对哪些BraftEditor生效,不传此属性则对所有BraftEditor有效
excludeEditors: ['editor-id-2'], // 指定该模块对哪些BraftEditor无效
}
BraftEditor.use(MaxLength(options))
使用MaxLength扩展之后,可为编辑器组件传入maxLength和onReachMaxLength:
<BraftEditor maxLength={100} onReachMaxLength={() => console.log('不能再输入了!')} />
为标题区块(h1-h6)增加随机的id,便于在展示页支持锚点跳转功能
import 'braft-editor/dist/index.css'
import BraftEditor from 'braft-editor'
import HeaderId from 'braft-extensions/dist/header-id'
const options = {
includeEditors: ['editor-id-1'], // 指定该模块对哪些BraftEditor生效,不传此属性则对所有BraftEditor有效
excludeEditors: ['editor-id-2'], // 指定该模块对哪些BraftEditor无效
}
BraftEditor.use(HeaderId(options))
基于 draft-js-mention 实现的 Mention 功能
options
除了可以使用 includeEditors 和 excludeEditors 指定和排除 editor 外,其余的参数请参考 draft-js-mention 的参数配置
可参考 https://www.draft-js-plugins.com/plugin/mention
import Mention from 'braft-extensions/dist/mention'
interface MentionData {
link?: string;
avatar?: string;
name: string;
id?: null | string | number;
}
interface MentionSuggestionsPubProps {
suggestions: MentionData[];
open: boolean;
onOpenChange(open: boolean): void;
onSearchChange(event: { value: string }): void;
onAddMention(Mention: MentionData): void;
}
const options = {
includeEditors: ['editor-id-1'], // 指定该模块对哪些BraftEditor生效,不传此属性则对所有BraftEditor有效
excludeEditors: ['editor-id-2'], // 指定该模块对哪些BraftEditor无效
mentionTrigger: '@' // 可选参数。设置触发 mention 的符号,默认为 '@'
}
// Mention 方法返回一个二元祖
// 第一个是 braft-extension 所用插件数据
// 第二个是 控制 mention suggestions 的组件
// 类型为 React.ComponentType<MentionSuggestionsPubProps>
const [mentionExtension, MentionSuggestions] = Mention(options)
BraftEditor.use(mentionExtension)
const DemoEditor = (props) => {
// ... 省略
return (
<div>
<BraftEditor ... />
<MentionSuggestions ... />
</div>
)
}
FAQs
Extensions for Braft Editor
The npm package braft-extensions receives a total of 462 weekly downloads. As such, braft-extensions popularity was classified as not popular.
We found that braft-extensions demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Research
Security News
Socket researchers found several malicious npm packages typosquatting Chalk and Chokidar, targeting Node.js developers with kill switches and data theft.
Security News
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
Product
Socket now supports uv.lock files to ensure consistent, secure dependency resolution for Python projects and enhance supply chain security.