初始化
This commit is contained in:
commit
e68d52a92c
|
@ -0,0 +1,22 @@
|
||||||
|
# 告诉EditorConfig插件,这是根文件,不用继续往上查找
|
||||||
|
root = true
|
||||||
|
|
||||||
|
# 匹配全部文件
|
||||||
|
[*]
|
||||||
|
# 设置字符集
|
||||||
|
charset = utf-8
|
||||||
|
# 缩进风格,可选space、tab
|
||||||
|
indent_style = space
|
||||||
|
# 缩进的空格数
|
||||||
|
indent_size = 2
|
||||||
|
# 结尾换行符,可选lf、cr、crlf
|
||||||
|
end_of_line = lf
|
||||||
|
# 在文件结尾插入新行
|
||||||
|
insert_final_newline = true
|
||||||
|
# 删除一行中的前后空格
|
||||||
|
trim_trailing_whitespace = true
|
||||||
|
|
||||||
|
# 匹配md结尾的文件
|
||||||
|
[*.md]
|
||||||
|
insert_final_newline = false
|
||||||
|
trim_trailing_whitespace = false
|
|
@ -0,0 +1,11 @@
|
||||||
|
# 页面标题
|
||||||
|
VUE_APP_TITLE = 大妈集市商户端
|
||||||
|
|
||||||
|
# 开发环境配置
|
||||||
|
ENV = 'development'
|
||||||
|
|
||||||
|
# 大妈集市商户端/开发环境
|
||||||
|
VUE_APP_BASE_API = '/dev-api'
|
||||||
|
|
||||||
|
# 路由懒加载
|
||||||
|
VUE_CLI_BABEL_TRANSPILE_MODULES = true
|
|
@ -0,0 +1,8 @@
|
||||||
|
# 页面标题
|
||||||
|
VUE_APP_TITLE = 大妈集市商户端
|
||||||
|
|
||||||
|
# 生产环境配置
|
||||||
|
ENV = 'production'
|
||||||
|
|
||||||
|
# 大妈集市商户端/生产环境
|
||||||
|
VUE_APP_BASE_API = '/prod-api'
|
|
@ -0,0 +1,10 @@
|
||||||
|
# 页面标题
|
||||||
|
VUE_APP_TITLE = 大妈集市商户端
|
||||||
|
|
||||||
|
NODE_ENV = production
|
||||||
|
|
||||||
|
# 测试环境配置
|
||||||
|
ENV = 'staging'
|
||||||
|
|
||||||
|
# 大妈集市商户端/测试环境
|
||||||
|
VUE_APP_BASE_API = '/stage-api'
|
|
@ -0,0 +1,10 @@
|
||||||
|
# 忽略build目录下类型为js的文件的语法检查
|
||||||
|
build/*.js
|
||||||
|
# 忽略src/assets目录下文件的语法检查
|
||||||
|
src/assets
|
||||||
|
# 忽略public目录下文件的语法检查
|
||||||
|
public
|
||||||
|
# 忽略当前目录下为js的文件的语法检查
|
||||||
|
*.js
|
||||||
|
# 忽略当前目录下为vue的文件的语法检查
|
||||||
|
*.vue
|
|
@ -0,0 +1,199 @@
|
||||||
|
// ESlint 检查配置
|
||||||
|
module.exports = {
|
||||||
|
root: true,
|
||||||
|
parserOptions: {
|
||||||
|
parser: 'babel-eslint',
|
||||||
|
sourceType: 'module'
|
||||||
|
},
|
||||||
|
env: {
|
||||||
|
browser: true,
|
||||||
|
node: true,
|
||||||
|
es6: true,
|
||||||
|
},
|
||||||
|
extends: ['plugin:vue/recommended', 'eslint:recommended'],
|
||||||
|
|
||||||
|
// add your custom rules here
|
||||||
|
//it is base on https://github.com/vuejs/eslint-config-vue
|
||||||
|
rules: {
|
||||||
|
"vue/max-attributes-per-line": [2, {
|
||||||
|
"singleline": 10,
|
||||||
|
"multiline": {
|
||||||
|
"max": 1,
|
||||||
|
"allowFirstLine": false
|
||||||
|
}
|
||||||
|
}],
|
||||||
|
"vue/singleline-html-element-content-newline": "off",
|
||||||
|
"vue/multiline-html-element-content-newline":"off",
|
||||||
|
"vue/name-property-casing": ["error", "PascalCase"],
|
||||||
|
"vue/no-v-html": "off",
|
||||||
|
'accessor-pairs': 2,
|
||||||
|
'arrow-spacing': [2, {
|
||||||
|
'before': true,
|
||||||
|
'after': true
|
||||||
|
}],
|
||||||
|
'block-spacing': [2, 'always'],
|
||||||
|
'brace-style': [2, '1tbs', {
|
||||||
|
'allowSingleLine': true
|
||||||
|
}],
|
||||||
|
'camelcase': [0, {
|
||||||
|
'properties': 'always'
|
||||||
|
}],
|
||||||
|
'comma-dangle': [2, 'never'],
|
||||||
|
'comma-spacing': [2, {
|
||||||
|
'before': false,
|
||||||
|
'after': true
|
||||||
|
}],
|
||||||
|
'comma-style': [2, 'last'],
|
||||||
|
'constructor-super': 2,
|
||||||
|
'curly': [2, 'multi-line'],
|
||||||
|
'dot-location': [2, 'property'],
|
||||||
|
'eol-last': 2,
|
||||||
|
'eqeqeq': ["error", "always", {"null": "ignore"}],
|
||||||
|
'generator-star-spacing': [2, {
|
||||||
|
'before': true,
|
||||||
|
'after': true
|
||||||
|
}],
|
||||||
|
'handle-callback-err': [2, '^(err|error)$'],
|
||||||
|
'indent': [2, 2, {
|
||||||
|
'SwitchCase': 1
|
||||||
|
}],
|
||||||
|
'jsx-quotes': [2, 'prefer-single'],
|
||||||
|
'key-spacing': [2, {
|
||||||
|
'beforeColon': false,
|
||||||
|
'afterColon': true
|
||||||
|
}],
|
||||||
|
'keyword-spacing': [2, {
|
||||||
|
'before': true,
|
||||||
|
'after': true
|
||||||
|
}],
|
||||||
|
'new-cap': [2, {
|
||||||
|
'newIsCap': true,
|
||||||
|
'capIsNew': false
|
||||||
|
}],
|
||||||
|
'new-parens': 2,
|
||||||
|
'no-array-constructor': 2,
|
||||||
|
'no-caller': 2,
|
||||||
|
'no-console': 'off',
|
||||||
|
'no-class-assign': 2,
|
||||||
|
'no-cond-assign': 2,
|
||||||
|
'no-const-assign': 2,
|
||||||
|
'no-control-regex': 0,
|
||||||
|
'no-delete-var': 2,
|
||||||
|
'no-dupe-args': 2,
|
||||||
|
'no-dupe-class-members': 2,
|
||||||
|
'no-dupe-keys': 2,
|
||||||
|
'no-duplicate-case': 2,
|
||||||
|
'no-empty-character-class': 2,
|
||||||
|
'no-empty-pattern': 2,
|
||||||
|
'no-eval': 2,
|
||||||
|
'no-ex-assign': 2,
|
||||||
|
'no-extend-native': 2,
|
||||||
|
'no-extra-bind': 2,
|
||||||
|
'no-extra-boolean-cast': 2,
|
||||||
|
'no-extra-parens': [2, 'functions'],
|
||||||
|
'no-fallthrough': 2,
|
||||||
|
'no-floating-decimal': 2,
|
||||||
|
'no-func-assign': 2,
|
||||||
|
'no-implied-eval': 2,
|
||||||
|
'no-inner-declarations': [2, 'functions'],
|
||||||
|
'no-invalid-regexp': 2,
|
||||||
|
'no-irregular-whitespace': 2,
|
||||||
|
'no-iterator': 2,
|
||||||
|
'no-label-var': 2,
|
||||||
|
'no-labels': [2, {
|
||||||
|
'allowLoop': false,
|
||||||
|
'allowSwitch': false
|
||||||
|
}],
|
||||||
|
'no-lone-blocks': 2,
|
||||||
|
'no-mixed-spaces-and-tabs': 2,
|
||||||
|
'no-multi-spaces': 2,
|
||||||
|
'no-multi-str': 2,
|
||||||
|
'no-multiple-empty-lines': [2, {
|
||||||
|
'max': 1
|
||||||
|
}],
|
||||||
|
'no-native-reassign': 2,
|
||||||
|
'no-negated-in-lhs': 2,
|
||||||
|
'no-new-object': 2,
|
||||||
|
'no-new-require': 2,
|
||||||
|
'no-new-symbol': 2,
|
||||||
|
'no-new-wrappers': 2,
|
||||||
|
'no-obj-calls': 2,
|
||||||
|
'no-octal': 2,
|
||||||
|
'no-octal-escape': 2,
|
||||||
|
'no-path-concat': 2,
|
||||||
|
'no-proto': 2,
|
||||||
|
'no-redeclare': 2,
|
||||||
|
'no-regex-spaces': 2,
|
||||||
|
'no-return-assign': [2, 'except-parens'],
|
||||||
|
'no-self-assign': 2,
|
||||||
|
'no-self-compare': 2,
|
||||||
|
'no-sequences': 2,
|
||||||
|
'no-shadow-restricted-names': 2,
|
||||||
|
'no-spaced-func': 2,
|
||||||
|
'no-sparse-arrays': 2,
|
||||||
|
'no-this-before-super': 2,
|
||||||
|
'no-throw-literal': 2,
|
||||||
|
'no-trailing-spaces': 2,
|
||||||
|
'no-undef': 2,
|
||||||
|
'no-undef-init': 2,
|
||||||
|
'no-unexpected-multiline': 2,
|
||||||
|
'no-unmodified-loop-condition': 2,
|
||||||
|
'no-unneeded-ternary': [2, {
|
||||||
|
'defaultAssignment': false
|
||||||
|
}],
|
||||||
|
'no-unreachable': 2,
|
||||||
|
'no-unsafe-finally': 2,
|
||||||
|
'no-unused-vars': [2, {
|
||||||
|
'vars': 'all',
|
||||||
|
'args': 'none'
|
||||||
|
}],
|
||||||
|
'no-useless-call': 2,
|
||||||
|
'no-useless-computed-key': 2,
|
||||||
|
'no-useless-constructor': 2,
|
||||||
|
'no-useless-escape': 0,
|
||||||
|
'no-whitespace-before-property': 2,
|
||||||
|
'no-with': 2,
|
||||||
|
'one-var': [2, {
|
||||||
|
'initialized': 'never'
|
||||||
|
}],
|
||||||
|
'operator-linebreak': [2, 'after', {
|
||||||
|
'overrides': {
|
||||||
|
'?': 'before',
|
||||||
|
':': 'before'
|
||||||
|
}
|
||||||
|
}],
|
||||||
|
'padded-blocks': [2, 'never'],
|
||||||
|
'quotes': [2, 'single', {
|
||||||
|
'avoidEscape': true,
|
||||||
|
'allowTemplateLiterals': true
|
||||||
|
}],
|
||||||
|
'semi': [2, 'never'],
|
||||||
|
'semi-spacing': [2, {
|
||||||
|
'before': false,
|
||||||
|
'after': true
|
||||||
|
}],
|
||||||
|
'space-before-blocks': [2, 'always'],
|
||||||
|
'space-before-function-paren': [2, 'never'],
|
||||||
|
'space-in-parens': [2, 'never'],
|
||||||
|
'space-infix-ops': 2,
|
||||||
|
'space-unary-ops': [2, {
|
||||||
|
'words': true,
|
||||||
|
'nonwords': false
|
||||||
|
}],
|
||||||
|
'spaced-comment': [2, 'always', {
|
||||||
|
'markers': ['global', 'globals', 'eslint', 'eslint-disable', '*package', '!', ',']
|
||||||
|
}],
|
||||||
|
'template-curly-spacing': [2, 'never'],
|
||||||
|
'use-isnan': 2,
|
||||||
|
'valid-typeof': 2,
|
||||||
|
'wrap-iife': [2, 'any'],
|
||||||
|
'yield-star-spacing': [2, 'both'],
|
||||||
|
'yoda': [2, 'never'],
|
||||||
|
'prefer-const': 2,
|
||||||
|
'no-debugger': process.env.NODE_ENV === 'production' ? 2 : 0,
|
||||||
|
'object-curly-spacing': [2, 'always', {
|
||||||
|
objectsInObjects: false
|
||||||
|
}],
|
||||||
|
'array-bracket-spacing': [2, 'never']
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,23 @@
|
||||||
|
.DS_Store
|
||||||
|
node_modules/
|
||||||
|
dist/
|
||||||
|
npm-debug.log*
|
||||||
|
yarn-debug.log*
|
||||||
|
yarn-error.log*
|
||||||
|
**/*.log
|
||||||
|
|
||||||
|
tests/**/coverage/
|
||||||
|
tests/e2e/reports
|
||||||
|
selenium-debug.log
|
||||||
|
|
||||||
|
# Editor directories and files
|
||||||
|
.idea
|
||||||
|
.vscode
|
||||||
|
*.suo
|
||||||
|
*.ntvs*
|
||||||
|
*.njsproj
|
||||||
|
*.sln
|
||||||
|
*.local
|
||||||
|
|
||||||
|
package-lock.json
|
||||||
|
yarn.lock
|
|
@ -0,0 +1,216 @@
|
||||||
|
# 大妈集市商户端平台开发文档
|
||||||
|
|
||||||
|
## 项目简介
|
||||||
|
|
||||||
|
**项目名称**: 大妈集市商户端
|
||||||
|
|
||||||
|
**版本**: 2.0.0
|
||||||
|
|
||||||
|
**描述**: 大妈集市商户端
|
||||||
|
|
||||||
|
**作者**: objstudio
|
||||||
|
|
||||||
|
## 项目结构
|
||||||
|
|
||||||
|
### 主要目录
|
||||||
|
|
||||||
|
- `src/`: 源代码目录,包括所有 Vue 组件和相关资源。
|
||||||
|
- `build/`: 构建脚本和配置文件。
|
||||||
|
- `public/`: 静态资源目录。
|
||||||
|
- `node_modules/`: 项目依赖包目录。
|
||||||
|
|
||||||
|
### 关键文件
|
||||||
|
|
||||||
|
- `package.json`: 项目配置和依赖管理文件。
|
||||||
|
- `vue.config.js`: Vue CLI 配置文件。
|
||||||
|
- `babel.config.js`: Babel 配置文件。
|
||||||
|
- `.eslintrc.js`: ESLint 配置文件。
|
||||||
|
|
||||||
|
## 脚本命令
|
||||||
|
|
||||||
|
### 开发和构建
|
||||||
|
|
||||||
|
- `serve`: 启动开发服务器。
|
||||||
|
```sh
|
||||||
|
npm run serve
|
||||||
|
```
|
||||||
|
- `build:prod`: 进行生产环境构建。
|
||||||
|
```sh
|
||||||
|
npm run build:prod
|
||||||
|
```
|
||||||
|
- `build:stage`: 进行阶段环境构建。
|
||||||
|
```sh
|
||||||
|
npm run build:stage
|
||||||
|
```
|
||||||
|
|
||||||
|
### 代码检查和修复
|
||||||
|
|
||||||
|
- `lint`: 运行 ESLint 进行代码检查。
|
||||||
|
```sh
|
||||||
|
npm run lint
|
||||||
|
```
|
||||||
|
|
||||||
|
### 预览
|
||||||
|
|
||||||
|
- `preview`: 启动预览服务器。
|
||||||
|
```sh
|
||||||
|
npm run preview
|
||||||
|
```
|
||||||
|
|
||||||
|
## 代码质量控制
|
||||||
|
|
||||||
|
### Husky
|
||||||
|
|
||||||
|
配置了 `husky` 来管理 Git 钩子,保证代码在提交前经过检查。
|
||||||
|
|
||||||
|
- `pre-commit`: 在提交前运行 `lint-staged`。
|
||||||
|
|
||||||
|
### Lint-Staged
|
||||||
|
|
||||||
|
使用 `lint-staged` 在提交前自动修复和添加代码。
|
||||||
|
|
||||||
|
```json
|
||||||
|
"lint-staged": {
|
||||||
|
"src/**/*.{js,vue}": [
|
||||||
|
"eslint --fix",
|
||||||
|
"git add"
|
||||||
|
]
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
## 依赖管理
|
||||||
|
|
||||||
|
### 生产依赖
|
||||||
|
|
||||||
|
项目使用了多种前端依赖来实现不同的功能。以下是主要的生产依赖:
|
||||||
|
|
||||||
|
- `vue`: Vue.js 框架。
|
||||||
|
- `axios`: HTTP 请求库。
|
||||||
|
- `element-ui`: 组件库。
|
||||||
|
- `vue-router`: 路由管理。
|
||||||
|
- `vuex`: 状态管理。
|
||||||
|
- 其他库如 `dayjs`, `echarts`, `quill`, `xlsx` 等,用于日期处理、图表绘制、富文本编辑、Excel 文件处理等功能。
|
||||||
|
|
||||||
|
### 开发依赖
|
||||||
|
|
||||||
|
主要用于开发环境的工具和插件:
|
||||||
|
|
||||||
|
- `@vue/cli-plugin-babel`: Babel 插件。
|
||||||
|
- `@vue/cli-plugin-eslint`: ESLint 插件。
|
||||||
|
- `eslint`: 代码检查工具。
|
||||||
|
- `sass` 和 `sass-loader`: 用于处理 Sass 样式。
|
||||||
|
- `vue-loader`, `vue-template-compiler`: Vue 文件编译工具。
|
||||||
|
|
||||||
|
## 浏览器兼容性
|
||||||
|
|
||||||
|
项目设置了浏览器兼容性配置,以确保在主流浏览器上正常运行。
|
||||||
|
|
||||||
|
```json
|
||||||
|
"browserslist": [
|
||||||
|
"> 1%",
|
||||||
|
"last 2 versions"
|
||||||
|
]
|
||||||
|
```
|
||||||
|
|
||||||
|
## 运行环境
|
||||||
|
|
||||||
|
项目要求的 Node.js 和 npm 版本:
|
||||||
|
|
||||||
|
```json
|
||||||
|
"engines": {
|
||||||
|
"node": ">=8.9",
|
||||||
|
"npm": ">= 3.0.0"
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
## 版本控制
|
||||||
|
|
||||||
|
项目的代码托管在 Git 仓库中
|
||||||
|
|
||||||
|
## 关键词
|
||||||
|
|
||||||
|
为了方便搜索和分类,项目添加了以下关键词:
|
||||||
|
|
||||||
|
```json
|
||||||
|
"keywords": [
|
||||||
|
"vue",
|
||||||
|
"admin",
|
||||||
|
"dashboard",
|
||||||
|
"element-ui",
|
||||||
|
"boilerplate",
|
||||||
|
"admin-template",
|
||||||
|
"management-system"
|
||||||
|
]
|
||||||
|
```
|
||||||
|
|
||||||
|
确实,有一些依赖没有详细介绍。下面是对所有依赖项的详细说明。
|
||||||
|
|
||||||
|
### 生产依赖
|
||||||
|
|
||||||
|
- **@micro-zoe/micro-app**: 用于微前端架构的解决方案,支持在主应用中加载和运行多个子应用。
|
||||||
|
- **@riophae/vue-treeselect**: Vue 组件,用于实现树选择功能。
|
||||||
|
- **axios**: 用于处理 HTTP 请求。
|
||||||
|
- **clipboard**: 操作剪贴板的库。
|
||||||
|
- **compressorjs**: 用于图片压缩的 JavaScript 库。
|
||||||
|
- **core-js**: 提供 JavaScript 标准库的 polyfill。
|
||||||
|
- **crypto-js**: 提供加密算法的 JavaScript 库。
|
||||||
|
- **dayjs**: 轻量级的日期处理库。
|
||||||
|
- **echarts**: 强大的图表绘制库。
|
||||||
|
- **element-ui**: 基于 Vue 的组件库。
|
||||||
|
- **file-saver**: 用于保存文件的库。
|
||||||
|
- **fuse.js**: 轻量级的模糊搜索库。
|
||||||
|
- **highlight.js**: 用于代码高亮显示的库。
|
||||||
|
- **js-beautify**: 用于美化 JavaScript、HTML 和 CSS 代码的库。
|
||||||
|
- **js-cookie**: 用于操作 cookies 的简单 API。
|
||||||
|
- **jsencrypt**: 用于实现 RSA 加密解密的库。
|
||||||
|
- **mockjs**: 用于生成随机数据和拦截 Ajax 请求。
|
||||||
|
- **nprogress**: 轻量级的进度条库。
|
||||||
|
- **obj-table-plus**: 高度自定义的数据表格组件。
|
||||||
|
- **quill**: 强大的富文本编辑器。
|
||||||
|
- **screenfull**: 用于全屏操作的库。
|
||||||
|
- **signature_pad**: 用于签名绘制的库。
|
||||||
|
- **sortablejs**: 强大的拖拽排序库。
|
||||||
|
- **video.js**: 用于播放视频的库。
|
||||||
|
- **vue**: Vue.js 框架。
|
||||||
|
- **vue-amap**: Vue 组件,用于高德地图集成。
|
||||||
|
- **vue-cookie**: 用于操作 Vue 应用中的 cookies。
|
||||||
|
- **vue-count-to**: 用于实现数字滚动效果的 Vue 组件。
|
||||||
|
- **vue-cropper**: 用于图像裁剪的 Vue 组件。
|
||||||
|
- **vue-meta**: 用于管理 Vue 应用的 meta 信息。
|
||||||
|
- **vue-router**: Vue 的路由管理库。
|
||||||
|
- **vuedraggable**: 用于实现拖拽功能的 Vue 组件。
|
||||||
|
- **vuex**: Vue 的状态管理库。
|
||||||
|
- **vxe-table**: 高性能的 Vue 表格组件。
|
||||||
|
- **xe-utils**: 实用工具库,提供一系列实用函数。
|
||||||
|
- **xlsx**: 用于解析和编写 Excel 文件的库。
|
||||||
|
|
||||||
|
### 开发依赖
|
||||||
|
|
||||||
|
- **@vue/cli-plugin-babel**: Vue CLI 的 Babel 插件,用于编译 ES6+ 代码。
|
||||||
|
- **@vue/cli-plugin-eslint**: Vue CLI 的 ESLint 插件,用于代码检查。
|
||||||
|
- **@vue/cli-service**: Vue CLI 的核心服务,用于构建和开发。
|
||||||
|
- **autoprefixer**: 自动为 CSS 规则添加浏览器前缀的插件。
|
||||||
|
- **babel-eslint**: 用于解析 Babel 代码的 ESLint 解析器。
|
||||||
|
- **babel-plugin-dynamic-import-node**: 用于在 Node.js 中解析 `import()` 语法。
|
||||||
|
- **chalk**: 用于终端字符串样式的库。
|
||||||
|
- **compression-webpack-plugin**: 用于压缩资源文件的 Webpack 插件。
|
||||||
|
- **connect**: 用于创建服务器中间件的库。
|
||||||
|
- **eslint**: JavaScript 代码检查工具。
|
||||||
|
- **eslint-plugin-vue**: 用于检查 Vue 代码的 ESLint 插件。
|
||||||
|
- **lint-staged**: 在提交代码前检查暂存文件的工具。
|
||||||
|
- **postcss**: 用于转换 CSS 的工具。
|
||||||
|
- **runjs**: 用于运行 JavaScript 脚本的命令行工具。
|
||||||
|
- **sass**: 用于编译 Sass/SCSS 代码。
|
||||||
|
- **sass-loader**: 用于在 Webpack 中加载和编译 Sass/SCSS 代码。
|
||||||
|
- **script-ext-html-webpack-plugin**: 用于增强 HTML Webpack 插件功能的扩展插件。
|
||||||
|
- **svg-sprite-loader**: 用于将 SVG 图标打包成雪碧图的 Webpack 插件。
|
||||||
|
- **tailwindcss**: 一个功能类优先的 CSS 框架。
|
||||||
|
- **vue-loader**: 用于加载和编译 Vue 组件的 Webpack 插件。
|
||||||
|
- **vue-style-loader**: 用于处理 Vue 组件中的样式的 Webpack 插件。
|
||||||
|
- **vue-template-compiler**: 用于编译 Vue 模板的库。
|
||||||
|
|
||||||
|
通过上述详细说明,可以帮助开发者更好地理解项目的依赖项及其作用。
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
本开发文档旨在帮助开发者快速了解项目结构、依赖管理和主要脚本命令。通过上述信息,开发者可以更高效地进行开发和维护工作。
|
|
@ -0,0 +1,20 @@
|
||||||
|
module.exports = {
|
||||||
|
presets: [
|
||||||
|
// https://github.com/vuejs/vue-cli/tree/master/packages/@vue/babel-preset-app
|
||||||
|
'@vue/cli-plugin-babel/preset',
|
||||||
|
// JSX support for Vue
|
||||||
|
[
|
||||||
|
"@vue/babel-preset-jsx",
|
||||||
|
{
|
||||||
|
injectH: false
|
||||||
|
}
|
||||||
|
],
|
||||||
|
],
|
||||||
|
'env': {
|
||||||
|
'development': {
|
||||||
|
// babel-plugin-dynamic-import-node plugin only does one thing by converting all import() to require().
|
||||||
|
// This plugin can significantly increase the speed of hot updates, when you have a large number of pages.
|
||||||
|
'plugins': ['dynamic-import-node']
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,12 @@
|
||||||
|
@echo off
|
||||||
|
echo.
|
||||||
|
echo [信息] 打包Web工程,生成dist文件。
|
||||||
|
echo.
|
||||||
|
|
||||||
|
%~d0
|
||||||
|
cd %~dp0
|
||||||
|
|
||||||
|
cd ..
|
||||||
|
npm run build:prod
|
||||||
|
|
||||||
|
pause
|
|
@ -0,0 +1,12 @@
|
||||||
|
@echo off
|
||||||
|
echo.
|
||||||
|
echo [信息] 安装Web工程,生成node_modules文件。
|
||||||
|
echo.
|
||||||
|
|
||||||
|
%~d0
|
||||||
|
cd %~dp0
|
||||||
|
|
||||||
|
cd ..
|
||||||
|
npm install --registry=https://registry.npmmirror.com
|
||||||
|
|
||||||
|
pause
|
|
@ -0,0 +1,12 @@
|
||||||
|
@echo off
|
||||||
|
echo.
|
||||||
|
echo [信息] 使用 Vue CLI 命令运行 Web 工程。
|
||||||
|
echo.
|
||||||
|
|
||||||
|
%~d0
|
||||||
|
cd %~dp0
|
||||||
|
|
||||||
|
cd ..
|
||||||
|
npm run dev
|
||||||
|
|
||||||
|
pause
|
|
@ -0,0 +1,35 @@
|
||||||
|
const { run } = require('runjs')
|
||||||
|
const chalk = require('chalk')
|
||||||
|
const config = require('../vue.config.js')
|
||||||
|
const rawArgv = process.argv.slice(2)
|
||||||
|
const args = rawArgv.join(' ')
|
||||||
|
|
||||||
|
if (process.env.npm_config_preview || rawArgv.includes('--preview')) {
|
||||||
|
const report = rawArgv.includes('--report')
|
||||||
|
|
||||||
|
run(`vue-cli-service build ${args}`)
|
||||||
|
|
||||||
|
const port = 9526
|
||||||
|
const publicPath = config.publicPath
|
||||||
|
|
||||||
|
var connect = require('connect')
|
||||||
|
var serveStatic = require('serve-static')
|
||||||
|
const app = connect()
|
||||||
|
|
||||||
|
app.use(
|
||||||
|
publicPath,
|
||||||
|
serveStatic('./dist', {
|
||||||
|
index: ['index.html', '/']
|
||||||
|
})
|
||||||
|
)
|
||||||
|
|
||||||
|
app.listen(port, function () {
|
||||||
|
console.log(chalk.green(`> Preview at http://localhost:${port}${publicPath}`))
|
||||||
|
if (report) {
|
||||||
|
console.log(chalk.green(`> Report at http://localhost:${port}${publicPath}report.html`))
|
||||||
|
}
|
||||||
|
|
||||||
|
})
|
||||||
|
} else {
|
||||||
|
run(`vue-cli-service build ${args}`)
|
||||||
|
}
|
|
@ -0,0 +1,111 @@
|
||||||
|
{
|
||||||
|
"name": "huaxiaqiusuo",
|
||||||
|
"version": "0.1.0",
|
||||||
|
"description": "大妈集市商户端",
|
||||||
|
"author": "objstudio",
|
||||||
|
"license": "MIT",
|
||||||
|
"scripts": {
|
||||||
|
"serve": "vue-cli-service serve",
|
||||||
|
"build:prod": "vue-cli-service build",
|
||||||
|
"build:stage": "vue-cli-service build --mode staging",
|
||||||
|
"preview": "node build/index.js --preview",
|
||||||
|
"lint": "eslint --ext .js,.vue src"
|
||||||
|
},
|
||||||
|
"husky": {
|
||||||
|
"hooks": {
|
||||||
|
"pre-commit": "lint-staged"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"lint-staged": {
|
||||||
|
"src/**/*.{js,vue}": [
|
||||||
|
"eslint --fix",
|
||||||
|
"git add"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"keywords": [
|
||||||
|
"vue",
|
||||||
|
"admin",
|
||||||
|
"dashboard",
|
||||||
|
"element-ui",
|
||||||
|
"boilerplate",
|
||||||
|
"admin-template",
|
||||||
|
"management-system"
|
||||||
|
],
|
||||||
|
"repository": {
|
||||||
|
"type": "git",
|
||||||
|
"url": "https://gitee.com/y_project/RuoYi-Vue.git"
|
||||||
|
},
|
||||||
|
"dependencies": {
|
||||||
|
"@micro-zoe/micro-app": "^1.0.0-rc.5",
|
||||||
|
"@riophae/vue-treeselect": "0.4.0",
|
||||||
|
"axios": "0.24.0",
|
||||||
|
"clipboard": "2.0.8",
|
||||||
|
"compressorjs": "^1.1.1",
|
||||||
|
"core-js": "3.37.1",
|
||||||
|
"crypto-js": "^4.1.1",
|
||||||
|
"dayjs": "^1.10.7",
|
||||||
|
"echarts": "5.4.0",
|
||||||
|
"element-ui": "2.15.14",
|
||||||
|
"file-saver": "2.0.5",
|
||||||
|
"fuse.js": "6.4.3",
|
||||||
|
"highlight.js": "9.18.5",
|
||||||
|
"js-beautify": "1.13.0",
|
||||||
|
"js-cookie": "3.0.1",
|
||||||
|
"jsencrypt": "3.0.0-rc.1",
|
||||||
|
"mockjs": "^1.1.0",
|
||||||
|
"nprogress": "0.2.0",
|
||||||
|
"obj-modal": "^1.1.2",
|
||||||
|
"obj-table-plus": "^2.2.1",
|
||||||
|
"quill": "1.3.7",
|
||||||
|
"screenfull": "5.0.2",
|
||||||
|
"signature_pad": "^3.0.0-beta.4",
|
||||||
|
"sortablejs": "1.10.2",
|
||||||
|
"video.js": "^7.20.3",
|
||||||
|
"vue": "^2.7.16",
|
||||||
|
"vue-amap": "^0.5.10",
|
||||||
|
"vue-async-computed": "^4.0.1",
|
||||||
|
"vue-contextmenujs": "^1.4.11",
|
||||||
|
"vue-cookie": "1.1.4",
|
||||||
|
"vue-count-to": "1.0.13",
|
||||||
|
"vue-cropper": "0.5.5",
|
||||||
|
"vue-meta": "2.4.0",
|
||||||
|
"vue-router": "3.4.9",
|
||||||
|
"vuedraggable": "2.24.3",
|
||||||
|
"vuex": "3.6.0",
|
||||||
|
"vxe-table": "3.8.9",
|
||||||
|
"xe-utils": "^3.5.6",
|
||||||
|
"xlsx": "^0.17.4"
|
||||||
|
},
|
||||||
|
"devDependencies": {
|
||||||
|
"@vue/cli-plugin-babel": "4.4.6",
|
||||||
|
"@vue/cli-plugin-eslint": "4.4.6",
|
||||||
|
"@vue/cli-service": "4.4.6",
|
||||||
|
"autoprefixer": "^9.8.8",
|
||||||
|
"babel-eslint": "10.1.0",
|
||||||
|
"babel-plugin-dynamic-import-node": "2.3.3",
|
||||||
|
"chalk": "4.1.0",
|
||||||
|
"compression-webpack-plugin": "6.1.2",
|
||||||
|
"connect": "3.6.6",
|
||||||
|
"eslint": "7.15.0",
|
||||||
|
"eslint-plugin-vue": "7.2.0",
|
||||||
|
"lint-staged": "10.5.3",
|
||||||
|
"postcss": "^7.0.39",
|
||||||
|
"runjs": "4.4.2",
|
||||||
|
"sass": "1.32.13",
|
||||||
|
"sass-loader": "10.1.1",
|
||||||
|
"script-ext-html-webpack-plugin": "2.1.5",
|
||||||
|
"svg-sprite-loader": "5.1.1",
|
||||||
|
"tailwindcss": "npm:@tailwindcss/postcss7-compat@^2.2.17",
|
||||||
|
"vue-loader": "13.3.0",
|
||||||
|
"vue-style-loader": "3.0.1",
|
||||||
|
"vue-template-compiler": "^2.7.16"
|
||||||
|
},
|
||||||
|
"engines": {
|
||||||
|
"node": ">=8.9",
|
||||||
|
"npm": ">= 3.0.0"
|
||||||
|
},
|
||||||
|
"browserslist": [
|
||||||
|
"> 1%",
|
||||||
|
"last 2 versions"
|
||||||
|
]
|
||||||
|
}
|
|
@ -0,0 +1,6 @@
|
||||||
|
module.exports = {
|
||||||
|
plugins: {
|
||||||
|
tailwindcss: {},
|
||||||
|
autoprefixer: {},
|
||||||
|
},
|
||||||
|
}
|
|
@ -0,0 +1,25 @@
|
||||||
|
/*
|
||||||
|
* @Author: 陈伟亮 1186723967@qq.com
|
||||||
|
* @Date: 2022-01-15 14:49:20
|
||||||
|
* @LastEditors: 陈伟亮 1186723967@qq.com
|
||||||
|
* @LastEditTime: 2022-08-18 14:35:11
|
||||||
|
* @FilePath: \background-front-end\static\config\index-prod.js
|
||||||
|
* @Description: 这是默认设置,请设置`customMade`, 打开koroFileHeader查看配置 进行设置: https://github.com/OBKoro1/koro1FileHeader/wiki/%E9%85%8D%E7%BD%AE
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* 生产环境
|
||||||
|
*/
|
||||||
|
;(function () {
|
||||||
|
window.SITE_CONFIG = {};
|
||||||
|
|
||||||
|
// 在线api接口请求地址
|
||||||
|
window.SITE_CONFIG['baseUrl'] ="http://yr.dddd.zone:9001/"
|
||||||
|
window.SITE_CONFIG['baseUrl_USER'] ="http://api-red.yingruikeji.cn/red-user/red-memory-user"
|
||||||
|
// 在线api接口请求地址
|
||||||
|
window.SITE_CONFIG['baseUrlComment'] = 'http://123.60.109.11:8081/red-memory-user';
|
||||||
|
|
||||||
|
// cdn地址 = 域名 + 版本号
|
||||||
|
window.SITE_CONFIG['domain'] = './'; // 域名
|
||||||
|
window.SITE_CONFIG['version'] = ''; // 版本号(年月日时分)
|
||||||
|
window.SITE_CONFIG['cdnUrl'] = window.SITE_CONFIG.domain + window.SITE_CONFIG.version;
|
||||||
|
})();
|
|
@ -0,0 +1,14 @@
|
||||||
|
/**
|
||||||
|
* 测试环境
|
||||||
|
*/
|
||||||
|
;(function () {
|
||||||
|
window.SITE_CONFIG = {};
|
||||||
|
|
||||||
|
// api接口请求地址
|
||||||
|
window.SITE_CONFIG['baseUrl'] = 'http://localhost:8080/renren-fast';
|
||||||
|
|
||||||
|
// cdn地址 = 域名 + 版本号
|
||||||
|
window.SITE_CONFIG['domain'] = './'; // 域名
|
||||||
|
window.SITE_CONFIG['version'] = ''; // 版本号(年月日时分)
|
||||||
|
window.SITE_CONFIG['cdnUrl'] = window.SITE_CONFIG.domain + window.SITE_CONFIG.version;
|
||||||
|
})();
|
|
@ -0,0 +1,14 @@
|
||||||
|
/**
|
||||||
|
* 验收环境
|
||||||
|
*/
|
||||||
|
;(function () {
|
||||||
|
window.SITE_CONFIG = {};
|
||||||
|
|
||||||
|
// api接口请求地址
|
||||||
|
window.SITE_CONFIG['baseUrl'] = 'http://localhost:8080/renren-fast';
|
||||||
|
|
||||||
|
// cdn地址 = 域名 + 版本号
|
||||||
|
window.SITE_CONFIG['domain'] = './'; // 域名
|
||||||
|
window.SITE_CONFIG['version'] = ''; // 版本号(年月日时分)
|
||||||
|
window.SITE_CONFIG['cdnUrl'] = window.SITE_CONFIG.domain + window.SITE_CONFIG.version;
|
||||||
|
})();
|
|
@ -0,0 +1,24 @@
|
||||||
|
/*
|
||||||
|
* @Author: ym
|
||||||
|
* @Date: 2021-09-28 10:53:53
|
||||||
|
* @LastEditTime: 2022-08-26 16:42:07
|
||||||
|
* @LastEditors: chenkangxu
|
||||||
|
* @Description: In User Settings Edit
|
||||||
|
* @FilePath: \background-front-end\static\config\index.js
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* 开发环境
|
||||||
|
*/
|
||||||
|
;(function () {
|
||||||
|
window.SITE_CONFIG = {};
|
||||||
|
// api接口请求地址
|
||||||
|
window.SITE_CONFIG['baseUrl'] ="http://admin-test.damajishi.cn:8899"
|
||||||
|
// 在线api接口请求地址
|
||||||
|
// window.SITE_CONFIG['baseUrl'] = 'http://119.29.103.250:8082/red-memory';
|
||||||
|
// 在线api接口请求地址
|
||||||
|
window.SITE_CONFIG['baseUrlComment'] = 'http://123.60.109.11:8081/red-memory-user';
|
||||||
|
// cdn地址 = 域名 + 版本号
|
||||||
|
window.SITE_CONFIG['domain'] = './'; // 域名
|
||||||
|
window.SITE_CONFIG['version'] = ''; // 版本号(年月日时分)
|
||||||
|
window.SITE_CONFIG['cdnUrl'] = window.SITE_CONFIG.domain + window.SITE_CONFIG.version;
|
||||||
|
})();
|
|
@ -0,0 +1,86 @@
|
||||||
|
/*
|
||||||
|
* @Author: chenkangxu
|
||||||
|
* @Date: 2021-12-06 14:21:25
|
||||||
|
* @LastEditTime: 2022-05-01 22:48:44
|
||||||
|
* @LastEditors: chenkangxu
|
||||||
|
* @Description:
|
||||||
|
* @Github:
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* 动态加载初始资源
|
||||||
|
*/
|
||||||
|
;(function() {
|
||||||
|
var resList = {
|
||||||
|
icon: window.SITE_CONFIG.cdnUrl + '/static/img/favicon.ico',
|
||||||
|
css: [
|
||||||
|
window.SITE_CONFIG.cdnUrl + '/static/css/app.css',
|
||||||
|
],
|
||||||
|
js: [
|
||||||
|
// 插件, 放置业务之前加载, 以免业务需求依赖插件时, 还未加载出错
|
||||||
|
// 插件 - echarts
|
||||||
|
window.SITE_CONFIG.cdnUrl + '/static/plugins/echarts-3.8.5/echarts.common.min.js',
|
||||||
|
// 插件 - ueditor
|
||||||
|
window.SITE_CONFIG.cdnUrl + '/static/plugins/ueditor-1.4.3.3/ueditor.config.js',
|
||||||
|
window.SITE_CONFIG.cdnUrl + '/static/plugins/ueditor-1.4.3.3/ueditor.all.min.js',
|
||||||
|
window.SITE_CONFIG.cdnUrl + '/static/plugins/ueditor-1.4.3.3/lang/zh-cn/zh-cn.js',
|
||||||
|
//tinymic
|
||||||
|
window.SITE_CONFIG.cdnUrl + '/static/plugins/tinymce/tinymce.min.js',
|
||||||
|
// 业务
|
||||||
|
window.SITE_CONFIG.cdnUrl + '/static/js/manifest.js',
|
||||||
|
window.SITE_CONFIG.cdnUrl + '/static/js/vendor.js',
|
||||||
|
window.SITE_CONFIG.cdnUrl + '/static/js/app.js'
|
||||||
|
]
|
||||||
|
};
|
||||||
|
|
||||||
|
// 图标
|
||||||
|
(function () {
|
||||||
|
var _icon = document.createElement('link');
|
||||||
|
_icon.setAttribute('rel', 'shortcut icon');
|
||||||
|
_icon.setAttribute('type', 'image/x-icon');
|
||||||
|
_icon.setAttribute('href', resList.icon);
|
||||||
|
document.getElementsByTagName('head')[0].appendChild(_icon);
|
||||||
|
})();
|
||||||
|
|
||||||
|
// 样式
|
||||||
|
(function () {
|
||||||
|
document.getElementsByTagName('html')[0].style.opacity = 0;
|
||||||
|
var i = 0;
|
||||||
|
var _style = null;
|
||||||
|
var createStyles = function () {
|
||||||
|
if (i >= resList.css.length) {
|
||||||
|
document.getElementsByTagName('html')[0].style.opacity = 1;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
_style = document.createElement('link');
|
||||||
|
_style.href = resList.css[i];
|
||||||
|
_style.setAttribute('rel', 'stylesheet');
|
||||||
|
_style.onload = function () {
|
||||||
|
i++;
|
||||||
|
createStyles();
|
||||||
|
}
|
||||||
|
document.getElementsByTagName('head')[0].appendChild(_style);
|
||||||
|
}
|
||||||
|
createStyles();
|
||||||
|
})();
|
||||||
|
|
||||||
|
// 脚本
|
||||||
|
document.onreadystatechange = function () {
|
||||||
|
if (document.readyState === 'interactive') {
|
||||||
|
var i = 0;
|
||||||
|
var _script = null;
|
||||||
|
var createScripts = function () {
|
||||||
|
if (i >= resList.js.length) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
_script = document.createElement('script');
|
||||||
|
_script.src = resList.js[i];
|
||||||
|
_script.onload = function () {
|
||||||
|
i++;
|
||||||
|
createScripts();
|
||||||
|
}
|
||||||
|
document.getElementsByTagName('body')[0].appendChild(_script);
|
||||||
|
}
|
||||||
|
createScripts();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
})();
|
Binary file not shown.
After Width: | Height: | Size: 3.1 KiB |
File diff suppressed because one or more lines are too long
Binary file not shown.
After Width: | Height: | Size: 3.1 KiB |
|
@ -0,0 +1,233 @@
|
||||||
|
<!DOCTYPE html>
|
||||||
|
<html>
|
||||||
|
|
||||||
|
<head>
|
||||||
|
<meta charset="utf-8">
|
||||||
|
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
|
||||||
|
<meta name="renderer" content="webkit">
|
||||||
|
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no">
|
||||||
|
<link rel="icon" href="<%= BASE_URL %>favicon.ico">
|
||||||
|
<title>
|
||||||
|
<%= webpackConfig.name %>
|
||||||
|
</title>
|
||||||
|
<!--[if lt IE 11]><script>window.location.href='/html/ie.html';</script><![endif]-->
|
||||||
|
<style>
|
||||||
|
html,
|
||||||
|
body,
|
||||||
|
#app {
|
||||||
|
height: 100%;
|
||||||
|
margin: 0px;
|
||||||
|
padding: 0px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.chromeframe {
|
||||||
|
margin: 0.2em 0;
|
||||||
|
background: #4B9AE9;
|
||||||
|
color: #000;
|
||||||
|
padding: 0.2em 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#loader-wrapper {
|
||||||
|
position: fixed;
|
||||||
|
top: 0;
|
||||||
|
left: 0;
|
||||||
|
width: 100%;
|
||||||
|
height: 100%;
|
||||||
|
z-index: 999999;
|
||||||
|
}
|
||||||
|
|
||||||
|
#loader {
|
||||||
|
display: block;
|
||||||
|
position: relative;
|
||||||
|
left: 50%;
|
||||||
|
top: 50%;
|
||||||
|
width: 150px;
|
||||||
|
height: 150px;
|
||||||
|
margin: -75px 0 0 -75px;
|
||||||
|
border-radius: 50%;
|
||||||
|
border: 3px solid transparent;
|
||||||
|
border-top-color: #4B9AE9;
|
||||||
|
-webkit-animation: spin 2s linear infinite;
|
||||||
|
-ms-animation: spin 2s linear infinite;
|
||||||
|
-moz-animation: spin 2s linear infinite;
|
||||||
|
-o-animation: spin 2s linear infinite;
|
||||||
|
animation: spin 2s linear infinite;
|
||||||
|
z-index: 1001;
|
||||||
|
}
|
||||||
|
|
||||||
|
#loader:before {
|
||||||
|
content: "";
|
||||||
|
position: absolute;
|
||||||
|
top: 5px;
|
||||||
|
left: 5px;
|
||||||
|
right: 5px;
|
||||||
|
bottom: 5px;
|
||||||
|
border-radius: 50%;
|
||||||
|
border: 3px solid transparent;
|
||||||
|
border-top-color: #4B9AE9;
|
||||||
|
-webkit-animation: spin 3s linear infinite;
|
||||||
|
-moz-animation: spin 3s linear infinite;
|
||||||
|
-o-animation: spin 3s linear infinite;
|
||||||
|
-ms-animation: spin 3s linear infinite;
|
||||||
|
animation: spin 3s linear infinite;
|
||||||
|
}
|
||||||
|
|
||||||
|
#loader:after {
|
||||||
|
content: "";
|
||||||
|
position: absolute;
|
||||||
|
top: 15px;
|
||||||
|
left: 15px;
|
||||||
|
right: 15px;
|
||||||
|
bottom: 15px;
|
||||||
|
border-radius: 50%;
|
||||||
|
border: 3px solid transparent;
|
||||||
|
border-top-color: #4B9AE9;
|
||||||
|
-moz-animation: spin 1.5s linear infinite;
|
||||||
|
-o-animation: spin 1.5s linear infinite;
|
||||||
|
-ms-animation: spin 1.5s linear infinite;
|
||||||
|
-webkit-animation: spin 1.5s linear infinite;
|
||||||
|
animation: spin 1.5s linear infinite;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@-webkit-keyframes spin {
|
||||||
|
0% {
|
||||||
|
-webkit-transform: rotate(0deg);
|
||||||
|
-ms-transform: rotate(0deg);
|
||||||
|
transform: rotate(0deg);
|
||||||
|
}
|
||||||
|
|
||||||
|
100% {
|
||||||
|
-webkit-transform: rotate(360deg);
|
||||||
|
-ms-transform: rotate(360deg);
|
||||||
|
transform: rotate(360deg);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@keyframes spin {
|
||||||
|
0% {
|
||||||
|
-webkit-transform: rotate(0deg);
|
||||||
|
-ms-transform: rotate(0deg);
|
||||||
|
transform: rotate(0deg);
|
||||||
|
}
|
||||||
|
|
||||||
|
100% {
|
||||||
|
-webkit-transform: rotate(360deg);
|
||||||
|
-ms-transform: rotate(360deg);
|
||||||
|
transform: rotate(360deg);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#loader-wrapper .loader-section {
|
||||||
|
position: fixed;
|
||||||
|
top: 0;
|
||||||
|
width: 51%;
|
||||||
|
height: 100%;
|
||||||
|
background: #fff;
|
||||||
|
z-index: 1000;
|
||||||
|
-webkit-transform: translateX(0);
|
||||||
|
-ms-transform: translateX(0);
|
||||||
|
transform: translateX(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
#loader-wrapper .loader-section.section-left {
|
||||||
|
left: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#loader-wrapper .loader-section.section-right {
|
||||||
|
right: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
.loaded #loader-wrapper .loader-section.section-left {
|
||||||
|
-webkit-transform: translateX(-100%);
|
||||||
|
-ms-transform: translateX(-100%);
|
||||||
|
transform: translateX(-100%);
|
||||||
|
-webkit-transition: all 0.7s 0.3s cubic-bezier(0.645, 0.045, 0.355, 1.000);
|
||||||
|
transition: all 0.7s 0.3s cubic-bezier(0.645, 0.045, 0.355, 1.000);
|
||||||
|
}
|
||||||
|
|
||||||
|
.loaded #loader-wrapper .loader-section.section-right {
|
||||||
|
-webkit-transform: translateX(100%);
|
||||||
|
-ms-transform: translateX(100%);
|
||||||
|
transform: translateX(100%);
|
||||||
|
-webkit-transition: all 0.7s 0.3s cubic-bezier(0.645, 0.045, 0.355, 1.000);
|
||||||
|
transition: all 0.7s 0.3s cubic-bezier(0.645, 0.045, 0.355, 1.000);
|
||||||
|
}
|
||||||
|
|
||||||
|
.loaded #loader {
|
||||||
|
opacity: 0;
|
||||||
|
-webkit-transition: all 0.3s ease-out;
|
||||||
|
transition: all 0.3s ease-out;
|
||||||
|
}
|
||||||
|
|
||||||
|
.loaded #loader-wrapper {
|
||||||
|
visibility: hidden;
|
||||||
|
-webkit-transform: translateY(-100%);
|
||||||
|
-ms-transform: translateY(-100%);
|
||||||
|
transform: translateY(-100%);
|
||||||
|
-webkit-transition: all 0.3s 1s ease-out;
|
||||||
|
transition: all 0.3s 1s ease-out;
|
||||||
|
}
|
||||||
|
|
||||||
|
.no-js #loader-wrapper {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.no-js h1 {
|
||||||
|
color: #222222;
|
||||||
|
}
|
||||||
|
|
||||||
|
#loader-wrapper .load_title {
|
||||||
|
font-family: 'Open Sans';
|
||||||
|
color: #4B9AE9;
|
||||||
|
font-size: 19px;
|
||||||
|
width: 100%;
|
||||||
|
text-align: center;
|
||||||
|
z-index: 9999999999999;
|
||||||
|
position: absolute;
|
||||||
|
top: 60%;
|
||||||
|
opacity: 1;
|
||||||
|
line-height: 30px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#loader-wrapper .load_title span {
|
||||||
|
font-weight: normal;
|
||||||
|
font-style: italic;
|
||||||
|
font-size: 13px;
|
||||||
|
color: #4B9AE9;
|
||||||
|
opacity: 0.5;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
<% if (process.env.NODE_ENV==='development' ) { %>
|
||||||
|
<script src="./config/index.js"></script>
|
||||||
|
<% }else{ %>
|
||||||
|
<script src="./config/index-prod.js"></script>
|
||||||
|
<script>
|
||||||
|
//生产环境下不打印任何日志
|
||||||
|
console.log = (function (oriLogFunc) {
|
||||||
|
return function () {
|
||||||
|
}
|
||||||
|
})(console.log);
|
||||||
|
</script>
|
||||||
|
<% } %>
|
||||||
|
<script src="./plugins/echarts-3.8.5/echarts.common.min.js"></script>
|
||||||
|
<script src="./plugins/ueditor-1.4.3.3/ueditor.config.js"></script>
|
||||||
|
<script src="./plugins/ueditor-1.4.3.3/ueditor.all.min.js"></script>
|
||||||
|
<script src="./plugins/tinymce/tinymce.min.js"></script>
|
||||||
|
<script src="./plugins/ueditor-1.4.3.3/lang/zh-cn/zh-cn.js"></script>
|
||||||
|
</head>
|
||||||
|
|
||||||
|
<body>
|
||||||
|
<div id="app">
|
||||||
|
<div id="loader-wrapper">
|
||||||
|
<div id="loader"></div>
|
||||||
|
<div class="loader-section section-left"></div>
|
||||||
|
<div class="loader-section section-right"></div>
|
||||||
|
<div class="load_title">正在加载系统资源,请耐心等待</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</body>
|
||||||
|
|
||||||
|
</html>
|
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
|
@ -0,0 +1,7 @@
|
||||||
|
// Exports the "default" icons for usage with module loaders
|
||||||
|
// Usage:
|
||||||
|
// CommonJS:
|
||||||
|
// require('tinymce/icons/default')
|
||||||
|
// ES2015:
|
||||||
|
// import 'tinymce/icons/default'
|
||||||
|
require('./icons.js');
|
|
@ -0,0 +1,182 @@
|
||||||
|
tinymce.IconManager.add('default', {
|
||||||
|
icons: {
|
||||||
|
'accessibility-check': '<svg width="24" height="24"><path d="M12 2a2 2 0 012 2 2 2 0 01-2 2 2 2 0 01-2-2c0-1.1.9-2 2-2zm8 7h-5v12c0 .6-.4 1-1 1a1 1 0 01-1-1v-5c0-.6-.4-1-1-1a1 1 0 00-1 1v5c0 .6-.4 1-1 1a1 1 0 01-1-1V9H4a1 1 0 110-2h16c.6 0 1 .4 1 1s-.4 1-1 1z" fill-rule="nonzero"/></svg>',
|
||||||
|
'action-next': '<svg width="24" height="24"><path fill-rule="nonzero" d="M5.7 7.3a1 1 0 00-1.4 1.4l7.7 7.7 7.7-7.7a1 1 0 10-1.4-1.4L12 13.6 5.7 7.3z"/></svg>',
|
||||||
|
'action-prev': '<svg width="24" height="24"><path fill-rule="nonzero" d="M18.3 15.7a1 1 0 001.4-1.4L12 6.6l-7.7 7.7a1 1 0 001.4 1.4L12 9.4l6.3 6.3z"/></svg>',
|
||||||
|
'align-center': '<svg width="24" height="24"><path d="M5 5h14c.6 0 1 .4 1 1s-.4 1-1 1H5a1 1 0 110-2zm3 4h8c.6 0 1 .4 1 1s-.4 1-1 1H8a1 1 0 110-2zm0 8h8c.6 0 1 .4 1 1s-.4 1-1 1H8a1 1 0 010-2zm-3-4h14c.6 0 1 .4 1 1s-.4 1-1 1H5a1 1 0 010-2z" fill-rule="evenodd"/></svg>',
|
||||||
|
'align-justify': '<svg width="24" height="24"><path d="M5 5h14c.6 0 1 .4 1 1s-.4 1-1 1H5a1 1 0 110-2zm0 4h14c.6 0 1 .4 1 1s-.4 1-1 1H5a1 1 0 110-2zm0 4h14c.6 0 1 .4 1 1s-.4 1-1 1H5a1 1 0 010-2zm0 4h14c.6 0 1 .4 1 1s-.4 1-1 1H5a1 1 0 010-2z" fill-rule="evenodd"/></svg>',
|
||||||
|
'align-left': '<svg width="24" height="24"><path d="M5 5h14c.6 0 1 .4 1 1s-.4 1-1 1H5a1 1 0 110-2zm0 4h8c.6 0 1 .4 1 1s-.4 1-1 1H5a1 1 0 110-2zm0 8h8c.6 0 1 .4 1 1s-.4 1-1 1H5a1 1 0 010-2zm0-4h14c.6 0 1 .4 1 1s-.4 1-1 1H5a1 1 0 010-2z" fill-rule="evenodd"/></svg>',
|
||||||
|
'align-none': '<svg width="24" height="24"><path d="M14.2 5L13 7H5a1 1 0 110-2h9.2zm4 0h.8a1 1 0 010 2h-2l1.2-2zm-6.4 4l-1.2 2H5a1 1 0 010-2h6.8zm4 0H19a1 1 0 010 2h-4.4l1.2-2zm-6.4 4l-1.2 2H5a1 1 0 010-2h4.4zm4 0H19a1 1 0 010 2h-6.8l1.2-2zM7 17l-1.2 2H5a1 1 0 010-2h2zm4 0h8a1 1 0 010 2H9.8l1.2-2zm5.2-13.5l1.3.7-9.7 16.3-1.3-.7 9.7-16.3z" fill-rule="evenodd"/></svg>',
|
||||||
|
'align-right': '<svg width="24" height="24"><path d="M5 5h14c.6 0 1 .4 1 1s-.4 1-1 1H5a1 1 0 110-2zm6 4h8c.6 0 1 .4 1 1s-.4 1-1 1h-8a1 1 0 010-2zm0 8h8c.6 0 1 .4 1 1s-.4 1-1 1h-8a1 1 0 010-2zm-6-4h14c.6 0 1 .4 1 1s-.4 1-1 1H5a1 1 0 010-2z" fill-rule="evenodd"/></svg>',
|
||||||
|
'arrow-left': '<svg width="24" height="24"><path d="M5.6 13l12 6a1 1 0 001.4-1V6a1 1 0 00-1.4-.9l-12 6a1 1 0 000 1.8z" fill-rule="evenodd"/></svg>',
|
||||||
|
'arrow-right': '<svg width="24" height="24"><path d="M18.5 13l-12 6A1 1 0 015 18V6a1 1 0 011.4-.9l12 6a1 1 0 010 1.8z" fill-rule="evenodd"/></svg>',
|
||||||
|
'bold': '<svg width="24" height="24"><path d="M7.8 19c-.3 0-.5 0-.6-.2l-.2-.5V5.7c0-.2 0-.4.2-.5l.6-.2h5c1.5 0 2.7.3 3.5 1 .7.6 1.1 1.4 1.1 2.5a3 3 0 01-.6 1.9c-.4.6-1 1-1.6 1.2.4.1.9.3 1.3.6s.8.7 1 1.2c.4.4.5 1 .5 1.6 0 1.3-.4 2.3-1.3 3-.8.7-2.1 1-3.8 1H7.8zm5-8.3c.6 0 1.2-.1 1.6-.5.4-.3.6-.7.6-1.3 0-1.1-.8-1.7-2.3-1.7H9.3v3.5h3.4zm.5 6c.7 0 1.3-.1 1.7-.4.4-.4.6-.9.6-1.5s-.2-1-.7-1.4c-.4-.3-1-.4-2-.4H9.4v3.8h4z" fill-rule="evenodd"/></svg>',
|
||||||
|
'bookmark': '<svg width="24" height="24"><path d="M6 4v17l6-4 6 4V4c0-.6-.4-1-1-1H7a1 1 0 00-1 1z" fill-rule="nonzero"/></svg>',
|
||||||
|
'border-style': '<svg width="24" height="24"><g fill-rule="evenodd"><rect width="18" height="2" x="3" y="6" rx="1"/><rect width="2.8" height="2" x="3" y="16" rx="1"/><rect width="2.8" height="2" x="6.8" y="16" rx="1"/><rect width="2.8" height="2" x="10.6" y="16" rx="1"/><rect width="2.8" height="2" x="14.4" y="16" rx="1"/><rect width="2.8" height="2" x="18.2" y="16" rx="1"/><rect width="8" height="2" x="3" y="11" rx="1"/><rect width="8" height="2" x="13" y="11" rx="1"/></g></svg>',
|
||||||
|
'border-width': '<svg width="24" height="24"><g fill-rule="evenodd"><rect width="18" height="5" x="3" y="5" rx="1"/><rect width="18" height="3.5" x="3" y="11.5" rx="1"/><rect width="18" height="2" x="3" y="17" rx="1"/></g></svg>',
|
||||||
|
'brightness': '<svg width="24" height="24"><path d="M12 17c.3 0 .5.1.7.3.2.2.3.4.3.7v1c0 .3-.1.5-.3.7a1 1 0 01-.7.3 1 1 0 01-.7-.3 1 1 0 01-.3-.7v-1c0-.3.1-.5.3-.7.2-.2.4-.3.7-.3zm0-10a1 1 0 01-.7-.3A1 1 0 0111 6V5c0-.3.1-.5.3-.7.2-.2.4-.3.7-.3.3 0 .5.1.7.3.2.2.3.4.3.7v1c0 .3-.1.5-.3.7a1 1 0 01-.7.3zm7 4c.3 0 .5.1.7.3.2.2.3.4.3.7 0 .3-.1.5-.3.7a1 1 0 01-.7.3h-1a1 1 0 01-.7-.3 1 1 0 01-.3-.7c0-.3.1-.5.3-.7.2-.2.4-.3.7-.3h1zM7 12c0 .3-.1.5-.3.7a1 1 0 01-.7.3H5a1 1 0 01-.7-.3A1 1 0 014 12c0-.3.1-.5.3-.7.2-.2.4-.3.7-.3h1c.3 0 .5.1.7.3.2.2.3.4.3.7zm10 3.5l.7.8c.2.1.3.4.3.6 0 .3-.1.6-.3.8a1 1 0 01-.8.3 1 1 0 01-.6-.3l-.8-.7a1 1 0 01-.3-.8c0-.2.1-.5.3-.7a1 1 0 011.4 0zm-10-7l-.7-.8a1 1 0 01-.3-.6c0-.3.1-.6.3-.8.2-.2.5-.3.8-.3.2 0 .5.1.7.3l.7.7c.2.2.3.5.3.8 0 .2-.1.5-.3.7a1 1 0 01-.7.3 1 1 0 01-.8-.3zm10 0a1 1 0 01-.8.3 1 1 0 01-.7-.3 1 1 0 01-.3-.7c0-.3.1-.6.3-.8l.8-.7c.1-.2.4-.3.6-.3.3 0 .6.1.8.3.2.2.3.5.3.8 0 .2-.1.5-.3.7l-.7.7zm-10 7c.2-.2.5-.3.8-.3.2 0 .5.1.7.3a1 1 0 010 1.4l-.8.8a1 1 0 01-.6.3 1 1 0 01-.8-.3 1 1 0 01-.3-.8c0-.2.1-.5.3-.6l.7-.8zM12 8a4 4 0 013.7 2.4 4 4 0 010 3.2A4 4 0 0112 16a4 4 0 01-3.7-2.4 4 4 0 010-3.2A4 4 0 0112 8zm0 6.5c.7 0 1.3-.2 1.8-.7.5-.5.7-1.1.7-1.8s-.2-1.3-.7-1.8c-.5-.5-1.1-.7-1.8-.7s-1.3.2-1.8.7c-.5.5-.7 1.1-.7 1.8s.2 1.3.7 1.8c.5.5 1.1.7 1.8.7z" fill-rule="evenodd"/></svg>',
|
||||||
|
'browse': '<svg width="24" height="24"><path d="M19 4a2 2 0 012 2v12a2 2 0 01-2 2h-4v-2h4V8H5v10h4v2H5a2 2 0 01-2-2V6c0-1.1.9-2 2-2h14zm-8 9.4l-2.3 2.3a1 1 0 11-1.4-1.4l4-4a1 1 0 011.4 0l4 4a1 1 0 01-1.4 1.4L13 13.4V20a1 1 0 01-2 0v-6.6z" fill-rule="nonzero"/></svg>',
|
||||||
|
'cancel': '<svg width="24" height="24"><path d="M12 4.6a7.4 7.4 0 110 14.8 7.4 7.4 0 010-14.8zM12 3a9 9 0 100 18 9 9 0 000-18zm0 8L14.8 8l1 1.1-2.7 2.8 2.7 2.7-1.1 1.1-2.7-2.7-2.7 2.7-1-1.1 2.6-2.7-2.7-2.7 1-1.1 2.8 2.7z" fill-rule="nonzero"/></svg>',
|
||||||
|
'cell-background-color': '<svg width="24" height="24"><path d="M15.7 2l1.6 1.6-2.7 2.6 5.9 5.8c.7.7.7 1.7 0 2.4l-6.3 6.1a1.7 1.7 0 01-2.4 0l-6.3-6.1c-.7-.7-.7-1.7 0-2.4L15.7 2zM18 12l-4.5-4L9 12h9zM4 16s2 2.4 2 3.8C6 21 5.1 22 4 22s-2-1-2-2.2C2 18.4 4 16 4 16z"/></svg>',
|
||||||
|
'cell-border-color': '<svg width="24" height="24"><g fill-rule="evenodd"><path fill-rule="nonzero" d="M5 13v5h2v2H5a2 2 0 01-2-2v-5h2zm8-7V4h6a2 2 0 012 2h-8z" opacity=".2"/><path fill-rule="nonzero" d="M13 4v2H5v7H3V6c0-1.1.9-2 2-2h8zm-2.6 14.1l.1-.1.1.1.2.3.2.2.2.2c.4.6.8 1.2.8 1.7 0 .8-.7 1.5-1.5 1.5S9 21.3 9 20.5c0-.5.4-1.1.8-1.7l.2-.2.2-.2.2-.3z"/><path d="M13 11l-2 2H5v-2h6V6h2z"/><path fill-rule="nonzero" d="M18.4 8l1 1-1.8 1.9 4 4c.5.4.5 1.1 0 1.6l-4.3 4.2a1.2 1.2 0 01-1.6 0l-4.4-4.2c-.4-.5-.4-1.2 0-1.7l7-6.8zm1.6 7l-3-3-3 3h6z"/></g></svg>',
|
||||||
|
'change-case': '<svg width="24" height="24"><path d="M18.4 18.2v-.6c-.5.8-1.3 1.2-2.4 1.2-2.2 0-3.3-1.6-3.3-4.8 0-3.1 1-4.7 3.3-4.7 1.1 0 1.8.3 2.4 1.1v-.6c0-.5.4-.8.8-.8s.8.3.8.8v8.4c0 .5-.4.8-.8.8a.8.8 0 01-.8-.8zm-2-7.4c-1.3 0-1.8.9-1.8 3.2 0 2.4.5 3.3 1.7 3.3 1.3 0 1.8-.9 1.8-3.2 0-2.4-.5-3.3-1.7-3.3zM10 15.7H5.5l-.8 2.6a1 1 0 01-1 .7h-.2a.7.7 0 01-.7-1l4-12a1 1 0 012 0l4 12a.7.7 0 01-.8 1h-.2a1 1 0 01-1-.7l-.8-2.6zm-.3-1.5l-2-6.5-1.9 6.5h3.9z" fill-rule="evenodd"/></svg>',
|
||||||
|
'character-count': '<svg width="24" height="24"><path d="M4 11.5h16v1H4v-1zm4.8-6.8V10H7.7V5.8h-1v-1h2zM11 8.3V9h2v1h-3V7.7l2-1v-.9h-2v-1h3v2.4l-2 1zm6.3-3.4V10h-3.1V9h2.1V8h-2.1V6.8h2.1v-1h-2.1v-1h3.1zM5.8 16.4c0-.5.2-.8.5-1 .2-.2.6-.3 1.2-.3l.8.1c.2 0 .4.2.5.3l.4.4v2.8l.2.3H8.2v-.1-.2l-.6.3H7c-.4 0-.7 0-1-.2a1 1 0 01-.3-.9c0-.3 0-.6.3-.8.3-.2.7-.4 1.2-.4l.6-.2h.3v-.2l-.1-.2a.8.8 0 00-.5-.1 1 1 0 00-.4 0l-.3.4h-1zm2.3.8h-.2l-.2.1-.4.1a1 1 0 00-.4.2l-.2.2.1.3.5.1h.4l.4-.4v-.6zm2-3.4h1.2v1.7l.5-.3h.5c.5 0 .9.1 1.2.5.3.4.5.8.5 1.4 0 .6-.2 1.1-.5 1.5-.3.4-.7.6-1.3.6l-.6-.1-.4-.4v.4h-1.1v-5.4zm1.1 3.3c0 .3 0 .6.2.8a.7.7 0 001.2 0l.2-.8c0-.4 0-.6-.2-.8a.7.7 0 00-.6-.3l-.6.3-.2.8zm6.1-.5c0-.2 0-.3-.2-.4a.8.8 0 00-.5-.2c-.3 0-.5.1-.6.3l-.2.9c0 .3 0 .6.2.8.1.2.3.3.6.3.2 0 .4 0 .5-.2l.2-.4h1.1c0 .5-.3.8-.6 1.1a2 2 0 01-1.3.4c-.5 0-1-.2-1.3-.6a2 2 0 01-.5-1.4c0-.6.1-1.1.5-1.5.3-.4.8-.5 1.4-.5.5 0 1 0 1.2.3.4.3.5.7.5 1.2h-1v-.1z" fill-rule="evenodd"/></svg>',
|
||||||
|
'checklist-rtl': '<svg width="24" height="24"><path d="M5 17h8c.6 0 1 .4 1 1s-.4 1-1 1H5a1 1 0 010-2zm0-6h8c.6 0 1 .4 1 1s-.4 1-1 1H5a1 1 0 010-2zm0-6h8c.6 0 1 .4 1 1s-.4 1-1 1H5a1 1 0 110-2zm14.2 11c.2-.4.6-.5.9-.3.3.2.4.6.2 1L18 20c-.2.3-.7.4-1 0l-1.3-1.3a.7.7 0 010-1c.3-.2.7-.2 1 0l.7.9 1.7-2.8zm0-6c.2-.4.6-.5.9-.3.3.2.4.6.2 1L18 14c-.2.3-.7.4-1 0l-1.3-1.3a.7.7 0 010-1c.3-.2.7-.2 1 0l.7.9 1.7-2.8zm0-6c.2-.4.6-.5.9-.3.3.2.4.6.2 1L18 8c-.2.3-.7.4-1 0l-1.3-1.3a.7.7 0 010-1c.3-.2.7-.2 1 0l.7.9 1.7-2.8z" fill-rule="evenodd"/></svg>',
|
||||||
|
'checklist': '<svg width="24" height="24"><path d="M11 17h8c.6 0 1 .4 1 1s-.4 1-1 1h-8a1 1 0 010-2zm0-6h8c.6 0 1 .4 1 1s-.4 1-1 1h-8a1 1 0 010-2zm0-6h8a1 1 0 010 2h-8a1 1 0 010-2zM7.2 16c.2-.4.6-.5.9-.3.3.2.4.6.2 1L6 20c-.2.3-.7.4-1 0l-1.3-1.3a.7.7 0 010-1c.3-.2.7-.2 1 0l.7.9 1.7-2.8zm0-6c.2-.4.6-.5.9-.3.3.2.4.6.2 1L6 14c-.2.3-.7.4-1 0l-1.3-1.3a.7.7 0 010-1c.3-.2.7-.2 1 0l.7.9 1.7-2.8zm0-6c.2-.4.6-.5.9-.3.3.2.4.6.2 1L6 8c-.2.3-.7.4-1 0L3.8 6.9a.7.7 0 010-1c.3-.2.7-.2 1 0l.7.9 1.7-2.8z" fill-rule="evenodd"/></svg>',
|
||||||
|
'checkmark': '<svg width="24" height="24"><path d="M18.2 5.4a1 1 0 011.6 1.2l-8 12a1 1 0 01-1.5.1l-5-5a1 1 0 111.4-1.4l4.1 4.1 7.4-11z" fill-rule="nonzero"/></svg>',
|
||||||
|
'chevron-down': '<svg width="10" height="10"><path d="M8.7 2.2c.3-.3.8-.3 1 0 .4.4.4.9 0 1.2L5.7 7.8c-.3.3-.9.3-1.2 0L.2 3.4a.8.8 0 010-1.2c.3-.3.8-.3 1.1 0L5 6l3.7-3.8z" fill-rule="nonzero"/></svg>',
|
||||||
|
'chevron-left': '<svg width="10" height="10"><path d="M7.8 1.3L4 5l3.8 3.7c.3.3.3.8 0 1-.4.4-.9.4-1.2 0L2.2 5.7a.8.8 0 010-1.2L6.6.2C7 0 7.4 0 7.8.2c.3.3.3.8 0 1.1z" fill-rule="nonzero"/></svg>',
|
||||||
|
'chevron-right': '<svg width="10" height="10"><path d="M2.2 1.3a.8.8 0 010-1c.4-.4.9-.4 1.2 0l4.4 4.1c.3.4.3.9 0 1.2L3.4 9.8c-.3.3-.8.3-1.2 0a.8.8 0 010-1.1L6 5 2.2 1.3z" fill-rule="nonzero"/></svg>',
|
||||||
|
'chevron-up': '<svg width="10" height="10"><path d="M8.7 7.8L5 4 1.3 7.8c-.3.3-.8.3-1 0a.8.8 0 010-1.2l4.1-4.4c.3-.3.9-.3 1.2 0l4.2 4.4c.3.3.3.9 0 1.2-.3.3-.8.3-1.1 0z" fill-rule="nonzero"/></svg>',
|
||||||
|
'close': '<svg width="24" height="24"><path d="M17.3 8.2L13.4 12l3.9 3.8a1 1 0 01-1.5 1.5L12 13.4l-3.8 3.9a1 1 0 01-1.5-1.5l3.9-3.8-3.9-3.8a1 1 0 011.5-1.5l3.8 3.9 3.8-3.9a1 1 0 011.5 1.5z" fill-rule="evenodd"/></svg>',
|
||||||
|
'code-sample': '<svg width="24" height="26"><path d="M7.1 11a2.8 2.8 0 01-.8 2 2.8 2.8 0 01.8 2v1.7c0 .3.1.6.4.8.2.3.5.4.8.4.3 0 .4.2.4.4v.8c0 .2-.1.4-.4.4-.7 0-1.4-.3-2-.8-.5-.6-.8-1.3-.8-2V15c0-.3-.1-.6-.4-.8-.2-.3-.5-.4-.8-.4a.4.4 0 01-.4-.4v-.8c0-.2.2-.4.4-.4.3 0 .6-.1.8-.4.3-.2.4-.5.4-.8V9.3c0-.7.3-1.4.8-2 .6-.5 1.3-.8 2-.8.3 0 .4.2.4.4v.8c0 .2-.1.4-.4.4-.3 0-.6.1-.8.4-.3.2-.4.5-.4.8V11zm9.8 0V9.3c0-.3-.1-.6-.4-.8-.2-.3-.5-.4-.8-.4a.4.4 0 01-.4-.4V7c0-.2.1-.4.4-.4.7 0 1.4.3 2 .8.5.6.8 1.3.8 2V11c0 .3.1.6.4.8.2.3.5.4.8.4.2 0 .4.2.4.4v.8c0 .2-.2.4-.4.4-.3 0-.6.1-.8.4-.3.2-.4.5-.4.8v1.7c0 .7-.3 1.4-.8 2-.6.5-1.3.8-2 .8a.4.4 0 01-.4-.4v-.8c0-.2.1-.4.4-.4.3 0 .6-.1.8-.4.3-.2.4-.5.4-.8V15a2.8 2.8 0 01.8-2 2.8 2.8 0 01-.8-2zm-3.3-.4c0 .4-.1.8-.5 1.1-.3.3-.7.5-1.1.5-.4 0-.8-.2-1.1-.5-.4-.3-.5-.7-.5-1.1 0-.5.1-.9.5-1.2.3-.3.7-.4 1.1-.4.4 0 .8.1 1.1.4.4.3.5.7.5 1.2zM12 13c.4 0 .8.1 1.1.5.4.3.5.7.5 1.1 0 1-.1 1.6-.5 2a3 3 0 01-1.1 1c-.4.3-.8.4-1.1.4a.5.5 0 01-.5-.5V17a3 3 0 001-.2l.6-.6c-.6 0-1-.2-1.3-.5-.2-.3-.3-.7-.3-1 0-.5.1-1 .5-1.2.3-.4.7-.5 1.1-.5z" fill-rule="evenodd"/></svg>',
|
||||||
|
'color-levels': '<svg width="24" height="24"><path d="M17.5 11.4A9 9 0 0118 14c0 .5 0 1-.2 1.4 0 .4-.3.9-.5 1.3a6.2 6.2 0 01-3.7 3 5.7 5.7 0 01-3.2 0A5.9 5.9 0 017.6 18a6.2 6.2 0 01-1.4-2.6 6.7 6.7 0 010-2.8c0-.4.1-.9.3-1.3a13.6 13.6 0 012.3-4A20 20 0 0112 4a26.4 26.4 0 013.2 3.4 18.2 18.2 0 012.3 4zm-2 4.5c.4-.7.5-1.4.5-2a7.3 7.3 0 00-1-3.2c.2.6.2 1.2.2 1.9a4.5 4.5 0 01-1.3 3 5.3 5.3 0 01-2.3 1.5 4.9 4.9 0 01-2 .1 4.3 4.3 0 002.4.8 4 4 0 002-.6 4 4 0 001.5-1.5z" fill-rule="evenodd"/></svg>',
|
||||||
|
'color-picker': '<svg width="24" height="24"><path d="M12 3a9 9 0 000 18 1.5 1.5 0 001.1-2.5c-.2-.3-.4-.6-.4-1 0-.8.7-1.5 1.5-1.5H16a5 5 0 005-5c0-4.4-4-8-9-8zm-5.5 9a1.5 1.5 0 110-3 1.5 1.5 0 010 3zm3-4a1.5 1.5 0 110-3 1.5 1.5 0 010 3zm5 0a1.5 1.5 0 110-3 1.5 1.5 0 010 3zm3 4a1.5 1.5 0 110-3 1.5 1.5 0 010 3z" fill-rule="nonzero"/></svg>',
|
||||||
|
'color-swatch-remove-color': '<svg width="24" height="24"><path stroke="#000" stroke-width="2" d="M21 3L3 21" fill-rule="evenodd"/></svg>',
|
||||||
|
'color-swatch': '<svg width="24" height="24"><rect x="3" y="3" width="18" height="18" rx="1" fill-rule="evenodd"/></svg>',
|
||||||
|
'comment-add': '<svg width="24" height="24"><g fill-rule="nonzero"><path d="M9 19l3-2h7c.6 0 1-.4 1-1V6c0-.6-.4-1-1-1H5a1 1 0 00-1 1v10c0 .6.4 1 1 1h4v2zm-2 4v-4H5a3 3 0 01-3-3V6a3 3 0 013-3h14a3 3 0 013 3v10a3 3 0 01-3 3h-6.4L7 23z"/><path d="M13 10h2a1 1 0 010 2h-2v2a1 1 0 01-2 0v-2H9a1 1 0 010-2h2V8a1 1 0 012 0v2z"/></g></svg>',
|
||||||
|
'comment': '<svg width="24" height="24"><path fill-rule="nonzero" d="M9 19l3-2h7c.6 0 1-.4 1-1V6c0-.6-.4-1-1-1H5a1 1 0 00-1 1v10c0 .6.4 1 1 1h4v2zm-2 4v-4H5a3 3 0 01-3-3V6a3 3 0 013-3h14a3 3 0 013 3v10a3 3 0 01-3 3h-6.4L7 23z"/></svg>',
|
||||||
|
'contrast': '<svg width="24" height="24"><path d="M12 4a7.8 7.8 0 015.7 2.3A8 8 0 1112 4zm-6 8a6 6 0 006 6V6a6 6 0 00-6 6z" fill-rule="evenodd"/></svg>',
|
||||||
|
'copy': '<svg width="24" height="24"><path d="M16 3H6a2 2 0 00-2 2v11h2V5h10V3zm1 4a2 2 0 012 2v10a2 2 0 01-2 2h-7a2 2 0 01-2-2V9c0-1.2.9-2 2-2h7zm0 12V9h-7v10h7z" fill-rule="nonzero"/></svg>',
|
||||||
|
'crop': '<svg width="24" height="24"><path d="M17 8v7h2c.6 0 1 .4 1 1s-.4 1-1 1h-2v2c0 .6-.4 1-1 1a1 1 0 01-1-1v-2H7V9H5a1 1 0 110-2h2V5c0-.6.4-1 1-1s1 .4 1 1v2h7l3-3 1 1-3 3zM9 9v5l5-5H9zm1 6h5v-5l-5 5z" fill-rule="evenodd"/></svg>',
|
||||||
|
'cut-column': '<svg width="24" height="24"><path fill-rule="evenodd" d="M7.2 4.5c.9 0 1.6.4 2.2 1A3.7 3.7 0 0110.5 8v.5l1 1 4-4 1-.5a3.3 3.3 0 012 0c.4 0 .7.3 1 .5L17 8h4v13h-6V10l-1.5 1.5.5.5v4l-2.5-2.5-1 1v.5c0 .4 0 .8-.3 1.2-.2.5-.4.9-.8 1.2-.6.7-1.3 1-2.2 1-.8.2-1.5 0-2-.6l-.5-.8-.2-1c0-.4 0-.8.3-1.2A3.9 3.9 0 017 12.7c.5-.2 1-.3 1.5-.2l1-1-1-1c-.5 0-1 0-1.5-.2-.5-.1-1-.4-1.4-.9-.4-.3-.6-.7-.8-1.2L4.5 7c0-.4 0-.7.2-1 0-.3.3-.6.5-.8.5-.5 1.2-.8 2-.7zm12.3 5h-3v10h3v-10zM8 13.8h-.3l-.4.2a2.8 2.8 0 00-.7.4v.1a2.8 2.8 0 00-.6.8l-.1.4v.7l.2.5.5.2h.7a2.6 2.6 0 00.8-.3 2.4 2.4 0 00.7-.7 2.5 2.5 0 00.3-.8 1.5 1.5 0 000-.8 1 1 0 00-.2-.4 1 1 0 00-.5-.2H8zm3.5-3.7c-.4 0-.7.1-1 .4-.3.3-.4.6-.4 1s.1.7.4 1c.3.3.6.4 1 .4s.7-.1 1-.4c.3-.3.4-.6.4-1s-.1-.7-.4-1c-.3-.3-.6-.4-1-.4zM7 5.8h-.4a1 1 0 00-.5.3 1 1 0 00-.2.5v.7a2.5 2.5 0 00.3.8l.2.3h.1l.4.4.4.2.4.1h.7L9 9l.2-.4a1.6 1.6 0 000-.8 2.6 2.6 0 00-.3-.8A2.5 2.5 0 007.7 6l-.4-.1H7z"/></svg>',
|
||||||
|
'cut-row': '<svg width="24" height="24"><path fill-rule="evenodd" d="M22 3v5H9l3 3 2-2h4l-4 4 1 1h.5c.4 0 .8 0 1.2.3.5.2.9.4 1.2.8.7.6 1 1.3 1 2.2.2.8 0 1.5-.6 2l-.8.5-1 .2c-.4 0-.8 0-1.2-.3a3.9 3.9 0 01-2.1-2.2c-.2-.5-.3-1-.2-1.5l-1-1-1 1c0 .5 0 1-.2 1.5-.1.5-.4 1-.9 1.4-.3.4-.7.6-1.2.8l-1.2.3c-.4 0-.7 0-1-.2-.3 0-.6-.3-.8-.5-.5-.5-.8-1.2-.7-2 0-.9.4-1.6 1-2.2A3.7 3.7 0 018.6 14H9l1-1-4-4-.5-1a3.3 3.3 0 010-2c0-.4.3-.7.5-1l2 2V3h14zM8.5 15.3h-.3a2.6 2.6 0 00-.8.4 2.5 2.5 0 00-.9 1.1l-.1.4v.7l.2.5.5.2h.7a2.5 2.5 0 00.8-.3L9 18V18l.4-.4.2-.4.1-.4v-.3-.4a1 1 0 00-.2-.5 1 1 0 00-.4-.2h-.5zm7 0H15a1 1 0 00-.4.3 1 1 0 00-.2.5 1.5 1.5 0 000 .7v.4a2.8 2.8 0 00.5.7h.1a2.8 2.8 0 00.8.6l.4.1h.7l.5-.2.2-.5v-.4-.3a2.6 2.6 0 00-.3-.8 2.4 2.4 0 00-.7-.7 2.5 2.5 0 00-.8-.3h-.3zM12 11.6c-.4 0-.7.1-1 .4-.3.3-.4.6-.4 1s.1.7.4 1c.3.3.6.4 1 .4s.7-.1 1-.4c.3-.3.4-.6.4-1s-.1-.7-.4-1c-.3-.3-.6-.4-1-.4zm8.5-7.1h-11v2h11v-2z"/></svg>',
|
||||||
|
'cut': '<svg width="24" height="24"><path d="M18 15c.6.7 1 1.4 1 2.3 0 .8-.2 1.5-.7 2l-.8.5-1 .2c-.4 0-.8 0-1.2-.3a3.9 3.9 0 01-2.1-2.2c-.2-.5-.3-1-.2-1.5l-1-1-1 1c0 .5 0 1-.2 1.5-.1.5-.4 1-.9 1.4-.3.4-.7.6-1.2.8l-1.2.3c-.4 0-.7 0-1-.2-.3 0-.6-.3-.8-.5-.5-.5-.8-1.2-.7-2 0-.9.4-1.6 1-2.2A3.7 3.7 0 018.6 14H9l1-1-4-4-.5-1a3.3 3.3 0 010-2c0-.4.3-.7.5-1l6 6 6-6 .5 1a3.3 3.3 0 010 2c0 .4-.3.7-.5 1l-4 4 1 1h.5c.4 0 .8 0 1.2.3.5.2.9.4 1.2.8zm-8.5 2.2l.1-.4v-.3-.4a1 1 0 00-.2-.5 1 1 0 00-.4-.2 1.6 1.6 0 00-.8 0 2.6 2.6 0 00-.8.3 2.5 2.5 0 00-.9 1.1l-.1.4v.7l.2.5.5.2h.7a2.5 2.5 0 00.8-.3 2.8 2.8 0 001-1zm2.5-2.8c.4 0 .7-.1 1-.4.3-.3.4-.6.4-1s-.1-.7-.4-1c-.3-.3-.6-.4-1-.4s-.7.1-1 .4c-.3.3-.4.6-.4 1s.1.7.4 1c.3.3.6.4 1 .4zm5.4 4l.2-.5v-.4-.3a2.6 2.6 0 00-.3-.8 2.4 2.4 0 00-.7-.7 2.5 2.5 0 00-.8-.3 1.5 1.5 0 00-.8 0 1 1 0 00-.4.2 1 1 0 00-.2.5 1.5 1.5 0 000 .7v.4l.3.4.3.4a2.8 2.8 0 00.8.5l.4.1h.7l.5-.2z" fill-rule="evenodd"/></svg>',
|
||||||
|
'document-properties': '<svg width="24" height="24"><path d="M14.4 3H7a2 2 0 00-2 2v14c0 1.1.9 2 2 2h10a2 2 0 002-2V7.6L14.4 3zM17 19H7V5h6v4h4v10z" fill-rule="nonzero"/></svg>',
|
||||||
|
'drag': '<svg width="24" height="24"><path d="M13 5h2v2h-2V5zm0 4h2v2h-2V9zM9 9h2v2H9V9zm4 4h2v2h-2v-2zm-4 0h2v2H9v-2zm0 4h2v2H9v-2zm4 0h2v2h-2v-2zM9 5h2v2H9V5z" fill-rule="evenodd"/></svg>',
|
||||||
|
'duplicate-column': '<svg width="24" height="24"><path d="M17 6v16h-7V6h7zm-2 2h-3v12h3V8zm-2-6v2H8v15H6V2h7z"/></svg>',
|
||||||
|
'duplicate-row': '<svg width="24" height="24"><path d="M22 11v7H6v-7h16zm-2 2H8v3h12v-3zm-1-6v2H4v5H2V7h17z"/></svg>',
|
||||||
|
'duplicate': '<svg width="24" height="24"><g fill-rule="nonzero"><path d="M16 3v2H6v11H4V5c0-1.1.9-2 2-2h10zm3 8h-2V9h-7v10h9a2 2 0 01-2 2h-7a2 2 0 01-2-2V9c0-1.2.9-2 2-2h7a2 2 0 012 2v2z"/><path d="M17 14h1a1 1 0 010 2h-1v1a1 1 0 01-2 0v-1h-1a1 1 0 010-2h1v-1a1 1 0 012 0v1z"/></g></svg>',
|
||||||
|
'edit-block': '<svg width="24" height="24"><path fill-rule="nonzero" d="M19.8 8.8l-9.4 9.4c-.2.2-.5.4-.9.4l-5.4 1.2 1.2-5.4.5-.8 9.4-9.4c.7-.7 1.8-.7 2.5 0l2.1 2.1c.7.7.7 1.8 0 2.5zm-2-.2l1-.9v-.3l-2.2-2.2a.3.3 0 00-.3 0l-1 1L18 8.5zm-1 1l-2.5-2.4-6 6 2.5 2.5 6-6zm-7 7.1l-2.6-2.4-.3.3-.1.2-.7 3 3.1-.6h.1l.4-.5z"/></svg>',
|
||||||
|
'edit-image': '<svg width="24" height="24"><path d="M18 16h2V7a2 2 0 00-2-2H7v2h11v9zM6 17h15a1 1 0 010 2h-1v1a1 1 0 01-2 0v-1H6a2 2 0 01-2-2V7H3a1 1 0 110-2h1V4a1 1 0 112 0v13zm3-5.3l1.3 2 3-4.7 3.7 6H7l2-3.3z" fill-rule="nonzero"/></svg>',
|
||||||
|
'embed-page': '<svg width="24" height="24"><path d="M19 6V5H5v14h2A13 13 0 0119 6zm0 1.4c-.8.8-1.6 2.4-2.2 4.6H19V7.4zm0 5.6h-2.4c-.4 1.8-.6 3.8-.6 6h3v-6zm-4 6c0-2.2.2-4.2.6-6H13c-.7 1.8-1.1 3.8-1.1 6h3zm-4 0c0-2.2.4-4.2 1-6H9.6A12 12 0 008 19h3zM4 3h16c.6 0 1 .4 1 1v16c0 .6-.4 1-1 1H4a1 1 0 01-1-1V4c0-.6.4-1 1-1zm11.8 9c.4-1.9 1-3.4 1.8-4.5a9.2 9.2 0 00-4 4.5h2.2zm-3.4 0a12 12 0 012.8-4 12 12 0 00-5 4h2.2z" fill-rule="nonzero"/></svg>',
|
||||||
|
'embed': '<svg width="24" height="24"><path d="M4 3h16c.6 0 1 .4 1 1v16c0 .6-.4 1-1 1H4a1 1 0 01-1-1V4c0-.6.4-1 1-1zm1 2v14h14V5H5zm4.8 2.6l5.6 4a.5.5 0 010 .8l-5.6 4A.5.5 0 019 16V8a.5.5 0 01.8-.4z" fill-rule="nonzero"/></svg>',
|
||||||
|
'emoji': '<svg width="24" height="24"><path d="M9 11c.6 0 1-.4 1-1s-.4-1-1-1a1 1 0 00-1 1c0 .6.4 1 1 1zm6 0c.6 0 1-.4 1-1s-.4-1-1-1a1 1 0 00-1 1c0 .6.4 1 1 1zm-3 5.5c2.1 0 4-1.5 4.4-3.5H7.6c.5 2 2.3 3.5 4.4 3.5zM12 4a8 8 0 100 16 8 8 0 000-16zm0 14.5a6.5 6.5 0 110-13 6.5 6.5 0 010 13z" fill-rule="nonzero"/></svg>',
|
||||||
|
'export': '<svg width="24" height="24"><g fill-rule="nonzero"><path d="M14.4 3L18 7v1h-5V5H7v14h9a1 1 0 012 0c0 1-.8 2-1.9 2H7c-1 0-2-.8-2-1.9V5c0-1 .8-2 1.9-2h7.5z"/><path d="M18.1 12c.5 0 .9.4.9 1 0 .5-.3 1-.8 1h-7.3c-.5 0-.9-.4-.9-1 0-.5.3-1 .8-1h7.3z"/><path d="M16.4 9.2a1 1 0 011.4.2l2.4 3.6-2.4 3.6a1 1 0 01-1.7-1v-.2l1.7-2.4-1.6-2.4a1 1 0 01.2-1.4z"/></g></svg>',
|
||||||
|
'fill': '<svg width="24" height="26"><path d="M16.6 12l-9-9-1.4 1.4 2.4 2.4-5.2 5.1c-.5.6-.5 1.6 0 2.2L9 19.6a1.5 1.5 0 002.2 0l5.5-5.5c.5-.6.5-1.6 0-2.2zM5.2 13L10 8.2l4.8 4.8H5.2zM19 14.5s-2 2.2-2 3.5c0 1.1.9 2 2 2a2 2 0 002-2c0-1.3-2-3.5-2-3.5z" fill-rule="nonzero"/></svg>',
|
||||||
|
'flip-horizontally': '<svg width="24" height="24"><path d="M14 19h2v-2h-2v2zm4-8h2V9h-2v2zM4 7v10c0 1.1.9 2 2 2h3v-2H6V7h3V5H6a2 2 0 00-2 2zm14-2v2h2a2 2 0 00-2-2zm-7 16h2V3h-2v18zm7-6h2v-2h-2v2zm-4-8h2V5h-2v2zm4 12a2 2 0 002-2h-2v2z" fill-rule="nonzero"/></svg>',
|
||||||
|
'flip-vertically': '<svg width="24" height="24"><path d="M5 14v2h2v-2H5zm8 4v2h2v-2h-2zm4-14H7a2 2 0 00-2 2v3h2V6h10v3h2V6a2 2 0 00-2-2zm2 14h-2v2a2 2 0 002-2zM3 11v2h18v-2H3zm6 7v2h2v-2H9zm8-4v2h2v-2h-2zM5 18c0 1.1.9 2 2 2v-2H5z" fill-rule="nonzero"/></svg>',
|
||||||
|
'format-painter': '<svg width="24" height="24"><path d="M18 5V4c0-.5-.4-1-1-1H5a1 1 0 00-1 1v4c0 .6.5 1 1 1h12c.6 0 1-.4 1-1V7h1v4H9v9c0 .6.4 1 1 1h2c.6 0 1-.4 1-1v-7h8V5h-3z" fill-rule="nonzero"/></svg>',
|
||||||
|
'format': '<svg width="24" height="24"><path fill-rule="evenodd" d="M17 5a1 1 0 010 2h-4v11a1 1 0 01-2 0V7H7a1 1 0 110-2h10z"/></svg>',
|
||||||
|
'fullscreen': '<svg width="24" height="24"><path d="M15.3 10l-1.2-1.3 2.9-3h-2.3a.9.9 0 110-1.7H19c.5 0 .9.4.9.9v4.4a.9.9 0 11-1.8 0V7l-2.9 3zm0 4l3 3v-2.3a.9.9 0 111.7 0V19c0 .5-.4.9-.9.9h-4.4a.9.9 0 110-1.8H17l-3-2.9 1.3-1.2zM10 15.4l-2.9 3h2.3a.9.9 0 110 1.7H5a.9.9 0 01-.9-.9v-4.4a.9.9 0 111.8 0V17l2.9-3 1.2 1.3zM8.7 10L5.7 7v2.3a.9.9 0 01-1.7 0V5c0-.5.4-.9.9-.9h4.4a.9.9 0 010 1.8H7l3 2.9-1.3 1.2z" fill-rule="nonzero"/></svg>',
|
||||||
|
'gallery': '<svg width="24" height="24"><path fill-rule="nonzero" d="M5 15.7l2.3-2.2c.3-.3.7-.3 1 0L11 16l5.1-5c.3-.4.8-.4 1 0l2 1.9V8H5v7.7zM5 18V19h3l1.8-1.9-2-2L5 17.9zm14-3l-2.5-2.4-6.4 6.5H19v-4zM4 6h16c.6 0 1 .4 1 1v13c0 .6-.4 1-1 1H4a1 1 0 01-1-1V7c0-.6.4-1 1-1zm6 7a2 2 0 110-4 2 2 0 010 4zM4.5 4h15a.5.5 0 110 1h-15a.5.5 0 010-1zm2-2h11a.5.5 0 110 1h-11a.5.5 0 010-1z"/></svg>',
|
||||||
|
'gamma': '<svg width="24" height="24"><path d="M4 3h16c.6 0 1 .4 1 1v16c0 .6-.4 1-1 1H4a1 1 0 01-1-1V4c0-.6.4-1 1-1zm1 2v14h14V5H5zm6.5 11.8V14L9.2 8.7a5.1 5.1 0 00-.4-.8l-.1-.2H8 8v-1l.3-.1.3-.1h.7a1 1 0 01.6.5l.1.3a8.5 8.5 0 01.3.6l1.9 4.6 2-5.2a1 1 0 011-.6.5.5 0 01.5.6L13 14v2.8a.7.7 0 01-1.4 0z" fill-rule="nonzero"/></svg>',
|
||||||
|
'help': '<svg width="24" height="24"><g fill-rule="evenodd"><path d="M12 5.5a6.5 6.5 0 00-6 9 6.3 6.3 0 001.4 2l1 1a6.3 6.3 0 003.6 1 6.5 6.5 0 006-9 6.3 6.3 0 00-1.4-2l-1-1a6.3 6.3 0 00-3.6-1zM12 4a7.8 7.8 0 015.7 2.3A8 8 0 1112 4z"/><path d="M9.6 9.7a.7.7 0 01-.7-.8c0-1.1 1.5-1.8 3.2-1.8 1.8 0 3.2.8 3.2 2.4 0 1.4-.4 2.1-1.5 2.8-.2 0-.3.1-.3.2a2 2 0 00-.8.8.8.8 0 01-1.4-.6c.3-.7.8-1 1.3-1.5l.4-.2c.7-.4.8-.6.8-1.5 0-.5-.6-.9-1.7-.9-.5 0-1 .1-1.4.3-.2 0-.3.1-.3.2v-.2c0 .4-.4.8-.8.8z" fill-rule="nonzero"/><circle cx="12" cy="16" r="1"/></g></svg>',
|
||||||
|
'highlight-bg-color': '<svg width="24" height="24"><g fill-rule="evenodd"><path id="tox-icon-highlight-bg-color__color" d="M3 18h18v3H3z"/><path fill-rule="nonzero" d="M7.7 16.7H3l3.3-3.3-.7-.8L10.2 8l4 4.1-4 4.2c-.2.2-.6.2-.8 0l-.6-.7-1.1 1.1zm5-7.5L11 7.4l3-2.9a2 2 0 012.6 0L18 6c.7.7.7 2 0 2.7l-2.9 2.9-1.8-1.8-.5-.6"/></g></svg>',
|
||||||
|
'home': '<svg width="24" height="24"><path fill-rule="nonzero" d="M10 20v-6h4v6h5v-8h3L12 3 2 12h3v8z"/></svg>',
|
||||||
|
'horizontal-rule': '<svg width="24" height="24"><path d="M4 11h16v2H4z" fill-rule="evenodd"/></svg>',
|
||||||
|
'image-options': '<svg width="24" height="24"><path d="M6 10a2 2 0 00-2 2c0 1.1.9 2 2 2a2 2 0 002-2 2 2 0 00-2-2zm12 0a2 2 0 00-2 2c0 1.1.9 2 2 2a2 2 0 002-2 2 2 0 00-2-2zm-6 0a2 2 0 00-2 2c0 1.1.9 2 2 2a2 2 0 002-2 2 2 0 00-2-2z" fill-rule="nonzero"/></svg>',
|
||||||
|
'image': '<svg width="24" height="24"><path d="M5 15.7l3.3-3.2c.3-.3.7-.3 1 0L12 15l4.1-4c.3-.4.8-.4 1 0l2 1.9V5H5v10.7zM5 18V19h3l2.8-2.9-2-2L5 17.9zm14-3l-2.5-2.4-6.4 6.5H19v-4zM4 3h16c.6 0 1 .4 1 1v16c0 .6-.4 1-1 1H4a1 1 0 01-1-1V4c0-.6.4-1 1-1zm6 8a2 2 0 100-4 2 2 0 000 4z" fill-rule="nonzero"/></svg>',
|
||||||
|
'indent': '<svg width="24" height="24"><path d="M7 5h12c.6 0 1 .4 1 1s-.4 1-1 1H7a1 1 0 110-2zm5 4h7c.6 0 1 .4 1 1s-.4 1-1 1h-7a1 1 0 010-2zm0 4h7c.6 0 1 .4 1 1s-.4 1-1 1h-7a1 1 0 010-2zm-5 4h12a1 1 0 010 2H7a1 1 0 010-2zm-2.6-3.8L6.2 12l-1.8-1.2a1 1 0 011.2-1.6l3 2a1 1 0 010 1.6l-3 2a1 1 0 11-1.2-1.6z" fill-rule="evenodd"/></svg>',
|
||||||
|
'info': '<svg width="24" height="24"><path d="M12 4a7.8 7.8 0 015.7 2.3A8 8 0 1112 4zm-1 3v2h2V7h-2zm3 10v-1h-1v-5h-3v1h1v4h-1v1h4z" fill-rule="evenodd"/></svg>',
|
||||||
|
'insert-character': '<svg width="24" height="24"><path d="M15 18h4l1-2v4h-6v-3.3l1.4-1a6 6 0 001.8-2.9 6.3 6.3 0 00-.1-4.1 5.8 5.8 0 00-3-3.2c-.6-.3-1.3-.5-2.1-.5a5.1 5.1 0 00-3.9 1.8 6.3 6.3 0 00-1.3 6 6.2 6.2 0 001.8 3l1.4.9V20H4v-4l1 2h4v-.5l-2-1L5.4 15A6.5 6.5 0 014 11c0-1 .2-1.9.6-2.7A7 7 0 016.3 6C7.1 5.4 8 5 9 4.5c1-.3 2-.5 3.1-.5a8.8 8.8 0 015.7 2 7 7 0 011.7 2.3 6 6 0 01.2 4.8c-.2.7-.6 1.3-1 1.9a7.6 7.6 0 01-3.6 2.5v.5z" fill-rule="evenodd"/></svg>',
|
||||||
|
'insert-time': '<svg width="24" height="24"><g fill-rule="nonzero"><path d="M12 19a7 7 0 100-14 7 7 0 000 14zm0 2a9 9 0 110-18 9 9 0 010 18z"/><path d="M16 12h-3V7c0-.6-.4-1-1-1a1 1 0 00-1 1v7h5c.6 0 1-.4 1-1s-.4-1-1-1z"/></g></svg>',
|
||||||
|
'invert': '<svg width="24" height="24"><path d="M18 19.3L16.5 18a5.8 5.8 0 01-3.1 1.9 6.1 6.1 0 01-5.5-1.6A5.8 5.8 0 016 14v-.3l.1-1.2A13.9 13.9 0 017.7 9l-3-3 .7-.8 2.8 2.9 9 8.9 1.5 1.6-.7.6zm0-5.5v.3l-.1 1.1-.4 1-1.2-1.2a4.3 4.3 0 00.2-1v-.2c0-.4 0-.8-.2-1.3l-.5-1.4a14.8 14.8 0 00-3-4.2L12 6a26.1 26.1 0 00-2.2 2.5l-1-1a20.9 20.9 0 012.9-3.3L12 4l1 .8a22.2 22.2 0 014 5.4c.6 1.2 1 2.4 1 3.6z" fill-rule="evenodd"/></svg>',
|
||||||
|
'italic': '<svg width="24" height="24"><path d="M16.7 4.7l-.1.9h-.3c-.6 0-1 0-1.4.3-.3.3-.4.6-.5 1.1l-2.1 9.8v.6c0 .5.4.8 1.4.8h.2l-.2.8H8l.2-.8h.2c1.1 0 1.8-.5 2-1.5l2-9.8.1-.5c0-.6-.4-.8-1.4-.8h-.3l.2-.9h5.8z" fill-rule="evenodd"/></svg>',
|
||||||
|
'language': '<svg width="24" height="24"><path d="M12 3a9 9 0 110 18 9 9 0 010-18zm4.3 13.3c-.5 1-1.2 2-2 2.9a7.5 7.5 0 003.2-2.1l-.2-.2a6 6 0 00-1-.6zm-8.6 0c-.5.2-.9.5-1.2.8.9 1 2 1.7 3.2 2a10 10 0 01-2-2.8zm3.6-.8c-.8 0-1.6.1-2.2.3.5 1 1.2 1.9 2.1 2.7zm1.5 0v3c.9-.8 1.6-1.7 2.1-2.7-.6-.2-1.4-.3-2.1-.3zm-6-2.7H4.5c.2 1 .5 2.1 1 3h.3l1.3-1a10 10 0 01-.3-2zm12.7 0h-2.3c0 .7-.1 1.4-.3 2l1.6 1.1c.5-1 .9-2 1-3.1zm-3.8 0h-3V14c1 0 2 .1 2.7.4.2-.5.3-1 .3-1.6zm-4.4 0h-3l.3 1.6c.8-.3 1.7-.4 2.7-.4v-1.3zm-5.5-5c-.7 1-1.1 2.2-1.3 3.5h2.3c0-1 .2-1.8.5-2.6l-1.5-1zm2.9 1.4v.1c-.2.6-.4 1.3-.4 2h3V9.4c-1 0-1.8-.1-2.6-.3zm6.6 0h-.1l-2.4.3v1.8h3l-.5-2.1zm3-1.4l-.3.1-1.3.8c.3.8.5 1.6.5 2.6h2.3a7.5 7.5 0 00-1.3-3.5zm-9 0l2 .2V5.5a9 9 0 00-2 2.2zm3.5-2.3V8c.6 0 1.3 0 1.9-.2a9 9 0 00-2-2.3zm-3-.7h-.1c-1.1.4-2.1 1-3 1.8l1.2.7a10 10 0 011.9-2.5zm4.4 0l.1.1a10 10 0 011.8 2.4l1.1-.7a7.5 7.5 0 00-3-1.8z"/></svg>',
|
||||||
|
'line-height': '<svg width="24" height="24"><path d="M21 5a1 1 0 01.1 2H13a1 1 0 01-.1-2H21zm0 4a1 1 0 01.1 2H13a1 1 0 01-.1-2H21zm0 4a1 1 0 01.1 2H13a1 1 0 01-.1-2H21zm0 4a1 1 0 01.1 2H13a1 1 0 01-.1-2H21zM7 3.6l3.7 3.7a1 1 0 01-1.3 1.5h-.1L8 7.3v9.2l1.3-1.3a1 1 0 011.3 0h.1c.4.4.4 1 0 1.3v.1L7 20.4l-3.7-3.7a1 1 0 011.3-1.5h.1L6 16.7V7.4L4.7 8.7a1 1 0 01-1.3 0h-.1a1 1 0 010-1.3v-.1L7 3.6z"/></svg>',
|
||||||
|
'line': '<svg width="24" height="24"><path d="M15 9l-8 8H4v-3l8-8 3 3zm1-1l-3-3 1-1h1c-.2 0 0 0 0 0l2 2s0 .2 0 0v1l-1 1zM4 18h16v2H4v-2z" fill-rule="evenodd"/></svg>',
|
||||||
|
'link': '<svg width="24" height="24"><path d="M6.2 12.3a1 1 0 011.4 1.4l-2.1 2a2 2 0 102.7 2.8l4.8-4.8a1 1 0 000-1.4 1 1 0 111.4-1.3 2.9 2.9 0 010 4L9.6 20a3.9 3.9 0 01-5.5-5.5l2-2zm11.6-.6a1 1 0 01-1.4-1.4l2-2a2 2 0 10-2.6-2.8L11 10.3a1 1 0 000 1.4A1 1 0 119.6 13a2.9 2.9 0 010-4L14.4 4a3.9 3.9 0 015.5 5.5l-2 2z" fill-rule="nonzero"/></svg>',
|
||||||
|
'list-bull-circle': '<svg width="48" height="48"><g fill-rule="evenodd"><path d="M11 16a2 2 0 100-4 2 2 0 000 4zm0 1a3 3 0 110-6 3 3 0 010 6zM11 26a2 2 0 100-4 2 2 0 000 4zm0 1a3 3 0 110-6 3 3 0 010 6zM11 36a2 2 0 100-4 2 2 0 000 4zm0 1a3 3 0 110-6 3 3 0 010 6z" fill-rule="nonzero"/><path opacity=".2" d="M18 12h22v4H18zM18 22h22v4H18zM18 32h22v4H18z"/></g></svg>',
|
||||||
|
'list-bull-default': '<svg width="48" height="48"><g fill-rule="evenodd"><circle cx="11" cy="14" r="3"/><circle cx="11" cy="24" r="3"/><circle cx="11" cy="34" r="3"/><path opacity=".2" d="M18 12h22v4H18zM18 22h22v4H18zM18 32h22v4H18z"/></g></svg>',
|
||||||
|
'list-bull-square': '<svg width="48" height="48"><g fill-rule="evenodd"><path d="M8 11h6v6H8zM8 21h6v6H8zM8 31h6v6H8z"/><path opacity=".2" d="M18 12h22v4H18zM18 22h22v4H18zM18 32h22v4H18z"/></g></svg>',
|
||||||
|
'list-num-default-rtl': '<svg width="48" height="48"><g fill-rule="evenodd"><path opacity=".2" d="M8 12h22v4H8zM8 22h22v4H8zM8 32h22v4H8z"/><path d="M37.4 17v-4.8l-1.6 1v-1.1l1.6-1h1.2V17zM33.3 17.1c-.5 0-.8-.3-.8-.7 0-.4.3-.7.8-.7.4 0 .7.3.7.7 0 .4-.3.7-.7.7zm1.7 5.7c0-1.2 1-2 2.2-2 1.3 0 2.1.8 2.1 1.8 0 .7-.3 1.2-1.3 2.2l-1.2 1v.2h2.6v1h-4.3v-.9l2-1.9c.8-.8 1-1.1 1-1.5 0-.5-.4-.8-1-.8-.5 0-.9.3-.9.9H35zm-1.7 4.3c-.5 0-.8-.3-.8-.7 0-.4.3-.7.8-.7.4 0 .7.3.7.7 0 .4-.3.7-.7.7zm3.2 7.3v-1h.7c.6 0 1-.3 1-.8 0-.4-.4-.7-1-.7s-1 .3-1 .8H35c0-1.1 1-1.8 2.2-1.8 1.2 0 2.1.6 2.1 1.6 0 .7-.4 1.2-1 1.3v.1c.7.1 1.3.7 1.3 1.4 0 1-1 1.9-2.4 1.9-1.3 0-2.2-.8-2.3-2h1.2c0 .6.5 1 1.1 1 .6 0 1-.4 1-1 0-.5-.3-.8-1-.8h-.7zm-3.3 2.7c-.4 0-.7-.3-.7-.7 0-.4.3-.7.7-.7.5 0 .8.3.8.7 0 .4-.3.7-.8.7z"/></g></svg>',
|
||||||
|
'list-num-default': '<svg width="48" height="48"><g fill-rule="evenodd"><path opacity=".2" d="M18 12h22v4H18zM18 22h22v4H18zM18 32h22v4H18z"/><path d="M10 17v-4.8l-1.5 1v-1.1l1.6-1h1.2V17h-1.2zm3.6.1c-.4 0-.7-.3-.7-.7 0-.4.3-.7.7-.7.5 0 .7.3.7.7 0 .4-.2.7-.7.7zm-5 5.7c0-1.2.8-2 2.1-2s2.1.8 2.1 1.8c0 .7-.3 1.2-1.4 2.2l-1.1 1v.2h2.6v1H8.6v-.9l2-1.9c.8-.8 1-1.1 1-1.5 0-.5-.4-.8-1-.8-.5 0-.9.3-.9.9H8.5zm6.3 4.3c-.5 0-.7-.3-.7-.7 0-.4.2-.7.7-.7.4 0 .7.3.7.7 0 .4-.3.7-.7.7zM10 34.4v-1h.7c.6 0 1-.3 1-.8 0-.4-.4-.7-1-.7s-1 .3-1 .8H8.6c0-1.1 1-1.8 2.2-1.8 1.3 0 2.1.6 2.1 1.6 0 .7-.4 1.2-1 1.3v.1c.8.1 1.3.7 1.3 1.4 0 1-1 1.9-2.4 1.9-1.3 0-2.2-.8-2.3-2h1.2c0 .6.5 1 1.1 1 .7 0 1-.4 1-1 0-.5-.3-.8-1-.8h-.7zm4.7 2.7c-.4 0-.7-.3-.7-.7 0-.4.3-.7.7-.7.5 0 .8.3.8.7 0 .4-.3.7-.8.7z"/></g></svg>',
|
||||||
|
'list-num-lower-alpha-rtl': '<svg width="48" height="48"><g fill-rule="evenodd"><path opacity=".2" d="M8 12h22v4H8zM8 22h22v4H8zM8 32h22v4H8z"/><path d="M36.5 16c-.9 0-1.5-.5-1.5-1.3s.6-1.3 1.8-1.4h1v-.4c0-.4-.2-.6-.7-.6-.4 0-.7.1-.8.4h-1.1c0-.8.8-1.4 2-1.4S39 12 39 13V16h-1.2v-.6c-.3.4-.8.7-1.4.7zm.4-.8c.6 0 1-.4 1-.9V14h-1c-.5.1-.7.3-.7.6 0 .4.3.6.7.6zM33.1 16.1c-.4 0-.7-.3-.7-.7 0-.4.3-.7.7-.7.5 0 .8.3.8.7 0 .4-.3.7-.8.7zM37.7 26c-.7 0-1.2-.2-1.5-.7v.7H35v-6.3h1.2v2.5c.3-.5.8-.9 1.5-.9 1.1 0 1.8 1 1.8 2.4 0 1.5-.7 2.4-1.8 2.4zm-.5-3.6c-.6 0-1 .5-1 1.3s.4 1.4 1 1.4c.7 0 1-.6 1-1.4 0-.8-.3-1.3-1-1.3zM33.2 26.1c-.4 0-.7-.3-.7-.7 0-.4.3-.7.7-.7.5 0 .8.3.8.7 0 .4-.3.7-.8.7zm6 7h-1c-.1-.5-.4-.8-1-.8s-1 .5-1 1.4c0 1 .4 1.4 1 1.4.5 0 .9-.2 1-.7h1c0 1-.8 1.7-2 1.7-1.4 0-2.2-.9-2.2-2.4s.8-2.4 2.2-2.4c1.2 0 2 .7 2 1.7zm-6.1 3c-.5 0-.7-.3-.7-.7 0-.4.2-.7.7-.7.4 0 .7.3.7.7 0 .4-.3.7-.7.7z"/></g></svg>',
|
||||||
|
'list-num-lower-alpha': '<svg width="48" height="48"><g fill-rule="evenodd"><path opacity=".2" d="M18 12h22v4H18zM18 22h22v4H18zM18 32h22v4H18z"/><path d="M10.3 15.2c.5 0 1-.4 1-.9V14h-1c-.5.1-.8.3-.8.6 0 .4.3.6.8.6zm-.4.9c-1 0-1.5-.6-1.5-1.4 0-.8.6-1.3 1.7-1.4h1.1v-.4c0-.4-.2-.6-.7-.6-.5 0-.8.1-.9.4h-1c0-.8.8-1.4 2-1.4 1.1 0 1.8.6 1.8 1.6V16h-1.1v-.6h-.1c-.2.4-.7.7-1.3.7zm4.6 0c-.5 0-.7-.3-.7-.7 0-.4.2-.7.7-.7.4 0 .7.3.7.7 0 .4-.3.7-.7.7zm-3.2 10c-.6 0-1.2-.3-1.4-.8v.7H8.5v-6.3H10v2.5c.3-.5.8-.9 1.4-.9 1.2 0 1.9 1 1.9 2.4 0 1.5-.7 2.4-1.9 2.4zm-.4-3.7c-.7 0-1 .5-1 1.3s.3 1.4 1 1.4c.6 0 1-.6 1-1.4 0-.8-.4-1.3-1-1.3zm4 3.7c-.5 0-.7-.3-.7-.7 0-.4.2-.7.7-.7.4 0 .7.3.7.7 0 .4-.3.7-.7.7zm-2.2 7h-1.2c0-.5-.4-.8-.9-.8-.6 0-1 .5-1 1.4 0 1 .4 1.4 1 1.4.5 0 .8-.2 1-.7h1c0 1-.8 1.7-2 1.7-1.4 0-2.2-.9-2.2-2.4s.8-2.4 2.2-2.4c1.2 0 2 .7 2 1.7zm1.8 3c-.5 0-.8-.3-.8-.7 0-.4.3-.7.8-.7.4 0 .7.3.7.7 0 .4-.3.7-.7.7z"/></g></svg>',
|
||||||
|
'list-num-lower-greek-rtl': '<svg width="48" height="48"><g fill-rule="evenodd"><path opacity=".2" d="M8 12h22v4H8zM8 22h22v4H8zM8 32h22v4H8z"/><path d="M37.4 16c-1.2 0-2-.8-2-2.3 0-1.5.8-2.4 2-2.4.6 0 1 .4 1.3 1v-.9H40v3.2c0 .4.1.5.4.5h.2v.9h-.6c-.6 0-1-.2-1-.7h-.2c-.2.4-.7.8-1.3.8zm.3-1c.6 0 1-.5 1-1.3s-.4-1.3-1-1.3-1 .5-1 1.3.4 1.4 1 1.4zM33.3 16.1c-.5 0-.8-.3-.8-.7 0-.4.3-.7.8-.7.4 0 .7.3.7.7 0 .4-.3.7-.7.7zM36 21.9c0-1.5.8-2.3 2.1-2.3 1.2 0 2 .6 2 1.6 0 .6-.3 1-.9 1.3.9.3 1.3.8 1.3 1.7 0 1.2-.7 1.9-1.8 1.9-.6 0-1.1-.3-1.4-.8v2.2H36V22zm1.8 1.2v-1h.3c.5 0 .9-.2.9-.7 0-.5-.3-.8-.9-.8-.5 0-.8.3-.8 1v2.2c0 .8.4 1.3 1 1.3s1-.4 1-1-.4-1-1.2-1h-.3zM33.3 26.1c-.5 0-.8-.3-.8-.7 0-.4.3-.7.8-.7.4 0 .7.3.7.7 0 .4-.3.7-.7.7zM37.1 34.6L34.8 30h1.4l1.7 3.5 1.7-3.5h1.1l-2.2 4.6v.1c.5.8.7 1.4.7 1.8 0 .4-.2.8-.4 1-.2.2-.6.3-1 .3-.9 0-1.3-.4-1.3-1.2 0-.5.2-1 .5-1.7l.1-.2zm.7 1a2 2 0 00-.4.9c0 .3.1.4.4.4.3 0 .4-.1.4-.4 0-.2-.1-.6-.4-1zM33.3 36.1c-.5 0-.8-.3-.8-.7 0-.4.3-.7.8-.7.4 0 .7.3.7.7 0 .4-.3.7-.7.7z"/></g></svg>',
|
||||||
|
'list-num-lower-greek': '<svg width="48" height="48"><g fill-rule="evenodd"><path opacity=".2" d="M18 12h22v4H18zM18 22h22v4H18zM18 32h22v4H18z"/><path d="M10.5 15c.7 0 1-.5 1-1.3s-.3-1.3-1-1.3c-.5 0-.9.5-.9 1.3s.4 1.4 1 1.4zm-.3 1c-1.1 0-1.8-.8-1.8-2.3 0-1.5.7-2.4 1.8-2.4.7 0 1.1.4 1.3 1h.1v-.9h1.2v3.2c0 .4.1.5.4.5h.2v.9h-.6c-.6 0-1-.2-1.1-.7h-.1c-.2.4-.7.8-1.4.8zm5 .1c-.5 0-.8-.3-.8-.7 0-.4.3-.7.7-.7.5 0 .8.3.8.7 0 .4-.3.7-.8.7zm-4.9 7v-1h.3c.6 0 1-.2 1-.7 0-.5-.4-.8-1-.8-.5 0-.8.3-.8 1v2.2c0 .8.4 1.3 1.1 1.3.6 0 1-.4 1-1s-.5-1-1.3-1h-.3zM8.6 22c0-1.5.7-2.3 2-2.3 1.2 0 2 .6 2 1.6 0 .6-.3 1-.8 1.3.8.3 1.3.8 1.3 1.7 0 1.2-.8 1.9-1.9 1.9-.6 0-1.1-.3-1.3-.8v2.2H8.5V22zm6.2 4.2c-.4 0-.7-.3-.7-.7 0-.4.3-.7.7-.7.5 0 .7.3.7.7 0 .4-.2.7-.7.7zm-4.5 8.5L8 30h1.4l1.7 3.5 1.7-3.5h1.1l-2.2 4.6v.1c.5.8.7 1.4.7 1.8 0 .4-.1.8-.4 1-.2.2-.6.3-1 .3-.9 0-1.3-.4-1.3-1.2 0-.5.2-1 .5-1.7l.1-.2zm.7 1a2 2 0 00-.4.9c0 .3.1.4.4.4.3 0 .4-.1.4-.4 0-.2-.1-.6-.4-1zm4.5.5c-.5 0-.8-.3-.8-.7 0-.4.3-.7.8-.7.4 0 .7.3.7.7 0 .4-.3.7-.7.7z"/></g></svg>',
|
||||||
|
'list-num-lower-roman-rtl': '<svg width="48" height="48"><g fill-rule="evenodd"><path opacity=".2" d="M8 12h22v4H8zM8 22h22v4H8zM8 32h22v4H8z"/><path d="M32.9 16v-1.2h-1.3V16H33zm0 10v-1.2h-1.3V26H33zm0 10v-1.2h-1.3V36H33z"/><path fill-rule="nonzero" d="M36 21h-1.5v5H36zM36 31h-1.5v5H36zM39 21h-1.5v5H39zM39 31h-1.5v5H39zM42 31h-1.5v5H42zM36 11h-1.5v5H36zM36 19h-1.5v1H36zM36 29h-1.5v1H36zM39 19h-1.5v1H39zM39 29h-1.5v1H39zM42 29h-1.5v1H42zM36 9h-1.5v1H36z"/></g></svg>',
|
||||||
|
'list-num-lower-roman': '<svg width="48" height="48"><g fill-rule="evenodd"><path opacity=".2" d="M18 12h22v4H18zM18 22h22v4H18zM18 32h22v4H18z"/><path d="M15.1 16v-1.2h1.3V16H15zm0 10v-1.2h1.3V26H15zm0 10v-1.2h1.3V36H15z"/><path fill-rule="nonzero" d="M12 21h1.5v5H12zM12 31h1.5v5H12zM9 21h1.5v5H9zM9 31h1.5v5H9zM6 31h1.5v5H6zM12 11h1.5v5H12zM12 19h1.5v1H12zM12 29h1.5v1H12zM9 19h1.5v1H9zM9 29h1.5v1H9zM6 29h1.5v1H6zM12 9h1.5v1H12z"/></g></svg>',
|
||||||
|
'list-num-upper-alpha-rtl': '<svg width="48" height="48"><g fill-rule="evenodd"><path opacity=".2" d="M8 12h22v4H8zM8 22h22v4H8zM8 32h22v4H8z"/><path d="M39.3 17l-.5-1.4h-2l-.5 1.4H35l2-6h1.6l2 6h-1.3zm-1.6-4.7l-.7 2.3h1.6l-.8-2.3zM33.4 17c-.4 0-.7-.3-.7-.7 0-.4.3-.7.7-.7.5 0 .7.3.7.7 0 .4-.2.7-.7.7zm4.7 9.9h-2.7v-6H38c1.2 0 1.9.6 1.9 1.5 0 .6-.5 1.2-1 1.3.7.1 1.3.7 1.3 1.5 0 1-.8 1.7-2 1.7zm-1.4-5v1.5h1c.6 0 1-.3 1-.8 0-.4-.4-.7-1-.7h-1zm0 4h1.1c.7 0 1.1-.3 1.1-.8 0-.6-.4-.9-1.1-.9h-1.1V26zM33 27.1c-.5 0-.8-.3-.8-.7 0-.4.3-.7.8-.7.4 0 .7.3.7.7 0 .4-.3.7-.7.7zm4.9 10c-1.8 0-2.8-1.1-2.8-3.1s1-3.1 2.8-3.1c1.4 0 2.5.9 2.6 2.2h-1.3c0-.7-.6-1.1-1.3-1.1-1 0-1.6.7-1.6 2s.6 2 1.6 2c.7 0 1.2-.4 1.4-1h1.2c-.1 1.3-1.2 2.2-2.6 2.2zm-4.5 0c-.5 0-.8-.3-.8-.7 0-.4.3-.7.8-.7.4 0 .7.3.7.7 0 .4-.3.7-.7.7z"/></g></svg>',
|
||||||
|
'list-num-upper-alpha': '<svg width="48" height="48"><g fill-rule="evenodd"><path opacity=".2" d="M18 12h22v4H18zM18 22h22v4H18zM18 32h22v4H18z"/><path d="M12.6 17l-.5-1.4h-2L9.5 17H8.3l2-6H12l2 6h-1.3zM11 12.3l-.7 2.3h1.6l-.8-2.3zm4.7 4.8c-.4 0-.7-.3-.7-.7 0-.4.3-.7.7-.7.5 0 .7.3.7.7 0 .4-.2.7-.7.7zM11.4 27H8.7v-6h2.6c1.2 0 1.9.6 1.9 1.5 0 .6-.5 1.2-1 1.3.7.1 1.3.7 1.3 1.5 0 1-.8 1.7-2 1.7zM10 22v1.5h1c.6 0 1-.3 1-.8 0-.4-.4-.7-1-.7h-1zm0 4H11c.7 0 1.1-.3 1.1-.8 0-.6-.4-.9-1.1-.9H10V26zm5.4 1.1c-.5 0-.8-.3-.8-.7 0-.4.3-.7.8-.7.4 0 .7.3.7.7 0 .4-.3.7-.7.7zm-4.1 10c-1.8 0-2.8-1.1-2.8-3.1s1-3.1 2.8-3.1c1.4 0 2.5.9 2.6 2.2h-1.3c0-.7-.6-1.1-1.3-1.1-1 0-1.6.7-1.6 2s.6 2 1.6 2c.7 0 1.2-.4 1.4-1h1.2c-.1 1.3-1.2 2.2-2.6 2.2zm4.5 0c-.5 0-.8-.3-.8-.7 0-.4.3-.7.8-.7.4 0 .7.3.7.7 0 .4-.3.7-.7.7z"/></g></svg>',
|
||||||
|
'list-num-upper-roman-rtl': '<svg width="48" height="48"><g fill-rule="evenodd"><path opacity=".2" d="M8 12h22v4H8zM8 22h22v4H8zM8 32h22v4H8z"/><path d="M31.6 17v-1.2H33V17h-1.3zm0 10v-1.2H33V27h-1.3zm0 10v-1.2H33V37h-1.3z"/><path fill-rule="nonzero" d="M34.5 20H36v7h-1.5zM34.5 30H36v7h-1.5zM37.5 20H39v7h-1.5zM37.5 30H39v7h-1.5zM40.5 30H42v7h-1.5zM34.5 10H36v7h-1.5z"/></g></svg>',
|
||||||
|
'list-num-upper-roman': '<svg width="48" height="48"><g fill-rule="evenodd"><path opacity=".2" d="M18 12h22v4H18zM18 22h22v4H18zM18 32h22v4H18z"/><path d="M15.1 17v-1.2h1.3V17H15zm0 10v-1.2h1.3V27H15zm0 10v-1.2h1.3V37H15z"/><path fill-rule="nonzero" d="M12 20h1.5v7H12zM12 30h1.5v7H12zM9 20h1.5v7H9zM9 30h1.5v7H9zM6 30h1.5v7H6zM12 10h1.5v7H12z"/></g></svg>',
|
||||||
|
'lock': '<svg width="24" height="24"><path d="M16.3 11c.2 0 .3 0 .5.2l.2.6v7.4c0 .3 0 .4-.2.6l-.6.2H7.8c-.3 0-.4 0-.6-.2a.7.7 0 01-.2-.6v-7.4c0-.3 0-.4.2-.6l.5-.2H8V8c0-.8.3-1.5.9-2.1.6-.6 1.3-.9 2.1-.9h2c.8 0 1.5.3 2.1.9.6.6.9 1.3.9 2.1v3h.3zM10 8v3h4V8a1 1 0 00-.3-.7A1 1 0 0013 7h-2a1 1 0 00-.7.3 1 1 0 00-.3.7z" fill-rule="evenodd"/></svg>',
|
||||||
|
'ltr': '<svg width="24" height="24"><path d="M11 5h7a1 1 0 010 2h-1v11a1 1 0 01-2 0V7h-2v11a1 1 0 01-2 0v-6c-.5 0-1 0-1.4-.3A3.4 3.4 0 017.8 10a3.3 3.3 0 010-2.8 3.4 3.4 0 011.8-1.8L11 5zM4.4 16.2L6.2 15l-1.8-1.2a1 1 0 011.2-1.6l3 2a1 1 0 010 1.6l-3 2a1 1 0 11-1.2-1.6z" fill-rule="evenodd"/></svg>',
|
||||||
|
'more-drawer': '<svg width="24" height="24"><path d="M6 10a2 2 0 00-2 2c0 1.1.9 2 2 2a2 2 0 002-2 2 2 0 00-2-2zm12 0a2 2 0 00-2 2c0 1.1.9 2 2 2a2 2 0 002-2 2 2 0 00-2-2zm-6 0a2 2 0 00-2 2c0 1.1.9 2 2 2a2 2 0 002-2 2 2 0 00-2-2z" fill-rule="nonzero"/></svg>',
|
||||||
|
'new-document': '<svg width="24" height="24"><path d="M14.4 3H7a2 2 0 00-2 2v14c0 1.1.9 2 2 2h10a2 2 0 002-2V7.6L14.4 3zM17 19H7V5h6v4h4v10z" fill-rule="nonzero"/></svg>',
|
||||||
|
'new-tab': '<svg width="24" height="24"><path d="M15 13l2-2v8H5V7h8l-2 2H7v8h8v-4zm4-8v5.5l-2-2-5.6 5.5H10v-1.4L15.5 7l-2-2H19z" fill-rule="evenodd"/></svg>',
|
||||||
|
'non-breaking': '<svg width="24" height="24"><path d="M11 11H8a1 1 0 110-2h3V6c0-.6.4-1 1-1s1 .4 1 1v3h3c.6 0 1 .4 1 1s-.4 1-1 1h-3v3c0 .6-.4 1-1 1a1 1 0 01-1-1v-3zm10 4v5H3v-5c0-.6.4-1 1-1s1 .4 1 1v3h14v-3c0-.6.4-1 1-1s1 .4 1 1z" fill-rule="evenodd"/></svg>',
|
||||||
|
'notice': '<svg width="24" height="24"><path d="M17.8 9.8L15.4 4 20 8.5v7L15.5 20h-7L4 15.5v-7L8.5 4h7l2.3 5.8zm0 0l2.2 5.7-2.3-5.8zM13 17v-2h-2v2h2zm0-4V7h-2v6h2z" fill-rule="evenodd"/></svg>',
|
||||||
|
'ordered-list-rtl': '<svg width="24" height="24"><path d="M6 17h8a1 1 0 010 2H6a1 1 0 010-2zm0-6h8a1 1 0 010 2H6a1 1 0 010-2zm0-6h8a1 1 0 010 2H6a1 1 0 110-2zm13-1v3.5a.5.5 0 11-1 0V5h-.5a.5.5 0 110-1H19zm-1 8.8l.2.2h1.3a.5.5 0 110 1h-1.6a1 1 0 01-.9-1V13c0-.4.3-.8.6-1l1.2-.4.2-.3a.2.2 0 00-.2-.2h-1.3a.5.5 0 01-.5-.5c0-.3.2-.5.5-.5h1.6c.5 0 .9.4.9 1v.1c0 .4-.3.8-.6 1l-1.2.4-.2.3zm2 4.2v2c0 .6-.4 1-1 1h-1.5a.5.5 0 010-1h1.2a.3.3 0 100-.6h-1.3a.4.4 0 110-.8h1.3a.3.3 0 000-.6h-1.2a.5.5 0 110-1H19c.6 0 1 .4 1 1z" fill-rule="evenodd"/></svg>',
|
||||||
|
'ordered-list': '<svg width="24" height="24"><path d="M10 17h8c.6 0 1 .4 1 1s-.4 1-1 1h-8a1 1 0 010-2zm0-6h8c.6 0 1 .4 1 1s-.4 1-1 1h-8a1 1 0 010-2zm0-6h8c.6 0 1 .4 1 1s-.4 1-1 1h-8a1 1 0 110-2zM6 4v3.5c0 .3-.2.5-.5.5a.5.5 0 01-.5-.5V5h-.5a.5.5 0 010-1H6zm-1 8.8l.2.2h1.3c.3 0 .5.2.5.5s-.2.5-.5.5H4.9a1 1 0 01-.9-1V13c0-.4.3-.8.6-1l1.2-.4.2-.3a.2.2 0 00-.2-.2H4.5a.5.5 0 01-.5-.5c0-.3.2-.5.5-.5h1.6c.5 0 .9.4.9 1v.1c0 .4-.3.8-.6 1l-1.2.4-.2.3zM7 17v2c0 .6-.4 1-1 1H4.5a.5.5 0 010-1h1.2c.2 0 .3-.1.3-.3 0-.2-.1-.3-.3-.3H4.4a.4.4 0 110-.8h1.3c.2 0 .3-.1.3-.3 0-.2-.1-.3-.3-.3H4.5a.5.5 0 110-1H6c.6 0 1 .4 1 1z" fill-rule="evenodd"/></svg>',
|
||||||
|
'orientation': '<svg width="24" height="24"><path d="M7.3 6.4L1 13l6.4 6.5 6.5-6.5-6.5-6.5zM3.7 13l3.6-3.7L11 13l-3.7 3.7-3.6-3.7zM12 6l2.8 2.7c.3.3.3.8 0 1-.3.4-.9.4-1.2 0L9.2 5.7a.8.8 0 010-1.2L13.6.2c.3-.3.9-.3 1.2 0 .3.3.3.8 0 1.1L12 4h1a9 9 0 11-4.3 16.9l1.5-1.5A7 7 0 1013 6h-1z" fill-rule="nonzero"/></svg>',
|
||||||
|
'outdent': '<svg width="24" height="24"><path d="M7 5h12c.6 0 1 .4 1 1s-.4 1-1 1H7a1 1 0 110-2zm5 4h7c.6 0 1 .4 1 1s-.4 1-1 1h-7a1 1 0 010-2zm0 4h7c.6 0 1 .4 1 1s-.4 1-1 1h-7a1 1 0 010-2zm-5 4h12a1 1 0 010 2H7a1 1 0 010-2zm1.6-3.8a1 1 0 01-1.2 1.6l-3-2a1 1 0 010-1.6l3-2a1 1 0 011.2 1.6L6.8 12l1.8 1.2z" fill-rule="evenodd"/></svg>',
|
||||||
|
'page-break': '<svg width="24" height="24"><g fill-rule="evenodd"><path d="M5 11c.6 0 1 .4 1 1s-.4 1-1 1a1 1 0 010-2zm3 0h1c.6 0 1 .4 1 1s-.4 1-1 1H8a1 1 0 010-2zm4 0c.6 0 1 .4 1 1s-.4 1-1 1a1 1 0 010-2zm3 0h1c.6 0 1 .4 1 1s-.4 1-1 1h-1a1 1 0 010-2zm4 0c.6 0 1 .4 1 1s-.4 1-1 1a1 1 0 010-2zM7 3v5h10V3c0-.6.4-1 1-1s1 .4 1 1v7H5V3c0-.6.4-1 1-1s1 .4 1 1zM6 22a1 1 0 01-1-1v-7h14v7c0 .6-.4 1-1 1a1 1 0 01-1-1v-5H7v5c0 .6-.4 1-1 1z"/></g></svg>',
|
||||||
|
'paragraph': '<svg width="24" height="24"><path fill-rule="evenodd" d="M10 5h7a1 1 0 010 2h-1v11a1 1 0 01-2 0V7h-2v11a1 1 0 01-2 0v-6c-.5 0-1 0-1.4-.3A3.4 3.4 0 016.8 10a3.3 3.3 0 010-2.8 3.4 3.4 0 011.8-1.8L10 5z"/></svg>',
|
||||||
|
'paste-column-after': '<svg width="24" height="24"><path fill-rule="evenodd" d="M12 1a3 3 0 012.8 2H18c1 0 2 .8 2 1.9V7h-2V5h-2v1c0 .6-.4 1-1 1H9a1 1 0 01-1-1V5H6v13h7v2H6c-1 0-2-.8-2-1.9V5c0-1 .8-2 1.9-2H9.2A3 3 0 0112 1zm8 7v12h-6V8h6zm-1.5 1.5h-3v9h3v-9zM12 3a1 1 0 100 2 1 1 0 000-2z"/></svg>',
|
||||||
|
'paste-column-before': '<svg width="24" height="24"><path fill-rule="evenodd" d="M12 1a3 3 0 012.8 2H18c1 0 2 .8 2 1.9V18c0 1-.8 2-1.9 2H11v-2h7V5h-2v1c0 .6-.4 1-1 1H9a1 1 0 01-1-1V5H6v2H4V5c0-1 .8-2 1.9-2H9.2A3 3 0 0112 1zm-2 7v12H4V8h6zM8.5 9.5h-3v9h3v-9zM12 3a1 1 0 100 2 1 1 0 000-2z"/></svg>',
|
||||||
|
'paste-row-after': '<svg width="24" height="24"><path fill-rule="evenodd" d="M12 1a3 3 0 012.8 2H18c1 0 2 .8 2 1.9V11h-2V5h-2v1c0 .6-.4 1-1 1H9a1 1 0 01-1-1V5H6v13h14c0 1-.8 2-1.9 2H6c-1 0-2-.8-2-1.9V5c0-1 .8-2 1.9-2H9.2A3 3 0 0112 1zm10 11v5H8v-5h14zm-1.5 1.5h-11v2h11v-2zM12 3a1 1 0 100 2 1 1 0 000-2z"/></svg>',
|
||||||
|
'paste-row-before': '<svg width="24" height="24"><path fill-rule="evenodd" d="M12 1a3 3 0 012.8 2H18c1 0 2 .8 2 1.9V7h-2V5h-2v1c0 .6-.4 1-1 1H9a1 1 0 01-1-1V5H6v13h12v-4h2v4c0 1-.8 2-1.9 2H6c-1 0-2-.8-2-1.9V5c0-1 .8-2 1.9-2H9.2A3 3 0 0112 1zm10 7v5H8V8h14zm-1.5 1.5h-11v2h11v-2zM12 3a1 1 0 100 2 1 1 0 000-2z"/></svg>',
|
||||||
|
'paste-text': '<svg width="24" height="24"><path d="M18 9V5h-2v1c0 .6-.4 1-1 1H9a1 1 0 01-1-1V5H6v13h3V9h9zM9 20H6a2 2 0 01-2-2V5c0-1.1.9-2 2-2h3.2A3 3 0 0112 1a3 3 0 012.8 2H18a2 2 0 012 2v4h1v12H9v-1zm1.5-9.5v9h9v-9h-9zM12 3a1 1 0 00-1 1c0 .5.4 1 1 1s1-.5 1-1-.4-1-1-1zm0 9h6v2h-.5l-.5-1h-1v4h.8v1h-3.6v-1h.8v-4h-1l-.5 1H12v-2z" fill-rule="nonzero"/></svg>',
|
||||||
|
'paste': '<svg width="24" height="24"><path d="M18 9V5h-2v1c0 .6-.4 1-1 1H9a1 1 0 01-1-1V5H6v13h3V9h9zM9 20H6a2 2 0 01-2-2V5c0-1.1.9-2 2-2h3.2A3 3 0 0112 1a3 3 0 012.8 2H18a2 2 0 012 2v4h1v12H9v-1zm1.5-9.5v9h9v-9h-9zM12 3a1 1 0 00-1 1c0 .5.4 1 1 1s1-.5 1-1-.4-1-1-1z" fill-rule="nonzero"/></svg>',
|
||||||
|
'permanent-pen': '<svg width="24" height="24"><path d="M10.5 17.5L8 20H3v-3l3.5-3.5a2 2 0 010-3L14 3l1 1-7.3 7.3a1 1 0 000 1.4l3.6 3.6c.4.4 1 .4 1.4 0L20 9l1 1-7.6 7.6a2 2 0 01-2.8 0l-.1-.1z" fill-rule="nonzero"/></svg>',
|
||||||
|
'plus': '<svg width="24" height="24"><path d="M12 4c.5 0 1 .4 1 .9V11h6a1 1 0 01.1 2H13v6a1 1 0 01-2 .1V13H5a1 1 0 01-.1-2H11V5c0-.6.4-1 1-1z"/></svg>',
|
||||||
|
'preferences': '<svg width="24" height="24"><path d="M20.1 13.5l-1.9.2a5.8 5.8 0 01-.6 1.5l1.2 1.5c.4.4.3 1 0 1.4l-.7.7a1 1 0 01-1.4 0l-1.5-1.2a6.2 6.2 0 01-1.5.6l-.2 1.9c0 .5-.5.9-1 .9h-1a1 1 0 01-1-.9l-.2-1.9a5.8 5.8 0 01-1.5-.6l-1.5 1.2a1 1 0 01-1.4 0l-.7-.7a1 1 0 010-1.4l1.2-1.5a6.2 6.2 0 01-.6-1.5l-1.9-.2a1 1 0 01-.9-1v-1c0-.5.4-1 .9-1l1.9-.2a5.8 5.8 0 01.6-1.5L5.2 7.3a1 1 0 010-1.4l.7-.7a1 1 0 011.4 0l1.5 1.2a6.2 6.2 0 011.5-.6l.2-1.9c0-.5.5-.9 1-.9h1c.5 0 1 .4 1 .9l.2 1.9a5.8 5.8 0 011.5.6l1.5-1.2a1 1 0 011.4 0l.7.7c.3.4.4 1 0 1.4l-1.2 1.5a6.2 6.2 0 01.6 1.5l1.9.2c.5 0 .9.5.9 1v1c0 .5-.4 1-.9 1zM12 15a3 3 0 100-6 3 3 0 000 6z" fill-rule="evenodd"/></svg>',
|
||||||
|
'preview': '<svg width="24" height="24"><path d="M3.5 12.5c.5.8 1.1 1.6 1.8 2.3 2 2 4.2 3.2 6.7 3.2s4.7-1.2 6.7-3.2a16.2 16.2 0 002.1-2.8 15.7 15.7 0 00-2.1-2.8c-2-2-4.2-3.2-6.7-3.2a9.3 9.3 0 00-6.7 3.2A16.2 16.2 0 003.2 12c0 .2.2.3.3.5zm-2.4-1l.7-1.2L4 7.8C6.2 5.4 8.9 4 12 4c3 0 5.8 1.4 8.1 3.8a18.2 18.2 0 012.8 3.7v1l-.7 1.2-2.1 2.5c-2.3 2.4-5 3.8-8.1 3.8-3 0-5.8-1.4-8.1-3.8a18.2 18.2 0 01-2.8-3.7 1 1 0 010-1zm12-3.3a2 2 0 102.7 2.6 4 4 0 11-2.6-2.6z" fill-rule="nonzero"/></svg>',
|
||||||
|
'print': '<svg width="24" height="24"><path d="M18 8H6a3 3 0 00-3 3v6h2v3h14v-3h2v-6a3 3 0 00-3-3zm-1 10H7v-4h10v4zm.5-5c-.8 0-1.5-.7-1.5-1.5s.7-1.5 1.5-1.5 1.5.7 1.5 1.5-.7 1.5-1.5 1.5zm.5-8H6v2h12V5z" fill-rule="nonzero"/></svg>',
|
||||||
|
'quote': '<svg width="24" height="24"><path d="M7.5 17h.9c.4 0 .7-.2.9-.6L11 13V8c0-.6-.4-1-1-1H6a1 1 0 00-1 1v4c0 .6.4 1 1 1h2l-1.3 2.7a1 1 0 00.8 1.3zm8 0h.9c.4 0 .7-.2.9-.6L19 13V8c0-.6-.4-1-1-1h-4a1 1 0 00-1 1v4c0 .6.4 1 1 1h2l-1.3 2.7a1 1 0 00.8 1.3z" fill-rule="nonzero"/></svg>',
|
||||||
|
'redo': '<svg width="24" height="24"><path d="M17.6 10H12c-2.8 0-4.4 1.4-4.9 3.5-.4 2 .3 4 1.4 4.6a1 1 0 11-1 1.8c-2-1.2-2.9-4.1-2.3-6.8.6-3 3-5.1 6.8-5.1h5.6l-3.3-3.3a1 1 0 111.4-1.4l5 5a1 1 0 010 1.4l-5 5a1 1 0 01-1.4-1.4l3.3-3.3z" fill-rule="nonzero"/></svg>',
|
||||||
|
'reload': '<svg width="24" height="24"><g fill-rule="nonzero"><path d="M5 22.1l-1.2-4.7v-.2a1 1 0 011-1l5 .4a1 1 0 11-.2 2l-2.2-.2a7.8 7.8 0 008.4.2 7.5 7.5 0 003.5-6.4 1 1 0 112 0 9.5 9.5 0 01-4.5 8 9.9 9.9 0 01-10.2 0l.4 1.4a1 1 0 11-2 .5zM13.6 7.4c0-.5.5-1 1-.9l2.8.2a8 8 0 00-9.5-1 7.5 7.5 0 00-3.6 7 1 1 0 01-2 0 9.5 9.5 0 014.5-8.6 10 10 0 0110.9.3l-.3-1a1 1 0 012-.5l1.1 4.8a1 1 0 01-1 1.2l-5-.4a1 1 0 01-.9-1z"/></g></svg>',
|
||||||
|
'remove-formatting': '<svg width="24" height="24"><path d="M13.2 6a1 1 0 010 .2l-2.6 10a1 1 0 01-1 .8h-.2a.8.8 0 01-.8-1l2.6-10H8a1 1 0 110-2h9a1 1 0 010 2h-3.8zM5 18h7a1 1 0 010 2H5a1 1 0 010-2zm13 1.5L16.5 18 15 19.5a.7.7 0 01-1-1l1.5-1.5-1.5-1.5a.7.7 0 011-1l1.5 1.5 1.5-1.5a.7.7 0 011 1L17.5 17l1.5 1.5a.7.7 0 01-1 1z" fill-rule="evenodd"/></svg>',
|
||||||
|
'remove': '<svg width="24" height="24"><path d="M16 7h3a1 1 0 010 2h-1v9a3 3 0 01-3 3H9a3 3 0 01-3-3V9H5a1 1 0 110-2h3V6a3 3 0 013-3h2a3 3 0 013 3v1zm-2 0V6c0-.6-.4-1-1-1h-2a1 1 0 00-1 1v1h4zm2 2H8v9c0 .6.4 1 1 1h6c.6 0 1-.4 1-1V9zm-7 3a1 1 0 012 0v4a1 1 0 01-2 0v-4zm4 0a1 1 0 012 0v4a1 1 0 01-2 0v-4z" fill-rule="nonzero"/></svg>',
|
||||||
|
'resize-handle': '<svg width="10" height="10"><g fill-rule="nonzero"><path d="M8.1 1.1A.5.5 0 119 2l-7 7A.5.5 0 111 8l7-7zM8.1 5.1A.5.5 0 119 6l-3 3A.5.5 0 115 8l3-3z"/></g></svg>',
|
||||||
|
'resize': '<svg width="24" height="24"><path d="M4 5c0-.3.1-.5.3-.7.2-.2.4-.3.7-.3h6c.3 0 .5.1.7.3.2.2.3.4.3.7 0 .3-.1.5-.3.7a1 1 0 01-.7.3H7.4L18 16.6V13c0-.3.1-.5.3-.7.2-.2.4-.3.7-.3.3 0 .5.1.7.3.2.2.3.4.3.7v6c0 .3-.1.5-.3.7a1 1 0 01-.7.3h-6a1 1 0 01-.7-.3 1 1 0 01-.3-.7c0-.3.1-.5.3-.7.2-.2.4-.3.7-.3h3.6L6 7.4V11c0 .3-.1.5-.3.7a1 1 0 01-.7.3 1 1 0 01-.7-.3A1 1 0 014 11V5z" fill-rule="evenodd"/></svg>',
|
||||||
|
'restore-draft': '<svg width="24" height="24"><g fill-rule="evenodd"><path d="M17 13c0 .6-.4 1-1 1h-4V8c0-.6.4-1 1-1s1 .4 1 1v4h2c.6 0 1 .4 1 1z"/><path d="M4.7 10H9a1 1 0 010 2H3a1 1 0 01-1-1V5a1 1 0 112 0v3l2.5-2.4a9.2 9.2 0 0110.8-1.5A9 9 0 0113.4 21c-2.4.1-4.7-.7-6.5-2.2a1 1 0 111.3-1.5 7.2 7.2 0 0011.6-3.7 7 7 0 00-3.5-7.7A7.2 7.2 0 008 7L4.7 10z" fill-rule="nonzero"/></g></svg>',
|
||||||
|
'rotate-left': '<svg width="24" height="24"><path d="M4.7 10H9a1 1 0 010 2H3a1 1 0 01-1-1V5a1 1 0 112 0v3l2.5-2.4a9.2 9.2 0 0110.8-1.5A9 9 0 0113.4 21c-2.4.1-4.7-.7-6.5-2.2a1 1 0 111.3-1.5 7.2 7.2 0 0011.6-3.7 7 7 0 00-3.5-7.7A7.2 7.2 0 008 7L4.7 10z" fill-rule="nonzero"/></svg>',
|
||||||
|
'rotate-right': '<svg width="24" height="24"><path d="M20 8V5a1 1 0 012 0v6c0 .6-.4 1-1 1h-6a1 1 0 010-2h4.3L16 7A7.2 7.2 0 007.7 6a7 7 0 003 13.1c1.9.1 3.7-.5 5-1.7a1 1 0 011.4 1.5A9.2 9.2 0 012.2 14c-.9-3.9 1-8 4.5-9.9 3.5-1.9 8-1.3 10.8 1.5L20 8z" fill-rule="nonzero"/></svg>',
|
||||||
|
'rtl': '<svg width="24" height="24"><path d="M8 5h8v2h-2v12h-2V7h-2v12H8v-7c-.5 0-1 0-1.4-.3A3.4 3.4 0 014.8 10a3.3 3.3 0 010-2.8 3.4 3.4 0 011.8-1.8L8 5zm12 11.2a1 1 0 11-1 1.6l-3-2a1 1 0 010-1.6l3-2a1 1 0 111 1.6L18.4 15l1.8 1.2z" fill-rule="evenodd"/></svg>',
|
||||||
|
'save': '<svg width="24" height="24"><path d="M5 16h14a2 2 0 012 2v2a2 2 0 01-2 2H5a2 2 0 01-2-2v-2c0-1.1.9-2 2-2zm0 2v2h14v-2H5zm10 0h2v2h-2v-2zm-4-6.4L8.7 9.3a1 1 0 10-1.4 1.4l4 4c.4.4 1 .4 1.4 0l4-4a1 1 0 10-1.4-1.4L13 11.6V4a1 1 0 00-2 0v7.6z" fill-rule="nonzero"/></svg>',
|
||||||
|
'search': '<svg width="24" height="24"><path d="M16 17.3a8 8 0 111.4-1.4l4.3 4.4a1 1 0 01-1.4 1.4l-4.4-4.3zm-5-.3a6 6 0 100-12 6 6 0 000 12z" fill-rule="nonzero"/></svg>',
|
||||||
|
'select-all': '<svg width="24" height="24"><path d="M3 5h2V3a2 2 0 00-2 2zm0 8h2v-2H3v2zm4 8h2v-2H7v2zM3 9h2V7H3v2zm10-6h-2v2h2V3zm6 0v2h2a2 2 0 00-2-2zM5 21v-2H3c0 1.1.9 2 2 2zm-2-4h2v-2H3v2zM9 3H7v2h2V3zm2 18h2v-2h-2v2zm8-8h2v-2h-2v2zm0 8a2 2 0 002-2h-2v2zm0-12h2V7h-2v2zm0 8h2v-2h-2v2zm-4 4h2v-2h-2v2zm0-16h2V3h-2v2zM7 17h10V7H7v10zm2-8h6v6H9V9z" fill-rule="nonzero"/></svg>',
|
||||||
|
'selected': '<svg width="24" height="24"><path fill-rule="nonzero" d="M6 4h12a2 2 0 012 2v12a2 2 0 01-2 2H6a2 2 0 01-2-2V6c0-1.1.9-2 2-2zm3.6 10.9L7 12.3a.7.7 0 00-1 1L9.6 17 18 8.6a.7.7 0 000-1 .7.7 0 00-1 0l-7.4 7.3z"/></svg>',
|
||||||
|
'settings': '<svg width="24" height="24"><path d="M11 6h8c.6 0 1 .4 1 1s-.4 1-1 1h-8v.3c0 .2 0 .3-.2.5l-.6.2H7.8c-.3 0-.4 0-.6-.2a.7.7 0 01-.2-.6V8H5a1 1 0 110-2h2v-.3c0-.2 0-.3.2-.5l.5-.2h2.5c.3 0 .4 0 .6.2l.2.5V6zM8 8h2V6H8v2zm9 2.8v.2h2c.6 0 1 .4 1 1s-.4 1-1 1h-2v.3c0 .2 0 .3-.2.5l-.6.2h-2.4c-.3 0-.4 0-.6-.2a.7.7 0 01-.2-.6V13H5a1 1 0 010-2h8v-.3c0-.2 0-.3.2-.5l.6-.2h2.4c.3 0 .4 0 .6.2l.2.6zM14 13h2v-2h-2v2zm-3 2.8v.2h8c.6 0 1 .4 1 1s-.4 1-1 1h-8v.3c0 .2 0 .3-.2.5l-.6.2H7.8c-.3 0-.4 0-.6-.2a.7.7 0 01-.2-.6V18H5a1 1 0 010-2h2v-.3c0-.2 0-.3.2-.5l.5-.2h2.5c.3 0 .4 0 .6.2l.2.6zM8 18h2v-2H8v2z" fill-rule="evenodd"/></svg>',
|
||||||
|
'sharpen': '<svg width="24" height="24"><path d="M16 6l4 4-8 9-8-9 4-4h8zm-4 10.2l5.5-6.2-.1-.1H12v-.3h5.1l-.2-.2H12V9h4.6l-.2-.2H12v-.3h4.1l-.2-.2H12V8h3.6l-.2-.2H8.7L6.5 10l.1.1H12v.3H6.9l.2.2H12v.3H7.3l.2.2H12v.3H7.7l.3.2h4v.3H8.2l.2.2H12v.3H8.6l.3.2H12v.3H9l.3.2H12v.3H9.5l.2.2H12v.3h-2l.2.2H12v.3h-1.6l.2.2H12v.3h-1.1l.2.2h.9v.3h-.7l.2.2h.5v.3h-.3l.3.2z" fill-rule="evenodd"/></svg>',
|
||||||
|
'sourcecode': '<svg width="24" height="24"><g fill-rule="nonzero"><path d="M9.8 15.7c.3.3.3.8 0 1-.3.4-.9.4-1.2 0l-4.4-4.1a.8.8 0 010-1.2l4.4-4.2c.3-.3.9-.3 1.2 0 .3.3.3.8 0 1.1L6 12l3.8 3.7zM14.2 15.7c-.3.3-.3.8 0 1 .4.4.9.4 1.2 0l4.4-4.1c.3-.3.3-.9 0-1.2l-4.4-4.2a.8.8 0 00-1.2 0c-.3.3-.3.8 0 1.1L18 12l-3.8 3.7z"/></g></svg>',
|
||||||
|
'spell-check': '<svg width="24" height="24"><path d="M6 8v3H5V5c0-.3.1-.5.3-.7.2-.2.4-.3.7-.3h2c.3 0 .5.1.7.3.2.2.3.4.3.7v6H8V8H6zm0-3v2h2V5H6zm13 0h-3v5h3v1h-3a1 1 0 01-.7-.3 1 1 0 01-.3-.7V5c0-.3.1-.5.3-.7.2-.2.4-.3.7-.3h3v1zm-5 1.5l-.1.7c-.1.2-.3.3-.6.3.3 0 .5.1.6.3l.1.7V10c0 .3-.1.5-.3.7a1 1 0 01-.7.3h-3V4h3c.3 0 .5.1.7.3.2.2.3.4.3.7v1.5zM13 10V8h-2v2h2zm0-3V5h-2v2h2zm3 5l1 1-6.5 7L7 15.5l1.3-1 2.2 2.2L16 12z" fill-rule="evenodd"/></svg>',
|
||||||
|
'strike-through': '<svg width="24" height="24"><g fill-rule="evenodd"><path d="M15.6 8.5c-.5-.7-1-1.1-1.3-1.3-.6-.4-1.3-.6-2-.6-2.7 0-2.8 1.7-2.8 2.1 0 1.6 1.8 2 3.2 2.3 4.4.9 4.6 2.8 4.6 3.9 0 1.4-.7 4.1-5 4.1A6.2 6.2 0 017 16.4l1.5-1.1c.4.6 1.6 2 3.7 2 1.6 0 2.5-.4 3-1.2.4-.8.3-2-.8-2.6-.7-.4-1.6-.7-2.9-1-1-.2-3.9-.8-3.9-3.6C7.6 6 10.3 5 12.4 5c2.9 0 4.2 1.6 4.7 2.4l-1.5 1.1z"/><path d="M5 11h14a1 1 0 010 2H5a1 1 0 010-2z" fill-rule="nonzero"/></g></svg>',
|
||||||
|
'subscript': '<svg width="24" height="24"><path d="M10.4 10l4.6 4.6-1.4 1.4L9 11.4 4.4 16 3 14.6 7.6 10 3 5.4 4.4 4 9 8.6 13.6 4 15 5.4 10.4 10zM21 19h-5v-1l1-.8 1.7-1.6c.3-.4.5-.8.5-1.2 0-.3 0-.6-.2-.7-.2-.2-.5-.3-.9-.3a2 2 0 00-.8.2l-.7.3-.4-1.1 1-.6 1.2-.2c.8 0 1.4.3 1.8.7.4.4.6.9.6 1.5s-.2 1.1-.5 1.6a8 8 0 01-1.3 1.3l-.6.6h2.6V19z" fill-rule="nonzero"/></svg>',
|
||||||
|
'superscript': '<svg width="24" height="24"><path d="M15 9.4L10.4 14l4.6 4.6-1.4 1.4L9 15.4 4.4 20 3 18.6 7.6 14 3 9.4 4.4 8 9 12.6 13.6 8 15 9.4zm5.9 1.6h-5v-1l1-.8 1.7-1.6c.3-.5.5-.9.5-1.3 0-.3 0-.5-.2-.7-.2-.2-.5-.3-.9-.3l-.8.2-.7.4-.4-1.2c.2-.2.5-.4 1-.5.3-.2.8-.2 1.2-.2.8 0 1.4.2 1.8.6.4.4.6 1 .6 1.6 0 .5-.2 1-.5 1.5l-1.3 1.4-.6.5h2.6V11z" fill-rule="nonzero"/></svg>',
|
||||||
|
'table-caption': '<svg width="24" height="24"><g fill-rule="nonzero"><rect width="12" height="2" x="3" y="4" rx="1"/><path d="M19 8a2 2 0 012 2v8a2 2 0 01-2 2H5a2 2 0 01-2-2v-8c0-1.1.9-2 2-2h14zM5 15v3h6v-3H5zm14 0h-6v3h6v-3zm0-5h-6v3h6v-3zM5 13h6v-3H5v3z"/></g></svg>',
|
||||||
|
'table-cell-classes': '<svg width="24" height="24"><g fill-rule="evenodd"><path fill-rule="nonzero" d="M13 4v9H3V6c0-1.1.9-2 2-2h8zm-2 2H5v5h6V6z"/><path fill-rule="nonzero" d="M13 4h6a2 2 0 012 2v7h-8v-2h6V6h-6V4z" opacity=".2"/><path d="M18 20l-2.6 1.6.7-3-2.4-2 3.1-.2 1.2-2.9 1.2 2.9 3 .2-2.3 2 .7 3z"/><path fill-rule="nonzero" d="M3 13v5c0 1.1.9 2 2 2h8v-7h-2v5H5v-5H3z" opacity=".2"/></g></svg>',
|
||||||
|
'table-cell-properties': '<svg width="24" height="24"><path fill-rule="nonzero" d="M19 4a2 2 0 012 2v12a2 2 0 01-2 2H5a2 2 0 01-2-2V6c0-1.1.9-2 2-2h14zm-8 9H5v5h6v-5zm8 0h-6v5h6v-5zm-8-7H5v5h6V6z"/></svg>',
|
||||||
|
'table-cell-select-all': '<svg width="24" height="24"><g fill-rule="evenodd"><path fill-rule="nonzero" d="M19 4a2 2 0 012 2v12a2 2 0 01-2 2H5a2 2 0 01-2-2V6c0-1.1.9-2 2-2h14zm0 2H5v12h14V6z"/><path d="M13 6v5h6v2h-6v5h-2v-5H5v-2h6V6h2z" opacity=".2"/></g></svg>',
|
||||||
|
'table-cell-select-inner': '<svg width="24" height="24"><g fill-rule="evenodd"><path fill-rule="nonzero" d="M19 4a2 2 0 012 2v12a2 2 0 01-2 2H5a2 2 0 01-2-2V6c0-1.1.9-2 2-2h14zm0 2H5v12h14V6z" opacity=".2"/><path d="M13 6v5h6v2h-6v5h-2v-5H5v-2h6V6h2z"/></g></svg>',
|
||||||
|
'table-classes': '<svg width="24" height="24"><g fill-rule="evenodd"><path fill-rule="nonzero" d="M19 4a2 2 0 012 2v7h-8v7H5a2 2 0 01-2-2V6c0-1.1.9-2 2-2h14zm-8 9H5v5h6v-5zm8-7h-6v5h6V6zm-8 0H5v5h6V6z"/><path d="M18 20l-2.6 1.6.7-3-2.4-2 3.1-.2 1.2-2.9 1.2 2.9 3 .2-2.3 2 .7 3z"/></g></svg>',
|
||||||
|
'table-delete-column': '<svg width="24" height="24"><path fill-rule="nonzero" d="M19 4a2 2 0 012 2v12a2 2 0 01-2 2H5a2 2 0 01-2-2V6c0-1.1.9-2 2-2h14zm-4 4h-2V6h-2v2H9V6H5v12h4v-2h2v2h2v-2h2v2h4V6h-4v2zm.3.5l1 1.2-3 2.3 3 2.3-1 1.2L12 13l-3.3 2.6-1-1.2 3-2.3-3-2.3 1-1.2L12 11l3.3-2.5z"/></svg>',
|
||||||
|
'table-delete-row': '<svg width="24" height="24"><path fill-rule="nonzero" d="M19 4a2 2 0 012 2v12a2 2 0 01-2 2H5a2 2 0 01-2-2V6c0-1.1.9-2 2-2h14zm0 2H5v3h2.5v2H5v2h2.5v2H5v3h14v-3h-2.5v-2H19v-2h-2.5V9H19V6zm-4.7 1.8l1.2 1L13 12l2.6 3.3-1.2 1-2.3-3-2.3 3-1.2-1L11 12 8.5 8.7l1.2-1 2.3 3 2.3-3z"/></svg>',
|
||||||
|
'table-delete-table': '<svg width="24" height="24"><g fill-rule="nonzero"><path d="M19 4a2 2 0 012 2v12a2 2 0 01-2 2H5a2 2 0 01-2-2V6c0-1.1.9-2 2-2h14zM5 6v12h14V6H5z"/><path d="M14.4 8.6l1 1-2.3 2.4 2.3 2.4-1 1-2.4-2.3-2.4 2.3-1-1 2.3-2.4-2.3-2.4 1-1 2.4 2.3z"/></g></svg>',
|
||||||
|
'table-insert-column-after': '<svg width="24" height="24"><path fill-rule="nonzero" d="M20 4c.6 0 1 .4 1 1v2a1 1 0 01-2 0V6h-8v12h8v-1a1 1 0 012 0v2c0 .5-.4 1-.9 1H5a2 2 0 01-2-2V6c0-1.1.9-2 2-2h15zM9 13H5v5h4v-5zm7-5c.5 0 1 .4 1 .9V11h2a1 1 0 01.1 2H17v2a1 1 0 01-2 .1V13h-2a1 1 0 01-.1-2H15V9c0-.6.4-1 1-1zM9 6H5v5h4V6z"/></svg>',
|
||||||
|
'table-insert-column-before': '<svg width="24" height="24"><path fill-rule="nonzero" d="M19 4a2 2 0 012 2v12a2 2 0 01-2 2H4a1 1 0 01-1-1v-2a1 1 0 012 0v1h8V6H5v1a1 1 0 11-2 0V5c0-.6.4-1 1-1h15zm0 9h-4v5h4v-5zM8 8c.5 0 1 .4 1 .9V11h2a1 1 0 01.1 2H9v2a1 1 0 01-2 .1V13H5a1 1 0 01-.1-2H7V9c0-.6.4-1 1-1zm11-2h-4v5h4V6z"/></svg>',
|
||||||
|
'table-insert-row-above': '<svg width="24" height="24"><path fill-rule="nonzero" d="M6 4a1 1 0 110 2H5v6h14V6h-1a1 1 0 010-2h2c.6 0 1 .4 1 1v13a2 2 0 01-2 2H5a2 2 0 01-2-2V5c0-.6.4-1 1-1h2zm5 10H5v4h6v-4zm8 0h-6v4h6v-4zM12 3c.5 0 1 .4 1 .9V6h2a1 1 0 010 2h-2v2a1 1 0 01-2 .1V8H9a1 1 0 010-2h2V4c0-.6.4-1 1-1z"/></svg>',
|
||||||
|
'table-insert-row-after': '<svg width="24" height="24"><path fill-rule="nonzero" d="M12 13c.5 0 1 .4 1 .9V16h2a1 1 0 01.1 2H13v2a1 1 0 01-2 .1V18H9a1 1 0 01-.1-2H11v-2c0-.6.4-1 1-1zm6 7a1 1 0 010-2h1v-6H5v6h1a1 1 0 010 2H4a1 1 0 01-1-1V6c0-1.1.9-2 2-2h14a2 2 0 012 2v13c0 .5-.4 1-.9 1H18zM11 6H5v4h6V6zm8 0h-6v4h6V6z"/></svg>',
|
||||||
|
'table-left-header': '<svg width="24" height="24"><path d="M19 4a2 2 0 012 2v12a2 2 0 01-2 2H5a2 2 0 01-2-2V6c0-1.1.9-2 2-2h14zm0 9h-4v5h4v-5zm-6 0H9v5h4v-5zm0-7H9v5h4V6zm6 0h-4v5h4V6z"/></svg>',
|
||||||
|
'table-merge-cells': '<svg width="24" height="24"><path fill-rule="nonzero" d="M19 4a2 2 0 012 2v12a2 2 0 01-2 2H5a2 2 0 01-2-2V6c0-1.1.9-2 2-2h14zM5 15.5V18h3v-2.5H5zm14-5h-9V18h9v-7.5zM19 6h-4v2.5h4V6zM8 6H5v2.5h3V6zm5 0h-3v2.5h3V6zm-8 7.5h3v-3H5v3z"/></svg>',
|
||||||
|
'table-row-numbering-rtl': '<svg width="24" height="24"><path d="M6 4a2 2 0 00-2 2v13c0 1.1.9 2 2 2h12a2 2 0 002-2V6a2 2 0 00-2-2H6zm0 12h8v3H6v-3zm11 0c.6 0 1 .4 1 1v1a1 1 0 01-2 0v-1c0-.6.4-1 1-1zM6 11h8v3H6v-3zm11 0c.6 0 1 .4 1 1v1a1 1 0 01-2 0v-1c0-.6.4-1 1-1zM6 6h8v3H6V6zm11 0c.6 0 1 .4 1 1v1a1 1 0 11-2 0V7c0-.6.4-1 1-1z"/></svg>',
|
||||||
|
'table-row-numbering': '<svg width="24" height="24"><path d="M18 4a2 2 0 012 2v13a2 2 0 01-2 2H6a2 2 0 01-2-2V6c0-1.1.9-2 2-2h12zm0 12h-8v3h8v-3zM7 16a1 1 0 00-1 1v1a1 1 0 002 0v-1c0-.6-.4-1-1-1zm11-5h-8v3h8v-3zM7 11a1 1 0 00-1 1v1a1 1 0 002 0v-1c0-.6-.4-1-1-1zm11-5h-8v3h8V6zM7 6a1 1 0 00-1 1v1a1 1 0 102 0V7c0-.6-.4-1-1-1z"/></svg>',
|
||||||
|
'table-row-properties': '<svg width="24" height="24"><path fill-rule="nonzero" d="M19 4a2 2 0 012 2v12a2 2 0 01-2 2H5a2 2 0 01-2-2V6c0-1.1.9-2 2-2h14zM5 15v3h6v-3H5zm14 0h-6v3h6v-3zm0-9h-6v3h6V6zM5 9h6V6H5v3z"/></svg>',
|
||||||
|
'table-split-cells': '<svg width="24" height="24"><path fill-rule="nonzero" d="M19 4a2 2 0 012 2v12a2 2 0 01-2 2H5a2 2 0 01-2-2V6c0-1.1.9-2 2-2h14zM8 15.5H5V18h3v-2.5zm11-5h-9V18h9v-7.5zm-2.5 1l1 1-2 2 2 2-1 1-2-2-2 2-1-1 2-2-2-2 1-1 2 2 2-2zm-8.5-1H5v3h3v-3zM19 6h-4v2.5h4V6zM8 6H5v2.5h3V6zm5 0h-3v2.5h3V6z"/></svg>',
|
||||||
|
'table-top-header': '<svg width="24" height="24"><path d="M19 4a2 2 0 012 2v12a2 2 0 01-2 2H5a2 2 0 01-2-2V6c0-1.1.9-2 2-2h14zm-8 11H5v3h6v-3zm8 0h-6v3h6v-3zm0-5h-6v3h6v-3zM5 13h6v-3H5v3z"/></svg>',
|
||||||
|
'table': '<svg width="24" height="24"><path fill-rule="nonzero" d="M19 4a2 2 0 012 2v12a2 2 0 01-2 2H5a2 2 0 01-2-2V6c0-1.1.9-2 2-2h14zM5 14v4h6v-4H5zm14 0h-6v4h6v-4zm0-6h-6v4h6V8zM5 12h6V8H5v4z"/></svg>',
|
||||||
|
'template': '<svg width="24" height="24"><path d="M19 19v-1H5v1h14zM9 16v-4a5 5 0 116 0v4h4a2 2 0 012 2v3H3v-3c0-1.1.9-2 2-2h4zm4 0v-5l.8-.6a3 3 0 10-3.6 0l.8.6v5h2z" fill-rule="nonzero"/></svg>',
|
||||||
|
'temporary-placeholder': '<svg width="24" height="24"><g fill-rule="evenodd"><path d="M9 7.6V6h2.5V4.5a.5.5 0 111 0V6H15v1.6a8 8 0 11-6 0zm-2.6 5.3a.5.5 0 00.3.6c.3 0 .6 0 .6-.3l.1-.2a5 5 0 013.3-2.8c.3-.1.4-.4.4-.6-.1-.3-.4-.5-.6-.4a6 6 0 00-4.1 3.7z"/><circle cx="14" cy="4" r="1"/><circle cx="12" cy="2" r="1"/><circle cx="10" cy="4" r="1"/></g></svg>',
|
||||||
|
'text-color': '<svg width="24" height="24"><g fill-rule="evenodd"><path id="tox-icon-text-color__color" d="M3 18h18v3H3z"/><path d="M8.7 16h-.8a.5.5 0 01-.5-.6l2.7-9c.1-.3.3-.4.5-.4h2.8c.2 0 .4.1.5.4l2.7 9a.5.5 0 01-.5.6h-.8a.5.5 0 01-.4-.4l-.7-2.2c0-.3-.3-.4-.5-.4h-3.4c-.2 0-.4.1-.5.4l-.7 2.2c0 .3-.2.4-.4.4zm2.6-7.6l-.6 2a.5.5 0 00.5.6h1.6a.5.5 0 00.5-.6l-.6-2c0-.3-.3-.4-.5-.4h-.4c-.2 0-.4.1-.5.4z"/></g></svg>',
|
||||||
|
'toc': '<svg width="24" height="24"><path d="M5 5c.6 0 1 .4 1 1s-.4 1-1 1a1 1 0 110-2zm3 0h11c.6 0 1 .4 1 1s-.4 1-1 1H8a1 1 0 110-2zm-3 8c.6 0 1 .4 1 1s-.4 1-1 1a1 1 0 010-2zm3 0h11c.6 0 1 .4 1 1s-.4 1-1 1H8a1 1 0 010-2zm0-4c.6 0 1 .4 1 1s-.4 1-1 1a1 1 0 110-2zm3 0h8c.6 0 1 .4 1 1s-.4 1-1 1h-8a1 1 0 010-2zm-3 8c.6 0 1 .4 1 1s-.4 1-1 1a1 1 0 010-2zm3 0h8c.6 0 1 .4 1 1s-.4 1-1 1h-8a1 1 0 010-2z" fill-rule="evenodd"/></svg>',
|
||||||
|
'translate': '<svg width="24" height="24"><path d="M12.7 14.3l-.3.7-.4.7-2.2-2.2-3.1 3c-.3.4-.8.4-1 0a.7.7 0 010-1l3.1-3A12.4 12.4 0 016.7 9H8a10.1 10.1 0 001.7 2.4c.5-.5 1-1.1 1.4-1.8l.9-2H4.7a.7.7 0 110-1.5h4.4v-.7c0-.4.3-.8.7-.8.4 0 .7.4.7.8v.7H15c.4 0 .8.3.8.7 0 .4-.4.8-.8.8h-1.4a12.3 12.3 0 01-1 2.4 13.5 13.5 0 01-1.7 2.3l1.9 1.8zm4.3-3l2.7 7.3a.5.5 0 01-.4.7 1 1 0 01-1-.7l-.6-1.5h-3.4l-.6 1.5a1 1 0 01-1 .7.5.5 0 01-.4-.7l2.7-7.4a1 1 0 012 0zm-2.2 4.4h2.4L16 12.5l-1.2 3.2z" fill-rule="evenodd"/></svg>',
|
||||||
|
'underline': '<svg width="24" height="24"><path d="M16 5c.6 0 1 .4 1 1v5.5a4 4 0 01-.4 1.8l-1 1.4a5.3 5.3 0 01-5.5 1 5 5 0 01-1.6-1c-.5-.4-.8-.9-1.1-1.4a4 4 0 01-.4-1.8V6c0-.6.4-1 1-1s1 .4 1 1v5.5c0 .3 0 .6.2 1l.6.7a3.3 3.3 0 002.2.8 3.4 3.4 0 002.2-.8c.3-.2.4-.5.6-.8l.2-.9V6c0-.6.4-1 1-1zM8 17h8c.6 0 1 .4 1 1s-.4 1-1 1H8a1 1 0 010-2z" fill-rule="evenodd"/></svg>',
|
||||||
|
'undo': '<svg width="24" height="24"><path d="M6.4 8H12c3.7 0 6.2 2 6.8 5.1.6 2.7-.4 5.6-2.3 6.8a1 1 0 01-1-1.8c1.1-.6 1.8-2.7 1.4-4.6-.5-2.1-2.1-3.5-4.9-3.5H6.4l3.3 3.3a1 1 0 11-1.4 1.4l-5-5a1 1 0 010-1.4l5-5a1 1 0 011.4 1.4L6.4 8z" fill-rule="nonzero"/></svg>',
|
||||||
|
'unlink': '<svg width="24" height="24"><path d="M6.2 12.3a1 1 0 011.4 1.4l-2 2a2 2 0 102.6 2.8l4.8-4.8a1 1 0 000-1.4 1 1 0 111.4-1.3 2.9 2.9 0 010 4L9.6 20a3.9 3.9 0 01-5.5-5.5l2-2zm11.6-.6a1 1 0 01-1.4-1.4l2.1-2a2 2 0 10-2.7-2.8L11 10.3a1 1 0 000 1.4A1 1 0 119.6 13a2.9 2.9 0 010-4L14.4 4a3.9 3.9 0 015.5 5.5l-2 2zM7.6 6.3a.8.8 0 01-1 1.1L3.3 4.2a.7.7 0 111-1l3.2 3.1zM5.1 8.6a.8.8 0 010 1.5H3a.8.8 0 010-1.5H5zm5-3.5a.8.8 0 01-1.5 0V3a.8.8 0 011.5 0V5zm6 11.8a.8.8 0 011-1l3.2 3.2a.8.8 0 01-1 1L16 17zm-2.2 2a.8.8 0 011.5 0V21a.8.8 0 01-1.5 0V19zm5-3.5a.7.7 0 110-1.5H21a.8.8 0 010 1.5H19z" fill-rule="nonzero"/></svg>',
|
||||||
|
'unlock': '<svg width="24" height="24"><path d="M16 5c.8 0 1.5.3 2.1.9.6.6.9 1.3.9 2.1v3h-2V8a1 1 0 00-.3-.7A1 1 0 0016 7h-2a1 1 0 00-.7.3 1 1 0 00-.3.7v3h.3c.2 0 .3 0 .5.2l.2.6v7.4c0 .3 0 .4-.2.6l-.6.2H4.8c-.3 0-.4 0-.6-.2a.7.7 0 01-.2-.6v-7.4c0-.3 0-.4.2-.6l.5-.2H11V8c0-.8.3-1.5.9-2.1.6-.6 1.3-.9 2.1-.9h2z" fill-rule="evenodd"/></svg>',
|
||||||
|
'unordered-list': '<svg width="24" height="24"><path d="M11 5h8c.6 0 1 .4 1 1s-.4 1-1 1h-8a1 1 0 010-2zm0 6h8c.6 0 1 .4 1 1s-.4 1-1 1h-8a1 1 0 010-2zm0 6h8c.6 0 1 .4 1 1s-.4 1-1 1h-8a1 1 0 010-2zM4.5 6c0-.4.1-.8.4-1 .3-.4.7-.5 1.1-.5.4 0 .8.1 1 .4.4.3.5.7.5 1.1 0 .4-.1.8-.4 1-.3.4-.7.5-1.1.5-.4 0-.8-.1-1-.4-.4-.3-.5-.7-.5-1.1zm0 6c0-.4.1-.8.4-1 .3-.4.7-.5 1.1-.5.4 0 .8.1 1 .4.4.3.5.7.5 1.1 0 .4-.1.8-.4 1-.3.4-.7.5-1.1.5-.4 0-.8-.1-1-.4-.4-.3-.5-.7-.5-1.1zm0 6c0-.4.1-.8.4-1 .3-.4.7-.5 1.1-.5.4 0 .8.1 1 .4.4.3.5.7.5 1.1 0 .4-.1.8-.4 1-.3.4-.7.5-1.1.5-.4 0-.8-.1-1-.4-.4-.3-.5-.7-.5-1.1z" fill-rule="evenodd"/></svg>',
|
||||||
|
'unselected': '<svg width="24" height="24"><path fill-rule="nonzero" d="M6 4h12a2 2 0 012 2v12a2 2 0 01-2 2H6a2 2 0 01-2-2V6c0-1.1.9-2 2-2zm0 1a1 1 0 00-1 1v12c0 .6.4 1 1 1h12c.6 0 1-.4 1-1V6c0-.6-.4-1-1-1H6z"/></svg>',
|
||||||
|
'upload': '<svg width="24" height="24"><path d="M18 19v-2a1 1 0 012 0v3c0 .6-.4 1-1 1H5a1 1 0 01-1-1v-3a1 1 0 012 0v2h12zM11 6.4L8.7 8.7a1 1 0 01-1.4-1.4l4-4a1 1 0 011.4 0l4 4a1 1 0 11-1.4 1.4L13 6.4V16a1 1 0 01-2 0V6.4z" fill-rule="nonzero"/></svg>',
|
||||||
|
'user': '<svg width="24" height="24"><path d="M12 24a12 12 0 110-24 12 12 0 010 24zm-8.7-5.3a11 11 0 0017.4 0C19.4 16.3 14.6 15 12 15c-2.6 0-7.4 1.3-8.7 3.7zM12 13c2.2 0 4-2 4-4.5S14.2 4 12 4 8 6 8 8.5 9.8 13 12 13z" fill-rule="nonzero"/></svg>',
|
||||||
|
'vertical-align': '<svg width="24" height="24"><g fill-rule="nonzero"><rect width="18" height="2" x="3" y="11" rx="1"/><path d="M12 2c.6 0 1 .4 1 1v4l2-1.3a1 1 0 011.2 1.5l-.1.1-4.1 3-4-3a1 1 0 011-1.7l2 1.5V3c0-.6.4-1 1-1zm0 11.8l4 2.9a1 1 0 01-1 1.7l-2-1.5V21c0 .5-.4 1-.9 1H12a1 1 0 01-1-1v-4l-2 1.3a1 1 0 01-1.2-.1l-.1-.1a1 1 0 01.1-1.3l.1-.1 4.1-3z"/></g></svg>',
|
||||||
|
'visualblocks': '<svg width="24" height="24"><path d="M9 19v2H7v-2h2zm-4 0v2a2 2 0 01-2-2h2zm8 0v2h-2v-2h2zm8 0a2 2 0 01-2 2v-2h2zm-4 0v2h-2v-2h2zM15 7a1 1 0 010 2v7a1 1 0 01-2 0V9h-1v7a1 1 0 01-2 0v-4a2.5 2.5 0 01-.2-5H15zM5 15v2H3v-2h2zm16 0v2h-2v-2h2zM5 11v2H3v-2h2zm16 0v2h-2v-2h2zM5 7v2H3V7h2zm16 0v2h-2V7h2zM5 3v2H3c0-1.1.9-2 2-2zm8 0v2h-2V3h2zm6 0a2 2 0 012 2h-2V3zM9 3v2H7V3h2zm8 0v2h-2V3h2z" fill-rule="evenodd"/></svg>',
|
||||||
|
'visualchars': '<svg width="24" height="24"><path d="M10 5h7a1 1 0 010 2h-1v11a1 1 0 01-2 0V7h-2v11a1 1 0 01-2 0v-6c-.5 0-1 0-1.4-.3A3.4 3.4 0 016.8 10a3.3 3.3 0 010-2.8 3.4 3.4 0 011.8-1.8L10 5z" fill-rule="evenodd"/></svg>',
|
||||||
|
'warning': '<svg width="24" height="24"><path d="M19.8 18.3c.2.5.3.9 0 1.2-.1.3-.5.5-1 .5H5.2c-.5 0-.9-.2-1-.5-.3-.3-.2-.7 0-1.2L11 4.7l.5-.5.5-.2c.2 0 .3 0 .5.2.2 0 .3.3.5.5l6.8 13.6zM12 18c.3 0 .5-.1.7-.3.2-.2.3-.4.3-.7a1 1 0 00-.3-.7 1 1 0 00-.7-.3 1 1 0 00-.7.3 1 1 0 00-.3.7c0 .3.1.5.3.7.2.2.4.3.7.3zm.7-3l.3-4a1 1 0 00-.3-.7 1 1 0 00-.7-.3 1 1 0 00-.7.3 1 1 0 00-.3.7l.3 4h1.4z" fill-rule="evenodd"/></svg>',
|
||||||
|
'zoom-in': '<svg width="24" height="24"><path d="M16 17.3a8 8 0 111.4-1.4l4.3 4.4a1 1 0 01-1.4 1.4l-4.4-4.3zm-5-.3a6 6 0 100-12 6 6 0 000 12zm-1-9a1 1 0 012 0v6a1 1 0 01-2 0V8zm-2 4a1 1 0 010-2h6a1 1 0 010 2H8z" fill-rule="nonzero"/></svg>',
|
||||||
|
'zoom-out': '<svg width="24" height="24"><path d="M16 17.3a8 8 0 111.4-1.4l4.3 4.4a1 1 0 01-1.4 1.4l-4.4-4.3zm-5-.3a6 6 0 100-12 6 6 0 000 12zm-3-5a1 1 0 010-2h6a1 1 0 010 2H8z" fill-rule="nonzero"/></svg>',
|
||||||
|
}
|
||||||
|
});
|
File diff suppressed because one or more lines are too long
|
@ -0,0 +1,7 @@
|
||||||
|
// Exports the "default" icons for usage with module loaders
|
||||||
|
// Usage:
|
||||||
|
// CommonJS:
|
||||||
|
// require('tinymce/icons/default')
|
||||||
|
// ES2015:
|
||||||
|
// import 'tinymce/icons/default'
|
||||||
|
require('./icons.js');
|
|
@ -0,0 +1,7 @@
|
||||||
|
// Exports the "advlist" plugin for usage with module loaders
|
||||||
|
// Usage:
|
||||||
|
// CommonJS:
|
||||||
|
// require('tinymce/plugins/advlist')
|
||||||
|
// ES2015:
|
||||||
|
// import 'tinymce/plugins/advlist'
|
||||||
|
require('./plugin.js');
|
|
@ -0,0 +1,261 @@
|
||||||
|
/**
|
||||||
|
* Copyright (c) Tiny Technologies, Inc. All rights reserved.
|
||||||
|
* Licensed under the LGPL or a commercial license.
|
||||||
|
* For LGPL see License.txt in the project root for license information.
|
||||||
|
* For commercial licenses see https://www.tiny.cloud/
|
||||||
|
*
|
||||||
|
* Version: 5.9.2 (2021-09-08)
|
||||||
|
*/
|
||||||
|
(function () {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
var global$1 = tinymce.util.Tools.resolve('tinymce.PluginManager');
|
||||||
|
|
||||||
|
var applyListFormat = function (editor, listName, styleValue) {
|
||||||
|
var cmd = listName === 'UL' ? 'InsertUnorderedList' : 'InsertOrderedList';
|
||||||
|
editor.execCommand(cmd, false, styleValue === false ? null : { 'list-style-type': styleValue });
|
||||||
|
};
|
||||||
|
|
||||||
|
var register$1 = function (editor) {
|
||||||
|
editor.addCommand('ApplyUnorderedListStyle', function (ui, value) {
|
||||||
|
applyListFormat(editor, 'UL', value['list-style-type']);
|
||||||
|
});
|
||||||
|
editor.addCommand('ApplyOrderedListStyle', function (ui, value) {
|
||||||
|
applyListFormat(editor, 'OL', value['list-style-type']);
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
var global = tinymce.util.Tools.resolve('tinymce.util.Tools');
|
||||||
|
|
||||||
|
var getNumberStyles = function (editor) {
|
||||||
|
var styles = editor.getParam('advlist_number_styles', 'default,lower-alpha,lower-greek,lower-roman,upper-alpha,upper-roman');
|
||||||
|
return styles ? styles.split(/[ ,]/) : [];
|
||||||
|
};
|
||||||
|
var getBulletStyles = function (editor) {
|
||||||
|
var styles = editor.getParam('advlist_bullet_styles', 'default,circle,square');
|
||||||
|
return styles ? styles.split(/[ ,]/) : [];
|
||||||
|
};
|
||||||
|
|
||||||
|
var noop = function () {
|
||||||
|
};
|
||||||
|
var constant = function (value) {
|
||||||
|
return function () {
|
||||||
|
return value;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
var identity = function (x) {
|
||||||
|
return x;
|
||||||
|
};
|
||||||
|
var never = constant(false);
|
||||||
|
var always = constant(true);
|
||||||
|
|
||||||
|
var none = function () {
|
||||||
|
return NONE;
|
||||||
|
};
|
||||||
|
var NONE = function () {
|
||||||
|
var call = function (thunk) {
|
||||||
|
return thunk();
|
||||||
|
};
|
||||||
|
var id = identity;
|
||||||
|
var me = {
|
||||||
|
fold: function (n, _s) {
|
||||||
|
return n();
|
||||||
|
},
|
||||||
|
isSome: never,
|
||||||
|
isNone: always,
|
||||||
|
getOr: id,
|
||||||
|
getOrThunk: call,
|
||||||
|
getOrDie: function (msg) {
|
||||||
|
throw new Error(msg || 'error: getOrDie called on none.');
|
||||||
|
},
|
||||||
|
getOrNull: constant(null),
|
||||||
|
getOrUndefined: constant(undefined),
|
||||||
|
or: id,
|
||||||
|
orThunk: call,
|
||||||
|
map: none,
|
||||||
|
each: noop,
|
||||||
|
bind: none,
|
||||||
|
exists: never,
|
||||||
|
forall: always,
|
||||||
|
filter: function () {
|
||||||
|
return none();
|
||||||
|
},
|
||||||
|
toArray: function () {
|
||||||
|
return [];
|
||||||
|
},
|
||||||
|
toString: constant('none()')
|
||||||
|
};
|
||||||
|
return me;
|
||||||
|
}();
|
||||||
|
var some = function (a) {
|
||||||
|
var constant_a = constant(a);
|
||||||
|
var self = function () {
|
||||||
|
return me;
|
||||||
|
};
|
||||||
|
var bind = function (f) {
|
||||||
|
return f(a);
|
||||||
|
};
|
||||||
|
var me = {
|
||||||
|
fold: function (n, s) {
|
||||||
|
return s(a);
|
||||||
|
},
|
||||||
|
isSome: always,
|
||||||
|
isNone: never,
|
||||||
|
getOr: constant_a,
|
||||||
|
getOrThunk: constant_a,
|
||||||
|
getOrDie: constant_a,
|
||||||
|
getOrNull: constant_a,
|
||||||
|
getOrUndefined: constant_a,
|
||||||
|
or: self,
|
||||||
|
orThunk: self,
|
||||||
|
map: function (f) {
|
||||||
|
return some(f(a));
|
||||||
|
},
|
||||||
|
each: function (f) {
|
||||||
|
f(a);
|
||||||
|
},
|
||||||
|
bind: bind,
|
||||||
|
exists: bind,
|
||||||
|
forall: bind,
|
||||||
|
filter: function (f) {
|
||||||
|
return f(a) ? me : NONE;
|
||||||
|
},
|
||||||
|
toArray: function () {
|
||||||
|
return [a];
|
||||||
|
},
|
||||||
|
toString: function () {
|
||||||
|
return 'some(' + a + ')';
|
||||||
|
}
|
||||||
|
};
|
||||||
|
return me;
|
||||||
|
};
|
||||||
|
var from = function (value) {
|
||||||
|
return value === null || value === undefined ? NONE : some(value);
|
||||||
|
};
|
||||||
|
var Optional = {
|
||||||
|
some: some,
|
||||||
|
none: none,
|
||||||
|
from: from
|
||||||
|
};
|
||||||
|
|
||||||
|
var isChildOfBody = function (editor, elm) {
|
||||||
|
return editor.$.contains(editor.getBody(), elm);
|
||||||
|
};
|
||||||
|
var isTableCellNode = function (node) {
|
||||||
|
return node && /^(TH|TD)$/.test(node.nodeName);
|
||||||
|
};
|
||||||
|
var isListNode = function (editor) {
|
||||||
|
return function (node) {
|
||||||
|
return node && /^(OL|UL|DL)$/.test(node.nodeName) && isChildOfBody(editor, node);
|
||||||
|
};
|
||||||
|
};
|
||||||
|
var getSelectedStyleType = function (editor) {
|
||||||
|
var listElm = editor.dom.getParent(editor.selection.getNode(), 'ol,ul');
|
||||||
|
var style = editor.dom.getStyle(listElm, 'listStyleType');
|
||||||
|
return Optional.from(style);
|
||||||
|
};
|
||||||
|
|
||||||
|
var findIndex = function (list, predicate) {
|
||||||
|
for (var index = 0; index < list.length; index++) {
|
||||||
|
var element = list[index];
|
||||||
|
if (predicate(element)) {
|
||||||
|
return index;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return -1;
|
||||||
|
};
|
||||||
|
var styleValueToText = function (styleValue) {
|
||||||
|
return styleValue.replace(/\-/g, ' ').replace(/\b\w/g, function (chr) {
|
||||||
|
return chr.toUpperCase();
|
||||||
|
});
|
||||||
|
};
|
||||||
|
var isWithinList = function (editor, e, nodeName) {
|
||||||
|
var tableCellIndex = findIndex(e.parents, isTableCellNode);
|
||||||
|
var parents = tableCellIndex !== -1 ? e.parents.slice(0, tableCellIndex) : e.parents;
|
||||||
|
var lists = global.grep(parents, isListNode(editor));
|
||||||
|
return lists.length > 0 && lists[0].nodeName === nodeName;
|
||||||
|
};
|
||||||
|
var makeSetupHandler = function (editor, nodeName) {
|
||||||
|
return function (api) {
|
||||||
|
var nodeChangeHandler = function (e) {
|
||||||
|
api.setActive(isWithinList(editor, e, nodeName));
|
||||||
|
};
|
||||||
|
editor.on('NodeChange', nodeChangeHandler);
|
||||||
|
return function () {
|
||||||
|
return editor.off('NodeChange', nodeChangeHandler);
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
var addSplitButton = function (editor, id, tooltip, cmd, nodeName, styles) {
|
||||||
|
editor.ui.registry.addSplitButton(id, {
|
||||||
|
tooltip: tooltip,
|
||||||
|
icon: nodeName === 'OL' ? 'ordered-list' : 'unordered-list',
|
||||||
|
presets: 'listpreview',
|
||||||
|
columns: 3,
|
||||||
|
fetch: function (callback) {
|
||||||
|
var items = global.map(styles, function (styleValue) {
|
||||||
|
var iconStyle = nodeName === 'OL' ? 'num' : 'bull';
|
||||||
|
var iconName = styleValue === 'disc' || styleValue === 'decimal' ? 'default' : styleValue;
|
||||||
|
var itemValue = styleValue === 'default' ? '' : styleValue;
|
||||||
|
var displayText = styleValueToText(styleValue);
|
||||||
|
return {
|
||||||
|
type: 'choiceitem',
|
||||||
|
value: itemValue,
|
||||||
|
icon: 'list-' + iconStyle + '-' + iconName,
|
||||||
|
text: displayText
|
||||||
|
};
|
||||||
|
});
|
||||||
|
callback(items);
|
||||||
|
},
|
||||||
|
onAction: function () {
|
||||||
|
return editor.execCommand(cmd);
|
||||||
|
},
|
||||||
|
onItemAction: function (_splitButtonApi, value) {
|
||||||
|
applyListFormat(editor, nodeName, value);
|
||||||
|
},
|
||||||
|
select: function (value) {
|
||||||
|
var listStyleType = getSelectedStyleType(editor);
|
||||||
|
return listStyleType.map(function (listStyle) {
|
||||||
|
return value === listStyle;
|
||||||
|
}).getOr(false);
|
||||||
|
},
|
||||||
|
onSetup: makeSetupHandler(editor, nodeName)
|
||||||
|
});
|
||||||
|
};
|
||||||
|
var addButton = function (editor, id, tooltip, cmd, nodeName, _styles) {
|
||||||
|
editor.ui.registry.addToggleButton(id, {
|
||||||
|
active: false,
|
||||||
|
tooltip: tooltip,
|
||||||
|
icon: nodeName === 'OL' ? 'ordered-list' : 'unordered-list',
|
||||||
|
onSetup: makeSetupHandler(editor, nodeName),
|
||||||
|
onAction: function () {
|
||||||
|
return editor.execCommand(cmd);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
};
|
||||||
|
var addControl = function (editor, id, tooltip, cmd, nodeName, styles) {
|
||||||
|
if (styles.length > 1) {
|
||||||
|
addSplitButton(editor, id, tooltip, cmd, nodeName, styles);
|
||||||
|
} else {
|
||||||
|
addButton(editor, id, tooltip, cmd, nodeName);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
var register = function (editor) {
|
||||||
|
addControl(editor, 'numlist', 'Numbered list', 'InsertOrderedList', 'OL', getNumberStyles(editor));
|
||||||
|
addControl(editor, 'bullist', 'Bullet list', 'InsertUnorderedList', 'UL', getBulletStyles(editor));
|
||||||
|
};
|
||||||
|
|
||||||
|
function Plugin () {
|
||||||
|
global$1.add('advlist', function (editor) {
|
||||||
|
if (editor.hasPlugin('lists')) {
|
||||||
|
register(editor);
|
||||||
|
register$1(editor);
|
||||||
|
} else {
|
||||||
|
console.error('Please use the Lists plugin together with the Advanced List plugin.');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
Plugin();
|
||||||
|
|
||||||
|
}());
|
|
@ -0,0 +1,9 @@
|
||||||
|
/**
|
||||||
|
* Copyright (c) Tiny Technologies, Inc. All rights reserved.
|
||||||
|
* Licensed under the LGPL or a commercial license.
|
||||||
|
* For LGPL see License.txt in the project root for license information.
|
||||||
|
* For commercial licenses see https://www.tiny.cloud/
|
||||||
|
*
|
||||||
|
* Version: 5.9.2 (2021-09-08)
|
||||||
|
*/
|
||||||
|
!function(){"use strict";function f(t,e,n){t.execCommand("UL"===e?"InsertUnorderedList":"InsertOrderedList",!1,!1===n?null:{"list-style-type":n})}function i(t){return function(){return t}}function t(t){return t}function e(){return s}var n=tinymce.util.Tools.resolve("tinymce.PluginManager"),g=tinymce.util.Tools.resolve("tinymce.util.Tools"),u=i(!1),l=i(!0),s={fold:function(t,e){return t()},isSome:u,isNone:l,getOr:t,getOrThunk:r,getOrDie:function(t){throw new Error(t||"error: getOrDie called on none.")},getOrNull:i(null),getOrUndefined:i(void 0),or:t,orThunk:r,map:e,each:function(){},bind:e,exists:u,forall:l,filter:function(){return s},toArray:function(){return[]},toString:i("none()")};function r(t){return t()}function d(t){return t&&/^(TH|TD)$/.test(t.nodeName)}function m(c,a){return function(s){function t(t){var e,n,r,o,i,u,l;s.setActive((e=c,r=a,i=-1!==(o=function(t,e){for(var n=0;n<t.length;n++)if(e(t[n]))return n;return-1}((n=t).parents,d))?n.parents.slice(0,o):n.parents,0<(u=g.grep(i,(l=e,function(t){return t&&/^(OL|UL|DL)$/.test(t.nodeName)&&(e=t,l.$.contains(l.getBody(),e));var e}))).length&&u[0].nodeName===r))}return c.on("NodeChange",t),function(){return c.off("NodeChange",t)}}}function c(t,e,n,r,o,i){var u,l,s,c,a,d;1<i.length?(c=r,a=o,d=i,(s=t).ui.registry.addSplitButton(e,{tooltip:n,icon:"OL"===a?"ordered-list":"unordered-list",presets:"listpreview",columns:3,fetch:function(t){t(g.map(d,function(t){return{type:"choiceitem",value:"default"===t?"":t,icon:"list-"+("OL"===a?"num":"bull")+"-"+("disc"===t||"decimal"===t?"default":t),text:t.replace(/\-/g," ").replace(/\b\w/g,function(t){return t.toUpperCase()})}}))},onAction:function(){return s.execCommand(c)},onItemAction:function(t,e){f(s,a,e)},select:function(e){var t,n=(t=s).dom.getParent(t.selection.getNode(),"ol,ul"),r=t.dom.getStyle(n,"listStyleType");return p(r).map(function(t){return e===t}).getOr(!1)},onSetup:m(s,a)})):(l=r,(u=t).ui.registry.addToggleButton(e,{active:!1,tooltip:n,icon:"OL"===o?"ordered-list":"unordered-list",onSetup:m(u,o),onAction:function(){return u.execCommand(l)}}))}var a=function(n){function t(){return o}function e(t){return t(n)}var r=i(n),o={fold:function(t,e){return e(n)},isSome:l,isNone:u,getOr:r,getOrThunk:r,getOrDie:r,getOrNull:r,getOrUndefined:r,or:t,orThunk:t,map:function(t){return a(t(n))},each:function(t){t(n)},bind:e,exists:e,forall:e,filter:function(t){return t(n)?o:s},toArray:function(){return[n]},toString:function(){return"some("+n+")"}};return o},p=function(t){return null==t?s:a(t)};n.add("advlist",function(t){var n,e,r,o;t.hasPlugin("lists")?(c(e=t,"numlist","Numbered list","InsertOrderedList","OL",(r=e.getParam("advlist_number_styles","default,lower-alpha,lower-greek,lower-roman,upper-alpha,upper-roman"))?r.split(/[ ,]/):[]),c(e,"bullist","Bullet list","InsertUnorderedList","UL",(o=e.getParam("advlist_bullet_styles","default,circle,square"))?o.split(/[ ,]/):[]),(n=t).addCommand("ApplyUnorderedListStyle",function(t,e){f(n,"UL",e["list-style-type"])}),n.addCommand("ApplyOrderedListStyle",function(t,e){f(n,"OL",e["list-style-type"])})):console.error("Please use the Lists plugin together with the Advanced List plugin.")})}();
|
|
@ -0,0 +1,7 @@
|
||||||
|
// Exports the "anchor" plugin for usage with module loaders
|
||||||
|
// Usage:
|
||||||
|
// CommonJS:
|
||||||
|
// require('tinymce/plugins/anchor')
|
||||||
|
// ES2015:
|
||||||
|
// import 'tinymce/plugins/anchor'
|
||||||
|
require('./plugin.js');
|
|
@ -0,0 +1,216 @@
|
||||||
|
/**
|
||||||
|
* Copyright (c) Tiny Technologies, Inc. All rights reserved.
|
||||||
|
* Licensed under the LGPL or a commercial license.
|
||||||
|
* For LGPL see License.txt in the project root for license information.
|
||||||
|
* For commercial licenses see https://www.tiny.cloud/
|
||||||
|
*
|
||||||
|
* Version: 5.9.2 (2021-09-08)
|
||||||
|
*/
|
||||||
|
(function () {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
var global$2 = tinymce.util.Tools.resolve('tinymce.PluginManager');
|
||||||
|
|
||||||
|
var global$1 = tinymce.util.Tools.resolve('tinymce.dom.RangeUtils');
|
||||||
|
|
||||||
|
var global = tinymce.util.Tools.resolve('tinymce.util.Tools');
|
||||||
|
|
||||||
|
var allowHtmlInNamedAnchor = function (editor) {
|
||||||
|
return editor.getParam('allow_html_in_named_anchor', false, 'boolean');
|
||||||
|
};
|
||||||
|
|
||||||
|
var namedAnchorSelector = 'a:not([href])';
|
||||||
|
var isEmptyString = function (str) {
|
||||||
|
return !str;
|
||||||
|
};
|
||||||
|
var getIdFromAnchor = function (elm) {
|
||||||
|
var id = elm.getAttribute('id') || elm.getAttribute('name');
|
||||||
|
return id || '';
|
||||||
|
};
|
||||||
|
var isAnchor = function (elm) {
|
||||||
|
return elm && elm.nodeName.toLowerCase() === 'a';
|
||||||
|
};
|
||||||
|
var isNamedAnchor = function (elm) {
|
||||||
|
return isAnchor(elm) && !elm.getAttribute('href') && getIdFromAnchor(elm) !== '';
|
||||||
|
};
|
||||||
|
var isEmptyNamedAnchor = function (elm) {
|
||||||
|
return isNamedAnchor(elm) && !elm.firstChild;
|
||||||
|
};
|
||||||
|
|
||||||
|
var removeEmptyNamedAnchorsInSelection = function (editor) {
|
||||||
|
var dom = editor.dom;
|
||||||
|
global$1(dom).walk(editor.selection.getRng(), function (nodes) {
|
||||||
|
global.each(nodes, function (node) {
|
||||||
|
if (isEmptyNamedAnchor(node)) {
|
||||||
|
dom.remove(node, false);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
|
};
|
||||||
|
var isValidId = function (id) {
|
||||||
|
return /^[A-Za-z][A-Za-z0-9\-:._]*$/.test(id);
|
||||||
|
};
|
||||||
|
var getNamedAnchor = function (editor) {
|
||||||
|
return editor.dom.getParent(editor.selection.getStart(), namedAnchorSelector);
|
||||||
|
};
|
||||||
|
var getId = function (editor) {
|
||||||
|
var anchor = getNamedAnchor(editor);
|
||||||
|
if (anchor) {
|
||||||
|
return getIdFromAnchor(anchor);
|
||||||
|
} else {
|
||||||
|
return '';
|
||||||
|
}
|
||||||
|
};
|
||||||
|
var createAnchor = function (editor, id) {
|
||||||
|
editor.undoManager.transact(function () {
|
||||||
|
if (!allowHtmlInNamedAnchor(editor)) {
|
||||||
|
editor.selection.collapse(true);
|
||||||
|
}
|
||||||
|
if (editor.selection.isCollapsed()) {
|
||||||
|
editor.insertContent(editor.dom.createHTML('a', { id: id }));
|
||||||
|
} else {
|
||||||
|
removeEmptyNamedAnchorsInSelection(editor);
|
||||||
|
editor.formatter.remove('namedAnchor', null, null, true);
|
||||||
|
editor.formatter.apply('namedAnchor', { value: id });
|
||||||
|
editor.addVisual();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
};
|
||||||
|
var updateAnchor = function (editor, id, anchorElement) {
|
||||||
|
anchorElement.removeAttribute('name');
|
||||||
|
anchorElement.id = id;
|
||||||
|
editor.addVisual();
|
||||||
|
editor.undoManager.add();
|
||||||
|
};
|
||||||
|
var insert = function (editor, id) {
|
||||||
|
var anchor = getNamedAnchor(editor);
|
||||||
|
if (anchor) {
|
||||||
|
updateAnchor(editor, id, anchor);
|
||||||
|
} else {
|
||||||
|
createAnchor(editor, id);
|
||||||
|
}
|
||||||
|
editor.focus();
|
||||||
|
};
|
||||||
|
|
||||||
|
var insertAnchor = function (editor, newId) {
|
||||||
|
if (!isValidId(newId)) {
|
||||||
|
editor.windowManager.alert('Id should start with a letter, followed only by letters, numbers, dashes, dots, colons or underscores.');
|
||||||
|
return false;
|
||||||
|
} else {
|
||||||
|
insert(editor, newId);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
var open = function (editor) {
|
||||||
|
var currentId = getId(editor);
|
||||||
|
editor.windowManager.open({
|
||||||
|
title: 'Anchor',
|
||||||
|
size: 'normal',
|
||||||
|
body: {
|
||||||
|
type: 'panel',
|
||||||
|
items: [{
|
||||||
|
name: 'id',
|
||||||
|
type: 'input',
|
||||||
|
label: 'ID',
|
||||||
|
placeholder: 'example'
|
||||||
|
}]
|
||||||
|
},
|
||||||
|
buttons: [
|
||||||
|
{
|
||||||
|
type: 'cancel',
|
||||||
|
name: 'cancel',
|
||||||
|
text: 'Cancel'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
type: 'submit',
|
||||||
|
name: 'save',
|
||||||
|
text: 'Save',
|
||||||
|
primary: true
|
||||||
|
}
|
||||||
|
],
|
||||||
|
initialData: { id: currentId },
|
||||||
|
onSubmit: function (api) {
|
||||||
|
if (insertAnchor(editor, api.getData().id)) {
|
||||||
|
api.close();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
var register$1 = function (editor) {
|
||||||
|
editor.addCommand('mceAnchor', function () {
|
||||||
|
open(editor);
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
var isNamedAnchorNode = function (node) {
|
||||||
|
return node && isEmptyString(node.attr('href')) && !isEmptyString(node.attr('id') || node.attr('name'));
|
||||||
|
};
|
||||||
|
var isEmptyNamedAnchorNode = function (node) {
|
||||||
|
return isNamedAnchorNode(node) && !node.firstChild;
|
||||||
|
};
|
||||||
|
var setContentEditable = function (state) {
|
||||||
|
return function (nodes) {
|
||||||
|
for (var i = 0; i < nodes.length; i++) {
|
||||||
|
var node = nodes[i];
|
||||||
|
if (isEmptyNamedAnchorNode(node)) {
|
||||||
|
node.attr('contenteditable', state);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
};
|
||||||
|
var setup = function (editor) {
|
||||||
|
editor.on('PreInit', function () {
|
||||||
|
editor.parser.addNodeFilter('a', setContentEditable('false'));
|
||||||
|
editor.serializer.addNodeFilter('a', setContentEditable(null));
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
var registerFormats = function (editor) {
|
||||||
|
editor.formatter.register('namedAnchor', {
|
||||||
|
inline: 'a',
|
||||||
|
selector: namedAnchorSelector,
|
||||||
|
remove: 'all',
|
||||||
|
split: true,
|
||||||
|
deep: true,
|
||||||
|
attributes: { id: '%value' },
|
||||||
|
onmatch: function (node, _fmt, _itemName) {
|
||||||
|
return isNamedAnchor(node);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
var register = function (editor) {
|
||||||
|
editor.ui.registry.addToggleButton('anchor', {
|
||||||
|
icon: 'bookmark',
|
||||||
|
tooltip: 'Anchor',
|
||||||
|
onAction: function () {
|
||||||
|
return editor.execCommand('mceAnchor');
|
||||||
|
},
|
||||||
|
onSetup: function (buttonApi) {
|
||||||
|
return editor.selection.selectorChangedWithUnbind('a:not([href])', buttonApi.setActive).unbind;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
editor.ui.registry.addMenuItem('anchor', {
|
||||||
|
icon: 'bookmark',
|
||||||
|
text: 'Anchor...',
|
||||||
|
onAction: function () {
|
||||||
|
return editor.execCommand('mceAnchor');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
function Plugin () {
|
||||||
|
global$2.add('anchor', function (editor) {
|
||||||
|
setup(editor);
|
||||||
|
register$1(editor);
|
||||||
|
register(editor);
|
||||||
|
editor.on('PreInit', function () {
|
||||||
|
registerFormats(editor);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
Plugin();
|
||||||
|
|
||||||
|
}());
|
|
@ -0,0 +1,9 @@
|
||||||
|
/**
|
||||||
|
* Copyright (c) Tiny Technologies, Inc. All rights reserved.
|
||||||
|
* Licensed under the LGPL or a commercial license.
|
||||||
|
* For LGPL see License.txt in the project root for license information.
|
||||||
|
* For commercial licenses see https://www.tiny.cloud/
|
||||||
|
*
|
||||||
|
* Version: 5.9.2 (2021-09-08)
|
||||||
|
*/
|
||||||
|
!function(){"use strict";function a(e){return e.getAttribute("id")||e.getAttribute("name")||""}function c(e){return e&&"a"===e.nodeName.toLowerCase()&&!e.getAttribute("href")&&""!==a(e)}function d(e){return e.dom.getParent(e.selection.getStart(),l)}function r(e,t){var o,a,n,r,i,l=d(e);l?(n=e,r=t,(i=l).removeAttribute("name"),i.id=r,n.addVisual(),n.undoManager.add()):(a=t,(o=e).undoManager.transact(function(){var e,n;o.getParam("allow_html_in_named_anchor",!1,"boolean")||o.selection.collapse(!0),o.selection.isCollapsed()?o.insertContent(o.dom.createHTML("a",{id:a})):(n=(e=o).dom,u(n).walk(e.selection.getRng(),function(e){s.each(e,function(e){var t;c(t=e)&&!t.firstChild&&n.remove(e,!1)})}),o.formatter.remove("namedAnchor",null,null,!0),o.formatter.apply("namedAnchor",{value:a}),o.addVisual())})),e.focus()}function i(r){return function(e){for(var t,n=0;n<e.length;n++){var o=e[n],a=void 0;!(a=t=o)||a.attr("href")||!a.attr("id")&&!a.attr("name")||t.firstChild||o.attr("contenteditable",r)}}}var e=tinymce.util.Tools.resolve("tinymce.PluginManager"),u=tinymce.util.Tools.resolve("tinymce.dom.RangeUtils"),s=tinymce.util.Tools.resolve("tinymce.util.Tools"),l="a:not([href])";e.add("anchor",function(e){var t,n,o;(t=e).on("PreInit",function(){t.parser.addNodeFilter("a",i("false")),t.serializer.addNodeFilter("a",i(null))}),(n=e).addCommand("mceAnchor",function(){var o,e,t;t=(e=d(o=n))?a(e):"",o.windowManager.open({title:"Anchor",size:"normal",body:{type:"panel",items:[{name:"id",type:"input",label:"ID",placeholder:"example"}]},buttons:[{type:"cancel",name:"cancel",text:"Cancel"},{type:"submit",name:"save",text:"Save",primary:!0}],initialData:{id:t},onSubmit:function(e){var t=o,n=e.getData().id;(/^[A-Za-z][A-Za-z0-9\-:._]*$/.test(n)?(r(t,n),0):(t.windowManager.alert("Id should start with a letter, followed only by letters, numbers, dashes, dots, colons or underscores."),1))||e.close()}})}),(o=e).ui.registry.addToggleButton("anchor",{icon:"bookmark",tooltip:"Anchor",onAction:function(){return o.execCommand("mceAnchor")},onSetup:function(e){return o.selection.selectorChangedWithUnbind("a:not([href])",e.setActive).unbind}}),o.ui.registry.addMenuItem("anchor",{icon:"bookmark",text:"Anchor...",onAction:function(){return o.execCommand("mceAnchor")}}),e.on("PreInit",function(){e.formatter.register("namedAnchor",{inline:"a",selector:l,remove:"all",split:!0,deep:!0,attributes:{id:"%value"},onmatch:c})})})}();
|
|
@ -0,0 +1,7 @@
|
||||||
|
// Exports the "autolink" plugin for usage with module loaders
|
||||||
|
// Usage:
|
||||||
|
// CommonJS:
|
||||||
|
// require('tinymce/plugins/autolink')
|
||||||
|
// ES2015:
|
||||||
|
// import 'tinymce/plugins/autolink'
|
||||||
|
require('./plugin.js');
|
|
@ -0,0 +1,207 @@
|
||||||
|
/**
|
||||||
|
* Copyright (c) Tiny Technologies, Inc. All rights reserved.
|
||||||
|
* Licensed under the LGPL or a commercial license.
|
||||||
|
* For LGPL see License.txt in the project root for license information.
|
||||||
|
* For commercial licenses see https://www.tiny.cloud/
|
||||||
|
*
|
||||||
|
* Version: 5.9.2 (2021-09-08)
|
||||||
|
*/
|
||||||
|
(function () {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
var global$1 = tinymce.util.Tools.resolve('tinymce.PluginManager');
|
||||||
|
|
||||||
|
var checkRange = function (str, substr, start) {
|
||||||
|
return substr === '' || str.length >= substr.length && str.substr(start, start + substr.length) === substr;
|
||||||
|
};
|
||||||
|
var contains = function (str, substr) {
|
||||||
|
return str.indexOf(substr) !== -1;
|
||||||
|
};
|
||||||
|
var startsWith = function (str, prefix) {
|
||||||
|
return checkRange(str, prefix, 0);
|
||||||
|
};
|
||||||
|
|
||||||
|
var global = tinymce.util.Tools.resolve('tinymce.Env');
|
||||||
|
|
||||||
|
var link = function () {
|
||||||
|
return /(?:[A-Za-z][A-Za-z\d.+-]{0,14}:\/\/(?:[-.~*+=!&;:'%@?^${}(),\w]+@)?|www\.|[-;:&=+$,.\w]+@)[A-Za-z\d-]+(?:\.[A-Za-z\d-]+)*(?::\d+)?(?:\/(?:[-+~=.,%()\/\w]*[-+~=%()\/\w])?)?(?:\?(?:[-.~*+=!&;:'%@?^${}(),\/\w]+))?(?:#(?:[-.~*+=!&;:'%@?^${}(),\/\w]+))?/g;
|
||||||
|
};
|
||||||
|
|
||||||
|
var defaultLinkPattern = new RegExp('^' + link().source + '$', 'i');
|
||||||
|
var getAutoLinkPattern = function (editor) {
|
||||||
|
return editor.getParam('autolink_pattern', defaultLinkPattern);
|
||||||
|
};
|
||||||
|
var getDefaultLinkTarget = function (editor) {
|
||||||
|
return editor.getParam('default_link_target', false);
|
||||||
|
};
|
||||||
|
var getDefaultLinkProtocol = function (editor) {
|
||||||
|
return editor.getParam('link_default_protocol', 'http', 'string');
|
||||||
|
};
|
||||||
|
|
||||||
|
var rangeEqualsDelimiterOrSpace = function (rangeString, delimiter) {
|
||||||
|
return rangeString === delimiter || rangeString === ' ' || rangeString.charCodeAt(0) === 160;
|
||||||
|
};
|
||||||
|
var handleEclipse = function (editor) {
|
||||||
|
parseCurrentLine(editor, -1, '(');
|
||||||
|
};
|
||||||
|
var handleSpacebar = function (editor) {
|
||||||
|
parseCurrentLine(editor, 0, '');
|
||||||
|
};
|
||||||
|
var handleEnter = function (editor) {
|
||||||
|
parseCurrentLine(editor, -1, '');
|
||||||
|
};
|
||||||
|
var scopeIndex = function (container, index) {
|
||||||
|
if (index < 0) {
|
||||||
|
index = 0;
|
||||||
|
}
|
||||||
|
if (container.nodeType === 3) {
|
||||||
|
var len = container.data.length;
|
||||||
|
if (index > len) {
|
||||||
|
index = len;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return index;
|
||||||
|
};
|
||||||
|
var setStart = function (rng, container, offset) {
|
||||||
|
if (container.nodeType !== 1 || container.hasChildNodes()) {
|
||||||
|
rng.setStart(container, scopeIndex(container, offset));
|
||||||
|
} else {
|
||||||
|
rng.setStartBefore(container);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
var setEnd = function (rng, container, offset) {
|
||||||
|
if (container.nodeType !== 1 || container.hasChildNodes()) {
|
||||||
|
rng.setEnd(container, scopeIndex(container, offset));
|
||||||
|
} else {
|
||||||
|
rng.setEndAfter(container);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
var hasProtocol = function (url) {
|
||||||
|
return /^([A-Za-z][A-Za-z\d.+-]*:\/\/)|mailto:/.test(url);
|
||||||
|
};
|
||||||
|
var isPunctuation = function (char) {
|
||||||
|
return /[?!,.;:]/.test(char);
|
||||||
|
};
|
||||||
|
var parseCurrentLine = function (editor, endOffset, delimiter) {
|
||||||
|
var end, endContainer, bookmark, text, prev, len, rngText;
|
||||||
|
var autoLinkPattern = getAutoLinkPattern(editor);
|
||||||
|
var defaultLinkTarget = getDefaultLinkTarget(editor);
|
||||||
|
if (editor.selection.getNode().tagName === 'A') {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
var rng = editor.selection.getRng().cloneRange();
|
||||||
|
if (rng.startOffset < 5) {
|
||||||
|
prev = rng.endContainer.previousSibling;
|
||||||
|
if (!prev) {
|
||||||
|
if (!rng.endContainer.firstChild || !rng.endContainer.firstChild.nextSibling) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
prev = rng.endContainer.firstChild.nextSibling;
|
||||||
|
}
|
||||||
|
len = prev.length;
|
||||||
|
setStart(rng, prev, len);
|
||||||
|
setEnd(rng, prev, len);
|
||||||
|
if (rng.endOffset < 5) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
end = rng.endOffset;
|
||||||
|
endContainer = prev;
|
||||||
|
} else {
|
||||||
|
endContainer = rng.endContainer;
|
||||||
|
if (endContainer.nodeType !== 3 && endContainer.firstChild) {
|
||||||
|
while (endContainer.nodeType !== 3 && endContainer.firstChild) {
|
||||||
|
endContainer = endContainer.firstChild;
|
||||||
|
}
|
||||||
|
if (endContainer.nodeType === 3) {
|
||||||
|
setStart(rng, endContainer, 0);
|
||||||
|
setEnd(rng, endContainer, endContainer.nodeValue.length);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (rng.endOffset === 1) {
|
||||||
|
end = 2;
|
||||||
|
} else {
|
||||||
|
end = rng.endOffset - 1 - endOffset;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
var start = end;
|
||||||
|
do {
|
||||||
|
setStart(rng, endContainer, end >= 2 ? end - 2 : 0);
|
||||||
|
setEnd(rng, endContainer, end >= 1 ? end - 1 : 0);
|
||||||
|
end -= 1;
|
||||||
|
rngText = rng.toString();
|
||||||
|
} while (rngText !== ' ' && rngText !== '' && rngText.charCodeAt(0) !== 160 && end - 2 >= 0 && rngText !== delimiter);
|
||||||
|
if (rangeEqualsDelimiterOrSpace(rng.toString(), delimiter)) {
|
||||||
|
setStart(rng, endContainer, end);
|
||||||
|
setEnd(rng, endContainer, start);
|
||||||
|
end += 1;
|
||||||
|
} else if (rng.startOffset === 0) {
|
||||||
|
setStart(rng, endContainer, 0);
|
||||||
|
setEnd(rng, endContainer, start);
|
||||||
|
} else {
|
||||||
|
setStart(rng, endContainer, end);
|
||||||
|
setEnd(rng, endContainer, start);
|
||||||
|
}
|
||||||
|
text = rng.toString();
|
||||||
|
if (isPunctuation(text.charAt(text.length - 1))) {
|
||||||
|
setEnd(rng, endContainer, start - 1);
|
||||||
|
}
|
||||||
|
text = rng.toString().trim();
|
||||||
|
var matches = text.match(autoLinkPattern);
|
||||||
|
var protocol = getDefaultLinkProtocol(editor);
|
||||||
|
if (matches) {
|
||||||
|
var url = matches[0];
|
||||||
|
if (startsWith(url, 'www.')) {
|
||||||
|
url = protocol + '://' + url;
|
||||||
|
} else if (contains(url, '@') && !hasProtocol(url)) {
|
||||||
|
url = 'mailto:' + url;
|
||||||
|
}
|
||||||
|
bookmark = editor.selection.getBookmark();
|
||||||
|
editor.selection.setRng(rng);
|
||||||
|
editor.execCommand('createlink', false, url);
|
||||||
|
if (defaultLinkTarget !== false) {
|
||||||
|
editor.dom.setAttrib(editor.selection.getNode(), 'target', defaultLinkTarget);
|
||||||
|
}
|
||||||
|
editor.selection.moveToBookmark(bookmark);
|
||||||
|
editor.nodeChanged();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
var setup = function (editor) {
|
||||||
|
var autoUrlDetectState;
|
||||||
|
editor.on('keydown', function (e) {
|
||||||
|
if (e.keyCode === 13) {
|
||||||
|
return handleEnter(editor);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
if (global.browser.isIE()) {
|
||||||
|
editor.on('focus', function () {
|
||||||
|
if (!autoUrlDetectState) {
|
||||||
|
autoUrlDetectState = true;
|
||||||
|
try {
|
||||||
|
editor.execCommand('AutoUrlDetect', false, true);
|
||||||
|
} catch (ex) {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
editor.on('keypress', function (e) {
|
||||||
|
if (e.keyCode === 41) {
|
||||||
|
return handleEclipse(editor);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
editor.on('keyup', function (e) {
|
||||||
|
if (e.keyCode === 32) {
|
||||||
|
return handleSpacebar(editor);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
function Plugin () {
|
||||||
|
global$1.add('autolink', function (editor) {
|
||||||
|
setup(editor);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
Plugin();
|
||||||
|
|
||||||
|
}());
|
|
@ -0,0 +1,9 @@
|
||||||
|
/**
|
||||||
|
* Copyright (c) Tiny Technologies, Inc. All rights reserved.
|
||||||
|
* Licensed under the LGPL or a commercial license.
|
||||||
|
* For LGPL see License.txt in the project root for license information.
|
||||||
|
* For commercial licenses see https://www.tiny.cloud/
|
||||||
|
*
|
||||||
|
* Version: 5.9.2 (2021-09-08)
|
||||||
|
*/
|
||||||
|
!function(){"use strict";function o(e,t){var n;return t<0&&(t=0),3!==e.nodeType||(n=e.data.length)<t&&(t=n),t}function p(e,t,n){1!==t.nodeType||t.hasChildNodes()?e.setStart(t,o(t,n)):e.setStartBefore(t)}function A(e,t,n){1!==t.nodeType||t.hasChildNodes()?e.setEnd(t,o(t,n)):e.setEndAfter(t)}function i(e,t,n){var o,i,r,a,d,s,l=e.getParam("autolink_pattern",v),f=e.getParam("default_link_target",!1);if("A"!==e.selection.getNode().tagName){var c=e.selection.getRng().cloneRange();if(c.startOffset<5){if(!(a=c.endContainer.previousSibling)){if(!c.endContainer.firstChild||!c.endContainer.firstChild.nextSibling)return;a=c.endContainer.firstChild.nextSibling}if(p(c,a,d=a.length),A(c,a,d),c.endOffset<5)return;o=c.endOffset,i=a}else{if(3!==(i=c.endContainer).nodeType&&i.firstChild){for(;3!==i.nodeType&&i.firstChild;)i=i.firstChild;3===i.nodeType&&(p(c,i,0),A(c,i,i.nodeValue.length))}o=1===c.endOffset?2:c.endOffset-1-t}for(var g,u=o;p(c,i,2<=o?o-2:0),A(c,i,1<=o?o-1:0),--o," "!==(s=c.toString())&&""!==s&&160!==s.charCodeAt(0)&&0<=o-2&&s!==n;);(g=c.toString())===n||" "===g||160===g.charCodeAt(0)?(p(c,i,o),A(c,i,u),o+=1):(0===c.startOffset?p(c,i,0):p(c,i,o),A(c,i,u)),h=c.toString(),/[?!,.;:]/.test(h.charAt(h.length-1))&&A(c,i,u-1);var h,C,m,y,k=(h=c.toString().trim()).match(l),w=e.getParam("link_default_protocol","http","string");k&&((m=C=k[0]).length>=(y="www.").length&&m.substr(0,0+y.length)===y?C=w+"://"+C:-1===C.indexOf("@")||/^([A-Za-z][A-Za-z\d.+-]*:\/\/)|mailto:/.test(C)||(C="mailto:"+C),r=e.selection.getBookmark(),e.selection.setRng(c),e.execCommand("createlink",!1,C),!1!==f&&e.dom.setAttrib(e.selection.getNode(),"target",f),e.selection.moveToBookmark(r),e.nodeChanged())}}var e=tinymce.util.Tools.resolve("tinymce.PluginManager"),r=tinymce.util.Tools.resolve("tinymce.Env"),v=new RegExp("^"+/(?:[A-Za-z][A-Za-z\d.+-]{0,14}:\/\/(?:[-.~*+=!&;:'%@?^${}(),\w]+@)?|www\.|[-;:&=+$,.\w]+@)[A-Za-z\d-]+(?:\.[A-Za-z\d-]+)*(?::\d+)?(?:\/(?:[-+~=.,%()\/\w]*[-+~=%()\/\w])?)?(?:\?(?:[-.~*+=!&;:'%@?^${}(),\/\w]+))?(?:#(?:[-.~*+=!&;:'%@?^${}(),\/\w]+))?/g.source+"$","i");e.add("autolink",function(e){var t,n;(t=e).on("keydown",function(e){13===e.keyCode&&i(t,-1,"")}),r.browser.isIE()?t.on("focus",function(){if(!n){n=!0;try{t.execCommand("AutoUrlDetect",!1,!0)}catch(e){}}}):(t.on("keypress",function(e){41===e.keyCode&&i(t,-1,"(")}),t.on("keyup",function(e){32===e.keyCode&&i(t,0,"")}))})}();
|
|
@ -0,0 +1,7 @@
|
||||||
|
// Exports the "autoresize" plugin for usage with module loaders
|
||||||
|
// Usage:
|
||||||
|
// CommonJS:
|
||||||
|
// require('tinymce/plugins/autoresize')
|
||||||
|
// ES2015:
|
||||||
|
// import 'tinymce/plugins/autoresize'
|
||||||
|
require('./plugin.js');
|
|
@ -0,0 +1,176 @@
|
||||||
|
/**
|
||||||
|
* Copyright (c) Tiny Technologies, Inc. All rights reserved.
|
||||||
|
* Licensed under the LGPL or a commercial license.
|
||||||
|
* For LGPL see License.txt in the project root for license information.
|
||||||
|
* For commercial licenses see https://www.tiny.cloud/
|
||||||
|
*
|
||||||
|
* Version: 5.9.2 (2021-09-08)
|
||||||
|
*/
|
||||||
|
(function () {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
var Cell = function (initial) {
|
||||||
|
var value = initial;
|
||||||
|
var get = function () {
|
||||||
|
return value;
|
||||||
|
};
|
||||||
|
var set = function (v) {
|
||||||
|
value = v;
|
||||||
|
};
|
||||||
|
return {
|
||||||
|
get: get,
|
||||||
|
set: set
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
var hasOwnProperty = Object.hasOwnProperty;
|
||||||
|
var has = function (obj, key) {
|
||||||
|
return hasOwnProperty.call(obj, key);
|
||||||
|
};
|
||||||
|
|
||||||
|
var global$2 = tinymce.util.Tools.resolve('tinymce.PluginManager');
|
||||||
|
|
||||||
|
var global$1 = tinymce.util.Tools.resolve('tinymce.Env');
|
||||||
|
|
||||||
|
var global = tinymce.util.Tools.resolve('tinymce.util.Delay');
|
||||||
|
|
||||||
|
var fireResizeEditor = function (editor) {
|
||||||
|
return editor.fire('ResizeEditor');
|
||||||
|
};
|
||||||
|
|
||||||
|
var getAutoResizeMinHeight = function (editor) {
|
||||||
|
return editor.getParam('min_height', editor.getElement().offsetHeight, 'number');
|
||||||
|
};
|
||||||
|
var getAutoResizeMaxHeight = function (editor) {
|
||||||
|
return editor.getParam('max_height', 0, 'number');
|
||||||
|
};
|
||||||
|
var getAutoResizeOverflowPadding = function (editor) {
|
||||||
|
return editor.getParam('autoresize_overflow_padding', 1, 'number');
|
||||||
|
};
|
||||||
|
var getAutoResizeBottomMargin = function (editor) {
|
||||||
|
return editor.getParam('autoresize_bottom_margin', 50, 'number');
|
||||||
|
};
|
||||||
|
var shouldAutoResizeOnInit = function (editor) {
|
||||||
|
return editor.getParam('autoresize_on_init', true, 'boolean');
|
||||||
|
};
|
||||||
|
|
||||||
|
var isFullscreen = function (editor) {
|
||||||
|
return editor.plugins.fullscreen && editor.plugins.fullscreen.isFullscreen();
|
||||||
|
};
|
||||||
|
var wait = function (editor, oldSize, times, interval, callback) {
|
||||||
|
global.setEditorTimeout(editor, function () {
|
||||||
|
resize(editor, oldSize);
|
||||||
|
if (times--) {
|
||||||
|
wait(editor, oldSize, times, interval, callback);
|
||||||
|
} else if (callback) {
|
||||||
|
callback();
|
||||||
|
}
|
||||||
|
}, interval);
|
||||||
|
};
|
||||||
|
var toggleScrolling = function (editor, state) {
|
||||||
|
var body = editor.getBody();
|
||||||
|
if (body) {
|
||||||
|
body.style.overflowY = state ? '' : 'hidden';
|
||||||
|
if (!state) {
|
||||||
|
body.scrollTop = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
var parseCssValueToInt = function (dom, elm, name, computed) {
|
||||||
|
var value = parseInt(dom.getStyle(elm, name, computed), 10);
|
||||||
|
return isNaN(value) ? 0 : value;
|
||||||
|
};
|
||||||
|
var resize = function (editor, oldSize) {
|
||||||
|
var dom = editor.dom;
|
||||||
|
var doc = editor.getDoc();
|
||||||
|
if (!doc) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (isFullscreen(editor)) {
|
||||||
|
toggleScrolling(editor, true);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
var docEle = doc.documentElement;
|
||||||
|
var resizeBottomMargin = getAutoResizeBottomMargin(editor);
|
||||||
|
var resizeHeight = getAutoResizeMinHeight(editor);
|
||||||
|
var marginTop = parseCssValueToInt(dom, docEle, 'margin-top', true);
|
||||||
|
var marginBottom = parseCssValueToInt(dom, docEle, 'margin-bottom', true);
|
||||||
|
var contentHeight = docEle.offsetHeight + marginTop + marginBottom + resizeBottomMargin;
|
||||||
|
if (contentHeight < 0) {
|
||||||
|
contentHeight = 0;
|
||||||
|
}
|
||||||
|
var containerHeight = editor.getContainer().offsetHeight;
|
||||||
|
var contentAreaHeight = editor.getContentAreaContainer().offsetHeight;
|
||||||
|
var chromeHeight = containerHeight - contentAreaHeight;
|
||||||
|
if (contentHeight + chromeHeight > getAutoResizeMinHeight(editor)) {
|
||||||
|
resizeHeight = contentHeight + chromeHeight;
|
||||||
|
}
|
||||||
|
var maxHeight = getAutoResizeMaxHeight(editor);
|
||||||
|
if (maxHeight && resizeHeight > maxHeight) {
|
||||||
|
resizeHeight = maxHeight;
|
||||||
|
toggleScrolling(editor, true);
|
||||||
|
} else {
|
||||||
|
toggleScrolling(editor, false);
|
||||||
|
}
|
||||||
|
if (resizeHeight !== oldSize.get()) {
|
||||||
|
var deltaSize = resizeHeight - oldSize.get();
|
||||||
|
dom.setStyle(editor.getContainer(), 'height', resizeHeight + 'px');
|
||||||
|
oldSize.set(resizeHeight);
|
||||||
|
fireResizeEditor(editor);
|
||||||
|
if (global$1.browser.isSafari() && global$1.mac) {
|
||||||
|
var win = editor.getWin();
|
||||||
|
win.scrollTo(win.pageXOffset, win.pageYOffset);
|
||||||
|
}
|
||||||
|
if (editor.hasFocus()) {
|
||||||
|
editor.selection.scrollIntoView(editor.selection.getNode());
|
||||||
|
}
|
||||||
|
if (global$1.webkit && deltaSize < 0) {
|
||||||
|
resize(editor, oldSize);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
var setup = function (editor, oldSize) {
|
||||||
|
editor.on('init', function () {
|
||||||
|
var overflowPadding = getAutoResizeOverflowPadding(editor);
|
||||||
|
var dom = editor.dom;
|
||||||
|
dom.setStyles(editor.getDoc().documentElement, { height: 'auto' });
|
||||||
|
dom.setStyles(editor.getBody(), {
|
||||||
|
'paddingLeft': overflowPadding,
|
||||||
|
'paddingRight': overflowPadding,
|
||||||
|
'min-height': 0
|
||||||
|
});
|
||||||
|
});
|
||||||
|
editor.on('NodeChange SetContent keyup FullscreenStateChanged ResizeContent', function () {
|
||||||
|
resize(editor, oldSize);
|
||||||
|
});
|
||||||
|
if (shouldAutoResizeOnInit(editor)) {
|
||||||
|
editor.on('init', function () {
|
||||||
|
wait(editor, oldSize, 20, 100, function () {
|
||||||
|
wait(editor, oldSize, 5, 1000);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
var register = function (editor, oldSize) {
|
||||||
|
editor.addCommand('mceAutoResize', function () {
|
||||||
|
resize(editor, oldSize);
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
function Plugin () {
|
||||||
|
global$2.add('autoresize', function (editor) {
|
||||||
|
if (!has(editor.settings, 'resize')) {
|
||||||
|
editor.settings.resize = false;
|
||||||
|
}
|
||||||
|
if (!editor.inline) {
|
||||||
|
var oldSize = Cell(0);
|
||||||
|
register(editor, oldSize);
|
||||||
|
setup(editor, oldSize);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
Plugin();
|
||||||
|
|
||||||
|
}());
|
|
@ -0,0 +1,9 @@
|
||||||
|
/**
|
||||||
|
* Copyright (c) Tiny Technologies, Inc. All rights reserved.
|
||||||
|
* Licensed under the LGPL or a commercial license.
|
||||||
|
* For LGPL see License.txt in the project root for license information.
|
||||||
|
* For commercial licenses see https://www.tiny.cloud/
|
||||||
|
*
|
||||||
|
* Version: 5.9.2 (2021-09-08)
|
||||||
|
*/
|
||||||
|
!function(){"use strict";function d(e){return e.getParam("min_height",e.getElement().offsetHeight,"number")}function h(e,t){var n=e.getBody();n&&(n.style.overflowY=t?"":"hidden",t||(n.scrollTop=0))}function y(e,t,n,i){var o=parseInt(e.getStyle(t,n,i),10);return isNaN(o)?0:o}var g=Object.hasOwnProperty,e=tinymce.util.Tools.resolve("tinymce.PluginManager"),p=tinymce.util.Tools.resolve("tinymce.Env"),r=tinymce.util.Tools.resolve("tinymce.util.Delay"),u=function(e,t,n,i,o){r.setEditorTimeout(e,function(){v(e,t),n--?u(e,t,n,i,o):o&&o()},i)},v=function(e,t){var n,i,o,r,s,a,g,u,l,c,m=e.dom,f=e.getDoc();f&&(e.plugins.fullscreen&&e.plugins.fullscreen.isFullscreen()?h(e,!0):(n=f.documentElement,i=e.getParam("autoresize_bottom_margin",50,"number"),o=d(e),r=y(m,n,"margin-top",!0),s=y(m,n,"margin-bottom",!0),(a=(a=n.offsetHeight+r+s+i)<0?0:a)+(g=e.getContainer().offsetHeight-e.getContentAreaContainer().offsetHeight)>d(e)&&(o=a+g),(u=e.getParam("max_height",0,"number"))&&u<o?(o=u,h(e,!0)):h(e,!1),o!==t.get()&&(l=o-t.get(),m.setStyle(e.getContainer(),"height",o+"px"),t.set(o),e.fire("ResizeEditor"),p.browser.isSafari()&&p.mac&&(c=e.getWin()).scrollTo(c.pageXOffset,c.pageYOffset),e.hasFocus()&&e.selection.scrollIntoView(e.selection.getNode()),p.webkit&&l<0&&v(e,t))))};e.add("autoresize",function(e){var t,n,i,o,r,s,a=e.settings;g.call(a,"resize")||(e.settings.resize=!1),e.inline||(s=0,r=t={get:function(){return s},set:function(e){s=e}},(o=e).addCommand("mceAutoResize",function(){v(o,r)}),i=t,(n=e).on("init",function(){var e=n.getParam("autoresize_overflow_padding",1,"number"),t=n.dom;t.setStyles(n.getDoc().documentElement,{height:"auto"}),t.setStyles(n.getBody(),{paddingLeft:e,paddingRight:e,"min-height":0})}),n.on("NodeChange SetContent keyup FullscreenStateChanged ResizeContent",function(){v(n,i)}),n.getParam("autoresize_on_init",!0,"boolean")&&n.on("init",function(){u(n,i,20,100,function(){u(n,i,5,1e3)})}))})}();
|
|
@ -0,0 +1,7 @@
|
||||||
|
// Exports the "autosave" plugin for usage with module loaders
|
||||||
|
// Usage:
|
||||||
|
// CommonJS:
|
||||||
|
// require('tinymce/plugins/autosave')
|
||||||
|
// ES2015:
|
||||||
|
// import 'tinymce/plugins/autosave'
|
||||||
|
require('./plugin.js');
|
|
@ -0,0 +1,212 @@
|
||||||
|
/**
|
||||||
|
* Copyright (c) Tiny Technologies, Inc. All rights reserved.
|
||||||
|
* Licensed under the LGPL or a commercial license.
|
||||||
|
* For LGPL see License.txt in the project root for license information.
|
||||||
|
* For commercial licenses see https://www.tiny.cloud/
|
||||||
|
*
|
||||||
|
* Version: 5.9.2 (2021-09-08)
|
||||||
|
*/
|
||||||
|
(function () {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
var global$4 = tinymce.util.Tools.resolve('tinymce.PluginManager');
|
||||||
|
|
||||||
|
var eq = function (t) {
|
||||||
|
return function (a) {
|
||||||
|
return t === a;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
var isUndefined = eq(undefined);
|
||||||
|
|
||||||
|
var global$3 = tinymce.util.Tools.resolve('tinymce.util.Delay');
|
||||||
|
|
||||||
|
var global$2 = tinymce.util.Tools.resolve('tinymce.util.LocalStorage');
|
||||||
|
|
||||||
|
var global$1 = tinymce.util.Tools.resolve('tinymce.util.Tools');
|
||||||
|
|
||||||
|
var fireRestoreDraft = function (editor) {
|
||||||
|
return editor.fire('RestoreDraft');
|
||||||
|
};
|
||||||
|
var fireStoreDraft = function (editor) {
|
||||||
|
return editor.fire('StoreDraft');
|
||||||
|
};
|
||||||
|
var fireRemoveDraft = function (editor) {
|
||||||
|
return editor.fire('RemoveDraft');
|
||||||
|
};
|
||||||
|
|
||||||
|
var parse = function (timeString, defaultTime) {
|
||||||
|
var multiples = {
|
||||||
|
s: 1000,
|
||||||
|
m: 60000
|
||||||
|
};
|
||||||
|
var toParse = timeString || defaultTime;
|
||||||
|
var parsedTime = /^(\d+)([ms]?)$/.exec('' + toParse);
|
||||||
|
return (parsedTime[2] ? multiples[parsedTime[2]] : 1) * parseInt(toParse, 10);
|
||||||
|
};
|
||||||
|
|
||||||
|
var shouldAskBeforeUnload = function (editor) {
|
||||||
|
return editor.getParam('autosave_ask_before_unload', true);
|
||||||
|
};
|
||||||
|
var getAutoSavePrefix = function (editor) {
|
||||||
|
var location = document.location;
|
||||||
|
return editor.getParam('autosave_prefix', 'tinymce-autosave-{path}{query}{hash}-{id}-').replace(/{path}/g, location.pathname).replace(/{query}/g, location.search).replace(/{hash}/g, location.hash).replace(/{id}/g, editor.id);
|
||||||
|
};
|
||||||
|
var shouldRestoreWhenEmpty = function (editor) {
|
||||||
|
return editor.getParam('autosave_restore_when_empty', false);
|
||||||
|
};
|
||||||
|
var getAutoSaveInterval = function (editor) {
|
||||||
|
return parse(editor.getParam('autosave_interval'), '30s');
|
||||||
|
};
|
||||||
|
var getAutoSaveRetention = function (editor) {
|
||||||
|
return parse(editor.getParam('autosave_retention'), '20m');
|
||||||
|
};
|
||||||
|
|
||||||
|
var isEmpty = function (editor, html) {
|
||||||
|
if (isUndefined(html)) {
|
||||||
|
return editor.dom.isEmpty(editor.getBody());
|
||||||
|
} else {
|
||||||
|
var trimmedHtml = global$1.trim(html);
|
||||||
|
if (trimmedHtml === '') {
|
||||||
|
return true;
|
||||||
|
} else {
|
||||||
|
var fragment = new DOMParser().parseFromString(trimmedHtml, 'text/html');
|
||||||
|
return editor.dom.isEmpty(fragment);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
var hasDraft = function (editor) {
|
||||||
|
var time = parseInt(global$2.getItem(getAutoSavePrefix(editor) + 'time'), 10) || 0;
|
||||||
|
if (new Date().getTime() - time > getAutoSaveRetention(editor)) {
|
||||||
|
removeDraft(editor, false);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
};
|
||||||
|
var removeDraft = function (editor, fire) {
|
||||||
|
var prefix = getAutoSavePrefix(editor);
|
||||||
|
global$2.removeItem(prefix + 'draft');
|
||||||
|
global$2.removeItem(prefix + 'time');
|
||||||
|
if (fire !== false) {
|
||||||
|
fireRemoveDraft(editor);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
var storeDraft = function (editor) {
|
||||||
|
var prefix = getAutoSavePrefix(editor);
|
||||||
|
if (!isEmpty(editor) && editor.isDirty()) {
|
||||||
|
global$2.setItem(prefix + 'draft', editor.getContent({
|
||||||
|
format: 'raw',
|
||||||
|
no_events: true
|
||||||
|
}));
|
||||||
|
global$2.setItem(prefix + 'time', new Date().getTime().toString());
|
||||||
|
fireStoreDraft(editor);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
var restoreDraft = function (editor) {
|
||||||
|
var prefix = getAutoSavePrefix(editor);
|
||||||
|
if (hasDraft(editor)) {
|
||||||
|
editor.setContent(global$2.getItem(prefix + 'draft'), { format: 'raw' });
|
||||||
|
fireRestoreDraft(editor);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
var startStoreDraft = function (editor) {
|
||||||
|
var interval = getAutoSaveInterval(editor);
|
||||||
|
global$3.setEditorInterval(editor, function () {
|
||||||
|
storeDraft(editor);
|
||||||
|
}, interval);
|
||||||
|
};
|
||||||
|
var restoreLastDraft = function (editor) {
|
||||||
|
editor.undoManager.transact(function () {
|
||||||
|
restoreDraft(editor);
|
||||||
|
removeDraft(editor);
|
||||||
|
});
|
||||||
|
editor.focus();
|
||||||
|
};
|
||||||
|
|
||||||
|
var get = function (editor) {
|
||||||
|
return {
|
||||||
|
hasDraft: function () {
|
||||||
|
return hasDraft(editor);
|
||||||
|
},
|
||||||
|
storeDraft: function () {
|
||||||
|
return storeDraft(editor);
|
||||||
|
},
|
||||||
|
restoreDraft: function () {
|
||||||
|
return restoreDraft(editor);
|
||||||
|
},
|
||||||
|
removeDraft: function (fire) {
|
||||||
|
return removeDraft(editor, fire);
|
||||||
|
},
|
||||||
|
isEmpty: function (html) {
|
||||||
|
return isEmpty(editor, html);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
var global = tinymce.util.Tools.resolve('tinymce.EditorManager');
|
||||||
|
|
||||||
|
var setup = function (editor) {
|
||||||
|
editor.editorManager.on('BeforeUnload', function (e) {
|
||||||
|
var msg;
|
||||||
|
global$1.each(global.get(), function (editor) {
|
||||||
|
if (editor.plugins.autosave) {
|
||||||
|
editor.plugins.autosave.storeDraft();
|
||||||
|
}
|
||||||
|
if (!msg && editor.isDirty() && shouldAskBeforeUnload(editor)) {
|
||||||
|
msg = editor.translate('You have unsaved changes are you sure you want to navigate away?');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
if (msg) {
|
||||||
|
e.preventDefault();
|
||||||
|
e.returnValue = msg;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
var makeSetupHandler = function (editor) {
|
||||||
|
return function (api) {
|
||||||
|
api.setDisabled(!hasDraft(editor));
|
||||||
|
var editorEventCallback = function () {
|
||||||
|
return api.setDisabled(!hasDraft(editor));
|
||||||
|
};
|
||||||
|
editor.on('StoreDraft RestoreDraft RemoveDraft', editorEventCallback);
|
||||||
|
return function () {
|
||||||
|
return editor.off('StoreDraft RestoreDraft RemoveDraft', editorEventCallback);
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
var register = function (editor) {
|
||||||
|
startStoreDraft(editor);
|
||||||
|
editor.ui.registry.addButton('restoredraft', {
|
||||||
|
tooltip: 'Restore last draft',
|
||||||
|
icon: 'restore-draft',
|
||||||
|
onAction: function () {
|
||||||
|
restoreLastDraft(editor);
|
||||||
|
},
|
||||||
|
onSetup: makeSetupHandler(editor)
|
||||||
|
});
|
||||||
|
editor.ui.registry.addMenuItem('restoredraft', {
|
||||||
|
text: 'Restore last draft',
|
||||||
|
icon: 'restore-draft',
|
||||||
|
onAction: function () {
|
||||||
|
restoreLastDraft(editor);
|
||||||
|
},
|
||||||
|
onSetup: makeSetupHandler(editor)
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
function Plugin () {
|
||||||
|
global$4.add('autosave', function (editor) {
|
||||||
|
setup(editor);
|
||||||
|
register(editor);
|
||||||
|
editor.on('init', function () {
|
||||||
|
if (shouldRestoreWhenEmpty(editor) && editor.dom.isEmpty(editor.getBody())) {
|
||||||
|
restoreDraft(editor);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
return get(editor);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
Plugin();
|
||||||
|
|
||||||
|
}());
|
|
@ -0,0 +1,9 @@
|
||||||
|
/**
|
||||||
|
* Copyright (c) Tiny Technologies, Inc. All rights reserved.
|
||||||
|
* Licensed under the LGPL or a commercial license.
|
||||||
|
* For LGPL see License.txt in the project root for license information.
|
||||||
|
* For commercial licenses see https://www.tiny.cloud/
|
||||||
|
*
|
||||||
|
* Version: 5.9.2 (2021-09-08)
|
||||||
|
*/
|
||||||
|
!function(){"use strict";function o(t,e){var r=t||e,n=/^(\d+)([ms]?)$/.exec(""+r);return(n[2]?{s:1e3,m:6e4}[n[2]]:1)*parseInt(r,10)}function n(t){var e=document.location;return t.getParam("autosave_prefix","tinymce-autosave-{path}{query}{hash}-{id}-").replace(/{path}/g,e.pathname).replace(/{query}/g,e.search).replace(/{hash}/g,e.hash).replace(/{id}/g,t.id)}function i(t,e){if(a(e))return t.dom.isEmpty(t.getBody());var r=d.trim(e);if(""===r)return!0;var n=(new DOMParser).parseFromString(r,"text/html");return t.dom.isEmpty(n)}function u(t){var e=parseInt(v.getItem(n(t)+"time"),10)||0;return!((new Date).getTime()-e>o(t.getParam("autosave_retention"),"20m")&&(g(t,!1),1))}function s(t){var e=n(t);!i(t)&&t.isDirty()&&(v.setItem(e+"draft",t.getContent({format:"raw",no_events:!0})),v.setItem(e+"time",(new Date).getTime().toString()),t.fire("StoreDraft"))}function f(t){var e=n(t);u(t)&&(t.setContent(v.getItem(e+"draft"),{format:"raw"}),t.fire("RestoreDraft"))}function c(t){t.undoManager.transact(function(){f(t),g(t)}),t.focus()}function m(r){return function(t){function e(){return t.setDisabled(!u(r))}return t.setDisabled(!u(r)),r.on("StoreDraft RestoreDraft RemoveDraft",e),function(){return r.off("StoreDraft RestoreDraft RemoveDraft",e)}}}var t=tinymce.util.Tools.resolve("tinymce.PluginManager"),a=function(t){return void 0===t},l=tinymce.util.Tools.resolve("tinymce.util.Delay"),v=tinymce.util.Tools.resolve("tinymce.util.LocalStorage"),d=tinymce.util.Tools.resolve("tinymce.util.Tools"),g=function(t,e){var r=n(t);v.removeItem(r+"draft"),v.removeItem(r+"time"),!1!==e&&t.fire("RemoveDraft")},y=tinymce.util.Tools.resolve("tinymce.EditorManager");t.add("autosave",function(t){var e,r,n,a;return t.editorManager.on("BeforeUnload",function(t){var e;d.each(y.get(),function(t){t.plugins.autosave&&t.plugins.autosave.storeDraft(),!e&&t.isDirty()&&t.getParam("autosave_ask_before_unload",!0)&&(e=t.translate("You have unsaved changes are you sure you want to navigate away?"))}),e&&(t.preventDefault(),t.returnValue=e)}),n=e=t,a=o(n.getParam("autosave_interval"),"30s"),l.setEditorInterval(n,function(){s(n)},a),e.ui.registry.addButton("restoredraft",{tooltip:"Restore last draft",icon:"restore-draft",onAction:function(){c(e)},onSetup:m(e)}),e.ui.registry.addMenuItem("restoredraft",{text:"Restore last draft",icon:"restore-draft",onAction:function(){c(e)},onSetup:m(e)}),t.on("init",function(){t.getParam("autosave_restore_when_empty",!1)&&t.dom.isEmpty(t.getBody())&&f(t)}),r=t,{hasDraft:function(){return u(r)},storeDraft:function(){return s(r)},restoreDraft:function(){return f(r)},removeDraft:function(t){return g(r,t)},isEmpty:function(t){return i(r,t)}}})}();
|
|
@ -0,0 +1,7 @@
|
||||||
|
// Exports the "bbcode" plugin for usage with module loaders
|
||||||
|
// Usage:
|
||||||
|
// CommonJS:
|
||||||
|
// require('tinymce/plugins/bbcode')
|
||||||
|
// ES2015:
|
||||||
|
// import 'tinymce/plugins/bbcode'
|
||||||
|
require('./plugin.js');
|
|
@ -0,0 +1,100 @@
|
||||||
|
/**
|
||||||
|
* Copyright (c) Tiny Technologies, Inc. All rights reserved.
|
||||||
|
* Licensed under the LGPL or a commercial license.
|
||||||
|
* For LGPL see License.txt in the project root for license information.
|
||||||
|
* For commercial licenses see https://www.tiny.cloud/
|
||||||
|
*
|
||||||
|
* Version: 5.9.2 (2021-09-08)
|
||||||
|
*/
|
||||||
|
(function () {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
var global$1 = tinymce.util.Tools.resolve('tinymce.PluginManager');
|
||||||
|
|
||||||
|
var global = tinymce.util.Tools.resolve('tinymce.util.Tools');
|
||||||
|
|
||||||
|
var html2bbcode = function (s) {
|
||||||
|
s = global.trim(s);
|
||||||
|
var rep = function (re, str) {
|
||||||
|
s = s.replace(re, str);
|
||||||
|
};
|
||||||
|
rep(/<a.*?href=\"(.*?)\".*?>(.*?)<\/a>/gi, '[url=$1]$2[/url]');
|
||||||
|
rep(/<font.*?color=\"(.*?)\".*?class=\"codeStyle\".*?>(.*?)<\/font>/gi, '[code][color=$1]$2[/color][/code]');
|
||||||
|
rep(/<font.*?color=\"(.*?)\".*?class=\"quoteStyle\".*?>(.*?)<\/font>/gi, '[quote][color=$1]$2[/color][/quote]');
|
||||||
|
rep(/<font.*?class=\"codeStyle\".*?color=\"(.*?)\".*?>(.*?)<\/font>/gi, '[code][color=$1]$2[/color][/code]');
|
||||||
|
rep(/<font.*?class=\"quoteStyle\".*?color=\"(.*?)\".*?>(.*?)<\/font>/gi, '[quote][color=$1]$2[/color][/quote]');
|
||||||
|
rep(/<span style=\"color: ?(.*?);\">(.*?)<\/span>/gi, '[color=$1]$2[/color]');
|
||||||
|
rep(/<font.*?color=\"(.*?)\".*?>(.*?)<\/font>/gi, '[color=$1]$2[/color]');
|
||||||
|
rep(/<span style=\"font-size:(.*?);\">(.*?)<\/span>/gi, '[size=$1]$2[/size]');
|
||||||
|
rep(/<font>(.*?)<\/font>/gi, '$1');
|
||||||
|
rep(/<img.*?src=\"(.*?)\".*?\/>/gi, '[img]$1[/img]');
|
||||||
|
rep(/<span class=\"codeStyle\">(.*?)<\/span>/gi, '[code]$1[/code]');
|
||||||
|
rep(/<span class=\"quoteStyle\">(.*?)<\/span>/gi, '[quote]$1[/quote]');
|
||||||
|
rep(/<strong class=\"codeStyle\">(.*?)<\/strong>/gi, '[code][b]$1[/b][/code]');
|
||||||
|
rep(/<strong class=\"quoteStyle\">(.*?)<\/strong>/gi, '[quote][b]$1[/b][/quote]');
|
||||||
|
rep(/<em class=\"codeStyle\">(.*?)<\/em>/gi, '[code][i]$1[/i][/code]');
|
||||||
|
rep(/<em class=\"quoteStyle\">(.*?)<\/em>/gi, '[quote][i]$1[/i][/quote]');
|
||||||
|
rep(/<u class=\"codeStyle\">(.*?)<\/u>/gi, '[code][u]$1[/u][/code]');
|
||||||
|
rep(/<u class=\"quoteStyle\">(.*?)<\/u>/gi, '[quote][u]$1[/u][/quote]');
|
||||||
|
rep(/<\/(strong|b)>/gi, '[/b]');
|
||||||
|
rep(/<(strong|b)>/gi, '[b]');
|
||||||
|
rep(/<\/(em|i)>/gi, '[/i]');
|
||||||
|
rep(/<(em|i)>/gi, '[i]');
|
||||||
|
rep(/<\/u>/gi, '[/u]');
|
||||||
|
rep(/<span style=\"text-decoration: ?underline;\">(.*?)<\/span>/gi, '[u]$1[/u]');
|
||||||
|
rep(/<u>/gi, '[u]');
|
||||||
|
rep(/<blockquote[^>]*>/gi, '[quote]');
|
||||||
|
rep(/<\/blockquote>/gi, '[/quote]');
|
||||||
|
rep(/<br \/>/gi, '\n');
|
||||||
|
rep(/<br\/>/gi, '\n');
|
||||||
|
rep(/<br>/gi, '\n');
|
||||||
|
rep(/<p>/gi, '');
|
||||||
|
rep(/<\/p>/gi, '\n');
|
||||||
|
rep(/ |\u00a0/gi, ' ');
|
||||||
|
rep(/"/gi, '"');
|
||||||
|
rep(/</gi, '<');
|
||||||
|
rep(/>/gi, '>');
|
||||||
|
rep(/&/gi, '&');
|
||||||
|
return s;
|
||||||
|
};
|
||||||
|
var bbcode2html = function (s) {
|
||||||
|
s = global.trim(s);
|
||||||
|
var rep = function (re, str) {
|
||||||
|
s = s.replace(re, str);
|
||||||
|
};
|
||||||
|
rep(/\n/gi, '<br />');
|
||||||
|
rep(/\[b\]/gi, '<strong>');
|
||||||
|
rep(/\[\/b\]/gi, '</strong>');
|
||||||
|
rep(/\[i\]/gi, '<em>');
|
||||||
|
rep(/\[\/i\]/gi, '</em>');
|
||||||
|
rep(/\[u\]/gi, '<u>');
|
||||||
|
rep(/\[\/u\]/gi, '</u>');
|
||||||
|
rep(/\[url=([^\]]+)\](.*?)\[\/url\]/gi, '<a href="$1">$2</a>');
|
||||||
|
rep(/\[url\](.*?)\[\/url\]/gi, '<a href="$1">$1</a>');
|
||||||
|
rep(/\[img\](.*?)\[\/img\]/gi, '<img src="$1" />');
|
||||||
|
rep(/\[color=(.*?)\](.*?)\[\/color\]/gi, '<font color="$1">$2</font>');
|
||||||
|
rep(/\[code\](.*?)\[\/code\]/gi, '<span class="codeStyle">$1</span> ');
|
||||||
|
rep(/\[quote.*?\](.*?)\[\/quote\]/gi, '<span class="quoteStyle">$1</span> ');
|
||||||
|
return s;
|
||||||
|
};
|
||||||
|
|
||||||
|
function Plugin () {
|
||||||
|
global$1.add('bbcode', function (editor) {
|
||||||
|
console.warn('The bbcode plugin has been deprecated and marked for removal in TinyMCE 6.0');
|
||||||
|
editor.on('BeforeSetContent', function (e) {
|
||||||
|
e.content = bbcode2html(e.content);
|
||||||
|
});
|
||||||
|
editor.on('PostProcess', function (e) {
|
||||||
|
if (e.set) {
|
||||||
|
e.content = bbcode2html(e.content);
|
||||||
|
}
|
||||||
|
if (e.get) {
|
||||||
|
e.content = html2bbcode(e.content);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
Plugin();
|
||||||
|
|
||||||
|
}());
|
|
@ -0,0 +1,9 @@
|
||||||
|
/**
|
||||||
|
* Copyright (c) Tiny Technologies, Inc. All rights reserved.
|
||||||
|
* Licensed under the LGPL or a commercial license.
|
||||||
|
* For LGPL see License.txt in the project root for license information.
|
||||||
|
* For commercial licenses see https://www.tiny.cloud/
|
||||||
|
*
|
||||||
|
* Version: 5.9.2 (2021-09-08)
|
||||||
|
*/
|
||||||
|
!function(){"use strict";function i(t){function o(o,e){t=t.replace(o,e)}return t=n.trim(t),o(/\n/gi,"<br />"),o(/\[b\]/gi,"<strong>"),o(/\[\/b\]/gi,"</strong>"),o(/\[i\]/gi,"<em>"),o(/\[\/i\]/gi,"</em>"),o(/\[u\]/gi,"<u>"),o(/\[\/u\]/gi,"</u>"),o(/\[url=([^\]]+)\](.*?)\[\/url\]/gi,'<a href="$1">$2</a>'),o(/\[url\](.*?)\[\/url\]/gi,'<a href="$1">$1</a>'),o(/\[img\](.*?)\[\/img\]/gi,'<img src="$1" />'),o(/\[color=(.*?)\](.*?)\[\/color\]/gi,'<font color="$1">$2</font>'),o(/\[code\](.*?)\[\/code\]/gi,'<span class="codeStyle">$1</span> '),o(/\[quote.*?\](.*?)\[\/quote\]/gi,'<span class="quoteStyle">$1</span> '),t}var o=tinymce.util.Tools.resolve("tinymce.PluginManager"),n=tinymce.util.Tools.resolve("tinymce.util.Tools");o.add("bbcode",function(o){console.warn("The bbcode plugin has been deprecated and marked for removal in TinyMCE 6.0"),o.on("BeforeSetContent",function(o){o.content=i(o.content)}),o.on("PostProcess",function(o){function e(o,e){t=t.replace(o,e)}var t;o.set&&(o.content=i(o.content)),o.get&&(o.content=(t=o.content,t=n.trim(t),e(/<a.*?href=\"(.*?)\".*?>(.*?)<\/a>/gi,"[url=$1]$2[/url]"),e(/<font.*?color=\"(.*?)\".*?class=\"codeStyle\".*?>(.*?)<\/font>/gi,"[code][color=$1]$2[/color][/code]"),e(/<font.*?color=\"(.*?)\".*?class=\"quoteStyle\".*?>(.*?)<\/font>/gi,"[quote][color=$1]$2[/color][/quote]"),e(/<font.*?class=\"codeStyle\".*?color=\"(.*?)\".*?>(.*?)<\/font>/gi,"[code][color=$1]$2[/color][/code]"),e(/<font.*?class=\"quoteStyle\".*?color=\"(.*?)\".*?>(.*?)<\/font>/gi,"[quote][color=$1]$2[/color][/quote]"),e(/<span style=\"color: ?(.*?);\">(.*?)<\/span>/gi,"[color=$1]$2[/color]"),e(/<font.*?color=\"(.*?)\".*?>(.*?)<\/font>/gi,"[color=$1]$2[/color]"),e(/<span style=\"font-size:(.*?);\">(.*?)<\/span>/gi,"[size=$1]$2[/size]"),e(/<font>(.*?)<\/font>/gi,"$1"),e(/<img.*?src=\"(.*?)\".*?\/>/gi,"[img]$1[/img]"),e(/<span class=\"codeStyle\">(.*?)<\/span>/gi,"[code]$1[/code]"),e(/<span class=\"quoteStyle\">(.*?)<\/span>/gi,"[quote]$1[/quote]"),e(/<strong class=\"codeStyle\">(.*?)<\/strong>/gi,"[code][b]$1[/b][/code]"),e(/<strong class=\"quoteStyle\">(.*?)<\/strong>/gi,"[quote][b]$1[/b][/quote]"),e(/<em class=\"codeStyle\">(.*?)<\/em>/gi,"[code][i]$1[/i][/code]"),e(/<em class=\"quoteStyle\">(.*?)<\/em>/gi,"[quote][i]$1[/i][/quote]"),e(/<u class=\"codeStyle\">(.*?)<\/u>/gi,"[code][u]$1[/u][/code]"),e(/<u class=\"quoteStyle\">(.*?)<\/u>/gi,"[quote][u]$1[/u][/quote]"),e(/<\/(strong|b)>/gi,"[/b]"),e(/<(strong|b)>/gi,"[b]"),e(/<\/(em|i)>/gi,"[/i]"),e(/<(em|i)>/gi,"[i]"),e(/<\/u>/gi,"[/u]"),e(/<span style=\"text-decoration: ?underline;\">(.*?)<\/span>/gi,"[u]$1[/u]"),e(/<u>/gi,"[u]"),e(/<blockquote[^>]*>/gi,"[quote]"),e(/<\/blockquote>/gi,"[/quote]"),e(/<br \/>/gi,"\n"),e(/<br\/>/gi,"\n"),e(/<br>/gi,"\n"),e(/<p>/gi,""),e(/<\/p>/gi,"\n"),e(/ |\u00a0/gi," "),e(/"/gi,'"'),e(/</gi,"<"),e(/>/gi,">"),e(/&/gi,"&"),t))})})}();
|
|
@ -0,0 +1,7 @@
|
||||||
|
// Exports the "charmap" plugin for usage with module loaders
|
||||||
|
// Usage:
|
||||||
|
// CommonJS:
|
||||||
|
// require('tinymce/plugins/charmap')
|
||||||
|
// ES2015:
|
||||||
|
// import 'tinymce/plugins/charmap'
|
||||||
|
require('./plugin.js');
|
File diff suppressed because it is too large
Load Diff
File diff suppressed because one or more lines are too long
|
@ -0,0 +1,7 @@
|
||||||
|
// Exports the "code" plugin for usage with module loaders
|
||||||
|
// Usage:
|
||||||
|
// CommonJS:
|
||||||
|
// require('tinymce/plugins/code')
|
||||||
|
// ES2015:
|
||||||
|
// import 'tinymce/plugins/code'
|
||||||
|
require('./plugin.js');
|
|
@ -0,0 +1,91 @@
|
||||||
|
/**
|
||||||
|
* Copyright (c) Tiny Technologies, Inc. All rights reserved.
|
||||||
|
* Licensed under the LGPL or a commercial license.
|
||||||
|
* For LGPL see License.txt in the project root for license information.
|
||||||
|
* For commercial licenses see https://www.tiny.cloud/
|
||||||
|
*
|
||||||
|
* Version: 5.9.2 (2021-09-08)
|
||||||
|
*/
|
||||||
|
(function () {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
var global = tinymce.util.Tools.resolve('tinymce.PluginManager');
|
||||||
|
|
||||||
|
var setContent = function (editor, html) {
|
||||||
|
editor.focus();
|
||||||
|
editor.undoManager.transact(function () {
|
||||||
|
editor.setContent(html);
|
||||||
|
});
|
||||||
|
editor.selection.setCursorLocation();
|
||||||
|
editor.nodeChanged();
|
||||||
|
};
|
||||||
|
var getContent = function (editor) {
|
||||||
|
return editor.getContent({ source_view: true });
|
||||||
|
};
|
||||||
|
|
||||||
|
var open = function (editor) {
|
||||||
|
var editorContent = getContent(editor);
|
||||||
|
editor.windowManager.open({
|
||||||
|
title: 'Source Code',
|
||||||
|
size: 'large',
|
||||||
|
body: {
|
||||||
|
type: 'panel',
|
||||||
|
items: [{
|
||||||
|
type: 'textarea',
|
||||||
|
name: 'code'
|
||||||
|
}]
|
||||||
|
},
|
||||||
|
buttons: [
|
||||||
|
{
|
||||||
|
type: 'cancel',
|
||||||
|
name: 'cancel',
|
||||||
|
text: 'Cancel'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
type: 'submit',
|
||||||
|
name: 'save',
|
||||||
|
text: 'Save',
|
||||||
|
primary: true
|
||||||
|
}
|
||||||
|
],
|
||||||
|
initialData: { code: editorContent },
|
||||||
|
onSubmit: function (api) {
|
||||||
|
setContent(editor, api.getData().code);
|
||||||
|
api.close();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
var register$1 = function (editor) {
|
||||||
|
editor.addCommand('mceCodeEditor', function () {
|
||||||
|
open(editor);
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
var register = function (editor) {
|
||||||
|
var onAction = function () {
|
||||||
|
return editor.execCommand('mceCodeEditor');
|
||||||
|
};
|
||||||
|
editor.ui.registry.addButton('code', {
|
||||||
|
icon: 'sourcecode',
|
||||||
|
tooltip: 'Source code',
|
||||||
|
onAction: onAction
|
||||||
|
});
|
||||||
|
editor.ui.registry.addMenuItem('code', {
|
||||||
|
icon: 'sourcecode',
|
||||||
|
text: 'Source code',
|
||||||
|
onAction: onAction
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
function Plugin () {
|
||||||
|
global.add('code', function (editor) {
|
||||||
|
register$1(editor);
|
||||||
|
register(editor);
|
||||||
|
return {};
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
Plugin();
|
||||||
|
|
||||||
|
}());
|
|
@ -0,0 +1,9 @@
|
||||||
|
/**
|
||||||
|
* Copyright (c) Tiny Technologies, Inc. All rights reserved.
|
||||||
|
* Licensed under the LGPL or a commercial license.
|
||||||
|
* For LGPL see License.txt in the project root for license information.
|
||||||
|
* For commercial licenses see https://www.tiny.cloud/
|
||||||
|
*
|
||||||
|
* Version: 5.9.2 (2021-09-08)
|
||||||
|
*/
|
||||||
|
!function(){"use strict";tinymce.util.Tools.resolve("tinymce.PluginManager").add("code",function(e){var t,o;function n(){return o.execCommand("mceCodeEditor")}return(t=e).addCommand("mceCodeEditor",function(){var n,e;e=(n=t).getContent({source_view:!0}),n.windowManager.open({title:"Source Code",size:"large",body:{type:"panel",items:[{type:"textarea",name:"code"}]},buttons:[{type:"cancel",name:"cancel",text:"Cancel"},{type:"submit",name:"save",text:"Save",primary:!0}],initialData:{code:e},onSubmit:function(e){var t=n,o=e.getData().code;t.focus(),t.undoManager.transact(function(){t.setContent(o)}),t.selection.setCursorLocation(),t.nodeChanged(),e.close()}})}),(o=e).ui.registry.addButton("code",{icon:"sourcecode",tooltip:"Source code",onAction:n}),o.ui.registry.addMenuItem("code",{icon:"sourcecode",text:"Source code",onAction:n}),{}})}();
|
|
@ -0,0 +1,7 @@
|
||||||
|
// Exports the "codesample" plugin for usage with module loaders
|
||||||
|
// Usage:
|
||||||
|
// CommonJS:
|
||||||
|
// require('tinymce/plugins/codesample')
|
||||||
|
// ES2015:
|
||||||
|
// import 'tinymce/plugins/codesample'
|
||||||
|
require('./plugin.js');
|
File diff suppressed because it is too large
Load Diff
File diff suppressed because one or more lines are too long
|
@ -0,0 +1,7 @@
|
||||||
|
// Exports the "colorpicker" plugin for usage with module loaders
|
||||||
|
// Usage:
|
||||||
|
// CommonJS:
|
||||||
|
// require('tinymce/plugins/colorpicker')
|
||||||
|
// ES2015:
|
||||||
|
// import 'tinymce/plugins/colorpicker'
|
||||||
|
require('./plugin.js');
|
|
@ -0,0 +1,22 @@
|
||||||
|
/**
|
||||||
|
* Copyright (c) Tiny Technologies, Inc. All rights reserved.
|
||||||
|
* Licensed under the LGPL or a commercial license.
|
||||||
|
* For LGPL see License.txt in the project root for license information.
|
||||||
|
* For commercial licenses see https://www.tiny.cloud/
|
||||||
|
*
|
||||||
|
* Version: 5.9.2 (2021-09-08)
|
||||||
|
*/
|
||||||
|
(function () {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
var global = tinymce.util.Tools.resolve('tinymce.PluginManager');
|
||||||
|
|
||||||
|
function Plugin () {
|
||||||
|
global.add('colorpicker', function () {
|
||||||
|
console.warn('Color picker plugin is now built in to the core editor, please remove it from your editor configuration');
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
Plugin();
|
||||||
|
|
||||||
|
}());
|
|
@ -0,0 +1,9 @@
|
||||||
|
/**
|
||||||
|
* Copyright (c) Tiny Technologies, Inc. All rights reserved.
|
||||||
|
* Licensed under the LGPL or a commercial license.
|
||||||
|
* For LGPL see License.txt in the project root for license information.
|
||||||
|
* For commercial licenses see https://www.tiny.cloud/
|
||||||
|
*
|
||||||
|
* Version: 5.9.2 (2021-09-08)
|
||||||
|
*/
|
||||||
|
!function(){"use strict";tinymce.util.Tools.resolve("tinymce.PluginManager").add("colorpicker",function(){console.warn("Color picker plugin is now built in to the core editor, please remove it from your editor configuration")})}();
|
|
@ -0,0 +1,7 @@
|
||||||
|
// Exports the "contextmenu" plugin for usage with module loaders
|
||||||
|
// Usage:
|
||||||
|
// CommonJS:
|
||||||
|
// require('tinymce/plugins/contextmenu')
|
||||||
|
// ES2015:
|
||||||
|
// import 'tinymce/plugins/contextmenu'
|
||||||
|
require('./plugin.js');
|
|
@ -0,0 +1,22 @@
|
||||||
|
/**
|
||||||
|
* Copyright (c) Tiny Technologies, Inc. All rights reserved.
|
||||||
|
* Licensed under the LGPL or a commercial license.
|
||||||
|
* For LGPL see License.txt in the project root for license information.
|
||||||
|
* For commercial licenses see https://www.tiny.cloud/
|
||||||
|
*
|
||||||
|
* Version: 5.9.2 (2021-09-08)
|
||||||
|
*/
|
||||||
|
(function () {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
var global = tinymce.util.Tools.resolve('tinymce.PluginManager');
|
||||||
|
|
||||||
|
function Plugin () {
|
||||||
|
global.add('contextmenu', function () {
|
||||||
|
console.warn('Context menu plugin is now built in to the core editor, please remove it from your editor configuration');
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
Plugin();
|
||||||
|
|
||||||
|
}());
|
|
@ -0,0 +1,9 @@
|
||||||
|
/**
|
||||||
|
* Copyright (c) Tiny Technologies, Inc. All rights reserved.
|
||||||
|
* Licensed under the LGPL or a commercial license.
|
||||||
|
* For LGPL see License.txt in the project root for license information.
|
||||||
|
* For commercial licenses see https://www.tiny.cloud/
|
||||||
|
*
|
||||||
|
* Version: 5.9.2 (2021-09-08)
|
||||||
|
*/
|
||||||
|
!function(){"use strict";tinymce.util.Tools.resolve("tinymce.PluginManager").add("contextmenu",function(){console.warn("Context menu plugin is now built in to the core editor, please remove it from your editor configuration")})}();
|
|
@ -0,0 +1,7 @@
|
||||||
|
// Exports the "directionality" plugin for usage with module loaders
|
||||||
|
// Usage:
|
||||||
|
// CommonJS:
|
||||||
|
// require('tinymce/plugins/directionality')
|
||||||
|
// ES2015:
|
||||||
|
// import 'tinymce/plugins/directionality'
|
||||||
|
require('./plugin.js');
|
|
@ -0,0 +1,453 @@
|
||||||
|
/**
|
||||||
|
* Copyright (c) Tiny Technologies, Inc. All rights reserved.
|
||||||
|
* Licensed under the LGPL or a commercial license.
|
||||||
|
* For LGPL see License.txt in the project root for license information.
|
||||||
|
* For commercial licenses see https://www.tiny.cloud/
|
||||||
|
*
|
||||||
|
* Version: 5.9.2 (2021-09-08)
|
||||||
|
*/
|
||||||
|
(function () {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
var global = tinymce.util.Tools.resolve('tinymce.PluginManager');
|
||||||
|
|
||||||
|
var typeOf = function (x) {
|
||||||
|
var t = typeof x;
|
||||||
|
if (x === null) {
|
||||||
|
return 'null';
|
||||||
|
} else if (t === 'object' && (Array.prototype.isPrototypeOf(x) || x.constructor && x.constructor.name === 'Array')) {
|
||||||
|
return 'array';
|
||||||
|
} else if (t === 'object' && (String.prototype.isPrototypeOf(x) || x.constructor && x.constructor.name === 'String')) {
|
||||||
|
return 'string';
|
||||||
|
} else {
|
||||||
|
return t;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
var isType$1 = function (type) {
|
||||||
|
return function (value) {
|
||||||
|
return typeOf(value) === type;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
var isSimpleType = function (type) {
|
||||||
|
return function (value) {
|
||||||
|
return typeof value === type;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
var isString = isType$1('string');
|
||||||
|
var isBoolean = isSimpleType('boolean');
|
||||||
|
var isNullable = function (a) {
|
||||||
|
return a === null || a === undefined;
|
||||||
|
};
|
||||||
|
var isNonNullable = function (a) {
|
||||||
|
return !isNullable(a);
|
||||||
|
};
|
||||||
|
var isFunction = isSimpleType('function');
|
||||||
|
var isNumber = isSimpleType('number');
|
||||||
|
|
||||||
|
var noop = function () {
|
||||||
|
};
|
||||||
|
var compose1 = function (fbc, fab) {
|
||||||
|
return function (a) {
|
||||||
|
return fbc(fab(a));
|
||||||
|
};
|
||||||
|
};
|
||||||
|
var constant = function (value) {
|
||||||
|
return function () {
|
||||||
|
return value;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
var identity = function (x) {
|
||||||
|
return x;
|
||||||
|
};
|
||||||
|
var never = constant(false);
|
||||||
|
var always = constant(true);
|
||||||
|
|
||||||
|
var none = function () {
|
||||||
|
return NONE;
|
||||||
|
};
|
||||||
|
var NONE = function () {
|
||||||
|
var call = function (thunk) {
|
||||||
|
return thunk();
|
||||||
|
};
|
||||||
|
var id = identity;
|
||||||
|
var me = {
|
||||||
|
fold: function (n, _s) {
|
||||||
|
return n();
|
||||||
|
},
|
||||||
|
isSome: never,
|
||||||
|
isNone: always,
|
||||||
|
getOr: id,
|
||||||
|
getOrThunk: call,
|
||||||
|
getOrDie: function (msg) {
|
||||||
|
throw new Error(msg || 'error: getOrDie called on none.');
|
||||||
|
},
|
||||||
|
getOrNull: constant(null),
|
||||||
|
getOrUndefined: constant(undefined),
|
||||||
|
or: id,
|
||||||
|
orThunk: call,
|
||||||
|
map: none,
|
||||||
|
each: noop,
|
||||||
|
bind: none,
|
||||||
|
exists: never,
|
||||||
|
forall: always,
|
||||||
|
filter: function () {
|
||||||
|
return none();
|
||||||
|
},
|
||||||
|
toArray: function () {
|
||||||
|
return [];
|
||||||
|
},
|
||||||
|
toString: constant('none()')
|
||||||
|
};
|
||||||
|
return me;
|
||||||
|
}();
|
||||||
|
var some = function (a) {
|
||||||
|
var constant_a = constant(a);
|
||||||
|
var self = function () {
|
||||||
|
return me;
|
||||||
|
};
|
||||||
|
var bind = function (f) {
|
||||||
|
return f(a);
|
||||||
|
};
|
||||||
|
var me = {
|
||||||
|
fold: function (n, s) {
|
||||||
|
return s(a);
|
||||||
|
},
|
||||||
|
isSome: always,
|
||||||
|
isNone: never,
|
||||||
|
getOr: constant_a,
|
||||||
|
getOrThunk: constant_a,
|
||||||
|
getOrDie: constant_a,
|
||||||
|
getOrNull: constant_a,
|
||||||
|
getOrUndefined: constant_a,
|
||||||
|
or: self,
|
||||||
|
orThunk: self,
|
||||||
|
map: function (f) {
|
||||||
|
return some(f(a));
|
||||||
|
},
|
||||||
|
each: function (f) {
|
||||||
|
f(a);
|
||||||
|
},
|
||||||
|
bind: bind,
|
||||||
|
exists: bind,
|
||||||
|
forall: bind,
|
||||||
|
filter: function (f) {
|
||||||
|
return f(a) ? me : NONE;
|
||||||
|
},
|
||||||
|
toArray: function () {
|
||||||
|
return [a];
|
||||||
|
},
|
||||||
|
toString: function () {
|
||||||
|
return 'some(' + a + ')';
|
||||||
|
}
|
||||||
|
};
|
||||||
|
return me;
|
||||||
|
};
|
||||||
|
var from = function (value) {
|
||||||
|
return value === null || value === undefined ? NONE : some(value);
|
||||||
|
};
|
||||||
|
var Optional = {
|
||||||
|
some: some,
|
||||||
|
none: none,
|
||||||
|
from: from
|
||||||
|
};
|
||||||
|
|
||||||
|
var map = function (xs, f) {
|
||||||
|
var len = xs.length;
|
||||||
|
var r = new Array(len);
|
||||||
|
for (var i = 0; i < len; i++) {
|
||||||
|
var x = xs[i];
|
||||||
|
r[i] = f(x, i);
|
||||||
|
}
|
||||||
|
return r;
|
||||||
|
};
|
||||||
|
var each = function (xs, f) {
|
||||||
|
for (var i = 0, len = xs.length; i < len; i++) {
|
||||||
|
var x = xs[i];
|
||||||
|
f(x, i);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
var filter = function (xs, pred) {
|
||||||
|
var r = [];
|
||||||
|
for (var i = 0, len = xs.length; i < len; i++) {
|
||||||
|
var x = xs[i];
|
||||||
|
if (pred(x, i)) {
|
||||||
|
r.push(x);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return r;
|
||||||
|
};
|
||||||
|
|
||||||
|
var DOCUMENT = 9;
|
||||||
|
var DOCUMENT_FRAGMENT = 11;
|
||||||
|
var ELEMENT = 1;
|
||||||
|
var TEXT = 3;
|
||||||
|
|
||||||
|
var fromHtml = function (html, scope) {
|
||||||
|
var doc = scope || document;
|
||||||
|
var div = doc.createElement('div');
|
||||||
|
div.innerHTML = html;
|
||||||
|
if (!div.hasChildNodes() || div.childNodes.length > 1) {
|
||||||
|
console.error('HTML does not have a single root node', html);
|
||||||
|
throw new Error('HTML must have a single root node');
|
||||||
|
}
|
||||||
|
return fromDom(div.childNodes[0]);
|
||||||
|
};
|
||||||
|
var fromTag = function (tag, scope) {
|
||||||
|
var doc = scope || document;
|
||||||
|
var node = doc.createElement(tag);
|
||||||
|
return fromDom(node);
|
||||||
|
};
|
||||||
|
var fromText = function (text, scope) {
|
||||||
|
var doc = scope || document;
|
||||||
|
var node = doc.createTextNode(text);
|
||||||
|
return fromDom(node);
|
||||||
|
};
|
||||||
|
var fromDom = function (node) {
|
||||||
|
if (node === null || node === undefined) {
|
||||||
|
throw new Error('Node cannot be null or undefined');
|
||||||
|
}
|
||||||
|
return { dom: node };
|
||||||
|
};
|
||||||
|
var fromPoint = function (docElm, x, y) {
|
||||||
|
return Optional.from(docElm.dom.elementFromPoint(x, y)).map(fromDom);
|
||||||
|
};
|
||||||
|
var SugarElement = {
|
||||||
|
fromHtml: fromHtml,
|
||||||
|
fromTag: fromTag,
|
||||||
|
fromText: fromText,
|
||||||
|
fromDom: fromDom,
|
||||||
|
fromPoint: fromPoint
|
||||||
|
};
|
||||||
|
|
||||||
|
var is = function (element, selector) {
|
||||||
|
var dom = element.dom;
|
||||||
|
if (dom.nodeType !== ELEMENT) {
|
||||||
|
return false;
|
||||||
|
} else {
|
||||||
|
var elem = dom;
|
||||||
|
if (elem.matches !== undefined) {
|
||||||
|
return elem.matches(selector);
|
||||||
|
} else if (elem.msMatchesSelector !== undefined) {
|
||||||
|
return elem.msMatchesSelector(selector);
|
||||||
|
} else if (elem.webkitMatchesSelector !== undefined) {
|
||||||
|
return elem.webkitMatchesSelector(selector);
|
||||||
|
} else if (elem.mozMatchesSelector !== undefined) {
|
||||||
|
return elem.mozMatchesSelector(selector);
|
||||||
|
} else {
|
||||||
|
throw new Error('Browser lacks native selectors');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
typeof window !== 'undefined' ? window : Function('return this;')();
|
||||||
|
|
||||||
|
var name = function (element) {
|
||||||
|
var r = element.dom.nodeName;
|
||||||
|
return r.toLowerCase();
|
||||||
|
};
|
||||||
|
var type = function (element) {
|
||||||
|
return element.dom.nodeType;
|
||||||
|
};
|
||||||
|
var isType = function (t) {
|
||||||
|
return function (element) {
|
||||||
|
return type(element) === t;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
var isElement = isType(ELEMENT);
|
||||||
|
var isText = isType(TEXT);
|
||||||
|
var isDocument = isType(DOCUMENT);
|
||||||
|
var isDocumentFragment = isType(DOCUMENT_FRAGMENT);
|
||||||
|
var isTag = function (tag) {
|
||||||
|
return function (e) {
|
||||||
|
return isElement(e) && name(e) === tag;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
var owner = function (element) {
|
||||||
|
return SugarElement.fromDom(element.dom.ownerDocument);
|
||||||
|
};
|
||||||
|
var documentOrOwner = function (dos) {
|
||||||
|
return isDocument(dos) ? dos : owner(dos);
|
||||||
|
};
|
||||||
|
var parent = function (element) {
|
||||||
|
return Optional.from(element.dom.parentNode).map(SugarElement.fromDom);
|
||||||
|
};
|
||||||
|
var children$2 = function (element) {
|
||||||
|
return map(element.dom.childNodes, SugarElement.fromDom);
|
||||||
|
};
|
||||||
|
|
||||||
|
var rawSet = function (dom, key, value) {
|
||||||
|
if (isString(value) || isBoolean(value) || isNumber(value)) {
|
||||||
|
dom.setAttribute(key, value + '');
|
||||||
|
} else {
|
||||||
|
console.error('Invalid call to Attribute.set. Key ', key, ':: Value ', value, ':: Element ', dom);
|
||||||
|
throw new Error('Attribute value was not simple');
|
||||||
|
}
|
||||||
|
};
|
||||||
|
var set = function (element, key, value) {
|
||||||
|
rawSet(element.dom, key, value);
|
||||||
|
};
|
||||||
|
var remove = function (element, key) {
|
||||||
|
element.dom.removeAttribute(key);
|
||||||
|
};
|
||||||
|
|
||||||
|
var isShadowRoot = function (dos) {
|
||||||
|
return isDocumentFragment(dos) && isNonNullable(dos.dom.host);
|
||||||
|
};
|
||||||
|
var supported = isFunction(Element.prototype.attachShadow) && isFunction(Node.prototype.getRootNode);
|
||||||
|
var getRootNode = supported ? function (e) {
|
||||||
|
return SugarElement.fromDom(e.dom.getRootNode());
|
||||||
|
} : documentOrOwner;
|
||||||
|
var getShadowRoot = function (e) {
|
||||||
|
var r = getRootNode(e);
|
||||||
|
return isShadowRoot(r) ? Optional.some(r) : Optional.none();
|
||||||
|
};
|
||||||
|
var getShadowHost = function (e) {
|
||||||
|
return SugarElement.fromDom(e.dom.host);
|
||||||
|
};
|
||||||
|
|
||||||
|
var inBody = function (element) {
|
||||||
|
var dom = isText(element) ? element.dom.parentNode : element.dom;
|
||||||
|
if (dom === undefined || dom === null || dom.ownerDocument === null) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
var doc = dom.ownerDocument;
|
||||||
|
return getShadowRoot(SugarElement.fromDom(dom)).fold(function () {
|
||||||
|
return doc.body.contains(dom);
|
||||||
|
}, compose1(inBody, getShadowHost));
|
||||||
|
};
|
||||||
|
|
||||||
|
var ancestor$1 = function (scope, predicate, isRoot) {
|
||||||
|
var element = scope.dom;
|
||||||
|
var stop = isFunction(isRoot) ? isRoot : never;
|
||||||
|
while (element.parentNode) {
|
||||||
|
element = element.parentNode;
|
||||||
|
var el = SugarElement.fromDom(element);
|
||||||
|
if (predicate(el)) {
|
||||||
|
return Optional.some(el);
|
||||||
|
} else if (stop(el)) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return Optional.none();
|
||||||
|
};
|
||||||
|
|
||||||
|
var ancestor = function (scope, selector, isRoot) {
|
||||||
|
return ancestor$1(scope, function (e) {
|
||||||
|
return is(e, selector);
|
||||||
|
}, isRoot);
|
||||||
|
};
|
||||||
|
|
||||||
|
var isSupported = function (dom) {
|
||||||
|
return dom.style !== undefined && isFunction(dom.style.getPropertyValue);
|
||||||
|
};
|
||||||
|
|
||||||
|
var get = function (element, property) {
|
||||||
|
var dom = element.dom;
|
||||||
|
var styles = window.getComputedStyle(dom);
|
||||||
|
var r = styles.getPropertyValue(property);
|
||||||
|
return r === '' && !inBody(element) ? getUnsafeProperty(dom, property) : r;
|
||||||
|
};
|
||||||
|
var getUnsafeProperty = function (dom, property) {
|
||||||
|
return isSupported(dom) ? dom.style.getPropertyValue(property) : '';
|
||||||
|
};
|
||||||
|
|
||||||
|
var getDirection = function (element) {
|
||||||
|
return get(element, 'direction') === 'rtl' ? 'rtl' : 'ltr';
|
||||||
|
};
|
||||||
|
|
||||||
|
var children$1 = function (scope, predicate) {
|
||||||
|
return filter(children$2(scope), predicate);
|
||||||
|
};
|
||||||
|
|
||||||
|
var children = function (scope, selector) {
|
||||||
|
return children$1(scope, function (e) {
|
||||||
|
return is(e, selector);
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
var getParentElement = function (element) {
|
||||||
|
return parent(element).filter(isElement);
|
||||||
|
};
|
||||||
|
var getNormalizedBlock = function (element, isListItem) {
|
||||||
|
var normalizedElement = isListItem ? ancestor(element, 'ol,ul') : Optional.some(element);
|
||||||
|
return normalizedElement.getOr(element);
|
||||||
|
};
|
||||||
|
var isListItem = isTag('li');
|
||||||
|
var setDir = function (editor, dir) {
|
||||||
|
var selectedBlocks = editor.selection.getSelectedBlocks();
|
||||||
|
if (selectedBlocks.length > 0) {
|
||||||
|
each(selectedBlocks, function (block) {
|
||||||
|
var blockElement = SugarElement.fromDom(block);
|
||||||
|
var isBlockElementListItem = isListItem(blockElement);
|
||||||
|
var normalizedBlock = getNormalizedBlock(blockElement, isBlockElementListItem);
|
||||||
|
var normalizedBlockParent = getParentElement(normalizedBlock);
|
||||||
|
normalizedBlockParent.each(function (parent) {
|
||||||
|
var parentDirection = getDirection(parent);
|
||||||
|
if (parentDirection !== dir) {
|
||||||
|
set(normalizedBlock, 'dir', dir);
|
||||||
|
} else if (getDirection(normalizedBlock) !== dir) {
|
||||||
|
remove(normalizedBlock, 'dir');
|
||||||
|
}
|
||||||
|
if (isBlockElementListItem) {
|
||||||
|
var listItems = children(normalizedBlock, 'li[dir]');
|
||||||
|
each(listItems, function (listItem) {
|
||||||
|
return remove(listItem, 'dir');
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
|
editor.nodeChanged();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
var register$1 = function (editor) {
|
||||||
|
editor.addCommand('mceDirectionLTR', function () {
|
||||||
|
setDir(editor, 'ltr');
|
||||||
|
});
|
||||||
|
editor.addCommand('mceDirectionRTL', function () {
|
||||||
|
setDir(editor, 'rtl');
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
var getNodeChangeHandler = function (editor, dir) {
|
||||||
|
return function (api) {
|
||||||
|
var nodeChangeHandler = function (e) {
|
||||||
|
var element = SugarElement.fromDom(e.element);
|
||||||
|
api.setActive(getDirection(element) === dir);
|
||||||
|
};
|
||||||
|
editor.on('NodeChange', nodeChangeHandler);
|
||||||
|
return function () {
|
||||||
|
return editor.off('NodeChange', nodeChangeHandler);
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
var register = function (editor) {
|
||||||
|
editor.ui.registry.addToggleButton('ltr', {
|
||||||
|
tooltip: 'Left to right',
|
||||||
|
icon: 'ltr',
|
||||||
|
onAction: function () {
|
||||||
|
return editor.execCommand('mceDirectionLTR');
|
||||||
|
},
|
||||||
|
onSetup: getNodeChangeHandler(editor, 'ltr')
|
||||||
|
});
|
||||||
|
editor.ui.registry.addToggleButton('rtl', {
|
||||||
|
tooltip: 'Right to left',
|
||||||
|
icon: 'rtl',
|
||||||
|
onAction: function () {
|
||||||
|
return editor.execCommand('mceDirectionRTL');
|
||||||
|
},
|
||||||
|
onSetup: getNodeChangeHandler(editor, 'rtl')
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
function Plugin () {
|
||||||
|
global.add('directionality', function (editor) {
|
||||||
|
register$1(editor);
|
||||||
|
register(editor);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
Plugin();
|
||||||
|
|
||||||
|
}());
|
File diff suppressed because one or more lines are too long
|
@ -0,0 +1,7 @@
|
||||||
|
// Exports the "emoticons" plugin for usage with module loaders
|
||||||
|
// Usage:
|
||||||
|
// CommonJS:
|
||||||
|
// require('tinymce/plugins/emoticons')
|
||||||
|
// ES2015:
|
||||||
|
// import 'tinymce/plugins/emoticons'
|
||||||
|
require('./plugin.js');
|
File diff suppressed because it is too large
Load Diff
File diff suppressed because one or more lines are too long
File diff suppressed because it is too large
Load Diff
File diff suppressed because one or more lines are too long
|
@ -0,0 +1,636 @@
|
||||||
|
/**
|
||||||
|
* Copyright (c) Tiny Technologies, Inc. All rights reserved.
|
||||||
|
* Licensed under the LGPL or a commercial license.
|
||||||
|
* For LGPL see License.txt in the project root for license information.
|
||||||
|
* For commercial licenses see https://www.tiny.cloud/
|
||||||
|
*
|
||||||
|
* Version: 5.9.2 (2021-09-08)
|
||||||
|
*/
|
||||||
|
(function () {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
var global$3 = tinymce.util.Tools.resolve('tinymce.PluginManager');
|
||||||
|
|
||||||
|
var eq = function (t) {
|
||||||
|
return function (a) {
|
||||||
|
return t === a;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
var isNull = eq(null);
|
||||||
|
|
||||||
|
var noop = function () {
|
||||||
|
};
|
||||||
|
var constant = function (value) {
|
||||||
|
return function () {
|
||||||
|
return value;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
var identity = function (x) {
|
||||||
|
return x;
|
||||||
|
};
|
||||||
|
var never = constant(false);
|
||||||
|
var always = constant(true);
|
||||||
|
|
||||||
|
var none = function () {
|
||||||
|
return NONE;
|
||||||
|
};
|
||||||
|
var NONE = function () {
|
||||||
|
var call = function (thunk) {
|
||||||
|
return thunk();
|
||||||
|
};
|
||||||
|
var id = identity;
|
||||||
|
var me = {
|
||||||
|
fold: function (n, _s) {
|
||||||
|
return n();
|
||||||
|
},
|
||||||
|
isSome: never,
|
||||||
|
isNone: always,
|
||||||
|
getOr: id,
|
||||||
|
getOrThunk: call,
|
||||||
|
getOrDie: function (msg) {
|
||||||
|
throw new Error(msg || 'error: getOrDie called on none.');
|
||||||
|
},
|
||||||
|
getOrNull: constant(null),
|
||||||
|
getOrUndefined: constant(undefined),
|
||||||
|
or: id,
|
||||||
|
orThunk: call,
|
||||||
|
map: none,
|
||||||
|
each: noop,
|
||||||
|
bind: none,
|
||||||
|
exists: never,
|
||||||
|
forall: always,
|
||||||
|
filter: function () {
|
||||||
|
return none();
|
||||||
|
},
|
||||||
|
toArray: function () {
|
||||||
|
return [];
|
||||||
|
},
|
||||||
|
toString: constant('none()')
|
||||||
|
};
|
||||||
|
return me;
|
||||||
|
}();
|
||||||
|
var some = function (a) {
|
||||||
|
var constant_a = constant(a);
|
||||||
|
var self = function () {
|
||||||
|
return me;
|
||||||
|
};
|
||||||
|
var bind = function (f) {
|
||||||
|
return f(a);
|
||||||
|
};
|
||||||
|
var me = {
|
||||||
|
fold: function (n, s) {
|
||||||
|
return s(a);
|
||||||
|
},
|
||||||
|
isSome: always,
|
||||||
|
isNone: never,
|
||||||
|
getOr: constant_a,
|
||||||
|
getOrThunk: constant_a,
|
||||||
|
getOrDie: constant_a,
|
||||||
|
getOrNull: constant_a,
|
||||||
|
getOrUndefined: constant_a,
|
||||||
|
or: self,
|
||||||
|
orThunk: self,
|
||||||
|
map: function (f) {
|
||||||
|
return some(f(a));
|
||||||
|
},
|
||||||
|
each: function (f) {
|
||||||
|
f(a);
|
||||||
|
},
|
||||||
|
bind: bind,
|
||||||
|
exists: bind,
|
||||||
|
forall: bind,
|
||||||
|
filter: function (f) {
|
||||||
|
return f(a) ? me : NONE;
|
||||||
|
},
|
||||||
|
toArray: function () {
|
||||||
|
return [a];
|
||||||
|
},
|
||||||
|
toString: function () {
|
||||||
|
return 'some(' + a + ')';
|
||||||
|
}
|
||||||
|
};
|
||||||
|
return me;
|
||||||
|
};
|
||||||
|
var from = function (value) {
|
||||||
|
return value === null || value === undefined ? NONE : some(value);
|
||||||
|
};
|
||||||
|
var Optional = {
|
||||||
|
some: some,
|
||||||
|
none: none,
|
||||||
|
from: from
|
||||||
|
};
|
||||||
|
|
||||||
|
var exists = function (xs, pred) {
|
||||||
|
for (var i = 0, len = xs.length; i < len; i++) {
|
||||||
|
var x = xs[i];
|
||||||
|
if (pred(x, i)) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
};
|
||||||
|
var map$1 = function (xs, f) {
|
||||||
|
var len = xs.length;
|
||||||
|
var r = new Array(len);
|
||||||
|
for (var i = 0; i < len; i++) {
|
||||||
|
var x = xs[i];
|
||||||
|
r[i] = f(x, i);
|
||||||
|
}
|
||||||
|
return r;
|
||||||
|
};
|
||||||
|
var each$1 = function (xs, f) {
|
||||||
|
for (var i = 0, len = xs.length; i < len; i++) {
|
||||||
|
var x = xs[i];
|
||||||
|
f(x, i);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
var Cell = function (initial) {
|
||||||
|
var value = initial;
|
||||||
|
var get = function () {
|
||||||
|
return value;
|
||||||
|
};
|
||||||
|
var set = function (v) {
|
||||||
|
value = v;
|
||||||
|
};
|
||||||
|
return {
|
||||||
|
get: get,
|
||||||
|
set: set
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
var last = function (fn, rate) {
|
||||||
|
var timer = null;
|
||||||
|
var cancel = function () {
|
||||||
|
if (!isNull(timer)) {
|
||||||
|
clearTimeout(timer);
|
||||||
|
timer = null;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
var throttle = function () {
|
||||||
|
var args = [];
|
||||||
|
for (var _i = 0; _i < arguments.length; _i++) {
|
||||||
|
args[_i] = arguments[_i];
|
||||||
|
}
|
||||||
|
cancel();
|
||||||
|
timer = setTimeout(function () {
|
||||||
|
timer = null;
|
||||||
|
fn.apply(null, args);
|
||||||
|
}, rate);
|
||||||
|
};
|
||||||
|
return {
|
||||||
|
cancel: cancel,
|
||||||
|
throttle: throttle
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
var insertEmoticon = function (editor, ch) {
|
||||||
|
editor.insertContent(ch);
|
||||||
|
};
|
||||||
|
|
||||||
|
var __assign = function () {
|
||||||
|
__assign = Object.assign || function __assign(t) {
|
||||||
|
for (var s, i = 1, n = arguments.length; i < n; i++) {
|
||||||
|
s = arguments[i];
|
||||||
|
for (var p in s)
|
||||||
|
if (Object.prototype.hasOwnProperty.call(s, p))
|
||||||
|
t[p] = s[p];
|
||||||
|
}
|
||||||
|
return t;
|
||||||
|
};
|
||||||
|
return __assign.apply(this, arguments);
|
||||||
|
};
|
||||||
|
|
||||||
|
var keys = Object.keys;
|
||||||
|
var hasOwnProperty = Object.hasOwnProperty;
|
||||||
|
var each = function (obj, f) {
|
||||||
|
var props = keys(obj);
|
||||||
|
for (var k = 0, len = props.length; k < len; k++) {
|
||||||
|
var i = props[k];
|
||||||
|
var x = obj[i];
|
||||||
|
f(x, i);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
var map = function (obj, f) {
|
||||||
|
return tupleMap(obj, function (x, i) {
|
||||||
|
return {
|
||||||
|
k: i,
|
||||||
|
v: f(x, i)
|
||||||
|
};
|
||||||
|
});
|
||||||
|
};
|
||||||
|
var tupleMap = function (obj, f) {
|
||||||
|
var r = {};
|
||||||
|
each(obj, function (x, i) {
|
||||||
|
var tuple = f(x, i);
|
||||||
|
r[tuple.k] = tuple.v;
|
||||||
|
});
|
||||||
|
return r;
|
||||||
|
};
|
||||||
|
var has = function (obj, key) {
|
||||||
|
return hasOwnProperty.call(obj, key);
|
||||||
|
};
|
||||||
|
|
||||||
|
var shallow = function (old, nu) {
|
||||||
|
return nu;
|
||||||
|
};
|
||||||
|
var baseMerge = function (merger) {
|
||||||
|
return function () {
|
||||||
|
var objects = [];
|
||||||
|
for (var _i = 0; _i < arguments.length; _i++) {
|
||||||
|
objects[_i] = arguments[_i];
|
||||||
|
}
|
||||||
|
if (objects.length === 0) {
|
||||||
|
throw new Error('Can\'t merge zero objects');
|
||||||
|
}
|
||||||
|
var ret = {};
|
||||||
|
for (var j = 0; j < objects.length; j++) {
|
||||||
|
var curObject = objects[j];
|
||||||
|
for (var key in curObject) {
|
||||||
|
if (has(curObject, key)) {
|
||||||
|
ret[key] = merger(ret[key], curObject[key]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return ret;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
var merge = baseMerge(shallow);
|
||||||
|
|
||||||
|
var singleton = function (doRevoke) {
|
||||||
|
var subject = Cell(Optional.none());
|
||||||
|
var revoke = function () {
|
||||||
|
return subject.get().each(doRevoke);
|
||||||
|
};
|
||||||
|
var clear = function () {
|
||||||
|
revoke();
|
||||||
|
subject.set(Optional.none());
|
||||||
|
};
|
||||||
|
var isSet = function () {
|
||||||
|
return subject.get().isSome();
|
||||||
|
};
|
||||||
|
var get = function () {
|
||||||
|
return subject.get();
|
||||||
|
};
|
||||||
|
var set = function (s) {
|
||||||
|
revoke();
|
||||||
|
subject.set(Optional.some(s));
|
||||||
|
};
|
||||||
|
return {
|
||||||
|
clear: clear,
|
||||||
|
isSet: isSet,
|
||||||
|
get: get,
|
||||||
|
set: set
|
||||||
|
};
|
||||||
|
};
|
||||||
|
var value = function () {
|
||||||
|
var subject = singleton(noop);
|
||||||
|
var on = function (f) {
|
||||||
|
return subject.get().each(f);
|
||||||
|
};
|
||||||
|
return __assign(__assign({}, subject), { on: on });
|
||||||
|
};
|
||||||
|
|
||||||
|
var checkRange = function (str, substr, start) {
|
||||||
|
return substr === '' || str.length >= substr.length && str.substr(start, start + substr.length) === substr;
|
||||||
|
};
|
||||||
|
var contains = function (str, substr) {
|
||||||
|
return str.indexOf(substr) !== -1;
|
||||||
|
};
|
||||||
|
var startsWith = function (str, prefix) {
|
||||||
|
return checkRange(str, prefix, 0);
|
||||||
|
};
|
||||||
|
|
||||||
|
var global$2 = tinymce.util.Tools.resolve('tinymce.Resource');
|
||||||
|
|
||||||
|
var global$1 = tinymce.util.Tools.resolve('tinymce.util.Delay');
|
||||||
|
|
||||||
|
var global = tinymce.util.Tools.resolve('tinymce.util.Promise');
|
||||||
|
|
||||||
|
var DEFAULT_ID = 'tinymce.plugins.emoticons';
|
||||||
|
var getEmoticonDatabase = function (editor) {
|
||||||
|
return editor.getParam('emoticons_database', 'emojis', 'string');
|
||||||
|
};
|
||||||
|
var getEmoticonDatabaseUrl = function (editor, pluginUrl) {
|
||||||
|
var database = getEmoticonDatabase(editor);
|
||||||
|
return editor.getParam('emoticons_database_url', pluginUrl + '/js/' + database + editor.suffix + '.js', 'string');
|
||||||
|
};
|
||||||
|
var getEmoticonDatabaseId = function (editor) {
|
||||||
|
return editor.getParam('emoticons_database_id', DEFAULT_ID, 'string');
|
||||||
|
};
|
||||||
|
var getAppendedEmoticons = function (editor) {
|
||||||
|
return editor.getParam('emoticons_append', {}, 'object');
|
||||||
|
};
|
||||||
|
var getEmotionsImageUrl = function (editor) {
|
||||||
|
return editor.getParam('emoticons_images_url', 'https://twemoji.maxcdn.com/v/13.0.1/72x72/', 'string');
|
||||||
|
};
|
||||||
|
|
||||||
|
var ALL_CATEGORY = 'All';
|
||||||
|
var categoryNameMap = {
|
||||||
|
symbols: 'Symbols',
|
||||||
|
people: 'People',
|
||||||
|
animals_and_nature: 'Animals and Nature',
|
||||||
|
food_and_drink: 'Food and Drink',
|
||||||
|
activity: 'Activity',
|
||||||
|
travel_and_places: 'Travel and Places',
|
||||||
|
objects: 'Objects',
|
||||||
|
flags: 'Flags',
|
||||||
|
user: 'User Defined'
|
||||||
|
};
|
||||||
|
var translateCategory = function (categories, name) {
|
||||||
|
return has(categories, name) ? categories[name] : name;
|
||||||
|
};
|
||||||
|
var getUserDefinedEmoticons = function (editor) {
|
||||||
|
var userDefinedEmoticons = getAppendedEmoticons(editor);
|
||||||
|
return map(userDefinedEmoticons, function (value) {
|
||||||
|
return __assign({
|
||||||
|
keywords: [],
|
||||||
|
category: 'user'
|
||||||
|
}, value);
|
||||||
|
});
|
||||||
|
};
|
||||||
|
var initDatabase = function (editor, databaseUrl, databaseId) {
|
||||||
|
var categories = value();
|
||||||
|
var all = value();
|
||||||
|
var emojiImagesUrl = getEmotionsImageUrl(editor);
|
||||||
|
var getEmoji = function (lib) {
|
||||||
|
if (startsWith(lib.char, '<img')) {
|
||||||
|
return lib.char.replace(/src="([^"]+)"/, function (match, url) {
|
||||||
|
return 'src="' + emojiImagesUrl + url + '"';
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
return lib.char;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
var processEmojis = function (emojis) {
|
||||||
|
var cats = {};
|
||||||
|
var everything = [];
|
||||||
|
each(emojis, function (lib, title) {
|
||||||
|
var entry = {
|
||||||
|
title: title,
|
||||||
|
keywords: lib.keywords,
|
||||||
|
char: getEmoji(lib),
|
||||||
|
category: translateCategory(categoryNameMap, lib.category)
|
||||||
|
};
|
||||||
|
var current = cats[entry.category] !== undefined ? cats[entry.category] : [];
|
||||||
|
cats[entry.category] = current.concat([entry]);
|
||||||
|
everything.push(entry);
|
||||||
|
});
|
||||||
|
categories.set(cats);
|
||||||
|
all.set(everything);
|
||||||
|
};
|
||||||
|
editor.on('init', function () {
|
||||||
|
global$2.load(databaseId, databaseUrl).then(function (emojis) {
|
||||||
|
var userEmojis = getUserDefinedEmoticons(editor);
|
||||||
|
processEmojis(merge(emojis, userEmojis));
|
||||||
|
}, function (err) {
|
||||||
|
console.log('Failed to load emoticons: ' + err);
|
||||||
|
categories.set({});
|
||||||
|
all.set([]);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
var listCategory = function (category) {
|
||||||
|
if (category === ALL_CATEGORY) {
|
||||||
|
return listAll();
|
||||||
|
}
|
||||||
|
return categories.get().bind(function (cats) {
|
||||||
|
return Optional.from(cats[category]);
|
||||||
|
}).getOr([]);
|
||||||
|
};
|
||||||
|
var listAll = function () {
|
||||||
|
return all.get().getOr([]);
|
||||||
|
};
|
||||||
|
var listCategories = function () {
|
||||||
|
return [ALL_CATEGORY].concat(keys(categories.get().getOr({})));
|
||||||
|
};
|
||||||
|
var waitForLoad = function () {
|
||||||
|
if (hasLoaded()) {
|
||||||
|
return global.resolve(true);
|
||||||
|
} else {
|
||||||
|
return new global(function (resolve, reject) {
|
||||||
|
var numRetries = 15;
|
||||||
|
var interval = global$1.setInterval(function () {
|
||||||
|
if (hasLoaded()) {
|
||||||
|
global$1.clearInterval(interval);
|
||||||
|
resolve(true);
|
||||||
|
} else {
|
||||||
|
numRetries--;
|
||||||
|
if (numRetries < 0) {
|
||||||
|
console.log('Could not load emojis from url: ' + databaseUrl);
|
||||||
|
global$1.clearInterval(interval);
|
||||||
|
reject(false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}, 100);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
};
|
||||||
|
var hasLoaded = function () {
|
||||||
|
return categories.isSet() && all.isSet();
|
||||||
|
};
|
||||||
|
return {
|
||||||
|
listCategories: listCategories,
|
||||||
|
hasLoaded: hasLoaded,
|
||||||
|
waitForLoad: waitForLoad,
|
||||||
|
listAll: listAll,
|
||||||
|
listCategory: listCategory
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
var emojiMatches = function (emoji, lowerCasePattern) {
|
||||||
|
return contains(emoji.title.toLowerCase(), lowerCasePattern) || exists(emoji.keywords, function (k) {
|
||||||
|
return contains(k.toLowerCase(), lowerCasePattern);
|
||||||
|
});
|
||||||
|
};
|
||||||
|
var emojisFrom = function (list, pattern, maxResults) {
|
||||||
|
var matches = [];
|
||||||
|
var lowerCasePattern = pattern.toLowerCase();
|
||||||
|
var reachedLimit = maxResults.fold(function () {
|
||||||
|
return never;
|
||||||
|
}, function (max) {
|
||||||
|
return function (size) {
|
||||||
|
return size >= max;
|
||||||
|
};
|
||||||
|
});
|
||||||
|
for (var i = 0; i < list.length; i++) {
|
||||||
|
if (pattern.length === 0 || emojiMatches(list[i], lowerCasePattern)) {
|
||||||
|
matches.push({
|
||||||
|
value: list[i].char,
|
||||||
|
text: list[i].title,
|
||||||
|
icon: list[i].char
|
||||||
|
});
|
||||||
|
if (reachedLimit(matches.length)) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return matches;
|
||||||
|
};
|
||||||
|
|
||||||
|
var patternName = 'pattern';
|
||||||
|
var open = function (editor, database) {
|
||||||
|
var initialState = {
|
||||||
|
pattern: '',
|
||||||
|
results: emojisFrom(database.listAll(), '', Optional.some(300))
|
||||||
|
};
|
||||||
|
var currentTab = Cell(ALL_CATEGORY);
|
||||||
|
var scan = function (dialogApi) {
|
||||||
|
var dialogData = dialogApi.getData();
|
||||||
|
var category = currentTab.get();
|
||||||
|
var candidates = database.listCategory(category);
|
||||||
|
var results = emojisFrom(candidates, dialogData[patternName], category === ALL_CATEGORY ? Optional.some(300) : Optional.none());
|
||||||
|
dialogApi.setData({ results: results });
|
||||||
|
};
|
||||||
|
var updateFilter = last(function (dialogApi) {
|
||||||
|
scan(dialogApi);
|
||||||
|
}, 200);
|
||||||
|
var searchField = {
|
||||||
|
label: 'Search',
|
||||||
|
type: 'input',
|
||||||
|
name: patternName
|
||||||
|
};
|
||||||
|
var resultsField = {
|
||||||
|
type: 'collection',
|
||||||
|
name: 'results'
|
||||||
|
};
|
||||||
|
var getInitialState = function () {
|
||||||
|
var body = {
|
||||||
|
type: 'tabpanel',
|
||||||
|
tabs: map$1(database.listCategories(), function (cat) {
|
||||||
|
return {
|
||||||
|
title: cat,
|
||||||
|
name: cat,
|
||||||
|
items: [
|
||||||
|
searchField,
|
||||||
|
resultsField
|
||||||
|
]
|
||||||
|
};
|
||||||
|
})
|
||||||
|
};
|
||||||
|
return {
|
||||||
|
title: 'Emoticons',
|
||||||
|
size: 'normal',
|
||||||
|
body: body,
|
||||||
|
initialData: initialState,
|
||||||
|
onTabChange: function (dialogApi, details) {
|
||||||
|
currentTab.set(details.newTabName);
|
||||||
|
updateFilter.throttle(dialogApi);
|
||||||
|
},
|
||||||
|
onChange: updateFilter.throttle,
|
||||||
|
onAction: function (dialogApi, actionData) {
|
||||||
|
if (actionData.name === 'results') {
|
||||||
|
insertEmoticon(editor, actionData.value);
|
||||||
|
dialogApi.close();
|
||||||
|
}
|
||||||
|
},
|
||||||
|
buttons: [{
|
||||||
|
type: 'cancel',
|
||||||
|
text: 'Close',
|
||||||
|
primary: true
|
||||||
|
}]
|
||||||
|
};
|
||||||
|
};
|
||||||
|
var dialogApi = editor.windowManager.open(getInitialState());
|
||||||
|
dialogApi.focus(patternName);
|
||||||
|
if (!database.hasLoaded()) {
|
||||||
|
dialogApi.block('Loading emoticons...');
|
||||||
|
database.waitForLoad().then(function () {
|
||||||
|
dialogApi.redial(getInitialState());
|
||||||
|
updateFilter.throttle(dialogApi);
|
||||||
|
dialogApi.focus(patternName);
|
||||||
|
dialogApi.unblock();
|
||||||
|
}).catch(function (_err) {
|
||||||
|
dialogApi.redial({
|
||||||
|
title: 'Emoticons',
|
||||||
|
body: {
|
||||||
|
type: 'panel',
|
||||||
|
items: [{
|
||||||
|
type: 'alertbanner',
|
||||||
|
level: 'error',
|
||||||
|
icon: 'warning',
|
||||||
|
text: '<p>Could not load emoticons</p>'
|
||||||
|
}]
|
||||||
|
},
|
||||||
|
buttons: [{
|
||||||
|
type: 'cancel',
|
||||||
|
text: 'Close',
|
||||||
|
primary: true
|
||||||
|
}],
|
||||||
|
initialData: {
|
||||||
|
pattern: '',
|
||||||
|
results: []
|
||||||
|
}
|
||||||
|
});
|
||||||
|
dialogApi.focus(patternName);
|
||||||
|
dialogApi.unblock();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
var register$1 = function (editor, database) {
|
||||||
|
editor.addCommand('mceEmoticons', function () {
|
||||||
|
return open(editor, database);
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
var setup = function (editor) {
|
||||||
|
editor.on('PreInit', function () {
|
||||||
|
editor.parser.addAttributeFilter('data-emoticon', function (nodes) {
|
||||||
|
each$1(nodes, function (node) {
|
||||||
|
node.attr('data-mce-resize', 'false');
|
||||||
|
node.attr('data-mce-placeholder', '1');
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
var init = function (editor, database) {
|
||||||
|
editor.ui.registry.addAutocompleter('emoticons', {
|
||||||
|
ch: ':',
|
||||||
|
columns: 'auto',
|
||||||
|
minChars: 2,
|
||||||
|
fetch: function (pattern, maxResults) {
|
||||||
|
return database.waitForLoad().then(function () {
|
||||||
|
var candidates = database.listAll();
|
||||||
|
return emojisFrom(candidates, pattern, Optional.some(maxResults));
|
||||||
|
});
|
||||||
|
},
|
||||||
|
onAction: function (autocompleteApi, rng, value) {
|
||||||
|
editor.selection.setRng(rng);
|
||||||
|
editor.insertContent(value);
|
||||||
|
autocompleteApi.hide();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
var register = function (editor) {
|
||||||
|
var onAction = function () {
|
||||||
|
return editor.execCommand('mceEmoticons');
|
||||||
|
};
|
||||||
|
editor.ui.registry.addButton('emoticons', {
|
||||||
|
tooltip: 'Emoticons',
|
||||||
|
icon: 'emoji',
|
||||||
|
onAction: onAction
|
||||||
|
});
|
||||||
|
editor.ui.registry.addMenuItem('emoticons', {
|
||||||
|
text: 'Emoticons...',
|
||||||
|
icon: 'emoji',
|
||||||
|
onAction: onAction
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
function Plugin () {
|
||||||
|
global$3.add('emoticons', function (editor, pluginUrl) {
|
||||||
|
var databaseUrl = getEmoticonDatabaseUrl(editor, pluginUrl);
|
||||||
|
var databaseId = getEmoticonDatabaseId(editor);
|
||||||
|
var database = initDatabase(editor, databaseUrl, databaseId);
|
||||||
|
register$1(editor, database);
|
||||||
|
register(editor);
|
||||||
|
init(editor, database);
|
||||||
|
setup(editor);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
Plugin();
|
||||||
|
|
||||||
|
}());
|
File diff suppressed because one or more lines are too long
|
@ -0,0 +1,7 @@
|
||||||
|
// Exports the "fullpage" plugin for usage with module loaders
|
||||||
|
// Usage:
|
||||||
|
// CommonJS:
|
||||||
|
// require('tinymce/plugins/fullpage')
|
||||||
|
// ES2015:
|
||||||
|
// import 'tinymce/plugins/fullpage'
|
||||||
|
require('./plugin.js');
|
|
@ -0,0 +1,545 @@
|
||||||
|
/**
|
||||||
|
* Copyright (c) Tiny Technologies, Inc. All rights reserved.
|
||||||
|
* Licensed under the LGPL or a commercial license.
|
||||||
|
* For LGPL see License.txt in the project root for license information.
|
||||||
|
* For commercial licenses see https://www.tiny.cloud/
|
||||||
|
*
|
||||||
|
* Version: 5.9.2 (2021-09-08)
|
||||||
|
*/
|
||||||
|
(function () {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
var Cell = function (initial) {
|
||||||
|
var value = initial;
|
||||||
|
var get = function () {
|
||||||
|
return value;
|
||||||
|
};
|
||||||
|
var set = function (v) {
|
||||||
|
value = v;
|
||||||
|
};
|
||||||
|
return {
|
||||||
|
get: get,
|
||||||
|
set: set
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
var global$4 = tinymce.util.Tools.resolve('tinymce.PluginManager');
|
||||||
|
|
||||||
|
var __assign = function () {
|
||||||
|
__assign = Object.assign || function __assign(t) {
|
||||||
|
for (var s, i = 1, n = arguments.length; i < n; i++) {
|
||||||
|
s = arguments[i];
|
||||||
|
for (var p in s)
|
||||||
|
if (Object.prototype.hasOwnProperty.call(s, p))
|
||||||
|
t[p] = s[p];
|
||||||
|
}
|
||||||
|
return t;
|
||||||
|
};
|
||||||
|
return __assign.apply(this, arguments);
|
||||||
|
};
|
||||||
|
|
||||||
|
var global$3 = tinymce.util.Tools.resolve('tinymce.util.Tools');
|
||||||
|
|
||||||
|
var global$2 = tinymce.util.Tools.resolve('tinymce.html.DomParser');
|
||||||
|
|
||||||
|
var global$1 = tinymce.util.Tools.resolve('tinymce.html.Node');
|
||||||
|
|
||||||
|
var global = tinymce.util.Tools.resolve('tinymce.html.Serializer');
|
||||||
|
|
||||||
|
var shouldHideInSourceView = function (editor) {
|
||||||
|
return editor.getParam('fullpage_hide_in_source_view');
|
||||||
|
};
|
||||||
|
var getDefaultXmlPi = function (editor) {
|
||||||
|
return editor.getParam('fullpage_default_xml_pi');
|
||||||
|
};
|
||||||
|
var getDefaultEncoding = function (editor) {
|
||||||
|
return editor.getParam('fullpage_default_encoding');
|
||||||
|
};
|
||||||
|
var getDefaultFontFamily = function (editor) {
|
||||||
|
return editor.getParam('fullpage_default_font_family');
|
||||||
|
};
|
||||||
|
var getDefaultFontSize = function (editor) {
|
||||||
|
return editor.getParam('fullpage_default_font_size');
|
||||||
|
};
|
||||||
|
var getDefaultTextColor = function (editor) {
|
||||||
|
return editor.getParam('fullpage_default_text_color');
|
||||||
|
};
|
||||||
|
var getDefaultTitle = function (editor) {
|
||||||
|
return editor.getParam('fullpage_default_title');
|
||||||
|
};
|
||||||
|
var getDefaultDocType = function (editor) {
|
||||||
|
return editor.getParam('fullpage_default_doctype', '<!DOCTYPE html>');
|
||||||
|
};
|
||||||
|
var getProtect = function (editor) {
|
||||||
|
return editor.getParam('protect');
|
||||||
|
};
|
||||||
|
|
||||||
|
var parseHeader = function (editor, head) {
|
||||||
|
return global$2({
|
||||||
|
validate: false,
|
||||||
|
root_name: '#document'
|
||||||
|
}, editor.schema).parse(head, { format: 'xhtml' });
|
||||||
|
};
|
||||||
|
var htmlToData = function (editor, head) {
|
||||||
|
var headerFragment = parseHeader(editor, head);
|
||||||
|
var data = {};
|
||||||
|
var elm, matches;
|
||||||
|
var getAttr = function (elm, name) {
|
||||||
|
var value = elm.attr(name);
|
||||||
|
return value || '';
|
||||||
|
};
|
||||||
|
data.fontface = getDefaultFontFamily(editor);
|
||||||
|
data.fontsize = getDefaultFontSize(editor);
|
||||||
|
elm = headerFragment.firstChild;
|
||||||
|
if (elm.type === 7) {
|
||||||
|
data.xml_pi = true;
|
||||||
|
matches = /encoding="([^"]+)"/.exec(elm.value);
|
||||||
|
if (matches) {
|
||||||
|
data.docencoding = matches[1];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
elm = headerFragment.getAll('#doctype')[0];
|
||||||
|
if (elm) {
|
||||||
|
data.doctype = '<!DOCTYPE' + elm.value + '>';
|
||||||
|
}
|
||||||
|
elm = headerFragment.getAll('title')[0];
|
||||||
|
if (elm && elm.firstChild) {
|
||||||
|
data.title = elm.firstChild.value;
|
||||||
|
}
|
||||||
|
global$3.each(headerFragment.getAll('meta'), function (meta) {
|
||||||
|
var name = meta.attr('name');
|
||||||
|
var httpEquiv = meta.attr('http-equiv');
|
||||||
|
var matches;
|
||||||
|
if (name) {
|
||||||
|
data[name.toLowerCase()] = meta.attr('content');
|
||||||
|
} else if (httpEquiv === 'Content-Type') {
|
||||||
|
matches = /charset\s*=\s*(.*)\s*/gi.exec(meta.attr('content'));
|
||||||
|
if (matches) {
|
||||||
|
data.docencoding = matches[1];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
elm = headerFragment.getAll('html')[0];
|
||||||
|
if (elm) {
|
||||||
|
data.langcode = getAttr(elm, 'lang') || getAttr(elm, 'xml:lang');
|
||||||
|
}
|
||||||
|
data.stylesheets = [];
|
||||||
|
global$3.each(headerFragment.getAll('link'), function (link) {
|
||||||
|
if (link.attr('rel') === 'stylesheet') {
|
||||||
|
data.stylesheets.push(link.attr('href'));
|
||||||
|
}
|
||||||
|
});
|
||||||
|
elm = headerFragment.getAll('body')[0];
|
||||||
|
if (elm) {
|
||||||
|
data.langdir = getAttr(elm, 'dir');
|
||||||
|
data.style = getAttr(elm, 'style');
|
||||||
|
data.visited_color = getAttr(elm, 'vlink');
|
||||||
|
data.link_color = getAttr(elm, 'link');
|
||||||
|
data.active_color = getAttr(elm, 'alink');
|
||||||
|
}
|
||||||
|
return data;
|
||||||
|
};
|
||||||
|
var dataToHtml = function (editor, data, head) {
|
||||||
|
var headElement, elm;
|
||||||
|
var dom = editor.dom;
|
||||||
|
var setAttr = function (elm, name, value) {
|
||||||
|
elm.attr(name, value ? value : undefined);
|
||||||
|
};
|
||||||
|
var addHeadNode = function (node) {
|
||||||
|
if (headElement.firstChild) {
|
||||||
|
headElement.insert(node, headElement.firstChild);
|
||||||
|
} else {
|
||||||
|
headElement.append(node);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
var headerFragment = parseHeader(editor, head);
|
||||||
|
headElement = headerFragment.getAll('head')[0];
|
||||||
|
if (!headElement) {
|
||||||
|
elm = headerFragment.getAll('html')[0];
|
||||||
|
headElement = new global$1('head', 1);
|
||||||
|
if (elm.firstChild) {
|
||||||
|
elm.insert(headElement, elm.firstChild, true);
|
||||||
|
} else {
|
||||||
|
elm.append(headElement);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
elm = headerFragment.firstChild;
|
||||||
|
if (data.xml_pi) {
|
||||||
|
var value = 'version="1.0"';
|
||||||
|
if (data.docencoding) {
|
||||||
|
value += ' encoding="' + data.docencoding + '"';
|
||||||
|
}
|
||||||
|
if (elm.type !== 7) {
|
||||||
|
elm = new global$1('xml', 7);
|
||||||
|
headerFragment.insert(elm, headerFragment.firstChild, true);
|
||||||
|
}
|
||||||
|
elm.value = value;
|
||||||
|
} else if (elm && elm.type === 7) {
|
||||||
|
elm.remove();
|
||||||
|
}
|
||||||
|
elm = headerFragment.getAll('#doctype')[0];
|
||||||
|
if (data.doctype) {
|
||||||
|
if (!elm) {
|
||||||
|
elm = new global$1('#doctype', 10);
|
||||||
|
if (data.xml_pi) {
|
||||||
|
headerFragment.insert(elm, headerFragment.firstChild);
|
||||||
|
} else {
|
||||||
|
addHeadNode(elm);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
elm.value = data.doctype.substring(9, data.doctype.length - 1);
|
||||||
|
} else if (elm) {
|
||||||
|
elm.remove();
|
||||||
|
}
|
||||||
|
elm = null;
|
||||||
|
global$3.each(headerFragment.getAll('meta'), function (meta) {
|
||||||
|
if (meta.attr('http-equiv') === 'Content-Type') {
|
||||||
|
elm = meta;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
if (data.docencoding) {
|
||||||
|
if (!elm) {
|
||||||
|
elm = new global$1('meta', 1);
|
||||||
|
elm.attr('http-equiv', 'Content-Type');
|
||||||
|
elm.shortEnded = true;
|
||||||
|
addHeadNode(elm);
|
||||||
|
}
|
||||||
|
elm.attr('content', 'text/html; charset=' + data.docencoding);
|
||||||
|
} else if (elm) {
|
||||||
|
elm.remove();
|
||||||
|
}
|
||||||
|
elm = headerFragment.getAll('title')[0];
|
||||||
|
if (data.title) {
|
||||||
|
if (!elm) {
|
||||||
|
elm = new global$1('title', 1);
|
||||||
|
addHeadNode(elm);
|
||||||
|
} else {
|
||||||
|
elm.empty();
|
||||||
|
}
|
||||||
|
elm.append(new global$1('#text', 3)).value = data.title;
|
||||||
|
} else if (elm) {
|
||||||
|
elm.remove();
|
||||||
|
}
|
||||||
|
global$3.each('keywords,description,author,copyright,robots'.split(','), function (name) {
|
||||||
|
var nodes = headerFragment.getAll('meta');
|
||||||
|
var i, meta;
|
||||||
|
var value = data[name];
|
||||||
|
for (i = 0; i < nodes.length; i++) {
|
||||||
|
meta = nodes[i];
|
||||||
|
if (meta.attr('name') === name) {
|
||||||
|
if (value) {
|
||||||
|
meta.attr('content', value);
|
||||||
|
} else {
|
||||||
|
meta.remove();
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (value) {
|
||||||
|
elm = new global$1('meta', 1);
|
||||||
|
elm.attr('name', name);
|
||||||
|
elm.attr('content', value);
|
||||||
|
elm.shortEnded = true;
|
||||||
|
addHeadNode(elm);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
var currentStyleSheetsMap = {};
|
||||||
|
global$3.each(headerFragment.getAll('link'), function (stylesheet) {
|
||||||
|
if (stylesheet.attr('rel') === 'stylesheet') {
|
||||||
|
currentStyleSheetsMap[stylesheet.attr('href')] = stylesheet;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
global$3.each(data.stylesheets, function (stylesheet) {
|
||||||
|
if (!currentStyleSheetsMap[stylesheet]) {
|
||||||
|
elm = new global$1('link', 1);
|
||||||
|
elm.attr({
|
||||||
|
rel: 'stylesheet',
|
||||||
|
text: 'text/css',
|
||||||
|
href: stylesheet
|
||||||
|
});
|
||||||
|
elm.shortEnded = true;
|
||||||
|
addHeadNode(elm);
|
||||||
|
}
|
||||||
|
delete currentStyleSheetsMap[stylesheet];
|
||||||
|
});
|
||||||
|
global$3.each(currentStyleSheetsMap, function (stylesheet) {
|
||||||
|
stylesheet.remove();
|
||||||
|
});
|
||||||
|
elm = headerFragment.getAll('body')[0];
|
||||||
|
if (elm) {
|
||||||
|
setAttr(elm, 'dir', data.langdir);
|
||||||
|
setAttr(elm, 'style', data.style);
|
||||||
|
setAttr(elm, 'vlink', data.visited_color);
|
||||||
|
setAttr(elm, 'link', data.link_color);
|
||||||
|
setAttr(elm, 'alink', data.active_color);
|
||||||
|
dom.setAttribs(editor.getBody(), {
|
||||||
|
style: data.style,
|
||||||
|
dir: data.dir,
|
||||||
|
vLink: data.visited_color,
|
||||||
|
link: data.link_color,
|
||||||
|
aLink: data.active_color
|
||||||
|
});
|
||||||
|
}
|
||||||
|
elm = headerFragment.getAll('html')[0];
|
||||||
|
if (elm) {
|
||||||
|
setAttr(elm, 'lang', data.langcode);
|
||||||
|
setAttr(elm, 'xml:lang', data.langcode);
|
||||||
|
}
|
||||||
|
if (!headElement.firstChild) {
|
||||||
|
headElement.remove();
|
||||||
|
}
|
||||||
|
var html = global({
|
||||||
|
validate: false,
|
||||||
|
indent: true,
|
||||||
|
indent_before: 'head,html,body,meta,title,script,link,style',
|
||||||
|
indent_after: 'head,html,body,meta,title,script,link,style'
|
||||||
|
}).serialize(headerFragment);
|
||||||
|
return html.substring(0, html.indexOf('</body>'));
|
||||||
|
};
|
||||||
|
|
||||||
|
var open = function (editor, headState) {
|
||||||
|
var data = htmlToData(editor, headState.get());
|
||||||
|
var defaultData = {
|
||||||
|
title: '',
|
||||||
|
keywords: '',
|
||||||
|
description: '',
|
||||||
|
robots: '',
|
||||||
|
author: '',
|
||||||
|
docencoding: ''
|
||||||
|
};
|
||||||
|
var initialData = __assign(__assign({}, defaultData), data);
|
||||||
|
editor.windowManager.open({
|
||||||
|
title: 'Metadata and Document Properties',
|
||||||
|
size: 'normal',
|
||||||
|
body: {
|
||||||
|
type: 'panel',
|
||||||
|
items: [
|
||||||
|
{
|
||||||
|
name: 'title',
|
||||||
|
type: 'input',
|
||||||
|
label: 'Title'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'keywords',
|
||||||
|
type: 'input',
|
||||||
|
label: 'Keywords'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'description',
|
||||||
|
type: 'input',
|
||||||
|
label: 'Description'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'robots',
|
||||||
|
type: 'input',
|
||||||
|
label: 'Robots'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'author',
|
||||||
|
type: 'input',
|
||||||
|
label: 'Author'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'docencoding',
|
||||||
|
type: 'input',
|
||||||
|
label: 'Encoding'
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
buttons: [
|
||||||
|
{
|
||||||
|
type: 'cancel',
|
||||||
|
name: 'cancel',
|
||||||
|
text: 'Cancel'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
type: 'submit',
|
||||||
|
name: 'save',
|
||||||
|
text: 'Save',
|
||||||
|
primary: true
|
||||||
|
}
|
||||||
|
],
|
||||||
|
initialData: initialData,
|
||||||
|
onSubmit: function (api) {
|
||||||
|
var nuData = api.getData();
|
||||||
|
var headHtml = dataToHtml(editor, global$3.extend(data, nuData), headState.get());
|
||||||
|
headState.set(headHtml);
|
||||||
|
api.close();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
var register$1 = function (editor, headState) {
|
||||||
|
editor.addCommand('mceFullPageProperties', function () {
|
||||||
|
open(editor, headState);
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
var protectHtml = function (protect, html) {
|
||||||
|
global$3.each(protect, function (pattern) {
|
||||||
|
html = html.replace(pattern, function (str) {
|
||||||
|
return '<!--mce:protected ' + escape(str) + '-->';
|
||||||
|
});
|
||||||
|
});
|
||||||
|
return html;
|
||||||
|
};
|
||||||
|
var unprotectHtml = function (html) {
|
||||||
|
return html.replace(/<!--mce:protected ([\s\S]*?)-->/g, function (a, m) {
|
||||||
|
return unescape(m);
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
var each = global$3.each;
|
||||||
|
var low = function (s) {
|
||||||
|
return s.replace(/<\/?[A-Z]+/g, function (a) {
|
||||||
|
return a.toLowerCase();
|
||||||
|
});
|
||||||
|
};
|
||||||
|
var handleSetContent = function (editor, headState, footState, evt) {
|
||||||
|
var startPos, endPos, content, styles = '';
|
||||||
|
var dom = editor.dom;
|
||||||
|
if (evt.selection) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
content = protectHtml(getProtect(editor), evt.content);
|
||||||
|
if (evt.format === 'raw' && headState.get()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (evt.source_view && shouldHideInSourceView(editor)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (content.length === 0 && !evt.source_view) {
|
||||||
|
content = global$3.trim(headState.get()) + '\n' + global$3.trim(content) + '\n' + global$3.trim(footState.get());
|
||||||
|
}
|
||||||
|
content = content.replace(/<(\/?)BODY/gi, '<$1body');
|
||||||
|
startPos = content.indexOf('<body');
|
||||||
|
if (startPos !== -1) {
|
||||||
|
startPos = content.indexOf('>', startPos);
|
||||||
|
headState.set(low(content.substring(0, startPos + 1)));
|
||||||
|
endPos = content.indexOf('</body', startPos);
|
||||||
|
if (endPos === -1) {
|
||||||
|
endPos = content.length;
|
||||||
|
}
|
||||||
|
evt.content = global$3.trim(content.substring(startPos + 1, endPos));
|
||||||
|
footState.set(low(content.substring(endPos)));
|
||||||
|
} else {
|
||||||
|
headState.set(getDefaultHeader(editor));
|
||||||
|
footState.set('\n</body>\n</html>');
|
||||||
|
}
|
||||||
|
var headerFragment = parseHeader(editor, headState.get());
|
||||||
|
each(headerFragment.getAll('style'), function (node) {
|
||||||
|
if (node.firstChild) {
|
||||||
|
styles += node.firstChild.value;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
var bodyElm = headerFragment.getAll('body')[0];
|
||||||
|
if (bodyElm) {
|
||||||
|
dom.setAttribs(editor.getBody(), {
|
||||||
|
style: bodyElm.attr('style') || '',
|
||||||
|
dir: bodyElm.attr('dir') || '',
|
||||||
|
vLink: bodyElm.attr('vlink') || '',
|
||||||
|
link: bodyElm.attr('link') || '',
|
||||||
|
aLink: bodyElm.attr('alink') || ''
|
||||||
|
});
|
||||||
|
}
|
||||||
|
dom.remove('fullpage_styles');
|
||||||
|
var headElm = editor.getDoc().getElementsByTagName('head')[0];
|
||||||
|
if (styles) {
|
||||||
|
var styleElm = dom.add(headElm, 'style', { id: 'fullpage_styles' });
|
||||||
|
styleElm.appendChild(document.createTextNode(styles));
|
||||||
|
}
|
||||||
|
var currentStyleSheetsMap = {};
|
||||||
|
global$3.each(headElm.getElementsByTagName('link'), function (stylesheet) {
|
||||||
|
if (stylesheet.rel === 'stylesheet' && stylesheet.getAttribute('data-mce-fullpage')) {
|
||||||
|
currentStyleSheetsMap[stylesheet.href] = stylesheet;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
global$3.each(headerFragment.getAll('link'), function (stylesheet) {
|
||||||
|
var href = stylesheet.attr('href');
|
||||||
|
if (!href) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (!currentStyleSheetsMap[href] && stylesheet.attr('rel') === 'stylesheet') {
|
||||||
|
dom.add(headElm, 'link', {
|
||||||
|
'rel': 'stylesheet',
|
||||||
|
'text': 'text/css',
|
||||||
|
href: href,
|
||||||
|
'data-mce-fullpage': '1'
|
||||||
|
});
|
||||||
|
}
|
||||||
|
delete currentStyleSheetsMap[href];
|
||||||
|
});
|
||||||
|
global$3.each(currentStyleSheetsMap, function (stylesheet) {
|
||||||
|
stylesheet.parentNode.removeChild(stylesheet);
|
||||||
|
});
|
||||||
|
};
|
||||||
|
var getDefaultHeader = function (editor) {
|
||||||
|
var header = '', value, styles = '';
|
||||||
|
if (getDefaultXmlPi(editor)) {
|
||||||
|
var piEncoding = getDefaultEncoding(editor);
|
||||||
|
header += '<?xml version="1.0" encoding="' + (piEncoding ? piEncoding : 'ISO-8859-1') + '" ?>\n';
|
||||||
|
}
|
||||||
|
header += getDefaultDocType(editor);
|
||||||
|
header += '\n<html>\n<head>\n';
|
||||||
|
if (value = getDefaultTitle(editor)) {
|
||||||
|
header += '<title>' + value + '</title>\n';
|
||||||
|
}
|
||||||
|
if (value = getDefaultEncoding(editor)) {
|
||||||
|
header += '<meta http-equiv="Content-Type" content="text/html; charset=' + value + '" />\n';
|
||||||
|
}
|
||||||
|
if (value = getDefaultFontFamily(editor)) {
|
||||||
|
styles += 'font-family: ' + value + ';';
|
||||||
|
}
|
||||||
|
if (value = getDefaultFontSize(editor)) {
|
||||||
|
styles += 'font-size: ' + value + ';';
|
||||||
|
}
|
||||||
|
if (value = getDefaultTextColor(editor)) {
|
||||||
|
styles += 'color: ' + value + ';';
|
||||||
|
}
|
||||||
|
header += '</head>\n<body' + (styles ? ' style="' + styles + '"' : '') + '>\n';
|
||||||
|
return header;
|
||||||
|
};
|
||||||
|
var handleGetContent = function (editor, head, foot, evt) {
|
||||||
|
if (evt.format === 'html' && !evt.selection && (!evt.source_view || !shouldHideInSourceView(editor))) {
|
||||||
|
evt.content = unprotectHtml(global$3.trim(head) + '\n' + global$3.trim(evt.content) + '\n' + global$3.trim(foot));
|
||||||
|
}
|
||||||
|
};
|
||||||
|
var setup = function (editor, headState, footState) {
|
||||||
|
editor.on('BeforeSetContent', function (evt) {
|
||||||
|
handleSetContent(editor, headState, footState, evt);
|
||||||
|
});
|
||||||
|
editor.on('GetContent', function (evt) {
|
||||||
|
handleGetContent(editor, headState.get(), footState.get(), evt);
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
var register = function (editor) {
|
||||||
|
editor.ui.registry.addButton('fullpage', {
|
||||||
|
tooltip: 'Metadata and document properties',
|
||||||
|
icon: 'document-properties',
|
||||||
|
onAction: function () {
|
||||||
|
editor.execCommand('mceFullPageProperties');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
editor.ui.registry.addMenuItem('fullpage', {
|
||||||
|
text: 'Metadata and document properties',
|
||||||
|
icon: 'document-properties',
|
||||||
|
onAction: function () {
|
||||||
|
editor.execCommand('mceFullPageProperties');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
function Plugin () {
|
||||||
|
global$4.add('fullpage', function (editor) {
|
||||||
|
console.warn('The fullpage plugin has been deprecated and marked for removal in TinyMCE 6.0');
|
||||||
|
var headState = Cell(''), footState = Cell('');
|
||||||
|
register$1(editor, headState);
|
||||||
|
register(editor);
|
||||||
|
setup(editor, headState, footState);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
Plugin();
|
||||||
|
|
||||||
|
}());
|
File diff suppressed because one or more lines are too long
|
@ -0,0 +1,7 @@
|
||||||
|
// Exports the "fullscreen" plugin for usage with module loaders
|
||||||
|
// Usage:
|
||||||
|
// CommonJS:
|
||||||
|
// require('tinymce/plugins/fullscreen')
|
||||||
|
// ES2015:
|
||||||
|
// import 'tinymce/plugins/fullscreen'
|
||||||
|
require('./plugin.js');
|
|
@ -0,0 +1,963 @@
|
||||||
|
/**
|
||||||
|
* Copyright (c) Tiny Technologies, Inc. All rights reserved.
|
||||||
|
* Licensed under the LGPL or a commercial license.
|
||||||
|
* For LGPL see License.txt in the project root for license information.
|
||||||
|
* For commercial licenses see https://www.tiny.cloud/
|
||||||
|
*
|
||||||
|
* Version: 5.9.2 (2021-09-08)
|
||||||
|
*/
|
||||||
|
(function () {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
var Cell = function (initial) {
|
||||||
|
var value = initial;
|
||||||
|
var get = function () {
|
||||||
|
return value;
|
||||||
|
};
|
||||||
|
var set = function (v) {
|
||||||
|
value = v;
|
||||||
|
};
|
||||||
|
return {
|
||||||
|
get: get,
|
||||||
|
set: set
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
var global$3 = tinymce.util.Tools.resolve('tinymce.PluginManager');
|
||||||
|
|
||||||
|
var get$5 = function (fullscreenState) {
|
||||||
|
return {
|
||||||
|
isFullscreen: function () {
|
||||||
|
return fullscreenState.get() !== null;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
var typeOf = function (x) {
|
||||||
|
var t = typeof x;
|
||||||
|
if (x === null) {
|
||||||
|
return 'null';
|
||||||
|
} else if (t === 'object' && (Array.prototype.isPrototypeOf(x) || x.constructor && x.constructor.name === 'Array')) {
|
||||||
|
return 'array';
|
||||||
|
} else if (t === 'object' && (String.prototype.isPrototypeOf(x) || x.constructor && x.constructor.name === 'String')) {
|
||||||
|
return 'string';
|
||||||
|
} else {
|
||||||
|
return t;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
var isType$1 = function (type) {
|
||||||
|
return function (value) {
|
||||||
|
return typeOf(value) === type;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
var isSimpleType = function (type) {
|
||||||
|
return function (value) {
|
||||||
|
return typeof value === type;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
var isString = isType$1('string');
|
||||||
|
var isArray = isType$1('array');
|
||||||
|
var isBoolean = isSimpleType('boolean');
|
||||||
|
var isNullable = function (a) {
|
||||||
|
return a === null || a === undefined;
|
||||||
|
};
|
||||||
|
var isNonNullable = function (a) {
|
||||||
|
return !isNullable(a);
|
||||||
|
};
|
||||||
|
var isFunction = isSimpleType('function');
|
||||||
|
var isNumber = isSimpleType('number');
|
||||||
|
|
||||||
|
var noop = function () {
|
||||||
|
};
|
||||||
|
var compose = function (fa, fb) {
|
||||||
|
return function () {
|
||||||
|
var args = [];
|
||||||
|
for (var _i = 0; _i < arguments.length; _i++) {
|
||||||
|
args[_i] = arguments[_i];
|
||||||
|
}
|
||||||
|
return fa(fb.apply(null, args));
|
||||||
|
};
|
||||||
|
};
|
||||||
|
var compose1 = function (fbc, fab) {
|
||||||
|
return function (a) {
|
||||||
|
return fbc(fab(a));
|
||||||
|
};
|
||||||
|
};
|
||||||
|
var constant = function (value) {
|
||||||
|
return function () {
|
||||||
|
return value;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
var identity = function (x) {
|
||||||
|
return x;
|
||||||
|
};
|
||||||
|
function curry(fn) {
|
||||||
|
var initialArgs = [];
|
||||||
|
for (var _i = 1; _i < arguments.length; _i++) {
|
||||||
|
initialArgs[_i - 1] = arguments[_i];
|
||||||
|
}
|
||||||
|
return function () {
|
||||||
|
var restArgs = [];
|
||||||
|
for (var _i = 0; _i < arguments.length; _i++) {
|
||||||
|
restArgs[_i] = arguments[_i];
|
||||||
|
}
|
||||||
|
var all = initialArgs.concat(restArgs);
|
||||||
|
return fn.apply(null, all);
|
||||||
|
};
|
||||||
|
}
|
||||||
|
var never = constant(false);
|
||||||
|
var always = constant(true);
|
||||||
|
|
||||||
|
var none = function () {
|
||||||
|
return NONE;
|
||||||
|
};
|
||||||
|
var NONE = function () {
|
||||||
|
var call = function (thunk) {
|
||||||
|
return thunk();
|
||||||
|
};
|
||||||
|
var id = identity;
|
||||||
|
var me = {
|
||||||
|
fold: function (n, _s) {
|
||||||
|
return n();
|
||||||
|
},
|
||||||
|
isSome: never,
|
||||||
|
isNone: always,
|
||||||
|
getOr: id,
|
||||||
|
getOrThunk: call,
|
||||||
|
getOrDie: function (msg) {
|
||||||
|
throw new Error(msg || 'error: getOrDie called on none.');
|
||||||
|
},
|
||||||
|
getOrNull: constant(null),
|
||||||
|
getOrUndefined: constant(undefined),
|
||||||
|
or: id,
|
||||||
|
orThunk: call,
|
||||||
|
map: none,
|
||||||
|
each: noop,
|
||||||
|
bind: none,
|
||||||
|
exists: never,
|
||||||
|
forall: always,
|
||||||
|
filter: function () {
|
||||||
|
return none();
|
||||||
|
},
|
||||||
|
toArray: function () {
|
||||||
|
return [];
|
||||||
|
},
|
||||||
|
toString: constant('none()')
|
||||||
|
};
|
||||||
|
return me;
|
||||||
|
}();
|
||||||
|
var some = function (a) {
|
||||||
|
var constant_a = constant(a);
|
||||||
|
var self = function () {
|
||||||
|
return me;
|
||||||
|
};
|
||||||
|
var bind = function (f) {
|
||||||
|
return f(a);
|
||||||
|
};
|
||||||
|
var me = {
|
||||||
|
fold: function (n, s) {
|
||||||
|
return s(a);
|
||||||
|
},
|
||||||
|
isSome: always,
|
||||||
|
isNone: never,
|
||||||
|
getOr: constant_a,
|
||||||
|
getOrThunk: constant_a,
|
||||||
|
getOrDie: constant_a,
|
||||||
|
getOrNull: constant_a,
|
||||||
|
getOrUndefined: constant_a,
|
||||||
|
or: self,
|
||||||
|
orThunk: self,
|
||||||
|
map: function (f) {
|
||||||
|
return some(f(a));
|
||||||
|
},
|
||||||
|
each: function (f) {
|
||||||
|
f(a);
|
||||||
|
},
|
||||||
|
bind: bind,
|
||||||
|
exists: bind,
|
||||||
|
forall: bind,
|
||||||
|
filter: function (f) {
|
||||||
|
return f(a) ? me : NONE;
|
||||||
|
},
|
||||||
|
toArray: function () {
|
||||||
|
return [a];
|
||||||
|
},
|
||||||
|
toString: function () {
|
||||||
|
return 'some(' + a + ')';
|
||||||
|
}
|
||||||
|
};
|
||||||
|
return me;
|
||||||
|
};
|
||||||
|
var from = function (value) {
|
||||||
|
return value === null || value === undefined ? NONE : some(value);
|
||||||
|
};
|
||||||
|
var Optional = {
|
||||||
|
some: some,
|
||||||
|
none: none,
|
||||||
|
from: from
|
||||||
|
};
|
||||||
|
|
||||||
|
var __assign = function () {
|
||||||
|
__assign = Object.assign || function __assign(t) {
|
||||||
|
for (var s, i = 1, n = arguments.length; i < n; i++) {
|
||||||
|
s = arguments[i];
|
||||||
|
for (var p in s)
|
||||||
|
if (Object.prototype.hasOwnProperty.call(s, p))
|
||||||
|
t[p] = s[p];
|
||||||
|
}
|
||||||
|
return t;
|
||||||
|
};
|
||||||
|
return __assign.apply(this, arguments);
|
||||||
|
};
|
||||||
|
|
||||||
|
var singleton = function (doRevoke) {
|
||||||
|
var subject = Cell(Optional.none());
|
||||||
|
var revoke = function () {
|
||||||
|
return subject.get().each(doRevoke);
|
||||||
|
};
|
||||||
|
var clear = function () {
|
||||||
|
revoke();
|
||||||
|
subject.set(Optional.none());
|
||||||
|
};
|
||||||
|
var isSet = function () {
|
||||||
|
return subject.get().isSome();
|
||||||
|
};
|
||||||
|
var get = function () {
|
||||||
|
return subject.get();
|
||||||
|
};
|
||||||
|
var set = function (s) {
|
||||||
|
revoke();
|
||||||
|
subject.set(Optional.some(s));
|
||||||
|
};
|
||||||
|
return {
|
||||||
|
clear: clear,
|
||||||
|
isSet: isSet,
|
||||||
|
get: get,
|
||||||
|
set: set
|
||||||
|
};
|
||||||
|
};
|
||||||
|
var unbindable = function () {
|
||||||
|
return singleton(function (s) {
|
||||||
|
return s.unbind();
|
||||||
|
});
|
||||||
|
};
|
||||||
|
var value = function () {
|
||||||
|
var subject = singleton(noop);
|
||||||
|
var on = function (f) {
|
||||||
|
return subject.get().each(f);
|
||||||
|
};
|
||||||
|
return __assign(__assign({}, subject), { on: on });
|
||||||
|
};
|
||||||
|
|
||||||
|
var nativePush = Array.prototype.push;
|
||||||
|
var map = function (xs, f) {
|
||||||
|
var len = xs.length;
|
||||||
|
var r = new Array(len);
|
||||||
|
for (var i = 0; i < len; i++) {
|
||||||
|
var x = xs[i];
|
||||||
|
r[i] = f(x, i);
|
||||||
|
}
|
||||||
|
return r;
|
||||||
|
};
|
||||||
|
var each$1 = function (xs, f) {
|
||||||
|
for (var i = 0, len = xs.length; i < len; i++) {
|
||||||
|
var x = xs[i];
|
||||||
|
f(x, i);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
var filter$1 = function (xs, pred) {
|
||||||
|
var r = [];
|
||||||
|
for (var i = 0, len = xs.length; i < len; i++) {
|
||||||
|
var x = xs[i];
|
||||||
|
if (pred(x, i)) {
|
||||||
|
r.push(x);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return r;
|
||||||
|
};
|
||||||
|
var flatten = function (xs) {
|
||||||
|
var r = [];
|
||||||
|
for (var i = 0, len = xs.length; i < len; ++i) {
|
||||||
|
if (!isArray(xs[i])) {
|
||||||
|
throw new Error('Arr.flatten item ' + i + ' was not an array, input: ' + xs);
|
||||||
|
}
|
||||||
|
nativePush.apply(r, xs[i]);
|
||||||
|
}
|
||||||
|
return r;
|
||||||
|
};
|
||||||
|
var bind$3 = function (xs, f) {
|
||||||
|
return flatten(map(xs, f));
|
||||||
|
};
|
||||||
|
var get$4 = function (xs, i) {
|
||||||
|
return i >= 0 && i < xs.length ? Optional.some(xs[i]) : Optional.none();
|
||||||
|
};
|
||||||
|
var head = function (xs) {
|
||||||
|
return get$4(xs, 0);
|
||||||
|
};
|
||||||
|
|
||||||
|
var keys = Object.keys;
|
||||||
|
var each = function (obj, f) {
|
||||||
|
var props = keys(obj);
|
||||||
|
for (var k = 0, len = props.length; k < len; k++) {
|
||||||
|
var i = props[k];
|
||||||
|
var x = obj[i];
|
||||||
|
f(x, i);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
var isSupported$1 = function (dom) {
|
||||||
|
return dom.style !== undefined && isFunction(dom.style.getPropertyValue);
|
||||||
|
};
|
||||||
|
|
||||||
|
var fromHtml = function (html, scope) {
|
||||||
|
var doc = scope || document;
|
||||||
|
var div = doc.createElement('div');
|
||||||
|
div.innerHTML = html;
|
||||||
|
if (!div.hasChildNodes() || div.childNodes.length > 1) {
|
||||||
|
console.error('HTML does not have a single root node', html);
|
||||||
|
throw new Error('HTML must have a single root node');
|
||||||
|
}
|
||||||
|
return fromDom(div.childNodes[0]);
|
||||||
|
};
|
||||||
|
var fromTag = function (tag, scope) {
|
||||||
|
var doc = scope || document;
|
||||||
|
var node = doc.createElement(tag);
|
||||||
|
return fromDom(node);
|
||||||
|
};
|
||||||
|
var fromText = function (text, scope) {
|
||||||
|
var doc = scope || document;
|
||||||
|
var node = doc.createTextNode(text);
|
||||||
|
return fromDom(node);
|
||||||
|
};
|
||||||
|
var fromDom = function (node) {
|
||||||
|
if (node === null || node === undefined) {
|
||||||
|
throw new Error('Node cannot be null or undefined');
|
||||||
|
}
|
||||||
|
return { dom: node };
|
||||||
|
};
|
||||||
|
var fromPoint = function (docElm, x, y) {
|
||||||
|
return Optional.from(docElm.dom.elementFromPoint(x, y)).map(fromDom);
|
||||||
|
};
|
||||||
|
var SugarElement = {
|
||||||
|
fromHtml: fromHtml,
|
||||||
|
fromTag: fromTag,
|
||||||
|
fromText: fromText,
|
||||||
|
fromDom: fromDom,
|
||||||
|
fromPoint: fromPoint
|
||||||
|
};
|
||||||
|
|
||||||
|
typeof window !== 'undefined' ? window : Function('return this;')();
|
||||||
|
|
||||||
|
var DOCUMENT = 9;
|
||||||
|
var DOCUMENT_FRAGMENT = 11;
|
||||||
|
var ELEMENT = 1;
|
||||||
|
var TEXT = 3;
|
||||||
|
|
||||||
|
var type = function (element) {
|
||||||
|
return element.dom.nodeType;
|
||||||
|
};
|
||||||
|
var isType = function (t) {
|
||||||
|
return function (element) {
|
||||||
|
return type(element) === t;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
var isElement = isType(ELEMENT);
|
||||||
|
var isText = isType(TEXT);
|
||||||
|
var isDocument = isType(DOCUMENT);
|
||||||
|
var isDocumentFragment = isType(DOCUMENT_FRAGMENT);
|
||||||
|
|
||||||
|
var is = function (element, selector) {
|
||||||
|
var dom = element.dom;
|
||||||
|
if (dom.nodeType !== ELEMENT) {
|
||||||
|
return false;
|
||||||
|
} else {
|
||||||
|
var elem = dom;
|
||||||
|
if (elem.matches !== undefined) {
|
||||||
|
return elem.matches(selector);
|
||||||
|
} else if (elem.msMatchesSelector !== undefined) {
|
||||||
|
return elem.msMatchesSelector(selector);
|
||||||
|
} else if (elem.webkitMatchesSelector !== undefined) {
|
||||||
|
return elem.webkitMatchesSelector(selector);
|
||||||
|
} else if (elem.mozMatchesSelector !== undefined) {
|
||||||
|
return elem.mozMatchesSelector(selector);
|
||||||
|
} else {
|
||||||
|
throw new Error('Browser lacks native selectors');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
var bypassSelector = function (dom) {
|
||||||
|
return dom.nodeType !== ELEMENT && dom.nodeType !== DOCUMENT && dom.nodeType !== DOCUMENT_FRAGMENT || dom.childElementCount === 0;
|
||||||
|
};
|
||||||
|
var all$1 = function (selector, scope) {
|
||||||
|
var base = scope === undefined ? document : scope.dom;
|
||||||
|
return bypassSelector(base) ? [] : map(base.querySelectorAll(selector), SugarElement.fromDom);
|
||||||
|
};
|
||||||
|
|
||||||
|
var eq = function (e1, e2) {
|
||||||
|
return e1.dom === e2.dom;
|
||||||
|
};
|
||||||
|
|
||||||
|
var owner = function (element) {
|
||||||
|
return SugarElement.fromDom(element.dom.ownerDocument);
|
||||||
|
};
|
||||||
|
var documentOrOwner = function (dos) {
|
||||||
|
return isDocument(dos) ? dos : owner(dos);
|
||||||
|
};
|
||||||
|
var parent = function (element) {
|
||||||
|
return Optional.from(element.dom.parentNode).map(SugarElement.fromDom);
|
||||||
|
};
|
||||||
|
var parents = function (element, isRoot) {
|
||||||
|
var stop = isFunction(isRoot) ? isRoot : never;
|
||||||
|
var dom = element.dom;
|
||||||
|
var ret = [];
|
||||||
|
while (dom.parentNode !== null && dom.parentNode !== undefined) {
|
||||||
|
var rawParent = dom.parentNode;
|
||||||
|
var p = SugarElement.fromDom(rawParent);
|
||||||
|
ret.push(p);
|
||||||
|
if (stop(p) === true) {
|
||||||
|
break;
|
||||||
|
} else {
|
||||||
|
dom = rawParent;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return ret;
|
||||||
|
};
|
||||||
|
var siblings$2 = function (element) {
|
||||||
|
var filterSelf = function (elements) {
|
||||||
|
return filter$1(elements, function (x) {
|
||||||
|
return !eq(element, x);
|
||||||
|
});
|
||||||
|
};
|
||||||
|
return parent(element).map(children).map(filterSelf).getOr([]);
|
||||||
|
};
|
||||||
|
var children = function (element) {
|
||||||
|
return map(element.dom.childNodes, SugarElement.fromDom);
|
||||||
|
};
|
||||||
|
|
||||||
|
var isShadowRoot = function (dos) {
|
||||||
|
return isDocumentFragment(dos) && isNonNullable(dos.dom.host);
|
||||||
|
};
|
||||||
|
var supported = isFunction(Element.prototype.attachShadow) && isFunction(Node.prototype.getRootNode);
|
||||||
|
var isSupported = constant(supported);
|
||||||
|
var getRootNode = supported ? function (e) {
|
||||||
|
return SugarElement.fromDom(e.dom.getRootNode());
|
||||||
|
} : documentOrOwner;
|
||||||
|
var getShadowRoot = function (e) {
|
||||||
|
var r = getRootNode(e);
|
||||||
|
return isShadowRoot(r) ? Optional.some(r) : Optional.none();
|
||||||
|
};
|
||||||
|
var getShadowHost = function (e) {
|
||||||
|
return SugarElement.fromDom(e.dom.host);
|
||||||
|
};
|
||||||
|
var getOriginalEventTarget = function (event) {
|
||||||
|
if (isSupported() && isNonNullable(event.target)) {
|
||||||
|
var el = SugarElement.fromDom(event.target);
|
||||||
|
if (isElement(el) && isOpenShadowHost(el)) {
|
||||||
|
if (event.composed && event.composedPath) {
|
||||||
|
var composedPath = event.composedPath();
|
||||||
|
if (composedPath) {
|
||||||
|
return head(composedPath);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return Optional.from(event.target);
|
||||||
|
};
|
||||||
|
var isOpenShadowHost = function (element) {
|
||||||
|
return isNonNullable(element.dom.shadowRoot);
|
||||||
|
};
|
||||||
|
|
||||||
|
var inBody = function (element) {
|
||||||
|
var dom = isText(element) ? element.dom.parentNode : element.dom;
|
||||||
|
if (dom === undefined || dom === null || dom.ownerDocument === null) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
var doc = dom.ownerDocument;
|
||||||
|
return getShadowRoot(SugarElement.fromDom(dom)).fold(function () {
|
||||||
|
return doc.body.contains(dom);
|
||||||
|
}, compose1(inBody, getShadowHost));
|
||||||
|
};
|
||||||
|
var getBody = function (doc) {
|
||||||
|
var b = doc.dom.body;
|
||||||
|
if (b === null || b === undefined) {
|
||||||
|
throw new Error('Body is not available yet');
|
||||||
|
}
|
||||||
|
return SugarElement.fromDom(b);
|
||||||
|
};
|
||||||
|
|
||||||
|
var rawSet = function (dom, key, value) {
|
||||||
|
if (isString(value) || isBoolean(value) || isNumber(value)) {
|
||||||
|
dom.setAttribute(key, value + '');
|
||||||
|
} else {
|
||||||
|
console.error('Invalid call to Attribute.set. Key ', key, ':: Value ', value, ':: Element ', dom);
|
||||||
|
throw new Error('Attribute value was not simple');
|
||||||
|
}
|
||||||
|
};
|
||||||
|
var set = function (element, key, value) {
|
||||||
|
rawSet(element.dom, key, value);
|
||||||
|
};
|
||||||
|
var get$3 = function (element, key) {
|
||||||
|
var v = element.dom.getAttribute(key);
|
||||||
|
return v === null ? undefined : v;
|
||||||
|
};
|
||||||
|
var remove = function (element, key) {
|
||||||
|
element.dom.removeAttribute(key);
|
||||||
|
};
|
||||||
|
|
||||||
|
var internalSet = function (dom, property, value) {
|
||||||
|
if (!isString(value)) {
|
||||||
|
console.error('Invalid call to CSS.set. Property ', property, ':: Value ', value, ':: Element ', dom);
|
||||||
|
throw new Error('CSS value must be a string: ' + value);
|
||||||
|
}
|
||||||
|
if (isSupported$1(dom)) {
|
||||||
|
dom.style.setProperty(property, value);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
var setAll = function (element, css) {
|
||||||
|
var dom = element.dom;
|
||||||
|
each(css, function (v, k) {
|
||||||
|
internalSet(dom, k, v);
|
||||||
|
});
|
||||||
|
};
|
||||||
|
var get$2 = function (element, property) {
|
||||||
|
var dom = element.dom;
|
||||||
|
var styles = window.getComputedStyle(dom);
|
||||||
|
var r = styles.getPropertyValue(property);
|
||||||
|
return r === '' && !inBody(element) ? getUnsafeProperty(dom, property) : r;
|
||||||
|
};
|
||||||
|
var getUnsafeProperty = function (dom, property) {
|
||||||
|
return isSupported$1(dom) ? dom.style.getPropertyValue(property) : '';
|
||||||
|
};
|
||||||
|
|
||||||
|
var mkEvent = function (target, x, y, stop, prevent, kill, raw) {
|
||||||
|
return {
|
||||||
|
target: target,
|
||||||
|
x: x,
|
||||||
|
y: y,
|
||||||
|
stop: stop,
|
||||||
|
prevent: prevent,
|
||||||
|
kill: kill,
|
||||||
|
raw: raw
|
||||||
|
};
|
||||||
|
};
|
||||||
|
var fromRawEvent = function (rawEvent) {
|
||||||
|
var target = SugarElement.fromDom(getOriginalEventTarget(rawEvent).getOr(rawEvent.target));
|
||||||
|
var stop = function () {
|
||||||
|
return rawEvent.stopPropagation();
|
||||||
|
};
|
||||||
|
var prevent = function () {
|
||||||
|
return rawEvent.preventDefault();
|
||||||
|
};
|
||||||
|
var kill = compose(prevent, stop);
|
||||||
|
return mkEvent(target, rawEvent.clientX, rawEvent.clientY, stop, prevent, kill, rawEvent);
|
||||||
|
};
|
||||||
|
var handle = function (filter, handler) {
|
||||||
|
return function (rawEvent) {
|
||||||
|
if (filter(rawEvent)) {
|
||||||
|
handler(fromRawEvent(rawEvent));
|
||||||
|
}
|
||||||
|
};
|
||||||
|
};
|
||||||
|
var binder = function (element, event, filter, handler, useCapture) {
|
||||||
|
var wrapped = handle(filter, handler);
|
||||||
|
element.dom.addEventListener(event, wrapped, useCapture);
|
||||||
|
return { unbind: curry(unbind, element, event, wrapped, useCapture) };
|
||||||
|
};
|
||||||
|
var bind$2 = function (element, event, filter, handler) {
|
||||||
|
return binder(element, event, filter, handler, false);
|
||||||
|
};
|
||||||
|
var unbind = function (element, event, handler, useCapture) {
|
||||||
|
element.dom.removeEventListener(event, handler, useCapture);
|
||||||
|
};
|
||||||
|
|
||||||
|
var filter = always;
|
||||||
|
var bind$1 = function (element, event, handler) {
|
||||||
|
return bind$2(element, event, filter, handler);
|
||||||
|
};
|
||||||
|
|
||||||
|
var r = function (left, top) {
|
||||||
|
var translate = function (x, y) {
|
||||||
|
return r(left + x, top + y);
|
||||||
|
};
|
||||||
|
return {
|
||||||
|
left: left,
|
||||||
|
top: top,
|
||||||
|
translate: translate
|
||||||
|
};
|
||||||
|
};
|
||||||
|
var SugarPosition = r;
|
||||||
|
|
||||||
|
var get$1 = function (_DOC) {
|
||||||
|
var doc = _DOC !== undefined ? _DOC.dom : document;
|
||||||
|
var x = doc.body.scrollLeft || doc.documentElement.scrollLeft;
|
||||||
|
var y = doc.body.scrollTop || doc.documentElement.scrollTop;
|
||||||
|
return SugarPosition(x, y);
|
||||||
|
};
|
||||||
|
|
||||||
|
var get = function (_win) {
|
||||||
|
var win = _win === undefined ? window : _win;
|
||||||
|
return Optional.from(win['visualViewport']);
|
||||||
|
};
|
||||||
|
var bounds = function (x, y, width, height) {
|
||||||
|
return {
|
||||||
|
x: x,
|
||||||
|
y: y,
|
||||||
|
width: width,
|
||||||
|
height: height,
|
||||||
|
right: x + width,
|
||||||
|
bottom: y + height
|
||||||
|
};
|
||||||
|
};
|
||||||
|
var getBounds = function (_win) {
|
||||||
|
var win = _win === undefined ? window : _win;
|
||||||
|
var doc = win.document;
|
||||||
|
var scroll = get$1(SugarElement.fromDom(doc));
|
||||||
|
return get(win).fold(function () {
|
||||||
|
var html = win.document.documentElement;
|
||||||
|
var width = html.clientWidth;
|
||||||
|
var height = html.clientHeight;
|
||||||
|
return bounds(scroll.left, scroll.top, width, height);
|
||||||
|
}, function (visualViewport) {
|
||||||
|
return bounds(Math.max(visualViewport.pageLeft, scroll.left), Math.max(visualViewport.pageTop, scroll.top), visualViewport.width, visualViewport.height);
|
||||||
|
});
|
||||||
|
};
|
||||||
|
var bind = function (name, callback, _win) {
|
||||||
|
return get(_win).map(function (visualViewport) {
|
||||||
|
var handler = function (e) {
|
||||||
|
return callback(fromRawEvent(e));
|
||||||
|
};
|
||||||
|
visualViewport.addEventListener(name, handler);
|
||||||
|
return {
|
||||||
|
unbind: function () {
|
||||||
|
return visualViewport.removeEventListener(name, handler);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}).getOrThunk(function () {
|
||||||
|
return { unbind: noop };
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
var global$2 = tinymce.util.Tools.resolve('tinymce.dom.DOMUtils');
|
||||||
|
|
||||||
|
var global$1 = tinymce.util.Tools.resolve('tinymce.Env');
|
||||||
|
|
||||||
|
var global = tinymce.util.Tools.resolve('tinymce.util.Delay');
|
||||||
|
|
||||||
|
var fireFullscreenStateChanged = function (editor, state) {
|
||||||
|
editor.fire('FullscreenStateChanged', { state: state });
|
||||||
|
};
|
||||||
|
|
||||||
|
var getFullscreenNative = function (editor) {
|
||||||
|
return editor.getParam('fullscreen_native', false, 'boolean');
|
||||||
|
};
|
||||||
|
|
||||||
|
var getFullscreenRoot = function (editor) {
|
||||||
|
var elem = SugarElement.fromDom(editor.getElement());
|
||||||
|
return getShadowRoot(elem).map(getShadowHost).getOrThunk(function () {
|
||||||
|
return getBody(owner(elem));
|
||||||
|
});
|
||||||
|
};
|
||||||
|
var getFullscreenElement = function (root) {
|
||||||
|
if (root.fullscreenElement !== undefined) {
|
||||||
|
return root.fullscreenElement;
|
||||||
|
} else if (root.msFullscreenElement !== undefined) {
|
||||||
|
return root.msFullscreenElement;
|
||||||
|
} else if (root.webkitFullscreenElement !== undefined) {
|
||||||
|
return root.webkitFullscreenElement;
|
||||||
|
} else {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
var getFullscreenchangeEventName = function () {
|
||||||
|
if (document.fullscreenElement !== undefined) {
|
||||||
|
return 'fullscreenchange';
|
||||||
|
} else if (document.msFullscreenElement !== undefined) {
|
||||||
|
return 'MSFullscreenChange';
|
||||||
|
} else if (document.webkitFullscreenElement !== undefined) {
|
||||||
|
return 'webkitfullscreenchange';
|
||||||
|
} else {
|
||||||
|
return 'fullscreenchange';
|
||||||
|
}
|
||||||
|
};
|
||||||
|
var requestFullscreen = function (sugarElem) {
|
||||||
|
var elem = sugarElem.dom;
|
||||||
|
if (elem.requestFullscreen) {
|
||||||
|
elem.requestFullscreen();
|
||||||
|
} else if (elem.msRequestFullscreen) {
|
||||||
|
elem.msRequestFullscreen();
|
||||||
|
} else if (elem.webkitRequestFullScreen) {
|
||||||
|
elem.webkitRequestFullScreen();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
var exitFullscreen = function (sugarDoc) {
|
||||||
|
var doc = sugarDoc.dom;
|
||||||
|
if (doc.exitFullscreen) {
|
||||||
|
doc.exitFullscreen();
|
||||||
|
} else if (doc.msExitFullscreen) {
|
||||||
|
doc.msExitFullscreen();
|
||||||
|
} else if (doc.webkitCancelFullScreen) {
|
||||||
|
doc.webkitCancelFullScreen();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
var isFullscreenElement = function (elem) {
|
||||||
|
return elem.dom === getFullscreenElement(owner(elem).dom);
|
||||||
|
};
|
||||||
|
|
||||||
|
var ancestors$1 = function (scope, predicate, isRoot) {
|
||||||
|
return filter$1(parents(scope, isRoot), predicate);
|
||||||
|
};
|
||||||
|
var siblings$1 = function (scope, predicate) {
|
||||||
|
return filter$1(siblings$2(scope), predicate);
|
||||||
|
};
|
||||||
|
|
||||||
|
var all = function (selector) {
|
||||||
|
return all$1(selector);
|
||||||
|
};
|
||||||
|
var ancestors = function (scope, selector, isRoot) {
|
||||||
|
return ancestors$1(scope, function (e) {
|
||||||
|
return is(e, selector);
|
||||||
|
}, isRoot);
|
||||||
|
};
|
||||||
|
var siblings = function (scope, selector) {
|
||||||
|
return siblings$1(scope, function (e) {
|
||||||
|
return is(e, selector);
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
var attr = 'data-ephox-mobile-fullscreen-style';
|
||||||
|
var siblingStyles = 'display:none!important;';
|
||||||
|
var ancestorPosition = 'position:absolute!important;';
|
||||||
|
var ancestorStyles = 'top:0!important;left:0!important;margin:0!important;padding:0!important;width:100%!important;height:100%!important;overflow:visible!important;';
|
||||||
|
var bgFallback = 'background-color:rgb(255,255,255)!important;';
|
||||||
|
var isAndroid = global$1.os.isAndroid();
|
||||||
|
var matchColor = function (editorBody) {
|
||||||
|
var color = get$2(editorBody, 'background-color');
|
||||||
|
return color !== undefined && color !== '' ? 'background-color:' + color + '!important' : bgFallback;
|
||||||
|
};
|
||||||
|
var clobberStyles = function (dom, container, editorBody) {
|
||||||
|
var gatherSiblings = function (element) {
|
||||||
|
return siblings(element, '*:not(.tox-silver-sink)');
|
||||||
|
};
|
||||||
|
var clobber = function (clobberStyle) {
|
||||||
|
return function (element) {
|
||||||
|
var styles = get$3(element, 'style');
|
||||||
|
var backup = styles === undefined ? 'no-styles' : styles.trim();
|
||||||
|
if (backup === clobberStyle) {
|
||||||
|
return;
|
||||||
|
} else {
|
||||||
|
set(element, attr, backup);
|
||||||
|
setAll(element, dom.parseStyle(clobberStyle));
|
||||||
|
}
|
||||||
|
};
|
||||||
|
};
|
||||||
|
var ancestors$1 = ancestors(container, '*');
|
||||||
|
var siblings$1 = bind$3(ancestors$1, gatherSiblings);
|
||||||
|
var bgColor = matchColor(editorBody);
|
||||||
|
each$1(siblings$1, clobber(siblingStyles));
|
||||||
|
each$1(ancestors$1, clobber(ancestorPosition + ancestorStyles + bgColor));
|
||||||
|
var containerStyles = isAndroid === true ? '' : ancestorPosition;
|
||||||
|
clobber(containerStyles + ancestorStyles + bgColor)(container);
|
||||||
|
};
|
||||||
|
var restoreStyles = function (dom) {
|
||||||
|
var clobberedEls = all('[' + attr + ']');
|
||||||
|
each$1(clobberedEls, function (element) {
|
||||||
|
var restore = get$3(element, attr);
|
||||||
|
if (restore !== 'no-styles') {
|
||||||
|
setAll(element, dom.parseStyle(restore));
|
||||||
|
} else {
|
||||||
|
remove(element, 'style');
|
||||||
|
}
|
||||||
|
remove(element, attr);
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
var DOM = global$2.DOM;
|
||||||
|
var getScrollPos = function () {
|
||||||
|
return getBounds(window);
|
||||||
|
};
|
||||||
|
var setScrollPos = function (pos) {
|
||||||
|
return window.scrollTo(pos.x, pos.y);
|
||||||
|
};
|
||||||
|
var viewportUpdate = get().fold(function () {
|
||||||
|
return {
|
||||||
|
bind: noop,
|
||||||
|
unbind: noop
|
||||||
|
};
|
||||||
|
}, function (visualViewport) {
|
||||||
|
var editorContainer = value();
|
||||||
|
var resizeBinder = unbindable();
|
||||||
|
var scrollBinder = unbindable();
|
||||||
|
var refreshScroll = function () {
|
||||||
|
document.body.scrollTop = 0;
|
||||||
|
document.documentElement.scrollTop = 0;
|
||||||
|
};
|
||||||
|
var refreshVisualViewport = function () {
|
||||||
|
window.requestAnimationFrame(function () {
|
||||||
|
editorContainer.on(function (container) {
|
||||||
|
return setAll(container, {
|
||||||
|
top: visualViewport.offsetTop + 'px',
|
||||||
|
left: visualViewport.offsetLeft + 'px',
|
||||||
|
height: visualViewport.height + 'px',
|
||||||
|
width: visualViewport.width + 'px'
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
};
|
||||||
|
var update = global.throttle(function () {
|
||||||
|
refreshScroll();
|
||||||
|
refreshVisualViewport();
|
||||||
|
}, 50);
|
||||||
|
var bind$1 = function (element) {
|
||||||
|
editorContainer.set(element);
|
||||||
|
update();
|
||||||
|
resizeBinder.set(bind('resize', update));
|
||||||
|
scrollBinder.set(bind('scroll', update));
|
||||||
|
};
|
||||||
|
var unbind = function () {
|
||||||
|
editorContainer.on(function () {
|
||||||
|
resizeBinder.clear();
|
||||||
|
scrollBinder.clear();
|
||||||
|
});
|
||||||
|
editorContainer.clear();
|
||||||
|
};
|
||||||
|
return {
|
||||||
|
bind: bind$1,
|
||||||
|
unbind: unbind
|
||||||
|
};
|
||||||
|
});
|
||||||
|
var toggleFullscreen = function (editor, fullscreenState) {
|
||||||
|
var body = document.body;
|
||||||
|
var documentElement = document.documentElement;
|
||||||
|
var editorContainer = editor.getContainer();
|
||||||
|
var editorContainerS = SugarElement.fromDom(editorContainer);
|
||||||
|
var fullscreenRoot = getFullscreenRoot(editor);
|
||||||
|
var fullscreenInfo = fullscreenState.get();
|
||||||
|
var editorBody = SugarElement.fromDom(editor.getBody());
|
||||||
|
var isTouch = global$1.deviceType.isTouch();
|
||||||
|
var editorContainerStyle = editorContainer.style;
|
||||||
|
var iframe = editor.iframeElement;
|
||||||
|
var iframeStyle = iframe.style;
|
||||||
|
var handleClasses = function (handler) {
|
||||||
|
handler(body, 'tox-fullscreen');
|
||||||
|
handler(documentElement, 'tox-fullscreen');
|
||||||
|
handler(editorContainer, 'tox-fullscreen');
|
||||||
|
getShadowRoot(editorContainerS).map(function (root) {
|
||||||
|
return getShadowHost(root).dom;
|
||||||
|
}).each(function (host) {
|
||||||
|
handler(host, 'tox-fullscreen');
|
||||||
|
handler(host, 'tox-shadowhost');
|
||||||
|
});
|
||||||
|
};
|
||||||
|
var cleanup = function () {
|
||||||
|
if (isTouch) {
|
||||||
|
restoreStyles(editor.dom);
|
||||||
|
}
|
||||||
|
handleClasses(DOM.removeClass);
|
||||||
|
viewportUpdate.unbind();
|
||||||
|
Optional.from(fullscreenState.get()).each(function (info) {
|
||||||
|
return info.fullscreenChangeHandler.unbind();
|
||||||
|
});
|
||||||
|
};
|
||||||
|
if (!fullscreenInfo) {
|
||||||
|
var fullscreenChangeHandler = bind$1(owner(fullscreenRoot), getFullscreenchangeEventName(), function (_evt) {
|
||||||
|
if (getFullscreenNative(editor)) {
|
||||||
|
if (!isFullscreenElement(fullscreenRoot) && fullscreenState.get() !== null) {
|
||||||
|
toggleFullscreen(editor, fullscreenState);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
var newFullScreenInfo = {
|
||||||
|
scrollPos: getScrollPos(),
|
||||||
|
containerWidth: editorContainerStyle.width,
|
||||||
|
containerHeight: editorContainerStyle.height,
|
||||||
|
containerTop: editorContainerStyle.top,
|
||||||
|
containerLeft: editorContainerStyle.left,
|
||||||
|
iframeWidth: iframeStyle.width,
|
||||||
|
iframeHeight: iframeStyle.height,
|
||||||
|
fullscreenChangeHandler: fullscreenChangeHandler
|
||||||
|
};
|
||||||
|
if (isTouch) {
|
||||||
|
clobberStyles(editor.dom, editorContainerS, editorBody);
|
||||||
|
}
|
||||||
|
iframeStyle.width = iframeStyle.height = '100%';
|
||||||
|
editorContainerStyle.width = editorContainerStyle.height = '';
|
||||||
|
handleClasses(DOM.addClass);
|
||||||
|
viewportUpdate.bind(editorContainerS);
|
||||||
|
editor.on('remove', cleanup);
|
||||||
|
fullscreenState.set(newFullScreenInfo);
|
||||||
|
if (getFullscreenNative(editor)) {
|
||||||
|
requestFullscreen(fullscreenRoot);
|
||||||
|
}
|
||||||
|
fireFullscreenStateChanged(editor, true);
|
||||||
|
} else {
|
||||||
|
fullscreenInfo.fullscreenChangeHandler.unbind();
|
||||||
|
if (getFullscreenNative(editor) && isFullscreenElement(fullscreenRoot)) {
|
||||||
|
exitFullscreen(owner(fullscreenRoot));
|
||||||
|
}
|
||||||
|
iframeStyle.width = fullscreenInfo.iframeWidth;
|
||||||
|
iframeStyle.height = fullscreenInfo.iframeHeight;
|
||||||
|
editorContainerStyle.width = fullscreenInfo.containerWidth;
|
||||||
|
editorContainerStyle.height = fullscreenInfo.containerHeight;
|
||||||
|
editorContainerStyle.top = fullscreenInfo.containerTop;
|
||||||
|
editorContainerStyle.left = fullscreenInfo.containerLeft;
|
||||||
|
setScrollPos(fullscreenInfo.scrollPos);
|
||||||
|
fullscreenState.set(null);
|
||||||
|
fireFullscreenStateChanged(editor, false);
|
||||||
|
cleanup();
|
||||||
|
editor.off('remove', cleanup);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
var register$1 = function (editor, fullscreenState) {
|
||||||
|
editor.addCommand('mceFullScreen', function () {
|
||||||
|
toggleFullscreen(editor, fullscreenState);
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
var makeSetupHandler = function (editor, fullscreenState) {
|
||||||
|
return function (api) {
|
||||||
|
api.setActive(fullscreenState.get() !== null);
|
||||||
|
var editorEventCallback = function (e) {
|
||||||
|
return api.setActive(e.state);
|
||||||
|
};
|
||||||
|
editor.on('FullscreenStateChanged', editorEventCallback);
|
||||||
|
return function () {
|
||||||
|
return editor.off('FullscreenStateChanged', editorEventCallback);
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
var register = function (editor, fullscreenState) {
|
||||||
|
var onAction = function () {
|
||||||
|
return editor.execCommand('mceFullScreen');
|
||||||
|
};
|
||||||
|
editor.ui.registry.addToggleMenuItem('fullscreen', {
|
||||||
|
text: 'Fullscreen',
|
||||||
|
icon: 'fullscreen',
|
||||||
|
shortcut: 'Meta+Shift+F',
|
||||||
|
onAction: onAction,
|
||||||
|
onSetup: makeSetupHandler(editor, fullscreenState)
|
||||||
|
});
|
||||||
|
editor.ui.registry.addToggleButton('fullscreen', {
|
||||||
|
tooltip: 'Fullscreen',
|
||||||
|
icon: 'fullscreen',
|
||||||
|
onAction: onAction,
|
||||||
|
onSetup: makeSetupHandler(editor, fullscreenState)
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
function Plugin () {
|
||||||
|
global$3.add('fullscreen', function (editor) {
|
||||||
|
var fullscreenState = Cell(null);
|
||||||
|
if (editor.inline) {
|
||||||
|
return get$5(fullscreenState);
|
||||||
|
}
|
||||||
|
register$1(editor, fullscreenState);
|
||||||
|
register(editor, fullscreenState);
|
||||||
|
editor.addShortcut('Meta+Shift+F', '', 'mceFullScreen');
|
||||||
|
return get$5(fullscreenState);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
Plugin();
|
||||||
|
|
||||||
|
}());
|
File diff suppressed because one or more lines are too long
|
@ -0,0 +1,7 @@
|
||||||
|
// Exports the "help" plugin for usage with module loaders
|
||||||
|
// Usage:
|
||||||
|
// CommonJS:
|
||||||
|
// require('tinymce/plugins/help')
|
||||||
|
// ES2015:
|
||||||
|
// import 'tinymce/plugins/help'
|
||||||
|
require('./plugin.js');
|
|
@ -0,0 +1,859 @@
|
||||||
|
/**
|
||||||
|
* Copyright (c) Tiny Technologies, Inc. All rights reserved.
|
||||||
|
* Licensed under the LGPL or a commercial license.
|
||||||
|
* For LGPL see License.txt in the project root for license information.
|
||||||
|
* For commercial licenses see https://www.tiny.cloud/
|
||||||
|
*
|
||||||
|
* Version: 5.9.2 (2021-09-08)
|
||||||
|
*/
|
||||||
|
(function () {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
var Cell = function (initial) {
|
||||||
|
var value = initial;
|
||||||
|
var get = function () {
|
||||||
|
return value;
|
||||||
|
};
|
||||||
|
var set = function (v) {
|
||||||
|
value = v;
|
||||||
|
};
|
||||||
|
return {
|
||||||
|
get: get,
|
||||||
|
set: set
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
var global$3 = tinymce.util.Tools.resolve('tinymce.PluginManager');
|
||||||
|
|
||||||
|
var get$1 = function (customTabs) {
|
||||||
|
var addTab = function (spec) {
|
||||||
|
var currentCustomTabs = customTabs.get();
|
||||||
|
currentCustomTabs[spec.name] = spec;
|
||||||
|
customTabs.set(currentCustomTabs);
|
||||||
|
};
|
||||||
|
return { addTab: addTab };
|
||||||
|
};
|
||||||
|
|
||||||
|
var register$1 = function (editor, dialogOpener) {
|
||||||
|
editor.addCommand('mceHelp', dialogOpener);
|
||||||
|
};
|
||||||
|
|
||||||
|
var register = function (editor, dialogOpener) {
|
||||||
|
editor.ui.registry.addButton('help', {
|
||||||
|
icon: 'help',
|
||||||
|
tooltip: 'Help',
|
||||||
|
onAction: dialogOpener
|
||||||
|
});
|
||||||
|
editor.ui.registry.addMenuItem('help', {
|
||||||
|
text: 'Help',
|
||||||
|
icon: 'help',
|
||||||
|
shortcut: 'Alt+0',
|
||||||
|
onAction: dialogOpener
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
var __assign = function () {
|
||||||
|
__assign = Object.assign || function __assign(t) {
|
||||||
|
for (var s, i = 1, n = arguments.length; i < n; i++) {
|
||||||
|
s = arguments[i];
|
||||||
|
for (var p in s)
|
||||||
|
if (Object.prototype.hasOwnProperty.call(s, p))
|
||||||
|
t[p] = s[p];
|
||||||
|
}
|
||||||
|
return t;
|
||||||
|
};
|
||||||
|
return __assign.apply(this, arguments);
|
||||||
|
};
|
||||||
|
|
||||||
|
var noop = function () {
|
||||||
|
};
|
||||||
|
var constant = function (value) {
|
||||||
|
return function () {
|
||||||
|
return value;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
var identity = function (x) {
|
||||||
|
return x;
|
||||||
|
};
|
||||||
|
var never = constant(false);
|
||||||
|
var always = constant(true);
|
||||||
|
|
||||||
|
var none = function () {
|
||||||
|
return NONE;
|
||||||
|
};
|
||||||
|
var NONE = function () {
|
||||||
|
var call = function (thunk) {
|
||||||
|
return thunk();
|
||||||
|
};
|
||||||
|
var id = identity;
|
||||||
|
var me = {
|
||||||
|
fold: function (n, _s) {
|
||||||
|
return n();
|
||||||
|
},
|
||||||
|
isSome: never,
|
||||||
|
isNone: always,
|
||||||
|
getOr: id,
|
||||||
|
getOrThunk: call,
|
||||||
|
getOrDie: function (msg) {
|
||||||
|
throw new Error(msg || 'error: getOrDie called on none.');
|
||||||
|
},
|
||||||
|
getOrNull: constant(null),
|
||||||
|
getOrUndefined: constant(undefined),
|
||||||
|
or: id,
|
||||||
|
orThunk: call,
|
||||||
|
map: none,
|
||||||
|
each: noop,
|
||||||
|
bind: none,
|
||||||
|
exists: never,
|
||||||
|
forall: always,
|
||||||
|
filter: function () {
|
||||||
|
return none();
|
||||||
|
},
|
||||||
|
toArray: function () {
|
||||||
|
return [];
|
||||||
|
},
|
||||||
|
toString: constant('none()')
|
||||||
|
};
|
||||||
|
return me;
|
||||||
|
}();
|
||||||
|
var some = function (a) {
|
||||||
|
var constant_a = constant(a);
|
||||||
|
var self = function () {
|
||||||
|
return me;
|
||||||
|
};
|
||||||
|
var bind = function (f) {
|
||||||
|
return f(a);
|
||||||
|
};
|
||||||
|
var me = {
|
||||||
|
fold: function (n, s) {
|
||||||
|
return s(a);
|
||||||
|
},
|
||||||
|
isSome: always,
|
||||||
|
isNone: never,
|
||||||
|
getOr: constant_a,
|
||||||
|
getOrThunk: constant_a,
|
||||||
|
getOrDie: constant_a,
|
||||||
|
getOrNull: constant_a,
|
||||||
|
getOrUndefined: constant_a,
|
||||||
|
or: self,
|
||||||
|
orThunk: self,
|
||||||
|
map: function (f) {
|
||||||
|
return some(f(a));
|
||||||
|
},
|
||||||
|
each: function (f) {
|
||||||
|
f(a);
|
||||||
|
},
|
||||||
|
bind: bind,
|
||||||
|
exists: bind,
|
||||||
|
forall: bind,
|
||||||
|
filter: function (f) {
|
||||||
|
return f(a) ? me : NONE;
|
||||||
|
},
|
||||||
|
toArray: function () {
|
||||||
|
return [a];
|
||||||
|
},
|
||||||
|
toString: function () {
|
||||||
|
return 'some(' + a + ')';
|
||||||
|
}
|
||||||
|
};
|
||||||
|
return me;
|
||||||
|
};
|
||||||
|
var from = function (value) {
|
||||||
|
return value === null || value === undefined ? NONE : some(value);
|
||||||
|
};
|
||||||
|
var Optional = {
|
||||||
|
some: some,
|
||||||
|
none: none,
|
||||||
|
from: from
|
||||||
|
};
|
||||||
|
|
||||||
|
var nativeIndexOf = Array.prototype.indexOf;
|
||||||
|
var rawIndexOf = function (ts, t) {
|
||||||
|
return nativeIndexOf.call(ts, t);
|
||||||
|
};
|
||||||
|
var contains = function (xs, x) {
|
||||||
|
return rawIndexOf(xs, x) > -1;
|
||||||
|
};
|
||||||
|
var map = function (xs, f) {
|
||||||
|
var len = xs.length;
|
||||||
|
var r = new Array(len);
|
||||||
|
for (var i = 0; i < len; i++) {
|
||||||
|
var x = xs[i];
|
||||||
|
r[i] = f(x, i);
|
||||||
|
}
|
||||||
|
return r;
|
||||||
|
};
|
||||||
|
var filter = function (xs, pred) {
|
||||||
|
var r = [];
|
||||||
|
for (var i = 0, len = xs.length; i < len; i++) {
|
||||||
|
var x = xs[i];
|
||||||
|
if (pred(x, i)) {
|
||||||
|
r.push(x);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return r;
|
||||||
|
};
|
||||||
|
var findUntil = function (xs, pred, until) {
|
||||||
|
for (var i = 0, len = xs.length; i < len; i++) {
|
||||||
|
var x = xs[i];
|
||||||
|
if (pred(x, i)) {
|
||||||
|
return Optional.some(x);
|
||||||
|
} else if (until(x, i)) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return Optional.none();
|
||||||
|
};
|
||||||
|
var find = function (xs, pred) {
|
||||||
|
return findUntil(xs, pred, never);
|
||||||
|
};
|
||||||
|
|
||||||
|
var keys = Object.keys;
|
||||||
|
var hasOwnProperty = Object.hasOwnProperty;
|
||||||
|
var get = function (obj, key) {
|
||||||
|
return has(obj, key) ? Optional.from(obj[key]) : Optional.none();
|
||||||
|
};
|
||||||
|
var has = function (obj, key) {
|
||||||
|
return hasOwnProperty.call(obj, key);
|
||||||
|
};
|
||||||
|
|
||||||
|
var cat = function (arr) {
|
||||||
|
var r = [];
|
||||||
|
var push = function (x) {
|
||||||
|
r.push(x);
|
||||||
|
};
|
||||||
|
for (var i = 0; i < arr.length; i++) {
|
||||||
|
arr[i].each(push);
|
||||||
|
}
|
||||||
|
return r;
|
||||||
|
};
|
||||||
|
|
||||||
|
var getHelpTabs = function (editor) {
|
||||||
|
return Optional.from(editor.getParam('help_tabs'));
|
||||||
|
};
|
||||||
|
var getForcedPlugins = function (editor) {
|
||||||
|
return editor.getParam('forced_plugins');
|
||||||
|
};
|
||||||
|
|
||||||
|
var description = '<h1>Editor UI keyboard navigation</h1>\n\n<h2>Activating keyboard navigation</h2>\n\n<p>The sections of the outer UI of the editor - the menubar, toolbar, sidebar and footer - are all keyboard navigable. As such, there are multiple ways to activate keyboard navigation:</p>\n<ul>\n <li>Focus the menubar: Alt + F9 (Windows) or ⌥F9 (MacOS)</li>\n <li>Focus the toolbar: Alt + F10 (Windows) or ⌥F10 (MacOS)</li>\n <li>Focus the footer: Alt + F11 (Windows) or ⌥F11 (MacOS)</li>\n</ul>\n\n<p>Focusing the menubar or toolbar will start keyboard navigation at the first item in the menubar or toolbar, which will be highlighted with a gray background. Focusing the footer will start keyboard navigation at the first item in the element path, which will be highlighted with an underline. </p>\n\n<h2>Moving between UI sections</h2>\n\n<p>When keyboard navigation is active, pressing tab will move the focus to the next major section of the UI, where applicable. These sections are:</p>\n<ul>\n <li>the menubar</li>\n <li>each group of the toolbar </li>\n <li>the sidebar</li>\n <li>the element path in the footer </li>\n <li>the wordcount toggle button in the footer </li>\n <li>the branding link in the footer </li>\n <li>the editor resize handle in the footer</li>\n</ul>\n\n<p>Pressing shift + tab will move backwards through the same sections, except when moving from the footer to the toolbar. Focusing the element path then pressing shift + tab will move focus to the first toolbar group, not the last.</p>\n\n<h2>Moving within UI sections</h2>\n\n<p>Keyboard navigation within UI sections can usually be achieved using the left and right arrow keys. This includes:</p>\n<ul>\n <li>moving between menus in the menubar</li>\n <li>moving between buttons in a toolbar group</li>\n <li>moving between items in the element path</li>\n</ul>\n\n<p>In all these UI sections, keyboard navigation will cycle within the section. For example, focusing the last button in a toolbar group then pressing right arrow will move focus to the first item in the same toolbar group. </p>\n\n<h1>Executing buttons</h1>\n\n<p>To execute a button, navigate the selection to the desired button and hit space or enter.</p>\n\n<h1>Opening, navigating and closing menus</h1>\n\n<p>When focusing a menubar button or a toolbar button with a menu, pressing space, enter or down arrow will open the menu. When the menu opens the first item will be selected. To move up or down the menu, press the up or down arrow key respectively. This is the same for submenus, which can also be opened and closed using the left and right arrow keys.</p>\n\n<p>To close any active menu, hit the escape key. When a menu is closed the selection will be restored to its previous selection. This also works for closing submenus.</p>\n\n<h1>Context toolbars and menus</h1>\n\n<p>To focus an open context toolbar such as the table context toolbar, press Ctrl + F9 (Windows) or ⌃F9 (MacOS).</p>\n\n<p>Context toolbar navigation is the same as toolbar navigation, and context menu navigation is the same as standard menu navigation.</p>\n\n<h1>Dialog navigation</h1>\n\n<p>There are two types of dialog UIs in TinyMCE: tabbed dialogs and non-tabbed dialogs.</p>\n\n<p>When a non-tabbed dialog is opened, the first interactive component in the dialog will be focused. Users can navigate between interactive components by pressing tab. This includes any footer buttons. Navigation will cycle back to the first dialog component if tab is pressed while focusing the last component in the dialog. Pressing shift + tab will navigate backwards.</p>\n\n<p>When a tabbed dialog is opened, the first button in the tab menu is focused. Pressing tab will navigate to the first interactive component in that tab, and will cycle through the tab\u2019s components, the footer buttons, then back to the tab button. To switch to another tab, focus the tab button for the current tab, then use the arrow keys to cycle through the tab buttons.</p>';
|
||||||
|
var tab$3 = function () {
|
||||||
|
var body = {
|
||||||
|
type: 'htmlpanel',
|
||||||
|
presets: 'document',
|
||||||
|
html: description
|
||||||
|
};
|
||||||
|
return {
|
||||||
|
name: 'keyboardnav',
|
||||||
|
title: 'Keyboard Navigation',
|
||||||
|
items: [body]
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
var global$2 = tinymce.util.Tools.resolve('tinymce.Env');
|
||||||
|
|
||||||
|
var convertText = function (source) {
|
||||||
|
var mac = {
|
||||||
|
alt: '⌥',
|
||||||
|
ctrl: '⌃',
|
||||||
|
shift: '⇧',
|
||||||
|
meta: '⌘',
|
||||||
|
access: '⌃⌥'
|
||||||
|
};
|
||||||
|
var other = {
|
||||||
|
meta: 'Ctrl ',
|
||||||
|
access: 'Shift + Alt '
|
||||||
|
};
|
||||||
|
var replace = global$2.mac ? mac : other;
|
||||||
|
var shortcut = source.split('+');
|
||||||
|
var updated = map(shortcut, function (segment) {
|
||||||
|
var search = segment.toLowerCase().trim();
|
||||||
|
return has(replace, search) ? replace[search] : segment;
|
||||||
|
});
|
||||||
|
return global$2.mac ? updated.join('').replace(/\s/, '') : updated.join('+');
|
||||||
|
};
|
||||||
|
|
||||||
|
var shortcuts = [
|
||||||
|
{
|
||||||
|
shortcuts: ['Meta + B'],
|
||||||
|
action: 'Bold'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
shortcuts: ['Meta + I'],
|
||||||
|
action: 'Italic'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
shortcuts: ['Meta + U'],
|
||||||
|
action: 'Underline'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
shortcuts: ['Meta + A'],
|
||||||
|
action: 'Select all'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
shortcuts: [
|
||||||
|
'Meta + Y',
|
||||||
|
'Meta + Shift + Z'
|
||||||
|
],
|
||||||
|
action: 'Redo'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
shortcuts: ['Meta + Z'],
|
||||||
|
action: 'Undo'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
shortcuts: ['Access + 1'],
|
||||||
|
action: 'Heading 1'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
shortcuts: ['Access + 2'],
|
||||||
|
action: 'Heading 2'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
shortcuts: ['Access + 3'],
|
||||||
|
action: 'Heading 3'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
shortcuts: ['Access + 4'],
|
||||||
|
action: 'Heading 4'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
shortcuts: ['Access + 5'],
|
||||||
|
action: 'Heading 5'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
shortcuts: ['Access + 6'],
|
||||||
|
action: 'Heading 6'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
shortcuts: ['Access + 7'],
|
||||||
|
action: 'Paragraph'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
shortcuts: ['Access + 8'],
|
||||||
|
action: 'Div'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
shortcuts: ['Access + 9'],
|
||||||
|
action: 'Address'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
shortcuts: ['Alt + 0'],
|
||||||
|
action: 'Open help dialog'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
shortcuts: ['Alt + F9'],
|
||||||
|
action: 'Focus to menubar'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
shortcuts: ['Alt + F10'],
|
||||||
|
action: 'Focus to toolbar'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
shortcuts: ['Alt + F11'],
|
||||||
|
action: 'Focus to element path'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
shortcuts: ['Ctrl + F9'],
|
||||||
|
action: 'Focus to contextual toolbar'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
shortcuts: ['Shift + Enter'],
|
||||||
|
action: 'Open popup menu for split buttons'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
shortcuts: ['Meta + K'],
|
||||||
|
action: 'Insert link (if link plugin activated)'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
shortcuts: ['Meta + S'],
|
||||||
|
action: 'Save (if save plugin activated)'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
shortcuts: ['Meta + F'],
|
||||||
|
action: 'Find (if searchreplace plugin activated)'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
shortcuts: ['Meta + Shift + F'],
|
||||||
|
action: 'Switch to or from fullscreen mode'
|
||||||
|
}
|
||||||
|
];
|
||||||
|
|
||||||
|
var tab$2 = function () {
|
||||||
|
var shortcutList = map(shortcuts, function (shortcut) {
|
||||||
|
var shortcutText = map(shortcut.shortcuts, convertText).join(' or ');
|
||||||
|
return [
|
||||||
|
shortcut.action,
|
||||||
|
shortcutText
|
||||||
|
];
|
||||||
|
});
|
||||||
|
var tablePanel = {
|
||||||
|
type: 'table',
|
||||||
|
header: [
|
||||||
|
'Action',
|
||||||
|
'Shortcut'
|
||||||
|
],
|
||||||
|
cells: shortcutList
|
||||||
|
};
|
||||||
|
return {
|
||||||
|
name: 'shortcuts',
|
||||||
|
title: 'Handy Shortcuts',
|
||||||
|
items: [tablePanel]
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
var global$1 = tinymce.util.Tools.resolve('tinymce.util.I18n');
|
||||||
|
|
||||||
|
var premiumType = 'premium';
|
||||||
|
var openSourceType = 'opensource';
|
||||||
|
var urls = map([
|
||||||
|
{
|
||||||
|
key: 'advlist',
|
||||||
|
name: 'Advanced List'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'anchor',
|
||||||
|
name: 'Anchor'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'autolink',
|
||||||
|
name: 'Autolink'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'autoresize',
|
||||||
|
name: 'Autoresize'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'autosave',
|
||||||
|
name: 'Autosave'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'bbcode',
|
||||||
|
name: 'BBCode'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'charmap',
|
||||||
|
name: 'Character Map'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'code',
|
||||||
|
name: 'Code'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'codesample',
|
||||||
|
name: 'Code Sample'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'colorpicker',
|
||||||
|
name: 'Color Picker'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'directionality',
|
||||||
|
name: 'Directionality'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'emoticons',
|
||||||
|
name: 'Emoticons'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'fullpage',
|
||||||
|
name: 'Full Page'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'fullscreen',
|
||||||
|
name: 'Full Screen'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'help',
|
||||||
|
name: 'Help'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'hr',
|
||||||
|
name: 'Horizontal Rule'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'image',
|
||||||
|
name: 'Image'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'imagetools',
|
||||||
|
name: 'Image Tools'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'importcss',
|
||||||
|
name: 'Import CSS'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'insertdatetime',
|
||||||
|
name: 'Insert Date/Time'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'legacyoutput',
|
||||||
|
name: 'Legacy Output'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'link',
|
||||||
|
name: 'Link'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'lists',
|
||||||
|
name: 'Lists'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'media',
|
||||||
|
name: 'Media'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'nonbreaking',
|
||||||
|
name: 'Nonbreaking'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'noneditable',
|
||||||
|
name: 'Noneditable'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'pagebreak',
|
||||||
|
name: 'Page Break'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'paste',
|
||||||
|
name: 'Paste'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'preview',
|
||||||
|
name: 'Preview'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'print',
|
||||||
|
name: 'Print'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'save',
|
||||||
|
name: 'Save'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'searchreplace',
|
||||||
|
name: 'Search and Replace'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'spellchecker',
|
||||||
|
name: 'Spell Checker'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'tabfocus',
|
||||||
|
name: 'Tab Focus'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'table',
|
||||||
|
name: 'Table'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'template',
|
||||||
|
name: 'Template'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'textcolor',
|
||||||
|
name: 'Text Color'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'textpattern',
|
||||||
|
name: 'Text Pattern'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'toc',
|
||||||
|
name: 'Table of Contents'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'visualblocks',
|
||||||
|
name: 'Visual Blocks'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'visualchars',
|
||||||
|
name: 'Visual Characters'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'wordcount',
|
||||||
|
name: 'Word Count'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'advcode',
|
||||||
|
name: 'Advanced Code Editor*',
|
||||||
|
type: premiumType
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'formatpainter',
|
||||||
|
name: 'Format Painter*',
|
||||||
|
type: premiumType
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'powerpaste',
|
||||||
|
name: 'PowerPaste*',
|
||||||
|
type: premiumType
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'tinydrive',
|
||||||
|
name: 'Tiny Drive*',
|
||||||
|
type: premiumType
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'tinymcespellchecker',
|
||||||
|
name: 'Spell Checker Pro*',
|
||||||
|
type: premiumType
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'a11ychecker',
|
||||||
|
name: 'Accessibility Checker*',
|
||||||
|
type: premiumType
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'linkchecker',
|
||||||
|
name: 'Link Checker*',
|
||||||
|
type: premiumType
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'mentions',
|
||||||
|
name: 'Mentions*',
|
||||||
|
type: premiumType
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'mediaembed',
|
||||||
|
name: 'Enhanced Media Embed*',
|
||||||
|
type: premiumType
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'checklist',
|
||||||
|
name: 'Checklist*',
|
||||||
|
type: premiumType
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'casechange',
|
||||||
|
name: 'Case Change*',
|
||||||
|
type: premiumType
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'permanentpen',
|
||||||
|
name: 'Permanent Pen*',
|
||||||
|
type: premiumType
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'pageembed',
|
||||||
|
name: 'Page Embed*',
|
||||||
|
type: premiumType
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'tinycomments',
|
||||||
|
name: 'Tiny Comments*',
|
||||||
|
type: premiumType,
|
||||||
|
slug: 'comments'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'advtable',
|
||||||
|
name: 'Advanced Tables*',
|
||||||
|
type: premiumType
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'autocorrect',
|
||||||
|
name: 'Autocorrect*',
|
||||||
|
type: premiumType
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'export',
|
||||||
|
name: 'Export*',
|
||||||
|
type: premiumType
|
||||||
|
}
|
||||||
|
], function (item) {
|
||||||
|
return __assign(__assign({}, item), {
|
||||||
|
type: item.type || openSourceType,
|
||||||
|
slug: item.slug || item.key
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
var tab$1 = function (editor) {
|
||||||
|
var availablePlugins = function () {
|
||||||
|
var premiumPlugins = [
|
||||||
|
'Accessibility Checker',
|
||||||
|
'Advanced Code Editor',
|
||||||
|
'Advanced Tables',
|
||||||
|
'Case Change',
|
||||||
|
'Checklist',
|
||||||
|
'Export',
|
||||||
|
'Tiny Comments',
|
||||||
|
'Tiny Drive',
|
||||||
|
'Enhanced Media Embed',
|
||||||
|
'Format Painter',
|
||||||
|
'Link Checker',
|
||||||
|
'Mentions',
|
||||||
|
'MoxieManager',
|
||||||
|
'Page Embed',
|
||||||
|
'Permanent Pen',
|
||||||
|
'PowerPaste',
|
||||||
|
'Spell Checker Pro'
|
||||||
|
];
|
||||||
|
var premiumPluginList = map(premiumPlugins, function (plugin) {
|
||||||
|
return '<li>' + global$1.translate(plugin) + '</li>';
|
||||||
|
}).join('');
|
||||||
|
return '<div data-mce-tabstop="1" tabindex="-1">' + '<p><b>' + global$1.translate('Premium plugins:') + '</b></p>' + '<ul>' + premiumPluginList + '<li class="tox-help__more-link" "><a href="https://www.tiny.cloud/pricing/?utm_campaign=editor_referral&utm_medium=help_dialog&utm_source=tinymce" target="_blank">' + global$1.translate('Learn more...') + '</a></li>' + '</ul>' + '</div>';
|
||||||
|
};
|
||||||
|
var makeLink = function (p) {
|
||||||
|
return '<a href="' + p.url + '" target="_blank" rel="noopener">' + p.name + '</a>';
|
||||||
|
};
|
||||||
|
var maybeUrlize = function (editor, key) {
|
||||||
|
return find(urls, function (x) {
|
||||||
|
return x.key === key;
|
||||||
|
}).fold(function () {
|
||||||
|
var getMetadata = editor.plugins[key].getMetadata;
|
||||||
|
return typeof getMetadata === 'function' ? makeLink(getMetadata()) : key;
|
||||||
|
}, function (x) {
|
||||||
|
return makeLink({
|
||||||
|
name: x.name,
|
||||||
|
url: 'https://www.tiny.cloud/docs/plugins/' + x.type + '/' + x.slug
|
||||||
|
});
|
||||||
|
});
|
||||||
|
};
|
||||||
|
var getPluginKeys = function (editor) {
|
||||||
|
var keys$1 = keys(editor.plugins);
|
||||||
|
var forced_plugins = getForcedPlugins(editor);
|
||||||
|
return forced_plugins === undefined ? keys$1 : filter(keys$1, function (k) {
|
||||||
|
return !contains(forced_plugins, k);
|
||||||
|
});
|
||||||
|
};
|
||||||
|
var pluginLister = function (editor) {
|
||||||
|
var pluginKeys = getPluginKeys(editor);
|
||||||
|
var pluginLis = map(pluginKeys, function (key) {
|
||||||
|
return '<li>' + maybeUrlize(editor, key) + '</li>';
|
||||||
|
});
|
||||||
|
var count = pluginLis.length;
|
||||||
|
var pluginsString = pluginLis.join('');
|
||||||
|
var html = '<p><b>' + global$1.translate([
|
||||||
|
'Plugins installed ({0}):',
|
||||||
|
count
|
||||||
|
]) + '</b></p>' + '<ul>' + pluginsString + '</ul>';
|
||||||
|
return html;
|
||||||
|
};
|
||||||
|
var installedPlugins = function (editor) {
|
||||||
|
if (editor == null) {
|
||||||
|
return '';
|
||||||
|
}
|
||||||
|
return '<div data-mce-tabstop="1" tabindex="-1">' + pluginLister(editor) + '</div>';
|
||||||
|
};
|
||||||
|
var htmlPanel = {
|
||||||
|
type: 'htmlpanel',
|
||||||
|
presets: 'document',
|
||||||
|
html: [
|
||||||
|
installedPlugins(editor),
|
||||||
|
availablePlugins()
|
||||||
|
].join('')
|
||||||
|
};
|
||||||
|
return {
|
||||||
|
name: 'plugins',
|
||||||
|
title: 'Plugins',
|
||||||
|
items: [htmlPanel]
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
var global = tinymce.util.Tools.resolve('tinymce.EditorManager');
|
||||||
|
|
||||||
|
var tab = function () {
|
||||||
|
var getVersion = function (major, minor) {
|
||||||
|
return major.indexOf('@') === 0 ? 'X.X.X' : major + '.' + minor;
|
||||||
|
};
|
||||||
|
var version = getVersion(global.majorVersion, global.minorVersion);
|
||||||
|
var changeLogLink = '<a href="https://www.tiny.cloud/docs/changelog/?utm_campaign=editor_referral&utm_medium=help_dialog&utm_source=tinymce" target="_blank">TinyMCE ' + version + '</a>';
|
||||||
|
var htmlPanel = {
|
||||||
|
type: 'htmlpanel',
|
||||||
|
html: '<p>' + global$1.translate([
|
||||||
|
'You are using {0}',
|
||||||
|
changeLogLink
|
||||||
|
]) + '</p>',
|
||||||
|
presets: 'document'
|
||||||
|
};
|
||||||
|
return {
|
||||||
|
name: 'versions',
|
||||||
|
title: 'Version',
|
||||||
|
items: [htmlPanel]
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
var parseHelpTabsSetting = function (tabsFromSettings, tabs) {
|
||||||
|
var newTabs = {};
|
||||||
|
var names = map(tabsFromSettings, function (t) {
|
||||||
|
if (typeof t === 'string') {
|
||||||
|
if (has(tabs, t)) {
|
||||||
|
newTabs[t] = tabs[t];
|
||||||
|
}
|
||||||
|
return t;
|
||||||
|
} else {
|
||||||
|
newTabs[t.name] = t;
|
||||||
|
return t.name;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
return {
|
||||||
|
tabs: newTabs,
|
||||||
|
names: names
|
||||||
|
};
|
||||||
|
};
|
||||||
|
var getNamesFromTabs = function (tabs) {
|
||||||
|
var names = keys(tabs);
|
||||||
|
var idx = names.indexOf('versions');
|
||||||
|
if (idx !== -1) {
|
||||||
|
names.splice(idx, 1);
|
||||||
|
names.push('versions');
|
||||||
|
}
|
||||||
|
return {
|
||||||
|
tabs: tabs,
|
||||||
|
names: names
|
||||||
|
};
|
||||||
|
};
|
||||||
|
var parseCustomTabs = function (editor, customTabs) {
|
||||||
|
var _a;
|
||||||
|
var shortcuts = tab$2();
|
||||||
|
var nav = tab$3();
|
||||||
|
var plugins = tab$1(editor);
|
||||||
|
var versions = tab();
|
||||||
|
var tabs = __assign((_a = {}, _a[shortcuts.name] = shortcuts, _a[nav.name] = nav, _a[plugins.name] = plugins, _a[versions.name] = versions, _a), customTabs.get());
|
||||||
|
return getHelpTabs(editor).fold(function () {
|
||||||
|
return getNamesFromTabs(tabs);
|
||||||
|
}, function (tabsFromSettings) {
|
||||||
|
return parseHelpTabsSetting(tabsFromSettings, tabs);
|
||||||
|
});
|
||||||
|
};
|
||||||
|
var init = function (editor, customTabs) {
|
||||||
|
return function () {
|
||||||
|
var _a = parseCustomTabs(editor, customTabs), tabs = _a.tabs, names = _a.names;
|
||||||
|
var foundTabs = map(names, function (name) {
|
||||||
|
return get(tabs, name);
|
||||||
|
});
|
||||||
|
var dialogTabs = cat(foundTabs);
|
||||||
|
var body = {
|
||||||
|
type: 'tabpanel',
|
||||||
|
tabs: dialogTabs
|
||||||
|
};
|
||||||
|
editor.windowManager.open({
|
||||||
|
title: 'Help',
|
||||||
|
size: 'medium',
|
||||||
|
body: body,
|
||||||
|
buttons: [{
|
||||||
|
type: 'cancel',
|
||||||
|
name: 'close',
|
||||||
|
text: 'Close',
|
||||||
|
primary: true
|
||||||
|
}],
|
||||||
|
initialData: {}
|
||||||
|
});
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
function Plugin () {
|
||||||
|
global$3.add('help', function (editor) {
|
||||||
|
var customTabs = Cell({});
|
||||||
|
var api = get$1(customTabs);
|
||||||
|
var dialogOpener = init(editor, customTabs);
|
||||||
|
register(editor, dialogOpener);
|
||||||
|
register$1(editor, dialogOpener);
|
||||||
|
editor.shortcuts.add('Alt+0', 'Open help dialog', 'mceHelp');
|
||||||
|
return api;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
Plugin();
|
||||||
|
|
||||||
|
}());
|
File diff suppressed because one or more lines are too long
|
@ -0,0 +1,7 @@
|
||||||
|
// Exports the "hr" plugin for usage with module loaders
|
||||||
|
// Usage:
|
||||||
|
// CommonJS:
|
||||||
|
// require('tinymce/plugins/hr')
|
||||||
|
// ES2015:
|
||||||
|
// import 'tinymce/plugins/hr'
|
||||||
|
require('./plugin.js');
|
|
@ -0,0 +1,45 @@
|
||||||
|
/**
|
||||||
|
* Copyright (c) Tiny Technologies, Inc. All rights reserved.
|
||||||
|
* Licensed under the LGPL or a commercial license.
|
||||||
|
* For LGPL see License.txt in the project root for license information.
|
||||||
|
* For commercial licenses see https://www.tiny.cloud/
|
||||||
|
*
|
||||||
|
* Version: 5.9.2 (2021-09-08)
|
||||||
|
*/
|
||||||
|
(function () {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
var global = tinymce.util.Tools.resolve('tinymce.PluginManager');
|
||||||
|
|
||||||
|
var register$1 = function (editor) {
|
||||||
|
editor.addCommand('InsertHorizontalRule', function () {
|
||||||
|
editor.execCommand('mceInsertContent', false, '<hr />');
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
var register = function (editor) {
|
||||||
|
var onAction = function () {
|
||||||
|
return editor.execCommand('InsertHorizontalRule');
|
||||||
|
};
|
||||||
|
editor.ui.registry.addButton('hr', {
|
||||||
|
icon: 'horizontal-rule',
|
||||||
|
tooltip: 'Horizontal line',
|
||||||
|
onAction: onAction
|
||||||
|
});
|
||||||
|
editor.ui.registry.addMenuItem('hr', {
|
||||||
|
icon: 'horizontal-rule',
|
||||||
|
text: 'Horizontal line',
|
||||||
|
onAction: onAction
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
function Plugin () {
|
||||||
|
global.add('hr', function (editor) {
|
||||||
|
register$1(editor);
|
||||||
|
register(editor);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
Plugin();
|
||||||
|
|
||||||
|
}());
|
|
@ -0,0 +1,9 @@
|
||||||
|
/**
|
||||||
|
* Copyright (c) Tiny Technologies, Inc. All rights reserved.
|
||||||
|
* Licensed under the LGPL or a commercial license.
|
||||||
|
* For LGPL see License.txt in the project root for license information.
|
||||||
|
* For commercial licenses see https://www.tiny.cloud/
|
||||||
|
*
|
||||||
|
* Version: 5.9.2 (2021-09-08)
|
||||||
|
*/
|
||||||
|
!function(){"use strict";tinymce.util.Tools.resolve("tinymce.PluginManager").add("hr",function(n){var o,t;function e(){return t.execCommand("InsertHorizontalRule")}(o=n).addCommand("InsertHorizontalRule",function(){o.execCommand("mceInsertContent",!1,"<hr />")}),(t=n).ui.registry.addButton("hr",{icon:"horizontal-rule",tooltip:"Horizontal line",onAction:e}),t.ui.registry.addMenuItem("hr",{icon:"horizontal-rule",text:"Horizontal line",onAction:e})})}();
|
|
@ -0,0 +1,7 @@
|
||||||
|
// Exports the "image" plugin for usage with module loaders
|
||||||
|
// Usage:
|
||||||
|
// CommonJS:
|
||||||
|
// require('tinymce/plugins/image')
|
||||||
|
// ES2015:
|
||||||
|
// import 'tinymce/plugins/image'
|
||||||
|
require('./plugin.js');
|
File diff suppressed because it is too large
Load Diff
File diff suppressed because one or more lines are too long
|
@ -0,0 +1,7 @@
|
||||||
|
// Exports the "imagetools" plugin for usage with module loaders
|
||||||
|
// Usage:
|
||||||
|
// CommonJS:
|
||||||
|
// require('tinymce/plugins/imagetools')
|
||||||
|
// ES2015:
|
||||||
|
// import 'tinymce/plugins/imagetools'
|
||||||
|
require('./plugin.js');
|
File diff suppressed because it is too large
Load Diff
File diff suppressed because one or more lines are too long
|
@ -0,0 +1,7 @@
|
||||||
|
// Exports the "importcss" plugin for usage with module loaders
|
||||||
|
// Usage:
|
||||||
|
// CommonJS:
|
||||||
|
// require('tinymce/plugins/importcss')
|
||||||
|
// ES2015:
|
||||||
|
// import 'tinymce/plugins/importcss'
|
||||||
|
require('./plugin.js');
|
|
@ -0,0 +1,341 @@
|
||||||
|
/**
|
||||||
|
* Copyright (c) Tiny Technologies, Inc. All rights reserved.
|
||||||
|
* Licensed under the LGPL or a commercial license.
|
||||||
|
* For LGPL see License.txt in the project root for license information.
|
||||||
|
* For commercial licenses see https://www.tiny.cloud/
|
||||||
|
*
|
||||||
|
* Version: 5.9.2 (2021-09-08)
|
||||||
|
*/
|
||||||
|
(function () {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
var global$4 = tinymce.util.Tools.resolve('tinymce.PluginManager');
|
||||||
|
|
||||||
|
var typeOf = function (x) {
|
||||||
|
var t = typeof x;
|
||||||
|
if (x === null) {
|
||||||
|
return 'null';
|
||||||
|
} else if (t === 'object' && (Array.prototype.isPrototypeOf(x) || x.constructor && x.constructor.name === 'Array')) {
|
||||||
|
return 'array';
|
||||||
|
} else if (t === 'object' && (String.prototype.isPrototypeOf(x) || x.constructor && x.constructor.name === 'String')) {
|
||||||
|
return 'string';
|
||||||
|
} else {
|
||||||
|
return t;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
var isType = function (type) {
|
||||||
|
return function (value) {
|
||||||
|
return typeOf(value) === type;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
var isString = isType('string');
|
||||||
|
var isArray = isType('array');
|
||||||
|
|
||||||
|
var global$3 = tinymce.util.Tools.resolve('tinymce.dom.DOMUtils');
|
||||||
|
|
||||||
|
var global$2 = tinymce.util.Tools.resolve('tinymce.EditorManager');
|
||||||
|
|
||||||
|
var global$1 = tinymce.util.Tools.resolve('tinymce.Env');
|
||||||
|
|
||||||
|
var global = tinymce.util.Tools.resolve('tinymce.util.Tools');
|
||||||
|
|
||||||
|
var shouldMergeClasses = function (editor) {
|
||||||
|
return editor.getParam('importcss_merge_classes');
|
||||||
|
};
|
||||||
|
var shouldImportExclusive = function (editor) {
|
||||||
|
return editor.getParam('importcss_exclusive');
|
||||||
|
};
|
||||||
|
var getSelectorConverter = function (editor) {
|
||||||
|
return editor.getParam('importcss_selector_converter');
|
||||||
|
};
|
||||||
|
var getSelectorFilter = function (editor) {
|
||||||
|
return editor.getParam('importcss_selector_filter');
|
||||||
|
};
|
||||||
|
var getCssGroups = function (editor) {
|
||||||
|
return editor.getParam('importcss_groups');
|
||||||
|
};
|
||||||
|
var shouldAppend = function (editor) {
|
||||||
|
return editor.getParam('importcss_append');
|
||||||
|
};
|
||||||
|
var getFileFilter = function (editor) {
|
||||||
|
return editor.getParam('importcss_file_filter');
|
||||||
|
};
|
||||||
|
var getSkin = function (editor) {
|
||||||
|
var skin = editor.getParam('skin');
|
||||||
|
return skin !== false ? skin || 'oxide' : false;
|
||||||
|
};
|
||||||
|
var getSkinUrl = function (editor) {
|
||||||
|
return editor.getParam('skin_url');
|
||||||
|
};
|
||||||
|
|
||||||
|
var nativePush = Array.prototype.push;
|
||||||
|
var map = function (xs, f) {
|
||||||
|
var len = xs.length;
|
||||||
|
var r = new Array(len);
|
||||||
|
for (var i = 0; i < len; i++) {
|
||||||
|
var x = xs[i];
|
||||||
|
r[i] = f(x, i);
|
||||||
|
}
|
||||||
|
return r;
|
||||||
|
};
|
||||||
|
var flatten = function (xs) {
|
||||||
|
var r = [];
|
||||||
|
for (var i = 0, len = xs.length; i < len; ++i) {
|
||||||
|
if (!isArray(xs[i])) {
|
||||||
|
throw new Error('Arr.flatten item ' + i + ' was not an array, input: ' + xs);
|
||||||
|
}
|
||||||
|
nativePush.apply(r, xs[i]);
|
||||||
|
}
|
||||||
|
return r;
|
||||||
|
};
|
||||||
|
var bind = function (xs, f) {
|
||||||
|
return flatten(map(xs, f));
|
||||||
|
};
|
||||||
|
|
||||||
|
var generate = function () {
|
||||||
|
var ungroupedOrder = [];
|
||||||
|
var groupOrder = [];
|
||||||
|
var groups = {};
|
||||||
|
var addItemToGroup = function (groupTitle, itemInfo) {
|
||||||
|
if (groups[groupTitle]) {
|
||||||
|
groups[groupTitle].push(itemInfo);
|
||||||
|
} else {
|
||||||
|
groupOrder.push(groupTitle);
|
||||||
|
groups[groupTitle] = [itemInfo];
|
||||||
|
}
|
||||||
|
};
|
||||||
|
var addItem = function (itemInfo) {
|
||||||
|
ungroupedOrder.push(itemInfo);
|
||||||
|
};
|
||||||
|
var toFormats = function () {
|
||||||
|
var groupItems = bind(groupOrder, function (g) {
|
||||||
|
var items = groups[g];
|
||||||
|
return items.length === 0 ? [] : [{
|
||||||
|
title: g,
|
||||||
|
items: items
|
||||||
|
}];
|
||||||
|
});
|
||||||
|
return groupItems.concat(ungroupedOrder);
|
||||||
|
};
|
||||||
|
return {
|
||||||
|
addItemToGroup: addItemToGroup,
|
||||||
|
addItem: addItem,
|
||||||
|
toFormats: toFormats
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
var removeCacheSuffix = function (url) {
|
||||||
|
var cacheSuffix = global$1.cacheSuffix;
|
||||||
|
if (isString(url)) {
|
||||||
|
url = url.replace('?' + cacheSuffix, '').replace('&' + cacheSuffix, '');
|
||||||
|
}
|
||||||
|
return url;
|
||||||
|
};
|
||||||
|
var isSkinContentCss = function (editor, href) {
|
||||||
|
var skin = getSkin(editor);
|
||||||
|
if (skin) {
|
||||||
|
var skinUrlBase = getSkinUrl(editor);
|
||||||
|
var skinUrl = skinUrlBase ? editor.documentBaseURI.toAbsolute(skinUrlBase) : global$2.baseURL + '/skins/ui/' + skin;
|
||||||
|
var contentSkinUrlPart = global$2.baseURL + '/skins/content/';
|
||||||
|
return href === skinUrl + '/content' + (editor.inline ? '.inline' : '') + '.min.css' || href.indexOf(contentSkinUrlPart) !== -1;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
};
|
||||||
|
var compileFilter = function (filter) {
|
||||||
|
if (isString(filter)) {
|
||||||
|
return function (value) {
|
||||||
|
return value.indexOf(filter) !== -1;
|
||||||
|
};
|
||||||
|
} else if (filter instanceof RegExp) {
|
||||||
|
return function (value) {
|
||||||
|
return filter.test(value);
|
||||||
|
};
|
||||||
|
}
|
||||||
|
return filter;
|
||||||
|
};
|
||||||
|
var isCssImportRule = function (rule) {
|
||||||
|
return rule.styleSheet;
|
||||||
|
};
|
||||||
|
var isCssPageRule = function (rule) {
|
||||||
|
return rule.selectorText;
|
||||||
|
};
|
||||||
|
var getSelectors = function (editor, doc, fileFilter) {
|
||||||
|
var selectors = [];
|
||||||
|
var contentCSSUrls = {};
|
||||||
|
var append = function (styleSheet, imported) {
|
||||||
|
var href = styleSheet.href, rules;
|
||||||
|
href = removeCacheSuffix(href);
|
||||||
|
if (!href || !fileFilter(href, imported) || isSkinContentCss(editor, href)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
global.each(styleSheet.imports, function (styleSheet) {
|
||||||
|
append(styleSheet, true);
|
||||||
|
});
|
||||||
|
try {
|
||||||
|
rules = styleSheet.cssRules || styleSheet.rules;
|
||||||
|
} catch (e) {
|
||||||
|
}
|
||||||
|
global.each(rules, function (cssRule) {
|
||||||
|
if (isCssImportRule(cssRule)) {
|
||||||
|
append(cssRule.styleSheet, true);
|
||||||
|
} else if (isCssPageRule(cssRule)) {
|
||||||
|
global.each(cssRule.selectorText.split(','), function (selector) {
|
||||||
|
selectors.push(global.trim(selector));
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
|
};
|
||||||
|
global.each(editor.contentCSS, function (url) {
|
||||||
|
contentCSSUrls[url] = true;
|
||||||
|
});
|
||||||
|
if (!fileFilter) {
|
||||||
|
fileFilter = function (href, imported) {
|
||||||
|
return imported || contentCSSUrls[href];
|
||||||
|
};
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
global.each(doc.styleSheets, function (styleSheet) {
|
||||||
|
append(styleSheet);
|
||||||
|
});
|
||||||
|
} catch (e) {
|
||||||
|
}
|
||||||
|
return selectors;
|
||||||
|
};
|
||||||
|
var defaultConvertSelectorToFormat = function (editor, selectorText) {
|
||||||
|
var format;
|
||||||
|
var selector = /^(?:([a-z0-9\-_]+))?(\.[a-z0-9_\-\.]+)$/i.exec(selectorText);
|
||||||
|
if (!selector) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
var elementName = selector[1];
|
||||||
|
var classes = selector[2].substr(1).split('.').join(' ');
|
||||||
|
var inlineSelectorElements = global.makeMap('a,img');
|
||||||
|
if (selector[1]) {
|
||||||
|
format = { title: selectorText };
|
||||||
|
if (editor.schema.getTextBlockElements()[elementName]) {
|
||||||
|
format.block = elementName;
|
||||||
|
} else if (editor.schema.getBlockElements()[elementName] || inlineSelectorElements[elementName.toLowerCase()]) {
|
||||||
|
format.selector = elementName;
|
||||||
|
} else {
|
||||||
|
format.inline = elementName;
|
||||||
|
}
|
||||||
|
} else if (selector[2]) {
|
||||||
|
format = {
|
||||||
|
inline: 'span',
|
||||||
|
title: selectorText.substr(1),
|
||||||
|
classes: classes
|
||||||
|
};
|
||||||
|
}
|
||||||
|
if (shouldMergeClasses(editor) !== false) {
|
||||||
|
format.classes = classes;
|
||||||
|
} else {
|
||||||
|
format.attributes = { class: classes };
|
||||||
|
}
|
||||||
|
return format;
|
||||||
|
};
|
||||||
|
var getGroupsBySelector = function (groups, selector) {
|
||||||
|
return global.grep(groups, function (group) {
|
||||||
|
return !group.filter || group.filter(selector);
|
||||||
|
});
|
||||||
|
};
|
||||||
|
var compileUserDefinedGroups = function (groups) {
|
||||||
|
return global.map(groups, function (group) {
|
||||||
|
return global.extend({}, group, {
|
||||||
|
original: group,
|
||||||
|
selectors: {},
|
||||||
|
filter: compileFilter(group.filter)
|
||||||
|
});
|
||||||
|
});
|
||||||
|
};
|
||||||
|
var isExclusiveMode = function (editor, group) {
|
||||||
|
return group === null || shouldImportExclusive(editor) !== false;
|
||||||
|
};
|
||||||
|
var isUniqueSelector = function (editor, selector, group, globallyUniqueSelectors) {
|
||||||
|
return !(isExclusiveMode(editor, group) ? selector in globallyUniqueSelectors : selector in group.selectors);
|
||||||
|
};
|
||||||
|
var markUniqueSelector = function (editor, selector, group, globallyUniqueSelectors) {
|
||||||
|
if (isExclusiveMode(editor, group)) {
|
||||||
|
globallyUniqueSelectors[selector] = true;
|
||||||
|
} else {
|
||||||
|
group.selectors[selector] = true;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
var convertSelectorToFormat = function (editor, plugin, selector, group) {
|
||||||
|
var selectorConverter;
|
||||||
|
if (group && group.selector_converter) {
|
||||||
|
selectorConverter = group.selector_converter;
|
||||||
|
} else if (getSelectorConverter(editor)) {
|
||||||
|
selectorConverter = getSelectorConverter(editor);
|
||||||
|
} else {
|
||||||
|
selectorConverter = function () {
|
||||||
|
return defaultConvertSelectorToFormat(editor, selector);
|
||||||
|
};
|
||||||
|
}
|
||||||
|
return selectorConverter.call(plugin, selector, group);
|
||||||
|
};
|
||||||
|
var setup = function (editor) {
|
||||||
|
editor.on('init', function () {
|
||||||
|
var model = generate();
|
||||||
|
var globallyUniqueSelectors = {};
|
||||||
|
var selectorFilter = compileFilter(getSelectorFilter(editor));
|
||||||
|
var groups = compileUserDefinedGroups(getCssGroups(editor));
|
||||||
|
var processSelector = function (selector, group) {
|
||||||
|
if (isUniqueSelector(editor, selector, group, globallyUniqueSelectors)) {
|
||||||
|
markUniqueSelector(editor, selector, group, globallyUniqueSelectors);
|
||||||
|
var format = convertSelectorToFormat(editor, editor.plugins.importcss, selector, group);
|
||||||
|
if (format) {
|
||||||
|
var formatName = format.name || global$3.DOM.uniqueId();
|
||||||
|
editor.formatter.register(formatName, format);
|
||||||
|
return {
|
||||||
|
title: format.title,
|
||||||
|
format: formatName
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
};
|
||||||
|
global.each(getSelectors(editor, editor.getDoc(), compileFilter(getFileFilter(editor))), function (selector) {
|
||||||
|
if (selector.indexOf('.mce-') === -1) {
|
||||||
|
if (!selectorFilter || selectorFilter(selector)) {
|
||||||
|
var selectorGroups = getGroupsBySelector(groups, selector);
|
||||||
|
if (selectorGroups.length > 0) {
|
||||||
|
global.each(selectorGroups, function (group) {
|
||||||
|
var menuItem = processSelector(selector, group);
|
||||||
|
if (menuItem) {
|
||||||
|
model.addItemToGroup(group.title, menuItem);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
var menuItem = processSelector(selector, null);
|
||||||
|
if (menuItem) {
|
||||||
|
model.addItem(menuItem);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
var items = model.toFormats();
|
||||||
|
editor.fire('addStyleModifications', {
|
||||||
|
items: items,
|
||||||
|
replace: !shouldAppend(editor)
|
||||||
|
});
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
var get = function (editor) {
|
||||||
|
var convertSelectorToFormat = function (selectorText) {
|
||||||
|
return defaultConvertSelectorToFormat(editor, selectorText);
|
||||||
|
};
|
||||||
|
return { convertSelectorToFormat: convertSelectorToFormat };
|
||||||
|
};
|
||||||
|
|
||||||
|
function Plugin () {
|
||||||
|
global$4.add('importcss', function (editor) {
|
||||||
|
setup(editor);
|
||||||
|
return get(editor);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
Plugin();
|
||||||
|
|
||||||
|
}());
|
|
@ -0,0 +1,9 @@
|
||||||
|
/**
|
||||||
|
* Copyright (c) Tiny Technologies, Inc. All rights reserved.
|
||||||
|
* Licensed under the LGPL or a commercial license.
|
||||||
|
* For LGPL see License.txt in the project root for license information.
|
||||||
|
* For commercial licenses see https://www.tiny.cloud/
|
||||||
|
*
|
||||||
|
* Version: 5.9.2 (2021-09-08)
|
||||||
|
*/
|
||||||
|
!function(){"use strict";function t(n){return function(t){return r=typeof(e=t),(null===e?"null":"object"==r&&(Array.prototype.isPrototypeOf(e)||e.constructor&&"Array"===e.constructor.name)?"array":"object"==r&&(String.prototype.isPrototypeOf(e)||e.constructor&&"String"===e.constructor.name)?"string":r)===n;var e,r}}function y(t){return t.getParam("importcss_selector_converter")}function u(e){return l(e)?function(t){return-1!==t.indexOf(e)}:e instanceof RegExp?function(t){return e.test(t)}:e}function h(t,e){var r,n=/^(?:([a-z0-9\-_]+))?(\.[a-z0-9_\-\.]+)$/i.exec(e);if(n){var o=n[1],i=n[2].substr(1).split(".").join(" "),c=x.makeMap("a,img");return n[1]?(r={title:e},t.schema.getTextBlockElements()[o]?r.block=o:t.schema.getBlockElements()[o]||c[o.toLowerCase()]?r.selector=o:r.inline=o):n[2]&&(r={inline:"span",title:e.substr(1),classes:i}),!1!==t.getParam("importcss_merge_classes")?r.classes=i:r.attributes={class:i},r}}function d(t,e){return null===e||!1!==t.getParam("importcss_exclusive")}function r(v){v.on("init",function(){function o(t,e){if(f=t,p=g,!(d(v,m=e)?f in p:f in m.selectors)){a=t,l=g,d(v,u=e)?l[a]=!0:u.selectors[a]=!0;var r=(i=(o=v).plugins.importcss,c=t,((s=e)&&s.selector_converter?s.selector_converter:y(o)?y(o):function(){return h(o,c)}).call(i,c,s));if(r){var n=r.name||_.DOM.uniqueId();return v.formatter.register(n,r),{title:r.title,format:n}}}var o,i,c,s,a,u,l,f,m,p;return null}var e,r,n,t,i=(e=[],r=[],n={},{addItemToGroup:function(t,e){n[t]?n[t].push(e):(r.push(t),n[t]=[e])},addItem:function(t){e.push(t)},toFormats:function(){return function(t){for(var e=[],r=0,n=t.length;r<n;++r){if(!f(t[r]))throw new Error("Arr.flatten item "+r+" was not an array, input: "+t);P.apply(e,t[r])}return e}(function(t,e){for(var r=t.length,n=new Array(r),o=0;o<r;o++){var i=t[o];n[o]=e(i,o)}return n}(r,function(t){var e=n[t];return 0===e.length?[]:[{title:t,items:e}]})).concat(e)}}),g={},c=u(v.getParam("importcss_selector_filter")),s=(t=v.getParam("importcss_groups"),x.map(t,function(t){return x.extend({},t,{original:t,selectors:{},filter:u(t.filter)})}));x.each(function(c,t,s){var a=[],r={},u=function(t,e){var r,n,o=n=t.href,i=p.cacheSuffix;if((n=o=l(o)?o.replace("?"+i,"").replace("&"+i,""):o)&&s(n,e)&&!function(t,e){var r,n=!1!==(r=t.getParam("skin"))&&(r||"oxide");if(n){var o=t.getParam("skin_url"),i=o?t.documentBaseURI.toAbsolute(o):m.baseURL+"/skins/ui/"+n,c=m.baseURL+"/skins/content/";return e===i+"/content"+(t.inline?".inline":"")+".min.css"||-1!==e.indexOf(c)}}(c,n)){x.each(t.imports,function(t){u(t,!0)});try{r=t.cssRules||t.rules}catch(t){}x.each(r,function(t){t.styleSheet?u(t.styleSheet,!0):t.selectorText&&x.each(t.selectorText.split(","),function(t){a.push(x.trim(t))})})}};x.each(c.contentCSS,function(t){r[t]=!0}),s=s||function(t,e){return e||r[t]};try{x.each(t.styleSheets,function(t){u(t)})}catch(t){}return a}(v,v.getDoc(),u(v.getParam("importcss_file_filter"))),function(r){var t,e,n;-1===r.indexOf(".mce-")&&(c&&!c(r)||(n=r,0<(t=x.grep(s,function(t){return!t.filter||t.filter(n)})).length?x.each(t,function(t){var e=o(r,t);e&&i.addItemToGroup(t.title,e)}):(e=o(r,null))&&i.addItem(e)))});var a=i.toFormats();v.fire("addStyleModifications",{items:a,replace:!v.getParam("importcss_append")})})}var e=tinymce.util.Tools.resolve("tinymce.PluginManager"),l=t("string"),f=t("array"),_=tinymce.util.Tools.resolve("tinymce.dom.DOMUtils"),m=tinymce.util.Tools.resolve("tinymce.EditorManager"),p=tinymce.util.Tools.resolve("tinymce.Env"),x=tinymce.util.Tools.resolve("tinymce.util.Tools"),P=Array.prototype.push;e.add("importcss",function(t){return r(t),e=t,{convertSelectorToFormat:function(t){return h(e,t)}};var e})}();
|
|
@ -0,0 +1 @@
|
||||||
|
require('./plugin.js')
|
|
@ -0,0 +1,88 @@
|
||||||
|
/*
|
||||||
|
* @Author: 陈伟亮 1186723967@qq.com
|
||||||
|
* @Date: 2020-09-02 10:01:22
|
||||||
|
* @LastEditors: 陈伟亮 1186723967@qq.com
|
||||||
|
* @LastEditTime: 2022-08-02 15:59:31
|
||||||
|
* @FilePath: \background-front-end\static\plugins\tinymce\plugins\indent2em\plugin.min.js
|
||||||
|
* @Description: 这是默认设置,请设置`customMade`, 打开koroFileHeader查看配置 进行设置: https://github.com/OBKoro1/koro1FileHeader/wiki/%E9%85%8D%E7%BD%AE
|
||||||
|
*/
|
||||||
|
tinymce.PluginManager.add('indent2em', function(editor, url) {
|
||||||
|
var pluginName='首行缩进';
|
||||||
|
var global$1 = tinymce.util.Tools.resolve('tinymce.util.Tools');
|
||||||
|
var indent2em_val = editor.getParam('indent2em_val', '2em');
|
||||||
|
var doAct = function () {
|
||||||
|
var dom = editor.dom;
|
||||||
|
var blocks = editor.selection.getSelectedBlocks();
|
||||||
|
var act = '';
|
||||||
|
|
||||||
|
// console.log(editor.dom)
|
||||||
|
global$1.each(blocks, function (block) {
|
||||||
|
var flag=true
|
||||||
|
var children=block.children
|
||||||
|
//给块级元素加上font-size使em宽度为一个文字大小
|
||||||
|
if(children.length!=0&&children[0].style['font-size']){
|
||||||
|
block.style['font-size']=children[0].style['font-size']
|
||||||
|
}
|
||||||
|
// 如果块级元素里有图片不设置text-indent
|
||||||
|
while (children.length==1){
|
||||||
|
if(children[0].tagName=='IMG'){
|
||||||
|
flag=false
|
||||||
|
}
|
||||||
|
children=children[0].children
|
||||||
|
}
|
||||||
|
if(flag||blocks.length==1){
|
||||||
|
if(act==''){
|
||||||
|
act = dom.getStyle(block,'text-indent')==indent2em_val ? 'remove' : 'add';
|
||||||
|
}
|
||||||
|
if( act=='add' ){
|
||||||
|
dom.setStyle(block, 'text-indent', indent2em_val);
|
||||||
|
}else{
|
||||||
|
var style=dom.getAttrib(block,'style');
|
||||||
|
var reg = new RegExp('text-indent:[\\s]*' + indent2em_val + ';', 'ig');
|
||||||
|
style = style.replace(reg, '');
|
||||||
|
dom.setAttrib(block,'style',style);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
editor.ui.registry.getAll().icons.indent2em || editor.ui.registry.addIcon('indent2em','<svg viewBox="0 0 1024 1024" xmlns="http://www.w3.org/2000/svg" width="24" height="24"><path d="M170.666667 563.2v-102.4H887.466667v102.4zM170.666667 836.266667v-102.4H887.466667v102.4zM512 290.133333v-102.4H887.466667v102.4zM238.933333 341.333333V136.533333l204.8 102.4z" fill="#2c2c2c" p-id="5210"></path></svg>');
|
||||||
|
|
||||||
|
var stateSelectorAdapter = function (editor, selector) {
|
||||||
|
return function (buttonApi) {
|
||||||
|
return editor.selection.selectorChangedWithUnbind(selector.join(','), buttonApi.setActive).unbind;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
editor.ui.registry.addToggleButton('indent2em', {
|
||||||
|
icon: 'indent2em',
|
||||||
|
tooltip: pluginName,
|
||||||
|
onAction: function () {
|
||||||
|
doAct();
|
||||||
|
},
|
||||||
|
onSetup: stateSelectorAdapter(editor, [
|
||||||
|
'*[style*="text-indent"]',
|
||||||
|
'*[data-mce-style*="text-indent"]',
|
||||||
|
])
|
||||||
|
});
|
||||||
|
|
||||||
|
editor.ui.registry.addMenuItem('indent2em', {
|
||||||
|
text: pluginName,
|
||||||
|
onAction: function() {
|
||||||
|
doAct();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
editor.addCommand('indent2em', doAct );
|
||||||
|
|
||||||
|
return {
|
||||||
|
getMetadata: function () {
|
||||||
|
return {
|
||||||
|
name: pluginName,
|
||||||
|
url: "http://tinymce.ax-z.cn/more-plugins/indent2em.php",
|
||||||
|
};
|
||||||
|
}
|
||||||
|
};
|
||||||
|
});
|
|
@ -0,0 +1,88 @@
|
||||||
|
/*
|
||||||
|
* @Author: 陈伟亮 1186723967@qq.com
|
||||||
|
* @Date: 2020-09-02 10:01:22
|
||||||
|
* @LastEditors: 陈伟亮 1186723967@qq.com
|
||||||
|
* @LastEditTime: 2022-08-02 16:31:59
|
||||||
|
* @FilePath: \background-front-end\static\plugins\tinymce\plugins\indent2em\plugin.min.js
|
||||||
|
* @Description: 这是默认设置,请设置`customMade`, 打开koroFileHeader查看配置 进行设置: https://github.com/OBKoro1/koro1FileHeader/wiki/%E9%85%8D%E7%BD%AE
|
||||||
|
*/
|
||||||
|
tinymce.PluginManager.add('indent2em', function(editor, url) {
|
||||||
|
var pluginName='首行缩进';
|
||||||
|
var global$1 = tinymce.util.Tools.resolve('tinymce.util.Tools');
|
||||||
|
var indent2em_val = editor.getParam('indent2em_val', '2em');
|
||||||
|
var doAct = function () {
|
||||||
|
var dom = editor.dom;
|
||||||
|
var blocks = editor.selection.getSelectedBlocks();
|
||||||
|
var act = '';
|
||||||
|
|
||||||
|
// console.log(editor.dom)
|
||||||
|
global$1.each(blocks, function (block) {
|
||||||
|
var flag=true
|
||||||
|
var children=block.children
|
||||||
|
//给块级元素加上font-size使em宽度为一个文字大小
|
||||||
|
if(children.length!=0&&children[0].style['font-size']){
|
||||||
|
block.style['font-size']=children[0].style['font-size']
|
||||||
|
}
|
||||||
|
// 如果块级元素里有图片不设置text-indent
|
||||||
|
while (children.length==1){
|
||||||
|
if(children[0].tagName=='IMG'){
|
||||||
|
flag=false
|
||||||
|
}
|
||||||
|
children=children[0].children
|
||||||
|
}
|
||||||
|
if(flag||blocks.length==1){
|
||||||
|
if(act==''){
|
||||||
|
act = dom.getStyle(block,'text-indent')==indent2em_val ? 'remove' : 'add';
|
||||||
|
}
|
||||||
|
if( act=='add' ){
|
||||||
|
dom.setStyle(block, 'text-indent', indent2em_val);
|
||||||
|
}else{
|
||||||
|
var style=dom.getAttrib(block,'style');
|
||||||
|
var reg = new RegExp('text-indent:[\\s]*' + indent2em_val + ';', 'ig');
|
||||||
|
style = style.replace(reg, '');
|
||||||
|
dom.setAttrib(block,'style',style);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
editor.ui.registry.getAll().icons.indent2em || editor.ui.registry.addIcon('indent2em','<svg viewBox="0 0 1024 1024" xmlns="http://www.w3.org/2000/svg" width="24" height="24"><path d="M170.666667 563.2v-102.4H887.466667v102.4zM170.666667 836.266667v-102.4H887.466667v102.4zM512 290.133333v-102.4H887.466667v102.4zM238.933333 341.333333V136.533333l204.8 102.4z" fill="#2c2c2c" p-id="5210"></path></svg>');
|
||||||
|
|
||||||
|
var stateSelectorAdapter = function (editor, selector) {
|
||||||
|
return function (buttonApi) {
|
||||||
|
return editor.selection.selectorChangedWithUnbind(selector.join(','), buttonApi.setActive).unbind;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
editor.ui.registry.addToggleButton('indent2em', {
|
||||||
|
icon: 'indent2em',
|
||||||
|
tooltip: pluginName,
|
||||||
|
onAction: function () {
|
||||||
|
doAct();
|
||||||
|
},
|
||||||
|
onSetup: stateSelectorAdapter(editor, [
|
||||||
|
'*[style*="text-indent"]',
|
||||||
|
'*[data-mce-style*="text-indent"]',
|
||||||
|
])
|
||||||
|
});
|
||||||
|
|
||||||
|
editor.ui.registry.addMenuItem('indent2em', {
|
||||||
|
text: pluginName,
|
||||||
|
onAction: function() {
|
||||||
|
doAct();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
editor.addCommand('indent2em', doAct );
|
||||||
|
|
||||||
|
return {
|
||||||
|
getMetadata: function () {
|
||||||
|
return {
|
||||||
|
name: pluginName,
|
||||||
|
url: "http://tinymce.ax-z.cn/more-plugins/indent2em.php",
|
||||||
|
};
|
||||||
|
}
|
||||||
|
};
|
||||||
|
});
|
|
@ -0,0 +1,7 @@
|
||||||
|
// Exports the "insertdatetime" plugin for usage with module loaders
|
||||||
|
// Usage:
|
||||||
|
// CommonJS:
|
||||||
|
// require('tinymce/plugins/insertdatetime')
|
||||||
|
// ES2015:
|
||||||
|
// import 'tinymce/plugins/insertdatetime'
|
||||||
|
require('./plugin.js');
|
|
@ -0,0 +1,179 @@
|
||||||
|
/**
|
||||||
|
* Copyright (c) Tiny Technologies, Inc. All rights reserved.
|
||||||
|
* Licensed under the LGPL or a commercial license.
|
||||||
|
* For LGPL see License.txt in the project root for license information.
|
||||||
|
* For commercial licenses see https://www.tiny.cloud/
|
||||||
|
*
|
||||||
|
* Version: 5.9.2 (2021-09-08)
|
||||||
|
*/
|
||||||
|
(function () {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
var global$1 = tinymce.util.Tools.resolve('tinymce.PluginManager');
|
||||||
|
|
||||||
|
var getDateFormat = function (editor) {
|
||||||
|
return editor.getParam('insertdatetime_dateformat', editor.translate('%Y-%m-%d'));
|
||||||
|
};
|
||||||
|
var getTimeFormat = function (editor) {
|
||||||
|
return editor.getParam('insertdatetime_timeformat', editor.translate('%H:%M:%S'));
|
||||||
|
};
|
||||||
|
var getFormats = function (editor) {
|
||||||
|
return editor.getParam('insertdatetime_formats', [
|
||||||
|
'%H:%M:%S',
|
||||||
|
'%Y-%m-%d',
|
||||||
|
'%I:%M:%S %p',
|
||||||
|
'%D'
|
||||||
|
]);
|
||||||
|
};
|
||||||
|
var getDefaultDateTime = function (editor) {
|
||||||
|
var formats = getFormats(editor);
|
||||||
|
return formats.length > 0 ? formats[0] : getTimeFormat(editor);
|
||||||
|
};
|
||||||
|
var shouldInsertTimeElement = function (editor) {
|
||||||
|
return editor.getParam('insertdatetime_element', false);
|
||||||
|
};
|
||||||
|
|
||||||
|
var daysShort = 'Sun Mon Tue Wed Thu Fri Sat Sun'.split(' ');
|
||||||
|
var daysLong = 'Sunday Monday Tuesday Wednesday Thursday Friday Saturday Sunday'.split(' ');
|
||||||
|
var monthsShort = 'Jan Feb Mar Apr May Jun Jul Aug Sep Oct Nov Dec'.split(' ');
|
||||||
|
var monthsLong = 'January February March April May June July August September October November December'.split(' ');
|
||||||
|
var addZeros = function (value, len) {
|
||||||
|
value = '' + value;
|
||||||
|
if (value.length < len) {
|
||||||
|
for (var i = 0; i < len - value.length; i++) {
|
||||||
|
value = '0' + value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return value;
|
||||||
|
};
|
||||||
|
var getDateTime = function (editor, fmt, date) {
|
||||||
|
if (date === void 0) {
|
||||||
|
date = new Date();
|
||||||
|
}
|
||||||
|
fmt = fmt.replace('%D', '%m/%d/%Y');
|
||||||
|
fmt = fmt.replace('%r', '%I:%M:%S %p');
|
||||||
|
fmt = fmt.replace('%Y', '' + date.getFullYear());
|
||||||
|
fmt = fmt.replace('%y', '' + date.getYear());
|
||||||
|
fmt = fmt.replace('%m', addZeros(date.getMonth() + 1, 2));
|
||||||
|
fmt = fmt.replace('%d', addZeros(date.getDate(), 2));
|
||||||
|
fmt = fmt.replace('%H', '' + addZeros(date.getHours(), 2));
|
||||||
|
fmt = fmt.replace('%M', '' + addZeros(date.getMinutes(), 2));
|
||||||
|
fmt = fmt.replace('%S', '' + addZeros(date.getSeconds(), 2));
|
||||||
|
fmt = fmt.replace('%I', '' + ((date.getHours() + 11) % 12 + 1));
|
||||||
|
fmt = fmt.replace('%p', '' + (date.getHours() < 12 ? 'AM' : 'PM'));
|
||||||
|
fmt = fmt.replace('%B', '' + editor.translate(monthsLong[date.getMonth()]));
|
||||||
|
fmt = fmt.replace('%b', '' + editor.translate(monthsShort[date.getMonth()]));
|
||||||
|
fmt = fmt.replace('%A', '' + editor.translate(daysLong[date.getDay()]));
|
||||||
|
fmt = fmt.replace('%a', '' + editor.translate(daysShort[date.getDay()]));
|
||||||
|
fmt = fmt.replace('%%', '%');
|
||||||
|
return fmt;
|
||||||
|
};
|
||||||
|
var updateElement = function (editor, timeElm, computerTime, userTime) {
|
||||||
|
var newTimeElm = editor.dom.create('time', { datetime: computerTime }, userTime);
|
||||||
|
timeElm.parentNode.insertBefore(newTimeElm, timeElm);
|
||||||
|
editor.dom.remove(timeElm);
|
||||||
|
editor.selection.select(newTimeElm, true);
|
||||||
|
editor.selection.collapse(false);
|
||||||
|
};
|
||||||
|
var insertDateTime = function (editor, format) {
|
||||||
|
if (shouldInsertTimeElement(editor)) {
|
||||||
|
var userTime = getDateTime(editor, format);
|
||||||
|
var computerTime = void 0;
|
||||||
|
if (/%[HMSIp]/.test(format)) {
|
||||||
|
computerTime = getDateTime(editor, '%Y-%m-%dT%H:%M');
|
||||||
|
} else {
|
||||||
|
computerTime = getDateTime(editor, '%Y-%m-%d');
|
||||||
|
}
|
||||||
|
var timeElm = editor.dom.getParent(editor.selection.getStart(), 'time');
|
||||||
|
if (timeElm) {
|
||||||
|
updateElement(editor, timeElm, computerTime, userTime);
|
||||||
|
} else {
|
||||||
|
editor.insertContent('<time datetime="' + computerTime + '">' + userTime + '</time>');
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
editor.insertContent(getDateTime(editor, format));
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
var register$1 = function (editor) {
|
||||||
|
editor.addCommand('mceInsertDate', function () {
|
||||||
|
insertDateTime(editor, getDateFormat(editor));
|
||||||
|
});
|
||||||
|
editor.addCommand('mceInsertTime', function () {
|
||||||
|
insertDateTime(editor, getTimeFormat(editor));
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
var Cell = function (initial) {
|
||||||
|
var value = initial;
|
||||||
|
var get = function () {
|
||||||
|
return value;
|
||||||
|
};
|
||||||
|
var set = function (v) {
|
||||||
|
value = v;
|
||||||
|
};
|
||||||
|
return {
|
||||||
|
get: get,
|
||||||
|
set: set
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
var global = tinymce.util.Tools.resolve('tinymce.util.Tools');
|
||||||
|
|
||||||
|
var register = function (editor) {
|
||||||
|
var formats = getFormats(editor);
|
||||||
|
var defaultFormat = Cell(getDefaultDateTime(editor));
|
||||||
|
editor.ui.registry.addSplitButton('insertdatetime', {
|
||||||
|
icon: 'insert-time',
|
||||||
|
tooltip: 'Insert date/time',
|
||||||
|
select: function (value) {
|
||||||
|
return value === defaultFormat.get();
|
||||||
|
},
|
||||||
|
fetch: function (done) {
|
||||||
|
done(global.map(formats, function (format) {
|
||||||
|
return {
|
||||||
|
type: 'choiceitem',
|
||||||
|
text: getDateTime(editor, format),
|
||||||
|
value: format
|
||||||
|
};
|
||||||
|
}));
|
||||||
|
},
|
||||||
|
onAction: function (_api) {
|
||||||
|
insertDateTime(editor, defaultFormat.get());
|
||||||
|
},
|
||||||
|
onItemAction: function (_api, value) {
|
||||||
|
defaultFormat.set(value);
|
||||||
|
insertDateTime(editor, value);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
var makeMenuItemHandler = function (format) {
|
||||||
|
return function () {
|
||||||
|
defaultFormat.set(format);
|
||||||
|
insertDateTime(editor, format);
|
||||||
|
};
|
||||||
|
};
|
||||||
|
editor.ui.registry.addNestedMenuItem('insertdatetime', {
|
||||||
|
icon: 'insert-time',
|
||||||
|
text: 'Date/time',
|
||||||
|
getSubmenuItems: function () {
|
||||||
|
return global.map(formats, function (format) {
|
||||||
|
return {
|
||||||
|
type: 'menuitem',
|
||||||
|
text: getDateTime(editor, format),
|
||||||
|
onAction: makeMenuItemHandler(format)
|
||||||
|
};
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
function Plugin () {
|
||||||
|
global$1.add('insertdatetime', function (editor) {
|
||||||
|
register$1(editor);
|
||||||
|
register(editor);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
Plugin();
|
||||||
|
|
||||||
|
}());
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue