diff --git a/.build_config/build.sh b/.build_config/build.sh new file mode 100644 index 000000000..836100dea --- /dev/null +++ b/.build_config/build.sh @@ -0,0 +1,14 @@ +if [ ! $version ]; +then npm version 0.1.0-`date "+%Y%m%d%H%M%S"`; +else npm version $version; +fi + +npm install + +if [ $? -ne 0 ] +then + echo "[ERROR] build falid!" + exit 1 +fi +echo '[INFO] build completed' + diff --git a/.cid/lowcode-design-core.yml b/.cid/lowcode-design-core.yml new file mode 100644 index 000000000..de9333bcb --- /dev/null +++ b/.cid/lowcode-design-core.yml @@ -0,0 +1,23 @@ +version: 1.0 +name: tiny-engine +language: nodejs + +# 构建工具 +dependencies: + base: + nodejs: best + +# 构建机器 +machine: + standard: + euler: + - default + +# 构建脚本 +scripts: + - sh ./.build_config/build.sh + +# 构建产物 +artifacts: + npm_deploy: + - config_path: ./package.json diff --git a/.codecheck/check.yml b/.codecheck/check.yml new file mode 100644 index 000000000..7ecb34223 --- /dev/null +++ b/.codecheck/check.yml @@ -0,0 +1,11 @@ +version: 2.0 + +steps: + pre_codecheck: + - checkout + +tool_params: + secsolar: + source_dir: ./ + cmetrics: + exclude: vite.config.js|package.json|index.js|mockServer/assets diff --git a/.env.local b/.env.local new file mode 100644 index 000000000..a361a78c8 --- /dev/null +++ b/.env.local @@ -0,0 +1,5 @@ +SQL_HOST=localhost +SQL_PORT=3306 +SQL_USER=root +SQL_PASSWORD=admin +SQL_DATABASE=tiny_engine \ No newline at end of file diff --git a/.eslintignore b/.eslintignore new file mode 100644 index 000000000..997d732c1 --- /dev/null +++ b/.eslintignore @@ -0,0 +1,9 @@ +.vscode +dist +public +package-lock.json +**/node_modules/** +tmp +temp +mockServer +packages/vue-generator/**/output/** diff --git a/.eslintrc.js b/.eslintrc.js new file mode 100644 index 000000000..9d1f4572d --- /dev/null +++ b/.eslintrc.js @@ -0,0 +1,31 @@ +module.exports = { + env: { + browser: true, + es2015: true, + worker: true, + node: true, + jest: true + }, + extends: ['eslint:recommended', 'plugin:vue/vue3-essential'], + parser: 'vue-eslint-parser', + parserOptions: { + parser: '@babel/eslint-parser', + ecmaVersion: 'latest', + sourceType: 'module', + requireConfigFile: false, + babelOptions: { + parserOpts: { + plugins: ['jsx'] + } + } + }, + plugins: ['vue'], + rules: { + 'no-console': 'error', + 'no-debugger': 'error', + 'space-before-function-paren': 'off', + 'vue/multi-word-component-names': 'off', + 'no-use-before-define': 'error', + 'no-unused-vars': ['error', { ignoreRestSiblings: true, varsIgnorePattern: '^_', argsIgnorePattern: '^_' }] + } +} diff --git a/.github/ISSUE_TEMPLATE/bug-report.yml b/.github/ISSUE_TEMPLATE/bug-report.yml new file mode 100644 index 000000000..b2afa9009 --- /dev/null +++ b/.github/ISSUE_TEMPLATE/bug-report.yml @@ -0,0 +1,81 @@ +name: '🐛 Bug report' +description: Create a report to help us improve Tiny Engine +title: '🐛 [Bug]: ' +labels: ['🐛 bug'] +body: + - type: markdown + attributes: + value: | + Please fill out the following carefully in order to better fix the problem. + - type: input + id: Environment + attributes: + label: Environment + description: | + **Depending on your browser and operating system, websites may behave differently from one environment to another. Make sure your developers know your technical environment.** + placeholder: Please browser information. + validations: + required: true + - type: input + id: node-version + attributes: + label: Version + description: | + ### **Check if the issue is reproducible with the latest stable version.** + You can use the command `node -v` to view it + placeholder: latest + validations: + required: true + - type: input + id: tiny-vue-version + attributes: + label: Version + description: | + ### **Check if the issue is reproducible with the latest stable version.** + You can use the command `npm ls @opentiny/vue` to view it + placeholder: latest + validations: + required: true + - type: textarea + id: minimal-repo + attributes: + label: Link to minimal reproduction + description: | + **Provide a streamlined CodePen / CodeSandbox or GitHub repository link as much as possible. Please don't fill in a link randomly, it will only close your issue directly.** + placeholder: Please Input + validations: + required: true + - type: textarea + id: reproduce + attributes: + label: Step to reproduce + description: | + **After the replay is turned on, what actions do we need to perform to make the bug appear? Simple and clear steps can help us locate the problem more quickly. Please clearly describe the steps of reproducing the issue. Issues without clear reproducing steps will not be repaired. If the issue marked with 'need reproduction' does not provide relevant steps within 7 days, it will be closed directly.** + placeholder: Please Input + validations: + required: true + - type: textarea + id: expected + attributes: + label: What is expected + placeholder: Please Input + - type: textarea + id: actually + attributes: + label: What is actually happening + placeholder: Please Input + - type: input + id: project-name + attributes: + label: What is your project name + description: We also welcome you to fill in more detailed project information in the following issue [#334](https://github.com/opentiny/tiny-engine/issues/334). + placeholder: Please Input + validations: + required: true + - type: textarea + id: additional-comments + attributes: + label: Any additional comments (optional) + description: | + **Some background / context of how you ran into this bug.** + placeholder: Please Input diff --git a/.github/ISSUE_TEMPLATE/config.yml b/.github/ISSUE_TEMPLATE/config.yml new file mode 100644 index 000000000..157e35cd3 --- /dev/null +++ b/.github/ISSUE_TEMPLATE/config.yml @@ -0,0 +1,5 @@ +blank_issues_enabled: true +contact_links: + - name: Questions or need help + url: https://github.com/opentiny/tiny-engine/discussions + about: Add this WeChat(opentiny-official), we will invite you to the WeChat discussion group later. diff --git a/.github/ISSUE_TEMPLATE/feature-request.yml b/.github/ISSUE_TEMPLATE/feature-request.yml new file mode 100644 index 000000000..d864f3dee --- /dev/null +++ b/.github/ISSUE_TEMPLATE/feature-request.yml @@ -0,0 +1,31 @@ +name: ✨ Feature Request +description: Propose new features to @opentiny/tiny-engine to improve it. +title: '✨ [Feature]: ' +labels: ['✨ feature'] +body: + - type: textarea + id: feature-solve + attributes: + label: What problem does this feature solve + description: | + Explain your use case, context, and rationale behind this feature request. More importantly, what is the end user experience you are trying to build that led to the need for this feature? + placeholder: Please Input + validations: + required: true + - type: textarea + id: feature-api + attributes: + label: What does the proposed API look like + description: | + Describe how you propose to solve the problem and provide code samples of how the API would work once implemented. Note that you can use Markdown to format your code blocks. + placeholder: Please Input + validations: + required: true + - type: input + id: project-name + attributes: + label: What is your project name + description: We also welcome you to fill in more detailed project information in the following issue [#334](https://github.com/opentiny/tiny-engine/issues/334). + placeholder: Please Input + validations: + required: true diff --git a/.github/PULL_REQUEST_TEMPLATE.md b/.github/PULL_REQUEST_TEMPLATE.md new file mode 100644 index 000000000..f4e2f220c --- /dev/null +++ b/.github/PULL_REQUEST_TEMPLATE.md @@ -0,0 +1,52 @@ +English | [简体中文](https://github.com/opentiny/tiny-engine/blob/develop/.github/PULL_REQUEST_TEMPLATE/PULL_REQUEST_TEMPLATE.zh-CN.md) + +# PR + +## PR Checklist + +Please check if your PR fulfills the following requirements: + +- [ ] The commit message follows our [Commit Message Guidelines](https://github.com/opentiny/tiny-engine/blob/develop/CONTRIBUTING.md) +- [ ] Tests for the changes have been added (for bug fixes / features) +- [ ] Docs have been added / updated (for bug fixes / features) +- [ ] Built its own designer, fully self-validated + +## PR Type + +What kind of change does this PR introduce? + + + +- [ ] Bugfix +- [ ] Feature +- [ ] Code style update (formatting, local variables) +- [ ] Refactoring (no functional changes, no api changes) +- [ ] Build related changes +- [ ] CI related changes +- [ ] Documentation content changes +- [ ] Other... Please describe: + +## Background and solution + + +### What is the current behavior? + + + +Issue Number: N/A + +### What is the new behavior? + + +## Does this PR introduce a breaking change? + +- [ ] Yes +- [ ] No + + + +## Other information diff --git a/.github/PULL_REQUEST_TEMPLATE/PULL_REQUEST_TEMPLATE.zh-CN.md b/.github/PULL_REQUEST_TEMPLATE/PULL_REQUEST_TEMPLATE.zh-CN.md new file mode 100644 index 000000000..6ceff4df4 --- /dev/null +++ b/.github/PULL_REQUEST_TEMPLATE/PULL_REQUEST_TEMPLATE.zh-CN.md @@ -0,0 +1,52 @@ +[English](https://github.com/opentiny/tiny-engine/blob/develop/.github/PULL_REQUEST_TEMPLATE.md) | 简体中文 + +# PR + +## PR Checklist + +请检查您的 PR 是否满足以下要求: + +- [ ] commit message遵循我们的[提交贡献指南](https://github.com/opentiny/tiny-engine/blob/develop/CONTRIBUTING.md) +- [ ] 添加了更改内容的测试用例(用于bugfix/功能) +- [ ] 文档已添加/更新(用于bugfix/功能) +- [ ] 是否构建了自己的设计器,经过了充分的自验证 + +## PR 类型 + +这个PR的类型是? + +- [ ] 日常 bug 修复 +- [ ] 新特性支持 +- [ ] 代码风格优化 +- [ ] 重构 +- [ ] 构建优化 +- [ ] 测试用例 +- [ ] 文档更新 +- [ ] 分支合并 +- [ ] 其他改动(请补充) + + +## 需求背景和解决方案 + + + + +Issue Number: N/A + +### 修改前 + + +### 修改后 + +## 此PR是否含有 breaking change? + +- [ ] 是 +- [ ] 否 + + + +## Other information diff --git a/.github/release.yml b/.github/release.yml new file mode 100644 index 000000000..274543b22 --- /dev/null +++ b/.github/release.yml @@ -0,0 +1,26 @@ +changelog: + exclude: + labels: + - ignore-for-release + authors: + - allcontributors[bot] + categories: + - title: Breaking Changes 🛠 + labels: + - Semver-Major + - breaking-change + - title: Exciting New Features 🎉 + labels: + - Semver-Minor + - feature + - enhancement + - title: Bug Fixes 🐛 + labels: + - Semver-Patch + - bug + - title: Other Changes + labels: + - documentation + - refactoring + - unit-test + - ci diff --git a/.github/workflows/ai-code-review.yml b/.github/workflows/ai-code-review.yml new file mode 100644 index 000000000..29777ff3f --- /dev/null +++ b/.github/workflows/ai-code-review.yml @@ -0,0 +1,23 @@ +name: AI Code Review + +permissions: + contents: read + pull-requests: write + +on: + pull_request: + types: [opened, reopened, synchronize] + +jobs: + review: + runs-on: ubuntu-latest + steps: + - uses: anc95/ChatGPT-CodeReview@main + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + OPENAI_API_KEY: ${{ secrets.OPENAI_API_KEY }} + LANGUAGE: Chinese + OPENAI_API_ENDPOINT: https://api.openai.com/v1 + MODEL: gpt-3.5-turbo + MAX_TOKENS: 4096 + MAX_PATCH_LENGTH: 10000 diff --git a/.github/workflows/issue-translator.yml b/.github/workflows/issue-translator.yml new file mode 100644 index 000000000..8b3397bf7 --- /dev/null +++ b/.github/workflows/issue-translator.yml @@ -0,0 +1,18 @@ +name: 'issue-translator' +on: + issue_comment: + types: [created] + issues: + types: [opened] + +jobs: + build: + runs-on: ubuntu-latest + steps: + - uses: usthe/issues-translate-action@v2.7 + with: + IS_MODIFY_TITLE: false + # 非必须,决定是否需要修改issue标题内容 + # 若是true,则机器人账户@Issues-translate-bot必须拥有修改此仓库issue权限。可以通过邀请@Issues-translate-bot加入仓库协作者实现。 + CUSTOM_BOT_NOTE: Bot detected the issue body's language is not English, translate it automatically. + # 非必须,自定义机器人翻译的前缀开始内容。 diff --git a/.github/workflows/push-check.yml b/.github/workflows/push-check.yml new file mode 100644 index 000000000..7f0d4ed41 --- /dev/null +++ b/.github/workflows/push-check.yml @@ -0,0 +1,36 @@ +name: Push And Create PR Check + +on: + push: + branches: [] + pull_request: + branches: [develop,main] + +jobs: + push-check: + runs-on: ubuntu-latest # windows-latest || macos-latest + + steps: + - uses: actions/checkout@v4 + - uses: actions/setup-node@v4 + with: + node-version: 16 + + - name: Install pnpm + run: npm i -g pnpm + + - name: Install dependencies + run: pnpm i + + - name: Get changed files + id: get_changed_files + uses: tj-actions/changed-files@v40 + with: + files: | + **.js + **.vue + **.jsx + - name: Run ESLint + run: npx eslint ${{steps.get_changed_files.outputs.all_changed_files}} + - name: Run Build + run: pnpm run build:plugin && pnpm run build:alpha diff --git a/.gitignore b/.gitignore new file mode 100644 index 000000000..3e3d94e59 --- /dev/null +++ b/.gitignore @@ -0,0 +1,28 @@ +.DS_Store +node_modules +dist/ +package-lock.json +yarn.lock +pnpm-lock.yaml +lerna-debug.log + +# local env files +.env.local +.env.*.local + +# Log files +npm-debug.log* +yarn-debug.log* +yarn-error.log* +pnpm-debug.log* + +# Editor directories and files +.idea +.vscode +*.suo +*.ntvs* +*.njsproj +*.sln +*.sw? +tmp +temp diff --git a/.husky/pre-commit b/.husky/pre-commit new file mode 100644 index 000000000..9179da3dd --- /dev/null +++ b/.husky/pre-commit @@ -0,0 +1,6 @@ +#!/usr/bin/env sh +. "$(dirname -- "$0")/_/husky.sh" + +# npm run lint +npx lint-staged -q + diff --git a/.npmignore b/.npmignore new file mode 100644 index 000000000..06d519d56 --- /dev/null +++ b/.npmignore @@ -0,0 +1,23 @@ +.build_config +.cid +.codecheck +.husky +.vscode +# 只忽略根目录的 dist 文件夹 +/dist +test +node_modules +.editorconfig +.eslintignore +.eslintrc.js +.prettierignore +.prettierrc +jsconfig.json +package-lock.json + +# 忽略可能存在的其它编辑器文件夹 +.idea + +/packages/design-core/public/mock/* +**/**/tmp +**/**/temp \ No newline at end of file diff --git a/.prettierignore b/.prettierignore new file mode 100644 index 000000000..2f118daef --- /dev/null +++ b/.prettierignore @@ -0,0 +1,3 @@ +dist +package-lock.json +**/node_modules/** \ No newline at end of file diff --git a/.prettierrc b/.prettierrc new file mode 100644 index 000000000..d2baaec51 --- /dev/null +++ b/.prettierrc @@ -0,0 +1,5 @@ +semi: false +singleQuote: true +printWidth: 120 +trailingComma: 'none' +endOfLine: 'auto' \ No newline at end of file diff --git a/CHANGELOG.md b/CHANGELOG.md new file mode 100644 index 000000000..3f29a6979 --- /dev/null +++ b/CHANGELOG.md @@ -0,0 +1,17 @@ +# 更新日志 + +## v1.0.0-alpha.0 + +`2023/09/25` + +### 📢 破坏性变更 + +无 + +### ✨ 新特性 + +- 首个版本提交 + +### 🐞 缺陷修复 + +无 diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md new file mode 100644 index 000000000..3070a8cce --- /dev/null +++ b/CONTRIBUTING.md @@ -0,0 +1,80 @@ +# Contributing + +We are glad that you are willing to contribute to the TinyEngine open source project. There are many forms of contribution. You can choose one or more of them based on your strengths and interests: + +- Report [new defect](https://github.com/opentiny/tiny-engine/issues/new?template=bug-report.yml). +- Provide more detailed information for the [existing defects](https://github.com/opentiny/tiny-engine/labels/bug), such as supplementary screenshots, more detailed reproduction steps, minimum reproducible demo links, etc. +- Submit Pull requests to fix typos in the document or make the document clearer and better. +- Add the official assistant WeChat `opentiny-official` and join the technical exchange group to participate in the discussion. + +When you personally use the TinyEngine component library and participate in many of the above contributions, as you become familiar with TinyEngine , you can try to do something more challenging, such as: + +- Fix the defect. You can start with [Good-first issue](https://github.com/opentiny/tiny-engine/labels/good%20first%20issue). +- Implementation of new features +- Complete unit tests. +- Translate documents +- Participate in code review. + +## Bug Reports + +If you encounter problems in the process of using TinyEngine components, you are welcome to submit Issue to us. Before submitting Issue, please read the relevant [official documentation](https://opentiny.design/tiny-engine) carefully to confirm whether this is a defect or an unimplemented function. + +If it is a defect, select [Bug report](https://github.com/opentiny/tiny-engine/issues/new?template=bug-report.yml) template when creating a new Issue. The title follows the format of `[toolkitName/pluginName/EngineCore] defect description`. For example: `[tiny-engine-toolbar-refresh] The refresh function cannot be used`. + +Issue that reports defects mainly needs to fill in the following information: + +- Version numbers of `tiny-engine` and `node`. +- The performance of the defect can be illustrated by screenshot, and if there is an error, the error message can be posted. +- Defect reproduction step, preferably with a minimum reproducible demo link. + +If it is a new feature, select [Feature request](https://github.com/opentiny/tiny-engine/issues/new?template=feature-request.yml) template. The title follows the format of `[toolkitName/pluginName/EngineCore] new feature description`. For example: `[tiny-engine-theme] New Blue Theme`. + +The following information is required for the Issue of the new feature: + +- What problems does this feature mainly solve for users? +- What is the api of this feature? + +## Pull Requests + +Before submitting pull request, please make sure that your submission is in line with the overall plan of TinyEngine. Generally, issues that marked as [bug](https://github.com/opentiny/tiny-engine/labels/bug) are encouraged to submit pull requests. If you are not sure, you can create a [Discussion](https://github.com/opentiny/tiny-engine/discussions) for discussion. + +Local startup steps: + +- Click the Fork button in the upper right corner of the [TinyEngine](https://github.com/opentiny/tiny-engine) code repository to fork the upstream warehouse to the personal warehouse. +- Clone personal warehouse to local +- Run `npm install` under the TinyEngine root directory to install node dependencies. +- Run `npm install` under the TinyEngine mockServer to install node dependencies +- Run `npm run serve` under the TinyEngine root directory, and then `run npm run dev` in the mockServer directory to start local development. + +```shell +# username indicates the user name. Replace it before running the command. +git clone git@github.com:username/tiny-engine.git +cd tiny-engine +git remote add upstream git@github.com:opentiny/tiny-engine.git +pnpm i + +# Start the project. +$ pnpm dev + +``` + +To submit a PR: + +- Create a new branch `git checkout -b username/feature1`. The name of the branch should be `username/feat-xxx` / `username/fix-xxx`. +- Local coding. +- Submit according to [Commit Message Format](https://www.conventionalcommits.org/zh-hans/v1.0.0/) specification. PR that do not conform to the submission specification will not be merged. +- Submit to remote repository: `git push origin branchName`. +- (Optional) Synchronize upstream repository dev branch latest code: `git pull upstream develop`. +- Open the [Pull requests](https://github.com/opentiny/tiny-engine/pulls) link of the TinyEngine code repository and click the New pull request button to submit the PR. +- Project Committer conducts Code Review and makes comments. +- The PR author adjusts the code according to the opinion. Please note that when a branch initiates PR, the subsequent commit will be synchronized automatically, and there is no need to resubmit the PR. +- Project administrator merges PR. + +The contribution process is over, thank you for your contribution! + +## Join the open source community + +If you are interested in our open source projects, please join our open source community in the following ways. + +- Add the official assistant WeChat: opentiny-official, join our technical exchange group +- Join the mailing list: opentiny@googlegroups.com diff --git a/CONTRIBUTING.zh-CN.md b/CONTRIBUTING.zh-CN.md new file mode 100644 index 000000000..6729ec585 --- /dev/null +++ b/CONTRIBUTING.zh-CN.md @@ -0,0 +1,79 @@ +# 贡献指南 + +很高兴你有意愿参与 TinyEngine 开源项目的贡献,参与贡献的形式有很多种,你可以根据自己的特长和兴趣选择其中的一个或多个: + +- 报告[新缺陷](https://github.com/opentiny/tiny-engine/issues/new?template=bug-report.yml) +- 为[已有缺陷](https://github.com/opentiny/tiny-engine/labels/bug)提供更详细的信息,比如补充截图、提供更详细的复现步骤、提供最小可复现 demo 链接等 +- 提交 Pull requests 修复文档中的错别字或让文档更清晰和完善 +- 添加官方小助手微信 opentiny-official,加入技术交流群参与讨论 + +当你亲自使用 TinyEngine 组件库,并参与多次以上形式的贡献,对 TinyEngine 逐渐熟悉之后,可以尝试做一些更有挑战的事情,比如: + +- 修复缺陷,可以先从 [Good-first issue](https://github.com/opentiny/tiny-engine/labels/good%20first%20issue) 开始 +- 实现新特性 +- 完善单元测试 +- 翻译文档 +- 参与代码检视 + +## 提交 Issue + +如果你在使用 TinyEngine 组件过程中遇到问题,欢迎给我们提交 Issue,提交 Issue 之前,请先仔细阅读相关的[官方文档](https://opentiny.design/tiny-engine),确认这是一个缺陷还是尚未实现的功能。 + +如果是一个缺陷,创建新 Issue 时选择 [Bug report](https://github.com/opentiny/tiny-engine/issues/new?template=bug-report.yml) 模板,标题遵循 `[toolkitName/pluginName/EngineCore]缺陷简述` 的格式,比如:`[tiny-engine-toolbar-refresh] 刷新功能无法使用`。 + +报告缺陷的 Issue 主要需要填写以下信息: + +- tiny-engine 和 node 的版本号 +- 缺陷的表现,可截图辅助说明,如果有报错可贴上报错信息 +- 缺陷的复现步骤,最好能提供一个最小可复现 demo 链接 + +如果是一个新特性,则选择 [Feature request](https://github.com/opentiny/tiny-engine/issues/new?template=feature-request.yml) 模板,标题遵循 `[toolkitName/pluginName/EngineCore]新特性简述` 的格式,比如:`[tiny-engine-theme] 新增蓝色主题`。 + +新特性的 Issue 主要需要填写以下信息: + +- 该特性主要解决用户的什么问题 +- 该特性的 api 是什么样的 + +## 提交 PR + +提交 PR 之前,请先确保你提交的内容是符合 TinyEngine 整体规划的,一般已经标记为 [bug](https://github.com/opentiny/tiny-engine/labels/bug) 的 Issue 是鼓励提交 PR 的,如果你不是很确定,可以创建一个 [Discussion](https://github.com/opentiny/tiny-engine/discussions) 进行讨论。 + +本地启动步骤: + +- 点击 [TinyEngine](https://github.com/opentiny/tiny-engine) 代码仓库右上角的 Fork 按钮,将上游仓库 Fork 到个人仓库 +- Clone 个人仓库到本地 +- 在 TinyEngine 根目录下运行 `pnpm i`, 安装依赖 +- 在 TinyEngine 根目录下运行 `pnpm dev`,启动本地开发 + +```shell +# username 为用户名,执行前请替换 +git clone git@github.com:username/tiny-engine.git +cd tiny-engine +git remote add upstream git@github.com:opentiny/tiny-engine.git +pnpm i + +# 启动项目 +$ pnpm dev + +``` + +提交 PR 的步骤: + +- 创建新分支 `git checkout -b username/feature1`,分支名字建议为 `username/feat-xxx` / `username/fix-xxx` +- 本地编码 +- 遵循 Commit Message Format 规范进行提交,不符合提交规范的 PR 将不会被合并 +- 提交到远程仓库:git push origin branchName +- (可选)同步上游仓库 develop 分支最新代码:git pull upstream develop +- 打开 TinyEngine 代码仓库的 [Pull requests](https://github.com/opentiny/tiny-engine/pulls) 链接,点击 New pull request 按钮提交 PR +- 项目 Committer 进行 Code Review,并提出意见 +- PR 作者根据意见调整代码,请注意一个分支发起了 PR 后,后续的 commit 会自动同步,无需重新提交 PR +- 项目管理员合并 PR + +贡献流程结束,感谢你的贡献! + +## 加入开源社区 + +如果你对我们的开源项目感兴趣,欢迎通过以下方式加入我们的开源社区。 + +- 添加官方小助手微信:opentiny-official,加入我们的技术交流群 +- 加入邮件列表:opentiny@googlegroups.com \ No newline at end of file diff --git a/LICENSE b/LICENSE new file mode 100644 index 000000000..91221a793 --- /dev/null +++ b/LICENSE @@ -0,0 +1,22 @@ +MIT License + +Copyright (c) 2023 - present TinyEngine Authors. +Copyright (c) 2023 - present Huawei Cloud Computing Technologies Co., Ltd. + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/README.md b/README.md index 19869b476..57af470d1 100644 --- a/README.md +++ b/README.md @@ -1,2 +1,108 @@ -# lowcode-design-core +
+ + + +
+TinyEngine enables developers to customize low-code platforms, build low-bit platforms online in real time, and support secondary development or integration of low-bit platform capabilities.
+ +English | [简体中文](README.zh-CN.md) + +🌈 Features: + +- Cross-end cross-frame front-end components +- Supports online real-time construction, secondary development, or being integrated. +- Directly generate deployable source code without engine support. +- Allows access to third-party components and customized extension plug-ins. +- Supports high-code and low-code, and hybrid development and deployment of applications. +- The platform accesses AI big model capabilities to help developers build applications. + +## Documentation + +- intro:https://opentiny.design/tiny-engine#/home +- tutorial:https://opentiny.design/tiny-engine#/help-center/course/engine +- playground:https://opentiny.design/tiny-engine#/tiny-engine-editor + +## Development + +### Dependencies required for installation + +```sh +$ pnpm install +``` + +### Local development: Start the local mock server and use the mock data of the local mock server. + +```sh +$ pnpm dev +``` + +## Local development, directly connected to the local tiny-engine-webservice server + +1. Start tiny-engine-data-center + +2. Start tiny-engine-webservice + +3. Modify the origin value in `vite.config.js` in the `packages/design-core/` directory of the tiny-engine project to be the address port of your local webService project (the webService port defaults to 7011), such as: + + + + +### Materials Synchronization [Solution](https://opentiny.design/tiny-engine#/help-center/course/engine/56) + +```sh +$ pnpm splitMaterials +``` + +```sh +$ pnpm buildMaterials +``` + +Open a browser: `http://localhost:8080/?type=app&id=918&tenant=1&pageid=NTJ4MjvqoVj8OVsc` +`url search` Parameters: + +- `type=app` Application type +- `id=xxx` Application ID +- `tenant=xxx` Organization ID +- `pageid=xxx` Page ID + +## Build + +```sh +# Build all plug-ins first +pnpm build:plugin + +# Build Designer +pnpm build:alpha or build:prod + +``` +The folder where the product is located after building +``` + tiny-engine/packages/design-core/dist/ +``` + +## Milestones + +```mermaid +gantt +dateFormat YYYY-MM-DD +axisFormat %Y-%m-%d + + 1.0.0-beta.x version :active,2023-09-25, 2024-03-31 + 1.0.0-rc version : 2024-04-01, 2024-06-30 + 1.0.0 version : 2024-07-01, 2024-07-31 + +``` + +## 🤝 Participation and Contribution + +If you are interested in our open source project, please join us! 🎉 + +Please read the [Contribution Guide](CONTRIBUTING.md) before participating in the contribution. + +- Add official assistant WeChat opentiny-official and join the technical exchange group +- Join the mailing list opentiny@googlegroups.com + +## License + +[MIT](LICENSE) diff --git a/README.zh-CN.md b/README.zh-CN.md new file mode 100644 index 000000000..747f286c8 --- /dev/null +++ b/README.zh-CN.md @@ -0,0 +1,108 @@ ++ + + +
+ +TinyEngine低代码引擎使能开发者定制低代码平台,支持在线实时构建低码平台,支持二次开发或集成低码平台能力
+ +[English](README.md) | 简体中文 + +🌈 特性: + +- 跨端跨框架前端组件 +- 支持在线实时构建、支持二次开发或被集成 +- 直接生成可部署的源码,运行时无需引擎支撑 +- 允许接入第三方组件、允许定制扩展插件 +- 支持高代码与低代码,混合开发部署应用 +- 平台接入 AI 大模型能力,辅助开发者构建应用 + +## 文档 + +- 介绍:https://opentiny.design/tiny-engine#/home +- 使用文档:https://opentiny.design/tiny-engine#/help-center/course/engine +- 演示应用:https://opentiny.design/tiny-engine#/tiny-engine-editor + +## 开发 + +### 安装所需的依赖 + +```sh +$ pnpm install +``` + +### 本地开发,启动本地 mock 服务器,使用本地 mock 服务器的 mock 数据 + +```sh +$ pnpm dev +``` + +### 本地开发,直连本地的tiny-engine-webservice服务端 + +1. 启动 tiny-engine-data-center + +2. 启动 tiny-engine-webservice + +3. 修改 tiny-engine 项目 `packages/design-core/` 目录下 `vite.config.js` 中origin的值为自己本地webService项目的地址端口(webService端口默认为7011),如: + + + + +### 物料同步[方案](https://opentiny.design/tiny-engine#/help-center/course/engine/56) + +```sh +$ pnpm splitMaterials +``` + +```sh +$ pnpm buildMaterials +``` + +浏览器打开:`http://localhost:8080/?type=app&id=918&tenant=1&pageid=NTJ4MjvqoVj8OVsc` +`url search`参数: + +- `type=app` 应用类型 +- `id=xxx` 应用 ID +- `tenant=xxx` 组织 ID +- `pageid=xxx` 页面 ID + +## 构建 + +```sh +# 先构建所有插件 +pnpm run build:plugin + +# 构建设计器 +pnpm run build:alpha 或 build:prod + +``` +构建后产物所在文件夹 +``` + tiny-engine/packages/design-core/dist/ +``` + +## 里程碑 + +```mermaid +gantt +dateFormat YYYY-MM-DD +axisFormat %Y-%m-%d + + 1.0.0-beta.x version :active,2023-09-25, 2024-03-31 + 1.0.0-rc version : 2024-04-01, 2024-06-30 + 1.0.0 version : 2024-07-01, 2024-07-31 + +``` + +## 🤝 参与贡献 + +如果你对我们的开源项目感兴趣,欢迎加入我们!🎉 + +参与贡献之前请先阅读[贡献指南](CONTRIBUTING.zh-CN.md)。 + +- 添加官方小助手微信 opentiny-official,加入技术交流群 +- 加入邮件列表 opentiny@googlegroups.com + +## 开源协议 + +[MIT](LICENSE) diff --git a/jsconfig.json b/jsconfig.json new file mode 100644 index 000000000..c366326a1 --- /dev/null +++ b/jsconfig.json @@ -0,0 +1,73 @@ +{ + "compilerOptions": { + "baseUrl": "./", + "jsx": "react", + "paths": { + "@/*": ["packages/*"], + "@opentiny/tiny-engine-canvas": ["packages/canvas/src/index.js"], + "@opentiny/tiny-engine-controller": ["packages/controller/src/index"], + "@opentiny/tiny-engine-plugin-materials": ["packages/plugins/materials/index"], + "@opentiny/tiny-engine-plugin-data": ["packages/plugins/data/index"], + "@opentiny/tiny-engine-plugin-script": ["packages/plugins/script/index"], + "@opentiny/tiny-engine-plugin-tree": ["packages/plugins/tree/index"], + "@opentiny/tiny-engine-plugin-help": ["packages/plugins/help/index"], + "@opentiny/tiny-engine-plugin-schema": ["packages/plugins/schema/index"], + "@opentiny/tiny-engine-plugin-page": ["packages/plugins/page/index"], + "@opentiny/tiny-engine-plugin-i18n": ["packages/plugins/i18n/index"], + "@opentiny/tiny-engine-plugin-bridge": ["packages/plugins/bridge/index"], + "@opentiny/tiny-engine-setting-events": ["packages/settings/events/index"], + "@opentiny/tiny-engine-setting-props": ["packages/settings/props/index"], + "@opentiny/tiny-engine-common": ["packages/common/index"], + "@opentiny/tiny-engine-setting-styles": ["packages/settings/styles/index"], + "@opentiny/tiny-engine-toolbar-breadcrumb": ["packages/toolbars/breadcrumb/index"], + "@opentiny/tiny-engine-toolbar-fullscreen": ["packages/toolbars/fullscreen/index"], + "@opentiny/tiny-engine-toolbar-lang": ["packages/toolbars/lang/index"], + "@opentiny/tiny-engine-toolbar-layout": ["packages/toolbars/layout/index"], + "@opentiny/tiny-engine-toolbar-checkinout": ["packages/toolbars/lock/index"], + "@opentiny/tiny-engine-toolbar-logo": ["packages/toolbars/logo/index"], + "@opentiny/tiny-engine-toolbar-media": ["packages/toolbars/media/index"], + "@opentiny/tiny-engine-toolbar-preview": ["packages/toolbars/preview/index"], + "@opentiny/tiny-engine-toolbar-generate-vue": ["packages/toolbars/generate-vue/index"], + "@opentiny/tiny-engine-toolbar-clean": ["packages/toolbars/clean/index"], + "@opentiny/tiny-engine-toolbar-save": ["packages/toolbars/save/index"], + "tiny-engine-canvas": ["packages/canvas/index"], + "@opentiny/tiny-engine-theme-dark": ["packages/theme/dark/index.less"], + "@opentiny/tiny-engine-theme-light": ["packages/theme/light/index.less"], + "@opentiny/tiny-engine-svgs": ["packages/svgs/index"], + "@opentiny/tiny-engine-http": ["packages/http/index"], + "@opentiny/tiny-engine-controller/*": ["packages/controller/src/*"], + "@opentiny/tiny-engine-plugin-materials/*": ["packages/plugins/materials/*"], + "@opentiny/tiny-engine-plugin-data/*": ["packages/plugins/data/*"], + "@opentiny/tiny-engine-plugin-script/*": ["packages/plugins/script/*"], + "@opentiny/tiny-engine-plugin-tree/*": ["packages/plugins/tree/*"], + "@opentiny/tiny-engine-plugin-help/*": ["packages/plugins/help/*"], + "@opentiny/tiny-engine-plugin-schema/*": ["packages/plugins/schema/*"], + "@opentiny/tiny-engine-plugin-page/*": ["packages/plugins/page/*"], + "@opentiny/tiny-engine-plugin-i18n/*": ["packages/plugins/i18n/*"], + "@opentiny/tiny-engine-plugin-bridge/*": ["packages/plugins/bridge/*"], + "@opentiny/tiny-engine-setting-events/*": ["packages/settings/events/*"], + "@opentiny/tiny-engine-setting-props/*": ["packages/settings/props/*"], + "@opentiny/tiny-engine-common/*": ["packages/common/*"], + "@opentiny/tiny-engine-setting-styles/*": ["packages/settings/styles/*"], + "@opentiny/tiny-engine-toolbar-breadcrumb/*": ["packages/toolbars/breadcrumb/*"], + "@opentiny/tiny-engine-toolbar-fullscreen/*": ["packages/toolbars/fullscreen/*"], + "@opentiny/tiny-engine-toolbar-lang/*": ["packages/toolbars/lang/*"], + "@opentiny/tiny-engine-toolbar-layout/*": ["packages/toolbars/layout/*"], + "@opentiny/tiny-engine-toolbar-checkinout/*": ["packages/toolbars/lock/*"], + "@opentiny/tiny-engine-toolbar-logo/*": ["packages/toolbars/logo/*"], + "@opentiny/tiny-engine-toolbar-media/*": ["packages/toolbars/media/*"], + "@opentiny/tiny-engine-toolbar-preview/*": ["packages/toolbars/preview/*"], + "@opentiny/tiny-engine-toolbar-clean/*": ["packages/toolbars/clean/*"], + "@opentiny/tiny-engine-toolbar-save/*": ["packages/toolbars/save/*"], + "@opentiny/tiny-engine-theme-dark/*": ["packages/theme/dark/*"], + "@opentiny/tiny-engine-theme-light/*": ["packages/theme/light/*"], + "@opentiny/tiny-engine-svgs/*": ["packages/svgs/*"], + "@opentiny/tiny-engine-http/*": ["packages/http/*"], + "@opentiny/tiny-engine-utils": ["packages/utils/src/index.js"], + "@opentiny/tiny-engine-webcomponent-core": ["packages/webcomponent/src/lib"], + "@opentiny/tiny-engine-i18n-host": ["packages/i18n/src/lib"] + } + }, + "include": ["packages/**/*"], + "exclude": ["node_modules", "dist"] +} diff --git a/lerna.json b/lerna.json new file mode 100644 index 000000000..74c0687b9 --- /dev/null +++ b/lerna.json @@ -0,0 +1,15 @@ +{ + "command": { + "version": { + "message": "chore(release): publish" + } + }, + "useNx": false, + "version": "independent", + "npmClient": "pnpm", + "publish": { + "npmClient": "pnpm" + }, + "ignoreChanges": ["**/*.md", "**/test/**", ".npmrc"], + "granularPathspec": false +} diff --git a/lint-staged.config.js b/lint-staged.config.js new file mode 100644 index 000000000..d673344c2 --- /dev/null +++ b/lint-staged.config.js @@ -0,0 +1,4 @@ +module.exports = { + './packages/**/**.{js,vue,jsx}': 'eslint', + './packages/**/**.{vue,js,ts,html,json,less}': 'prettier --write' +} diff --git a/logo.svg b/logo.svg new file mode 100644 index 000000000..59d1b063b --- /dev/null +++ b/logo.svg @@ -0,0 +1,44 @@ + + \ No newline at end of file diff --git a/mockServer/.babelrc b/mockServer/.babelrc new file mode 100644 index 000000000..f9f35a2e6 --- /dev/null +++ b/mockServer/.babelrc @@ -0,0 +1,21 @@ +{ + "presets": [ + ["@babel/preset-env", { + "targets": { + "node": "current" + } + }] + ], + "env": { + "test": { + "presets": [ + ["@babel/preset-env", { + "targets": { + "node": "current" + } + }] + ] + } + }, + "plugins": ["@babel/plugin-transform-runtime"] +} \ No newline at end of file diff --git a/mockServer/.editorconfig b/mockServer/.editorconfig new file mode 100644 index 000000000..9d08a1a82 --- /dev/null +++ b/mockServer/.editorconfig @@ -0,0 +1,9 @@ +root = true + +[*] +charset = utf-8 +indent_style = space +indent_size = 2 +end_of_line = lf +insert_final_newline = true +trim_trailing_whitespace = true diff --git a/mockServer/.eslintignore b/mockServer/.eslintignore new file mode 100644 index 000000000..e59172bdf --- /dev/null +++ b/mockServer/.eslintignore @@ -0,0 +1,3 @@ +build/*.js +assets/*.js +test/**/*.js \ No newline at end of file diff --git a/mockServer/.eslintrc.js b/mockServer/.eslintrc.js new file mode 100644 index 000000000..997ea0e78 --- /dev/null +++ b/mockServer/.eslintrc.js @@ -0,0 +1,36 @@ +/** +* Copyright (c) 2023 - present TinyEngine Authors. +* Copyright (c) 2023 - present Huawei Cloud Computing Technologies Co., Ltd. +* +* Use of this source code is governed by an MIT-style license. +* +* THE OPEN SOURCE SOFTWARE IN THIS PRODUCT IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, +* BUT WITHOUT ANY WARRANTY, WITHOUT EVEN THE IMPLIED WARRANTY OF MERCHANTABILITY OR FITNESS FOR +* A PARTICULAR PURPOSE. SEE THE APPLICABLE LICENSES FOR MORE DETAILS. +* +*/ + +module.exports = { + root: true, + parserOptions: { + parser: 'babel-eslint', + ecmaVersion: 2017, //指定ECMAScript支持的版本,6为ES6,这里为了兼容async和await,设置为2017 + sourceType: 'module' + }, + extends: 'standard', + plugins: ['html', 'promise'], + env: { + node: true + }, + rules: { + // allow console + 'no-console': 0, + // allow paren-less arrow functions + 'arrow-parens': 0, + // allow async-await + 'generator-star-spacing': 0, + // allow debugger during development + 'no-debugger': 0, + camelcase: 'off' + } +} diff --git a/mockServer/.gitignore b/mockServer/.gitignore new file mode 100644 index 000000000..89e660912 --- /dev/null +++ b/mockServer/.gitignore @@ -0,0 +1,9 @@ +.DS_Store +node_modules/ +dist/ +npm-debug.log +test/unit/coverage +test/e2e/reports +selenium-debug.log +.idea/ +package-lock.json \ No newline at end of file diff --git a/mockServer/.jsbeautifyrc b/mockServer/.jsbeautifyrc new file mode 100644 index 000000000..f4b0e8c71 --- /dev/null +++ b/mockServer/.jsbeautifyrc @@ -0,0 +1,11 @@ +{ + "indent_size": 2, + "indent_char": " ", + "other": " ", + "indent_level": 0, + "indent_with_tabs": false, + "preserve_newlines": true, + "max_preserve_newlines": 2, + "jslint_happy": true, + "indent_handlebars": true +} diff --git a/mockServer/assets/css/0.1.20/index.css b/mockServer/assets/css/0.1.20/index.css new file mode 100644 index 000000000..9a0397a1b --- /dev/null +++ b/mockServer/assets/css/0.1.20/index.css @@ -0,0 +1,24981 @@ +[class*='tiny-'] { + -webkit-box-sizing: border-box; + box-sizing: border-box; +} +[class*='tiny-'] :after, +[class*='tiny-'] :before { + -webkit-box-sizing: border-box; + box-sizing: border-box; +} +[class*='tiny-'] a { + cursor: pointer; + background-image: none; + text-decoration: none; + outline: 0; +} +[class*='tiny-'] a:active, +[class*='tiny-'] a:focus, +[class*='tiny-'] a:hover { + outline: 0; + text-decoration: none; +} +[class*='tiny-'] dd, +[class*='tiny-'] dl, +[class*='tiny-'] dt, +[class*='tiny-'] li, +[class*='tiny-'] ol, +[class*='tiny-'] td, +[class*='tiny-'] th, +[class*='tiny-'] ul { + margin: 0; + padding: 0; +} +[class*='tiny-'] ol, +[class*='tiny-'] ul { + list-style: none; +} +[class*='tiny-'] audio, +[class*='tiny-'] canvas, +[class*='tiny-'] video { + display: inline-block; +} +[class*='tiny-'] audio:not([controls]) { + display: none; + height: 0; +} +[class*='tiny-'] mark { + background: #ff0; + color: #000; +} +[class*='tiny-'] pre { + white-space: pre-wrap; +} +[class*='tiny-'] sub, +[class*='tiny-'] sup { + font-size: 75%; + line-height: 0; + position: relative; + vertical-align: baseline; +} +[class*='tiny-'] sup { + top: -0.5em; +} +[class*='tiny-'] sub { + bottom: -0.25em; +} +[class*='tiny-'] fieldset { + border: 1px solid silver; + margin: 0 2px; + padding: 0.35em 0.625em 0.75em; +} +[class*='tiny-'] legend { + border: 0; + padding: 0; +} +[class*='tiny-'] input::-ms-clear, +[class*='tiny-'] input::-ms-reveal { + display: none; +} +[class*='tiny-'] button::-moz-focus-inner, +[class*='tiny-'] input::-moz-focus-inner { + border: 0; + padding: 0; +} +[class*='tiny-'] textarea { + overflow: auto; + vertical-align: top; +} +[class*='tiny-'] table { + border-collapse: collapse; + border-spacing: 0; +} +[class*='tiny-'] .tiny-hide { + display: none; +} +[class*='tiny-'] .popper__arrow, +[class*='tiny-'] .popper__arrow:after { + position: absolute; + display: block; + width: 0; + height: 0; + border-color: transparent; + border-style: solid; +} +@media (min-width: 768px) { + [class*='tiny-'] ::-webkit-scrollbar { + width: 4px; + height: 4px; + } + [class*='tiny-'] ::-webkit-scrollbar-track-piece { + background: #fafafa; + } + [class*='tiny-'] ::-webkit-scrollbar-thumb { + background: #bfbfbf; + border-radius: 6px; + } + [class*='tiny-'] ::-webkit-scrollbar-thumb:hover { + background: #999; + } + [class*='tiny-'] ::-webkit-scrollbar-thumb:active { + background: #999; + } + [class*='tiny-'] .tiny-scrollbar::-webkit-scrollbar { + width: 8px; + height: 8px; + } + [class*='tiny-'] .tiny-scrollbar::-webkit-scrollbar-track-piece { + background: 0 0; + border: 0; + } + [class*='tiny-'] .tiny-scrollbar::-webkit-scrollbar-thumb { + background: #bfbfbf; + border-radius: 4px; + } + [class*='tiny-'] .tiny-scrollbar::-webkit-scrollbar-thumb:hover { + background: #999; + } + [class*='tiny-'] .tiny-scrollbar::-webkit-scrollbar-thumb:active { + background: #999; + } + [class*='tiny-'] .tiny-min-scrollbar::-webkit-scrollbar { + width: 4px; + height: 4px; + } + [class*='tiny-'] .tiny-min-scrollbar::-webkit-scrollbar-track-piece { + background: 0 0; + border: 0; + } + [class*='tiny-'] .tiny-min-scrollbar::-webkit-scrollbar-thumb { + background: #bfbfbf; + border-radius: 2px; + } + [class*='tiny-'] .tiny-min-scrollbar::-webkit-scrollbar-thumb:hover { + background: #999; + } + [class*='tiny-'] .tiny-min-scrollbar::-webkit-scrollbar-thumb:active { + background: #999; + } +} +:root { + --ti-base-color-white: #fff; + --ti-base-color-brand-6: #5e7ce0; + --ti-base-color-brand-8: #344899; + --ti-base-color-brand-7: #526ecc; + --ti-base-color-brand-5: #7693f5; + --ti-base-color-brand-4: #96adfa; + --ti-base-color-brand-3: #beccfa; + --ti-base-color-brand-2: #e9edfa; + --ti-base-color-brand-1: #f2f5fc; + --ti-base-color-common-9: #181818; + --ti-base-color-common-8: #282b33; + --ti-base-color-common-7: #252b3a; + --ti-base-color-common-6: #464c59; + --ti-base-color-common-5: #575d6c; + --ti-base-color-common-4: #5c6173; + --ti-base-color-common-3: #8a8e99; + --ti-base-color-common-2: #adb0b8; + --ti-base-color-common-1: #dfe1e6; + --ti-base-color-bg-9: #b12220; + --ti-base-color-bg-8: #c7000b; + --ti-base-color-bg-7: #d64a52; + --ti-base-color-bg-6: #eef0f5; + --ti-base-color-bg-5: #f5f5f6; + --ti-base-color-bg-4: #fafafa; + --ti-base-color-bg-3: #ffffff; + --ti-base-color-bg-2: #ffffff; + --ti-base-color-bg-1: #ffffff; + --ti-base-color-error-4: #de504e; + --ti-base-color-error-3: #f66f6a; + --ti-base-color-error-2: #ffbcba; + --ti-base-color-error-1: #ffeeed; + --ti-base-color-success-4: #3ac295; + --ti-base-color-success-3: #50d4ab; + --ti-base-color-success-2: #acf2dc; + --ti-base-color-success-1: #edfff9; + --ti-base-color-warn-5: #e37d29; + --ti-base-color-warn-4: #fa9841; + --ti-base-color-warn-3: #fac20a; + --ti-base-color-warn-2: #ffd0a6; + --ti-base-color-warn-1: #fff3e8; + --ti-base-color-prompt-4: var(--ti-base-color-brand-7); + --ti-base-color-prompt-3: var(--ti-base-color-brand-6); + --ti-base-color-prompt-2: var(--ti-base-color-brand-3); + --ti-base-color-prompt-1: #ebf6ff; + --ti-base-color-prompt-icon-from: #7769e8; + --ti-base-color-prompt-icon-to: #58bbff; + --ti-base-color-icon-info: #6cbfff; + --ti-base-color-data-3: #a6dd82; + --ti-base-color-data-4: #f3689a; + --ti-base-color-data-5: #a97af8; + --ti-base-color-transparent: transparent; + --ti-common-color-success: var(--ti-base-color-success-3); + --ti-common-color-text-success: var(--ti-base-color-success-4); + --ti-common-color-success-bg: var(--ti-base-color-success-1); + --ti-common-color-success-border: var(--ti-base-color-success-2); + --ti-common-color-error: var(--ti-base-color-error-3); + --ti-common-color-error-text: var(--ti-base-color-error-4); + --ti-common-color-error-bg: var(--ti-base-color-error-1); + --ti-common-color-error-border: var(--ti-base-color-error-3); + --ti-common-color-error-border-secondary: var(--ti-base-color-error-2); + --ti-common-color-info: var(--ti-base-color-info-normal); + --ti-common-color-info-text: var(--ti-base-color-common-7); + --ti-common-color-info-bg: rgba(51, 51, 51, 0.06); + --ti-common-color-info-border: #d3d4d6; + --ti-common-color-warn: var(--ti-base-color-warn-4); + --ti-common-color-warn-text: var(--ti-base-color-warn-5); + --ti-common-color-warn-bg: var(--ti-base-color-warn-1); + --ti-common-color-warn-border: var(--ti-base-color-warn-2); + --ti-common-color-warn-secondary: var(--ti-base-color-warn-3); + --ti-common-color-prompt: var(--ti-base-color-prompt-3); + --ti-common-color-prompt-text: var(--ti-base-color-prompt-4); + --ti-common-color-prompt-bg: var(--ti-base-color-prompt-1); + --ti-common-color-prompt-border: var(--ti-base-color-prompt-2); + --ti-common-color-prompt-icon-from: var(--ti-base-color-prompt-icon-from); + --ti-common-color-prompt-icon-to: var(--ti-base-color-prompt-icon-to); + --ti-common-color-text-primary: var(--ti-base-color-common-7); + --ti-common-color-text-secondary: var(--ti-base-color-common-5); + --ti-common-color-text-weaken: var(--ti-base-color-common-3); + --ti-common-color-text-disabled: var(--ti-base-color-common-2); + --ti-common-color-text-darkbg: var(--ti-base-color-common-2); + --ti-common-color-text-darkbg-disabled: var(--ti-base-color-common-5); + --ti-common-color-text-link: var(--ti-base-color-brand-7); + --ti-common-color-text-link-hover: var(--ti-base-color-brand-8); + --ti-common-color-text-link-darkbg: var(--ti-base-color-brand-4); + --ti-common-color-text-link-darkbg-hover: var(--ti-base-color-brand-3); + --ti-common-color-text-highlight: var(--ti-base-color-brand-7); + --ti-common-color-text-white: var(--ti-base-color-white); + --ti-common-color-text-gray: var(--ti-base-color-white); + --ti-common-color-text-gray-disabled: var(--ti-base-color-common-4); + --ti-common-color-text-important: var(--ti-base-color-error-4); + --ti-common-color-icon-normal: var(--ti-base-color-common-5); + --ti-common-color-icon-hover: var(--ti-base-color-brand-6); + --ti-common-color-icon-active: var(--ti-base-color-brand-6); + --ti-common-color-icon-disabled: var(--ti-base-color-common-2); + --ti-common-color-icon-white: var(--ti-base-color-white); + --ti-common-color-icon-graybg-normal: var(--ti-base-color-common-2); + --ti-common-color-icon-graybg-hover: var(--ti-base-color-brand-6); + --ti-common-color-icon-graybg-active: var(--ti-base-color-brand-6); + --ti-common-color-icon-graybg-disabled: var(--ti-base-color-common-1); + --ti-common-color-icon-darkbg-normal: var(--ti-base-color-common-2); + --ti-common-color-icon-darkbg-hover: var(--ti-base-color-brand-5); + --ti-common-color-icon-darkbg-active: var(--ti-base-color-brand-5); + --ti-common-color-icon-darkbg-disabled: var(--ti-base-color-common-5); + --ti-common-color-icon-info: var(--ti-base-color-icon-info); + --ti-common-color-line-normal: var(--ti-base-color-common-2); + --ti-common-color-line-hover: var(--ti-base-color-common-5); + --ti-common-color-line-active: var(--ti-base-color-brand-6); + --ti-common-color-line-disabled: var(--ti-base-color-common-1); + --ti-common-color-line-dividing: var(--ti-base-color-common-1); + --ti-common-color-dash-line-normal: var(--ti-base-color-common-5); + --ti-common-color-dash-line-hover: var(--ti-base-color-brand-7); + --ti-common-color-bg-normal: var(--ti-base-color-bg-6); + --ti-common-color-bg-emphasize: var(--ti-base-color-brand-6); + --ti-common-color-bg-disabled: var(--ti-base-color-bg-5); + --ti-common-color-bg-hover: var(--ti-base-color-brand-8); + --ti-common-color-bg-gray: var(--ti-base-color-bg-4); + --ti-common-color-bg-secondary: var(--ti-base-color-common-2); + --ti-common-bg-primary: var(--ti-base-color-bg-8); + --ti-common-bg-primary-hover: var(--ti-base-color-bg-7); + --ti-common-bg-primary-active: var(--ti-base-color-bg-9); + --ti-common-bg-minor: var(--ti-base-color-bg-2); + --ti-common-bg-minor-hover: var(--ti-base-color-bg-1); + --ti-common-bg-minor-active: var(--ti-base-color-bg-3); + --ti-common-color-bg-white-normal: var(--ti-base-color-white); + --ti-common-color-bg-white-emphasize: var(--ti-base-color-brand-1); + --ti-common-color-bg-light-normal: var(--ti-base-color-brand-2); + --ti-common-color-bg-light-emphasize: var(--ti-base-color-brand-3); + --ti-common-color-bg-dark-normal: var(--ti-base-color-common-6); + --ti-common-color-bg-dark-emphasize: var(--ti-base-color-common-4); + --ti-common-color-bg-dark-active: var(--ti-common-color-bg-normal); + --ti-common-color-bg-dark-deep: var(--ti-base-color-common-6); + --ti-common-color-bg-dark-disabled: var(--ti-base-color-common-1); + --ti-common-color-bg-navigation: var(--ti-base-color-common-8); + --ti-common-color-bg-dark-select: var(--ti-base-color-common-9); + --ti-common-color-data-1: var(--ti-base-color-success-3); + --ti-common-color-data-2: var(--ti-base-color-icon-info); + --ti-common-color-data-3: var(--ti-base-color-data-3); + --ti-common-color-data-4: var(--ti-base-color-data-4); + --ti-common-color-data-5: var(--ti-base-color-data-5); + --ti-common-color-data-6: var(--ti-base-color-warn-3); + --ti-common-color-data-7: var(--ti-base-color-warn-4); + --ti-common-color-data-8: var(--ti-base-color-error-3); + --ti-common-color-transparent: var(--ti-base-color-transparent); + --ti-common-border-radius-normal: 2px; + --ti-common-border-radius-0: 0px; + --ti-common-border-radius-1: 4px; + --ti-common-border-radius-2: 8px; + --ti-common-border-radius-3: 50%; + --ti-common-font-size-base: 12px; + --ti-common-font-size-1: 14px; + --ti-common-font-size-2: 16px; + --ti-common-font-size-3: 18px; + --ti-common-font-size-4: 20px; + --ti-common-font-size-5: 24px; + --ti-common-font-size-6: 32px; + --ti-common-font-size-7: 36px; + --ti-common-line-height-number: 1.5; + --ti-common-space-base: 4px; + --ti-common-space-2x: calc(var(--ti-common-space-base) * 2); + --ti-common-space-3x: calc(var(--ti-common-space-base) * 3); + --ti-common-space-4x: calc(var(--ti-common-space-base) * 4); + --ti-common-space-5x: calc(var(--ti-common-space-base) * 5); + --ti-common-space-6x: calc(var(--ti-common-space-base) * 6); + --ti-common-space-8x: calc(var(--ti-common-space-base) * 8); + --ti-common-space-10x: calc(var(--ti-common-space-base) * 10); + --ti-common-space-0: 0px; + --ti-common-space-1: 1px; + --ti-common-space-6: 6px; + --ti-common-space-10: 10px; + --ti-common-shadow-1-up: 0 -1px 4px 0 rgba(0, 0, 0, 0.1); + --ti-common-shadow-1-down: 0 1px 4px 0 rgba(0, 0, 0, 0.1); + --ti-common-shadow-1-left: -1px 0px 4px 0 rgba(0, 0, 0, 0.1); + --ti-common-shadow-1-right: 1px 0px 4px 0 rgba(0, 0, 0, 0.1); + --ti-common-shadow-2-up: 0 -2px 8px 0 rgba(0, 0, 0, 0.2); + --ti-common-shadow-2-down: 0 2px 8px 0 rgba(0, 0, 0, 0.2); + --ti-common-shadow-2-left: -2px 0 8px 0 rgba(238, 10, 10, 0.2); + --ti-common-shadow-2-right: 2px 0 8px 0 rgba(252, 5, 5, 0.2); + --ti-common-shadow-3-up: 0 -4px 16px 0 rgba(0, 0, 0, 0.2); + --ti-common-shadow-3-down: 0 4px 16px 0 rgba(0, 0, 0, 0.2); + --ti-common-shadow-3-left: -4px 0 16px 0 rgba(0, 0, 0, 0.2); + --ti-common-shadow-3-right: 4px 0 16px 0 rgba(0, 0, 0, 0.2); + --ti-common-shadow-4-up: 0 -8px 40px 0 rgba(0, 0, 0, 0.2); + --ti-common-shadow-4-down: 0 8px 40px 0 rgba(0, 0, 0, 0.2); + --ti-common-shadow-4-left: -8px 0 40px 0 rgba(0, 0, 0, 0.2); + --ti-common-shadow-4-right: 8px 0 40px 0 rgba(0, 0, 0, 0.2); + --ti-common-shadow-error: 0 1px 3px 0 rgba(199, 54, 54, 0.25); + --ti-common-shadow-warn: 0 1px 3px 0 rgba(204, 100, 20, 0.25); + --ti-common-shadow-prompt: 0 1px 3px 0 rgba(70, 94, 184, 0.25); + --ti-common-shadow-success: 0 1px 3px 0 rgba(39, 176, 128, 0.25); + --ti-common-font-family: 'Helvetica', 'Arial', 'PingFangSC-Regular', 'Hiragino Sans GB', 'Microsoft YaHei', + '寰蒋闆呴粦', 'Microsoft JhengHei'; + --ti-common-font-weight-1: 100; + --ti-common-font-weight-2: 200; + --ti-common-font-weight-3: 300; + --ti-common-font-weight-4: normal; + --ti-common-font-weight-5: 500; + --ti-common-font-weight-6: 600; + --ti-common-font-weight-7: bold; + --ti-common-font-weight-8: 800; + --ti-common-font-weight-9: 900; + --ti-common-border-weight-normal: 1px; + --ti-common-border-weight-1: 2px; + --ti-common-border-weight-2: 3px; + --ti-common-border-style-dashed: dashed; + --ti-common-border-style-dotted: dotted; + --ti-common-border-style-solid: solid; + --ti-common-size-base: 4px; + --ti-common-size-2x: calc(var(--ti-common-size-base) * 2); + --ti-common-size-3x: calc(var(--ti-common-size-base) * 3); + --ti-common-size-4x: calc(var(--ti-common-size-base) * 4); + --ti-common-size-5x: calc(var(--ti-common-size-base) * 5); + --ti-common-size-6x: calc(var(--ti-common-size-base) * 6); + --ti-common-size-7x: calc(var(--ti-common-size-base) * 7); + --ti-common-size-8x: calc(var(--ti-common-size-base) * 8); + --ti-common-size-9x: calc(var(--ti-common-size-base) * 9); + --ti-common-size-10x: calc(var(--ti-common-size-base) * 10); + --ti-common-size-11x: calc(var(--ti-common-size-base) * 11); + --ti-common-size-12x: calc(var(--ti-common-size-base) * 12); + --ti-common-size-13x: calc(var(--ti-common-size-base) * 13); + --ti-common-size-14x: calc(var(--ti-common-size-base) * 14); + --ti-common-size-15x: calc(var(--ti-common-size-base) * 15); + --ti-common-size-16x: calc(var(--ti-common-size-base) * 16); + --ti-common-size-17x: calc(var(--ti-common-size-base) * 17); + --ti-common-size-18x: calc(var(--ti-common-size-base) * 18); + --ti-common-size-19x: calc(var(--ti-common-size-base) * 19); + --ti-common-size-20x: calc(var(--ti-common-size-base) * 20); + --ti-common-size-21x: calc(var(--ti-common-size-base) * 21); + --ti-common-size-22x: calc(var(--ti-common-size-base) * 22); + --ti-common-size-23x: calc(var(--ti-common-size-base) * 23); + --ti-common-size-24x: calc(var(--ti-common-size-base) * 24); + --ti-common-size-25x: calc(var(--ti-common-size-base) * 25); + --ti-common-size-26x: calc(var(--ti-common-size-base) * 26); + --ti-common-size-27x: calc(var(--ti-common-size-base) * 27); + --ti-common-size-28x: calc(var(--ti-common-size-base) * 28); + --ti-common-size-29x: calc(var(--ti-common-size-base) * 29); + --ti-common-size-30x: calc(var(--ti-common-size-base) * 30); + --ti-common-size-31x: calc(var(--ti-common-size-base) * 31); + --ti-common-size-32x: calc(var(--ti-common-size-base) * 32); + --ti-common-size-33x: calc(var(--ti-common-size-base) * 33); + --ti-common-size-34x: calc(var(--ti-common-size-base) * 34); + --ti-common-size-35x: calc(var(--ti-common-size-base) * 35); + --ti-common-size-36x: calc(var(--ti-common-size-base) * 36); + --ti-common-size-37x: calc(var(--ti-common-size-base) * 37); + --ti-common-size-38x: calc(var(--ti-common-size-base) * 38); + --ti-common-size-39x: calc(var(--ti-common-size-base) * 39); + --ti-common-size-40x: calc(var(--ti-common-size-base) * 40); + --ti-common-size-41x: calc(var(--ti-common-size-base) * 41); + --ti-common-size-42x: calc(var(--ti-common-size-base) * 42); + --ti-common-size-43x: calc(var(--ti-common-size-base) * 43); + --ti-common-size-44x: calc(var(--ti-common-size-base) * 44); + --ti-common-size-45x: calc(var(--ti-common-size-base) * 45); + --ti-common-size-46x: calc(var(--ti-common-size-base) * 46); + --ti-common-size-47x: calc(var(--ti-common-size-base) * 47); + --ti-common-size-48x: calc(var(--ti-common-size-base) * 48); + --ti-common-size-49x: calc(var(--ti-common-size-base) * 49); + --ti-common-size-50x: calc(var(--ti-common-size-base) * 50); + --ti-common-size-0: 0px; + --ti-common-size-auto: auto; + --ti-base-color-primary-normal: var(--ti-base-color-brand-6); + --ti-base-color-primary-hover: var(--ti-base-color-brand-5); + --ti-base-color-primary-active: var(--ti-base-color-brand-5); + --ti-base-color-primary-disabled: var(--ti-common-color-bg-disabled); + --ti-base-color-primary-disabled-border: var(--ti-common-color-line-disabled); + --ti-base-color-primary-disabled-text: var(--ti-common-color-text-disabled); + --ti-base-color-success-normal: var(--ti-common-color-success); + --ti-base-color-success-hover: var(--ti-common-color-success-border); + --ti-base-color-success-active: var(--ti-common-color-success-border); + --ti-base-color-success-disabled: var(--ti-common-color-bg-disabled); + --ti-base-color-success-disabled-border: var(--ti-common-color-line-disabled); + --ti-base-color-success-disabled-text: var(--ti-common-color-text-disabled); + --ti-base-color-warning-normal: var(--ti-common-color-warn); + --ti-base-color-warning-hover: var(--ti-common-color-warn-secondary); + --ti-base-color-warning-active: var(--ti-common-color-warn-secondary); + --ti-base-color-warning-disabled: var(--ti-common-color-bg-disabled); + --ti-base-color-warning-disabled-border: var(--ti-common-color-line-disabled); + --ti-base-color-warning-disabled-text: var(--ti-common-color-text-disabled); + --ti-base-color-danger-normal: var(--ti-common-bg-primary); + --ti-base-color-danger-hover: var(--ti-common-bg-primary-hover); + --ti-base-color-danger-active: var(--ti-common-bg-primary-active); + --ti-base-color-danger-disabled: var(--ti-common-color-bg-disabled); + --ti-base-color-danger-disabled-border: var(--ti-common-color-line-disabled); + --ti-base-color-danger-disabled-text: var(--ti-common-color-text-disabled); + --ti-base-color-info-normal: var(--ti-base-color-common-7); + --ti-base-color-info-hover: #54657e; + --ti-base-color-info-active: #54657e; + --ti-base-color-info-disabled: var(--ti-common-color-bg-disabled); + --ti-base-color-info-disabled-border: var(--ti-common-color-line-disabled); + --ti-base-color-info-disabled-text: var(--ti-common-color-text-disabled); + --ti-base-color-border: var(--ti-base-color-common-2); + --ti-base-color-border-hover: var(--ti-base-color-common-5); + --ti-base-color-light: #fff; + --ti-base-color-hover-background: var(--ti-base-color-brand-1); + --ti-base-color-selected-background: var(--ti-base-color-brand-6); + --ti-base-color-selected-font-color: var(--ti-base-color-light); + --ti-base-size-height-normal: 30px; + --ti-base-box-shadow: 0 0 4px rgba(0, 0, 0, 0.3); + --ti-base-dropdown-gap: 2px; + --ti-base-color-dark: #000; + --ti-base-color-secondary: #666; + --ti-base-color-placeholder: #999; + --ti-base-color-navigation-background: #2e3243; + --ti-base-radius-large: 3px; + --ti-base-radius-medium: 2px; + --ti-base-radius-small: 1px; + --ti-base-font-size: 12px; + --ti-base-font-size-normal: 1em; + --ti-base-font-size-large: 1.125em; + --ti-base-font-weight-bold: 700; + --ti-base-size-width-large: 130px; + --ti-base-size-width-medium: 120px; + --ti-base-size-width-normal: 80px; + --ti-base-size-width-small: 36px; + --ti-base-size-width-minor: 30px; + --ti-base-size-width-mini: 24px; + --ti-base-size-height-large: 48px; + --ti-base-size-height-medium: 42px; + --ti-base-size-height-small: 28px; + --ti-base-size-height-minor: 30px; + --ti-base-size-height-mini: 24px; +} +:root { + --ti-errortips-box-background: var(--ti-base-color-light); + --ti-errortips-body-color: #5a5e66; + --ti-errortips-body-font-size: var(--ti-common-font-size-1); + --ti-errortips-body-code-font-size: 100px; + --ti-errortips-body-code-color: #9ac7ef; + --ti-errortips-body-content-font-size: var(--ti-common-font-size-2); + --ti-errortips-body-bottom-font-weight: var(--ti-common-font-weight-8); + --ti-errortips-sso-box-background: var(--ti-base-color-light); + --ti-errortips-sso-body-color: #5a5e66; + --ti-errortips-sso-body-font-size: var(--ti-common-font-size-1); + --ti-errortips-not-sso-background: #dcdfe4; + --ti-errortips-not-sso-body-background: #f4f5f9; + --ti-errortips-not-sso-body-border-color: #d4d5d7; + --ti-errortips-not-sso-body-title-border-color: #b6babf; + --ti-errortips-not-sso-body-title-font-size: var(--ti-common-font-size-4); + --ti-errortips-not-sso-body-login-font-size: var(--ti-common-font-size-2); + --ti-errortips-not-sso-body-color: #5a5e66; + --ti-errortips-not-sso-body-input-border-color: var(--ti-base-color-bg-5); + --ti-errortips-not-sso-body-input-border-radius: var(--ti-common-border-radius-normal); + --ti-errortips-not-sso-body-input-placeholder: var(--ti-base-color-placeholder); + --ti-errortips-not-sso-body-input-hover: var(--ti-base-color-placeholder); + --ti-errortips-not-sso-body-input-focus: var(--ti-base-color-border); + --ti-errortips-not-sso-body-input-danger: var(--ti-base-color-bg-8); + --ti-errortips-not-sso-body-button-color: var(--ti-base-color-light); + --ti-errortips-not-sso-body-button-background: var(--ti-base-color-brand-6); + --ti-errortips-not-sso-body-button-border-radius: var(--ti-common-border-radius-normal); + --ti-errortips-not-sso-body-button-hover: var(--ti-base-color-brand-5); + --ti-errortips-not-sso-body-errmessage-color: #f00; +} +.aurora-popup__wrapper { + z-index: 2147483647 !important; + background: rgba(0, 0, 0, 0.5); + position: fixed; + top: 0; + right: 0; + bottom: 0; + left: 0; + overflow: auto; + margin: 0; +} +.aurora-popup__wrapper .aurora-errortips__box { + position: absolute; + width: var(--ti-errortips-width); + min-height: var(--ti-errortips-min-height); + max-height: var(--ti-errortips-max-height); + top: 0; + left: 0; + right: 0; + bottom: 0; + margin: auto; + overflow: hidden; + background: var(--ti-errortips-box-background); + border: 1px solid transparent; + -webkit-box-shadow: 2px 2px 2px 0 rgba(0, 0, 0, 0.2); + box-shadow: 2px 2px 2px 0 rgba(0, 0, 0, 0.2); + text-align: center; + overflow-y: auto; +} +.aurora-popup__wrapper .aurora-errortips__box .aurora-errortips__body { + height: 100%; + text-align: initial; + padding: 20px; + color: var(--ti-errortips-body-color); + font-size: var(--ti-errortips-body-font-size); + display: table; + margin: auto; +} +.aurora-popup__wrapper .aurora-errortips__box .aurora-errortips__body .errortips { + text-align: center; + display: table-cell; + vertical-align: middle; +} +.aurora-popup__wrapper .aurora-errortips__box .aurora-errortips__body .errortips .error-code { + font-size: var(--ti-errortips-body-code-font-size); + color: var(--ti-errortips-body-code-color); + margin: 0 auto -45px; + text-shadow: 0 2px 0 #fff, -2px 0 0 #fff, 2px 0 0 #fff; +} +.aurora-popup__wrapper .aurora-errortips__box .aurora-errortips__body .errortips .error-img { + width: 260px; + height: 180px; + margin: 0 auto; + background: url(../images/errortips-bg.png) no-repeat; +} +.aurora-popup__wrapper .aurora-errortips__box .aurora-errortips__body .errortips .error-content { + font-size: var(--ti-errortips-body-content-font-size); + margin: 24px 0; + font-weight: 700; +} +.aurora-popup__wrapper .aurora-errortips__box .aurora-errortips__body .errortips .error-bottom a { + font-weight: var(--ti-errortips-body-bottom-font-weight); + cursor: pointer; +} +.aurora-popup__wrapper .aurora-errortips__box .aurora-errortips__body .errortips .error-bottom span { + padding-right: 15px; +} +.aurora-popup__wrapper .aurora-sso__box { + position: absolute; + background: var(--ti-errortips-sso-box-background); + border: 1px solid transparent; + -webkit-box-shadow: 2px 2px 2px 0 rgba(0, 0, 0, 0.2); + box-shadow: 2px 2px 2px 0 rgba(0, 0, 0, 0.2); + left: 50%; + top: 50%; + -webkit-transform: translate(-50%, -50%); + transform: translate(-50%, -50%); +} +.aurora-popup__wrapper .aurora-sso__box .aurora-sso__body { + text-align: initial; + padding: 20px; + color: var(--ti-errortips-sso-body-color); + line-height: 32px; + font-size: var(--ti-errortips-sso-body-font-size); +} +.aurora-popup__wrapper .aurora-sso__box .aurora-sso__body .aurora-sso__body-iframe { + width: 350px; + height: 350px; + overflow: hidden; +} +@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) { + .aurora-popup__wrapper .aurora-sso__box .aurora-sso__body .aurora-sso__body-iframe { + height: 460px; + } +} +@supports (-ms-ime-align: auto) { + .aurora-popup__wrapper .aurora-sso__box .aurora-sso__body .aurora-sso__body-iframe { + height: 460px; + } +} +.aurora-popup__wrapper.login-not-sso { + background: var(--ti-errortips-not-sso-background); + background-size: cover; +} +.aurora-popup__wrapper.login-not-sso .aurora-not-sso__box { + width: 100%; + height: 100%; + overflow: hidden; +} +.aurora-popup__wrapper.login-not-sso .aurora-not-sso__box .aurora-not-sso__body { + width: 650px; + height: 400px; + background: var(--ti-errortips-not-sso-body-background); + position: absolute; + left: 50%; + top: 50%; + -webkit-transform: translate(-50%, -50%); + transform: translate(-50%, -50%); + text-align: center; + border: 1px solid var(--ti-errortips-not-sso-body-border-color); + -webkit-box-shadow: 0 2px 4px #989a9e; + box-shadow: 0 2px 4px #989a9e; +} +.aurora-popup__wrapper.login-not-sso .aurora-not-sso__box .aurora-not-sso__body .title { + background: -webkit-gradient(linear, left top, left bottom, from(#ecedf1), to(#dadde2)); + background: linear-gradient(to bottom, #ecedf1, #dadde2); + border-bottom: 1px solid var(--ti-errortips-not-sso-body-title-border-color); + padding: 16px 20px; + font-size: var(--ti-errortips-not-sso-body-title-font-size); +} +.aurora-popup__wrapper.login-not-sso .aurora-not-sso__box .aurora-not-sso__body .tbl-login { + width: 100%; + border-collapse: collapse; + border-spacing: 0; + font-size: var(--ti-errortips-not-sso-body-login-font-size); + margin-top: 28px; +} +.aurora-popup__wrapper.login-not-sso .aurora-not-sso__box .aurora-not-sso__body .tbl-login .form-item { + height: 60px; + line-height: 60px; +} +.aurora-popup__wrapper.login-not-sso .aurora-not-sso__box .aurora-not-sso__body .tbl-login .form-item td.label { + width: 30%; + text-align: right; + color: var(--ti-errortips-not-sso-body-color); +} +.aurora-popup__wrapper.login-not-sso .aurora-not-sso__box .aurora-not-sso__body .tbl-login .form-item td.cell { + width: 70%; + text-align: left; + padding-left: 12px; +} +.aurora-popup__wrapper.login-not-sso .aurora-not-sso__box .aurora-not-sso__body .tbl-login .form-item td.cell input { + border: 1px solid var(--ti-errortips-not-sso-body-input-border-color); + border-radius: var(--ti-errortips-not-sso-body-input-border-radius); + outline: 0; + width: 75%; + height: 40px; + line-height: 40px; + padding: 0 8px; + background: 0 0; + color: var(--ti-errortips-not-sso-body-color); +} +.aurora-popup__wrapper.login-not-sso + .aurora-not-sso__box + .aurora-not-sso__body + .tbl-login + .form-item + td.cell + input::-webkit-input-placeholder { + color: var(--ti-errortips-not-sso-body-input-placeholder); +} +.aurora-popup__wrapper.login-not-sso + .aurora-not-sso__box + .aurora-not-sso__body + .tbl-login + .form-item + td.cell + input:hover { + border-color: var(--ti-errortips-not-sso-body-input-placeholder); +} +.aurora-popup__wrapper.login-not-sso + .aurora-not-sso__box + .aurora-not-sso__body + .tbl-login + .form-item + td.cell + input:focus::-webkit-input-placeholder { + color: var(--ti-errortips-not-sso-body-input-focus); +} +.aurora-popup__wrapper.login-not-sso + .aurora-not-sso__box + .aurora-not-sso__body + .tbl-login + .form-item + td.cell + input.text-danger { + border-color: var(--ti-errortips-not-sso-body-input-danger); +} +.aurora-popup__wrapper.login-not-sso .aurora-not-sso__box .aurora-not-sso__body .tbl-login .form-item td.cell button { + width: 75%; + height: 40px; + line-height: 40px; + padding: 0 24px; + text-align: center; + color: var(--ti-errortips-not-sso-body-button-color); + background-color: var(--ti-errortips-not-sso-body-button-background); + border: none; + border-radius: var(--ti-errortips-not-sso-body-button-border-radius); + -webkit-transition: 0.3s; + transition: 0.3s; + outline: 0; +} +.aurora-popup__wrapper.login-not-sso + .aurora-not-sso__box + .aurora-not-sso__body + .tbl-login + .form-item + td.cell + button:hover { + background-color: var(--ti-errortips-not-sso-body-button-hover); +} +.aurora-popup__wrapper.login-not-sso + .aurora-not-sso__box + .aurora-not-sso__body + .tbl-login + .form-item + td.cell + .errmessage { + color: var(--ti-errortips-not-sso-body-errmessage-color); + line-height: 20px; +} +.tiny-svg { + width: 1em; + height: 1em; + vertical-align: middle; + overflow: hidden; + display: inline-block; +} +.tiny-transition-alert-fade-enter, +.tiny-transition-alert-fade-enter-from, +.tiny-transition-alert-fade-leave-active { + opacity: 0; +} +.tiny-transition-alert-fade-leave-active { + -webkit-transition: opacity 0.3s ease-in; + transition: opacity 0.3s ease-in; +} +.tiny-alert { + --ti-alert-description-font-size: var(--ti-common-font-size-base); + --ti-alert-close-font-size: var(--ti-common-font-size-base); + --ti-alert-radius: var(--ti-common-border-radius-normal); + --ti-alert-title-color: var(--ti-base-color-info-normal); + --ti-alert-nomal-content-line-height: var(--ti-common-line-height-number); + --ti-alert-description-color: var(--ti-base-color-info-normal); + --ti-alert-opration-color: var(--ti-base-color-brand-7); + --ti-alert-warning-border-color: var(--ti-common-color-warn-border); + --ti-alert-warning-icon-color: var(--ti-common-color-warn); + --ti-alert-warning-link-color: var(--ti-common-color-warn-text); + --ti-alert-warning-bg-color: var(--ti-common-color-warn-bg); + --ti-alert-error-border-color: var(--ti-common-color-error-border-secondary); + --ti-alert-error-icon-color: var(--ti-common-color-error); + --ti-alert-error-link-color: var(--ti-common-color-error-text); + --ti-alert-error-bg-color: var(--ti-common-color-error-bg); + --ti-alert-success-border-color: var(--ti-common-color-success-border); + --ti-alert-success-icon-color: var(--ti-common-color-success); + --ti-alert-success-link-color: var(--ti-common-color-text-success); + --ti-alert-success-bg-color: var(--ti-common-color-success-bg); + --ti-alert-info-border-color: var(--ti-common-color-prompt-border); + --ti-alert-info-icon-color: var(--ti-common-color-prompt); + --ti-alert-info-link-color: var(--ti-common-color-prompt-text); + --ti-alert-info-bg-color: var(--ti-common-color-prompt-bg); + position: relative; + border: 1px solid; + border-radius: var(--ti-alert-radius); +} +.tiny-alert.tiny-alert--normal { + padding: 11px 16px; + margin: 8px 0; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-pack: start; + -ms-flex-pack: start; + justify-content: flex-start; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; +} +.tiny-alert.tiny-alert--normal .tiny-alert__content { + padding: 0 8px; + display: table-cell; + line-height: var(--ti-alert-nomal-content-line-height); + max-width: calc(100% - 30px); +} +.tiny-alert.tiny-alert--large { + padding: 18px 24px 14px; + display: -webkit-box; + display: -ms-flexbox; + display: flex; +} +.tiny-alert.tiny-alert--large .tiny-alert__content { + padding-left: 16px; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-orient: vertical; + -webkit-box-direction: normal; + -ms-flex-direction: column; + flex-direction: column; + -webkit-box-pack: start; + -ms-flex-pack: start; + justify-content: flex-start; + -webkit-box-align: start; + -ms-flex-align: start; + align-items: flex-start; +} +.tiny-alert.tiny-alert--large .tiny-alert__description { + margin-bottom: 6px; + margin-top: 12px; + line-height: 1; +} +.tiny-alert.tiny-alert--large .tiny-alert__description.is-hide { + margin: 0; +} +.tiny-alert.tiny-alert--large .tiny-alert__icon { + font-size: 24px; + vertical-align: top; + -ms-flex-negative: 0; + flex-shrink: 0; +} +.tiny-alert.tiny-alert--large .tiny-alert__icon.tiny-alert__close { + font-size: 12px; +} +.tiny-alert.tiny-alert--large .tiny-alert__close { + top: 12px; + right: 12px; + -webkit-transform: none; + transform: none; +} +.tiny-alert.tiny-alert--success { + background: var(--ti-alert-success-bg-color); + border-color: var(--ti-alert-success-border-color); + color: var(--ti-alert-title-color); +} +.tiny-alert.tiny-alert--success hr { + border-top-color: var(--ti-alert-success-link-color); +} +.tiny-alert.tiny-alert--success .alert-link { + color: var(--ti-alert-success-link-color); +} +.tiny-alert.tiny-alert--success .tiny-alert__icon { + fill: var(--ti-alert-success-icon-color); +} +.tiny-alert.tiny-alert--info { + background: var(--ti-alert-info-bg-color); + border-color: var(--ti-alert-info-border-color); + color: var(--ti-alert-title-color); +} +.tiny-alert.tiny-alert--info hr { + border-top-color: var(--ti-alert-info-link-color); +} +.tiny-alert.tiny-alert--info .alert-link { + color: var(--ti-alert-info-link-color); +} +.tiny-alert.tiny-alert--info .tiny-alert__icon { + fill: var(--ti-alert-info-icon-color); +} +.tiny-alert.tiny-alert--warning { + background: var(--ti-alert-warning-bg-color); + border-color: var(--ti-alert-warning-border-color); + color: var(--ti-alert-title-color); +} +.tiny-alert.tiny-alert--warning hr { + border-top-color: var(--ti-alert-warning-link-color); +} +.tiny-alert.tiny-alert--warning .alert-link { + color: var(--ti-alert-warning-link-color); +} +.tiny-alert.tiny-alert--warning .tiny-alert__icon { + fill: var(--ti-alert-warning-icon-color); +} +.tiny-alert.tiny-alert--error { + background: var(--ti-alert-error-bg-color); + border-color: var(--ti-alert-error-border-color); + color: var(--ti-alert-title-color); +} +.tiny-alert.tiny-alert--error hr { + border-top-color: var(--ti-alert-error-link-color); +} +.tiny-alert.tiny-alert--error .alert-link { + color: var(--ti-alert-error-link-color); +} +.tiny-alert.tiny-alert--error .tiny-alert__icon { + fill: var(--ti-alert-error-icon-color); +} +.tiny-alert__icon { + font-size: 16px; +} +.tiny-alert.is-center { + -webkit-box-pack: center; + -ms-flex-pack: center; + justify-content: center; + text-align: center; +} +.tiny-alert .is-custom { + position: absolute; + top: 50%; + right: 12px; + -webkit-transform: translateY(-50%); + transform: translateY(-50%); + cursor: pointer; +} +.tiny-alert .tiny-alert__close { + font-size: var(--ti-alert-close-font-size); + position: absolute; + top: 50%; + right: 12px; + -webkit-transform: translateY(-50%); + transform: translateY(-50%); + cursor: pointer; +} +.tiny-alert .tiny-alert__content .tiny-alert__opration { + font-size: 12px; + color: var(--ti-alert-opration-color); + line-height: 1; +} +.tiny-alert .tiny-alert__content .tiny-alert__opration a { + font-size: 12px; + color: var(--ti-alert-opration-color); +} +.tiny-alert .tiny-alert__content .tiny-alert__opration a:not(:last-child) { + margin-right: 16px; +} +.tiny-alert .tiny-alert__title { + font-size: 16px; + color: var(--ti-alert-title-color); + font-weight: 700; +} +.tiny-alert .tiny-alert__description { + font-size: var(--ti-alert-description-font-size); + color: var(--ti-alert-description-color); +} +.tiny-alert p { + display: inline-block; + line-height: 16px; + padding-left: 8px; +} +.tiny-amount { + --ti-amount-icon-color: var(--ti-base-color-brand-6); + --ti-amount-icon-font-size: var(--ti-common-font-size-1); + width: 270px; +} +.tiny-amount .tiny-amount-input-icon .tiny-svg { + fill: var(--ti-amount-icon-color); + font-size: var(--ti-amount-icon-font-size); +} +.tiny-amount-popper { + width: 270px; +} +.tiny-amount-popper .popover-con .module:not(:last-child) { + margin-bottom: 12px; +} +.tiny-amount-popper .popover-con .module { + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-pack: center; + -ms-flex-pack: center; + justify-content: center; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; +} +.tiny-amount-popper .popover-con .module .popover-left { + -webkit-box-flex: 0; + -ms-flex: 0 0 auto; + flex: 0 0 auto; + margin-right: 8px; + width: 30%; + text-align: right; +} +.tiny-amount-popper + .popover-con + .module + .popover-right:not(.tiny-input-prefix):not(.tiny-input-suffiX) + .tiny-input__inner { + padding: 0 8px; +} +.tiny-amount-popper .popover-con .module .popover-right.tiny-input { + display: inline-block; +} +.tiny-amount .tiny-input { + outline: 0; +} +.tiny-amount span.tiny-popover__reference { + width: 100%; +} +.tiny-area .tiny-select { + width: 270px; + margin-right: 10px; +} +.tiny-autocomplete { + --ti-autocomplete-suggestion-border-radius: var(--ti-common-border-radius-normal); + --ti-autocomplete-suggestion-border-color: var(--ti-base-color-white); + --ti-autocomplete-suggestion-bgcolor: var(--ti-base-color-light); + --ti-autocomplete-li-color: var(--ti-base-color-info-normal); + --ti-autocomplete-li-font-size: var(--ti-common-font-size-base); + --ti-autocomplete-li-hover-bgcolor: var(--ti-base-color-hover-background); + --ti-autocomplete-li-select-bgcolor: var(--ti-base-color-selected-background); + --ti-autocomplete-li-selected-font-color: var(--ti-base-color-selected-font-color); + --ti-autocomplete-li-divider-border-color: var(--ti-base-color-dark); + --ti-autocomplete-li-height: 30px; + --ti-autocomplete-loading-color: var(--ti-base-color-placeholder); + position: relative; + display: inline-block; +} +.tiny-autocomplete-suggestion { + border: 1px solid var(--ti-autocomplete-suggestion-border-color); + border-radius: var(--ti-autocomplete-suggestion-border-radius); + background-color: var(--ti-autocomplete-suggestion-bgcolor); + -webkit-box-sizing: border-box; + box-sizing: border-box; + -webkit-box-shadow: var(--ti-base-box-shadow); + box-shadow: var(--ti-base-box-shadow); +} +.tiny-autocomplete-suggestion__wrap { + max-height: 280px; + -webkit-box-sizing: border-box; + box-sizing: border-box; +} +@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) { + .tiny-autocomplete-suggestion__wrap { + margin-bottom: -17px !important; + padding-bottom: 6px; + } +} +.tiny-autocomplete-suggestion__list { + margin: 0; + padding: 0; +} +.tiny-autocomplete-suggestion .tiny-autocomplete-suggestion__list-item { + padding: 0 8px; + margin: 0; + line-height: var(--ti-autocomplete-li-height); + color: var(--ti-autocomplete-li-color); + font-size: var(--ti-autocomplete-li-font-size); + list-style: none; + white-space: nowrap; + overflow: hidden; + text-overflow: ellipsis; + cursor: pointer; +} +.tiny-autocomplete-suggestion .tiny-autocomplete-suggestion__list-item.highlighted, +.tiny-autocomplete-suggestion .tiny-autocomplete-suggestion__list-item:hover { + background-color: var(--ti-autocomplete-li-hover-bgcolor); +} +.tiny-autocomplete-suggestion .tiny-autocomplete-suggestion__list-item.divider { + margin-top: 6px; + border-top: 1px solid var(--ti-autocomplete-li-divider-border-color); +} +.tiny-autocomplete-suggestion .tiny-autocomplete-suggestion__list-item.divider:last-child { + margin-bottom: -6px; +} +.tiny-autocomplete-suggestion .tiny-autocomplete-suggestion__list-item:only-of-type, +.tiny-autocomplete-suggestion .tiny-autocomplete-suggestion__list-item:only-of-type:hover { + background-color: var(--ti-autocomplete-li-select-bgcolor); + color: var(--ti-autocomplete-li-selected-font-color); +} +.tiny-autocomplete-suggestion.is-loading .tiny-autocomplete-suggestion__list-loading { + text-align: center; + height: 100px; + line-height: 100px; + font-size: var(--ti-common-font-size-4); + color: var(--ti-autocomplete-loading-color); +} +.tiny-autocomplete-suggestion.is-loading .tiny-autocomplete-suggestion__list-loading::after { + display: inline-block; + content: ''; + height: 100%; + vertical-align: middle; +} +.tiny-autocomplete-suggestion.is-loading .tiny-autocomplete-suggestion__list-loading:hover { + background-color: #fff; +} +.tiny-autocomplete-suggestion.is-loading .tiny-icon-loading { + vertical-align: middle; +} +.tiny-autocomplete-suggestion.tiny-popper[x-placement^='bottom'] { + margin-top: var(--ti-base-dropdown-gap); +} +.tiny-badge { + --ti-badge-size: var(--ti-common-size-5x); + --ti-badge-font-size: 12px; + --ti-badge-font-weight: var(--ti-common-font-weight-7); + --ti-badge-border-raidus: 12px; + --ti-badge-color: var(--ti-base-color-light); + --ti-badge-bgcolor: var(--ti-base-color-error-3); + --ti-badge-link-hover-color: var(--ti-base-color-light); + --ti-badge-active-color: var(--ti-base-color-brand-6); + --ti-badge-active-bgcolor: var(--ti-base-color-light); + --ti-badge-primary-bgcolor: var(--ti-base-color-brand-6); + --ti-badge-success-bgcolor: var(--ti-base-color-success-normal); + --ti-badge-warning-bgcolor: var(--ti-base-color-warning-normal); + --ti-badge-danger-bgcolor: var(--ti-base-color-error-3); + --ti-badge-info-bgcolor: var(--ti-base-color-info-normal); + display: inline-block; + min-width: var(--ti-badge-size); + height: var(--ti-badge-size); + line-height: var(--ti-badge-size); + border-radius: var(--ti-badge-border-raidus); + padding: 0 4px; + font-size: var(--ti-badge-font-size); + font-weight: var(--ti-badge-font-weight); + color: var(--ti-badge-color); + background-color: var(--ti-badge-bgcolor); + vertical-align: baseline; + white-space: nowrap; + text-align: center; +} +.tiny-badge.tiny-badge--max { + padding: 0 6px; + border-radius: 10px; +} +.tiny-badge.tiny-badge--default { + width: 6px; + height: 6px; + min-width: auto; + background-color: var(--ti-badge-bgcolor); + display: inline-block; + vertical-align: top; + padding: 0; + border-radius: 50%; +} +.tiny-badge.tiny-badge--primary { + background-color: var(--ti-badge-primary-bgcolor); +} +.tiny-badge.tiny-badge--success { + background-color: var(--ti-badge-success-bgcolor); +} +.tiny-badge.tiny-badge--warning { + background-color: var(--ti-badge-warning-bgcolor); +} +.tiny-badge.tiny-badge--danger { + background-color: var(--ti-badge-danger-bgcolor); +} +.tiny-badge.tiny-badge--info { + background-color: var(--ti-badge-info-bgcolor); +} +.tiny-badge:empty { + display: none; +} +.btn .tiny-badge { + position: relative; + top: -1px; +} +.tiny-badge a, +.tiny-badge a:hover { + color: var(--ti-badge-color); + text-decoration: none; +} +a.badge:focus, +a.badge:hover { + color: var(--ti-badge-link-hover-color); + text-decoration: none; + cursor: pointer; +} +.nav-pills > .active > a > .badge, +a.list-group-item.active > .badge { + color: var(--ti-badge-active-color); + background-color: var(--ti-badge-active-bgcolor); +} +.nav-pills > li > a > .badge { + margin-left: 3px; +} +.tiny-breadcrumb { + --ti-breadcrumb-font-size: var(--ti-common-font-size-base); + --ti-breadcrumb-text-line-height: 1em; + --ti-breadcrumb-text-color: var(--ti-base-color-info-normal); + --ti-breadcrumb-separator-color: var(--ti-base-color-placeholder); + --ti-breadcrumb-text-hover-color: var(--ti-base-color-brand-6); + --ti-breadcrumb-text-font-weight: var(--ti-common-font-weight-7); + font-size: var(--ti-breadcrumb-font-size); + line-height: var(--ti-breadcrumb-text-line-height); +} +.tiny-breadcrumb:after, +.tiny-breadcrumb:before { + content: ''; + display: table; +} +.tiny-breadcrumb:after { + clear: both; +} +.tiny-breadcrumb .tiny-breadcrumb__item { + cursor: pointer; + display: -webkit-inline-box; + display: -ms-inline-flexbox; + display: inline-flex; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; +} +.tiny-breadcrumb .tiny-breadcrumb__item:last-child .tiny-breadcrumb__inner { + font-weight: var(--ti-breadcrumb-text-font-weight); +} +.tiny-breadcrumb .tiny-breadcrumb__item:last-child .tiny-breadcrumb__inner a { + cursor: text; +} +.tiny-breadcrumb .tiny-breadcrumb__item:last-child .tiny-breadcrumb__separator, +.tiny-breadcrumb .tiny-breadcrumb__item:last-child .tiny-breadcrumb__separator-cls { + display: none; +} +.tiny-breadcrumb .tiny-breadcrumb__inner { + vertical-align: middle; +} +.tiny-breadcrumb .tiny-breadcrumb__inner, +.tiny-breadcrumb .tiny-breadcrumb__inner a { + color: var(--ti-breadcrumb-text-color); +} +.tiny-breadcrumb .tiny-breadcrumb__inner:hover { + color: var(--ti-breadcrumb-text-hover-color); +} +.tiny-breadcrumb .tiny-breadcrumb__separator { + font-family: '\5B8B\4F53', sans-serif; + color: var(--ti-breadcrumb-separator-color); + padding: 0 4px; + vertical-align: middle; +} +.tiny-breadcrumb .tiny-breadcrumb__separator-cls { + font-size: var(--ti-breadcrumb-font-size); + fill: var(--ti-breadcrumb-separator-color); + margin: 0 4px; + vertical-align: middle; +} +.tiny-breadcrumb .tiny-breadcrumb__inner a:hover, +.tiny-breadcrumb .tiny-breadcrumb__item:last-child:hover { + color: var(--ti-breadcrumb-text-hover-color); + text-decoration: none; +} +.tiny-bulletin-board { + --ti-bulletin-board-title-font-size: var(--ti-common-font-size-3); + --ti-bulletin-board-title-font-weight: var(--ti-common-font-weight-7); + --ti-bulletin-board-title-color: var(--ti-base-color-info-normal); + --ti-bulletin-board-item-title-color: var(--ti-base-color-dark); + --ti-bulletin-board-item-date-color: var(--ti-base-color-placeholder); + --ti-bulletin-board-item-date-font-size: var(--ti-common-font-size-base); + --ti-bulletin-board-new-background: var(--ti-base-color-error-3); + --ti-bulletin-board-new-color: var(--ti-base-color-light); + --ti-bulletin-board-new-border-radius: var(--ti-common-border-radius-normal); + --ti-bulletin-board-more-color: var(--ti-base-color-brand-6); + --ti-bulletin-board-more-hover-color: var(--ti-base-color-brand-5); + --ti-bulletin-board-more-font-size: var(--ti-common-font-size-base); + --ti-bulletin-board-more-icon-font-size: var(--ti-common-font-size-1); + --ti-bulletin-board-tabs-item-color: var(--ti-base-color-info-normal); + --ti-bulletin-board-tabs-item-hover-color: var(--ti-base-color-brand-6); + --ti-bulletin-board-tabs-item-disabled-color: var(--ti-base-color-placeholder); + --ti-bulletin-board-tabs-header-border-color: var(--ti-base-color-border); +} +.tiny-bulletin-board__item { + margin-bottom: 12px; +} +.tiny-bulletin-board__item .tiny-bulletin-board__textTitle { + display: block; + color: var(--ti-bulletin-board-item-title-color); + margin-bottom: 2px; + font-size: var(--ti-common-font-size-base); + white-space: normal; + font-family: Helvetica, Arial, 'microsoft yahei'; + line-height: initial; +} +.tiny-bulletin-board__item .tiny-bulletin-board__textTitle, +.tiny-bulletin-board__item .tiny-bulletin-board__textTitle:hover { + text-decoration: none; +} +.tiny-bulletin-board__item .tiny-bulletin-board__textDate { + color: var(--ti-bulletin-board-item-date-color); + font-size: var(--ti-bulletin-board-item-date-font-size); +} +.tiny-bulletin-board__title { + font-size: var(--ti-bulletin-board-title-font-size); + padding: 12px 0 8px 24px; + color: var(--ti-bulletin-board-title-color); + font-weight: var(--ti-bulletin-board-title-font-weight); +} +.tiny-bulletin-board__more { + text-align: right; +} +.tiny-bulletin-board__more .tiny-bulletin-board__more-link { + color: var(--ti-bulletin-board-more-color); + font-size: var(--ti-bulletin-board-more-font-size); + line-height: normal; + display: -webkit-inline-box; + display: -ms-inline-flexbox; + display: inline-flex; + -webkit-box-pack: center; + -ms-flex-pack: center; + justify-content: center; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; +} +.tiny-bulletin-board__more .tiny-bulletin-board__more-link .tiny-svg { + fill: var(--ti-bulletin-board-more-color); + font-size: var(--ti-bulletin-board-more-icon-font-size); + margin-left: 4px; +} +.tiny-bulletin-board__more .tiny-bulletin-board__more-link:hover { + text-decoration: none; +} +.tiny-bulletin-board__more .tiny-bulletin-board__more-link:hover .tiny-svg { + fill: var(--ti-bulletin-board-more-hover-color); +} +.tiny-bulletin-board__new { + background-color: var(--ti-bulletin-board-new-background); + color: var(--ti-bulletin-board-new-color); + border-radius: var(--ti-bulletin-board-new-border-radius); + min-width: 30px; + min-height: 16px; + line-height: 16px; + font-size: var(--ti-common-font-size-base); + display: inline-block; + font-family: '瀹嬩綋', cursive, Helvetica, Arial, 'microsoft yahei'; + -webkit-box-sizing: border-box; + box-sizing: border-box; + text-align: center; +} +.tiny-bulletin-board .tiny-tabs .tiny-tabs--left, +.tiny-bulletin-board .tiny-tabs .tiny-tabs--right, +.tiny-bulletin-board .tiny-tabs .tiny-tabs__content, +.tiny-bulletin-board .tiny-tabs .tiny-tabs__nav-scroll, +.tiny-bulletin-board .tiny-tabs .tiny-tabs__nav-wrap { + overflow: hidden; +} +.tiny-bulletin-board .tiny-tabs .tiny-tabs__header .tiny-tabs__nav-wrap { + margin-bottom: -1px; + position: relative; +} +.tiny-bulletin-board .tiny-tabs .tiny-tabs__header .tiny-tabs__nav-wrap:after { + content: ''; + position: absolute; + left: 0; + bottom: 0; + width: 100%; + height: 1px; + background-color: var(--ti-tabs-border-color); + z-index: 1; +} +.tiny-bulletin-board .tiny-tabs .tiny-tabs__header .tiny-tabs__nav-wrap.is-scrollable { + padding: 0 20px; + -webkit-box-sizing: border-box; + box-sizing: border-box; +} +.tiny-bulletin-board .tiny-tabs .tiny-tabs__header .tiny-tabs__nav { + top: 1px; +} +.tiny-bulletin-board .tiny-tabs .tiny-tabs__nav { + white-space: nowrap; + position: relative; + -webkit-transition: -webkit-transform 0.3s; + transition: -webkit-transform 0.3s; + transition: transform 0.3s; + transition: transform 0.3s, -webkit-transform 0.3s; + float: left; + z-index: 2; +} +.tiny-bulletin-board .tiny-tabs .tiny-tabs__item { + line-height: 36px; + height: 36px; + padding: 0 24px; + -webkit-box-sizing: border-box; + box-sizing: border-box; + display: inline-block; + list-style: none; + font-size: var(--ti-common-font-size-1); + font-weight: 500; + color: var(--ti-bulletin-board-tabs-item-color); + position: relative; +} +.tiny-bulletin-board .tiny-tabs .tiny-tabs__item:active, +.tiny-bulletin-board .tiny-tabs .tiny-tabs__item:focus { + outline: 0; +} +.tiny-bulletin-board .tiny-tabs .tiny-tabs__item:hover { + color: var(--ti-bulletin-board-tabs-item-hover-color); + cursor: pointer; +} +.tiny-bulletin-board .tiny-tabs .tiny-tabs__item.is-active { + color: var(--ti-bulletin-board-tabs-item-hover-color); +} +.tiny-bulletin-board .tiny-tabs .tiny-tabs__item.is-disabled { + color: var(--ti-bulletin-board-tabs-item-disabled-color); + cursor: default; +} +.tiny-bulletin-board .tiny-tabs .tiny-tabs__item.is-closable > div { + display: inline-block; +} +.tiny-bulletin-board .tiny-tabs .tiny-tabs__item.is-closable .icon-close { + display: initial; +} +.tiny-bulletin-board .tiny-tabs .tiny-tabs__item .icon-close { + border-radius: 50%; + text-align: center; + -webkit-transition: all 0.3s cubic-bezier(0.645, 0.045, 0.355, 1); + transition: all 0.3s cubic-bezier(0.645, 0.045, 0.355, 1); + margin-left: 5px; +} +.tiny-bulletin-board .tiny-tabs .tiny-tabs__item .icon-close:before { + -webkit-transform: scale(0.9); + transform: scale(0.9); + display: inline-block; +} +.tiny-bulletin-board .tiny-tabs .tiny-tabs__item .icon-close:hover { + background-color: #b4bccc; + color: #fff; +} +.tiny-bulletin-board .tiny-tabs .tiny-tabs__item::before { + bottom: 0; + top: auto !important; + left: auto !important; +} +.tiny-bulletin-board .tiny-tabs .tiny-tabs__content { + padding: 12px 24px 24px; +} +.tiny-bulletin-board .tiny-tabs.tiny-tabs--card .tiny-tabs__header .tiny-tabs__nav { + border: none; +} +.tiny-bulletin-board .tiny-tabs.tiny-tabs--card .tiny-tabs__header .tiny-tabs__item { + border-left: none; +} +.tiny-bulletin-board .tiny-tabs.tiny-tabs--card > .tiny-tabs__header { + border-bottom: 1px solid var(--ti-bulletin-board-tabs-header-border-color); +} +.tiny-bulletin-board .tiny-tabs.tiny-tabs--card > .tiny-tabs__header .tiny-tabs__item { + border-bottom: 1px solid transparent; + -webkit-transition: color 0.3s cubic-bezier(0.645, 0.045, 0.355, 1), padding 0.3s cubic-bezier(0.645, 0.045, 0.355, 1); + transition: color 0.3s cubic-bezier(0.645, 0.045, 0.355, 1), padding 0.3s cubic-bezier(0.645, 0.045, 0.355, 1); +} +.tiny-bulletin-board .tiny-tabs.tiny-tabs--card > .tiny-tabs__header .tiny-tabs__item:first-child { + border-left: none; +} +.tiny-bulletin-board .tiny-tabs.tiny-tabs--card > .tiny-tabs__header .tiny-tabs__item.is-active { + border-bottom-color: #fff; +} +.tiny-bulletin-board .tiny-tabs.tiny-tabs--card > .tiny-tabs__header .tiny-tabs__item.is-active.is-closable { + padding-left: 24px; + padding-right: 24px; +} +.tiny-bulletin-board .tiny-tabs.tiny-tabs--card > .tiny-tabs__header .tiny-tabs__item.is-active:before { + position: absolute; + content: ''; + width: 100%; + height: 3px; + background: var(--ti-bulletin-board-tabs-item-hover-color); + margin-left: -24px; +} +.tiny-button { + --ti-button-radius: var(--ti-common-border-radius-normal); + --ti-button-font-size: var(--ti-common-font-size-base); + --ti-button-plain-disabled-font-color: var(--ti-base-color-common-2); + --ti-button-size-normal-min-width: var(--ti-base-size-width-normal); + --ti-button-size-normal-max-width: var(--ti-base-size-width-medium); + --ti-button-size-normal-height: var(--ti-common-size-7x); + --ti-button-size-normal-padding: var(--ti-common-space-2x); + --ti-button-size-large-min-width: var(--ti-base-size-width-normal); + --ti-button-size-large-max-width: var(--ti-base-size-width-large); + --ti-button-size-large-height: var(--ti-base-size-height-large); + --ti-button-size-large-font-size: var(--ti-common-font-size-2); + --ti-button-size-large-padding: var(--ti-common-space-14); + --ti-button-size-medium-min-width: var(--ti-base-size-width-normal); + --ti-button-size-medium-max-width: var(--ti-base-size-width-large); + --ti-button-size-medium-height: var(--ti-base-size-height-medium); + --ti-button-size-medium-font-size: var(--ti-common-font-size-1); + --ti-button-size-medium-padding: var(--ti-common-space-3x); + --ti-button-size-small-min-width: var(--ti-base-size-width-normal); + --ti-button-size-small-max-width: var(--ti-base-size-width-medium); + --ti-button-size-small-height: var(--ti-base-size-height-small); + --ti-button-size-small-font-size: var(--ti-common-font-size-1); + --ti-button-size-small-padding: var(--ti-common-space-10); + --ti-button-size-mini-min-width: var(--ti-base-size-width-normal); + --ti-button-size-mini-max-width: var(--ti-base-size-width-medium); + --ti-button-size-mini-height: var(--ti-base-size-height-mini); + --ti-button-size-mini-font-size: var(--ti-common-font-size-base); + --ti-button-size-mini-padding: var(--ti-common-space-2x); + --ti-button-normal-color: var(--ti-base-color-common-7); + --ti-button-normal-border-color: var(--ti-base-color-border); + --ti-button-normal-background-color: var(--ti-base-color-light); + --ti-button-normal-hover-color: var(--ti-base-color-brand-6); + --ti-button-normal-hover-border-color: var(--ti-base-color-brand-6); + --ti-button-normal-hover-background-color: var(--ti-base-color-light); + --ti-button-normal-active-color: var(--ti-base-color-brand-6); + --ti-button-normal-active-border-color: var(--ti-base-color-brand-6); + --ti-button-normal-active-background-color: var(--ti-base-color-hover-background); + --ti-button-normal-disabled-color: var(--ti-common-color-text-disabled); + --ti-button-normal-disabled-border-color: var(--ti-common-color-line-disabled); + --ti-button-normal-disabled-background-color: var(--ti-common-color-bg-disabled); + --ti-button-text-color: var(--ti-base-color-brand-6); + --ti-button-text-hover-color: var(--ti-base-color-brand-5); + --ti-button-text-active-color: var(--ti-base-color-primary-active); + --ti-button-text-disabled-color: var(--ti-base-color-placeholder); + --ti-button-primary-normal-color: var(--ti-base-color-primary-normal); + --ti-button-primary-hover-color: var(--ti-base-color-primary-hover); + --ti-button-primary-active-color: var(--ti-base-color-primary-active); + --ti-button-primary-disabled-bgcolor: var(--ti-base-color-primary-disabled); + --ti-button-primary-color: var(--ti-base-color-light); + --ti-button-primary-disabled-color: var(--ti-common-color-text-disabled); + --ti-button-primary-disabled-border-color: var(--ti-base-color-primary-disabled-border); + --ti-button-primary-plain-bgcolor: rgba(24, 144, 255, 0.06); + --ti-button-primary-plain-disabled-bgcolor: rgba(191, 191, 191, 0.1); + --ti-button-success-normal-color: var(--ti-base-color-success-normal); + --ti-button-success-hover-color: var(--ti-base-color-success-hover); + --ti-button-success-active-color: var(--ti-base-color-success-active); + --ti-button-success-disabled-bgcolor: var(--ti-base-color-success-disabled); + --ti-button-success-color: var(--ti-base-color-light); + --ti-button-success-disabled-color: var(--ti-common-color-text-disabled); + --ti-button-success-disabled-border-color: var(--ti-base-color-success-disabled-border); + --ti-button-success-plain-bgcolor: rgba(82, 196, 26, 0.06); + --ti-button-success-plain-disabled-bgcolor: rgba(166, 195, 185, 0.1); + --ti-button-warning-normal-color: var(--ti-base-color-warning-normal); + --ti-button-warning-hover-color: var(--ti-base-color-warning-hover); + --ti-button-warning-active-color: var(--ti-base-color-warning-active); + --ti-button-warning-disabled-bgcolor: var(--ti-base-color-warning-disabled); + --ti-button-warning-color: var(--ti-base-color-light); + --ti-button-warning-disabled-color: var(--ti-common-color-text-disabled); + --ti-button-warning-disabled-border-color: var(--ti-base-color-warning-disabled-border); + --ti-button-warning-plain-bgcolor: rgba(250, 173, 20, 0.06); + --ti-button-warning-plain-disabled-bgcolor: rgba(211, 198, 162, 0.1); + --ti-button-danger-normal-color: var(--ti-base-color-danger-normal); + --ti-button-danger-hover-color: var(--ti-base-color-danger-hover); + --ti-button-danger-active-color: var(--ti-base-color-danger-active); + --ti-button-danger-disabled-bgcolor: var(--ti-base-color-danger-disabled); + --ti-button-danger-color: var(--ti-base-color-light); + --ti-button-danger-disabled-color: var(--ti-common-color-text-disabled); + --ti-button-danger-disabled-border-color: var(--ti-base-color-danger-disabled-border); + --ti-button-danger-plain-bgcolor: rgba(245, 34, 45, 0.06); + --ti-button-danger-plain-disabled-bgcolor: rgba(216, 186, 181, 0.1); + --ti-button-info-normal-color: var(--ti-base-color-info-normal); + --ti-button-info-hover-color: var(--ti-base-color-info-hover); + --ti-button-info-active-color: var(--ti-base-color-info-active); + --ti-button-info-disabled-bgcolor: var(--ti-base-color-info-disabled); + --ti-button-info-color: var(--ti-base-color-light); + --ti-button-info-disabled-color: var(--ti-common-color-text-disabled); + --ti-button-info-disabled-border-color: var(--ti-base-color-info-disabled-border); + --ti-button-info-plain-bgcolor: rgba(51, 51, 51, 0.06); + --ti-button-info-plain-disabled-bgcolor: rgba(191, 191, 191, 0.1); + --ti-button-padding: 0 var(--ti-common-space-5x); + display: inline-block; + -webkit-appearance: none; + -moz-appearance: none; + appearance: none; + text-align: center; + -webkit-box-sizing: border-box; + box-sizing: border-box; + height: var(--ti-button-size-normal-height); + line-height: calc(var(--ti-button-size-normal-height) - 2px); + color: var(--ti-button-normal-color); + fill: var(--ti-button-normal-color); + font-size: var(--ti-button-font-size); + white-space: nowrap; + text-overflow: ellipsis; + cursor: pointer; + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; + border-width: 1px; + border-style: solid; + border-color: var(--ti-button-normal-border-color); + -o-border-image: initial; + border-image: initial; + border-radius: var(--ti-button-radius); + background: var(--ti-button-normal-background-color); + padding: var(--ti-button-padding); + overflow: hidden; + -webkit-transition: border 0.3s ease 0s, color 0.3s ease 0s, background 0.3s ease 0s; + transition: border 0.3s ease 0s, color 0.3s ease 0s, background 0.3s ease 0s; + outline: 0; +} +.tiny-button .tiny-svg { + vertical-align: text-top; +} +.tiny-button > img { + margin-right: 4px; + vertical-align: middle; +} +.tiny-button::-moz-focus-inner { + border: 0; +} +.tiny-button:focus, +.tiny-button:hover { + color: var(--ti-button-normal-hover-color); + fill: var(--ti-button-normal-hover-color); + border-color: var(--ti-button-normal-hover-border-color); + background-color: var(--ti-button-normal-hover-background-color); +} +.tiny-button.is-active, +.tiny-button.is-plain:active, +.tiny-button:active { + color: var(--ti-button-normal-active-color); + fill: var(--ti-button-normal-active-color); + border-color: var(--ti-button-normal-active-border-color); + background-color: var(--ti-button-normal-active-background-color); +} +.tiny-button.is-disabled, +.tiny-button.is-disabled:focus, +.tiny-button.is-disabled:hover { + cursor: not-allowed; + color: var(--ti-button-normal-disabled-color); + fill: var(--ti-button-normal-disabled-color); + border-color: var(--ti-button-normal-disabled-border-color); + background-color: var(--ti-button-normal-disabled-background-color); +} +.tiny-button.is-plain:focus, +.tiny-button.is-plain:hover { + color: var(--ti-button-normal-hover-color); + fill: var(--ti-button-normal-hover-color); + border-color: var(--ti-button-normal-hover-border-color); + background-color: var(--ti-button-normal-hover-background-color); +} +.tiny-button.is-disabled.is-plain, +.tiny-button.is-disabled.is-plain:focus, +.tiny-button.is-disabled.is-plain:hover { + color: var(--ti-button-normal-disabled-color); + fill: var(--ti-button-normal-disabled-color); + border-color: var(--ti-button-normal-disabled-border-color); + background-color: var(--ti-button-normal-disabled-background-color); +} +.tiny-button + .tiny-button { + margin-left: 8px; +} +.tiny-button.is-loading { + position: relative; + pointer-events: none; + overflow: initial; +} +.tiny-button.is-loading:before { + pointer-events: none; + content: ''; + position: absolute; + left: -1px; + top: -1px; + right: -1px; + bottom: -1px; + border-radius: inherit; + background-color: rgba(255, 255, 255, 0.35); +} +.tiny-button.is-loading .tiny-svg { + fill: var(--ti-button-info-color); +} +.tiny-button.is-loading.tiny-button--default .tiny-svg { + fill: var(--ti-button-normal-color); +} +.tiny-button.is-round { + border-radius: calc(var(--ti-button-size-normal-height, 30px) / 2); +} +.tiny-button.is-icon { + display: -webkit-inline-box; + display: -ms-inline-flexbox; + display: inline-flex; + -webkit-box-pack: center; + -ms-flex-pack: center; + justify-content: center; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; +} +.tiny-button:not(.is-circle) .tiny-svg.is-text { + margin-right: 8px; +} +.tiny-button:not(.is-circle).is-loading .tiny-svg { + margin-right: 4px; + margin-top: 2px; +} +.tiny-button.is-circle { + border-radius: 50%; + min-width: var(--ti-button-size-normal-height); + min-height: var(--ti-button-size-normal-height); + line-height: 1; + padding: var(--ti-button-size-normal-padding); +} +.tiny-button.is-circle.tiny-button--large { + min-width: var(--ti-button-size-large-height); + min-height: var(--ti-button-size-large-height); + height: auto; + line-height: 1; + padding: var(--ti-button-size-large-padding); +} +.tiny-button.is-circle.tiny-button--medium { + min-width: var(--ti-button-size-medium-height); + min-height: var(--ti-button-size-medium-height); + height: auto; + line-height: 1; + padding: var(--ti-button-size-medium-padding); +} +.tiny-button.is-circle.tiny-button--small { + min-width: var(--ti-button-size-small-height); + min-height: var(--ti-button-size-small-height); + height: auto; + line-height: 1; + padding: var(--ti-button-size-small-padding); +} +.tiny-button.is-circle.tiny-button--mini { + min-width: var(--ti-button-size-mini-height); + min-height: var(--ti-button-size-mini-height); + height: auto; + line-height: 1; + padding: var(--ti-button-size-mini-padding); +} +.tiny-button.tiny-button--primary { + color: var(--ti-button-primary-color); + fill: var(--ti-button-primary-color); + border-color: var(--ti-button-primary-normal-color); + background-color: var(--ti-button-primary-normal-color); +} +.tiny-button.tiny-button--primary:hover { + color: var(--ti-button-primary-color); + fill: var(--ti-button-primary-color); + border-color: var(--ti-button-primary-hover-color); + background-color: var(--ti-button-primary-hover-color); +} +.tiny-button.tiny-button--primary.is-active, +.tiny-button.tiny-button--primary:active, +.tiny-button.tiny-button--primary:focus { + color: var(--ti-button-primary-color); + fill: var(--ti-button-primary-color); + border-color: var(--ti-button-primary-active-color); + background-color: var(--ti-button-primary-active-color); + outline: 0; +} +.tiny-button.tiny-button--primary.is-disabled, +.tiny-button.tiny-button--primary.is-disabled:active, +.tiny-button.tiny-button--primary.is-disabled:focus, +.tiny-button.tiny-button--primary.is-disabled:hover { + color: var(--ti-button-primary-disabled-color); + fill: var(--ti-button-primary-disabled-color); + border-color: var(--ti-button-primary-disabled-border-color); + background-color: var(--ti-button-primary-disabled-bgcolor); +} +.tiny-button.tiny-button--primary.is-plain { + color: var(--ti-button-primary-normal-color); + fill: var(--ti-button-primary-normal-color); + border-color: var(--ti-button-primary-normal-color); + background-color: var(--ti-button-primary-plain-bgcolor); +} +.tiny-button.tiny-button--primary.is-plain:hover { + color: var(--ti-button-primary-color); + fill: var(--ti-button-primary-color); + border-color: var(--ti-button-primary-normal-color); + background-color: var(--ti-button-primary-normal-color); +} +.tiny-button.tiny-button--primary.is-plain.is-active, +.tiny-button.tiny-button--primary.is-plain:active, +.tiny-button.tiny-button--primary.is-plain:focus { + color: var(--ti-button-primary-color); + fill: var(--ti-button-primary-color); + border-color: var(--ti-button-primary-active-color); + background-color: var(--ti-button-primary-active-color); + outline: 0; +} +.tiny-button.tiny-button--primary.is-plain.is-disabled, +.tiny-button.tiny-button--primary.is-plain.is-disabled:active, +.tiny-button.tiny-button--primary.is-plain.is-disabled:focus, +.tiny-button.tiny-button--primary.is-plain.is-disabled:hover { + color: var(--ti-button-plain-disabled-font-color); + fill: var(--ti-button-primary-disabled-bgcolor); + border-color: var(--ti-button-primary-disabled-bgcolor); + background-color: var(--ti-button-primary-plain-disabled-bgcolor); +} +.tiny-button.tiny-button--success { + color: var(--ti-button-success-color); + fill: var(--ti-button-success-color); + border-color: var(--ti-button-success-normal-color); + background-color: var(--ti-button-success-normal-color); +} +.tiny-button.tiny-button--success:hover { + color: var(--ti-button-success-color); + fill: var(--ti-button-success-color); + border-color: var(--ti-button-success-hover-color); + background-color: var(--ti-button-success-hover-color); +} +.tiny-button.tiny-button--success.is-active, +.tiny-button.tiny-button--success:active, +.tiny-button.tiny-button--success:focus { + color: var(--ti-button-success-color); + fill: var(--ti-button-success-color); + border-color: var(--ti-button-success-active-color); + background-color: var(--ti-button-success-active-color); + outline: 0; +} +.tiny-button.tiny-button--success.is-disabled, +.tiny-button.tiny-button--success.is-disabled:active, +.tiny-button.tiny-button--success.is-disabled:focus, +.tiny-button.tiny-button--success.is-disabled:hover { + color: var(--ti-button-success-disabled-color); + fill: var(--ti-button-success-disabled-color); + border-color: var(--ti-button-success-disabled-border-color); + background-color: var(--ti-button-success-disabled-bgcolor); +} +.tiny-button.tiny-button--success.is-plain { + color: var(--ti-button-success-normal-color); + fill: var(--ti-button-success-normal-color); + border-color: var(--ti-button-success-normal-color); + background-color: var(--ti-button-success-plain-bgcolor); +} +.tiny-button.tiny-button--success.is-plain:hover { + color: var(--ti-button-success-color); + fill: var(--ti-button-success-color); + border-color: var(--ti-button-success-normal-color); + background-color: var(--ti-button-success-normal-color); +} +.tiny-button.tiny-button--success.is-plain.is-active, +.tiny-button.tiny-button--success.is-plain:active, +.tiny-button.tiny-button--success.is-plain:focus { + color: var(--ti-button-success-color); + fill: var(--ti-button-success-color); + border-color: var(--ti-button-success-active-color); + background-color: var(--ti-button-success-active-color); + outline: 0; +} +.tiny-button.tiny-button--success.is-plain.is-disabled, +.tiny-button.tiny-button--success.is-plain.is-disabled:active, +.tiny-button.tiny-button--success.is-plain.is-disabled:focus, +.tiny-button.tiny-button--success.is-plain.is-disabled:hover { + color: var(--ti-button-plain-disabled-font-color); + fill: var(--ti-button-success-disabled-bgcolor); + border-color: var(--ti-button-success-disabled-bgcolor); + background-color: var(--ti-button-success-plain-disabled-bgcolor); +} +.tiny-button.tiny-button--warning { + color: var(--ti-button-warning-color); + fill: var(--ti-button-warning-color); + border-color: var(--ti-button-warning-normal-color); + background-color: var(--ti-button-warning-normal-color); +} +.tiny-button.tiny-button--warning:hover { + color: var(--ti-button-warning-color); + fill: var(--ti-button-warning-color); + border-color: var(--ti-button-warning-hover-color); + background-color: var(--ti-button-warning-hover-color); +} +.tiny-button.tiny-button--warning.is-active, +.tiny-button.tiny-button--warning:active, +.tiny-button.tiny-button--warning:focus { + color: var(--ti-button-warning-color); + fill: var(--ti-button-warning-color); + border-color: var(--ti-button-warning-active-color); + background-color: var(--ti-button-warning-active-color); + outline: 0; +} +.tiny-button.tiny-button--warning.is-disabled, +.tiny-button.tiny-button--warning.is-disabled:active, +.tiny-button.tiny-button--warning.is-disabled:focus, +.tiny-button.tiny-button--warning.is-disabled:hover { + color: var(--ti-button-warning-disabled-color); + fill: var(--ti-button-warning-disabled-color); + border-color: var(--ti-button-warning-disabled-border-color); + background-color: var(--ti-button-warning-disabled-bgcolor); +} +.tiny-button.tiny-button--warning.is-plain { + color: var(--ti-button-warning-normal-color); + fill: var(--ti-button-warning-normal-color); + border-color: var(--ti-button-warning-normal-color); + background-color: var(--ti-button-warning-plain-bgcolor); +} +.tiny-button.tiny-button--warning.is-plain:hover { + color: var(--ti-button-warning-color); + fill: var(--ti-button-warning-color); + border-color: var(--ti-button-warning-normal-color); + background-color: var(--ti-button-warning-normal-color); +} +.tiny-button.tiny-button--warning.is-plain.is-active, +.tiny-button.tiny-button--warning.is-plain:active, +.tiny-button.tiny-button--warning.is-plain:focus { + color: var(--ti-button-warning-color); + fill: var(--ti-button-warning-color); + border-color: var(--ti-button-warning-active-color); + background-color: var(--ti-button-warning-active-color); + outline: 0; +} +.tiny-button.tiny-button--warning.is-plain.is-disabled, +.tiny-button.tiny-button--warning.is-plain.is-disabled:active, +.tiny-button.tiny-button--warning.is-plain.is-disabled:focus, +.tiny-button.tiny-button--warning.is-plain.is-disabled:hover { + color: var(--ti-button-plain-disabled-font-color); + fill: var(--ti-button-warning-disabled-bgcolor); + border-color: var(--ti-button-warning-disabled-bgcolor); + background-color: var(--ti-button-warning-plain-disabled-bgcolor); +} +.tiny-button.tiny-button--danger { + color: var(--ti-button-danger-color); + fill: var(--ti-button-danger-color); + border-color: var(--ti-button-danger-normal-color); + background-color: var(--ti-button-danger-normal-color); +} +.tiny-button.tiny-button--danger:hover { + color: var(--ti-button-danger-color); + fill: var(--ti-button-danger-color); + border-color: var(--ti-button-danger-hover-color); + background-color: var(--ti-button-danger-hover-color); +} +.tiny-button.tiny-button--danger.is-active, +.tiny-button.tiny-button--danger:active, +.tiny-button.tiny-button--danger:focus { + color: var(--ti-button-danger-color); + fill: var(--ti-button-danger-color); + border-color: var(--ti-button-danger-active-color); + background-color: var(--ti-button-danger-active-color); + outline: 0; +} +.tiny-button.tiny-button--danger.is-disabled, +.tiny-button.tiny-button--danger.is-disabled:active, +.tiny-button.tiny-button--danger.is-disabled:focus, +.tiny-button.tiny-button--danger.is-disabled:hover { + color: var(--ti-button-danger-disabled-color); + fill: var(--ti-button-danger-disabled-color); + border-color: var(--ti-button-danger-disabled-border-color); + background-color: var(--ti-button-danger-disabled-bgcolor); +} +.tiny-button.tiny-button--danger.is-plain { + color: var(--ti-button-danger-normal-color); + fill: var(--ti-button-danger-normal-color); + border-color: var(--ti-button-danger-normal-color); + background-color: var(--ti-button-danger-plain-bgcolor); +} +.tiny-button.tiny-button--danger.is-plain:hover { + color: var(--ti-button-danger-color); + fill: var(--ti-button-danger-color); + border-color: var(--ti-button-danger-normal-color); + background-color: var(--ti-button-danger-normal-color); +} +.tiny-button.tiny-button--danger.is-plain.is-active, +.tiny-button.tiny-button--danger.is-plain:active, +.tiny-button.tiny-button--danger.is-plain:focus { + color: var(--ti-button-danger-color); + fill: var(--ti-button-danger-color); + border-color: var(--ti-button-danger-active-color); + background-color: var(--ti-button-danger-active-color); + outline: 0; +} +.tiny-button.tiny-button--danger.is-plain.is-disabled, +.tiny-button.tiny-button--danger.is-plain.is-disabled:active, +.tiny-button.tiny-button--danger.is-plain.is-disabled:focus, +.tiny-button.tiny-button--danger.is-plain.is-disabled:hover { + color: var(--ti-button-plain-disabled-font-color); + fill: var(--ti-button-danger-disabled-bgcolor); + border-color: var(--ti-button-danger-disabled-bgcolor); + background-color: var(--ti-button-danger-plain-disabled-bgcolor); +} +.tiny-button.tiny-button--info { + color: var(--ti-button-info-color); + fill: var(--ti-button-info-color); + border-color: var(--ti-button-info-normal-color); + background-color: var(--ti-button-info-normal-color); +} +.tiny-button.tiny-button--info:hover { + color: var(--ti-button-info-color); + fill: var(--ti-button-info-color); + border-color: var(--ti-button-info-hover-color); + background-color: var(--ti-button-info-hover-color); +} +.tiny-button.tiny-button--info.is-active, +.tiny-button.tiny-button--info:active, +.tiny-button.tiny-button--info:focus { + color: var(--ti-button-info-color); + fill: var(--ti-button-info-color); + border-color: var(--ti-button-info-active-color); + background-color: var(--ti-button-info-active-color); + outline: 0; +} +.tiny-button.tiny-button--info.is-disabled, +.tiny-button.tiny-button--info.is-disabled:active, +.tiny-button.tiny-button--info.is-disabled:focus, +.tiny-button.tiny-button--info.is-disabled:hover { + color: var(--ti-button-info-disabled-color); + fill: var(--ti-button-info-disabled-color); + border-color: var(--ti-button-info-disabled-border-color); + background-color: var(--ti-button-info-disabled-bgcolor); +} +.tiny-button.tiny-button--info.is-plain { + color: var(--ti-button-info-normal-color); + fill: var(--ti-button-info-normal-color); + border-color: var(--ti-button-info-normal-color); + background-color: var(--ti-button-info-plain-bgcolor); +} +.tiny-button.tiny-button--info.is-plain:hover { + color: var(--ti-button-info-color); + fill: var(--ti-button-info-color); + border-color: var(--ti-button-info-normal-color); + background-color: var(--ti-button-info-normal-color); +} +.tiny-button.tiny-button--info.is-plain.is-active, +.tiny-button.tiny-button--info.is-plain:active, +.tiny-button.tiny-button--info.is-plain:focus { + color: var(--ti-button-info-color); + fill: var(--ti-button-info-color); + border-color: var(--ti-button-info-active-color); + background-color: var(--ti-button-info-active-color); + outline: 0; +} +.tiny-button.tiny-button--info.is-plain.is-disabled, +.tiny-button.tiny-button--info.is-plain.is-disabled:active, +.tiny-button.tiny-button--info.is-plain.is-disabled:focus, +.tiny-button.tiny-button--info.is-plain.is-disabled:hover { + color: var(--ti-button-plain-disabled-font-color); + fill: var(--ti-button-info-disabled-bgcolor); + border-color: var(--ti-button-info-disabled-bgcolor); + background-color: var(--ti-button-info-plain-disabled-bgcolor); +} +.tiny-button.tiny-button--text { + color: var(--ti-button-text-color); + font-size: var(--ti-common-font-size-1); + border-color: transparent; + background-color: transparent; +} +.tiny-button.tiny-button--text:hover { + color: var(--ti-button-text-hover-color); + border-color: transparent; + background-color: transparent; +} +.tiny-button.tiny-button--text.is-active, +.tiny-button.tiny-button--text:active, +.tiny-button.tiny-button--text:focus { + color: var(--ti-button-text-active-color); + border-color: transparent; + background-color: transparent; +} +.tiny-button.tiny-button--text.is-disabled, +.tiny-button.tiny-button--text.is-disabled:active, +.tiny-button.tiny-button--text.is-disabled:focus, +.tiny-button.tiny-button--text.is-disabled:hover { + color: var(--ti-button-text-disabled-color); + border-color: transparent; + background-color: transparent; +} +.tiny-button.tiny-button--large { + height: var(--ti-button-size-large-height); + line-height: var(--ti-button-size-large-height); + font-size: var(--ti-button-size-large-font-size); +} +.tiny-button.tiny-button--large.is-round { + border-radius: calc(var(--ti-button-size-large-height) / 2); +} +.tiny-button.tiny-button--large.is-circle { + border-radius: 50%; +} +.tiny-button.tiny-button--medium { + height: var(--ti-button-size-medium-height); + line-height: var(--ti-button-size-medium-height); + font-size: var(--ti-button-size-medium-font-size); +} +.tiny-button.tiny-button--medium.is-round { + border-radius: calc(var(--ti-button-size-medium-height) / 2); +} +.tiny-button.tiny-button--medium.is-circle { + border-radius: 50%; +} +.tiny-button.tiny-button--small { + height: var(--ti-button-size-small-height); + line-height: var(--ti-button-size-small-height); + font-size: var(--ti-button-size-small-font-size); +} +.tiny-button.tiny-button--small.is-round { + border-radius: calc(var(--ti-button-size-small-height) / 2); +} +.tiny-button.tiny-button--small.is-circle { + border-radius: 50%; +} +.tiny-button.tiny-button--mini { + height: var(--ti-button-size-mini-height); + line-height: var(--ti-button-size-mini-height); + font-size: var(--ti-button-size-mini-font-size); +} +.tiny-button.tiny-button--mini.is-round { + border-radius: calc(var(--ti-button-size-mini-height) / 2); +} +.tiny-button.tiny-button--mini.is-circle { + border-radius: 50%; +} +.tiny-icon-loading { + font-size: var(--ti-common-font-size-1); + line-height: 1; + -webkit-animation: rotating 2s linear infinite; + animation: rotating 2s linear infinite; +} +@-webkit-keyframes rotating { + 0% { + -webkit-transform: rotateZ(0); + transform: rotateZ(0); + } + 100% { + -webkit-transform: rotateZ(360deg); + transform: rotateZ(360deg); + } +} +@keyframes rotating { + 0% { + -webkit-transform: rotateZ(0); + transform: rotateZ(0); + } + 100% { + -webkit-transform: rotateZ(360deg); + transform: rotateZ(360deg); + } +} +.tiny-button-group { + --ti-button-group-border-color: var(--ti-base-color-border); + --ti-button-group-border-radius: var(--ti-common-border-radius-normal); + --ti-button-group-hover-border-color: var(--ti-base-color-brand-6); + --ti-button-group-info-border-color: rgba(255, 255, 255, 0.5); + --ti-button-group-disabled-color: var(--ti-common-color-bg-disabled); + --ti-button-group-item-background: var(--ti-base-color-light); + --ti-button-group-item-button-color: var(--ti-base-color-info-normal); + --ti-button-group-item-button-width: var(--ti-base-size-width-normal); + --ti-button-group-item-button-height: var(--ti-base-size-height-minor); + --ti-button-group-item-button-font-size: var(--ti-common-font-size-base); + --ti-button-group-item-button-disabled-background: var(--ti-common-color-bg-disabled); + --ti-button-group-item-button-disabled-border-color: var(--ti-base-color-border); + --ti-button-group-item-button-disabled-color: var(--ti-base-color-placeholder); + --ti-button-group-item-button-hover-background: var(--ti-base-color-brand-5); + --ti-button-group-item-button-hover-color: var(--ti-base-color-light); + --ti-button-group-item-button-plain-color: var(--ti-base-color-brand-6); + --ti-button-group-item-button-plain-background: rgba(24, 144, 255, 0.06); + --ti-button-group-item-button-plain-border-color: var(--ti-base-color-brand-6); + --ti-button-group-item-active-background: var(--ti-base-color-brand-6); + --ti-button-group-item-active-color: var(--ti-base-color-light); + display: inline-block; + vertical-align: middle; +} +.tiny-button-group:after, +.tiny-button-group:before { + content: ''; + display: table; +} +.tiny-button-group:after { + clear: both; +} +.tiny-button-group .tiny-group-item { + display: inline-block; + vertical-align: middle; +} +.tiny-button-group .tiny-group-item li { + line-height: 28px; + background: var(--ti-button-group-item-background); + float: left; + position: relative; +} +.tiny-button-group .tiny-group-item li button { + border: 1px solid var(--ti-button-group-border-color); + display: block; + text-align: center; + color: var(--ti-button-group-item-button-color); + background: var(--ti-button-group-item-background); + min-width: var(--ti-button-group-item-button-width); + height: var(--ti-button-group-item-button-height); + padding: 0 8px; + text-decoration: none; + font-size: var(--ti-button-group-item-button-font-size); + outline: 0; + cursor: pointer; + -webkit-transition: all 0.3s; + transition: all 0.3s; +} +.tiny-button-group .tiny-group-item li button.disabled, +.tiny-button-group .tiny-group-item li button[disabled] { + background: var(--ti-button-group-item-button-disabled-background); + border-color: var(--ti-button-group-item-button-disabled-border-color); + cursor: not-allowed; + color: var(--ti-button-group-item-button-disabled-color); +} +.tiny-button-group .tiny-group-item li button.plain, +.tiny-button-group .tiny-group-item li button[plain] { + background: 0 0; +} +.tiny-button-group .tiny-group-item li:hover { + z-index: 1; +} +.tiny-button-group .tiny-group-item li:hover button:not(.disabled) { + background: var(--ti-button-group-item-button-hover-background); + color: var(--ti-button-group-item-button-hover-color); + border-color: var(--ti-button-group-item-button-hover-background); + outline: 0; +} +.tiny-button-group .tiny-group-item li:hover button:not(.disabled).plain, +.tiny-button-group .tiny-group-item li:hover button:not(.disabled)[plain] { + color: var(--ti-button-group-item-button-plain-color); + background-color: var(--ti-button-group-item-button-plain-background); + border-color: var(--ti-button-group-item-button-plain-border-color); +} +.tiny-button-group .tiny-group-item li.active { + z-index: 1; +} +.tiny-button-group .tiny-group-item li.active:hover button:not(.disabled) { + background: var(--ti-button-group-item-button-hover-background); + border-color: var(--ti-button-group-item-button-hover-background); +} +.tiny-button-group .tiny-group-item li.active:hover button:not(.disabled).plain, +.tiny-button-group .tiny-group-item li.active:hover button:not(.disabled)[plain] { + background-color: var(--ti-button-group-item-button-plain-background); +} +.tiny-button-group .tiny-group-item li.active button:not(.disabled) { + background: var(--ti-button-group-item-active-background); + color: var(--ti-button-group-item-active-color); + border-color: var(--ti-button-group-item-active-background); + outline: 0; +} +.tiny-button-group .tiny-group-item li.active button:not(.disabled).plain, +.tiny-button-group .tiny-group-item li.active button:not(.disabled)[plain] { + color: var(--ti-button-group-item-active-background); + background: 0 0; +} +.tiny-button-group .tiny-group-item li:first-child button { + border-radius: var(--ti-common-border-radius-normal) 0 0 var(--ti-common-border-radius-normal); +} +.tiny-button-group .tiny-group-item li:last-child button { + border-radius: 0 var(--ti-common-border-radius-normal) var(--ti-common-border-radius-normal) 0; +} +.tiny-button-group .tiny-group-item li:not(:last-child) { + margin-right: -1px; +} +.tiny-button-group > .tiny-button { + float: left; + position: relative; +} +.tiny-button-group > .tiny-button + .tiny-button { + margin-left: 0; +} +.tiny-button-group > .tiny-button:first-child { + border-top-right-radius: 0; + border-bottom-right-radius: 0; + border-right-color: var(--ti-button-group-info-border-color); +} +.tiny-button-group > .tiny-button:first-child.tiny-button--default { + border-right-color: var(--ti-button-group-border-color); +} +.tiny-button-group > .tiny-button:first-child.tiny-button--default:active, +.tiny-button-group > .tiny-button:first-child.tiny-button--default:focus, +.tiny-button-group > .tiny-button:first-child.tiny-button--default:hover { + border-right-color: var(--ti-button-group-hover-border-color); + z-index: 1; +} +.tiny-button-group > .tiny-button:last-child { + border-top-left-radius: 0; + border-bottom-left-radius: 0; + border-left-color: var(--ti-button-group-info-border-color); +} +.tiny-button-group > .tiny-button:last-child.tiny-button--default { + border-left-color: var(--ti-button-group-border-color); +} +.tiny-button-group > .tiny-button:last-child.tiny-button--default:active, +.tiny-button-group > .tiny-button:last-child.tiny-button--default:focus, +.tiny-button-group > .tiny-button:last-child.tiny-button--default:hover { + border-left-color: var(--ti-button-group-hover-border-color); + z-index: 1; +} +.tiny-button-group > .tiny-button:first-child:last-child { + border-radius: var(--ti-button-group-border-radius); +} +.tiny-button-group > .tiny-button:first-child:last-child.is-round { + border-radius: calc(var(--ti-button-size-normal-height, 30px) / 2); +} +.tiny-button-group > .tiny-button:first-child:last-child.is-circle { + border-radius: 50%; +} +.tiny-button-group > .tiny-button:not(:first-child):not(:last-child) { + border-radius: 0; + border-left-color: var(--ti-button-group-info-border-color); + border-right-color: var(--ti-button-group-info-border-color); +} +.tiny-button-group > .tiny-button:not(:first-child):not(:last-child).tiny-button--default { + border-left-color: var(--ti-button-group-border-color); + border-right-color: var(--ti-button-group-border-color); +} +.tiny-button-group > .tiny-button:not(:first-child):not(:last-child).tiny-button--default:active, +.tiny-button-group > .tiny-button:not(:first-child):not(:last-child).tiny-button--default:focus, +.tiny-button-group > .tiny-button:not(:first-child):not(:last-child).tiny-button--default:hover { + border-left-color: var(--ti-button-group-hover-border-color); + border-right-color: var(--ti-button-group-hover-border-color); + z-index: 1; +} +.tiny-button-group > .tiny-button:not(:last-child) { + margin-right: -1px; +} +.tiny-button-group > .tiny-button > .tiny-dropdown > .tiny-button { + border-top-left-radius: 0; + border-bottom-left-radius: 0; + border-left-color: var(--ti-button-group-info-border-color); +} +.tiny-transition-zoom-in-top-enter-active, +.tiny-transition-zoom-in-top-leave-active { + opacity: 1; + -webkit-transform: scaleY(1); + transform: scaleY(1); + -webkit-transition: opacity 0.3s cubic-bezier(0.23, 1, 0.32, 1), -webkit-transform 0.3s cubic-bezier(0.23, 1, 0.32, 1); + transition: opacity 0.3s cubic-bezier(0.23, 1, 0.32, 1), -webkit-transform 0.3s cubic-bezier(0.23, 1, 0.32, 1); + transition: transform 0.3s cubic-bezier(0.23, 1, 0.32, 1), opacity 0.3s cubic-bezier(0.23, 1, 0.32, 1); + transition: transform 0.3s cubic-bezier(0.23, 1, 0.32, 1), opacity 0.3s cubic-bezier(0.23, 1, 0.32, 1), + -webkit-transform 0.3s cubic-bezier(0.23, 1, 0.32, 1); + -webkit-transform-origin: center top; + transform-origin: center top; +} +.tiny-transition-zoom-in-top-enter, +.tiny-transition-zoom-in-top-enter-from, +.tiny-transition-zoom-in-top-leave-to { + opacity: 0; + -webkit-transform: scaleY(0); + transform: scaleY(0); + -webkit-transform-origin: center top; + transform-origin: center top; +} +.tiny-calendar { + --ti-calendar-bgcolor: var(--ti-base-color-light); + --ti-calendar-list-item-selected-font-color: var(--ti-base-color-light); + --ti-calendar-hover-color: var(--ti-base-color-brand-5); + --ti-calendar-border-color: var(--ti-base-color-border); + --ti-calendar-color-primary: var(--ti-base-color-brand-6); + --ti-calendar-background-color-primary: rgba(24, 144, 255, 0.1); + --ti-calendar-color-success: var(--ti-base-color-success-normal); + --ti-calendar-color-warning: var(--ti-base-color-warning-normal); + --ti-calendar-color-danger: var(--ti-base-color-bg-8); + --ti-calendar-color-info: var(--ti-base-color-info-normal); + --ti-calendar-tool-width: var(--ti-base-size-width-normal); + --ti-calendar-content-heard-font-size: var(--ti-common-font-size-1); + --ti-calendar-selected-border-radius: var(--ti-base-radius-large); + --ti-calendar-input-height: var(--ti-base-size-height-minor); + --ti-calendar-input-border-radius: var(--ti-common-border-radius-normal); + --ti-calendar-input-font-size: var(--ti-common-font-size-base); + --ti-calendar-list-item-height: var(--ti-base-size-height-minor); + --ti-calendar-list-item-hover-bgcolor: var(--ti-base-color-hover-background); + --ti-calendar-list-item-selected-bgcolor: var(--ti-base-color-selected-background); + --ti-calendar-disabled-color: var(--ti-common-color-text-disabled); + --ti-calendar-disabled-info-color: var(--ti-base-color-bg-5); + --ti-calendar-disabled-success-color: var(--ti-base-color-bg-5); + --ti-calendar-disabled-warning-color: var(--ti-base-color-bg-5); + --ti-calendar-disabled-error-color: var(--ti-base-color-bg-5); + background: var(--ti-calendar-bgcolor); + overflow: hidden; + margin: 10px; +} +.tiny-calendar.is-popover.tiny-popover.tiny-popper { + padding: 0; + margin: 2px 0 0; +} +.tiny-calendar .tiny-calendar__header { + overflow: hidden; + margin-bottom: 12px; +} +.tiny-calendar .tiny-calendar__selected { + border: 1px solid var(--ti-calendar-color-primary); + background: var(--ti-calendar-background-color-primary); + padding: 8px; + color: var(--ti-calendar-color-info); + line-height: 140%; + border-radius: var(--ti-calendar-selected-border-radius); + margin-bottom: 8px; +} +.tiny-calendar .tiny-calendar__tool { + list-style: none; + overflow: hidden; + float: right; + margin-bottom: 8px; +} +.tiny-calendar .tiny-calendar__tool > li { + float: left; + margin-right: 8px; +} +.tiny-calendar .tiny-calendar__tool > li > span { + display: inline-block; +} +.tiny-calendar .tiny-calendar__tool > li:last-child { + margin-left: 16px; + margin-right: 0; +} +.tiny-calendar .tiny-calendar__input { + width: var(--ti-calendar-tool-width); + position: relative; + outline: 0; +} +.tiny-calendar .tiny-calendar__input > input { + width: 100%; + height: var(--ti-calendar-input-height); + line-height: var(--ti-calendar-input-height); + border: 1px solid var(--ti-calendar-border-color); + color: var(--ti-calendar-color-info); + border-radius: var(--ti-calendar-input-border-radius); + background: var(--ti-calendar-bgcolor); + font-size: var(--ti-calendar-input-font-size); + padding: 0 30px 0 8px; + display: block; + white-space: nowrap; + -webkit-transition: border 0.3s; + transition: border 0.3s; + outline: 0; + -webkit-box-sizing: border-box; + box-sizing: border-box; +} +.tiny-calendar .tiny-calendar__input > input.active, +.tiny-calendar .tiny-calendar__input > input:active, +.tiny-calendar .tiny-calendar__input > input:focus, +.tiny-calendar .tiny-calendar__input > input:hover, +.tiny-calendar .tiny-calendar__input > input[active] { + border: 1px solid var(--ti-calendar-color-primary); +} +.tiny-calendar .tiny-calendar__input > input[readonly] { + cursor: not-allowed; +} +.tiny-calendar .tiny-calendar__input-btn { + bottom: 0; + right: 4px; + position: absolute; + top: 0; + outline: 0; + -webkit-box-sizing: border-box; + box-sizing: border-box; + text-align: center; + overflow: hidden; + font-size: var(--ti-common-font-size-base); + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + cursor: pointer; +} +.tiny-calendar .tiny-calendar__input-btn svg { + fill: var(--ti-calendar-color-primary); +} +.tiny-calendar .tiny-calendar__input-btn svg:hover { + fill: var(--ti-calendar-hover-color); +} +.tiny-calendar .tiny-calendar__tabs { + list-style: none; + overflow: hidden; +} +.tiny-calendar .tiny-calendar__tabs > li { + position: relative; + float: left; + width: calc(var(--ti-calendar-tool-width) / 2); + height: var(--ti-calendar-input-height); + line-height: var(--ti-calendar-input-height); + border: 1px solid var(--ti-calendar-border-color); + text-align: center; + font-size: var(--ti-calendar-input-font-size); + font-weight: 500; + color: var(--ti-calendar-color-info); + cursor: pointer; +} +.tiny-calendar .tiny-calendar__tabs > li:first-child { + border-radius: 3px 0 0 3px; +} +.tiny-calendar .tiny-calendar__tabs > li:last-child { + margin-left: -1px; + border-radius: 0 3px 3px 0; +} +.tiny-calendar .tiny-calendar__tabs > li:hover { + color: var(--ti-calendar-color-primary); +} +.tiny-calendar .tiny-calendar__tabs > .active { + color: var(--ti-calendar-color-primary); + border: 1px solid var(--ti-calendar-color-primary); + z-index: 1; +} +.tiny-calendar .tiny-calendar__main { + width: 100%; + overflow: hidden; +} +.tiny-calendar .tiny-calendar__main table { + width: 100%; +} +.tiny-calendar .tiny-calendar__main table > tr > th { + line-height: 18px; + padding: 0 10px 5px 10px; + font-size: var(--ti-calendar-content-heard-font-size); + text-align: right; + width: 14.28571429%; +} +.tiny-calendar .tiny-calendar__main table > tr > td { + text-align: right; + padding: 0 5px 0 0; +} +.tiny-calendar .tiny-calendar__main.year table > tr > td { + width: 33.33333333%; +} +.tiny-calendar .tiny-calendar__day { + border-top: 3px solid var(--ti-calendar-border-color); + margin: 0 3px 5px 3px; + height: 100px; + padding: 5px; +} +.tiny-calendar .tiny-calendar__day.selected { + background: var(--ti-calendar-background-color-primary); +} +.tiny-calendar .tiny-calendar__day.selected .label { + color: var(--ti-calendar-color-primary); +} +.tiny-calendar .tiny-calendar__day:hover { + background: var(--ti-calendar-background-color-primary); +} +.tiny-calendar .tiny-calendar__day.disable { + color: var(--ti-calendar-disabled-color); +} +.tiny-calendar .tiny-calendar__day.disable .info:before { + background: var(--ti-calendar-disabled-info-color); +} +.tiny-calendar .tiny-calendar__day.disable .success:before { + background: var(--ti-calendar-disabled-success-color); +} +.tiny-calendar .tiny-calendar__day.disable .warning:before { + background: var(--ti-calendar-disabled-warning-color); +} +.tiny-calendar .tiny-calendar__day.disable .error:before { + background: var(--ti-calendar-disabled-error-color); +} +.tiny-calendar .tiny-calendar__day.this-month, +.tiny-calendar .tiny-calendar__day.today { + border-color: var(--ti-calendar-color-primary); +} +.tiny-calendar .tiny-calendar__events { + text-align: left; + height: calc(100% - 18px); + overflow-y: auto; +} +.tiny-calendar .tiny-calendar__events .event { + margin: 5px 10px; + cursor: pointer; +} +.tiny-calendar .tiny-calendar__events .event:before { + content: ''; + width: 6px; + height: 6px; + border-radius: 50%; + display: inline-block; + margin-right: 3px; +} +.tiny-calendar .tiny-calendar__events .info:before { + background: var(--ti-calendar-color-info); +} +.tiny-calendar .tiny-calendar__events .success:before { + background: var(--ti-calendar-color-success); +} +.tiny-calendar .tiny-calendar__events .warning:before { + background: var(--ti-calendar-color-warning); +} +.tiny-calendar .tiny-calendar__events .error:before { + background: var(--ti-calendar-color-danger); +} +.tiny-calendar__tip { + display: block; + min-width: 160px; +} +.tiny-calendar__tip-header { + overflow: hidden; + border-bottom: 1px solid rgba(255, 255, 255, 0.5); + padding: 5px 0; + font-size: var(--ti-calendar-content-heard-font-size); +} +.tiny-calendar__tip-year { + float: left; +} +.tiny-calendar__tip-hours { + float: right; +} +.tiny-calendar__tip-title { + margin: 5px 0; + font-weight: 700; +} +.tiny-calendar .tiny-calendar__selector { + width: var(--ti-calendar-tool-width); + max-height: 300px; + overflow-y: auto; + overflow-x: hidden; +} +.tiny-calendar .tiny-calendar__list-item { + min-height: var(--ti-calendar-list-item-height); + line-height: var(--ti-calendar-list-item-height); + max-width: 100%; + overflow: hidden; + text-overflow: ellipsis; + white-space: nowrap; + padding: 0 8px; + color: var(--ti-calendar-color-info); +} +.tiny-calendar .tiny-calendar__list-item:hover { + cursor: pointer; + background: var(--ti-calendar-list-item-hover-bgcolor); +} +.tiny-calendar .tiny-calendar__list-item.is-selected { + background: var(--ti-calendar-list-item-selected-bgcolor); + color: var(--ti-calendar-list-item-selected-font-color); +} +.tiny-cards { + --ti-card-background: var(--ti-base-color-light); + --ti-card-drop-border-color: var(--ti-base-color-brand-6); + border-radius: 0; + background-color: var(--ti-card-background); + overflow: hidden; + position: relative; + -webkit-box-shadow: none; + box-shadow: none; + border: 0; +} +.tiny-cards .tiny-cards_body { + padding: 12px 24px 24px; +} +.tiny-cards.card-layout { + border: none; + border-radius: 0; + overflow: hidden; + -webkit-box-shadow: none; + box-shadow: none; + position: relative; + -webkit-transition: height 0.2s ease; + transition: height 0.2s ease; +} +.tiny-cards.card-layout .tiny-cards_body { + padding: 0; +} +.tiny-cards.card-layout.drop-active { + border: 1px solid var(--ti-card-drop-border-color); + background-color: var(--ti-card-background); +} +.tiny-card-template { + --ti-card-background: var(--ti-base-color-light); + --ti-card-tool-icon-size: 16px; + --ti-card-tool-icon-color: var(--ti-base-color-brand-6); + --ti-card-tool-icon-hover-color: var(--ti-base-color-brand-5); + --ti-card-tool-icon-active-color: var(--ti-base-color-primary-active); + --ti-card-tool-selector-height: var(--ti-common-size-10x); + --ti-card-tool-selector-color: var(--ti-base-color-info-normal); + --ti-card-tool-selector-hover-color: var(--ti-base-color-brand-6); + --ti-card-tool-selector-hover-background: var(--ti-base-color-selected-background); + --ti-card-tool-selector-active-color: var(--ti-base-color-primary-active); + --ti-card-tool-selector-active-background: var(--ti-base-color-selected-background); + --ti-card-header-height: 46px; + --ti-card-header-border-color: var(--ti-base-color-border); + --ti-card-header-title-font-weight: var(--ti-common-font-weight-7); + --ti-card-header-title-font-size: var(--ti-common-font-size-1); + --ti-card-header-title-color: var(--ti-base-color-info-normal); + border-radius: 0; + background-color: var(--ti-card-background); + overflow: hidden; + position: relative; + -webkit-box-shadow: none; + box-shadow: none; + border: 0; +} +.tiny-card-template .tiny-card-template__header { + padding: 0 24px; + height: var(--ti-card-header-height); + line-height: var(--ti-card-header-height); +} +.tiny-card-template .tiny-card-template__header.is-line { + border-bottom: 1px solid var(--ti-card-header-border-color); +} +.tiny-card-template .tiny-card-template__title { + font-weight: var(--ti-card-header-title-font-weight); + font-size: var(--ti-card-header-title-font-size); + color: #333; + color: var(--ti-card-header-title-color); + float: left; +} +.tiny-card-template .tiny-card-template__tools:after, +.tiny-card-template .tiny-card-template__tools:before { + content: ''; + display: table; +} +.tiny-card-template .tiny-card-template__tools:after { + clear: both; +} +.tiny-card-template .tiny-card-template__tools .tiny-icon { + font-size: var(--ti-card-tool-icon-size); + cursor: pointer; +} +.tiny-card-template .tiny-card-template__list { + overflow: hidden; + float: right; +} +.tiny-card-template .tiny-card-template__list > li { + height: var(--ti-card-header-height); + line-height: var(--ti-card-header-height); + float: left; + font-size: var(--ti-common-font-size-2); + margin: 0 12px 0 0; +} +.tiny-card-template .tiny-card-template__list > li svg { + fill: var(--ti-card-tool-icon-color); + cursor: pointer; +} +.tiny-card-template .tiny-card-template__list > li .tiny-icon { + color: var(--ti-card-tool-icon-color); +} +.tiny-card-template .tiny-card-template__list > li .tiny-icon:hover { + color: var(--ti-card-tool-icon-hover-color); +} +.tiny-card-template .tiny-card-template__list > li .tiny-icon:active { + color: var(--ti-card-tool-icon-active-color); +} +.tiny-card-template .tiny-card-template__list > li:last-child { + margin: 0; +} +.tiny-card-template .tiny-card-template__more { + position: absolute; + top: calc(var(--ti-card-header-height, 45px) - 1 * 1px); + right: 5px; + border: 1px solid var(--ti-card-header-border-color); + border-radius: 2px; + -webkit-box-shadow: var(--ti-base-box-shadow); + box-shadow: var(--ti-base-box-shadow); + background: var(--ti-card-background); + color: #333; + color: var(--ti-card-tool-selector-color); + margin-top: 2px; +} +.tiny-card-template .tiny-card-template__more:before { + content: ''; + position: absolute; + display: block; + top: -5px; + right: 21px; + width: 0; + height: 0; + border-style: solid; + border-width: 6px; + border-color: #fff #fff transparent transparent; + -webkit-transform: rotate(-45deg); + transform: rotate(-45deg); + -webkit-box-shadow: 1px -1px 1px rgba(0, 0, 0, 0.2); + box-shadow: 1px -1px 1px rgba(0, 0, 0, 0.2); +} +.tiny-card-template .tiny-card-template__more > ul > li { + height: var(--ti-card-tool-selector-height); + line-height: var(--ti-card-tool-selector-height); + padding: 0 18px; + color: var(--ti-card-tool-selector-color); + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; +} +.tiny-card-template .tiny-card-template__more > ul > li .tiny-icon { + color: var(--ti-card-tool-icon-color); + margin-right: 10px; +} +.tiny-card-template .tiny-card-template__more > ul > li svg { + font-size: var(--ti-common-font-size-2); +} +.tiny-card-template .tiny-card-template__more > ul > li:hover { + cursor: pointer; + color: var(--ti-card-tool-selector-hover-color); + background: var(--ti-card-tool-selector-hover-background); +} +.tiny-card-template .tiny-card-template__more > ul > li:hover .tiny-icon { + color: var(--ti-card-tool-icon-hover-color); +} +.tiny-card-template .tiny-card-template__more > ul > li:active { + color: var(--ti-card-tool-selector-active-color); + background: var(--ti-card-tool-selector-active-background); +} +.tiny-card-template .tiny-card-template__more > ul > li:active .tiny-icon { + color: var(--ti-card-tool-icon-active-color); +} +.tiny-card-template .tiny-card-template__body { + padding: 12px 24px 24px; +} +.tiny-transition-carousel-arrow-left-enter, +.tiny-transition-carousel-arrow-left-enter-from, +.tiny-transition-carousel-arrow-left-leave-to { + opacity: 0; + left: 0; +} +.tiny-transition-carousel-arrow-left-enter-active { + -webkit-animation: animation-left 0.3s; + animation: animation-left 0.3s; +} +.tiny-transition-carousel-arrow-left-leave-active { + animation: animation-left 0.3s reverse; +} +.tiny-transition-carousel-arrow-right-enter, +.tiny-transition-carousel-arrow-right-enter-from, +.tiny-transition-carousel-arrow-right-leave-to { + opacity: 0; + right: 0; +} +.tiny-transition-carousel-arrow-right-enter-active { + -webkit-animation: animation-right 0.3s; + animation: animation-right 0.3s; +} +.tiny-transition-carousel-arrow-right-leave-active { + animation: animation-right 0.3s reverse; +} +@-webkit-keyframes animation-right { + 0% { + opacity: 0; + right: 0; + } + 100% { + opacity: 1; + -webkit-transform: translateY(-50%); + transform: translateY(-50%); + right: 16px; + } +} +@keyframes animation-right { + 0% { + opacity: 0; + right: 0; + } + 100% { + opacity: 1; + -webkit-transform: translateY(-50%); + transform: translateY(-50%); + right: 16px; + } +} +@-webkit-keyframes animation-left { + 0% { + opacity: 0; + left: 0; + } + 100% { + opacity: 1; + -webkit-transform: translateY(-50%); + transform: translateY(-50%); + left: 16px; + } +} +@keyframes animation-left { + 0% { + opacity: 0; + left: 0; + } + 100% { + opacity: 1; + -webkit-transform: translateY(-50%); + transform: translateY(-50%); + left: 16px; + } +} +.tiny-carousel { + --ti-carousel-arrow-height: var(--ti-base-size-height-minor); + --ti-carousel-arrow-width: var(--ti-base-size-width-minor); + --ti-carousel-arrow-font-size: var(--ti-common-font-size-base); + --ti-carousel-arrow-hover-color: rgba(0, 0, 0, 0.6); + --ti-carousel-arrow-background: rgba(0, 0, 0, 0.3); + --ti-carousel-arrow-box-shadow: none; + --ti-carousel-arrow-active-color: var(--ti-base-color-light); + --ti-carousel-indicators-background: rgba(3, 2, 2, 0.3); + --ti-carousel-indicators-radius: 13px; + --ti-carousel-indicators-height: var(--ti-common-size-4x); + --ti-carousel-indicators-radius-background: rgba(0, 0, 0, 0.3); + --ti-carousel-indicator-active-color: var(--ti-base-color-light); + --ti-carousel-indicator-button-width: var(--ti-common-size-2x); + --ti-carousel-indicator-button-height: var(--ti-common-size-2x); + --ti-carousel-indicator-button-color: #bfbfbf; + --ti-carousel-indicator-margin-right: 0; + --ti-carousel-indicator-active-width: var(--ti-common-size-3x); + --ti-carousel-indicator-padding: 0px 2px; + --ti-carousel-indicator-active-transition-property: none; + --ti-carousel-indicator-active-background-color: var(--ti-base-color-transparent); + --ti-carousel-indicator-active-button-width: var(--ti-carousel-indicator-button-width); + --ti-carousel-indicator-active-border-radius: var(--ti-carousel-indicators-radius); + --ti-carousel-indicator-active-transition: none; + --ti-carousel-outside-button-background: var(--ti-base-color-dark); + --ti-carousel-outside-button-active-background: var(--ti-base-color-secondary); + --ti-carousel-labels-button-font-size: var(--ti-common-font-size-base); + --ti-carousel-hover-opacity: 0.6; + overflow: hidden; + position: relative; +} +.tiny-carousel.tiny-carousel--card .tiny-carousel__indicators { + display: none; +} +.tiny-carousel__container { + position: relative; + height: 300px; +} +.tiny-carousel__container .tiny-carousel__arrow { + border: none; + outline: 0; + padding: 0; + margin: 0; + height: var(--ti-carousel-arrow-height); + width: var(--ti-carousel-arrow-width); + cursor: pointer; + -webkit-transition: 0.3s; + transition: 0.3s; + border-radius: 50%; + -webkit-box-shadow: var(--ti-carousel-arrow-box-shadow); + box-shadow: var(--ti-carousel-arrow-box-shadow); + background-color: var(--ti-carousel-arrow-background); + color: var(--ti-carousel-indicator-active-color); + position: absolute; + top: 50%; + z-index: 3; + -webkit-transform: translateY(-50%); + transform: translateY(-50%); + text-align: center; + font-size: var(--ti-carousel-arrow-font-size); + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + -webkit-box-pack: center; + -ms-flex-pack: center; + justify-content: center; +} +.tiny-carousel__container .tiny-carousel__arrow .tiny-svg { + fill: var(--ti-carousel-indicator-active-color); +} +.tiny-carousel__container .tiny-carousel__arrow.tiny-carousel__arrow-left { + left: 16px; +} +.tiny-carousel__container .tiny-carousel__arrow.tiny-carousel__arrow-right { + right: 16px; +} +.tiny-carousel__container .tiny-carousel__arrow:hover { + background-color: var(--ti-carousel-arrow-hover-color); +} +.tiny-carousel__container .tiny-carousel__arrow i { + cursor: pointer; +} +.tiny-carousel .tiny-carousel__indicators { + position: absolute; + list-style: none; + bottom: 8px; + left: 50%; + -webkit-transform: translateX(-50%); + transform: translateX(-50%); + margin: 0; + padding: 0 4px; + z-index: 2; + background: var(--ti-carousel-indicators-background); + border-radius: var(--ti-carousel-indicators-radius); + height: var(--ti-carousel-indicators-height); +} +.tiny-carousel .tiny-carousel__indicators .tiny-carousel__indicator { + display: inline-block; + background-color: transparent; + padding: var(--ti-carousel-indicator-padding); + margin-right: var(--ti-carousel-indicator-margin-right); + cursor: pointer; +} +.tiny-carousel .tiny-carousel__indicators .tiny-carousel__indicator:hover button { + opacity: var(--ti-carousel-hover-opacity); +} +.tiny-carousel .tiny-carousel__indicators .tiny-carousel__indicator.is-active { + width: var(--ti-carousel-indicator-active-width); + background-color: var(--ti-carousel-indicator-active-background-color); + border-radius: var(--ti-carousel-indicator-active-border-radius); + -webkit-transition: var(--ti-carousel-indicator-active-transition); + transition: var(--ti-carousel-indicator-active-transition); +} +.tiny-carousel .tiny-carousel__indicators .tiny-carousel__indicator.is-active button { + -webkit-transition-property: var(--ti-carousel-indicator-active-transition-property); + transition-property: var(--ti-carousel-indicator-active-transition-property); + -webkit-transition-timing-function: cubic-bezier(0.16, 0.75, 0.5, 1); + transition-timing-function: cubic-bezier(0.16, 0.75, 0.5, 1); + border-radius: var(--ti-carousel-indicator-active-border-radius); + background-color: var(--ti-carousel-indicator-active-color); + width: var(--ti-carousel-indicator-active-button-width); +} +.tiny-carousel .tiny-carousel__indicators .tiny-carousel__indicator .tiny-carousel__button { + display: block; + width: var(--ti-carousel-indicator-button-width); + height: var(--ti-carousel-indicator-button-height); + background-color: var(--ti-carousel-indicator-button-color); + border: none; + outline: 0; + padding: 0; + margin: 0; + cursor: pointer; + -webkit-transition: 0.3s; + transition: 0.3s; + border-radius: 50%; +} +.tiny-carousel .tiny-carousel__indicators .tiny-carousel__button._radius { + height: 8px; + width: 8px; + border-radius: 50%; + background-color: var(--ti-carousel-indicators-radius-background); +} +.tiny-carousel .tiny-carousel__indicators.tiny-carousel__indicators-outside { + bottom: 26px; + text-align: center; + position: static; + -webkit-transform: none; + transform: none; + margin-top: 16px; + background: 0 0; +} +.tiny-carousel .tiny-carousel__indicators.tiny-carousel__indicators-outside button { + background-color: var(--ti-carousel-outside-button-background); +} +.tiny-carousel .tiny-carousel__indicators.tiny-carousel__indicators-outside .tiny-carousel__indicator:hover button { + opacity: 0.6; +} +.tiny-carousel .tiny-carousel__indicators.tiny-carousel__indicators-outside .tiny-carousel__indicator.is-active button { + background-color: var(--ti-carousel-outside-button-active-background); +} +.tiny-carousel .tiny-carousel__indicators.tiny-carousel__indicators-labels { + left: 0; + right: 0; + -webkit-transform: none; + transform: none; + text-align: center; +} +.tiny-carousel .tiny-carousel__indicators.tiny-carousel__indicators-labels .tiny-carousel__button { + padding: 2px 18px; + font-size: var(--ti-carousel-labels-button-font-size); +} +.tiny-carousel .tiny-carousel__indicators.tiny-carousel__indicators-labels .tiny-carousel__indicator { + padding: 6px 4px; +} +.tiny-carousel .tiny-carousel__indicators.tiny-carousel__indicators-title { + left: auto; + right: 12px; + bottom: 3px; + -webkit-transform: none; + transform: none; + background: 0 0; +} +.tiny-carousel .tiny-carousel__indicators.tiny-carousel__indicators-vertical { + left: 12px; + right: 0; + bottom: 50%; + width: 16px; + height: 56px; + -webkit-transform: translateY(50%); + transform: translateY(50%); + padding: 2px 4px; +} +.tiny-carousel .tiny-carousel__indicators.tiny-carousel__indicators-vertical .tiny-carousel__indicator { + display: block; + margin: 4px 0; + padding: 0; +} +.tiny-carousel .tiny-carousel__indicators.tiny-carousel__indicators-vertical .tiny-carousel__indicator:first-child { + padding-left: 0; +} +.tiny-carousel .tiny-carousel__indicators.tiny-carousel__indicators-vertical .tiny-carousel__indicator:last-child { + padding-right: 0; +} +.tiny-carousel .tiny-carousel__indicators:not(.tiny-carousel__indicators-vertical) { + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-pack: center; + -ms-flex-pack: center; + justify-content: center; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; +} +.tiny-carousel { + --ti-carousel-item-title-height: var(--ti-base-size-height-small); + --ti-carousel-item-title-color: var(--ti-base-color-light); + --ti-carousel-item-title-background: rgba(0, 0, 0, 0.3); + --ti-carousel-item-title-span-font-size: var(--ti-common-font-size-base); + --ti-carousel-mask-background: var(--ti-base-color-light); +} +.tiny-carousel__item, +.tiny-carousel__mask { + position: absolute; + height: 100%; + top: 0; + left: 0; +} +.tiny-carousel__item { + width: 100%; + display: inline-block; + overflow: hidden; + z-index: 0; +} +.tiny-carousel__item .item-title { + position: absolute; + bottom: 0; + height: var(--ti-carousel-item-title-height); + width: 100%; + line-height: var(--ti-carousel-item-title-height); + color: var(--ti-carousel-item-title-color, #fff); + text-align: left; + background: var(--ti-carousel-item-title-background); +} +.tiny-carousel__item .item-title span { + padding: 0 12px; + font-size: var(--ti-carousel-item-title-span-font-size); + width: 80%; + display: inline-block; + text-overflow: ellipsis; + overflow: hidden; + white-space: nowrap; +} +.tiny-carousel__item.is-active { + z-index: 2; +} +.tiny-carousel__item.is-animating { + -webkit-transition: -webkit-transform 0.4s ease-in-out; + transition: -webkit-transform 0.4s ease-in-out; + transition: transform 0.4s ease-in-out; + transition: transform 0.4s ease-in-out, -webkit-transform 0.4s ease-in-out; +} +.tiny-carousel__item--card { + width: 50%; + -webkit-transition: -webkit-transform 0.4s ease-in-out; + transition: -webkit-transform 0.4s ease-in-out; + transition: transform 0.4s ease-in-out; + transition: transform 0.4s ease-in-out, -webkit-transform 0.4s ease-in-out; +} +.tiny-carousel__item--card.is-in-stage { + cursor: pointer; + z-index: 1; +} +.tiny-carousel__item--card.is-in-stage.is-hover .tiny-carousel__mask, +.tiny-carousel__item--card.is-in-stage:hover .tiny-carousel__mask { + opacity: 0.12; +} +.tiny-carousel__item--card.is-active { + z-index: 2; +} +.tiny-carousel__mask { + width: 100%; + background-color: var(--ti-carousel-mask-background); + opacity: 0.24; + -webkit-transition: 0.2s; + transition: 0.2s; +} +.tiny-cascader { + --ti-cascader-font-size: var(--ti-common-font-size-1); + --ti-cascader-hover-border-color: var(--ti-base-color-common-5); + --ti-cascader-focus-border-color: var(--ti-base-color-brand-6); + --ti-cascader-border-radius: var(--ti-common-border-radius-1); + --ti-cascader-icon-color: #909399; + --ti-cascader-medium-font-size: var(--ti-common-font-size-1); + --ti-cascader-medium-line-height: 36px; + --ti-cascader-small-line-height: 32px; + --ti-cascader-mini-line-height: 28px; + --ti-cascader-small-font-size: 13px; + --ti-cascader-mini-font-size: var(--ti-common-font-size-base, 12px); + --ti-cascader-disabled-color: #c0c4cc; + --ti-cascader-dropdown-background: var(--ti-base-color-light); + --ti-cascader-dropdown-border-color: #e4e7ed; + --ti-cascader-tag-background: #f0f2f5; + --ti-cascader-tag-icon-bgcolor: #c0c4cc; + --ti-cascader-tag-icon-color: var(--ti-base-color-light); + --ti-cascader-tag-icon-hover-bgcolor: #909399; + --ti-cascader-list-color: #606266; + --ti-cascader-item-height: var(--ti-base-size-height-minor); + --ti-cascader-item-hover-background: #f5f7fa; + --ti-cascader-item-checked-color: var(--ti-base-color-brand-5); + --ti-cascader-empty-text-color: #c0c4cc; + --ti-cascader-search-input-color: var(--ti-base-color-info-normal); + --ti-cascader-search-input-placeholder-color: var(--ti-base-color-placeholder); + --ti-cascader-dropdown-box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.1); + --ti-cascader-width: '100%'; + display: inline-block; + position: relative; + font-size: var(--ti-cascader-font-size); +} +.tiny-cascader:not(.is-disabled):hover .tiny-input__inner { + cursor: pointer; + border-color: var(--ti-cascader-hover-border-color); +} +.tiny-cascader .tiny-input { + cursor: pointer; +} +.tiny-cascader .tiny-input .tiny-input__inner { + text-overflow: ellipsis; +} +.tiny-cascader .tiny-input .tiny-input__inner:focus { + border-color: var(--ti-cascader-focus-border-color); +} +.tiny-cascader .tiny-input.is-focus .tiny-input__inner { + border-color: var(--ti-cascader-focus-border-color); +} +.tiny-cascader .tiny-input .tiny-icon-arrow-down { + -webkit-transition: -webkit-transform 0.3s; + transition: -webkit-transform 0.3s; + transition: transform 0.3s; + transition: transform 0.3s, -webkit-transform 0.3s; + font-size: var(--ti-cascader-font-size); +} +.tiny-cascader .tiny-input .tiny-icon-arrow-down.is-reverse { + -webkit-transform: rotateZ(180deg); + transform: rotateZ(180deg); +} +.tiny-cascader .tiny-input .tiny-icon-circle-close:hover { + color: var(--ti-cascader-icon-color); +} +.tiny-cascader--medium { + font-size: var(--ti-cascader-medium-font-size); + line-height: var(--ti-cascader-medium-line-height); +} +.tiny-cascader--small { + font-size: var(--ti-cascader-small-font-size); + line-height: var(--ti-cascader-small-line-height); +} +.tiny-cascader--mini { + font-size: var(--ti-cascader-mini-font-size); + line-height: var(--ti-cascader-mini-line-height); +} +.tiny-cascader.is-disabled .tiny-cascader__label { + z-index: 2; + color: var(--ti-cascader-disabled-color); +} +.tiny-cascader__dropdown { + --ti-cascader-font-size: var(--ti-common-font-size-1); + --ti-cascader-hover-border-color: var(--ti-base-color-common-5); + --ti-cascader-focus-border-color: var(--ti-base-color-brand-6); + --ti-cascader-border-radius: var(--ti-common-border-radius-1); + --ti-cascader-icon-color: #909399; + --ti-cascader-medium-font-size: var(--ti-common-font-size-1); + --ti-cascader-medium-line-height: 36px; + --ti-cascader-small-line-height: 32px; + --ti-cascader-mini-line-height: 28px; + --ti-cascader-small-font-size: 13px; + --ti-cascader-mini-font-size: var(--ti-common-font-size-base, 12px); + --ti-cascader-disabled-color: #c0c4cc; + --ti-cascader-dropdown-background: var(--ti-base-color-light); + --ti-cascader-dropdown-border-color: #e4e7ed; + --ti-cascader-tag-background: #f0f2f5; + --ti-cascader-tag-icon-bgcolor: #c0c4cc; + --ti-cascader-tag-icon-color: var(--ti-base-color-light); + --ti-cascader-tag-icon-hover-bgcolor: #909399; + --ti-cascader-list-color: #606266; + --ti-cascader-item-height: var(--ti-base-size-height-minor); + --ti-cascader-item-hover-background: #f5f7fa; + --ti-cascader-item-checked-color: var(--ti-base-color-brand-5); + --ti-cascader-empty-text-color: #c0c4cc; + --ti-cascader-search-input-color: var(--ti-base-color-info-normal); + --ti-cascader-search-input-placeholder-color: var(--ti-base-color-placeholder); + --ti-cascader-dropdown-box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.1); + --ti-cascader-width: '100%'; + margin: 5px 0; + font-size: var(--ti-cascader-font-size); + background: var(--ti-cascader-dropdown-background); + border: 1px solid var(--ti-cascader-dropdown-border-color); + border-radius: var(--ti-cascader-border-radius); + -webkit-box-shadow: var(--ti-cascader-dropdown-box-shadow); + box-shadow: var(--ti-cascader-dropdown-box-shadow); +} +.tiny-cascader__dropdown.is-auto-size { + background: 0 0; + border: none; + -webkit-box-shadow: none; + box-shadow: none; +} +.tiny-cascader__dropdown.is-auto-size .tiny-cascader-panel { + -webkit-box-pack: start; + -ms-flex-pack: start; + justify-content: flex-start; + -webkit-box-align: start; + -ms-flex-align: start; + align-items: flex-start; +} +.tiny-cascader__dropdown.is-auto-size .tiny-cascader-menu { + border: 1px solid #e4e7ed; + background: #fff; +} +.tiny-cascader__dropdown.is-auto-size .tiny-cascader-menu:not(:first-child) { + margin-left: -1px; +} +.tiny-cascader__dropdown.is-auto-size .tiny-cascader-menu .tiny-cascader-menu__wrap { + height: auto; + padding-bottom: 6px; + max-height: 220px; +} +.tiny-cascader__tags { + position: absolute; + left: 0; + right: 30px; + top: 50%; + -webkit-transform: translateY(-50%); + transform: translateY(-50%); + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -ms-flex-wrap: wrap; + flex-wrap: wrap; + line-height: normal; + text-align: left; + -webkit-box-sizing: border-box; + box-sizing: border-box; +} +.tiny-cascader__tags .tiny-tag { + display: -webkit-inline-box; + display: -ms-inline-flexbox; + display: inline-flex; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + max-width: 100%; + margin: 2px 0 2px 6px; + text-overflow: ellipsis; + background: var(--ti-cascader-tag-background); +} +.tiny-cascader__tags .tiny-tag:not(.is-hit) { + border-color: transparent; +} +.tiny-cascader__tags .tiny-tag > span { + -webkit-box-flex: 1; + -ms-flex: 1; + flex: 1; + overflow: hidden; + text-overflow: ellipsis; +} +@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) { + .tiny-cascader__tags .tiny-tag > span { + -ms-flex-preferred-size: auto; + flex-basis: auto; + } +} +@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) { + .tiny-cascader__tags .tiny-tag .tiny-tag__close { + -ms-flex-negative: 0; + flex-shrink: 0; + } +} +.tiny-cascader__tags .tiny-tag .tiny-icon-close { + -webkit-box-flex: 0; + -ms-flex: none; + flex: none; + background-color: var(--ti-cascader-tag-icon-bgcolor); + color: var(--ti-cascader-tag-icon-color); +} +.tiny-cascader__tags .tiny-tag .tiny-icon-close:hover { + background-color: var(--ti-cascader-tag-icon-hover-bgcolor); +} +.tiny-cascader__suggestion-panel { + border-radius: var(--ti-cascader-border-radius); +} +.tiny-cascader__suggestion-list { + max-height: 204px; + margin: 0; + padding: 6px 0; + font-size: var(--ti-cascader-font-size); + color: var(--ti-cascader-list-color); + text-align: center; +} +.tiny-cascader__suggestion-panel .tiny-cascader__suggestion-item { + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-pack: justify; + -ms-flex-pack: justify; + justify-content: space-between; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + height: var(--ti-cascader-item-height); + padding: 0 8px; + font-size: var(--ti-common-font-size-base); + color: var(--ti-cascader-search-input-color); + text-align: left; + outline: 0; + cursor: pointer; +} +.tiny-cascader__suggestion-panel .tiny-cascader__suggestion-item:focus, +.tiny-cascader__suggestion-panel .tiny-cascader__suggestion-item:hover { + background: var(--ti-cascader-item-hover-background); +} +.tiny-cascader__suggestion-panel .tiny-cascader__suggestion-item.is-checked { + color: var(--ti-cascader-item-checked-color); + font-weight: 700; +} +.tiny-cascader__suggestion-panel .tiny-cascader__suggestion-item.is-checked .icon-check { + fill: var(--ti-cascader-item-checked-color); +} +.tiny-cascader__suggestion-panel .tiny-cascader__suggestion-item > span { + margin-right: 10px; +} +.tiny-cascader__empty-text { + margin: 10px 0; + color: var(--ti-cascader-empty-text-color); +} +.tiny-cascader__search-input { + -webkit-box-flex: 1; + -ms-flex: 1; + flex: 1; + height: 24px; + min-width: 60px; + margin-left: 2px; + padding-left: 8px; + color: var(--ti-cascader-search-input-color); + font-size: var(--ti-common-font-size-base); + border: none; + outline: 0; + -webkit-box-sizing: border-box; + box-sizing: border-box; +} +.tiny-cascader__search-input::-moz-placeholder { + color: var(--ti-cascader-search-input-placeholder-color); + opacity: 1; +} +.tiny-cascader__search-input:-ms-input-placeholder { + color: var(--ti-cascader-search-input-placeholder-color); +} +.tiny-cascader__search-input::-webkit-input-placeholder { + color: var(--ti-cascader-search-input-placeholder-color); +} +.tiny-cascader__search-input::-ms-input-placeholder { + color: var(--ti-cascader-search-input-placeholder-color); +} +.tiny-cascader__search-input::placeholder { + color: var(--ti-cascader-search-input-placeholder-color); +} +.tiny-cascader-multiple { + width: var(--ti-cascader-width); +} +.tiny-cascader-menu { + --ti-cascader-menu-color: var(--ti-base-color-info-normal); + --ti-cascader-menu-border-color: #e4e7ed; + --ti-cascader-menu-empty-text-color: #c0c4cc; + --ti-cascader-menu-list-padding: 0; + --ti-cascader-menu-width: 180px; + min-width: var(--ti-cascader-menu-width); + -webkit-box-sizing: border-box; + box-sizing: border-box; + color: var(--ti-cascader-menu-color); + border-right: solid 1px var(--ti-cascader-menu-border-color); +} +.tiny-cascader-menu:last-child { + border-right: none; +} +.tiny-cascader-menu:last-child .tiny-cascader-node { + padding-right: 20px; +} +.tiny-cascader-menu .tiny-cascader-menu__wrap { + height: 204px; +} +.tiny-cascader-menu .tiny-cascader-menu__list { + position: relative; + min-height: 100%; + margin: 0; + list-style: none; + -webkit-box-sizing: border-box; + box-sizing: border-box; + padding: var(--ti-cascader-menu-list-padding); +} +.tiny-cascader-menu__hover-zone { + position: absolute; + top: 0; + left: 0; + width: 100%; + height: 100%; + pointer-events: none; +} +.tiny-cascader-menu__empty-text { + position: absolute; + top: 50%; + left: 50%; + -webkit-transform: translate(-50%, -50%); + transform: translate(-50%, -50%); + text-align: center; + color: var(--ti-cascader-menu-empty-text-color); +} +.tiny-cascader-node { + --ti-cascader-node-hover-bgcolor: var(--ti-base-color-brand-1); + --ti-cascader-node-hover-color: var(--ti-base-color-brand-6); + --ti-cascader-node-font-color: var(--ti-base-color-white); + --ti-cascader-node-selectable-hover-bgcolor: var(--ti-base-color-selected-background); + --ti-cascader-node-selectable-font-color: var(--ti-base-color-selected-font-color); + --ti-cascader-node-disabled-color: var(--ti-base-color-placeholder); + --ti-cascader-node-icon-font-size: var(--ti-common-font-size-1); + --ti-cascader-node-icon-color: #bfbfbf; + --ti-cascader-node-prefix-display: 'inline-block'; + --ti-cascader-node-label-padding: 0 10px; +} +.tiny-cascader-node.is-selectable.in-active-path { + color: var(--ti-cascader-node-font-color); +} +.tiny-cascader-node.in-active-path, +.tiny-cascader-node.is-active { + background: var(--ti-cascader-node-selectable-hover-bgcolor); + color: var(--ti-cascader-node-selectable-font-color); +} +.tiny-cascader-node.in-active-path, +.tiny-cascader-node.in-active-path:hover, +.tiny-cascader-node.is-active, +.tiny-cascader-node.is-active:hover { + background: var(--ti-cascader-node-selectable-hover-bgcolor); +} +.tiny-cascader-node:not(.is-disabled):not(.in-active-path):not(.is-active):focus, +.tiny-cascader-node:not(.is-disabled):not(.in-active-path):not(.is-active):hover { + background: var(--ti-cascader-node-hover-bgcolor); + color: var(--ti-cascader-node-hover-color); +} +.tiny-cascader-node:not(.is-disabled) { + cursor: pointer; +} +.tiny-cascader-node.is-disabled { + color: var(--ti-cascader-node-disabled-color); + fill: var(--ti-cascader-node-disabled-color); + background-color: var(--ti-cascader-node-disabled-bgcolor); + cursor: not-allowed; +} +.tiny-cascader-node__postfix, +.tiny-cascader-node__prefix { + font-size: var(--ti-cascader-node-icon-font-size); + fill: var(--ti-cascader-node-icon-color); +} +.tiny-cascader-node__prefix { + position: absolute; + left: 10px; + top: 50%; + -webkit-transform: translateY(-50%); + transform: translateY(-50%); + display: var(--ti-cascader-node-prefix-display) !important; +} +.tiny-cascader-node__postfix { + position: absolute; + top: 50%; + right: 10px; + -webkit-transform: translateY(-50%); + transform: translateY(-50%); +} +.tiny-cascader-node__label { + max-width: 360px; + -webkit-box-flex: 1; + -ms-flex: 1; + flex: 1; + padding: var(--ti-cascader-node-label-padding); + white-space: nowrap; + overflow: hidden; + text-overflow: ellipsis; +} +@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) { + .tiny-cascader-node__label { + -ms-flex-preferred-size: auto; + flex-basis: auto; + } +} +.tiny-cascader-node > .tiny-radio { + margin-right: var(--ti-common-space-base); +} +.tiny-cascader-node > .tiny-radio .tiny-radio__label { + padding-left: 0; +} +.tiny-cascader-node > .tiny-checkbox { + margin-right: var(--ti-common-space-base); +} +.tiny-cascader-panel { + --ti-cascader-panel-border-radius: var(--ti-common-border-radius-normal); + --ti-cascader-panel-border-color: var(--ti-base-color-border); + --ti-cascader-panel-font-size: var(--ti-common-font-size-base); + --ti-cascader-panel-node-height: var(--ti-base-size-height-minor); + --ti-cascader-panel-node-gap: 0; + --ti-cascader-panel-node-label-padding: 0 30px 0 20px; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + border-radius: var(--ti-cascader-panel-border-radius); + font-size: var(--ti-cascader-panel-font-size); +} +.tiny-cascader-panel.is-bordered { + border: 1px solid var(--ti-cascader-panel-border-color); + border-radius: var(--ti-cascader-panel-border-radius); +} +.tiny-cascader-panel .tiny-cascader-node { + position: relative; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + padding: var(--ti-cascader-panel-node-label-padding); + height: var(--ti-cascader-panel-node-height); + line-height: var(--ti-cascader-panel-node-height); + outline: 0; + border-radius: var(--ti-common-border-radius-normal); + margin-top: var(--ti-cascader-panel-node-gap); +} +.tiny-chart { + --ti-chart-core-data-empty-color: #888; + --ti-chart-core-data-empty-font-size: var(--ti-common-font-size-1); + --ti-chart-core-data-empty-bgcolor: rgba(255, 255, 255, 0.9); +} +.tiny-chart-data-empty { + position: absolute; + left: 0; + right: 0; + top: 0; + bottom: 0; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-pack: center; + -ms-flex-pack: center; + justify-content: center; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + background-color: var(--ti-chart-core-data-empty-bgcolor); + color: var(--ti-chart-core-data-empty-color); + font-size: var(--ti-chart-core-data-empty-font-size); +} +.tiny-chart-component-loading { + position: absolute; + left: 0; + right: 0; + top: 0; + bottom: 0; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-pack: center; + -ms-flex-pack: center; + justify-content: center; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + background-color: var(--ti-chart-core-data-empty-bgcolor); +} +.tiny-chart-component-loading .circular { + width: 42px; + height: 42px; + -webkit-animation: loading-rotate 2s linear infinite; + animation: loading-rotate 2s linear infinite; +} +.tiny-chart-component-loading .path { + -webkit-animation: loading-dash 1.5s ease-in-out infinite; + animation: loading-dash 1.5s ease-in-out infinite; + stroke-dasharray: 90, 150; + stroke-dashoffset: 0; + stroke-width: 2; + stroke: #20a0ff; + stroke-linecap: round; +} +.tiny-chart-mask-status { + -webkit-filter: blur(1px); + filter: blur(1px); +} +@-webkit-keyframes loading-rotate { + 100% { + -webkit-transform: rotate(360deg); + transform: rotate(360deg); + } +} +@keyframes loading-rotate { + 100% { + -webkit-transform: rotate(360deg); + transform: rotate(360deg); + } +} +@-webkit-keyframes loading-dash { + 0% { + stroke-dasharray: 1, 200; + stroke-dashoffset: 0; + } + 50% { + stroke-dasharray: 90, 150; + stroke-dashoffset: -40px; + } + 100% { + stroke-dasharray: 90, 150; + stroke-dashoffset: -120px; + } +} +@keyframes loading-dash { + 0% { + stroke-dasharray: 1, 200; + stroke-dashoffset: 0; + } + 50% { + stroke-dasharray: 90, 150; + stroke-dashoffset: -40px; + } + 100% { + stroke-dasharray: 90, 150; + stroke-dashoffset: -120px; + } +} +.tiny-checkbox { + --ti-checkbox-font-color: var(--ti-base-color-info-normal); + --ti-checkbox-font-size: var(--ti-common-font-size-base); + --ti-checkbox-background-color: var(--ti-base-color-brand-2); + --ti-checkbox-bg-color: var(--ti-base-color-white); + --ti-checkbox-shadow-color: #dfe1e6; + --ti-checkbox-border-radius: var(--ti-common-border-radius-normal); + --ti-checkbox-hover-color: var(--ti-base-color-common-7); + --ti-checkbox-checked-color: var(--ti-base-color-brand-6); + --ti-checkbox-disabled-color: var(--ti-base-color-placeholder); + --ti-checkbox-disabled-bgcolor: var(--ti-base-color-bg-5); + --ti-checkbox-disabled-border-color: var(--ti-base-color-bg-5); + --ti-checkbox-button-font-color: var(--ti-base-color-info-normal); + --ti-checkbox-button-checked-font-color: var(--ti-base-color-info-normal); + --ti-checkbox-inner-border-color: var(--ti-base-color-light); + --ti-checkbox-bg-color-checked: var(--ti-base-color-brand-6); + --ti-checkbox-border-color-checked: var(--ti-base-color-brand-6); + --ti-checkbox-border-color: var(--ti-common-color-line-normal); + --ti-checkbox-border-color-hover: var(--ti-base-color-brand-6); + --ti-checkbox-icon-height: 8px; + --ti-checkbox-icon-width: 4px; + --ti-checkbox-icon-left: 4.5px; + --ti-checkbox-icon-top: 0; + --ti-checkbox-bg-color-disable: var(--ti-base-color-bg-5); + --ti-checkbox-border-color-unchecked-disabled: var(--ti-base-color-common-1); + --ti-checkbox-label-color-disabled: var(--ti-base-color-common-2); + --ti-checkbox-bg-color-hover: var(--ti-base-color-brand-3); + position: relative; + display: -webkit-inline-box; + display: -ms-inline-flexbox; + display: inline-flex; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + color: var(--ti-checkbox-font-color); + font-weight: 500; + font-size: 0; + white-space: nowrap; + margin-right: 30px; + outline: 0; + cursor: pointer; + -ms-user-select: none; + -webkit-user-select: none; + -o-user-select: none; + -moz-user-select: none; + user-select: none; +} +.tiny-checkbox:last-of-type { + margin-right: 0; +} +.tiny-checkbox.is-bordered { + padding: 9px 20px 9px 10px; + border-radius: 2px; + border: 1px solid var(--ti-checkbox-border-color); + -webkit-box-sizing: border-box; + box-sizing: border-box; + line-height: normal; + height: 40px; +} +.tiny-checkbox.is-bordered + .tiny-checkbox.is-bordered { + margin-left: 10px; +} +.tiny-checkbox.is-bordered.is-checked { + border-color: var(--ti-checkbox-checked-color); +} +.tiny-checkbox.is-bordered.is-disabled { + border-color: var(--ti-checkbox-border-color-unchecked-disabled); + color: var(--ti-checkbox-bg-color-disable); + pointer-events: none; + cursor: not-allowed; +} +.tiny-checkbox.is-bordered.is-disabled .tiny-checkbox__inner, +.tiny-checkbox.is-bordered.is-disabled .tiny-checkbox__inner:hover { + border-color: var(--ti-checkbox-border-color-unchecked-disabled); + cursor: not-allowed; +} +.tiny-checkbox.is-bordered.is-disabled.is-checked { + border-color: var(--ti-checkbox-bg-color-disable); +} +.tiny-checkbox.is-bordered.is-disabled.is-checked .tiny-checkbox__inner, +.tiny-checkbox.is-bordered.is-disabled.is-checked .tiny-checkbox__inner:hover { + background-color: var(--ti-checkbox-bg-color-disable); + border-color: var(--ti-checkbox-bg-color-disable); +} +.tiny-checkbox.is-bordered.is-disabled.is-checked .tiny-checkbox__inner::after, +.tiny-checkbox.is-bordered.is-disabled.is-checked .tiny-checkbox__inner:hover::after { + border-color: var(--ti-checkbox-border-color-unchecked-disabled); +} +.tiny-checkbox.is-bordered.tiny-checkbox--medium { + padding: 7px 20px 7px 10px; + border-radius: 4px; + height: 36px; +} +.tiny-checkbox.is-bordered.tiny-checkbox--medium .tiny-checkbox__label { + line-height: 17px; + font-size: var(--ti-common-font-size-1); +} +.tiny-checkbox.is-bordered.tiny-checkbox--medium .tiny-checkbox__inner { + height: 14px; + width: 14px; +} +.tiny-checkbox.is-bordered.tiny-checkbox--small { + padding: 5px 15px 5px 10px; + border-radius: 3px; + height: 32px; +} +.tiny-checkbox.is-bordered.tiny-checkbox--small .tiny-checkbox__label { + line-height: 15px; + font-size: var(--ti-common-font-size-base); +} +.tiny-checkbox.is-bordered.tiny-checkbox--small .tiny-checkbox__inner { + height: 12px; + width: 12px; +} +.tiny-checkbox.is-bordered.tiny-checkbox--small .tiny-checkbox__inner::after { + height: 6px; + width: 2px; +} +.tiny-checkbox.is-bordered.tiny-checkbox--mini { + padding: 3px 15px 3px 10px; + border-radius: 3px; + height: 28px; +} +.tiny-checkbox.is-bordered.tiny-checkbox--mini .tiny-checkbox__label { + line-height: 12px; + font-size: var(--ti-common-font-size-base); +} +.tiny-checkbox.is-bordered.tiny-checkbox--mini .tiny-checkbox__inner { + height: 12px; + width: 12px; +} +.tiny-checkbox.is-bordered.tiny-checkbox--mini .tiny-checkbox__inner::after { + height: 6px; + width: 2px; +} +.tiny-checkbox__input { + position: relative; + display: inline-block; + white-space: nowrap; + vertical-align: middle; + outline: 0; + line-height: 1; + cursor: pointer; +} +@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) { + .tiny-checkbox__input { + display: inline-block; + } +} +@supports (-ms-ime-align: auto) { + .tiny-checkbox__input { + display: inline-block; + } +} +.tiny-checkbox__input .tiny-checkbox__inner svg { + fill: var(--ti-checkbox-border-color); +} +.tiny-checkbox__input .tiny-checkbox__inner:hover svg { + fill: var(--ti-checkbox-hover-color); +} +.tiny-checkbox__input.is-disabled .tiny-checkbox__inner { + background-color: var(--ti-checkbox-bg-color-disable); + border-color: var(--ti-checkbox-border-color-unchecked-disabled); + cursor: not-allowed; +} +.tiny-checkbox__input.is-disabled .tiny-checkbox__inner svg { + fill: var(--ti-checkbox-border-color-unchecked-disabled); +} +.tiny-checkbox__input.is-disabled .tiny-checkbox__inner + .tiny-checkbox__label { + cursor: not-allowed; +} +.tiny-checkbox__input.is-disabled.is-checked .tiny-checkbox__inner, +.tiny-checkbox__input.is-disabled.is-checked .tiny-checkbox__inner:hover { + background-color: var(--ti-checkbox-label-color-disabled); + border-color: var(--ti-checkbox-label-color-disabled); +} +.tiny-checkbox__input.is-disabled.is-checked .tiny-checkbox__inner::after, +.tiny-checkbox__input.is-disabled.is-checked .tiny-checkbox__inner:hover::after { + border-color: var(--ti-checkbox-bg-color-disable); +} +.tiny-checkbox__input.is-disabled.is-indeterminate .tiny-checkbox__inner, +.tiny-checkbox__input.is-disabled.is-indeterminate .tiny-checkbox__inner:hover { + background-color: var(--ti-checkbox-label-color-disabled); + border-color: var(--ti-checkbox-label-color-disabled); +} +.tiny-checkbox__input.is-disabled.is-indeterminate .tiny-checkbox__inner::before, +.tiny-checkbox__input.is-disabled.is-indeterminate .tiny-checkbox__inner:hover::before { + background-color: var(--ti-checkbox-bg-color-disable); + border-color: var(--ti-checkbox-bg-color-disable); +} +.tiny-checkbox__input.is-disabled + span.tiny-checkbox__label { + color: var(--ti-checkbox-label-color-disabled); + cursor: not-allowed; +} +.tiny-checkbox__input.is-checked .tiny-checkbox__inner::after { + -webkit-transform: rotate(45deg) scaleY(1); + transform: rotate(45deg) scaleY(1); +} +.tiny-checkbox__input.is-indeterminate .tiny-checkbox__inner::before { + content: ''; + position: absolute; + display: block; + border-radius: 1px; + background-color: #fff; + height: 6px; + width: 6px; + left: 0; + right: 0; + top: 0; + bottom: 0; + margin: auto; +} +.tiny-checkbox__input.is-indeterminate .tiny-checkbox__inner::after { + display: none; +} +.tiny-checkbox__input.is-checked .tiny-checkbox__inner, +.tiny-checkbox__input.is-indeterminate .tiny-checkbox__inner { + background-color: var(--ti-checkbox-bg-color-checked); + border-color: var(--ti-checkbox-border-color-checked); +} +.tiny-checkbox__input.is-checked .tiny-checkbox__inner:hover, +.tiny-checkbox__input.is-indeterminate .tiny-checkbox__inner:hover { + background-color: var(--ti-checkbox-bg-color-checked); + border-color: var(--ti-checkbox-border-color-checked); +} +.tiny-checkbox__inner { + display: inline-block; + position: relative; + border: 1px solid var(--ti-checkbox-border-color); + border-radius: var(--ti-common-border-radius-normal); + -webkit-box-sizing: border-box; + box-sizing: border-box; + width: 16px; + height: 16px; + background-color: var(--ti-checkbox-bg-color); + outline: 0; + z-index: 1; + -webkit-transition: border-color 0.25s cubic-bezier(0.71, -0.46, 0.29, 1.46), + background-color 0.25s cubic-bezier(0.71, -0.46, 0.29, 1.46); + transition: border-color 0.25s cubic-bezier(0.71, -0.46, 0.29, 1.46), + background-color 0.25s cubic-bezier(0.71, -0.46, 0.29, 1.46); +} +.tiny-checkbox__inner:hover { + border-color: var(--ti-checkbox-border-color-hover); +} +.tiny-checkbox__inner::after { + -webkit-box-sizing: content-box; + box-sizing: content-box; + content: ''; + border: 1px solid #fff; + border-width: 0 2px 2px 0; + border-left: 0; + border-top: 0; + height: var(--ti-checkbox-icon-height); + width: var(--ti-checkbox-icon-width); + position: absolute; + left: var(--ti-checkbox-icon-left); + top: var(--ti-checkbox-icon-top); + -webkit-transform: rotate(45deg) scaleY(0); + transform: rotate(45deg) scaleY(0); + -webkit-transition: -webkit-transform 0.15s ease-in 50ms; + transition: -webkit-transform 0.15s ease-in 50ms; + transition: transform 0.15s ease-in 50ms; + transition: transform 0.15s ease-in 50ms, -webkit-transform 0.15s ease-in 50ms; + -webkit-transform-origin: center; + transform-origin: center; +} +.tiny-checkbox__original { + opacity: 0; + outline: 0; + position: absolute; + margin: 0; + width: 0; + height: 0; + z-index: -1; +} +.tiny-checkbox__label { + padding-left: 8px; + font-size: var(--ti-checkbox-font-size); +} +.tiny-checkbox-button { + --ti-checkbox-font-color: var(--ti-base-color-info-normal); + --ti-checkbox-font-size: var(--ti-common-font-size-base); + --ti-checkbox-background-color: var(--ti-base-color-brand-2); + --ti-checkbox-bg-color: var(--ti-base-color-white); + --ti-checkbox-shadow-color: #dfe1e6; + --ti-checkbox-border-radius: var(--ti-common-border-radius-normal); + --ti-checkbox-hover-color: var(--ti-base-color-common-7); + --ti-checkbox-checked-color: var(--ti-base-color-brand-6); + --ti-checkbox-disabled-color: var(--ti-base-color-placeholder); + --ti-checkbox-disabled-bgcolor: var(--ti-base-color-bg-5); + --ti-checkbox-disabled-border-color: var(--ti-base-color-bg-5); + --ti-checkbox-button-font-color: var(--ti-base-color-info-normal); + --ti-checkbox-button-checked-font-color: var(--ti-base-color-info-normal); + --ti-checkbox-inner-border-color: var(--ti-base-color-light); + --ti-checkbox-bg-color-checked: var(--ti-base-color-brand-6); + --ti-checkbox-border-color-checked: var(--ti-base-color-brand-6); + --ti-checkbox-border-color: var(--ti-common-color-line-normal); + --ti-checkbox-border-color-hover: var(--ti-base-color-brand-6); + --ti-checkbox-icon-height: 8px; + --ti-checkbox-icon-width: 4px; + --ti-checkbox-icon-left: 4.5px; + --ti-checkbox-icon-top: 0; + --ti-checkbox-bg-color-disable: var(--ti-base-color-bg-5); + --ti-checkbox-border-color-unchecked-disabled: var(--ti-base-color-common-1); + --ti-checkbox-label-color-disabled: var(--ti-base-color-common-2); + --ti-checkbox-bg-color-hover: var(--ti-base-color-brand-3); + position: relative; + display: inline-block; +} +.tiny-checkbox-button:first-child .tiny-checkbox-button__inner { + border-radius: var(--ti-common-border-radius-normal) 0 0 var(--ti-common-border-radius-normal); +} +.tiny-checkbox-button:last-child .tiny-checkbox-button__inner { + border-radius: 0 var(--ti-common-border-radius-normal) var(--ti-common-border-radius-normal) 0; +} +.tiny-checkbox-button.is-checked .tiny-checkbox-button__inner { + color: var(--ti-checkbox-button-checked-font-color); + border-color: var(--ti-checkbox-checked-color); + -webkit-box-shadow: -1px 0 0 0 var(--ti-checkbox-shadow-color); + box-shadow: -1px 0 0 0 var(--ti-checkbox-shadow-color); +} +.tiny-checkbox-button.is-checked:first-child .tiny-checkbox-button__inner { + border-left-color: var(--ti-checkbox-checked-color); + -webkit-box-shadow: none; + box-shadow: none; +} +.tiny-checkbox-button.is-disabled .tiny-checkbox-button__inner { + color: var(--ti-checkbox-disabled-color); + cursor: not-allowed; + background-image: none; + background-color: var(--ti-checkbox-disabled-border-color); + border-color: var(--ti-checkbox-border-color); + -webkit-box-shadow: none; + box-shadow: none; +} +.tiny-checkbox-button.is-disabled:first-child .tiny-checkbox-button__inner { + border-left-color: var(--ti-checkbox-border-color); +} +.tiny-checkbox-button__inner { + position: relative; + display: inline-block; + white-space: nowrap; + vertical-align: middle; + outline: 0; + line-height: 1; + font-weight: 500; + cursor: pointer; + background: var(--ti-checkbox-background-color); + border-left: 0; + border: 1px solid #e9edfa; + color: var(--ti-checkbox-button-font-color); + -webkit-appearance: none; + -moz-appearance: none; + appearance: none; + text-align: center; + -webkit-box-sizing: border-box; + box-sizing: border-box; + margin: 0 2px; + -webkit-transition: all 0.3s cubic-bezier(0.645, 0.045, 0.355, 1); + transition: all 0.3s cubic-bezier(0.645, 0.045, 0.355, 1); + padding: 12px 20px; + font-size: var(--ti-common-font-size-2); + min-width: 80px; + border-radius: 0; + -ms-user-select: none; + -webkit-user-select: none; + -o-user-select: none; + -moz-user-select: none; + user-select: none; +} +.tiny-checkbox-button__inner.is-round { + padding: 12px 20px; +} +.tiny-checkbox-button__inner:hover { + background: var(--ti-checkbox-bg-color-hover); + color: var(--ti-checkbox-hover-color); +} +.tiny-checkbox-button__original { + opacity: 0; + outline: 0; + position: absolute; + margin: 0; + z-index: -1; +} +.tiny-checkbox-button--medium .tiny-checkbox-button__inner { + padding: 10px 20px; + font-size: var(--ti-common-font-size-1); + border-radius: 0; +} +.tiny-checkbox-button--medium .tiny-checkbox-button__inner.is-round { + padding: 10px 20px; +} +.tiny-checkbox-button--small .tiny-checkbox-button__inner { + padding: 8px 15px; + font-size: var(--ti-common-font-size-base); + border-radius: 0; +} +.tiny-checkbox-button--small .tiny-checkbox-button__inner.is-round { + padding: 8px 15px; +} +.tiny-checkbox-button--mini .tiny-checkbox-button__inner { + padding: 5px 15px; + font-size: var(--ti-common-font-size-base); + border-radius: 0; +} +.tiny-checkbox-button--mini .tiny-checkbox-button__inner.is-round { + padding: 5px 15px; +} +.tiny-checkbox-group { + --ti-checkbox-font-color: var(--ti-base-color-info-normal); + --ti-checkbox-font-size: var(--ti-common-font-size-base); + --ti-checkbox-background-color: var(--ti-base-color-brand-2); + --ti-checkbox-bg-color: var(--ti-base-color-white); + --ti-checkbox-shadow-color: #dfe1e6; + --ti-checkbox-border-radius: var(--ti-common-border-radius-normal); + --ti-checkbox-hover-color: var(--ti-base-color-common-7); + --ti-checkbox-checked-color: var(--ti-base-color-brand-6); + --ti-checkbox-disabled-color: var(--ti-base-color-placeholder); + --ti-checkbox-disabled-bgcolor: var(--ti-base-color-bg-5); + --ti-checkbox-disabled-border-color: var(--ti-base-color-bg-5); + --ti-checkbox-button-font-color: var(--ti-base-color-info-normal); + --ti-checkbox-button-checked-font-color: var(--ti-base-color-info-normal); + --ti-checkbox-inner-border-color: var(--ti-base-color-light); + --ti-checkbox-bg-color-checked: var(--ti-base-color-brand-6); + --ti-checkbox-border-color-checked: var(--ti-base-color-brand-6); + --ti-checkbox-border-color: var(--ti-common-color-line-normal); + --ti-checkbox-border-color-hover: var(--ti-base-color-brand-6); + --ti-checkbox-icon-height: 8px; + --ti-checkbox-icon-width: 4px; + --ti-checkbox-icon-left: 4.5px; + --ti-checkbox-icon-top: 0; + --ti-checkbox-bg-color-disable: var(--ti-base-color-bg-5); + --ti-checkbox-border-color-unchecked-disabled: var(--ti-base-color-common-1); + --ti-checkbox-label-color-disabled: var(--ti-base-color-common-2); + --ti-checkbox-bg-color-hover: var(--ti-base-color-brand-3); + display: -webkit-box; + display: -ms-flexbox; + display: flex; +} +.tiny-checkbox-group.is-vertical { + display: inline-block; +} +.tiny-checkbox-group.is-vertical .tiny-checkbox { + display: -webkit-box; + display: -ms-flexbox; + display: flex; + margin-right: 0; +} +.tiny-checkbox-group.is-vertical .tiny-checkbox:not(:last-child) { + margin-bottom: 8px; +} +.tiny-checkbox-group.is-vertical .tiny-checkbox-button { + display: block; +} +.tiny-checkbox-group.is-vertical .tiny-checkbox-button:first-child .tiny-checkbox-button__inner { + border-radius: 2px 2px 0 0; +} +.tiny-checkbox-group.is-vertical .tiny-checkbox-button:last-child .tiny-checkbox-button__inner { + border-radius: 0 0 2px 2px; +} +.tiny-checkbox-group.is-vertical .tiny-checkbox-button.is-checked .tiny-checkbox-button__inner { + -webkit-box-shadow: 0 -1px 0 0 var(--ti-checkbox-shadow-color); + box-shadow: 0 -1px 0 0 var(--ti-checkbox-shadow-color); + border-color: var(--ti-checkbox-checked-color); +} +.tiny-checkbox-group.is-vertical .tiny-checkbox-button.is-checked.is-disabled .tiny-checkbox-button__inner { + -webkit-box-shadow: 0 -1px 0 0 var(--ti-checkbox-border-color); + box-shadow: 0 -1px 0 0 var(--ti-checkbox-border-color); + border-color: var(--ti-checkbox-border-color); + background: var(--ti-checkbox-disabled-bgcolor); +} +.tiny- { + --ti-collapse-border-color: var(--ti-base-color-border); +} +.tiny-fade-in-linear-enter-active, +.tiny-fade-in-linear-leave-active { + -webkit-transition: opacity 0.2s linear; + transition: opacity 0.2s linear; +} +.tiny-fade-in-linear-enter, +.tiny-fade-in-linear-enter-from, +.tiny-fade-in-linear-leave, +.tiny-fade-in-linear-leave-active, +.tiny-fade-in-linear-leave-from { + opacity: 0; +} +.tiny-fade-in-enter-active, +.tiny-fade-in-leave-active { + -webkit-transition: all 0.3s cubic-bezier(0.55, 0, 0.1, 1); + transition: all 0.3s cubic-bezier(0.55, 0, 0.1, 1); +} +.tiny-fade-in-enter, +.tiny-fade-in-enter-from, +.tiny-fade-in-leave-active { + opacity: 0; +} +.tiny-zoom-in-center-enter-active, +.tiny-zoom-in-center-leave-active { + -webkit-transition: all 0.3s cubic-bezier(0.55, 0, 0.1, 1); + transition: all 0.3s cubic-bezier(0.55, 0, 0.1, 1); +} +.tiny-zoom-in-center-enter, +.tiny-zoom-in-center-enter-from, +.tiny-zoom-in-center-leave-active { + opacity: 0; + -webkit-transform: scaleX(0); + transform: scaleX(0); +} +.tiny-zoom-in-top-enter-active, +.tiny-zoom-in-top-leave-active { + opacity: 1; + -webkit-transform: scaleY(1); + transform: scaleY(1); + -webkit-transition: opacity 0.3s cubic-bezier(0.23, 1, 0.32, 1), -webkit-transform 0.3s cubic-bezier(0.23, 1, 0.32, 1); + transition: opacity 0.3s cubic-bezier(0.23, 1, 0.32, 1), -webkit-transform 0.3s cubic-bezier(0.23, 1, 0.32, 1); + transition: transform 0.3s cubic-bezier(0.23, 1, 0.32, 1), opacity 0.3s cubic-bezier(0.23, 1, 0.32, 1); + transition: transform 0.3s cubic-bezier(0.23, 1, 0.32, 1), opacity 0.3s cubic-bezier(0.23, 1, 0.32, 1), + -webkit-transform 0.3s cubic-bezier(0.23, 1, 0.32, 1); + -webkit-transform-origin: center top; + transform-origin: center top; +} +.tiny-zoom-in-top-enter, +.tiny-zoom-in-top-enter-from, +.tiny-zoom-in-top-leave-active { + opacity: 0; + -webkit-transform: scaleY(0); + transform: scaleY(0); +} +.tiny-zoom-in-bottom-enter-active, +.tiny-zoom-in-bottom-leave-active { + opacity: 1; + -webkit-transform: scaleY(1); + transform: scaleY(1); + -webkit-transition: opacity 0.3s cubic-bezier(0.23, 1, 0.32, 1), -webkit-transform 0.3s cubic-bezier(0.23, 1, 0.32, 1); + transition: opacity 0.3s cubic-bezier(0.23, 1, 0.32, 1), -webkit-transform 0.3s cubic-bezier(0.23, 1, 0.32, 1); + transition: transform 0.3s cubic-bezier(0.23, 1, 0.32, 1), opacity 0.3s cubic-bezier(0.23, 1, 0.32, 1); + transition: transform 0.3s cubic-bezier(0.23, 1, 0.32, 1), opacity 0.3s cubic-bezier(0.23, 1, 0.32, 1), + -webkit-transform 0.3s cubic-bezier(0.23, 1, 0.32, 1); + -webkit-transform-origin: center bottom; + transform-origin: center bottom; +} +.tiny-zoom-in-bottom-enter, +.tiny-zoom-in-bottom-leave-active, +.tiny-zoom-in-left-enter-from { + opacity: 0; + -webkit-transform: scaleY(0); + transform: scaleY(0); +} +.tiny-zoom-in-left-enter-active, +.tiny-zoom-in-left-leave-active { + opacity: 1; + -webkit-transform: scale(1, 1); + transform: scale(1, 1); + -webkit-transition: opacity 0.3s cubic-bezier(0.23, 1, 0.32, 1), -webkit-transform 0.3s cubic-bezier(0.23, 1, 0.32, 1); + transition: opacity 0.3s cubic-bezier(0.23, 1, 0.32, 1), -webkit-transform 0.3s cubic-bezier(0.23, 1, 0.32, 1); + transition: transform 0.3s cubic-bezier(0.23, 1, 0.32, 1), opacity 0.3s cubic-bezier(0.23, 1, 0.32, 1); + transition: transform 0.3s cubic-bezier(0.23, 1, 0.32, 1), opacity 0.3s cubic-bezier(0.23, 1, 0.32, 1), + -webkit-transform 0.3s cubic-bezier(0.23, 1, 0.32, 1); + -webkit-transform-origin: top left; + transform-origin: top left; +} +.tiny-zoom-in-left-enter, +.tiny-zoom-in-left-enter-from, +.tiny-zoom-in-left-leave-active { + opacity: 0; + -webkit-transform: scale(0.45, 0.45); + transform: scale(0.45, 0.45); +} +.tiny-list-enter-active, +.tiny-list-leave-active { + -webkit-transition: all 1s; + transition: all 1s; +} +.tiny-list-enter, +.tiny-list-enter-from, +.tiny-list-leave-active { + opacity: 0; + -webkit-transform: translateY(-30px); + transform: translateY(-30px); +} +.tiny-opacity-transition { + -webkit-transition: opacity 0.3s cubic-bezier(0.55, 0, 0.1, 1); + transition: opacity 0.3s cubic-bezier(0.55, 0, 0.1, 1); +} +.collapse-transition { + -webkit-transition: 0.3s height ease-in-out, 0.3s padding-top ease-in-out, 0.3s padding-bottom ease-in-out; + transition: 0.3s height ease-in-out, 0.3s padding-top ease-in-out, 0.3s padding-bottom ease-in-out; +} +.horizontal-collapse-transition { + -webkit-transition: 0.3s width ease-in-out, 0.3s padding-left ease-in-out, 0.3s padding-right ease-in-out; + transition: 0.3s width ease-in-out, 0.3s padding-left ease-in-out, 0.3s padding-right ease-in-out; +} +.fade-in-linear-enter, +.fade-in-linear-enter-from, +.fade-in-linear-leave, +.fade-in-linear-leave-active, +.fade-in-linear-leave-from { + opacity: 0; +} +.fade-in-linear-enter-active, +.fade-in-linear-leave-active { + -webkit-transition: opacity 0.2s linear; + transition: opacity 0.2s linear; +} +.tiny-collapse-item { + --ti-collapse-item-color: var(--ti-base-color-info-normal); + --ti-collapse-item-icon-color: var(--ti-common-color-icon-normal); + --ti-collapse-item-bgcolor: var(--ti-base-color-light); + --ti-collapse-item-border-color: var(--ti-base-color-border); + --ti-collapse-item-disabled-color: var(--ti-base-color-placeholder); + --ti-collapse-item-header-font-size: var(--ti-common-font-size-base); + --ti-collapse-item-header-focus-color: var(--ti-base-color-brand-5); + --ti-collapse-item-arrow-font-size: var(--ti-common-font-size-base); + --ti-collapse-item-arrow-hover-color: var(--ti-base-color-info-normal); + --ti-collapse-item-content-font-size: var(--ti-common-font-size-base); + --ti-collapse-item-header-bgcolor: var(--ti-base-color-brand-1); + --ti-collapse-item-space-between: var(--ti-common-space-2x); + --ti-collapse-item-bg-color: var(--ti-common-color-bg-white-normal); + --ti-collapse-item-border: 1px solid var(--ti-common-color-line-dividing); + --ti-collapse-item-border-radius: var(--ti-common-border-radius-normal); + --ti-collapse-item-icon-fs: var(--ti-common-font-size-2); + --ti-collapse-item-header-padding: 0 var(--ti-common-space-4x); + --ti-collapse-item-content-border-top: 1px solid var(--ti-common-color-line-dividing); + margin-top: var(--ti-collapse-item-space-between); + background-color: var(--ti-collapse-item-bg-color); + border: var(--ti-collapse-item-border); + border-radius: var(--ti-collapse-item-border-radius); +} +.tiny-collapse-item:last-child { + margin-bottom: -1px; +} +.tiny-collapse-item.is-disabled .tiny-collapse-item__header { + color: var(--ti-collapse-item-disabled-color); + cursor: not-allowed; +} +.tiny-collapse-item.is-disabled .tiny-collapse-item__arrow { + fill: var(--ti-collapse-item-disabled-color); +} +.tiny-collapse-item__header { + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + height: 34px; + line-height: 34px; + background-color: var(--ti-collapse-item-header-bgcolor); + color: var(--ti-collapse-item-color); + font-size: var(--ti-collapse-item-header-font-size); + font-family: Helvetica, Arial, 'microsoft yahei'; + outline: 0; + cursor: pointer; + -webkit-transition: border-bottom-color 0.3s; + transition: border-bottom-color 0.3s; + border-radius: var(--ti-common-border-radius-normal); + padding: var(--ti-collapse-item-header-padding); +} +.tiny-collapse-item__header.focusing:focus:not(:hover) { + color: var(--ti-collapse-item-header-focus-color); +} +.tiny-collapse-item__header.is-active { + border-bottom-color: transparent; +} +.tiny-collapse-item__header svg { + font-size: var(--ti-collapse-item-icon-fs); + fill: var(--ti-collapse-item-icon-color); +} +.tiny-collapse-item__arrow { + font-size: var(--ti-collapse-item-arrow-font-size); + margin-right: 12px; + -webkit-box-ordinal-group: 0; + -ms-flex-order: -1; + order: -1; + -webkit-transition: -webkit-transform 0.3s; + transition: -webkit-transform 0.3s; + transition: transform 0.3s; + transition: transform 0.3s, -webkit-transform 0.3s; + -webkit-transform: rotate(90deg); + transform: rotate(90deg); +} +.tiny-collapse-item__arrow.is-active { + -webkit-transform: rotate(-90deg); + transform: rotate(-90deg); +} +.tiny-collapse-item__arrow.is-active, +.tiny-collapse-item__arrow:hover { + fill: var(--ti-collapse-item-arrow-hover-color); +} +.tiny-collapse-item__wrap { + will-change: height; + background-color: var(--ti-collapse-item-bgcolor); + overflow: hidden; + -webkit-box-sizing: border-box; + box-sizing: border-box; +} +.tiny-collapse-item__content { + padding: 12px 16px; + font-size: var(--ti-collapse-item-content-font-size); + color: var(--ti-collapse-item-color); + border-top: var(--ti-collapse-item-content-border-top); + line-height: 1.76923077; +} +.tiny-container .tiny-container__aside, +.tiny-container .tiny-container__footer, +.tiny-container .tiny-container__header, +.tiny-container .tiny-container__main { + position: absolute; + -webkit-box-sizing: border-box; + box-sizing: border-box; + top: 0; + left: 0; + bottom: 0; + right: 0; + margin: 0; +} +.tiny-container .tiny-container__main { + overflow-y: auto; +} +.tiny-container .tiny-container__footer { + top: auto; + width: auto; +} +.credit-card-item { + max-width: 430px; + height: 270px; + margin-left: auto; + margin-right: auto; + position: relative; + z-index: 2; + width: 100%; +} +@media screen and (max-width: 480px) { + .credit-card-item { + max-width: 310px; + height: 220px; + width: 90%; + } +} +@media screen and (max-width: 360px) { + .credit-card-item { + height: 180px; + } +} +.credit-card-item.-active .credit-card-item__side.-front { + -webkit-transform: perspective(1000px) rotateY(180deg) rotateX(0) rotateZ(0); + transform: perspective(1000px) rotateY(180deg) rotateX(0) rotateZ(0); +} +.credit-card-item.-active .credit-card-item__side.-back { + -webkit-transform: perspective(1000px) rotateY(0) rotateX(0) rotateZ(0); + transform: perspective(1000px) rotateY(0) rotateX(0) rotateZ(0); +} +.credit-card-item__focus { + position: absolute; + z-index: 3; + border-radius: 5px; + left: 0; + top: 0; + width: 100%; + height: 100%; + -webkit-transition: all 0.35s cubic-bezier(0.71, 0.03, 0.56, 0.85); + transition: all 0.35s cubic-bezier(0.71, 0.03, 0.56, 0.85); + opacity: 0; + pointer-events: none; + overflow: hidden; + border: 2px solid rgba(255, 255, 255, 0.65); +} +.credit-card-item__focus:after { + content: ''; + position: absolute; + top: 0; + left: 0; + width: 100%; + background: #08142f; + height: 100%; + border-radius: 5px; + -webkit-filter: blur(25px); + filter: blur(25px); + opacity: 0.5; +} +.credit-card-item__focus.-active { + opacity: 1; +} +.credit-card-item__side { + border-radius: 15px; + overflow: hidden; + -webkit-box-shadow: 0 20px 60px 0 rgba(14, 42, 90, 0.55); + box-shadow: 0 20px 60px 0 rgba(14, 42, 90, 0.55); + -webkit-transform: perspective(2000px) rotateY(0) rotateX(0) rotate(0); + transform: perspective(2000px) rotateY(0) rotateX(0) rotate(0); + -webkit-transform-style: preserve-3d; + transform-style: preserve-3d; + -webkit-transition: all 0.8s cubic-bezier(0.71, 0.03, 0.56, 0.85); + transition: all 0.8s cubic-bezier(0.71, 0.03, 0.56, 0.85); + -webkit-backface-visibility: hidden; + backface-visibility: hidden; + height: 100%; +} +.credit-card-item__side.-back { + position: absolute; + top: 0; + left: 0; + width: 100%; + -webkit-transform: perspective(2000px) rotateY(-180deg) rotateX(0) rotate(0); + transform: perspective(2000px) rotateY(-180deg) rotateX(0) rotate(0); + z-index: 2; + padding: 0; + height: 100%; +} +.credit-card-item__side.-back .credit-card-item__cover { + -webkit-transform: rotateY(-180deg); + transform: rotateY(-180deg); +} +.credit-card-item__bg { + max-width: 100%; + display: block; + max-height: 100%; + height: 100%; + width: 100%; + -o-object-fit: cover; + object-fit: cover; +} +.credit-card-item__cover { + position: absolute; + height: 100%; + background-color: #1c1d27; + background-image: linear-gradient(147deg, #354fce 0, #0c296b 74%); + left: 0; + top: 0; + width: 100%; + border-radius: 15px; + overflow: hidden; +} +.credit-card-item__cover:after { + content: ''; + position: absolute; + left: 0; + top: 0; + width: 100%; + height: 100%; + background: rgba(6, 2, 29, 0.45); +} +.credit-card-item__top { + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-align: start; + -ms-flex-align: start; + align-items: flex-start; + -webkit-box-pack: justify; + -ms-flex-pack: justify; + justify-content: space-between; + margin-bottom: 40px; + padding: 0 10px; +} +@media screen and (max-width: 480px) { + .credit-card-item__top { + margin-bottom: 25px; + } +} +@media screen and (max-width: 360px) { + .credit-card-item__top { + margin-bottom: 15px; + } +} +.credit-card-item__chip { + width: 60px; +} +@media screen and (max-width: 480px) { + .credit-card-item__chip { + width: 50px; + } +} +@media screen and (max-width: 360px) { + .credit-card-item__chip { + width: 40px; + } +} +.credit-card-item__type { + height: 45px; + position: relative; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-pack: end; + -ms-flex-pack: end; + justify-content: flex-end; + max-width: 100px; + margin-left: auto; + width: 100%; +} +@media screen and (max-width: 480px) { + .credit-card-item__type { + height: 40px; + max-width: 90px; + } +} +@media screen and (max-width: 360px) { + .credit-card-item__type { + height: 30px; + } +} +.credit-card-item__typeImg { + max-width: 100%; + -o-object-fit: contain; + object-fit: contain; + max-height: 100%; + -o-object-position: top right; + object-position: top right; +} +.credit-card-item__info { + color: #fff; + width: 100%; + max-width: calc(100% - 85px); + padding: 10px 15px; + font-weight: 500; + display: block; + cursor: pointer; +} +@media screen and (max-width: 480px) { + .credit-card-item__info { + padding: 10px; + } +} +.credit-card-item__holder { + opacity: 0.7; + font-size: 13px; + margin-bottom: 6px; +} +@media screen and (max-width: 480px) { + .credit-card-item__holder { + font-size: var(--ti-common-font-size-base); + margin-bottom: 5px; + } +} +.credit-card-item__wrapper { + padding: 25px 15px; + position: relative; + z-index: 4; + height: 100%; + text-shadow: 7px 6px 10px rgba(14, 42, 90, 0.8); + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; +} +@media screen and (max-width: 480px) { + .credit-card-item__wrapper { + padding: 20px 10px; + } +} +.credit-card-item__name { + font-size: var(--ti-common-font-size-3); + line-height: 1; + white-space: nowrap; + max-width: 100%; + overflow: hidden; + text-overflow: ellipsis; + text-transform: uppercase; +} +@media screen and (max-width: 480px) { + .credit-card-item__name { + font-size: var(--ti-common-font-size-2); + } +} +.credit-card-item__nameItem { + display: inline-block; + min-width: 8px; + position: relative; +} +.credit-card-item__number { + font-weight: 500; + line-height: 1; + color: #fff; + font-size: 27px; + margin-bottom: 25px; + display: inline-block; + padding: 10px 15px; + cursor: pointer; +} +@media screen and (max-width: 480px) { + .credit-card-item__number { + font-size: 21px; + margin-bottom: 15px; + padding: 10px 10px; + } +} +@media screen and (max-width: 360px) { + .credit-card-item__number { + font-size: 19px; + margin-bottom: 10px; + padding: 10px 10px; + } +} +.credit-card-item__numberItem { + width: 16px; + display: inline-block; +} +.credit-card-item__numberItem.-active { + width: 30px; +} +@media screen and (max-width: 480px) { + .credit-card-item__numberItem { + width: 13px; + } + .credit-card-item__numberItem.-active { + width: 16px; + } +} +@media screen and (max-width: 360px) { + .credit-card-item__numberItem { + width: 12px; + } + .credit-card-item__numberItem.-active { + width: 8px; + } +} +.credit-card-item__content { + color: #fff; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-align: start; + -ms-flex-align: start; + align-items: flex-start; +} +.credit-card-item__date { + -ms-flex-wrap: wrap; + flex-wrap: wrap; + font-size: var(--ti-common-font-size-3); + margin-left: auto; + padding: 10px; + display: -webkit-inline-box; + display: -ms-inline-flexbox; + display: inline-flex; + width: 80px; + white-space: nowrap; + -ms-flex-negative: 0; + flex-shrink: 0; + cursor: pointer; +} +@media screen and (max-width: 480px) { + .credit-card-item__date { + font-size: var(--ti-common-font-size-2); + } +} +.credit-card-item__dateItem { + position: relative; +} +.credit-card-item__dateItem span { + width: 22px; + display: inline-block; +} +.credit-card-item__dateTitle { + opacity: 0.7; + font-size: 13px; + padding-bottom: 6px; + width: 100%; +} +@media screen and (max-width: 480px) { + .credit-card-item__dateTitle { + font-size: var(--ti-common-font-size-base); + padding-bottom: 5px; + } +} +.credit-card-item__band { + background: rgba(0, 0, 19, 0.8); + width: 100%; + height: 50px; + margin-top: 30px; + position: relative; + z-index: 2; +} +@media screen and (max-width: 480px) { + .credit-card-item__band { + margin-top: 20px; + } +} +@media screen and (max-width: 360px) { + .credit-card-item__band { + height: 40px; + margin-top: 10px; + } +} +.credit-card-item__cvv { + text-align: right; + position: relative; + z-index: 2; + padding: 15px; +} +.credit-card-item__cvv .credit-card-item__type { + opacity: 0.7; +} +@media screen and (max-width: 360px) { + .credit-card-item__cvv { + padding: 10px 15px; + } +} +.credit-card-item__cvvTitle { + padding-right: 10px; + font-size: 15px; + font-weight: 500; + color: #fff; + margin-bottom: 5px; +} +.credit-card-item__cvvBand { + height: 45px; + background: #fff; + margin-bottom: 30px; + text-align: right; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + -webkit-box-pack: end; + -ms-flex-pack: end; + justify-content: flex-end; + padding-right: 10px; + color: #1a3b5d; + font-size: var(--ti-common-font-size-3); + border-radius: 4px; + -webkit-box-shadow: 0 10px 20px -7px rgba(32, 56, 117, 0.35); + box-shadow: 0 10px 20px -7px rgba(32, 56, 117, 0.35); +} +@media screen and (max-width: 480px) { + .credit-card-item__cvvBand { + height: 40px; + margin-bottom: 20px; + } +} +@media screen and (max-width: 360px) { + .credit-card-item__cvvBand { + margin-bottom: 15px; + } +} +.credit-card-form { + max-width: 570px; + margin: auto; + width: 100%; + font-family: arial; +} +@media screen and (max-width: 576px) { + .credit-card-form { + margin: 0 auto; + } +} +.credit-card-form__inner { + background: #fff; + -webkit-box-shadow: 0 30px 60px 0 rgba(90, 116, 148, 0.4); + box-shadow: 0 30px 60px 0 rgba(90, 116, 148, 0.4); + border-radius: 10px; + padding: 35px; + padding-top: 180px; +} +@media screen and (max-width: 480px) { + .credit-card-form__inner { + padding: 25px; + padding-top: 165px; + } +} +@media screen and (max-width: 360px) { + .credit-card-form__inner { + padding: 15px; + padding-top: 165px; + } +} +.credit-card-form__row { + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-align: start; + -ms-flex-align: start; + align-items: flex-start; +} +@media screen and (max-width: 480px) { + .credit-card-form__row { + -ms-flex-wrap: wrap; + flex-wrap: wrap; + } +} +.credit-card-form__col { + -webkit-box-flex: 1; + -ms-flex: auto; + flex: auto; + margin-right: 35px; +} +.credit-card-form__col:last-child { + margin-right: 0; +} +@media screen and (max-width: 480px) { + .credit-card-form__col { + margin-right: 0; + -webkit-box-flex: unset; + -ms-flex: unset; + flex: unset; + width: 100%; + margin-bottom: 20px; + } + .credit-card-form__col:last-child { + margin-bottom: 0; + } +} +.credit-card-form__col.-cvv { + max-width: 150px; +} +@media screen and (max-width: 480px) { + .credit-card-form__col.-cvv { + max-width: initial; + } +} +.credit-card-form__group { + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-align: start; + -ms-flex-align: start; + align-items: flex-start; + -ms-flex-wrap: wrap; + flex-wrap: wrap; +} +.credit-card-form__group .credit-card-input__input { + -webkit-box-flex: 1; + -ms-flex: 1; + flex: 1; + margin-right: 15px; + outline: 0; +} +.credit-card-form__group .credit-card-input__input:last-child { + margin-right: 0; +} +.credit-card-form__group select::-ms-expand { + display: none; +} +.credit-card-form__button { + width: 100%; + height: 55px; + background: #2364d2; + border: none; + border-radius: 5px; + font-size: 22px; + font-weight: 500; + -webkit-box-shadow: 3px 10px 20px 0 rgba(35, 100, 210, 0.3); + box-shadow: 3px 10px 20px 0 rgba(35, 100, 210, 0.3); + color: #fff; + margin-top: 20px; + cursor: pointer; +} +@media screen and (max-width: 480px) { + .credit-card-form__button { + margin-top: 10px; + } +} +.credit-card-item { + max-width: 430px; + height: 270px; + margin-left: auto; + margin-right: auto; + position: relative; + z-index: 2; + width: 100%; +} +@media screen and (max-width: 480px) { + .credit-card-item { + max-width: 310px; + height: 220px; + width: 90%; + } +} +@media screen and (max-width: 360px) { + .credit-card-item { + height: 180px; + } +} +.credit-card-item.-active .card-item__side.-front { + -webkit-transform: perspective(1000px) rotateY(180deg) rotateX(0) rotateZ(0); + transform: perspective(1000px) rotateY(180deg) rotateX(0) rotateZ(0); +} +.credit-card-item.-active .card-item__side.-back { + -webkit-transform: perspective(1000px) rotateY(0) rotateX(0) rotateZ(0); + transform: perspective(1000px) rotateY(0) rotateX(0) rotateZ(0); +} +.credit-card-item__focus { + position: absolute; + z-index: 3; + border-radius: 5px; + left: 0; + top: 0; + width: 100%; + height: 100%; + -webkit-transition: all 0.35s cubic-bezier(0.71, 0.03, 0.56, 0.85); + transition: all 0.35s cubic-bezier(0.71, 0.03, 0.56, 0.85); + opacity: 0; + pointer-events: none; + overflow: hidden; + border: 2px solid rgba(255, 255, 255, 0.65); +} +.credit-card-item__focus:after { + content: ''; + position: absolute; + top: 0; + left: 0; + width: 100%; + background: #08142f; + height: 100%; + border-radius: 5px; + -webkit-filter: blur(25px); + filter: blur(25px); + opacity: 0.5; +} +.credit-card-item__focus.-active { + opacity: 1; +} +.credit-card-item__side { + border-radius: 15px; + overflow: hidden; + -webkit-box-shadow: 0 20px 60px 0 rgba(14, 42, 90, 0.55); + box-shadow: 0 20px 60px 0 rgba(14, 42, 90, 0.55); + -webkit-transform: perspective(2000px) rotateY(0) rotateX(0) rotate(0); + transform: perspective(2000px) rotateY(0) rotateX(0) rotate(0); + -webkit-transform-style: preserve-3d; + transform-style: preserve-3d; + -webkit-transition: all 0.8s cubic-bezier(0.71, 0.03, 0.56, 0.85); + transition: all 0.8s cubic-bezier(0.71, 0.03, 0.56, 0.85); + -webkit-backface-visibility: hidden; + backface-visibility: hidden; + height: 100%; +} +.credit-card-item__side.-back { + position: absolute; + top: 0; + left: 0; + width: 100%; + -webkit-transform: perspective(2000px) rotateY(-180deg) rotateX(0) rotate(0); + transform: perspective(2000px) rotateY(-180deg) rotateX(0) rotate(0); + z-index: 2; + padding: 0; + height: 100%; +} +.credit-card-item__side.-back .card-item__cover { + -webkit-transform: rotateY(-180deg); + transform: rotateY(-180deg); +} +.credit-card-item__bg { + max-width: 100%; + display: block; + max-height: 100%; + height: 100%; + width: 100%; + -o-object-fit: cover; + object-fit: cover; +} +.credit-card-item__cover { + position: absolute; + height: 100%; + background-color: #1c1d27; + background-image: linear-gradient(147deg, #354fce 0, #0c296b 74%); + left: 0; + top: 0; + width: 100%; + border-radius: 15px; + overflow: hidden; +} +.credit-card-item__cover:after { + content: ''; + position: absolute; + left: 0; + top: 0; + width: 100%; + height: 100%; + background: rgba(6, 2, 29, 0.45); +} +.credit-card-item__top { + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-align: start; + -ms-flex-align: start; + align-items: flex-start; + -webkit-box-pack: justify; + -ms-flex-pack: justify; + justify-content: space-between; + margin-bottom: 40px; + padding: 0 10px; +} +@media screen and (max-width: 480px) { + .credit-card-item__top { + margin-bottom: 25px; + } +} +@media screen and (max-width: 360px) { + .credit-card-item__top { + margin-bottom: 15px; + } +} +.credit-card-item__chip { + width: 60px; +} +@media screen and (max-width: 480px) { + .credit-card-item__chip { + width: 50px; + } +} +@media screen and (max-width: 360px) { + .credit-card-item__chip { + width: 40px; + } +} +.credit-card-item__type { + height: 45px; + position: relative; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-pack: end; + -ms-flex-pack: end; + justify-content: flex-end; + max-width: 100px; + margin-left: auto; + width: 100%; +} +@media screen and (max-width: 480px) { + .credit-card-item__type { + height: 40px; + max-width: 90px; + } +} +@media screen and (max-width: 360px) { + .credit-card-item__type { + height: 30px; + } +} +.credit-card-item__typeImg { + max-width: 100%; + -o-object-fit: contain; + object-fit: contain; + max-height: 100%; + -o-object-position: top right; + object-position: top right; +} +.credit-card-item__info { + color: #fff; + width: 100%; + max-width: calc(100% - 85px); + padding: 10px 15px; + font-weight: 500; + display: block; + cursor: pointer; +} +@media screen and (max-width: 480px) { + .credit-card-item__info { + padding: 10px; + } +} +.credit-card-item__holder { + opacity: 0.7; + font-size: 13px; + margin-bottom: 6px; +} +@media screen and (max-width: 480px) { + .credit-card-item__holder { + font-size: var(--ti-common-font-size-base); + margin-bottom: 5px; + } +} +.credit-card-item__wrapper { + padding: 25px 15px; + position: relative; + z-index: 4; + height: 100%; + text-shadow: 7px 6px 10px rgba(14, 42, 90, 0.8); + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; +} +@media screen and (max-width: 480px) { + .credit-card-item__wrapper { + padding: 20px 10px; + } +} +.credit-card-item__name { + font-size: var(--ti-common-font-size-3); + line-height: 1; + white-space: nowrap; + max-width: 100%; + overflow: hidden; + text-overflow: ellipsis; + text-transform: uppercase; +} +@media screen and (max-width: 480px) { + .credit-card-item__name { + font-size: var(--ti-common-font-size-2); + } +} +.credit-card-item__nameItem { + display: inline-block; + min-width: 8px; + position: relative; +} +.credit-card-item__number { + font-weight: 500; + line-height: 1; + color: #fff; + font-size: 27px; + margin-bottom: 25px; + display: inline-block; + padding: 10px 15px; + cursor: pointer; +} +@media screen and (max-width: 480px) { + .credit-card-item__number { + font-size: 21px; + margin-bottom: 15px; + padding: 10px 10px; + } +} +@media screen and (max-width: 360px) { + .credit-card-item__number { + font-size: 19px; + margin-bottom: 10px; + padding: 10px 10px; + } +} +.credit-card-item__numberItem { + width: 16px; + display: inline-block; +} +.credit-card-item__numberItem.-active { + width: 30px; +} +@media screen and (max-width: 480px) { + .credit-card-item__numberItem { + width: 13px; + } + .credit-card-item__numberItem.-active { + width: 16px; + } +} +@media screen and (max-width: 360px) { + .credit-card-item__numberItem { + width: 12px; + } + .credit-card-item__numberItem.-active { + width: 8px; + } +} +.credit-card-item__content { + color: #fff; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-align: start; + -ms-flex-align: start; + align-items: flex-start; +} +.credit-card-item__date { + -ms-flex-wrap: wrap; + flex-wrap: wrap; + font-size: var(--ti-common-font-size-3); + margin-left: auto; + padding: 10px; + display: -webkit-inline-box; + display: -ms-inline-flexbox; + display: inline-flex; + width: 80px; + white-space: nowrap; + -ms-flex-negative: 0; + flex-shrink: 0; + cursor: pointer; +} +@media screen and (max-width: 480px) { + .credit-card-item__date { + font-size: var(--ti-common-font-size-2); + } +} +.credit-card-item__dateItem { + position: relative; +} +.credit-card-item__dateItem span { + width: 22px; + display: inline-block; +} +.credit-card-item__dateTitle { + opacity: 0.7; + font-size: 13px; + padding-bottom: 6px; + width: 100%; +} +@media screen and (max-width: 480px) { + .credit-card-item__dateTitle { + font-size: var(--ti-common-font-size-base); + padding-bottom: 5px; + } +} +.credit-card-item__band { + background: rgba(0, 0, 19, 0.8); + width: 100%; + height: 50px; + margin-top: 30px; + position: relative; + z-index: 2; +} +@media screen and (max-width: 480px) { + .credit-card-item__band { + margin-top: 20px; + } +} +@media screen and (max-width: 360px) { + .credit-card-item__band { + height: 40px; + margin-top: 10px; + } +} +.credit-card-item__cvv { + text-align: right; + position: relative; + z-index: 2; + padding: 15px; +} +.credit-card-item__cvv .card-item__type { + opacity: 0.7; +} +@media screen and (max-width: 360px) { + .credit-card-item__cvv { + padding: 10px 15px; + } +} +.credit-card-item__cvvTitle { + padding-right: 10px; + font-size: 15px; + font-weight: 500; + color: #fff; + margin-bottom: 5px; +} +.credit-card-item__cvvBand { + height: 45px; + background: #fff; + margin-bottom: 30px; + text-align: right; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + -webkit-box-pack: end; + -ms-flex-pack: end; + justify-content: flex-end; + padding-right: 10px; + color: #1a3b5d; + font-size: var(--ti-common-font-size-3); + border-radius: 4px; + -webkit-box-shadow: 0 10px 20px -7px rgba(32, 56, 117, 0.35); + box-shadow: 0 10px 20px -7px rgba(32, 56, 117, 0.35); +} +@media screen and (max-width: 480px) { + .credit-card-item__cvvBand { + height: 40px; + margin-bottom: 20px; + } +} +@media screen and (max-width: 360px) { + .credit-card-item__cvvBand { + margin-bottom: 15px; + } +} +.credit-card-list { + margin-bottom: -130px; +} +@media screen and (max-width: 480px) { + .credit-card-list { + margin-bottom: -120px; + } +} +.credit-card-input { + margin-bottom: 20px; + position: relative; +} +.credit-card-input__label { + font-size: var(--ti-common-font-size-1); + margin-bottom: 5px; + font-weight: 500; + color: #1a3b5d; + width: 100%; + display: block; + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; +} +.credit-card-input__input { + width: 100%; + height: 50px; + border-radius: 5px; + -webkit-box-shadow: none; + box-shadow: none; + border: 1px solid #ced6e0; + -webkit-transition: all 0.3s ease-in-out; + transition: all 0.3s ease-in-out; + font-size: var(--ti-common-font-size-3); + padding: 5px 15px; + background: 0 0; + color: #1a3b5d; + outline: 0; +} +.credit-card-input__input:focus, +.credit-card-input__input:hover { + border-color: #3d9cff; +} +.credit-card-input__input:focus { + -webkit-box-shadow: 0 10px 20px -13px rgba(32, 56, 117, 0.35); + box-shadow: 0 10px 20px -13px rgba(32, 56, 117, 0.35); +} +.credit-card-input__input.-select { + -webkit-appearance: none; + background-image: url(); + background-size: 12px; + background-position: 90% center; + background-repeat: no-repeat; + padding-right: 30px; + -webkit-box-flex: 1; + -ms-flex: 1; + flex: 1; + cursor: pointer; +} +.credit-card-input__eye { + position: absolute; + width: 1em; + height: 1em; + font-size: var(--ti-common-font-size-5); + border-radius: 50%; + top: 42px; + right: 10px; + opacity: 0.75; + color: #8c9cae; + cursor: pointer; + padding: 0; + background: 0 0; + display: -webkit-inline-box; + display: -ms-inline-flexbox; + display: inline-flex; + border: 2px solid currentColor; + -webkit-box-shadow: none; + box-shadow: none; + -webkit-transition: all 0.3s ease-in-out; + transition: all 0.3s ease-in-out; + outline: 0; +} +.credit-card-input__eye:before { + content: ''; + position: absolute; + background: #fff; + width: 0.35em; + height: 0.35em; + top: 6px; + left: 6px; + z-index: 2; + border-radius: 50%; + -webkit-transform: scale(0.1); + transform: scale(0.1); + opacity: 0; + -webkit-transition: all 0.3s ease-in-out; + transition: all 0.3s ease-in-out; + -webkit-transition-delay: 0.1s; + transition-delay: 0.1s; +} +.credit-card-input__eye:after { + content: ''; + position: absolute; + top: 3px; + left: 3px; + background: currentColor; + width: 0.6em; + height: 0.6em; + border-radius: 50%; + -webkit-transform: scale(0.1); + transform: scale(0.1); + opacity: 0; + -webkit-transition: all 0.3s ease-in-out; + transition: all 0.3s ease-in-out; +} +.credit-card-input__eye.-active:not(:disabled), +.credit-card-input__eye:hover:not(:disabled) { + color: #2364d2; + opacity: 1; +} +.credit-card-input__eye.-active::after, +.credit-card-input__eye.-active::before { + -webkit-transform: scale(1); + transform: scale(1); + opacity: 1; +} +.credit-card-input__eye:disabled { + cursor: not-allowed; + opacity: 0.4; +} +.slide-fade-up-enter-active { + -webkit-transition: all 0.25s ease-in-out; + transition: all 0.25s ease-in-out; + -webkit-transition-delay: 0.1s; + transition-delay: 0.1s; + position: relative; +} +.slide-fade-up-leave-active { + -webkit-transition: all 0.25s ease-in-out; + transition: all 0.25s ease-in-out; + position: absolute; +} +.slide-fade-up-enter { + opacity: 0; + -webkit-transform: translateY(15px); + transform: translateY(15px); + pointer-events: none; +} +.slide-fade-up-leave-to { + opacity: 0; + -webkit-transform: translateY(-15px); + transform: translateY(-15px); + pointer-events: none; +} +.slide-fade-right-enter-active { + -webkit-transition: all 0.25s ease-in-out; + transition: all 0.25s ease-in-out; + -webkit-transition-delay: 0.1s; + transition-delay: 0.1s; + position: relative; +} +.slide-fade-right-leave-active { + -webkit-transition: all 0.25s ease-in-out; + transition: all 0.25s ease-in-out; + position: absolute; +} +.slide-fade-right-enter { + opacity: 0; + -webkit-transform: translateX(10px) rotate(45deg); + transform: translateX(10px) rotate(45deg); + pointer-events: none; +} +.slide-fade-right-leave-to { + opacity: 0; + -webkit-transform: translateX(-10px) rotate(45deg); + transform: translateX(-10px) rotate(45deg); + pointer-events: none; +} +.github-btn { + position: absolute; + right: 40px; + bottom: 50px; + text-decoration: none; + padding: 15px 25px; + border-radius: 4px; + -webkit-box-shadow: 0 4px 30px -6px rgba(36, 52, 70, 0.65); + box-shadow: 0 4px 30px -6px rgba(36, 52, 70, 0.65); + background: #24292e; + color: #fff; + font-weight: 700; + letter-spacing: 1px; + font-size: var(--ti-common-font-size-2); + text-align: center; + -webkit-transition: all 0.3s ease-in-out; + transition: all 0.3s ease-in-out; +} +@media screen and (min-width: 500px) { + .github-btn:hover { + -webkit-transform: scale(1.1); + transform: scale(1.1); + -webkit-box-shadow: 0 17px 20px -6px rgba(36, 52, 70, 0.36); + box-shadow: 0 17px 20px -6px rgba(36, 52, 70, 0.36); + } +} +@media screen and (max-width: 700px) { + .github-btn { + position: relative; + bottom: auto; + right: auto; + margin-top: 20px; + } + .github-btn:active { + -webkit-transform: scale(1.1); + transform: scale(1.1); + -webkit-box-shadow: 0 17px 20px -6px rgba(36, 52, 70, 0.36); + box-shadow: 0 17px 20px -6px rgba(36, 52, 70, 0.36); + } +} +.tiny-crop { + --ti-crop-drag-box-background: var(--ti-base-color-light); + --ti-crop-modal-background: var(--ti-base-color-dark); + --ti-crop-view-box-outline-color: var(--ti-base-color-brand-6); + --ti-crop-center-background: #eeeeee; + --ti-crop-face-background: var(--ti-base-color-light); + --ti-crop-line-background: var(--ti-base-color-brand-6); + --ti-crop-point-background: var(--ti-base-color-brand-6); + --ti-crop-opration-height: var(--ti-base-size-height-minor); + --ti-crop-opration-background: rgba(55, 55, 55, 0.3); + --ti-crop-opration-span-background: rgba(0, 0, 0, 0.5); + --ti-crop-opration-span-color: var(--ti-base-color-light); + --ti-crop-opration-span-hover-background: rgba(0, 0, 0, 0.8); + --ti-crop-modal-mask-background: rgba(55, 55, 55, 0.5); + --ti-crop-moda-close-background: rgba(0, 0, 0, 0.5); + --ti-crop-moda-close-icon-color: var(--ti-base-color-light); + --ti-crop-nopic-background: rgba(0, 0, 0, 0.3); + --ti-crop-nopic-center-color: rgba(255, 255, 255, 0.6); +} +.tiny-crop .cropper-container { + direction: ltr; + font-size: 0; + line-height: 0; + position: relative; + -ms-touch-action: none; + touch-action: none; + -ms-user-select: none; + -webkit-user-select: none; + -o-user-select: none; + -moz-user-select: none; + user-select: none; +} +.tiny-crop .cropper-container img { + display: block; + height: 100%; + image-orientation: 0deg; + max-height: none !important; + max-width: none !important; + min-height: 0 !important; + min-width: 0 !important; + width: 100%; +} +.tiny-crop .cropper-canvas, +.tiny-crop .cropper-crop-box, +.tiny-crop .cropper-drag-box, +.tiny-crop .cropper-modal, +.tiny-crop .cropper-wrap-box { + bottom: 0; + left: 0; + position: absolute; + right: 0; + top: 0; +} +.tiny-crop .cropper-canvas, +.tiny-crop .cropper-wrap-box { + overflow: hidden; +} +.tiny-crop .cropper-drag-box { + background-color: var(--ti-crop-drag-box-background); + opacity: 0; +} +.tiny-crop .cropper-modal { + background-color: var(--ti-crop-modal-background); + opacity: 0.5; +} +.tiny-crop .cropper-view-box { + display: block; + height: 100%; + outline-color: rgba(51, 153, 255, 0.75); + outline: 1px solid var(--ti-crop-view-box-outline-color); + overflow: hidden; + width: 100%; +} +.tiny-crop .cropper-dashed { + border: 0 dashed #eee; + display: block; + opacity: 0.5; + position: absolute; +} +.tiny-crop .cropper-dashed.dashed-h { + border-bottom-width: 1px; + border-top-width: 1px; + height: 33.33333%; + left: 0; + top: 33.33333%; + width: 100%; +} +.tiny-crop .cropper-dashed.dashed-v { + border-left-width: 1px; + border-right-width: 1px; + height: 100%; + left: 33.33333%; + top: 0; + width: 33.33333%; +} +.tiny-crop .cropper-center { + display: block; + height: 0; + left: 50%; + opacity: 0.75; + position: absolute; + top: 50%; + width: 0; +} +.tiny-crop .cropper-center:after, +.tiny-crop .cropper-center:before { + background-color: var(--ti-crop-center-background); + content: ' '; + display: block; + position: absolute; +} +.tiny-crop .cropper-center:before { + height: 1px; + left: -3px; + top: 0; + width: 7px; +} +.tiny-crop .cropper-center:after { + height: 7px; + left: 0; + top: -3px; + width: 1px; +} +.tiny-crop .cropper-face, +.tiny-crop .cropper-line, +.tiny-crop .cropper-point { + display: block; + height: 100%; + opacity: 0.1; + position: absolute; + width: 100%; +} +.tiny-crop .cropper-face { + background-color: var(--ti-crop-face-background); + left: 0; + top: 0; +} +.tiny-crop .cropper-line { + background-color: var(--ti-crop-line-background); +} +.tiny-crop .cropper-line.line-e { + cursor: ew-resize; + right: -3px; + top: 0; + width: 5px; +} +.tiny-crop .cropper-line.line-n { + cursor: ns-resize; + height: 5px; + left: 0; + top: -3px; +} +.tiny-crop .cropper-line.line-w { + cursor: ew-resize; + left: -3px; + top: 0; + width: 5px; +} +.tiny-crop .cropper-line.line-s { + bottom: -3px; + cursor: ns-resize; + height: 5px; + left: 0; +} +.tiny-crop .cropper-point { + background-color: var(--ti-crop-point-background); + height: 5px; + opacity: 0.75; + width: 5px; +} +.tiny-crop .cropper-point.point-e { + cursor: ew-resize; + margin-top: -3px; + right: -3px; + top: 50%; +} +.tiny-crop .cropper-point.point-n { + cursor: ns-resize; + left: 50%; + margin-left: -3px; + top: -3px; +} +.tiny-crop .cropper-point.point-w { + cursor: ew-resize; + left: -3px; + margin-top: -3px; + top: 50%; +} +.tiny-crop .cropper-point.point-s { + bottom: -3px; + cursor: s-resize; + left: 50%; + margin-left: -3px; +} +.tiny-crop .cropper-point.point-ne { + cursor: nesw-resize; + right: -3px; + top: -3px; +} +.tiny-crop .cropper-point.point-nw { + cursor: nwse-resize; + left: -3px; + top: -3px; +} +.tiny-crop .cropper-point.point-sw { + bottom: -3px; + cursor: nesw-resize; + left: -3px; +} +.tiny-crop .cropper-point.point-se { + bottom: -3px; + cursor: nwse-resize; + height: 20px; + opacity: 1; + right: -3px; + width: 20px; +} +@media (min-width: 768px) { + .tiny-crop .cropper-point.point-se { + height: 15px; + width: 15px; + } +} +@media (min-width: 992px) { + .tiny-crop .cropper-point.point-se { + height: 10px; + width: 10px; + } +} +@media (min-width: 1200px) { + .tiny-crop .cropper-point.point-se { + height: 5px; + opacity: 0.75; + width: 5px; + } +} +.tiny-crop .cropper-point.point-se:before { + background-color: var(--ti-crop-point-background); + bottom: -50%; + content: ' '; + display: block; + height: 200%; + opacity: 0; + position: absolute; + right: -50%; + width: 200%; +} +.tiny-crop .cropper-invisible { + opacity: 0; +} +.tiny-crop .cropper-bg { + background-image: url(); +} +.tiny-crop .cropper-hide { + display: block; + height: 0; + position: absolute; + width: 0; +} +.tiny-crop .cropper-hidden { + display: none !important; +} +.tiny-crop .cropper-move { + cursor: move; +} +.tiny-crop .cropper-crop { + cursor: crosshair; +} +.tiny-crop .cropper-disabled .cropper-drag-box, +.tiny-crop .cropper-disabled .cropper-face, +.tiny-crop .cropper-disabled .cropper-line, +.tiny-crop .cropper-disabled .cropper-point { + cursor: not-allowed; +} +.tiny-crop .img-container { + margin: auto; + overflow: hidden; +} +.tiny-crop .img-container > img { + max-width: 100%; +} +.tiny-crop .opration { + height: var(--ti-crop-opration-height); + line-height: var(--ti-crop-opration-height); + text-align: center; + background-color: var(--ti-crop-opration-background); + position: relative; +} +.tiny-crop .opration span { + width: 26px; + height: 26px; + margin: 0 2px; + display: inline-block; + color: var(--ti-crop-opration-span-color); + cursor: pointer; + border-radius: 50%; + background-color: var(--ti-crop-opration-span-background); +} +.tiny-crop .opration span:hover { + background-color: var(--ti-crop-opration-span-hover-background); + width: 28px; + height: 28px; +} +.tiny-crop .opration span.tiny-icon::before { + position: relative; +} +.tiny-crop .crop-modal-mask { + position: fixed; + top: 0; + bottom: 0; + left: 0; + right: 0; + background-color: var(--ti-crop-modal-mask-background); + height: 100%; + z-index: 1000; +} +.tiny-crop .crop-modal-warp { + position: fixed; + overflow: auto; + top: 0; + right: 0; + bottom: 0; + left: 0; + z-index: 1000; + -webkit-overflow-scrolling: touch; + outline: 0; +} +.tiny-crop .crop-modal { + position: relative; + top: 100px; + margin: 0 auto 50px; + background: #fff; + border-radius: 2px; + -webkit-box-sizing: border-box; + box-sizing: border-box; + width: 50%; +} +.tiny-crop .moda-close { + position: absolute; + top: -40px; + right: -40px; + width: 80px; + height: 80px; + cursor: pointer; + border-radius: 50%; + background-color: var(--ti-crop-moda-close-background); +} +.tiny-crop .moda-close .tiny-icon { + top: 45px; + left: 16px; + color: var(--ti-crop-moda-close-icon-color); + z-index: 9999999; +} +.tiny-crop .img-preview-box { + position: fixed; + top: 100px; +} +.tiny-crop .img-preview { + height: 9rem; + width: 16rem; + overflow: hidden; +} +@media (max-width: 768px) { + .tiny-crop .preview-lg { + display: none; + } +} +@media (max-width: 600px) { + .tiny-crop .preview-md { + display: none; + } +} +.tiny-crop .preview-lg { + height: 9rem; + width: 16rem; + margin-top: 4px; +} +.tiny-crop .preview-md { + height: 4.5rem; + width: 8rem; + margin-top: 4px; +} +.tiny-crop .preview-sm { + height: 2.25rem; + width: 4rem; + margin-top: 4px; +} +.tiny-crop .img-preview > img { + max-width: 100%; +} +.tiny-crop .nopic { + height: 200px; + text-align: center; + background: var(--ti-crop-nopic-background); +} +.tiny-crop .nopic-center { + position: relative; + font-size: 50px; + color: var(--ti-crop-nopic-center-color); + cursor: pointer; + top: 50px; +} +.tiny-crop input[type='file'] { + display: none; +} +.tiny-crop { + position: fixed; + height: 100%; + width: 100%; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + -webkit-box-pack: center; + -ms-flex-pack: center; + justify-content: center; + top: 0; + left: 0; + z-index: 1000; + background: rgba(97, 97, 97, 0.5); +} +.tiny-crop__dialog-content__handle { + width: 652px; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-pack: center; + -ms-flex-pack: center; + justify-content: center; + height: 26px; + margin: 10px 0 20px; +} +.tiny-crop__dialog-content__handle__button { + width: 268px; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-pack: justify; + -ms-flex-pack: justify; + justify-content: space-between; +} +.tiny-crop__dialog { + width: 652px; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-orient: vertical; + -webkit-box-direction: normal; + -ms-flex-direction: column; + flex-direction: column; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + -webkit-box-sizing: border-box; + box-sizing: border-box; + background: #fff; + z-index: 1001; +} +.tiny-crop__dialog-cropper { + width: 652px; + height: 300px; + overflow: hidden; +} +.tiny-crop__dialog-content { + width: 100%; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + margin-bottom: 10px; + -webkit-box-pack: center; + -ms-flex-pack: center; + justify-content: center; +} +.tiny-crop__dialog-content__crop { + width: 314px; + height: 200px; + border: 1px solid #393939; + -webkit-box-sizing: border-box; + box-sizing: border-box; + background: gray; + overflow: hidden; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + -webkit-box-pack: center; + -ms-flex-pack: center; + justify-content: center; +} +.tiny-crop__dialog-content__crop img { + height: 100%; + width: 100%; +} +.tiny-croppreview { + position: fixed; + top: calc(100% - 50% - 150px); + left: calc(100% - 50% + 336px); + height: 300px; + width: 300px; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + z-index: 1002; + -webkit-box-orient: vertical; + -webkit-box-direction: normal; + -ms-flex-direction: column; + flex-direction: column; + -webkit-box-pack: justify; + -ms-flex-pack: justify; + justify-content: space-between; +} +.iconButton { + border-radius: 50%; + background: #616161; + height: 26px; + width: 26px; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-pack: center; + -ms-flex-pack: center; + justify-content: center; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + cursor: pointer; +} +.iconButton .iconButtonset { + fill: #fff; + height: 12px; + width: 12px; +} +.iconButton:hover { + background: #272727; +} +.croppreview { + height: 100%; + width: 100%; +} +.croppreviewb { + width: 214px; + height: 140px; + overflow: hidden; + background: #fff; +} +.croppreviewm { + width: 114px; + height: 80px; + overflow: hidden; + background: #fff; +} +.croppreviews { + width: 84px; + height: 60px; + overflow: hidden; + background: #fff; +} +.tiny-dept { + --ti-dept-label-font-size: var(--ti-common-font-size-base); + --ti-dept-label-color: var(--ti-base-color-info-normal); + --ti-dept-label-font-weight: var(--ti-common-font-weight-7); + --ti-dept-selected-info-color: var(--ti-base-color-brand-6); + --ti-dept-selected-info-background: #f1f1f1; + --ti-dept-selected-info-border-radius: var(--ti-base-radius-large); +} +.tiny-dept__search { + margin-bottom: 12px; +} +.tiny-dept__label, +.tiny-dept__text { + font-size: var(--ti-dept-label-font-size); + color: var(--ti-dept-label-color); + font-weight: var(--ti-dept-label-font-weight); + white-space: nowrap; + overflow: hidden; + text-overflow: ellipsis; +} +.tiny-dept__label { + text-align: right; +} +.tiny-dept__label.is-selected { + text-align: left; + margin-bottom: 4px; +} +.tiny-dept__selected-info { + color: var(--ti-dept-selected-info-color); + font-size: var(--ti-dept-label-font-size); + background: var(--ti-dept-selected-info-background); + padding: 5px; + border-radius: var(--ti-dept-selected-info-border-radius); +} +.tiny-dept__item { + margin-bottom: 12px; +} +.tiny-dept__item .tiny-dept__label.tiny-col, +.tiny-dept__search .tiny-dept__label.tiny-col { + line-height: 30px; + padding-left: 0; + padding-right: 8px; +} +.tiny-dept__item .tiny-dept__label.tiny-col + .tiny-col, +.tiny-dept__search .tiny-dept__label.tiny-col + .tiny-col { + padding: 0; +} +.tiny-dept .tiny-input__inner { + overflow: hidden; + text-overflow: ellipsis; + white-space: nowrap; +} +.tiny-dept .tiny-input__icon { + vertical-align: middle; + fill: var(--ti-dept-selected-info-color); +} +.tiny-grid-modal__box { + --ti-detail-page-color: var(--ti-base-color-info-normal); + --ti-detail-page-font-size: var(--ti-common-font-size-base); + --ti-detail-page-header-font-size: var(--ti-common-font-size-1); + --ti-detail-page-header-border-color: var(--ti-base-color-border); + --ti-detail-page-header-seticon-color: var(--ti-base-color-brand-6); + --ti-detail-page-header-seticon-hover-color: var(--ti-base-color-brand-5); + --ti-detail-page-header-seticon-font-size: var(--ti-common-font-size-2); + --ti-detail-page-content-item-color: var(--ti-base-color-placeholder); + --ti-detail-dialog-header-background: #f1f1f1; + --ti-detail-dialog-content-item-hover-background: var(--ti-base-color-hover-background); + --ti-detail-dialog-active-background: #e9f4fd; +} +.tiny-detail-page { + width: 100%; + height: 700px; + font-size: var(--ti-detail-page-font-size); + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-orient: vertical; + -webkit-box-direction: normal; + -ms-flex-direction: column; + flex-direction: column; +} +.tiny-detail-page .tiny-detail-page__header { + width: 100%; + height: 40px; + color: var(--ti-detail-page-color); + display: -webkit-box; + display: -ms-flexbox; + display: flex; + border-bottom: 1px solid var(--ti-detail-page-header-border-color); + -webkit-box-pack: justify; + -ms-flex-pack: justify; + justify-content: space-between; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; +} +.tiny-detail-page .tiny-detail-page__header span { + font-size: var(--ti-detail-page-header-font-size); + font-weight: 700; +} +.tiny-detail-page .tiny-detail-page__header-icon { + line-height: 1; + cursor: pointer; +} +.tiny-detail-page .tiny-detail-page__header-icon .setIconStyle { + font-size: var(--ti-detail-page-header-seticon-font-size); + fill: var(--ti-detail-page-header-seticon-color); +} +.tiny-detail-page .tiny-detail-page__header-icon .setIconStyle:hover { + fill: var(--ti-detail-page-header-seticon-hover-color); +} +.tiny-detail-page .tiny-detail-page__content { + width: 100%; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-orient: vertical; + -webkit-box-direction: normal; + -ms-flex-direction: column; + flex-direction: column; +} +.tiny-detail-page .tiny-detail-page__content-item { + width: 100%; + height: 40px; + line-height: 40px; + display: -webkit-box; + display: -ms-flexbox; + display: flex; +} +.tiny-detail-page .tiny-detail-page__content-item .tiny-detail-page__content-item-span { + color: var(--ti-detail-page-content-item-color); + margin-right: 2px; +} +.tiny-detail-dialog { + width: 100%; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-orient: vertical; + -webkit-box-direction: normal; + -ms-flex-direction: column; + flex-direction: column; + font-size: 12px; +} +.tiny-detail-dialog .tiny-detail-dialog__header { + width: 100%; + height: 40px; + border-bottom: 1px solid var(--ti-detail-page-header-border-color); + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + -webkit-box-pack: justify; + -ms-flex-pack: justify; + justify-content: space-between; + background: var(--ti-detail-dialog-header-background); + padding-left: 8px; +} +.tiny-detail-dialog .tiny-detail-dialog__header > span { + width: 50%; + font-weight: 700; + border-right: 1px solid var(--ti-detail-page-header-border-color); +} +.tiny-detail-dialog .tiny-detail-dialog__header-check { + width: 130px; +} +.tiny-detail-dialog .tiny-detail-dialog__header-check span { + font-weight: 700; +} +.tiny-detail-dialog .tiny-detail-dialog__content { + width: 100%; + min-height: 225px; + max-height: 400px; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-orient: vertical; + -webkit-box-direction: normal; + -ms-flex-direction: column; + flex-direction: column; + overflow-y: auto; + border-bottom: 1px solid var(--ti-detail-page-header-border-color); +} +.tiny-detail-dialog .tiny-detail-dialog__content-item { + width: 100%; + height: 40px; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + -webkit-box-pack: justify; + -ms-flex-pack: justify; + justify-content: space-between; + padding-left: 8px; +} +.tiny-detail-dialog .tiny-detail-dialog__content-item:hover { + background: var(--ti-detail-dialog-content-item-hover-background); +} +.tiny-detail-dialog .tiny-detail-dialog__footer { + margin-top: 24px; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + -webkit-box-pack: center; + -ms-flex-pack: center; + justify-content: center; +} +.tiny-detail-dialog .active { + background: var(--ti-detail-dialog-active-background); +} +.tiny-dialog-box { + --ti-dialogbox-background: var(--ti-base-color-light); + --ti-dialogbox-border-radius: var(--ti-common-border-radius-normal); + --ti-dialogbox-head-border-color: var(--ti-base-color-border); + --ti-dialogbox-head-font-color: var(--ti-base-color-placeholder); + --ti-dialogbox-head-padding: 32px 32px 28px; + --ti-dialogbox-head-title-font-size: var(--ti-common-font-size-3); + --ti-dialogbox-head-title-font-weight: var(--ti-common-font-weight-7); + --ti-dialogbox-head-title-color: var(--ti-base-color-info-normal); + --ti-dialogbox-head-font-icon-color: #c4c4c4; + --ti-dialogbox-head-font-icon-size: 14px; + --ti-dialogbox-head-font-icon-hover: var(--ti-base-color-brand-6); + --ti-dialogbox-head-body-color: #5a5e66; + --ti-dialogbox-head-body-font-size: var(--ti-common-font-size-1); + --ti-dialogbox-close-icon-color: var(--ti-base-color-common-5); + --ti-dialogbox-close-icon-color-hover: var(--ti-base-color-brand-6); + --ti-dialogbox-box-body-font-size: var(--ti-common-font-size-base); + --ti-dialogbox-box-body-color: var(--ti-base-color-common-5); + --ti-dialogbox-box-body-padding: 0 32px; + --ti-dialogbox-box-body-margin-bottom: 12px; + --ti-dialogbox-btn-background-color-hover: none; + --ti-dialogbox-box-shadow: var(--ti-common-shadow-4-down); + --ti-dialogbox-btn-position-top: 18px; + position: absolute; + background: var(--ti-dialogbox-background); + border: 1px solid transparent; + border-radius: var(--ti-dialogbox-border-radius); + -webkit-box-shadow: var(--ti-dialogbox-box-shadow); + box-shadow: var(--ti-dialogbox-box-shadow); + overflow: hidden; +} +.tiny-dialog-box__wrapper { + position: fixed; + top: 0; + right: 0; + bottom: 0; + left: 0; + overflow: auto; + margin: 0; +} +.tiny-dialog-box.is-fullscreen { + left: 0; + top: 0; + width: 100vw; + height: 100vh; +} +.tiny-dialog-box.is-center .tiny-dialog-box__footer, +.tiny-dialog-box.is-center .tiny-dialog-box__header { + text-align: center; +} +.tiny-dialog-box .tiny-dialog-box__header { + padding: var(--ti-dialogbox-head-padding); + background: var(--ti-dialogbox-background); + font-weight: var(--ti-dialogbox-head-title-font-weight); + display: -webkit-box; + display: -ms-flexbox; + display: flex; + position: relative; + -webkit-box-pack: justify; + -ms-flex-pack: justify; + justify-content: space-between; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; +} +.tiny-dialog-box .tiny-dialog-box__header .tiny-dialog-box__title { + font-size: var(--ti-dialogbox-head-title-font-size); + color: var(--ti-dialogbox-head-title-color); + font-weight: var(--ti-dialogbox-head-title-font-weight); + -webkit-box-flex: 1; + -ms-flex: 1; + flex: 1; +} +.tiny-dialog-box .tiny-dialog-box__header .tiny-dialog-box__headerbtn { + border: none; + background: 0 0; + padding: 0; + line-height: 1; + position: absolute; + top: var(--ti-dialogbox-btn-position-top); + right: 20px; + cursor: pointer; + height: 32px; + width: 32px; +} +.tiny-dialog-box .tiny-dialog-box__header .tiny-dialog-box__headerbtn:hover { + background-color: var(--ti-dialogbox-btn-background-color-hover); + border-radius: 4px; +} +.tiny-dialog-box .tiny-dialog-box__header .tiny-dialog-box__headerbtn + .tiny-dialog-box__headerbtn { + margin-left: 8px; +} +.tiny-dialog-box .tiny-dialog-box__header .tiny-dialog-box__headerbtn:focus { + outline: 0; +} +.tiny-dialog-box .tiny-dialog-box__header .tiny-dialog-box__headerbtn .tiny-dialog-box__close { + fill: var(--ti-dialogbox-close-icon-color); + font-size: var(--ti-dialogbox-head-font-icon-size); +} +.tiny-dialog-box .tiny-dialog-box__header .tiny-dialog-box__headerbtn .tiny-dialog-box__close:hover { + fill: var(--ti-dialogbox-close-icon-color-hover); +} +.tiny-dialog-box .tiny-dialog-box__body { + text-align: left; + padding: var(--ti-dialogbox-box-body-padding); + margin-bottom: var(--ti-dialogbox-box-body-margin-bottom); + color: var(--ti-dialogbox-box-body-color); + font-size: var(--ti-dialogbox-box-body-font-size); + overflow: auto; + max-height: 65vh; +} +.tiny-dialog-box .tiny-dialog-box__body .tiny-upload { + overflow: hidden; +} +.tiny-dialog-box .tiny-dialog-box__body > span { + max-height: 120px; + overflow-y: auto; +} +.tiny-dialog-box .tiny-dialog-box__body .tiny-dept__search { + line-height: 30px; +} +.tiny-dialog-box.is-fullscreen .tiny-dialog-box__body { + max-height: calc(100vh - 94px); +} +.tiny-dialog-box .tiny-dialog-box__footer { + text-align: inherit; + padding: 28px 32px 32px; + text-align: center; + -webkit-box-sizing: border-box; + box-sizing: border-box; +} +.tiny-dialog-box .tiny-dialog-box__footer .tiny-toolbar .tiny-button { + margin: 0 4px; +} +.tiny-dialog-box__scroll-lock { + overflow: hidden; +} +.v-modal { + position: fixed; + left: 0; + top: 0; + width: 100%; + height: 100%; + opacity: 0.3; + background: #000; +} +.v-modal-enter { + -webkit-animation: v-modal-in 0.2s ease; + animation: v-modal-in 0.2s ease; +} +.v-modal-leave { + -webkit-animation: v-modal-out 0.2s ease forwards; + animation: v-modal-out 0.2s ease forwards; +} +@-webkit-keyframes v-modal-in { + 0% { + opacity: 0; + } +} +@keyframes v-modal-in { + 0% { + opacity: 0; + } +} +@-webkit-keyframes v-modal-out { + 100% { + opacity: 0; + } +} +@keyframes v-modal-out { + 100% { + opacity: 0; + } +} +.dialog-slideRight-enter-active { + -webkit-animation: slideRight 0.5s ease-in forwards; + animation: slideRight 0.5s ease-in forwards; +} +.dialog-slideRight-leave-active { + -webkit-animation: slideRightout 0.5s ease-in forwards; + animation: slideRightout 0.5s ease-in forwards; +} +@-webkit-keyframes slideRight { + 0% { + opacity: 0; + -webkit-transform: translateX(100%); + transform: translateX(100%); + } + 50% { + opacity: 0.6; + -webkit-transform: translateX(50%); + transform: translateX(50%); + } + 100% { + opacity: 1; + -webkit-transform: translateX(0); + transform: translateX(0); + } +} +@keyframes slideRight { + 0% { + opacity: 0; + -webkit-transform: translateX(100%); + transform: translateX(100%); + } + 50% { + opacity: 0.6; + -webkit-transform: translateX(50%); + transform: translateX(50%); + } + 100% { + opacity: 1; + -webkit-transform: translateX(0); + transform: translateX(0); + } +} +@-webkit-keyframes slideRightout { + 0% { + opacity: 1; + -webkit-transform: translateX(0); + transform: translateX(0); + } + 50% { + opacity: 0.6; + -webkit-transform: translateX(50%); + transform: translateX(50%); + } + 100% { + opacity: 0; + -webkit-transform: translateX(100%); + transform: translateX(100%); + } +} +@keyframes slideRightout { + 0% { + opacity: 1; + -webkit-transform: translateX(0); + transform: translateX(0); + } + 50% { + opacity: 0.6; + -webkit-transform: translateX(50%); + transform: translateX(50%); + } + 100% { + opacity: 0; + -webkit-transform: translateX(100%); + transform: translateX(100%); + } +} +.dialog-fade-enter-active { + -webkit-animation: dialog-fade-in 0.3s; + animation: dialog-fade-in 0.3s; +} +.dialog-fade-leave-active { + -webkit-animation: dialog-fade-out 0.3s; + animation: dialog-fade-out 0.3s; +} +@-webkit-keyframes dialog-fade-in { + 0% { + -webkit-transform: translate3d(0, -20px, 0); + transform: translate3d(0, -20px, 0); + opacity: 0; + } + 100% { + -webkit-transform: translate3d(0, 0, 0); + transform: translate3d(0, 0, 0); + opacity: 1; + } +} +@keyframes dialog-fade-in { + 0% { + -webkit-transform: translate3d(0, -20px, 0); + transform: translate3d(0, -20px, 0); + opacity: 0; + } + 100% { + -webkit-transform: translate3d(0, 0, 0); + transform: translate3d(0, 0, 0); + opacity: 1; + } +} +@-webkit-keyframes dialog-fade-out { + 0% { + -webkit-transform: translate3d(0, 0, 0); + transform: translate3d(0, 0, 0); + opacity: 1; + } + 100% { + -webkit-transform: translate3d(0, -20px, 0); + transform: translate3d(0, -20px, 0); + opacity: 0; + } +} +@keyframes dialog-fade-out { + 0% { + -webkit-transform: translate3d(0, 0, 0); + transform: translate3d(0, 0, 0); + opacity: 1; + } + 100% { + -webkit-transform: translate3d(0, -20px, 0); + transform: translate3d(0, -20px, 0); + opacity: 0; + } +} +@media (max-width: 480px) { + .tiny-dialog-box { + width: 100% !important; + top: 0 !important; + left: 0 !important; + } +} +.tiny-drop-roles .user-icon { + float: right; + position: relative; + top: 50%; + -webkit-transform: translateY(-50%); + transform: translateY(-50%); + margin-left: 10px; +} +.tiny-dropdown { + display: inline-block; + position: relative; + font-size: var(--ti-common-font-size-base); +} +.tiny-dropdown .tiny-button-group { + display: block; +} +.tiny-dropdown .tiny-button-group .tiny-button { + float: none; +} +.tiny-dropdown .tiny-dropdown__caret-button { + padding-left: 5px; + padding-right: 5px; + position: relative; + border-left: none; + min-width: 24px; +} +.tiny-dropdown .tiny-dropdown__caret-button:before { + content: ''; + position: absolute; + display: block; + width: 1px; + top: 5px; + bottom: 5px; + left: 0; + background: #fff; +} +.tiny-dropdown .tiny-dropdown__caret-button.tiny-button--default:before { + background: #d9d9d9; +} +.tiny-dropdown .tiny-dropdown__caret-button.tiny-button--default:hover:before { + background-color: #1890ff; +} +.tiny-dropdown .tiny-dropdown__caret-button:hover:not(.is-disabled):before { + top: 0; + bottom: 0; +} +.tiny-dropdown .tiny-dropdown__caret-button svg { + padding-left: 0; + margin: 0 3px; +} +.tiny-dropdown .tiny-dropdown-selfdefine:focus:active, +.tiny-dropdown .tiny-dropdown-selfdefine:focus:not(.focusing) { + outline-width: 0; +} +.tiny-dropdown [disabled] { + cursor: not-allowed; + color: #bbb; +} +.tiny-dropdown-menu__item { + --ti-dropdown-menu-item-hover-bgcolor: var(--ti-base-color-hover-background); + --ti-dropdown-menu-item-hover-color: var(--ti-base-color-brand-6); + --ti-dropdown-menu-item-active-bgcolor: var(--ti-base-color-brand-6); + --ti-dropdown-menu-item-active-color: var(--ti-base-color-white); + --ti-dropdown-menu-item-disabled-color: var(--ti-common-color-text-disabled); + --ti-dropdown-menu-item-color: #333; + --ti-dropdown-menu-item-height: 30px; + --ti-dropdown-menu-item-padding: 0 20px; + --ti-dropdown-menu-item-border-radius: 0; + list-style: none; + line-height: var(--ti-dropdown-menu-item-height); + padding: var(--ti-dropdown-menu-item-padding) !important; + margin: 0; + font-size: var(--ti-common-font-size-base); + color: var(--ti-dropdown-menu-item-color); + cursor: pointer; + outline: 0; +} +.tiny-dropdown-menu__item:focus, +.tiny-dropdown-menu__item:not(.is-disabled):hover { + background-color: var(--ti-dropdown-menu-item-hover-bgcolor); + color: var(--ti-dropdown-menu-item-hover-color); + border-radius: var(--ti-dropdown-menu-item-border-radius); +} +.tiny-dropdown-menu__item:focus svg, +.tiny-dropdown-menu__item:not(.is-disabled):hover svg { + fill: var(--ti-dropdown-menu-item-hover-color); +} +.tiny-dropdown-menu__item:not(.is-disabled):active { + background-color: var(--ti-dropdown-menu-item-active-bgcolor); + color: var(--ti-dropdown-menu-item-active-color); + border-radius: var(--ti-dropdown-menu-item-border-radius); +} +.tiny-dropdown-menu__item:not(.is-disabled):active svg { + fill: var(--ti-dropdown-menu-item-active-color); +} +.tiny-dropdown-menu__item svg { + margin-right: 5px; + margin-top: -2px; +} +.tiny-dropdown-menu__item.is-disabled { + cursor: default; + color: var(--ti-dropdown-menu-item-disabled-color); + pointer-events: none; +} +.tiny-dropdown-menu__item--divided { + position: relative; + margin-top: 6px; + border-top: 1px solid #e4e7ed; +} +.tiny-dropdown-menu__item--divided:before { + content: ''; + height: 6px; + display: block; + margin: 0 -20px; + background-color: #fff; +} +.tiny-dropdown-menu { + --ti-dropdown-menu-box-shadow: 0 2px 8px 0 rgba(0, 0, 0, 0.2); + --ti-dropdown-menu-gap: 0; + --ti-dropdown-menu-padding: 4px 0; + position: absolute; + top: 0; + left: 0; + z-index: 10; + padding: var(--ti-dropdown-menu-padding); + background-color: var(--ti-common-color-bg-white-normal); + border-radius: var(--ti-common-border-radius-normal); + -webkit-box-shadow: var(--ti-dropdown-menu-box-shadow); + box-shadow: var(--ti-dropdown-menu-box-shadow); +} +.tiny-dropdown-menu.tiny-popper .popper__arrow, +.tiny-dropdown-menu.tiny-popper .popper__arrow:after { + position: absolute; + display: block; + width: 0; + height: 0; + border-color: transparent; + border-style: solid; +} +.tiny-dropdown-menu.tiny-popper .popper__arrow { + border-width: 6px; + -webkit-filter: drop-shadow(0 2px 12px rgba(0, 0, 0, 0.03)); + filter: drop-shadow(0 2px 12px rgba(0, 0, 0, 0.03)); +} +.tiny-dropdown-menu.tiny-popper .popper__arrow::after { + content: ' '; + border-width: 6px; +} +.tiny-dropdown-menu.tiny-popper[x-placement^='top'] { + margin-bottom: var(--ti-dropdown-menu-gap); +} +.tiny-dropdown-menu.tiny-popper[x-placement^='top'] .popper__arrow { + bottom: -6px; + left: 50%; + margin-right: 3px; + border-top-color: #d9d9d9; + border-bottom-width: 0; +} +.tiny-dropdown-menu.tiny-popper[x-placement^='top'] .popper__arrow:after { + bottom: 1px; + margin-left: -6px; + border-top-color: #fff; + border-bottom-width: 0; +} +.tiny-dropdown-menu.tiny-popper[x-placement^='bottom'] { + margin-top: var(--ti-dropdown-menu-gap); +} +.tiny-dropdown-menu.tiny-popper[x-placement^='bottom'] .popper__arrow { + top: -6px; + left: 50%; + margin-right: 3px; + border-top-width: 0; + border-bottom-color: #d9d9d9; +} +.tiny-dropdown-menu.tiny-popper[x-placement^='bottom'] .popper__arrow:after { + top: 1px; + margin-left: -6px; + border-top-width: 0; + border-bottom-color: #fff; +} +.tiny-dropdown-menu.tiny-popper[x-placement^='right'] { + margin-left: 12px; +} +.tiny-dropdown-menu.tiny-popper[x-placement^='right'] .popper__arrow { + top: 50%; + left: -6px; + margin-bottom: 3px; + border-right-color: #d9d9d9; + border-left-width: 0; +} +.tiny-dropdown-menu.tiny-popper[x-placement^='right'] .popper__arrow:after { + bottom: -6px; + left: 1px; + border-right-color: #fff; + border-left-width: 0; +} +.tiny-dropdown-menu.tiny-popper[x-placement^='left'] { + margin-right: 12px; +} +.tiny-dropdown-menu.tiny-popper[x-placement^='left'] .popper__arrow { + top: 50%; + right: -6px; + margin-bottom: 3px; + border-right-width: 0; + border-left-color: #d9d9d9; +} +.tiny-dropdown-menu.tiny-popper[x-placement^='left'] .popper__arrow:after { + right: 1px; + bottom: -6px; + margin-left: -6px; + border-right-width: 0; + border-left-color: #fff; +} +.tiny-dropdown-menu--medium { + padding: 6px 0; +} +.tiny-dropdown-menu--medium .tiny-dropdown-menu__item { + line-height: 30px; + padding: 0 17px; + font-size: var(--ti-common-font-size-1); +} +.tiny-dropdown-menu--medium .tiny-dropdown-menu__item.tiny-dropdown-menu__item--divided { + margin-top: 6px; +} +.tiny-dropdown-menu--medium .tiny-dropdown-menu__item.tiny-dropdown-menu__item--divided:before { + height: 6px; + margin: 0 -17px; +} +.tiny-dropdown-menu--small { + padding: 6px 0; +} +.tiny-dropdown-menu--small .tiny-dropdown-menu__item { + line-height: 27px; + padding: 0 15px; + font-size: 13px; +} +.tiny-dropdown-menu--small .tiny-dropdown-menu__item.tiny-dropdown-menu__item--divided { + margin-top: 4px; +} +.tiny-dropdown-menu--small .tiny-dropdown-menu__item.tiny-dropdown-menu__item--divided:before { + height: 4px; + margin: 0 -15px; +} +.tiny-dropdown-menu--mini { + padding: 3px 0; +} +.tiny-dropdown-menu--mini .tiny-dropdown-menu__item { + line-height: 24px; + padding: 0 10px; + font-size: var(--ti-common-font-size-base); +} +.tiny-dropdown-menu--mini .tiny-dropdown-menu__item.tiny-dropdown-menu__item--divided { + margin-top: 3px; +} +.tiny-dropdown-menu--mini .tiny-dropdown-menu__item.tiny-dropdown-menu__item--divided:before { + height: 3px; + margin: 0 -10px; +} +.tiny-espace { + --ti-espace-font-size: 26px; + --ti-espace-color: var(--ti-base-color-brand-6); + --ti-espace-hover-color: var(--ti-base-color-brand-5); +} +.tiny-espace .item-call, +.tiny-espace .item-email, +.tiny-espace .item-talk { + margin: 0 8px 0 0; + line-height: 1; +} +.tiny-espace .item-call .tiny-svg, +.tiny-espace .item-email .tiny-svg, +.tiny-espace .item-talk .tiny-svg { + fill: var(--ti-espace-color); + font-size: var(--ti-espace-font-size); +} +.tiny-espace .item-call:hover .tiny-svg, +.tiny-espace .item-email:hover .tiny-svg, +.tiny-espace .item-talk:hover .tiny-svg { + fill: var(--ti-espace-hover-color); +} +.tiny-fall-menu { + --ti-fallmenu-menu-height: var(--ti-base-size-height-large); + --ti-fallmenu-background-normal: var(--ti-base-color-brand-6); + --ti-fallmenu-background-hover: var(--ti-base-color-brand-5); + --ti-fallmenu-icon-font-size: var(--ti-common-font-size-base); + --ti-fallmenu-slot-color: var(--ti-base-color-light); + --ti-fallmenu-title-font-size: var(--ti-common-font-size-2); + --ti-fallmenu-box-title-color: var(--ti-base-color-placeholder); + --ti-fallmenu-box-font-color: var(--ti-base-color-brand-6); + --ti-fallmenu-box-font-size: var(--ti-common-font-size-1); + --ti-fallmenu-box-title-height: var(--ti-base-size-height-small); + --ti-fallmenu-box-content-height: 26px; + --ti-fallmenu-box-hover-color: var(--ti-base-color-primary-active); +} +.tiny-fall-menu .tiny-fall-menu__wrap { + background: var(--ti-fallmenu-background-normal); + padding: 0 24px; +} +.tiny-fall-menu .tiny-fall-menu__nav { + height: var(--ti-fallmenu-menu-height); + margin: 0 auto; + position: relative; +} +.tiny-fall-menu .tiny-fall-menu__subnav { + overflow: hidden; +} +.tiny-fall-menu .tiny-fall-menu__subnav .icon-slot-left, +.tiny-fall-menu .tiny-fall-menu__subnav .icon-slot-right { + color: var(--ti-fallmenu-slot-color); + cursor: pointer; + position: absolute; + top: 50%; + -webkit-transform: translateY(-50%); + transform: translateY(-50%); + font-size: var(--ti-fallmenu-icon-font-size); + line-height: 1; +} +.tiny-fall-menu .tiny-fall-menu__subnav .icon-slot-left svg, +.tiny-fall-menu .tiny-fall-menu__subnav .icon-slot-right svg { + fill: #fff; +} +.tiny-fall-menu .tiny-fall-menu__subnav .icon-slot-left { + left: -12px; +} +.tiny-fall-menu .tiny-fall-menu__subnav .icon-slot-right { + right: -12px; +} +.tiny-fall-menu .tiny-fall-menu__list { + position: relative; + min-width: 4000px; + left: 0; + -webkit-transition: left 0.4s; + transition: left 0.4s; +} +.tiny-fall-menu .tiny-fall-menu__list .fall-hide { + opacity: 0; +} +.tiny-fall-menu .tiny-fall-menu__list ul:after, +.tiny-fall-menu .tiny-fall-menu__list ul:before { + content: ''; + display: table; +} +.tiny-fall-menu .tiny-fall-menu__list ul:after { + clear: both; +} +.tiny-fall-menu .tiny-fall-menu__list li { + float: left; + position: relative; + white-space: nowrap; + overflow: hidden; + text-overflow: ellipsis; +} +.tiny-fall-menu .tiny-fall-menu__list a { + float: left; + display: block; + width: auto; + padding: 0 12px; + height: var(--ti-fallmenu-menu-height); + text-align: center; + text-decoration: none; + font-weight: 400; + line-height: var(--ti-fallmenu-menu-height); + font-size: var(--ti-fallmenu-title-font-size); + color: var(--ti-fallmenu-slot-color); +} +.tiny-fall-menu .tiny-fall-menu__list a.now, +.tiny-fall-menu .tiny-fall-menu__list a:hover { + color: var(--ti-fallmenu-slot-color); + background: var(--ti-fallmenu-background-hover); + text-decoration: none; +} +.tiny-fall-menu .tiny-fall-menu__list a.now:before { + position: absolute; + content: ''; + width: 0; + height: 0; + border-style: solid; + border-width: 0; + border-color: #fff transparent; + top: 34px; + left: 42%; +} +.tiny-fall-menu .tiny-fall-menu__box { + position: absolute; + left: 0; + top: var(--ti-fallmenu-menu-height); + width: 100%; + background: var(--ti-fallmenu-slot-color); + overflow: hidden; + -webkit-transition: opacity 0.4s; + transition: opacity 0.4s; + opacity: 0; +} +.tiny-fall-menu .tiny-fall-menu__box .contbox { + overflow: hidden; +} +.tiny-fall-menu .tiny-fall-menu__box .cont { + min-width: 120px; + padding: 18px 20px; +} +.tiny-fall-menu .tiny-fall-menu__box .sublist li { + float: left; + width: 100%; +} +.tiny-fall-menu .tiny-fall-menu__box .sublist li h3.mcate-item-hd { + font-size: var(--ti-fallmenu-box-font-size); + border-bottom: 0 solid #ccc; + color: var(--ti-fallmenu-box-title-color); + font-weight: 400; + margin: 0; +} +.tiny-fall-menu .tiny-fall-menu__box .sublist li p.mcate-item-bd { + margin-top: 18px; +} +.tiny-fall-menu .tiny-fall-menu__box .sublist li p.mcate-item-bd a { + margin: 8px 0 0 0; + font-size: var(--ti-common-font-size-base); + color: var(--ti-fallmenu-box-font-color); + text-decoration: none; + display: block; + overflow: hidden; + white-space: nowrap; + text-overflow: ellipsis; +} +.tiny-fall-menu .tiny-fall-menu__box .sublist li p.mcate-item-bd a:hover { + color: var(--ti-fallmenu-box-hover-color); +} +.tiny-fall-menu .tiny-fall-menu__box.active, +.tiny-fall-menu .tiny-fall-menu__box:hover { + border-left: 1px solid #d9d9d9; + border-right: 1px solid #d9d9d9; + border-bottom: 1px solid #d9d9d9; + -webkit-box-shadow: 1px 1px 5px 1px #d9d9d9; + box-shadow: 1px 1px 5px 1px #d9d9d9; + opacity: 1; +} +@-webkit-keyframes leftArrow { + 0% { + left: -17px; + } + 50% { + left: -13px; + } + 100% { + left: -17px; + } +} +@keyframes leftArrow { + 0% { + left: -17px; + } + 50% { + left: -13px; + } + 100% { + left: -17px; + } +} +@-webkit-keyframes rightArrow { + 0% { + right: -17px; + } + 50% { + right: -13px; + } + 100% { + right: -17px; + } +} +@keyframes rightArrow { + 0% { + right: -17px; + } + 50% { + right: -13px; + } + 100% { + right: -17px; + } +} +.tiny-upload--thumb__head { + cursor: pointer; + color: #343434; + font-size: var(--ti-common-font-size-1); +} +.tiny-upload--thumb__head .thumb-icon { + margin-right: 8px; + fill: #999; +} +.tiny-upload--thumb__head span { + vertical-align: middle; +} +.tiny-upload--thumb__body .thumb-item { + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-pack: start; + -ms-flex-pack: start; + justify-content: flex-start; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; +} +.tiny-upload--thumb__body .thumb-item:not(:last-child) { + padding-bottom: 8px; +} +.tiny-upload--thumb__body .thumb-item-name { + padding: 4px 8px; + color: #333; + -webkit-box-flex: 1; + -ms-flex: 1; + flex: 1; + white-space: nowrap; + overflow: hidden; + text-overflow: ellipsis; +} +.tiny-upload--thumb__body .thumb-success-icon { + fill: #52c41a; +} +.tiny-upload--thumb__body .close-icon, +.tiny-upload--thumb__body .download-icon, +.tiny-upload--thumb__body .refres-icon { + fill: #7c7c7c; + cursor: pointer; +} +.tiny-upload--thumb__body .thumb-icon + .thumb-icon { + margin-left: 8px; +} +.tiny-float-bar { + --ti-floatbar-border-color: var(--ti-base-color-border); + --ti-floatbar-radius: var(--ti-base-radius-small); + --ti-floatbar-font-size: var(--ti-common-font-size-1); + --ti-floatbar-list-background: var(--ti-base-color-light); + --ti-floatbar-list-color: var(--ti-base-color-info-normal); + --ti-floatbar-list-hover-background: rgba(24, 144, 255, 0.06); + --ti-floatbar-list-hover-color: var(--ti-base-color-brand-6); + position: fixed; + top: 50%; + right: 10px; + z-index: 99999; + border: 1px solid var(--ti-floatbar-border-color); + -webkit-box-shadow: 2px 3px 7px rgba(0, 0, 0, 0.15); + box-shadow: 2px 3px 7px rgba(0, 0, 0, 0.15); + border-radius: var(--ti-floatbar-radius); + overflow: hidden; + background: var(--ti-floatbar-list-background); +} +.tiny-float-bar ul li { + display: block; + background: var(--ti-floatbar-list-background); + color: var(--ti-floatbar-list-color); + font-size: var(--ti-floatbar-font-size); + min-width: 80px; + min-height: 40px; + line-height: 40px; + text-align: center; +} +.tiny-float-bar ul li:hover { + background: var(--ti-floatbar-list-hover-background); +} +.tiny-float-bar ul li a { + width: 100%; + height: 100%; + color: var(--ti-floatbar-list-color); + cursor: pointer; + outline: 0; +} +.tiny-float-bar ul li a:focus, +.tiny-float-bar ul li a:hover { + color: var(--ti-floatbar-list-hover-color); + text-decoration: none; +} +.tiny-form { + --ti-form-item-margin-right: 10px; + width: 100%; + overflow: hidden; +} +.tiny-form div { + outline: 0; +} +.tiny-form--inline .tiny-form-item, +.tiny-form--inline .tiny-form-item__content { + display: inline-block; + vertical-align: top; +} +.tiny-form--inline .tiny-form-item { + margin-right: var(--ti-form-item-margin-right); +} +.tiny-form--inline .tiny-form-item__label { + float: none; + display: inline-block; +} +.tiny-form--inline .tiny-form--label-top .tiny-form-item__content { + display: block; +} +.tiny-form--label-left .tiny-form-item__label { + text-align: left; +} +.tiny-form--label-top .tiny-form-item__label { + float: none; + display: inline-block; + text-align: left; + line-height: 1; + padding: 0 0 8px; +} +.tiny-form--label-top .tiny-form-item { + margin-bottom: 16px; +} +.tiny-form--label-top .tiny-form { + margin-bottom: 16px; +} +.tiny-form--inline.tiny-form--label-top .tiny-form-item { + margin-bottom: 16px; + margin-right: 64px; +} +.tiny-form--inline.tiny-form--label-top .tiny-form-item__label { + display: block; + text-align: left; +} +.tiny-form__valid.tiny-tooltip.tiny-tooltip__popper { + padding: 7px 4px; +} +.tiny-form__valid.tiny-tooltip.tiny-tooltip__popper.is-error[x-placement^='top'] .popper__arrow { + bottom: -4px; +} +.tiny-form__valid.tiny-tooltip.tiny-tooltip__popper[x-placement^='top'] { + margin-bottom: 6px; +} +.tiny-form__valid.tiny-tooltip.tiny-tooltip__popper[x-placement^='bottom'] { + margin-top: 6px; +} +.tiny-form-item { + --ti-form-item-small-line-height: 36px; + --ti-form-item-medium-line-height: 42px; + --ti-form-item-mini-line-height: 24px; + --ti-form-item-label-line-height: var(--ti-base-size-height-minor); + --ti-form-item-label-font-size: var(--ti-common-font-size-1); + --ti-form-item-label-color: var(--ti-base-color-info-normal); + --ti-form-item-error-font-size: var(--ti-common-font-size-base); + --ti-form-item-error-color: var(--ti-base-color-error-3); + --ti-form-item-error-bgcolor: var(--ti-base-color-error-1); + margin-bottom: 12px; +} +.tiny-form-item:after, +.tiny-form-item:before { + content: ''; + display: table; +} +.tiny-form-item:after { + clear: both; +} +.tiny-form-item .tiny-form-item { + margin-bottom: 0; +} +.tiny-form-item.tiny-form-item--mini, +.tiny-form-item.tiny-form-item--small { + margin-bottom: 8px; +} +.tiny-form-item--medium .tiny-form-item__label { + height: var(--ti-form-item-medium-line-height); + line-height: var(--ti-form-item-medium-line-height); +} +.tiny-form-item--small .tiny-form-item__label { + height: var(--ti-form-item-small-line-height); + line-height: var(--ti-form-item-small-line-height); +} +.tiny-form-item--small .tiny-form-item__error { + padding-top: 2px; +} +.tiny-form-item--mini .tiny-form-item__label { + height: var(--ti-form-item-mini-line-height); + line-height: var(--ti-form-item-mini-line-height); +} +.tiny-form-item--medium .tiny-form-item__content .tiny-checkbox, +.tiny-form-item--medium .tiny-form-item__content .tiny-radio { + line-height: 42px; +} +.tiny-form-item--medium .tiny-form-item__content .tiny-input .tiny-input__inner { + height: 42px; + line-height: 42px; +} +.tiny-form-item--small .tiny-form-item__content .tiny-checkbox, +.tiny-form-item--small .tiny-form-item__content .tiny-radio { + line-height: 36px; +} +.tiny-form-item--small .tiny-form-item__content .tiny-input .tiny-input__inner { + height: 36px; + line-height: 36px; +} +.tiny-form-item--mini .tiny-form-item__content .tiny-checkbox, +.tiny-form-item--mini .tiny-form-item__content .tiny-radio { + line-height: 24px; +} +.tiny-form-item--mini .tiny-form-item__content .tiny-input .tiny-input__inner { + height: 24px; + line-height: 24px; +} +.tiny-form-item--mini .tiny-form-item__error { + padding-top: 1px; +} +.tiny-form-item__label-wrap { + float: left; +} +.tiny-form-item__label-wrap .tiny-form-item__label { + display: inline-block; + float: none; +} +.tiny-form-item__label { + text-align: right; + vertical-align: middle; + float: left; + font-size: var(--ti-form-item-label-font-size); + color: var(--ti-form-item-label-color); + height: var(--ti-form-item-label-line-height); + line-height: var(--ti-form-item-label-line-height); + padding-right: 8px; + -webkit-box-sizing: border-box; + box-sizing: border-box; + overflow: hidden; + white-space: nowrap; + text-overflow: ellipsis; +} +.tiny-form-item__content { + position: relative; + font-size: var(--ti-form-item-label-font-size); +} +.tiny-form-item__content:after, +.tiny-form-item__content:before { + content: ''; + display: table; +} +.tiny-form-item__content:after { + clear: both; +} +.tiny-form-item__content .tiny-input { + display: inline-block; +} +.tiny-form-item__content .tiny-input.tiny-range-editor.tiny-input__inner { + display: -webkit-inline-box; + display: -ms-inline-flexbox; + display: inline-flex; +} +.tiny-form-item__content .tiny-input.tiny-input-group { + display: inline-table; +} +.tiny-form-item__content .tiny-input-group { + vertical-align: top; +} +.tiny-form-item__content .tiny-button + .tiny-button { + margin-left: 8px; +} +.tiny-form-item__content .tiny-checkbox, +.tiny-form-item__content .tiny-radio { + line-height: 30px; +} +.tiny-form-item__content .tiny-date-editor--daterange.tiny-input, +.tiny-form-item__content .tiny-date-editor--daterange.tiny-input__inner, +.tiny-form-item__content .tiny-date-editor--timerange.tiny-input, +.tiny-form-item__content .tiny-date-editor--timerange.tiny-input__inner, +.tiny-form-item__content .tiny-numeric { + width: 100%; +} +.tiny-form-item__error { + color: var(--ti-form-item-error-color); + font-size: var(--ti-form-item-error-font-size); + line-height: 1; + padding-top: 4px; + position: absolute; + top: 100%; + left: 0; +} +.tiny-form-item__error--inline { + position: relative; + top: auto; + left: auto; + display: inline-block; + margin-left: 10px; +} +.tiny-form-item.is-required:not(.is-no-asterisk) .tiny-form-item__label-wrap > .tiny-form-item__label:before, +.tiny-form-item.is-required:not(.is-no-asterisk) > .tiny-form-item__label:before { + content: '*'; + color: var(--ti-form-item-error-color); + margin-right: 4px; +} +.tiny-form-item.is-error .tiny-input__inner, +.tiny-form-item.is-error .tiny-input__inner:focus, +.tiny-form-item.is-error .tiny-textarea__inner, +.tiny-form-item.is-error .tiny-textarea__inner:focus { + border-color: var(--ti-form-item-error-color); + background-color: var(--ti-form-item-error-bgcolor); +} +.tiny-form-item.is-error .tiny-input-group__append .tiny-input__inner, +.tiny-form-item.is-error .tiny-input-group__prepend .tiny-input__inner { + border-color: transparent; +} +.tiny-form-item.is-error .tiny-input__validateIcon { + color: var(--ti-form-item-error-color); +} +.tiny-form-item.is-error .tiny-numeric__input-inner, +.tiny-form-item.is-error .tiny-numeric__input-inner:focus { + border-color: #f5222d; +} +.tiny-form-item--feedback .tiny-input__validateIcon { + display: inline-block; +} +.tiny-form-item .tiny-input__validateIcon { + display: none; +} +.tiny-zoom-in-top-enter-active, +.tiny-zoom-in-top-leave-active { + opacity: 1; + -webkit-transform: scaleY(1); + transform: scaleY(1); + -webkit-transition: opacity 0.3s cubic-bezier(0.23, 1, 0.32, 1), -webkit-transform 0.3s cubic-bezier(0.23, 1, 0.32, 1); + transition: opacity 0.3s cubic-bezier(0.23, 1, 0.32, 1), -webkit-transform 0.3s cubic-bezier(0.23, 1, 0.32, 1); + transition: transform 0.3s cubic-bezier(0.23, 1, 0.32, 1), opacity 0.3s cubic-bezier(0.23, 1, 0.32, 1); + transition: transform 0.3s cubic-bezier(0.23, 1, 0.32, 1), opacity 0.3s cubic-bezier(0.23, 1, 0.32, 1), + -webkit-transform 0.3s cubic-bezier(0.23, 1, 0.32, 1); + -webkit-transform-origin: center top; + transform-origin: center top; +} +.tiny-zoom-in-top-enter, +.tiny-zoom-in-top-enter-from, +.tiny-zoom-in-top-leave-active { + opacity: 0; + -webkit-transform: scaleY(0); + transform: scaleY(0); +} +.tiny-gantt { + width: 100%; + height: 500px; +} +.container { + padding-right: 10px; + margin-right: auto; + padding-left: 10px; + margin-left: auto; +} +.container:after, +.container:before { + content: ''; + display: table; +} +.container:after { + clear: both; +} +@media (min-width: 768px) { + .container { + width: 788px; + } +} +@media (min-width: 992px) { + .container { + width: 1012px; + } +} +@media (min-width: 1200px) { + .container { + width: 1220px; + } +} +@media (min-width: 1920px) { + .container { + width: 1940px; + } +} +.row { + margin-left: -10px; + margin-right: -10px; +} +.row:after, +.row:before { + content: ''; + display: table; +} +.row:after { + clear: both; +} +.row h3 { + margin-left: 10px; +} +.tiny-filter .row { + overflow: hidden; +} +.tiny-filter .row .title { + margin-left: 10px; +} +.col-lg-1, +.col-lg-10, +.col-lg-11, +.col-lg-12, +.col-lg-2, +.col-lg-3, +.col-lg-4, +.col-lg-5, +.col-lg-6, +.col-lg-7, +.col-lg-8, +.col-lg-9, +.col-md-1, +.col-md-10, +.col-md-11, +.col-md-12, +.col-md-2, +.col-md-3, +.col-md-4, +.col-md-5, +.col-md-6, +.col-md-7, +.col-md-8, +.col-md-9, +.col-sm-1, +.col-sm-10, +.col-sm-11, +.col-sm-12, +.col-sm-2, +.col-sm-3, +.col-sm-4, +.col-sm-5, +.col-sm-6, +.col-sm-7, +.col-sm-8, +.col-sm-9, +.col-xl-1, +.col-xl-10, +.col-xl-11, +.col-xl-12, +.col-xl-2, +.col-xl-3, +.col-xl-4, +.col-xl-5, +.col-xl-6, +.col-xl-7, +.col-xl-8, +.col-xl-9, +.col-xs-1, +.col-xs-10, +.col-xs-11, +.col-xs-12, +.col-xs-2, +.col-xs-3, +.col-xs-4, +.col-xs-5, +.col-xs-6, +.col-xs-7, +.col-xs-8, +.col-xs-9 { + position: relative; + min-height: 1px; + padding-left: 10px; + padding-right: 10px; + -webkit-box-sizing: border-box; + box-sizing: border-box; +} +.col-xs-1, +.col-xs-10, +.col-xs-11, +.col-xs-12, +.col-xs-2, +.col-xs-3, +.col-xs-4, +.col-xs-5, +.col-xs-6, +.col-xs-7, +.col-xs-8, +.col-xs-9 { + float: left; +} +.col-xs-12 { + width: 100%; +} +.col-xs-11 { + width: 91.66666667%; +} +.col-xs-10 { + width: 83.33333333%; +} +.col-xs-9 { + width: 75%; +} +.col-xs-8 { + width: 66.66666667%; +} +.col-xs-7 { + width: 58.33333333%; +} +.col-xs-6 { + width: 50%; +} +.col-xs-5 { + width: 41.66666667%; +} +.col-xs-4 { + width: 33.33333333%; +} +.col-xs-3 { + width: 25%; +} +.col-xs-2 { + width: 16.66666667%; +} +.col-xs-1 { + width: 8.33333333%; +} +.col-xs-push-12 { + left: 100%; +} +.col-xs-push-11 { + left: 91.66666667%; +} +.col-xs-push-10 { + left: 83.33333333%; +} +.col-xs-push-9 { + left: 75%; +} +.col-xs-push-8 { + left: 66.66666667%; +} +.col-xs-push-7 { + left: 58.33333333%; +} +.col-xs-push-6 { + left: 50%; +} +.col-xs-push-5 { + left: 41.66666667%; +} +.col-xs-push-4 { + left: 33.33333333%; +} +.col-xs-push-3 { + left: 25%; +} +.col-xs-push-2 { + left: 16.66666667%; +} +.col-xs-push-1 { + left: 8.33333333%; +} +.col-xs-push-0 { + left: 0; +} +.col-xs-pull-12 { + right: 100%; +} +.col-xs-pull-11 { + right: 91.66666667%; +} +.col-xs-pull-10 { + right: 83.33333333%; +} +.col-xs-pull-9 { + right: 75%; +} +.col-xs-pull-8 { + right: 66.66666667%; +} +.col-xs-pull-7 { + right: 58.33333333%; +} +.col-xs-pull-6 { + right: 50%; +} +.col-xs-pull-5 { + right: 41.66666667%; +} +.col-xs-pull-4 { + right: 33.33333333%; +} +.col-xs-pull-3 { + right: 25%; +} +.col-xs-pull-2 { + right: 16.66666667%; +} +.col-xs-pull-1 { + right: 8.33333333%; +} +.col-xs-pull-0 { + right: 0; +} +.col-xs-offset-12 { + margin-left: 100%; +} +.col-xs-offset-11 { + margin-left: 91.66666667%; +} +.col-xs-offset-10 { + margin-left: 83.33333333%; +} +.col-xs-offset-9 { + margin-left: 75%; +} +.col-xs-offset-8 { + margin-left: 66.66666667%; +} +.col-xs-offset-7 { + margin-left: 58.33333333%; +} +.col-xs-offset-6 { + margin-left: 50%; +} +.col-xs-offset-5 { + margin-left: 41.66666667%; +} +.col-xs-offset-4 { + margin-left: 33.33333333%; +} +.col-xs-offset-3 { + margin-left: 25%; +} +.col-xs-offset-2 { + margin-left: 16.66666667%; +} +.col-xs-offset-1 { + margin-left: 8.33333333%; +} +.col-xs-offset-0 { + margin-left: 0; +} +@media (min-width: 768px) { + .col-sm-1, + .col-sm-10, + .col-sm-11, + .col-sm-12, + .col-sm-2, + .col-sm-3, + .col-sm-4, + .col-sm-5, + .col-sm-6, + .col-sm-7, + .col-sm-8, + .col-sm-9 { + float: left; + } + .col-sm-12 { + width: 100%; + } + .col-sm-11 { + width: 91.66666667%; + } + .col-sm-10 { + width: 83.33333333%; + } + .col-sm-9 { + width: 75%; + } + .col-sm-8 { + width: 66.66666667%; + } + .col-sm-7 { + width: 58.33333333%; + } + .col-sm-6 { + width: 50%; + } + .col-sm-5 { + width: 41.66666667%; + } + .col-sm-4 { + width: 33.33333333%; + } + .col-sm-3 { + width: 25%; + } + .col-sm-2 { + width: 16.66666667%; + } + .col-sm-1 { + width: 8.33333333%; + } + .col-sm-push-12 { + left: 100%; + } + .col-sm-push-11 { + left: 91.66666667%; + } + .col-sm-push-10 { + left: 83.33333333%; + } + .col-sm-push-9 { + left: 75%; + } + .col-sm-push-8 { + left: 66.66666667%; + } + .col-sm-push-7 { + left: 58.33333333%; + } + .col-sm-push-6 { + left: 50%; + } + .col-sm-push-5 { + left: 41.66666667%; + } + .col-sm-push-4 { + left: 33.33333333%; + } + .col-sm-push-3 { + left: 25%; + } + .col-sm-push-2 { + left: 16.66666667%; + } + .col-sm-push-1 { + left: 8.33333333%; + } + .col-sm-push-0 { + left: 0; + } + .col-sm-pull-12 { + right: 100%; + } + .col-sm-pull-11 { + right: 91.66666667%; + } + .col-sm-pull-10 { + right: 83.33333333%; + } + .col-sm-pull-9 { + right: 75%; + } + .col-sm-pull-8 { + right: 66.66666667%; + } + .col-sm-pull-7 { + right: 58.33333333%; + } + .col-sm-pull-6 { + right: 50%; + } + .col-sm-pull-5 { + right: 41.66666667%; + } + .col-sm-pull-4 { + right: 33.33333333%; + } + .col-sm-pull-3 { + right: 25%; + } + .col-sm-pull-2 { + right: 16.66666667%; + } + .col-sm-pull-1 { + right: 8.33333333%; + } + .col-sm-pull-0 { + right: 0; + } + .col-sm-offset-12 { + margin-left: 100%; + } + .col-sm-offset-11 { + margin-left: 91.66666667%; + } + .col-sm-offset-10 { + margin-left: 83.33333333%; + } + .col-sm-offset-9 { + margin-left: 75%; + } + .col-sm-offset-8 { + margin-left: 66.66666667%; + } + .col-sm-offset-7 { + margin-left: 58.33333333%; + } + .col-sm-offset-6 { + margin-left: 50%; + } + .col-sm-offset-5 { + margin-left: 41.66666667%; + } + .col-sm-offset-4 { + margin-left: 33.33333333%; + } + .col-sm-offset-3 { + margin-left: 25%; + } + .col-sm-offset-2 { + margin-left: 16.66666667%; + } + .col-sm-offset-1 { + margin-left: 8.33333333%; + } + .col-sm-offset-0 { + margin-left: 0; + } +} +@media (min-width: 992px) { + .col-md-1, + .col-md-10, + .col-md-11, + .col-md-12, + .col-md-2, + .col-md-3, + .col-md-4, + .col-md-5, + .col-md-6, + .col-md-7, + .col-md-8, + .col-md-9 { + float: left; + } + .col-md-12 { + width: 100%; + } + .col-md-11 { + width: 91.66666667%; + } + .col-md-10 { + width: 83.33333333%; + } + .col-md-9 { + width: 75%; + } + .col-md-8 { + width: 66.66666667%; + } + .col-md-7 { + width: 58.33333333%; + } + .col-md-6 { + width: 50%; + } + .col-md-5 { + width: 41.66666667%; + } + .col-md-4 { + width: 33.33333333%; + } + .col-md-3 { + width: 25%; + } + .col-md-2 { + width: 16.66666667%; + } + .col-md-1 { + width: 8.33333333%; + } + .col-md-push-12 { + left: 100%; + } + .col-md-push-11 { + left: 91.66666667%; + } + .col-md-push-10 { + left: 83.33333333%; + } + .col-md-push-9 { + left: 75%; + } + .col-md-push-8 { + left: 66.66666667%; + } + .col-md-push-7 { + left: 58.33333333%; + } + .col-md-push-6 { + left: 50%; + } + .col-md-push-5 { + left: 41.66666667%; + } + .col-md-push-4 { + left: 33.33333333%; + } + .col-md-push-3 { + left: 25%; + } + .col-md-push-2 { + left: 16.66666667%; + } + .col-md-push-1 { + left: 8.33333333%; + } + .col-md-push-0 { + left: 0; + } + .col-md-pull-12 { + right: 100%; + } + .col-md-pull-11 { + right: 91.66666667%; + } + .col-md-pull-10 { + right: 83.33333333%; + } + .col-md-pull-9 { + right: 75%; + } + .col-md-pull-8 { + right: 66.66666667%; + } + .col-md-pull-7 { + right: 58.33333333%; + } + .col-md-pull-6 { + right: 50%; + } + .col-md-pull-5 { + right: 41.66666667%; + } + .col-md-pull-4 { + right: 33.33333333%; + } + .col-md-pull-3 { + right: 25%; + } + .col-md-pull-2 { + right: 16.66666667%; + } + .col-md-pull-1 { + right: 8.33333333%; + } + .col-md-pull-0 { + right: 0; + } + .col-md-offset-12 { + margin-left: 100%; + } + .col-md-offset-11 { + margin-left: 91.66666667%; + } + .col-md-offset-10 { + margin-left: 83.33333333%; + } + .col-md-offset-9 { + margin-left: 75%; + } + .col-md-offset-8 { + margin-left: 66.66666667%; + } + .col-md-offset-7 { + margin-left: 58.33333333%; + } + .col-md-offset-6 { + margin-left: 50%; + } + .col-md-offset-5 { + margin-left: 41.66666667%; + } + .col-md-offset-4 { + margin-left: 33.33333333%; + } + .col-md-offset-3 { + margin-left: 25%; + } + .col-md-offset-2 { + margin-left: 16.66666667%; + } + .col-md-offset-1 { + margin-left: 8.33333333%; + } + .col-md-offset-0 { + margin-left: 0; + } +} +@media (min-width: 1200px) { + .col-lg-1, + .col-lg-10, + .col-lg-11, + .col-lg-12, + .col-lg-2, + .col-lg-3, + .col-lg-4, + .col-lg-5, + .col-lg-6, + .col-lg-7, + .col-lg-8, + .col-lg-9 { + float: left; + } + .col-lg-12 { + width: 100%; + } + .col-lg-11 { + width: 91.66666667%; + } + .col-lg-10 { + width: 83.33333333%; + } + .col-lg-9 { + width: 75%; + } + .col-lg-8 { + width: 66.66666667%; + } + .col-lg-7 { + width: 58.33333333%; + } + .col-lg-6 { + width: 50%; + } + .col-lg-5 { + width: 41.66666667%; + } + .col-lg-4 { + width: 33.33333333%; + } + .col-lg-3 { + width: 25%; + } + .col-lg-2 { + width: 16.66666667%; + } + .col-lg-1 { + width: 8.33333333%; + } + .col-lg-push-12 { + left: 100%; + } + .col-lg-push-11 { + left: 91.66666667%; + } + .col-lg-push-10 { + left: 83.33333333%; + } + .col-lg-push-9 { + left: 75%; + } + .col-lg-push-8 { + left: 66.66666667%; + } + .col-lg-push-7 { + left: 58.33333333%; + } + .col-lg-push-6 { + left: 50%; + } + .col-lg-push-5 { + left: 41.66666667%; + } + .col-lg-push-4 { + left: 33.33333333%; + } + .col-lg-push-3 { + left: 25%; + } + .col-lg-push-2 { + left: 16.66666667%; + } + .col-lg-push-1 { + left: 8.33333333%; + } + .col-lg-push-0 { + left: 0; + } + .col-lg-pull-12 { + right: 100%; + } + .col-lg-pull-11 { + right: 91.66666667%; + } + .col-lg-pull-10 { + right: 83.33333333%; + } + .col-lg-pull-9 { + right: 75%; + } + .col-lg-pull-8 { + right: 66.66666667%; + } + .col-lg-pull-7 { + right: 58.33333333%; + } + .col-lg-pull-6 { + right: 50%; + } + .col-lg-pull-5 { + right: 41.66666667%; + } + .col-lg-pull-4 { + right: 33.33333333%; + } + .col-lg-pull-3 { + right: 25%; + } + .col-lg-pull-2 { + right: 16.66666667%; + } + .col-lg-pull-1 { + right: 8.33333333%; + } + .col-lg-pull-0 { + right: 0; + } + .col-lg-offset-12 { + margin-left: 100%; + } + .col-lg-offset-11 { + margin-left: 91.66666667%; + } + .col-lg-offset-10 { + margin-left: 83.33333333%; + } + .col-lg-offset-9 { + margin-left: 75%; + } + .col-lg-offset-8 { + margin-left: 66.66666667%; + } + .col-lg-offset-7 { + margin-left: 58.33333333%; + } + .col-lg-offset-6 { + margin-left: 50%; + } + .col-lg-offset-5 { + margin-left: 41.66666667%; + } + .col-lg-offset-4 { + margin-left: 33.33333333%; + } + .col-lg-offset-3 { + margin-left: 25%; + } + .col-lg-offset-2 { + margin-left: 16.66666667%; + } + .col-lg-offset-1 { + margin-left: 8.33333333%; + } + .col-lg-offset-0 { + margin-left: 0; + } +} +@media (min-width: 1920px) { + .col-xl-1, + .col-xl-10, + .col-xl-11, + .col-xl-12, + .col-xl-2, + .col-xl-3, + .col-xl-4, + .col-xl-5, + .col-xl-6, + .col-xl-7, + .col-xl-8, + .col-xl-9 { + float: left; + } + .col-xl-12 { + width: 100%; + } + .col-xl-11 { + width: 91.66666667%; + } + .col-xl-10 { + width: 83.33333333%; + } + .col-xl-9 { + width: 75%; + } + .col-xl-8 { + width: 66.66666667%; + } + .col-xl-7 { + width: 58.33333333%; + } + .col-xl-6 { + width: 50%; + } + .col-xl-5 { + width: 41.66666667%; + } + .col-xl-4 { + width: 33.33333333%; + } + .col-xl-3 { + width: 25%; + } + .col-xl-2 { + width: 16.66666667%; + } + .col-xl-1 { + width: 8.33333333%; + } + .col-xl-push-12 { + left: 100%; + } + .col-xl-push-11 { + left: 91.66666667%; + } + .col-xl-push-10 { + left: 83.33333333%; + } + .col-xl-push-9 { + left: 75%; + } + .col-xl-push-8 { + left: 66.66666667%; + } + .col-xl-push-7 { + left: 58.33333333%; + } + .col-xl-push-6 { + left: 50%; + } + .col-xl-push-5 { + left: 41.66666667%; + } + .col-xl-push-4 { + left: 33.33333333%; + } + .col-xl-push-3 { + left: 25%; + } + .col-xl-push-2 { + left: 16.66666667%; + } + .col-xl-push-1 { + left: 8.33333333%; + } + .col-xl-push-0 { + left: 0; + } + .col-xl-pull-12 { + right: 100%; + } + .col-xl-pull-11 { + right: 91.66666667%; + } + .col-xl-pull-10 { + right: 83.33333333%; + } + .col-xl-pull-9 { + right: 75%; + } + .col-xl-pull-8 { + right: 66.66666667%; + } + .col-xl-pull-7 { + right: 58.33333333%; + } + .col-xl-pull-6 { + right: 50%; + } + .col-xl-pull-5 { + right: 41.66666667%; + } + .col-xl-pull-4 { + right: 33.33333333%; + } + .col-xl-pull-3 { + right: 25%; + } + .col-xl-pull-2 { + right: 16.66666667%; + } + .col-xl-pull-1 { + right: 8.33333333%; + } + .col-xl-pull-0 { + right: 0; + } + .col-xl-offset-12 { + margin-left: 100%; + } + .col-xl-offset-11 { + margin-left: 91.66666667%; + } + .col-xl-offset-10 { + margin-left: 83.33333333%; + } + .col-xl-offset-9 { + margin-left: 75%; + } + .col-xl-offset-8 { + margin-left: 66.66666667%; + } + .col-xl-offset-7 { + margin-left: 58.33333333%; + } + .col-xl-offset-6 { + margin-left: 50%; + } + .col-xl-offset-5 { + margin-left: 41.66666667%; + } + .col-xl-offset-4 { + margin-left: 33.33333333%; + } + .col-xl-offset-3 { + margin-left: 25%; + } + .col-xl-offset-2 { + margin-left: 16.66666667%; + } + .col-xl-offset-1 { + margin-left: 8.33333333%; + } + .col-xl-offset-0 { + margin-left: 0; + } +} +[class*='tiny-grid-icon__'] { + display: inline-block; + vertical-align: middle; + position: relative; + direction: ltr; + font-family: var(--ti-grid-font-family); +} +.tiny-grid-icon__zoomin { + width: 0.8em; + height: 0.8em; + margin: 0.1em; + border-width: 0.1em; + border-style: solid; + border-color: inherit; +} +.tiny-grid-icon__zoomout { + width: 1em; + height: 1em; + line-height: 1em; + position: relative; +} +.tiny-grid-icon__zoomout:before { + content: ''; + position: absolute; + right: 0; + width: 0.7em; + border-style: solid; + top: 0; + border-width: 0.1em; + height: 0.7em; + border-color: inherit; +} +.tiny-grid-icon__zoomout:after { + content: ''; + position: absolute; + bottom: 0.1em; + background-color: #fff; + left: 0.1em; + border-style: solid; + width: 0.7em; + border-width: 0.1em; + height: 0.7em; + border-color: inherit; +} +.tiny-grid-icon__menu { + width: 0.22em; + height: 0.22em; + -webkit-box-shadow: 0 -0.4em 0, -0.4em -0.4em 0, 0.4em -0.4em 0, 0 0 0 1em inset, -0.4em 0 0, 0.4em 0 0, 0 0.4em 0, + -0.4em 0.4em 0, 0.4em 0.4em 0; + box-shadow: 0 -0.4em 0, -0.4em -0.4em 0, 0.4em -0.4em 0, 0 0 0 1em inset, -0.4em 0 0, 0.4em 0 0, 0 0.4em 0, + -0.4em 0.4em 0, 0.4em 0.4em 0; + margin: 0.58em; + -webkit-transition: all 0.2s ease-in-out; + transition: all 0.2s ease-in-out; +} +.tiny-grid-icon__caret-bottom, +.tiny-grid-icon__caret-left, +.tiny-grid-icon__caret-right, +.tiny-grid-icon__caret-top { + width: 1em; + height: 1em; + line-height: 1em; +} +.tiny-grid-icon__caret-bottom:before, +.tiny-grid-icon__caret-left:before, +.tiny-grid-icon__caret-right:before, +.tiny-grid-icon__caret-top:before { + content: ''; + left: 0; + bottom: 0.25em; + border-right-color: transparent; + position: absolute; + border-width: 0.5em; + border-style: solid; + border-top-color: transparent; + border-bottom-color: inherit; + border-left-color: transparent; + -webkit-transition: border 0.1s ease-in-out; + transition: border 0.1s ease-in-out; +} +.tiny-grid-icon__caret-bottom { + -webkit-transform: rotate(180deg); + transform: rotate(180deg); +} +.tiny-grid-icon__caret-left { + -webkit-transform: rotate(-90deg); + transform: rotate(-90deg); +} +.tiny-grid-icon__caret-right { + -webkit-transform: rotate(90deg); + transform: rotate(90deg); +} +.tiny-grid-icon__arrow-top { + width: 1em; + height: 1em; + line-height: 1em; + -webkit-transform: rotate(-45deg); + transform: rotate(-45deg); +} +.tiny-grid-icon__arrow-top:before { + content: ''; + position: absolute; + top: 0.38em; + left: 0.12em; + width: 0.5em; + height: 0.5em; + border-width: 0.1em; + border-style: solid; + border-top-color: inherit; + border-bottom-color: transparent; + border-left-color: transparent; + border-right-color: inherit; +} +.tiny-grid-icon__arrow-bottom { + width: 1em; + height: 1em; + line-height: 1em; + -webkit-transform: rotate(135deg); + transform: rotate(135deg); +} +.tiny-grid-icon__arrow-bottom:before { + content: ''; + position: absolute; + top: 0.38em; + left: 0.12em; + width: 0.5em; + height: 0.5em; + border-width: 0.1em; + border-style: solid; + border-top-color: inherit; + border-bottom-color: transparent; + border-left-color: transparent; + border-right-color: inherit; +} +.tiny-grid-icon__arrow-left { + width: 1em; + height: 1em; + line-height: 1em; + -webkit-transform: rotate(-135deg); + transform: rotate(-135deg); +} +.tiny-grid-icon__arrow-left:before { + content: ''; + position: absolute; + top: 0.38em; + left: 0.12em; + width: 0.5em; + height: 0.5em; + border-width: 0.1em; + border-style: solid; + border-top-color: inherit; + border-bottom-color: transparent; + border-left-color: transparent; + border-right-color: inherit; +} +.tiny-grid-icon__arrow-right { + width: 1em; + height: 1em; + line-height: 1em; + -webkit-transform: rotate(45deg); + transform: rotate(45deg); +} +.tiny-grid-icon__arrow-right:before { + content: ''; + position: absolute; + top: 0.38em; + left: 0.12em; + width: 0.5em; + height: 0.5em; + border-width: 0.1em; + border-style: solid; + border-top-color: inherit; + border-bottom-color: transparent; + border-left-color: transparent; + border-right-color: inherit; +} +.tiny-grid-icon__d-arrow-top { + width: 1em; + height: 1em; + line-height: 1em; + -webkit-transform: rotate(-45deg); + transform: rotate(-45deg); +} +.tiny-grid-icon__d-arrow-top:before { + content: ''; + position: absolute; + top: 0.24em; + left: 0.26em; + width: 0.5em; + height: 0.5em; + border-width: 0.08em; + border-style: solid; + border-right-color: inherit; + border-top-color: inherit; + border-left-color: transparent; + border-bottom-color: transparent; +} +.tiny-grid-icon__d-arrow-top:after { + content: ''; + position: absolute; + top: 0.42em; + left: 0.1em; + width: 0.5em; + height: 0.5em; + border-width: 0.08em; + border-style: solid; + border-top-color: inherit; + border-bottom-color: transparent; + border-left-color: transparent; + border-right-color: inherit; +} +.tiny-grid-icon__d-arrow-bottom { + width: 1em; + height: 1em; + line-height: 1em; + -webkit-transform: rotate(135deg); + transform: rotate(135deg); +} +.tiny-grid-icon__d-arrow-bottom:before { + content: ''; + position: absolute; + top: 0.24em; + left: 0.26em; + width: 0.5em; + height: 0.5em; + border-width: 0.08em; + border-style: solid; + border-right-color: inherit; + border-top-color: inherit; + border-left-color: transparent; + border-bottom-color: transparent; +} +.tiny-grid-icon__d-arrow-bottom:after { + content: ''; + position: absolute; + top: 0.42em; + left: 0.1em; + width: 0.5em; + height: 0.5em; + border-width: 0.08em; + border-style: solid; + border-top-color: inherit; + border-bottom-color: transparent; + border-left-color: transparent; + border-right-color: inherit; +} +.tiny-grid-icon__d-arrow-left { + width: 1em; + height: 1em; + line-height: 1em; + -webkit-transform: rotate(-135deg); + transform: rotate(-135deg); +} +.tiny-grid-icon__d-arrow-left:before { + content: ''; + position: absolute; + top: 0.24em; + left: 0.26em; + width: 0.5em; + height: 0.5em; + border-width: 0.08em; + border-style: solid; + border-right-color: inherit; + border-top-color: inherit; + border-left-color: transparent; + border-bottom-color: transparent; +} +.tiny-grid-icon__d-arrow-left:after { + content: ''; + position: absolute; + top: 0.42em; + left: 0.1em; + width: 0.5em; + height: 0.5em; + border-width: 0.08em; + border-style: solid; + border-top-color: inherit; + border-bottom-color: transparent; + border-left-color: transparent; + border-right-color: inherit; +} +.tiny-grid-icon__d-arrow-right { + width: 1em; + height: 1em; + line-height: 1em; + -webkit-transform: rotate(45deg); + transform: rotate(45deg); +} +.tiny-grid-icon__d-arrow-right:before { + content: ''; + position: absolute; + top: 0.24em; + left: 0.26em; + width: 0.5em; + height: 0.5em; + border-width: 0.08em; + border-style: solid; + border-right-color: inherit; + border-top-color: inherit; + border-left-color: transparent; + border-bottom-color: transparent; +} +.tiny-grid-icon__d-arrow-right:after { + content: ''; + position: absolute; + top: 0.42em; + left: 0.1em; + width: 0.5em; + height: 0.5em; + border-width: 0.08em; + border-style: solid; + border-top-color: inherit; + border-bottom-color: transparent; + border-left-color: transparent; + border-right-color: inherit; +} +.tiny-grid-icon__funnel { + width: 1em; + height: 1em; + line-height: 1em; +} +.tiny-grid-icon__funnel:before { + content: ''; + border-top-color: inherit; + position: absolute; + border-bottom-color: transparent; + top: 0.1em; + border-right-color: transparent; + left: 0; + border-left-color: transparent; + border-width: 0.5em; + border-style: solid; +} +.tiny-grid-icon__funnel:after { + content: ''; + position: absolute; + left: 0.4em; + top: 0.5em; + width: 0; + height: 0.4em; + border-width: 0 0.2em 0 0; + border-style: solid; + border-right-color: inherit; +} +.tiny-grid-icon__edit-outline { + width: 1em; + height: 1em; + line-height: 1em; + border-radius: 0.2em; + border-width: 0.1em; + border-style: solid; + border-color: inherit; +} +.tiny-grid-icon__edit-outline:before { + content: ''; + position: absolute; + top: -0.1em; + right: -0.1em; + width: 0.4em; + height: 0.4em; + background-color: #fff; +} +.tiny-grid-icon__edit-outline:after { + content: ''; + position: absolute; + left: 0.15em; + top: 0.12em; + width: 0.9em; + height: 0; + border-radius: 0.2em; + border-width: 0 0 0.15em 0; + border-style: solid; + border-color: inherit; + -webkit-transform: rotate(-45deg); + transform: rotate(-45deg); +} +.tiny-grid-icon__more { + width: 1em; + height: 1em; + line-height: 1em; +} +.tiny-grid-icon__more:before { + content: '...'; + position: absolute; + top: 0; + left: 0.1em; + line-height: 0.5em; + font-weight: 700; +} +.tiny-grid-icon__close { + width: 1em; + height: 1em; + line-height: 1em; +} +.tiny-grid-icon__close:after, +.tiny-grid-icon__close:before { + content: ''; + position: absolute; + left: 0; + top: 0; + -webkit-transform: rotate(45deg); + transform: rotate(45deg); + border-style: solid; + border-width: 0; +} +.tiny-grid-icon__close:before { + width: 1em; + border-bottom-width: 0.1em; + top: 0.45em; +} +.tiny-grid-icon__close:after { + height: 1em; + border-right-width: 0.1em; + left: 0.45em; +} +.tiny-grid-icon__refresh { + width: 1em; + height: 1em; + line-height: 1em; + border-style: solid; + border-width: 0.1em; + border-right-color: transparent !important; + border-radius: 50%; + border-left-color: transparent !important; +} +.tiny-grid-icon__refresh:after { + right: 50%; + bottom: 0; + -webkit-transform: translateX(-50%) rotate(135deg); + transform: translateX(-50%) rotate(135deg); +} +.tiny-grid-icon__refresh:before { + left: 50%; + top: 0; + -webkit-transform: translateX(50%) rotate(-45deg); + transform: translateX(50%) rotate(-45deg); +} +.tiny-grid-icon__refresh:after, +.tiny-grid-icon__refresh:before { + content: ''; + position: absolute; + border-left-color: transparent; + width: 0; + border-right-color: transparent; + height: 0; + border-bottom-color: transparent; + border-width: 0.25em; + border-style: solid; +} +.tiny-grid-icon__refresh.roll { + -webkit-animation: rollCircle 1s infinite linear; + animation: rollCircle 1s infinite linear; +} +.tiny-grid-icon__question { + width: 1em; + height: 1em; + line-height: 1em; +} +.tiny-grid-icon__question:before { + content: ''; + border-radius: 50%; + border-width: 0.5em; + border-style: solid; + border-color: inherit; + position: absolute; + top: 0; + left: 0; +} +.tiny-grid-icon__question:after { + position: absolute; + color: #fff; + color: var(--ti-grid-light-color, #fff); + font-size: 0.7em; + display: inline-block; + top: 0; + left: 0; + width: inherit; + height: inherit; + text-align: center; + font-weight: 700; + content: '?'; +} +.tiny-grid-icon__info { + width: 1em; + height: 1em; + line-height: 1em; +} +.tiny-grid-icon__info:before { + content: ''; + border-radius: 50%; + border-width: 0.5em; + border-style: solid; + border-color: inherit; + position: absolute; + top: 0; + left: 0; +} +.tiny-grid-icon__info:after { + position: absolute; + color: #fff; + color: var(--ti-grid-light-color, #fff); + font-size: 0.7em; + display: inline-block; + top: 0; + left: 0; + width: inherit; + height: inherit; + text-align: center; + font-weight: 700; + content: '!'; + -webkit-transform: rotate(180deg) translateY(1px); + transform: rotate(180deg) translateY(1px); +} +@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) { + .tiny-grid-icon__info:after { + font-size: var(--ti-common-font-size-1); + } +} +@media screen and (-ms-ime-align: auto) { + .tiny-grid-icon__info:after { + font-size: var(--ti-common-font-size-1); + } +} +.tiny-grid-icon__warning { + width: 1em; + height: 1em; + line-height: 1em; +} +.tiny-grid-icon__warning:before { + content: ''; + border-radius: 50%; + border-width: 0.5em; + border-style: solid; + border-color: inherit; + position: absolute; + top: 0; + left: 0; +} +.tiny-grid-icon__warning:after { + position: absolute; + color: #fff; + color: var(--ti-grid-light-color, #fff); + font-size: 0.7em; + display: inline-block; + top: 0; + left: 0; + width: inherit; + height: inherit; + text-align: center; + font-weight: 700; + content: '!'; +} +@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) { + .tiny-grid-icon__warning:after { + font-size: var(--ti-common-font-size-1); + } +} +@media screen and (-ms-ime-align: auto) { + .tiny-grid-icon__warning:after { + font-size: var(--ti-common-font-size-1); + } +} +.tiny-grid-icon__success { + width: 1em; + height: 1em; + line-height: 1em; +} +.tiny-grid-icon__success:before { + content: ''; + border-radius: 50%; + border-width: 0.5em; + border-style: solid; + border-color: inherit; + position: absolute; + top: 0; + left: 0; +} +.tiny-grid-icon__success:after { + content: ''; + position: absolute; + height: 0.55em; + width: 0.3em; + left: 0.35em; + top: 0.15em; + border-width: 0.1em; + border-style: solid; + border-color: #fff; + border-left: 0; + border-top: 0; + -webkit-transform: rotate(45deg); + transform: rotate(45deg); +} +.tiny-grid-icon__error { + width: 1em; + height: 1em; + line-height: 1em; +} +.tiny-grid-icon__error:before { + content: ''; + border-radius: 50%; + border-width: 0.5em; + border-style: solid; + border-color: inherit; + position: absolute; + top: 0; + left: 0; +} +.tiny-grid-icon__error:after { + position: absolute; + color: #fff; + color: var(--ti-grid-light-color, #fff); + font-size: 0.7em; + display: inline-block; + top: 0; + left: 0; + width: inherit; + height: inherit; + text-align: center; + font-weight: 700; + content: '\2716'; +} +@-webkit-keyframes rollCircle { + 0% { + -webkit-transform: rotate(0); + transform: rotate(0); + } + 100% { + -webkit-transform: rotate(360deg); + transform: rotate(360deg); + } +} +@keyframes rollCircle { + 0% { + -webkit-transform: rotate(0); + transform: rotate(0); + } + 100% { + -webkit-transform: rotate(360deg); + transform: rotate(360deg); + } +} +.tiny-grid__animat .tiny-grid-filter__btn:after, +.tiny-grid__animat .tiny-grid-filter__btn:before, +.tiny-grid__animat .tiny-grid-sort__asc-btn:after, +.tiny-grid__animat .tiny-grid-sort__asc-btn:before, +.tiny-grid__animat .tiny-grid-sort__desc-btn:after, +.tiny-grid__animat .tiny-grid-sort__desc-btn:before { + -webkit-transition: border 0.1s ease-in-out; + transition: border 0.1s ease-in-out; +} +.tiny-grid__animat .tiny-grid__expand-icon { + -webkit-transition: all 0.1s ease-in-out; + transition: all 0.1s ease-in-out; +} +.tiny-grid__animat .tiny-grid-input__wrapper .tiny-grid-input { + -webkit-transition: border 0.1s ease-in-out; + transition: border 0.1s ease-in-out; +} +.tiny-grid__animat .tiny-grid-tree__node-btn { + -webkit-transition: -webkit-transform 0.1s ease-in-out; + transition: -webkit-transform 0.1s ease-in-out; + transition: transform 0.1s ease-in-out; + transition: transform 0.1s ease-in-out, -webkit-transform 0.1s ease-in-out; +} +.tiny-grid__animat .tiny-grid-checkbox > input:checked + span, +.tiny-grid__animat .tiny-grid-radio > input:checked + span { + -webkit-transition: background-color 0.1s ease-in-out; + transition: background-color 0.1s ease-in-out; +} +.tiny-grid { + position: relative; + overflow: hidden; + font-size: var(--ti-grid-font-size); + color: var(--ti-grid-font-color); + font-family: var(--ti-grid-font-family); + background-color: var(--ti-grid-light-color); +} +.tiny-grid.show__head .tiny-grid__fixed-left-wrapper .tiny-grid__body-wrapper:before, +.tiny-grid.show__head .tiny-grid__fixed-right-wrapper .tiny-grid__body-wrapper:before { + display: none; +} +.tiny-grid.show__foot.scroll__x .tiny-grid__body-wrapper { + overflow-x: auto; +} +.tiny-grid.show__foot.scroll__y .tiny-grid__body-wrapper.fixed-left__wrapper, +.tiny-grid.show__foot.scroll__y .tiny-grid__body-wrapper.fixed-right__wrapper { + padding-bottom: 12px; +} +@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) { + .tiny-grid.show__foot.scroll__y .tiny-grid__body-wrapper.fixed-left__wrapper .tiny-grid__body, + .tiny-grid.show__foot.scroll__y .tiny-grid__body-wrapper.fixed-right__wrapper .tiny-grid__body { + padding-bottom: 17px; + } +} +.tiny-grid.column__highlight .tiny-grid-header__column:not(.col__index):hover { + background-color: var(--ti-grid-column-hover-background-color); +} +.tiny-grid.size__medium .tiny-grid-body__column:not(.col__ellipsis), +.tiny-grid.size__medium .tiny-grid-footer__column:not(.col__ellipsis), +.tiny-grid.size__medium .tiny-grid-header__column:not(.col__ellipsis) { + padding: var(--ti-table-td-padding, 2px 8px); +} +.tiny-grid.size__medium .tiny-grid-body__column, +.tiny-grid.size__medium .tiny-grid-footer__column { + height: var(--ti-grid-medium-column-height, 46px); +} +.tiny-grid.size__medium .tiny-grid-loading .tiny-grid__spinner { + width: 50px; + height: 50px; +} +.tiny-grid.size__medium .tiny-grid-default-input, +.tiny-grid.size__medium .tiny-grid-default-select, +.tiny-grid.size__medium .tiny-grid-default-textarea, +.tiny-grid.size__medium .tiny-grid-input__wrapper { + height: var(--ti-grid-medium-column-height, 46px); +} +.tiny-grid.size__medium .tiny-grid-header__column .tiny-grid-resizable { + height: var(--ti-grid-medium-column-height, 46px); +} +.tiny-grid.size__small { + font-size: var(--ti-grid-font-size); +} +.tiny-grid.size__small .tiny-grid-body__column:not(.col__ellipsis), +.tiny-grid.size__small .tiny-grid-footer__column:not(.col__ellipsis), +.tiny-grid.size__small .tiny-grid-header__column:not(.col__ellipsis) { + padding: var(--ti-table-td-padding, 2px 8px); +} +.tiny-grid.size__small .tiny-grid-body__column, +.tiny-grid.size__small .tiny-grid-footer__column { + height: var(--ti-grid-small-column-height, 30px); +} +.tiny-grid.size__small .tiny-grid-loading .tiny-grid__spinner { + width: 44px; + height: 44px; +} +.tiny-grid.size__small .tiny-grid-default-input, +.tiny-grid.size__small .tiny-grid-default-select, +.tiny-grid.size__small .tiny-grid-default-textarea, +.tiny-grid.size__small .tiny-grid-input__wrapper { + height: var(--ti-grid-small-column-height, 30px); +} +.tiny-grid.size__small .tiny-grid-header__column .tiny-grid-resizable { + height: var(--ti-grid-small-column-height, 30px); +} +.tiny-grid.size__mini { + font-size: var(--ti-grid-font-size); +} +.tiny-grid.size__mini .tiny-grid-body__column:not(.col__ellipsis), +.tiny-grid.size__mini .tiny-grid-footer__column:not(.col__ellipsis), +.tiny-grid.size__mini .tiny-grid-header__column:not(.col__ellipsis) { + padding: var(--ti-table-td-padding, 2px 8px); +} +.tiny-grid.size__mini .tiny-grid-body__column, +.tiny-grid.size__mini .tiny-grid-footer__column { + height: var(--ti-grid-mini-column-height, 26px); +} +.tiny-grid.size__mini .tiny-grid-loading .tiny-grid__spinner { + width: 38px; + height: 38px; +} +.tiny-grid.size__mini .tiny-grid-default-input, +.tiny-grid.size__mini .tiny-grid-default-select, +.tiny-grid.size__mini .tiny-grid-default-textarea, +.tiny-grid.size__mini .tiny-grid-input__wrapper { + height: var(--ti-grid-mini-column-height, 26px); +} +.tiny-grid.size__mini .tiny-grid-header__column .tiny-grid-resizable { + height: var(--ti-grid-mini-column-height, 26px); +} +.tiny-grid .fixed__hidden { + visibility: hidden; +} +.tiny-grid table { + border-spacing: 0; + border-collapse: separate; + table-layout: fixed; +} +.tiny-grid.tiny-grid__stripe .tiny-grid-body__row:not(.row__hover):nth-child(2n) { + background-color: var(--ti-grid-row-striped-background-color); +} +.tiny-grid.tiny-grid__stripe .tiny-grid-body__row.row__selected:not(.row__hover):nth-child(2n) { + background-color: rgba(47, 143, 232, 0.1); +} +.tiny-grid.tiny-grid__stripe .tiny-grid-body__row.row__selected:not(.row__hover):nth-child(2n + 1) { + background-color: rgba(47, 143, 232, 0.15); +} +.tiny-grid.tiny-grid__stripe.mark-insert .tiny-grid-body__row.row__new { + background-color: #f2f5fc; +} +.tiny-grid.tiny-grid__border:after, +.tiny-grid.tiny-grid__border:before { + content: ''; + position: absolute; + left: 0; + width: 100%; + height: 0; + z-index: 1; +} +.tiny-grid.tiny-grid__border:before { + top: 0; + border-top: 1px solid var(--ti-grid-border-color); +} +.tiny-grid.tiny-grid__border:after { + bottom: 0; + border-bottom: 1px solid var(--ti-grid-border-color); +} +.tiny-grid.tiny-grid__border .tiny-grid__header { + border: 0; + border-spacing: 0; + border-collapse: separate; +} +.tiny-grid.tiny-grid__border .tiny-grid-body__column, +.tiny-grid.tiny-grid__border .tiny-grid-footer__column, +.tiny-grid.tiny-grid__border .tiny-grid-header__column { + background-image: -webkit-gradient( + linear, + right top, + left top, + from(var(--ti-grid-border-color)), + to(var(--ti-grid-border-color)) + ), + -webkit-gradient(linear, left top, left bottom, from(var(--ti-grid-border-color)), to(var(--ti-grid-border-color))); + background-image: linear-gradient(-90deg, var(--ti-grid-border-color), var(--ti-grid-border-color)), + linear-gradient(-180deg, var(--ti-grid-border-color), var(--ti-grid-border-color)); + background-repeat: no-repeat; + background-size: 1px 100%, 100% 1px; + background-position: 100% 0, 100% 100%; + border: none; +} +.tiny-grid.tiny-grid__border .tiny-grid__fixed-left-wrapper .tiny-grid-body__column { + border-right-color: var(--ti-grid-border-color); +} +.tiny-grid.tiny-grid__border .tiny-grid__body-wrapper, +.tiny-grid.tiny-grid__border .tiny-grid__fixed-left-body-wrapper, +.tiny-grid.tiny-grid__border .tiny-grid__fixed-right-body-wrapper { + border-bottom: none; +} +.tiny-grid.tiny-grid__border .tiny-grid__fixed-left-wrapper::before, +.tiny-grid.tiny-grid__border .tiny-grid__fixed-right-wrapper::before { + border-top-width: 1px; +} +.tiny-grid.tiny-grid__border .tiny-grid__border-line:after, +.tiny-grid.tiny-grid__border .tiny-grid__border-line:before { + content: ''; + position: absolute; + top: 0; + width: 0; + height: 100%; + z-index: 1; +} +.tiny-grid.tiny-grid__border .tiny-grid__border-line:before { + left: 0; + border-left: 1px solid var(--ti-grid-border-color); +} +.tiny-grid.tiny-grid__border .tiny-grid__border-line:after { + right: 0; + border-right: 1px solid var(--ti-grid-border-color); +} +.tiny-grid.tiny-grid__checked { + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; +} +.tiny-grid.tiny-grid__checked .tiny-grid-body__column.col__index, +.tiny-grid.tiny-grid__checked .tiny-grid-header__column.col__index { + text-align: center; + cursor: default; +} +.tiny-grid.tiny-grid__checked .tiny-grid-header__column.col__index .tiny-grid-cell { + visibility: hidden; +} +.tiny-grid.tiny-grid__checked .tiny-grid-body__column.col__index { + background-color: var(--ti-grid-header-background-color); +} +.tiny-grid.tiny-grid__checked .tiny-grid-body__column.col__index.col__index-checked { + background-color: #dcdcdc; +} +.tiny-grid .tiny-grid__footer-wrapper, +.tiny-grid .tiny-grid__header-wrapper { + overflow-x: hidden; + overflow-y: hidden; +} +.tiny-grid .tiny-grid__footer-wrapper { + border: 1px solid var(--ti-grid-border-color); + border-bottom: none; + overflow: hidden !important; +} +.tiny-grid .tiny-grid__footer-wrapper .tiny-grid-footer__row .tiny-grid-cell.cell__summary { + font-weight: 700; + text-align: right; +} +.tiny-grid .tiny-grid__fixed-left-wrapper, +.tiny-grid .tiny-grid__fixed-right-wrapper { + width: 100%; + position: absolute; + top: 0; + z-index: 1; + overflow: hidden; + background-color: var(--ti-grid-light-color); +} +.tiny-grid .tiny-grid__fixed-left-wrapper:before, +.tiny-grid .tiny-grid__fixed-right-wrapper:before { + content: ''; + position: absolute; + top: 0; + left: 0; + width: 100%; + height: 0; + border-top: 0 solid var(--ti-grid-border-color); + z-index: 1; +} +.tiny-grid .tiny-grid__fixed-left-wrapper .tiny-grid__body-wrapper, +.tiny-grid .tiny-grid__fixed-right-wrapper .tiny-grid__body-wrapper { + overflow-x: hidden; + border-bottom: none; +} +.tiny-grid .tiny-grid__fixed-left-wrapper { + left: 0; + width: 200px; + border-right: 0 solid var(--ti-grid-border-color); +} +.tiny-grid .tiny-grid__fixed-left-wrapper.scrolling__middle { + -webkit-box-shadow: 2px 2px 6px rgba(0, 0, 0, 0.12); + box-shadow: 2px 2px 6px rgba(0, 0, 0, 0.12); +} +.tiny-grid .tiny-grid__fixed-right-wrapper { + right: 0; +} +.tiny-grid .tiny-grid__fixed-right-wrapper.scrolling__middle { + -webkit-box-shadow: -2px 2px 6px rgba(0, 0, 0, 0.12); + box-shadow: -2px 2px 6px rgba(0, 0, 0, 0.12); +} +.tiny-grid .tiny-grid__body-wrapper, +.tiny-grid .tiny-grid__footer-wrapper, +.tiny-grid .tiny-grid__header-wrapper { + position: relative; +} +.tiny-grid .tiny-grid__body-wrapper.fixed-left__wrapper, +.tiny-grid .tiny-grid__body-wrapper.fixed-right__wrapper, +.tiny-grid .tiny-grid__footer-wrapper.fixed-left__wrapper, +.tiny-grid .tiny-grid__footer-wrapper.fixed-right__wrapper, +.tiny-grid .tiny-grid__header-wrapper.fixed-left__wrapper, +.tiny-grid .tiny-grid__header-wrapper.fixed-right__wrapper { + position: absolute; + top: 0; +} +.tiny-grid .tiny-grid__body-wrapper.fixed-left__wrapper, +.tiny-grid .tiny-grid__footer-wrapper.fixed-left__wrapper, +.tiny-grid .tiny-grid__header-wrapper.fixed-left__wrapper { + left: 0; +} +.tiny-grid .tiny-grid__body-wrapper.fixed-right__wrapper, +.tiny-grid .tiny-grid__footer-wrapper.fixed-right__wrapper, +.tiny-grid .tiny-grid__header-wrapper.fixed-right__wrapper { + right: 0; + overflow-y: auto; +} +.tiny-grid .tiny-grid__header-wrapper.fixed-right__wrapper { + -ms-overflow-style: none; +} +.tiny-grid.tiny-grid-cell__resize * { + cursor: col-resize; +} +.tiny-grid .tiny-grid-body__row { + background-color: var(--ti-grid-row-odd-background-color); +} +.tiny-grid .tiny-grid-body__row.row__hover { + background-color: var(--ti-grid-row-hover-background-color); +} +.tiny-grid .tiny-grid-body__row.row__current { + background-color: var(--ti-grid-row-hover-background-color); +} +.tiny-grid .tiny-grid-body__column, +.tiny-grid .tiny-grid-footer__column, +.tiny-grid .tiny-grid-header__column { + text-align: left; +} +.tiny-grid .tiny-grid-body__column:not(.col__ellipsis), +.tiny-grid .tiny-grid-footer__column:not(.col__ellipsis), +.tiny-grid .tiny-grid-header__column:not(.col__ellipsis) { + padding: var(--ti-table-td-padding, 2px 8px); +} +.tiny-grid .tiny-grid-body__column.col__current, +.tiny-grid .tiny-grid-footer__column.col__current, +.tiny-grid .tiny-grid-header__column.col__current { + background-color: var(--ti-grid-column-current-background-color); +} +.tiny-grid .tiny-grid-body__column.col__center, +.tiny-grid .tiny-grid-footer__column.col__center, +.tiny-grid .tiny-grid-header__column.col__center { + text-align: center; +} +.tiny-grid .tiny-grid-body__column.col__right, +.tiny-grid .tiny-grid-footer__column.col__right, +.tiny-grid .tiny-grid-header__column.col__right { + text-align: right; +} +.tiny-grid .tiny-grid-body__column.col__ellipsis:not(.col__actived) .tiny-grid-cell, +.tiny-grid .tiny-grid-footer__column.col__ellipsis:not(.col__actived) .tiny-grid-cell, +.tiny-grid .tiny-grid-header__column.col__ellipsis:not(.col__actived) .tiny-grid-cell { + overflow: hidden; + text-overflow: ellipsis; + white-space: nowrap; + padding-left: 8px; + -webkit-box-sizing: border-box; + box-sizing: border-box; +} +.tiny-grid .tiny-grid-body__column.col__ellipsis:not(.col__actived) .tiny-grid-cell > .tiny-grid-checkbox, +.tiny-grid .tiny-grid-footer__column.col__ellipsis:not(.col__actived) .tiny-grid-cell > .tiny-grid-checkbox, +.tiny-grid .tiny-grid-header__column.col__ellipsis:not(.col__actived) .tiny-grid-cell > .tiny-grid-checkbox { + overflow: hidden; + text-overflow: ellipsis; + white-space: nowrap; + padding-left: 8px; + -webkit-box-sizing: border-box; + box-sizing: border-box; + padding-left: 0; +} +.tiny-grid .tiny-grid-header__column { + height: var(--ti-grid-header-column-height); +} +.tiny-grid .tiny-grid-body__column, +.tiny-grid .tiny-grid-footer__column { + height: var(--ti-grid-default-column-height, 42px); + border-bottom: 1px solid var(--ti-grid-border-color); +} +.tiny-grid .tiny-grid-body__row .tiny-grid-body__column.hideTypeClass .tiny-grid-cell, +.tiny-grid .tiny-grid-header__row .tiny-grid-header__column.hideTypeClass .tiny-grid-cell { + padding: 0; +} +.tiny-grid .tiny-grid-cell { + line-height: 120%; + white-space: normal; + -ms-word-break: break-all; + word-break: break-word; +} +.tiny-grid .tiny-grid-cell .tiny-grid-checkbox { + vertical-align: bottom; +} +.tiny-grid .tiny-grid-cell .tiny-grid__data-boole, +.tiny-grid .tiny-grid-cell .tiny-grid__data-rate { + width: 100%; + position: relative; +} +.tiny-grid .tiny-grid-cell .tiny-grid__data-boole .icon-yes { + fill: var(--ti-grid-success-color); +} +.tiny-grid .tiny-grid-cell .tiny-grid__data-boole .icon-close { + fill: var(--ti-grid-error-color); +} +.tiny-grid .tiny-grid-cell .tiny-grid__data-rate .tiny-grid__rate-chart { + opacity: 0.6; + background-color: var(--ti-grid-success-color); + height: 30px; + line-height: 30px; +} +.tiny-grid .tiny-grid-cell .tiny-grid__data-rate .tiny-grid__rate-chart.tiny-grid__chart-completed { + background-color: var(--ti-grid-success-color); +} +.tiny-grid .tiny-grid-cell .tiny-grid__data-rate .tiny-grid__rate-chart.tiny-grid__chart-danger { + background-color: var(--ti-grid-error-color); +} +.tiny-grid .tiny-grid-cell .tiny-grid__data-rate .tiny-grid__rate-chart.tiny-grid__chart-warning { + background-color: var(--ti-grid-warning-color); +} +.tiny-grid .tiny-grid-cell .tiny-grid__data-rate .tiny-grid__rate-chart.tiny-grid__chart-normal { + background-color: var(--ti-grid-primary-color); +} +.tiny-grid .tiny-grid-cell .tiny-grid__data-rate .tiny-grid__rate-text { + position: absolute; + left: 8px; + top: 50%; + -webkit-transform: translateY(-50%); + transform: translateY(-50%); +} +.tiny-grid .tiny-grid-body__x-space { + width: 100%; + height: 1px; + margin-bottom: -1px; +} +.tiny-grid .tiny-grid-body__y-space { + width: 0; + float: left; +} +.tiny-grid .tiny-grid-sort-wrapper { + position: absolute; + right: 4px; + top: 0; + bottom: 0; + margin: auto; + text-align: center; + width: 20px; + height: 28px; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-orient: vertical; + -webkit-box-direction: normal; + -ms-flex-direction: column; + flex-direction: column; + -webkit-box-pack: center; + -ms-flex-pack: center; + justify-content: center; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; +} +@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) { + .tiny-grid .tiny-grid-sort-wrapper { + top: 4px; + margin: 0; + } +} +.tiny-grid .tiny-grid-sort-wrapper .tiny-grid-icon__caret-top:before { + bottom: 0.1em; +} +.tiny-grid .tiny-grid-sort-wrapper .tiny-grid-sort__asc-btn, +.tiny-grid .tiny-grid-sort-wrapper .tiny-grid-sort__desc-btn { + height: 16px; + line-height: 16px; + display: block; + font-size: var(--ti-grid-header-icon-font-size); + fill: var(--ti-grid-column-icon-border-color); + cursor: pointer; +} +.tiny-grid .tiny-grid-sort-wrapper .tiny-grid-sort__asc-btn:hover, +.tiny-grid .tiny-grid-sort-wrapper .tiny-grid-sort__desc-btn:hover { + fill: var(--ti-grid-font-color); +} +.tiny-grid .tiny-grid-sort-wrapper .tiny-grid-sort__asc-btn.sort__active, +.tiny-grid .tiny-grid-sort-wrapper .tiny-grid-sort__desc-btn.sort__active { + fill: var(--ti-grid-primary-color); +} +.tiny-grid .tiny-grid-sort-wrapper .tiny-grid-sort__desc-btn { + margin-top: -2px; +} +.tiny-grid .tiny-grid__resizable-bar { + display: none; + position: absolute; + top: 0; + left: 0; + width: 1px; + height: 100%; + z-index: 4; +} +.tiny-grid .tiny-grid__resizable-bar:before { + content: ''; + display: block; + height: 100%; + background-color: #d9dddf; +} +.tiny-grid .tiny-grid-tree__indent { + display: inline-block; +} +.tiny-grid .tiny-grid-tree-wrapper { + display: inline-block; + vertical-align: bottom; + width: 18px; + cursor: pointer; +} +.tiny-grid .tiny-grid-tree-wrapper.is__active .tiny-grid-tree__node-btn { + -webkit-transform: rotate(180deg); + transform: rotate(180deg); +} +.tiny-grid .tiny-grid-tree-wrapper .tiny-grid-tree__node-btn { + font-size: var(--ti-grid-font-size); + color: #939599; +} +.tiny-grid .tiny-grid-tree-wrapper .tiny-grid-tree__node-btn:hover { + color: var(--ti-grid-font-color); +} +.tiny-grid .tiny-grid__expanded { + display: inline-block; + text-align: center; + cursor: pointer; +} +.tiny-grid .tiny-grid__expanded .tiny-grid__expand-icon { + display: inline-block; + width: 8px; + height: 8px; + border: 1px solid #666; + vertical-align: middle; + border-width: 1px 1px 0 0; + -webkit-transform: rotate(45deg); + transform: rotate(45deg); + background-color: transparent; +} +.tiny-grid .tiny-grid__expanded.expand__active .tiny-grid__expand-icon { + -webkit-transform: rotate(135deg); + transform: rotate(135deg); +} +.tiny-grid .tiny-grid-body__expanded-column { + border-bottom: 1px solid var(--ti-grid-border-color); +} +.tiny-grid .tiny-grid-body__expanded-cell { + padding: 20px; +} +.tiny-grid.tiny-grid-editable .tiny-grid-body__column { + height: 43px; + line-height: inherit; +} +.tiny-grid.tiny-grid-editable.size__medium .tiny-grid-body__column { + height: var(--ti-grid-medium-column-height, 46px); +} +.tiny-grid.tiny-grid-editable.size__small .tiny-grid-body__column { + height: var(--ti-grid-small-column-height, 30px); +} +.tiny-grid.tiny-grid-editable.size__mini .tiny-grid-body__column { + height: var(--ti-grid-mini-column-height, 26px); +} +.tiny-grid .tiny-grid-body__column.col__ellipsis, +.tiny-grid .tiny-grid-footer__column.col__ellipsis, +.tiny-grid .tiny-grid-header__column.col__ellipsis { + line-height: inherit; +} +.tiny-grid .tiny-grid-body__column.col__ellipsis .tiny-grid-cell__ellipsis, +.tiny-grid .tiny-grid-body__column.col__ellipsis .tiny-grid-cell__title, +.tiny-grid .tiny-grid-body__column.col__ellipsis .tiny-grid-cell__tooltip, +.tiny-grid .tiny-grid-footer__column.col__ellipsis .tiny-grid-cell__ellipsis, +.tiny-grid .tiny-grid-footer__column.col__ellipsis .tiny-grid-cell__title, +.tiny-grid .tiny-grid-footer__column.col__ellipsis .tiny-grid-cell__tooltip, +.tiny-grid .tiny-grid-header__column.col__ellipsis .tiny-grid-cell__ellipsis, +.tiny-grid .tiny-grid-header__column.col__ellipsis .tiny-grid-cell__title, +.tiny-grid .tiny-grid-header__column.col__ellipsis .tiny-grid-cell__tooltip { + padding: 0 8px; +} +.tiny-grid.size__medium .tiny-grid-body__column.col__ellipsis, +.tiny-grid.size__medium .tiny-grid-footer__column.col__ellipsis, +.tiny-grid.size__medium .tiny-grid-header__column.col__ellipsis { + height: var(--ti-grid-medium-column-height, 46px); +} +.tiny-grid.size__small .tiny-grid-body__column.col__ellipsis, +.tiny-grid.size__small .tiny-grid-footer__column.col__ellipsis, +.tiny-grid.size__small .tiny-grid-header__column.col__ellipsis { + height: var(--ti-grid-small-column-height, 30px); +} +.tiny-grid.size__mini .tiny-grid-body__column.col__ellipsis, +.tiny-grid.size__mini .tiny-grid-footer__column.col__ellipsis, +.tiny-grid.size__mini .tiny-grid-header__column.col__ellipsis { + height: var(--ti-grid-mini-column-height, 26px); +} +.tiny-grid.is__loading .tiny-grid__empty-block { + visibility: hidden; +} +.tiny-grid .tiny-grid__empty-block { + display: none; + opacity: 0; + height: 100%; + min-height: 60px; + padding: 60px 0; + -webkit-box-pack: center; + -ms-flex-pack: center; + justify-content: center; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + text-align: center; +} +.tiny-grid .tiny-grid__empty-block.is__visible { + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-orient: horizontal; + -webkit-box-direction: normal; + -ms-flex-flow: row wrap; + flex-flow: row wrap; + opacity: 1; +} +.tiny-grid .tiny-grid__empty-block.is__visible.is__center { + opacity: 0; +} +.tiny-grid .empty-center-block { + z-index: 1; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-orient: vertical; + -webkit-box-direction: normal; + -ms-flex-direction: column; + flex-direction: column; + -webkit-box-pack: center; + -ms-flex-pack: center; + justify-content: center; + text-align: center; + position: absolute; + width: 100%; + height: calc(100% - 60px); +} +.tiny-grid .empty-center-block .tiny-grid__empty-text { + width: 100%; +} +.tiny-grid .tiny-grid__empty-img { + width: 100%; + height: 100px; + margin: 0; + background: var(--ti-table-nodata-td-bg-img-url) 50% no-repeat; +} +.tiny-grid .tiny-grid__empty-text { + display: block; + margin-top: 8px; + width: 50%; +} +.tiny-grid .tiny-grid-body__column.col__selected:not(.col__checked) { + -webkit-box-shadow: inset 0 0 0 2px var(--ti-grid-primary-color); + box-shadow: inset 0 0 0 2px var(--ti-grid-primary-color); +} +.tiny-grid .tiny-grid-body__column.col__actived, +.tiny-grid .tiny-grid-body__column.col__dirty, +.tiny-grid .tiny-grid-body__column.col__selected { + position: relative; +} +.tiny-grid .tiny-grid-body__column.col__valid-error .tiny-grid-cell__valid { + width: 320px; + position: absolute; + bottom: calc(100% + 4px); + left: 50%; + -webkit-transform: translateX(-50%); + transform: translateX(-50%); + text-align: center; + pointer-events: none; + z-index: 9; +} +.tiny-grid .tiny-grid-body__column.col__valid-error .tiny-grid-cell__valid .tiny-grid-cell__valid-msg { + display: inline-block; + border-radius: 4px; + padding: 8px 12px; + color: var(--ti-grid-light-color); + background-color: var(--ti-grid-error-color); + pointer-events: auto; +} +.tiny-grid .tiny-grid-body__column.col__valid-error .tiny-grid-default-input, +.tiny-grid .tiny-grid-body__column.col__valid-error .tiny-grid-default-select, +.tiny-grid .tiny-grid-body__column.col__valid-error .tiny-grid-default-textarea { + border-color: var(--ti-grid-error-color); +} +.tiny-grid .tiny-grid-body__column.col__valid-error .tiny-grid-input__wrapper > .tiny-grid-input { + border-color: var(--ti-grid-error-color); +} +.tiny-grid .tiny-grid-body__column.col__valid-error .tiny-input__inner { + border-color: var(--ti-grid-error-color); +} +.tiny-grid .tiny-grid-body__row:first-child .tiny-grid-cell__valid { + bottom: auto; + top: calc(100% + 4px); +} +.tiny-grid .tiny-grid__body-wrapper.body__wrapper.is__scrollload { + overflow-y: hidden; + position: static; +} +.tiny-grid .is__scrollload .tiny-grid-body__y-space { + position: absolute; + right: 0; + width: 12px; + overflow-y: scroll; +} +.tiny-grid.tiny-grid-editable.tiny-grid-cell__highlight .tiny-grid-body__column.col__actived { + -webkit-box-shadow: inset 0 0 0 2px var(--ti-grid-primary-color); + box-shadow: inset 0 0 0 2px var(--ti-grid-primary-color); +} +.tiny-grid.tiny-grid-editable.tiny-grid-cell__highlight .tiny-grid-body__column.col__actived.col__valid-error { + -webkit-box-shadow: inset 0 0 0 2px var(--ti-grid-error-color); + box-shadow: inset 0 0 0 2px var(--ti-grid-error-color); +} +.tiny-grid.tiny-grid-editable.tiny-grid-cell__highlight + .tiny-grid-body__column.col__actived + .tiny-grid-cell + .tiny-grid-default-input, +.tiny-grid.tiny-grid-editable.tiny-grid-cell__highlight + .tiny-grid-body__column.col__actived + .tiny-grid-cell + .tiny-grid-default-textarea { + border: 0; + padding: 0; +} +.tiny-grid.tiny-grid-editable.tiny-grid-cell__highlight + .tiny-grid-body__column.col__actived + .tiny-grid-cell + .tiny-grid-input__wrapper + .tiny-grid-input, +.tiny-grid.tiny-grid-editable.tiny-grid-cell__highlight + .tiny-grid-body__column.col__actived + .tiny-grid-cell + .tiny-grid-input__wrapper + .tiny-grid-textarea { + border: 0; + padding: 0; +} +.tiny-grid.tiny-grid-editable .tiny-grid-body__column { + padding: var(--ti-table-td-padding, 2px 8px); +} +.tiny-grid.tiny-grid-editable .tiny-grid-body__column.col__actived { + padding: var(--ti-table-td-padding, 2px 8px); +} +.tiny-grid.tiny-grid-editable .tiny-grid-body__column.col__ellipsis { + padding: 0; +} +.tiny-grid.tiny-grid-editable .tiny-grid-body__column.col__ellipsis.col__actived { + padding: 0; +} +.tiny-grid.tiny-grid-editable .tiny-grid-body__column.col__dirty:before { + content: ''; + top: -5px; + left: -5px; + position: absolute; + border-width: 5px; + border-style: solid; + border-color: transparent var(--ti-grid-error-color) transparent transparent; + -webkit-transform: rotate(45deg); + transform: rotate(45deg); +} +.tiny-grid.tiny-grid-editable .tiny-grid-body__column.col__dirty.col__valid-success:before { + border-color: transparent var(--ti-grid-success-color) transparent transparent; +} +.tiny-grid.tiny-grid-editable .tiny-grid__body-wrapper .tiny-grid-editor .tiny-select-dropdown { + left: 0 !important; +} +.tiny-grid.tiny-fullscreen-full { + z-index: 1000; + position: fixed; + overflow: auto; + background: var(--ti-grid-light-color); + width: 100%; + height: 100%; + top: 0; + left: 0; + margin: 0; + padding: 8px; +} +.tiny-grid .tiny-grid-default-input, +.tiny-grid .tiny-grid-default-select, +.tiny-grid .tiny-grid-default-textarea, +.tiny-grid__filter-wrapper .tiny-grid-default-input, +.tiny-grid__filter-wrapper .tiny-grid-default-select, +.tiny-grid__filter-wrapper .tiny-grid-default-textarea { + outline: 0; + padding: 0 8px; + height: 30px; + width: 100%; + color: var(--ti-grid-font-color); + border-radius: 2px; + border: 1px solid var(--ti-grid-border-color); +} +.tiny-grid .tiny-grid-default-input:focus, +.tiny-grid .tiny-grid-default-select:focus, +.tiny-grid .tiny-grid-default-textarea:focus, +.tiny-grid__filter-wrapper .tiny-grid-default-input:focus, +.tiny-grid__filter-wrapper .tiny-grid-default-select:focus, +.tiny-grid__filter-wrapper .tiny-grid-default-textarea:focus { + border: 1px solid var(--ti-grid-primary-color); +} +.tiny-grid .tiny-grid-editor, +.tiny-grid__filter-wrapper .tiny-grid-editor { + width: 100%; + height: 30px; + line-height: 30px; + color: var(--ti-grid-font-color); +} +.tiny-grid .tiny-grid-editor .tiny-input, +.tiny-grid__filter-wrapper .tiny-grid-editor .tiny-input { + width: 100%; +} +.tiny-grid .tiny-grid-editor .tiny-select, +.tiny-grid__filter-wrapper .tiny-grid-editor .tiny-select { + z-index: 1; +} +.tiny-grid .tiny-grid-default-textarea, +.tiny-grid__filter-wrapper .tiny-grid-default-textarea { + resize: none; + vertical-align: middle; +} +.tiny-grid .tiny-grid-input__wrapper, +.tiny-grid__filter-wrapper .tiny-grid-input__wrapper { + width: 100%; + display: block; +} +.tiny-grid .tiny-grid-input__wrapper .tiny-grid-input, +.tiny-grid .tiny-grid-input__wrapper .tiny-grid-textarea, +.tiny-grid__filter-wrapper .tiny-grid-input__wrapper .tiny-grid-input, +.tiny-grid__filter-wrapper .tiny-grid-input__wrapper .tiny-grid-textarea { + padding: 0 2px; +} +.tiny-grid .tiny-grid-input__wrapper .tiny-grid-textarea, +.tiny-grid__filter-wrapper .tiny-grid-input__wrapper .tiny-grid-textarea { + resize: none; +} +.tiny-grid__filter-wrapper .tiny-grid-default-input, +.tiny-grid__filter-wrapper .tiny-grid-default-textarea { + padding: 0 10px; +} +.tiny-grid-hidden-column { + display: none; +} +.tiny-grid .tiny-pager, +.tiny-grid + .tiny-pager { + padding-top: 24px; +} +.tiny-grid .tiny-grid__header th.col__gutter { + width: 0; +} +.tiny-grid .tiny-grid__header .tiny-grid-header__column.col__ellipsis.is__sortable .tiny-grid-cell { + padding-right: 28px; +} +.tiny-grid__header-wrapper { + background-color: var(--ti-grid-header-background-color); +} +.tiny-grid__header-wrapper .tiny-grid__repair { + position: absolute; + left: 0; + bottom: 0; + height: 0; + border-bottom: 1px solid var(--ti-grid-border-color); +} +.tiny-grid-header__column { + position: relative; + font-size: var(--ti-grid-font-size); + color: var(--ti-grid-font-color); +} +.tiny-grid-header__column.is__sortable .tiny-grid-cell { + padding-right: 20px; +} +.tiny-grid-header__column.is__editable .tiny-grid-cell { + padding-left: 20px; +} +.tiny-grid-header__column.col__title-checked { + background-color: #dcdcdc; +} +.tiny-grid-header__column.col__title-checked .tiny-grid-edit-icon.tiny-grid-icon__edit-outline:before { + background-color: #dcdcdc; +} +.tiny-grid-header__column.col__ellipsis .tiny-grid-edit-icon { + position: static; + -webkit-transform: translateY(0); + transform: translateY(0); +} +.tiny-grid-header__column.col__ellipsis.is__editable .tiny-grid-required-icon { + margin-left: 20px; +} +.tiny-grid-header__column.col__ellipsis.is__editable .tiny-grid-required-icon + .tiny-grid-edit-icon { + position: absolute; + -webkit-transform: translateY(-50%); + transform: translateY(-50%); +} +.tiny-grid-header__column .tiny-grid-required-icon { + display: inline-block; + color: var(--ti-grid-error-color); + line-height: 14px; + font-size: var(--ti-common-font-size-1); +} +.tiny-grid-header__column .tiny-grid-required-icon:before { + content: '*'; + width: 10px; + height: 10px; + display: block; +} +.tiny-grid-header__column .tiny-grid-edit-icon { + position: absolute; + left: 8px; + top: 50%; + -webkit-transform: translateY(-50%); + transform: translateY(-50%); + text-align: center; + font-size: var(--ti-common-font-size-2); + margin-right: 4px; + fill: var(--ti-grid-column-icon-border-color); +} +@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) { + .tiny-grid-header__column .tiny-grid-edit-icon { + top: 18px; + } +} +.tiny-grid-header__column .tiny-grid-resizable, +.tiny-grid-header__column .tiny-grid-thead-partition { + position: absolute; + right: 0; + -webkit-transform: translateX(50%); + transform: translateX(50%); + bottom: 0; + top: 0; + margin: auto; + width: 14px; + height: 28px; + text-align: center; + z-index: 1; + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; +} +@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) { + .tiny-grid-header__column .tiny-grid-resizable, + .tiny-grid-header__column .tiny-grid-thead-partition { + margin: 0; + } +} +.tiny-grid-header__column .tiny-grid-resizable.is__line:after, +.tiny-grid-header__column .tiny-grid-resizable.is__line:before, +.tiny-grid-header__column .tiny-grid-thead-partition.is__line:after, +.tiny-grid-header__column .tiny-grid-thead-partition.is__line:before { + content: ''; + display: inline-block; + vertical-align: middle; +} +.tiny-grid-header__column .tiny-grid-resizable.is__line:before, +.tiny-grid-header__column .tiny-grid-thead-partition.is__line:before { + width: 1px; + height: 100%; + background-color: #fff; +} +.tiny-grid-header__column .tiny-grid-resizable.is__line:after, +.tiny-grid-header__column .tiny-grid-thead-partition.is__line:after { + width: 0; + height: 100%; +} +.tiny-grid-header__column .tiny-grid-resizable.is__line:hover:before, +.tiny-grid-header__column .tiny-grid-thead-partition.is__line:hover:before { + background-color: var(--ti-grid-icon-fill-active-hover); +} +.tiny-grid-header__column .tiny-grid-resizable { + cursor: col-resize; +} +.tiny-grid-header__column .tiny-grid-checkbox > input:not(:checked) + .tiny-grid-checkbox__icon:hover { + border-color: var(--ti-grid-border-color); +} +.tiny-grid-header__column .tiny-grid-checkbox.is__indeterminate > input + .tiny-grid-checkbox__icon:hover { + border-color: var(--ti-grid-primary-color); +} +.tiny-grid__fixed-left-wrapper .tiny-grid-header__column .tiny-grid-resizable { + right: 1px; +} +.tiny-grid__fixed-right-wrapper .tiny-grid-header__column .tiny-grid-resizable { + right: auto; + left: 0; + -webkit-transform: translateX(-50%); + transform: translateX(-50%); +} +.tiny-grid__header .tiny-grid-cell__header-suffix { + position: relative; + min-height: 16px; +} +.tiny-grid__header .tiny-grid-cell__header-suffix .suffix-icon-1 { + position: absolute; + right: 12px; +} +.tiny-grid__header .tiny-grid-cell__header-suffix .suffix-icon-0 { + position: absolute; + right: 0; +} +.tiny-grid__header + .col__ellipsis.is__editable.is__sortable.is__filter + .tiny-grid-cell__header-suffix.tiny-grid-cell__tooltip { + padding-right: 28px; +} +.tiny-grid__header + .col__ellipsis.is__editable.is__filter:not(.is__sortable) + .tiny-grid-cell__header-suffix.tiny-grid-cell__tooltip, +.tiny-grid__header + .col__ellipsis.is__editable.is__sortable:not(.is__filter) + .tiny-grid-cell__header-suffix.tiny-grid-cell__tooltip { + padding-right: 14px; +} +.tiny-grid__header + .col__ellipsis:not(.is__sortable):not(.is__filter) + .tiny-grid-cell__header-suffix.tiny-grid-cell__tooltip { + padding-right: 8px; +} +.tiny-grid__header + .col__ellipsis.is__sortable.is__filter:not(.is__editable) + .tiny-grid-cell__header-suffix.tiny-grid-cell__tooltip { + padding-right: 26px; +} +.tiny-grid__header + .col__ellipsis.is__filter:not(.is__sortable):not(.is__editable) + .tiny-grid-cell__header-suffix.tiny-grid-cell__tooltip, +.tiny-grid__header + .col__ellipsis.is__sortable:not(.is__filter):not(.is__editable) + .tiny-grid-cell__header-suffix.tiny-grid-cell__tooltip { + padding-right: 12px; +} +.tiny-grid__body-wrapper, +.tiny-grid__fixed-left-body-wrapper, +.tiny-grid__fixed-right-body-wrapper { + overflow-y: auto; + overflow-x: auto; +} +.tiny-grid__borders .tiny-grid-border-bottom, +.tiny-grid__borders .tiny-grid-border-left, +.tiny-grid__borders .tiny-grid-border-right, +.tiny-grid__borders .tiny-grid-border-top { + position: absolute; + background-color: var(--ti-grid-primary-color); +} +.tiny-grid__borders .tiny-grid-checked-borders .tiny-grid-border-bottom, +.tiny-grid__borders .tiny-grid-checked-borders .tiny-grid-border-top { + height: var(--ti-grid-column-checked-border-width); +} +.tiny-grid__borders .tiny-grid-checked-borders .tiny-grid-border-left, +.tiny-grid__borders .tiny-grid-checked-borders .tiny-grid-border-right { + width: var(--ti-grid-column-checked-border-width); +} +.tiny-grid__borders .tiny-grid-copyed-borders .tiny-grid-border-bottom, +.tiny-grid__borders .tiny-grid-copyed-borders .tiny-grid-border-top { + height: calc(var(--ti-grid-column-checked-border-width) + 1px); +} +.tiny-grid__borders .tiny-grid-copyed-borders .tiny-grid-border-left, +.tiny-grid__borders .tiny-grid-copyed-borders .tiny-grid-border-right { + width: calc(var(--ti-grid-column-checked-border-width) + 1px); +} +.tiny-grid__borders .tiny-grid-copyed-borders > span { + background: repeating-linear-gradient( + 135deg, + transparent, + transparent 3px, + var(--ti-grid-primary-color) 3px, + var(--ti-grid-primary-color) 9px + ); + -webkit-animation: shine 1s infinite linear; + animation: shine 1s infinite linear; +} +.tiny-grid-body__row .tiny-grid-body__column.col__checked { + position: relative; + background-color: var(--ti-grid-column-current-background-color); + border-right-color: var(--ti-grid-column-checked-border-color); + border-bottom-color: var(--ti-grid-column-checked-border-color); +} +.tiny-grid-body__row .tiny-grid-body__column.col__selected { + background-color: var(--ti-grid-light-color); +} +.tiny-grid-body__row .tiny-grid-body__column .tiny-numeric { + width: 100%; +} +@-webkit-keyframes shine { + 0% { + background-position: -1px -1px; + } + 100% { + background-position: -12px -12px; + } +} +@keyframes shine { + 0% { + background-position: -1px -1px; + } + 100% { + background-position: -12px -12px; + } +} +.tiny-grid__footer-wrapper { + margin-top: -1px; + background-color: var(--ti-grid-light-color); +} +.tiny-grid__footer-wrapper.body__wrapper { + overflow-x: auto; +} +.tiny-grid-filter-wrapper { + padding: 0 4px; + vertical-align: middle; + display: inline-block; + line-height: 15px; +} +.tiny-grid-filter-wrapper.is__active .tiny-grid-filter__btn { + fill: var(--ti-grid-primary-hover-color); +} +.tiny-grid-filter-wrapper .tiny-grid-filter__btn { + font-size: var(--ti-common-font-size-base); + fill: #999; + cursor: pointer; + vertical-align: middle; +} +.tiny-grid-filter-wrapper .tiny-grid-filter__btn:hover { + fill: var(--ti-grid-primary-hover-color); +} +.filter__active .tiny-grid-filter-wrapper .tiny-grid-filter__btn { + fill: var(--ti-grid-primary-color); +} +.tiny-grid__filter-wrapper { + display: none; + position: absolute; + min-width: 270px; + border-radius: var(--ti-grid-border-radius); + border: 1px solid var(--ti-grid-popup-border-color); + -webkit-box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.2); + box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.2); + font-size: var(--ti-common-font-size-base); + z-index: 4000; +} +.tiny-grid__filter-wrapper.filter__active { + display: block; +} +.tiny-grid__filter-wrapper .tiny-grid__filter-body { + padding: 0; + list-style-type: none; + background-color: var(--ti-grid-light-color); + overflow-x: hidden; + overflow-y: auto; +} +.tiny-grid__filter-wrapper .tiny-grid__filter-body .tiny-grid__filter-panel { + margin: 0; + width: 100%; + padding: 12px 8px 8px; + border-bottom: solid 1px var(--ti-grid-border-color); +} +.tiny-grid__filter-wrapper .tiny-grid__filter-body .tiny-grid__filter-panel.filter-panel__default { + padding: 8px 20px 4px; +} +.tiny-grid__filter-wrapper .tiny-grid__filter-body .tiny-grid__filter-panel.filter-panel__clear, +.tiny-grid__filter-wrapper .tiny-grid__filter-body .tiny-grid__filter-panel.filter-panel__default { + padding-left: 0; + padding-right: 0; +} +.tiny-grid__filter-wrapper + .tiny-grid__filter-body + .tiny-grid__filter-panel.filter-panel__clear + .tiny-grid__filter-option, +.tiny-grid__filter-wrapper + .tiny-grid__filter-body + .tiny-grid__filter-panel.filter-panel__default + .tiny-grid__filter-option { + cursor: pointer; + padding-left: 16px; +} +.tiny-grid__filter-wrapper + .tiny-grid__filter-body + .tiny-grid__filter-panel.filter-panel__clear + .tiny-grid__filter-option:hover, +.tiny-grid__filter-wrapper + .tiny-grid__filter-body + .tiny-grid__filter-panel.filter-panel__default + .tiny-grid__filter-option:hover { + background-color: var(--ti-grid-primary-hover-color); +} +.tiny-grid__filter-wrapper + .tiny-grid__filter-body + .tiny-grid__filter-panel.filter-panel__clear + .tiny-grid__filter-option:hover + a, +.tiny-grid__filter-wrapper + .tiny-grid__filter-body + .tiny-grid__filter-panel.filter-panel__default + .tiny-grid__filter-option:hover + a { + color: var(--ti-grid-light-color); +} +.tiny-grid__filter-wrapper .tiny-grid__filter-body .tiny-grid__filter-panel.filter-panel__enum { + padding-top: 4px; +} +.tiny-grid__filter-wrapper + .tiny-grid__filter-body + .tiny-grid__filter-panel.filter-panel__enum + .tiny-grid__filter-options { + max-height: 170px; + overflow: auto; +} +.tiny-grid__filter-wrapper + .tiny-grid__filter-body + .tiny-grid__filter-panel.filter-panel__enum + .tiny-grid__filter-options + .tiny-grid__filter-empty { + text-align: center; + line-height: 30px; +} +.tiny-grid__filter-wrapper + .tiny-grid__filter-body + .tiny-grid__filter-panel.filter-panel__enum + .tiny-grid__filter-options + .tiny-grid__filter-option { + height: 28px; + line-height: 28px; + padding: 0 8px; + max-width: 240px; + width: auto; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-pack: center; + -ms-flex-pack: center; + justify-content: center; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + cursor: pointer; +} +.tiny-grid__filter-wrapper + .tiny-grid__filter-body + .tiny-grid__filter-panel.filter-panel__enum + .tiny-grid__filter-options + .tiny-grid__filter-option.selected { + background-color: var(--ti-grid-header-background-color); +} +.tiny-grid__filter-wrapper + .tiny-grid__filter-body + .tiny-grid__filter-panel.filter-panel__enum + .tiny-grid__filter-options + .tiny-grid__filter-option + svg { + font-size: var(--ti-common-font-size-2); + fill: var(--ti-grid-normal-color); + margin-right: 8px; + outline: 0; + vertical-align: middle; +} +.tiny-grid__filter-wrapper + .tiny-grid__filter-body + .tiny-grid__filter-panel.filter-panel__enum + .tiny-grid__filter-options + .tiny-grid__filter-option + svg:hover { + fill: var(--ti-grid-primary-hover-color); +} +.tiny-grid__filter-wrapper + .tiny-grid__filter-body + .tiny-grid__filter-panel.filter-panel__enum + .tiny-grid__filter-options + .tiny-grid__filter-option + svg.is-checked { + fill: var(--ti-grid-primary-color); +} +.tiny-grid__filter-wrapper .tiny-grid__filter-body .tiny-grid__filter-panel .tiny-grid__filter-option { + margin: 0; + height: 24px; + line-height: 24px; +} +.tiny-grid__filter-wrapper .tiny-grid__filter-body .tiny-grid__filter-panel .tiny-grid__filter-option a { + color: var(--ti-grid-font-color); + white-space: nowrap; + overflow: hidden; + text-overflow: ellipsis; + width: 100%; +} +.tiny-grid__filter-wrapper + .tiny-grid__filter-body + .tiny-grid__filter-panel + .tiny-grid__filter-option.filter-option__radios { + margin-bottom: 12px; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -ms-flex-pack: distribute; + justify-content: space-around; +} +.tiny-grid__filter-wrapper + .tiny-grid__filter-body + .tiny-grid__filter-panel + .tiny-grid__filter-option.filter-option__radios + label.tiny-grid-radio { + width: auto; + display: inline-block; +} +.tiny-grid__filter-wrapper + .tiny-grid__filter-body + .tiny-grid__filter-panel + .tiny-grid__filter-option.filter-option__radios + label.tiny-grid-radio + .tiny-grid-radio__label { + color: var(--ti-grid-font-color); + text-overflow: ellipsis; + overflow: hidden; + white-space: nowrap; + width: auto; + max-width: 80%; +} +.tiny-grid__filter-wrapper + .tiny-grid__filter-body + .tiny-grid__filter-panel + .tiny-grid__filter-option.filter-option__radios + label.tiny-grid-radio + + .tiny-grid-radio { + margin-left: 0; +} +.tiny-grid__filter-wrapper + .tiny-grid__filter-body + .tiny-grid__filter-panel + .tiny-grid__filter-option.filter-option__radios + label.tiny-grid-radio:nth-child(2) { + text-align: center; +} +.tiny-grid__filter-wrapper + .tiny-grid__filter-body + .tiny-grid__filter-panel + .tiny-grid__filter-option.filter-option__radios + label.tiny-grid-radio:nth-child(3) { + text-align: right; +} +.tiny-grid__filter-wrapper + .tiny-grid__filter-body + .tiny-grid__filter-panel + .tiny-grid__filter-option.filter-option__btns { + margin: 8px 0 16px; + text-align: center; +} +.tiny-grid__filter-wrapper .tiny-grid__filter-body .filter-option__input > input { + width: 100%; + border: solid 1px #bdbdbd; + border-radius: var(--ti-grid-border-radius); + outline: 0; + padding: 0 8px; + -webkit-box-sizing: border-box; + box-sizing: border-box; + line-height: inherit; + height: 30px; +} +.tiny-grid__filter-wrapper .tiny-grid__filter-body .filter-option__input > input:focus { + border: 1px solid var(--ti-grid-primary-color); +} +.tiny-grid__filter-wrapper .tiny-grid__filter-footer { + border-top: 1px solid var(--ti-grid-popup-border-color); + padding: 8px; +} +.tiny-grid__filter-wrapper .tiny-grid__filter-footer button { + background-color: transparent; + padding: 0 3px; + border: 0; + font-size: 13px; + color: var(--ti-grid-font-color); + cursor: pointer; +} +.tiny-grid__filter-wrapper .tiny-grid__filter-footer button:focus { + outline: 0; +} +.tiny-grid__filter-wrapper .tiny-grid__filter-footer button:hover { + color: var(--ti-grid-primary-color); +} +.tiny-grid__filter-wrapper .tiny-grid__filter-footer button.is__disabled { + color: var(--ti-grid-column-icon-border-color); + cursor: not-allowed; +} +.tiny-grid-loading { + display: none; + position: absolute; + width: 100%; + height: 100%; + top: 0; + left: 0; + z-index: 99; + background-color: var(--ti-grid-loading-background-color); +} +.tiny-grid-loading .tiny-grid-loading__wrap { + position: absolute; + top: 50%; + left: 50%; + -webkit-transform: translate(-50%, -50%); + transform: translate(-50%, -50%); +} +.tiny-grid-loading .tiny-grid-loading__wrap.tiny-loading__spinner { + margin-top: 0; +} +.tiny-grid-loading .tiny-grid-loading__round { + width: 46px; + height: 46px; + position: relative; + margin: 0 auto; + background: -webkit-gradient(linear, left bottom, left top, from(transparent), to(transparent)); + background: linear-gradient(to top, transparent, transparent); +} +.tiny-grid-loading .tiny-grid-loading__round span { + display: inline-block; + width: 10px; + height: 10px; + border-radius: 50%; + background: -webkit-gradient(linear, left top, left bottom, from(#000), to(#000)); + background: linear-gradient(#000, #000); + position: absolute; + -webkit-animation: load 1.04s ease infinite; + animation: load 1.04s ease infinite; +} +@-webkit-keyframes load { + 0% { + opacity: 10; + } + 100% { + opacity: 0.1; + } +} +@keyframes load { + 0% { + opacity: 10; + } + 100% { + opacity: 0.1; + } +} +.tiny-grid-loading .tiny-grid-loading__round span:nth-child(1) { + top: 68%; + left: 68%; + animation-delay: 0s; + -webkit-animation-delay: 0s; +} +.tiny-grid-loading .tiny-grid-loading__round span:nth-child(2) { + top: 50%; + right: 0; + -webkit-transform: translateY(-50%); + transform: translateY(-50%); + animation-delay: 0.1s; + -webkit-animation-delay: 0.1s; +} +.tiny-grid-loading .tiny-grid-loading__round span:nth-child(3) { + top: 10%; + left: 68%; + animation-delay: 0.2s; + -webkit-animation-delay: 0.2s; +} +.tiny-grid-loading .tiny-grid-loading__round span:nth-child(5) { + top: 10%; + left: 12%; + animation-delay: 0.4s; + -webkit-animation-delay: 0.4s; +} +.tiny-grid-loading .tiny-grid-loading__round span:nth-child(4) { + top: 0; + left: 50%; + -webkit-transform: translateX(-50%); + transform: translateX(-50%); + animation-delay: 0.3s; + -webkit-animation-delay: 0.3s; +} +.tiny-grid-loading .tiny-grid-loading__round span:nth-child(8) { + bottom: 0; + left: 50%; + -webkit-transform: translateX(-50%); + transform: translateX(-50%); + animation-delay: 0.7s; + -webkit-animation-delay: 0.7s; +} +.tiny-grid-loading .tiny-grid-loading__round span:nth-child(6) { + top: 50%; + left: 0; + -webkit-transform: translateY(-50%); + transform: translateY(-50%); + animation-delay: 0.5s; + -webkit-animation-delay: 0.5s; +} +.tiny-grid-loading .tiny-grid-loading__round span:nth-child(7) { + top: 68%; + left: 12%; + animation-delay: 0.6s; + -webkit-animation-delay: 0.6s; +} +.tiny-grid .tiny-grid-body__row.row__pending { + color: var(--ti-grid-error-color); + text-decoration: line-through; + cursor: no-drop; +} +.tiny-grid .tiny-grid-body__row.row__pending .tiny-grid-body__column { + position: relative; +} +.tiny-grid .tiny-grid-body__row.row__pending .tiny-grid-body__column:after { + content: ''; + position: absolute; + top: 50%; + left: 0; + width: 100%; + height: 0; + border-bottom: 1px solid var(--ti-grid-error-color); + z-index: 1; +} +.tiny-grid.mark-insert .tiny-grid-body__row.row__new { + background-color: #f2f5fc; +} +.tiny-grid-menu__clild-wrapper, +.tiny-grid-menu__wrapper { + display: none; + position: absolute; + top: 0; + left: 0; + z-index: 5000; + font-size: var(--ti-grid-font-size); + background-color: var(--ti-grid-light-color); + border: 1px solid var(--ti-grid-popup-border-color); + -webkit-box-shadow: 2px 2px 4px -2px rgba(0, 0, 0, 0.2); + box-shadow: 2px 2px 4px -2px rgba(0, 0, 0, 0.2); + padding: 0 1px; + color: var(--ti-grid-font-color); + font-family: var(--ti-grid-font-family); + -ms-user-select: none; + -webkit-user-select: none; + -o-user-select: none; + -moz-user-select: none; + user-select: none; +} +.tiny-grid-menu__clild-wrapper.show, +.tiny-grid-menu__wrapper.show { + display: block; +} +.tiny-grid-menu__clild-wrapper .tiny-grid-menu__clild-wrapper, +.tiny-grid-menu__clild-wrapper .tiny-grid-menu__option-wrapper, +.tiny-grid-menu__wrapper .tiny-grid-menu__clild-wrapper, +.tiny-grid-menu__wrapper .tiny-grid-menu__option-wrapper { + margin: 0; + padding: 0; + list-style-type: none; + border-bottom: 1px solid var(--ti-grid-border-color); +} +.tiny-grid-menu__clild-wrapper .tiny-grid-menu__clild-wrapper li, +.tiny-grid-menu__clild-wrapper .tiny-grid-menu__option-wrapper li, +.tiny-grid-menu__wrapper .tiny-grid-menu__clild-wrapper li, +.tiny-grid-menu__wrapper .tiny-grid-menu__option-wrapper li { + position: relative; + margin: 1px 0; + border: 1px solid transparent; +} +.tiny-grid-menu__clild-wrapper .tiny-grid-menu__clild-wrapper li:last-child, +.tiny-grid-menu__clild-wrapper .tiny-grid-menu__option-wrapper li:last-child, +.tiny-grid-menu__wrapper .tiny-grid-menu__clild-wrapper li:last-child, +.tiny-grid-menu__wrapper .tiny-grid-menu__option-wrapper li:last-child { + border: 0; +} +.tiny-grid-menu__clild-wrapper .tiny-grid-menu__clild-wrapper li.link__active, +.tiny-grid-menu__clild-wrapper .tiny-grid-menu__option-wrapper li.link__active, +.tiny-grid-menu__wrapper .tiny-grid-menu__clild-wrapper li.link__active, +.tiny-grid-menu__wrapper .tiny-grid-menu__option-wrapper li.link__active { + color: #2b2b2b; + background-color: #c5c5c5; + border-color: #c5c5c5; +} +.tiny-grid-menu__clild-wrapper .tiny-grid-menu__clild-wrapper li.link__disabled .tiny-grid-menu__link, +.tiny-grid-menu__clild-wrapper .tiny-grid-menu__option-wrapper li.link__disabled .tiny-grid-menu__link, +.tiny-grid-menu__wrapper .tiny-grid-menu__clild-wrapper li.link__disabled .tiny-grid-menu__link, +.tiny-grid-menu__wrapper .tiny-grid-menu__option-wrapper li.link__disabled .tiny-grid-menu__link { + color: var(--ti-grid-font-color); + cursor: initial; +} +.tiny-grid-menu__clild-wrapper .tiny-grid-menu__clild-wrapper li.link__disabled.link__active, +.tiny-grid-menu__clild-wrapper .tiny-grid-menu__option-wrapper li.link__disabled.link__active, +.tiny-grid-menu__wrapper .tiny-grid-menu__clild-wrapper li.link__disabled.link__active, +.tiny-grid-menu__wrapper .tiny-grid-menu__option-wrapper li.link__disabled.link__active { + border-color: #c0c1c2; + background-color: #eee; +} +.tiny-grid-menu__clild-wrapper .tiny-grid-menu__clild-wrapper li.link__disabled.link__active:hover, +.tiny-grid-menu__clild-wrapper .tiny-grid-menu__option-wrapper li.link__disabled.link__active:hover, +.tiny-grid-menu__wrapper .tiny-grid-menu__clild-wrapper li.link__disabled.link__active:hover, +.tiny-grid-menu__wrapper .tiny-grid-menu__option-wrapper li.link__disabled.link__active:hover { + background-color: inherit; +} +.tiny-grid-menu__clild-wrapper .tiny-grid-menu__clild-wrapper .tiny-grid-menu__link, +.tiny-grid-menu__clild-wrapper .tiny-grid-menu__option-wrapper .tiny-grid-menu__link, +.tiny-grid-menu__wrapper .tiny-grid-menu__clild-wrapper .tiny-grid-menu__link, +.tiny-grid-menu__wrapper .tiny-grid-menu__option-wrapper .tiny-grid-menu__link { + display: block; + padding: 0 30px; + min-width: 120px; + max-width: 180px; + line-height: 26px; + color: var(--ti-grid-font-color); +} +.tiny-grid-menu__clild-wrapper .tiny-grid-menu__clild-wrapper .tiny-grid-menu__link .tiny-grid-menu__link-prefix, +.tiny-grid-menu__clild-wrapper .tiny-grid-menu__clild-wrapper .tiny-grid-menu__link .tiny-grid-menu__link-suffix, +.tiny-grid-menu__clild-wrapper .tiny-grid-menu__option-wrapper .tiny-grid-menu__link .tiny-grid-menu__link-prefix, +.tiny-grid-menu__clild-wrapper .tiny-grid-menu__option-wrapper .tiny-grid-menu__link .tiny-grid-menu__link-suffix, +.tiny-grid-menu__wrapper .tiny-grid-menu__clild-wrapper .tiny-grid-menu__link .tiny-grid-menu__link-prefix, +.tiny-grid-menu__wrapper .tiny-grid-menu__clild-wrapper .tiny-grid-menu__link .tiny-grid-menu__link-suffix, +.tiny-grid-menu__wrapper .tiny-grid-menu__option-wrapper .tiny-grid-menu__link .tiny-grid-menu__link-prefix, +.tiny-grid-menu__wrapper .tiny-grid-menu__option-wrapper .tiny-grid-menu__link .tiny-grid-menu__link-suffix { + position: absolute; + top: 5px; + margin-right: 5px; + font-size: var(--ti-common-font-size-2); +} +.tiny-grid-menu__clild-wrapper .tiny-grid-menu__clild-wrapper .tiny-grid-menu__link .tiny-grid-menu__link-prefix, +.tiny-grid-menu__clild-wrapper .tiny-grid-menu__option-wrapper .tiny-grid-menu__link .tiny-grid-menu__link-prefix, +.tiny-grid-menu__wrapper .tiny-grid-menu__clild-wrapper .tiny-grid-menu__link .tiny-grid-menu__link-prefix, +.tiny-grid-menu__wrapper .tiny-grid-menu__option-wrapper .tiny-grid-menu__link .tiny-grid-menu__link-prefix { + left: 5px; +} +.tiny-grid-menu__clild-wrapper .tiny-grid-menu__clild-wrapper .tiny-grid-menu__link .tiny-grid-menu__link-suffix, +.tiny-grid-menu__clild-wrapper .tiny-grid-menu__option-wrapper .tiny-grid-menu__link .tiny-grid-menu__link-suffix, +.tiny-grid-menu__wrapper .tiny-grid-menu__clild-wrapper .tiny-grid-menu__link .tiny-grid-menu__link-suffix, +.tiny-grid-menu__wrapper .tiny-grid-menu__option-wrapper .tiny-grid-menu__link .tiny-grid-menu__link-suffix { + right: 5px; +} +.tiny-grid-menu__clild-wrapper + .tiny-grid-menu__clild-wrapper + .tiny-grid-menu__link + .tiny-grid-menu__link-suffix.suffix__haschild, +.tiny-grid-menu__clild-wrapper + .tiny-grid-menu__option-wrapper + .tiny-grid-menu__link + .tiny-grid-menu__link-suffix.suffix__haschild, +.tiny-grid-menu__wrapper + .tiny-grid-menu__clild-wrapper + .tiny-grid-menu__link + .tiny-grid-menu__link-suffix.suffix__haschild, +.tiny-grid-menu__wrapper + .tiny-grid-menu__option-wrapper + .tiny-grid-menu__link + .tiny-grid-menu__link-suffix.suffix__haschild { + top: 8px; +} +.tiny-grid-menu__clild-wrapper + .tiny-grid-menu__clild-wrapper + .tiny-grid-menu__link + .tiny-grid-menu__link-suffix.suffix__haschild:before, +.tiny-grid-menu__clild-wrapper + .tiny-grid-menu__option-wrapper + .tiny-grid-menu__link + .tiny-grid-menu__link-suffix.suffix__haschild:before, +.tiny-grid-menu__wrapper + .tiny-grid-menu__clild-wrapper + .tiny-grid-menu__link + .tiny-grid-menu__link-suffix.suffix__haschild:before, +.tiny-grid-menu__wrapper + .tiny-grid-menu__option-wrapper + .tiny-grid-menu__link + .tiny-grid-menu__link-suffix.suffix__haschild:before { + position: absolute; + content: ''; + border: 4px solid transparent; + border-left-color: #727272; +} +.tiny-grid-menu__clild-wrapper .tiny-grid-menu__clild-wrapper .tiny-grid-menu__link .tiny-grid-menu__link-content, +.tiny-grid-menu__clild-wrapper .tiny-grid-menu__option-wrapper .tiny-grid-menu__link .tiny-grid-menu__link-content, +.tiny-grid-menu__wrapper .tiny-grid-menu__clild-wrapper .tiny-grid-menu__link .tiny-grid-menu__link-content, +.tiny-grid-menu__wrapper .tiny-grid-menu__option-wrapper .tiny-grid-menu__link .tiny-grid-menu__link-content { + display: block; + overflow: hidden; + text-overflow: ellipsis; + white-space: nowrap; +} +.tiny-grid-menu__clild-wrapper .tiny-grid-menu__clild-wrapper .tiny-grid-menu__clild-wrapper .tiny-grid-menu__link, +.tiny-grid-menu__clild-wrapper .tiny-grid-menu__option-wrapper .tiny-grid-menu__clild-wrapper .tiny-grid-menu__link, +.tiny-grid-menu__wrapper .tiny-grid-menu__clild-wrapper .tiny-grid-menu__clild-wrapper .tiny-grid-menu__link, +.tiny-grid-menu__wrapper .tiny-grid-menu__option-wrapper .tiny-grid-menu__clild-wrapper .tiny-grid-menu__link { + max-width: 180px; + padding: 0 20px 0 30px; +} +.tiny-grid-menu__clild-wrapper { + display: none; + z-index: 5100; + top: 0; + left: 100%; +} +.tiny-grid-custom { + width: 100%; +} +.tiny-grid-custom .tiny-grid-custom__tabs .tiny-grid-custom__tabs-head { + white-space: nowrap; + margin: 0; + overflow: hidden; + height: var(--ti-grid-custom-head-height); + width: 100%; + position: relative; +} +.tiny-grid-custom .tiny-grid-custom__tabs .tiny-grid-custom__tabs-head ul { + height: var(--ti-grid-custom-head-height); + border-bottom: 1px solid var(--ti-grid-border-color); + list-style: none; + -webkit-box-sizing: border-box; + box-sizing: border-box; +} +.tiny-grid-custom .tiny-grid-custom__tabs .tiny-grid-custom__tabs-head ul li { + float: left; + margin-right: -1px; + cursor: pointer; + line-height: 28px; + padding: 0 20px; + color: var(--ti-grid-font-color); + min-width: 90px; + height: var(--ti-grid-custom-head-height); + line-height: var(--ti-grid-custom-head-height); +} +.tiny-grid-custom .tiny-grid-custom__tabs .tiny-grid-custom__tabs-head ul li.tiny-grid-custom__tabs-selected { + color: var(--ti-grid-primary-color); + border-bottom: 3px solid var(--ti-grid-primary-color); + font-weight: 700; +} +.tiny-grid-custom .tiny-grid-custom__tabs .tiny-grid-custom__tabs-body { + overflow-y: auto; + border: 0; + padding: 12px 0; +} +.tiny-grid-custom .tiny-grid-custom__tabs .tiny-grid-custom__tabs-body .tabs-body-item .tiny-grid-custom__alert { + position: relative; + border: 1px solid; + border-radius: var(--ti-grid-border-radius); + height: var(--ti-grid-custom-body-list-height); + line-height: var(--ti-grid-custom-body-list-height); + padding-left: 8px; + overflow: hidden; + background: var(--ti-grid-row-hover-background-color); + border-color: #91d5ff; + color: var(--ti-grid-font-color); + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; +} +.tiny-grid-custom + .tiny-grid-custom__tabs + .tiny-grid-custom__tabs-body + .tabs-body-item + .tiny-grid-custom__alert + .tiny-svg { + font-size: var(--ti-common-font-size-3); + fill: var(--ti-grid-primary-color); +} +.tiny-grid-custom .tiny-grid-custom__tabs .tiny-grid-custom__tabs-body .tabs-body-item .tiny-grid-custom__alert p { + display: inline-block; + line-height: 16px; + padding-left: 8px; +} +.tiny-grid-custom .tiny-grid-custom__tabs .tiny-grid-custom__tabs-body .tabs-body-item .tiny-grid-custom__setting { + border-bottom: 1px solid var(--ti-grid-border-color); + padding: 12px 0 24px; +} +.tiny-grid-custom + .tiny-grid-custom__tabs + .tiny-grid-custom__tabs-body + .tabs-body-item + .tiny-grid-custom__setting + .setting-item { + font-size: var(--ti-grid-font-size); + padding: 10px 8px; + overflow: hidden; + position: relative; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-align: start; + -ms-flex-align: start; + align-items: flex-start; + -webkit-box-pack: justify; + -ms-flex-pack: justify; + justify-content: space-between; +} +.tiny-grid-custom + .tiny-grid-custom__tabs + .tiny-grid-custom__tabs-body + .tabs-body-item + .tiny-grid-custom__setting + .setting-item + .setting-icon { + font-size: 0; +} +.tiny-grid-custom + .tiny-grid-custom__tabs + .tiny-grid-custom__tabs-body + .tabs-body-item + .tiny-grid-custom__setting + .setting-item + .setting-icon + .icon { + display: inline-block; +} +.tiny-grid-custom + .tiny-grid-custom__tabs + .tiny-grid-custom__tabs-body + .tabs-body-item + .tiny-grid-custom__setting + .setting-item + .setting-icon + .icon:not(:last-child) { + margin-right: 12px; +} +.tiny-grid-custom + .tiny-grid-custom__tabs + .tiny-grid-custom__tabs-body + .tabs-body-item + .tiny-grid-custom__setting + .setting-item + .setting-icon + .tiny-svg { + font-size: var(--ti-common-font-size-1); + fill: var(--ti-grid-normal-color); + cursor: pointer; +} +.tiny-grid-custom + .tiny-grid-custom__tabs + .tiny-grid-custom__tabs-body + .tabs-body-item + .tiny-grid-custom__setting + .setting-item + .setting-icon + .tiny-svg:hover { + fill: var(--ti-grid-primary-disabled-color); +} +.tiny-grid-custom + .tiny-grid-custom__tabs + .tiny-grid-custom__tabs-body + .tabs-body-item + .tiny-grid-custom__setting + .setting-item + .setting-icon + .tiny-svg.lock, +.tiny-grid-custom + .tiny-grid-custom__tabs + .tiny-grid-custom__tabs-body + .tabs-body-item + .tiny-grid-custom__setting + .setting-item + .setting-icon + .tiny-svg.open, +.tiny-grid-custom + .tiny-grid-custom__tabs + .tiny-grid-custom__tabs-body + .tabs-body-item + .tiny-grid-custom__setting + .setting-item + .setting-icon + .tiny-svg.sort { + fill: var(--ti-grid-primary-color); +} +.tiny-grid-custom + .tiny-grid-custom__tabs + .tiny-grid-custom__tabs-body + .tabs-body-item + .tiny-grid-custom__setting + .setting-item + .setting-icon + .tiny-svg.lock:hover, +.tiny-grid-custom + .tiny-grid-custom__tabs + .tiny-grid-custom__tabs-body + .tabs-body-item + .tiny-grid-custom__setting + .setting-item + .setting-icon + .tiny-svg.open:hover, +.tiny-grid-custom + .tiny-grid-custom__tabs + .tiny-grid-custom__tabs-body + .tabs-body-item + .tiny-grid-custom__setting + .setting-item + .setting-icon + .tiny-svg.sort:hover { + fill: var(--ti-grid-primary-hover-color); +} +.tiny-grid-custom + .tiny-grid-custom__tabs + .tiny-grid-custom__tabs-body + .tabs-body-item + .tiny-grid-custom__setting + .setting-item + .setting-icon + .tiny-svg.is-visible { + visibility: hidden; + pointer-events: none; +} +.tiny-grid-custom + .tiny-grid-custom__tabs + .tiny-grid-custom__tabs-body + .tabs-body-item + .tiny-grid-custom__setting.other-setting { + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-orient: vertical; + -webkit-box-direction: normal; + -ms-flex-direction: column; + flex-direction: column; +} +.tiny-grid-custom + .tiny-grid-custom__tabs + .tiny-grid-custom__tabs-body + .tabs-body-item + .tiny-grid-custom__setting.other-setting + .setting-item + span.label { + width: 26%; + display: inline-block; + text-align: right; + padding-right: 24px; +} +.tiny-grid-custom + .tiny-grid-custom__tabs + .tiny-grid-custom__tabs-body + .tabs-body-item + .tiny-grid-custom__setting.other-setting + .setting-item + span.selection { + -webkit-box-flex: 1; + -ms-flex: 1; + flex: 1; + display: inline-block; +} +.tiny-grid-custom + .tiny-grid-custom__tabs + .tiny-grid-custom__tabs-body + .tabs-body-item + .tiny-grid-custom__setting.other-setting + .setting-item + span.selection + .tiny-grid-radio { + margin-right: 10px; + margin-left: 0 !important; +} +.tiny-grid-custom + .tiny-grid-custom__tabs + .tiny-grid-custom__tabs-body + .tabs-body-item + .tiny-grid-custom__setting.other-setting + .setting-item + span.selection + .tiny-grid-radio__label { + height: 16px; + line-height: 18px; +} +.tiny-grid-custom .tiny-grid-custom__tabs .tiny-grid__body-wrapper { + max-height: 45vh; + border-bottom: 0; +} +.tiny-grid-custom .tiny-grid-custom__footer { + margin: 12px; + text-align: center; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-pack: center; + -ms-flex-pack: center; + justify-content: center; +} +.tiny-grid-custom-switch { + margin-top: 8px; + padding-bottom: 12px; + border-bottom: 1px solid #d9d9d9; +} +.tiny-grid-custom-switch .tiny-grid-custom-switch__title { + margin-bottom: 12px; + font-weight: 400; +} +.tiny-grid-custom-switch .tiny-grid-custom-switch__title .tiny-svg { + font-size: var(--ti-common-font-size-3); +} +.tiny-grid-custom-switch .tiny-grid-custom-switch__title .tiny-alert__description { + font-size: var(--ti-common-font-size-1); +} +.tiny-grid-custom-switch .tiny-grid-custom-switch__label { + text-align: right; + position: relative; + top: 2px; + padding-right: 3px; +} +.tiny-grid-custom-switch .tiny-grid-custom-switch__content { + position: relative; + top: -4px; +} +.tiny-grid-custom-switch .tiny-grid-custom-switch__icon-btn { + fill: #1890ff; + font-size: var(--ti-common-font-size-1); + cursor: pointer; +} +.tiny-grid-custom-switch .tiny-grid-custom-switch__icon-btn:hover { + fill: #096dd9; +} +.tiny-grid-custom-switch .tiny-grid-custom-switch__icon-btn--disabled, +.tiny-grid-custom-switch .tiny-grid-custom-switch__icon-btn--disabled:hover { + fill: #bfbfbf; + cursor: not-allowed; +} +.tiny-grid-custom-switch .tiny-grid-custom-switch__icon-btn + .tiny-grid-custom-switch__icon-btn { + margin-left: 12px; +} +.tiny-grid-custom-switch .tiny-grid-custom-switch__icon-btn:first-child { + margin-left: 20px; +} +.tiny-grid-custom-switch__dialog-box .tiny-grid-custom-switch__confirm-btns { + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-pack: end; + -ms-flex-pack: end; + justify-content: flex-end; + width: 85%; +} +.tiny-grid-custom-switch__dialog-box .tiny-grid-custom-switch__del-tip { + text-align: center; +} +.tiny-grid-modal__wrapper { + display: none; + position: fixed; + top: 0; + left: 0; + width: 100%; + height: 100%; + font-size: var(--ti-grid-font-size); + color: var(--ti-grid-font-color); + font-family: var(--ti-grid-font-family); + -webkit-transition: top 0.4s; + transition: top 0.4s; +} +.tiny-grid-modal__wrapper.active { + display: block; +} +.tiny-grid-modal__wrapper.is__visible.is__mask:before { + background-color: rgba(0, 0, 0, 0.5); +} +.tiny-grid-modal__wrapper.is__visible.type__message .tiny-grid-modal__box { + -webkit-transform: translateY(0); + transform: translateY(0); +} +.tiny-grid-modal__wrapper.is__visible:not(.type__message) .tiny-grid-modal__box:not(.is__drag) { + top: 15vh; + -webkit-transition: top 0.3s ease-in, opacity 0.4s ease-in; + transition: top 0.3s ease-in, opacity 0.4s ease-in; +} +.tiny-grid-modal__wrapper.is__visible .tiny-grid-modal__box { + opacity: 1; + visibility: visible; +} +.tiny-grid-modal__wrapper:not(.lock__view) { + pointer-events: none; +} +.tiny-grid-modal__wrapper.lock__scroll { + overflow: hidden; +} +.tiny-grid-modal__wrapper:not(.lock__scroll) { + overflow: auto; +} +.tiny-grid-modal__wrapper.is__mask:before, +.tiny-grid-modal__wrapper.lock__view:before { + content: ''; + position: fixed; + top: 0; + left: 0; + width: 100%; + height: 100%; + z-index: -1; + pointer-events: auto; +} +.tiny-grid-modal__wrapper.is__mask:before { + background-color: rgba(0, 0, 0, 0); +} +.tiny-grid-modal__wrapper.is__animat.is__mask:before { + -webkit-transition: background-color 0.2s ease-in-out; + transition: background-color 0.2s ease-in-out; +} +.tiny-grid-modal__wrapper.is__animat.type__message .tiny-grid-modal__box:not(.is__drag) { + -webkit-transition: all 0.2s ease-out; + transition: all 0.2s ease-out; +} +.tiny-grid-modal__wrapper.size__mini, +.tiny-grid-modal__wrapper.size__small { + font-size: var(--ti-grid-font-size); +} +.tiny-grid-modal__wrapper.size__mini .tiny-grid-modal__box, +.tiny-grid-modal__wrapper.size__small .tiny-grid-modal__box { + padding: 6px 0; +} +.tiny-grid-modal__wrapper.size__mini .tiny-grid-modal__body, +.tiny-grid-modal__wrapper.size__small .tiny-grid-modal__body { + padding: 4px 14px 10px 14px; +} +.tiny-grid-modal__wrapper.size__mini .tiny-grid-modal__footer, +.tiny-grid-modal__wrapper.size__small .tiny-grid-modal__footer { + padding: 4px 14px 8px 14px; +} +.tiny-grid-modal__wrapper.size__mini .tiny-grid-modal__header, +.tiny-grid-modal__wrapper.size__small .tiny-grid-modal__header { + font-size: var(--ti-grid-modal-header-font-size); + padding: 6px 30px 8px 14px; +} +.tiny-grid-modal__wrapper.size__mini .tiny-grid-modal__close-btn, +.tiny-grid-modal__wrapper.size__mini .tiny-grid-modal__zoom-btn, +.tiny-grid-modal__wrapper.size__small .tiny-grid-modal__close-btn, +.tiny-grid-modal__wrapper.size__small .tiny-grid-modal__zoom-btn { + font-size: var(--ti-grid-modal-small-btn-font-size); + top: 10px; +} +.tiny-grid-modal__wrapper.type__alert .tiny-grid-modal__body, +.tiny-grid-modal__wrapper.type__confirm .tiny-grid-modal__body, +.tiny-grid-modal__wrapper.type__message .tiny-grid-modal__body { + white-space: normal; + word-wrap: break-word; + word-break: break-all; +} +.tiny-grid-modal__wrapper.type__message { + text-align: center; +} +.tiny-grid-modal__wrapper.type__message .tiny-grid-modal__box { + display: inline-block; + padding: 2px 0; + margin-top: 0; + width: auto; + -webkit-box-shadow: 0 0 8px 0 rgba(0, 0, 0, 0.1); + box-shadow: 0 0 8px 0 rgba(0, 0, 0, 0.1); + -webkit-transform: translateY(-10%); + transform: translateY(-10%); +} +.tiny-grid-modal__wrapper.type__message .tiny-grid-modal__box .tiny-grid-modal__body:after { + content: ''; + display: block; + clear: both; + height: 0; + overflow: hidden; + visibility: hidden; +} +.tiny-grid-modal__wrapper.type__message .tiny-grid-modal__box .tiny-grid-modal__content { + max-width: 800px; + float: left; +} +.tiny-grid-modal__wrapper.type__message .tiny-grid-modal__status-wrapper { + font-size: var(--ti-grid-modal-small-btn-font-size); + padding-right: 10px; +} +.tiny-grid-modal__wrapper.type__alert .tiny-grid-modal__box, +.tiny-grid-modal__wrapper.type__confirm .tiny-grid-modal__box, +.tiny-grid-modal__wrapper.type__modal .tiny-grid-modal__box { + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-orient: vertical; + -webkit-box-direction: normal; + -ms-flex-direction: column; + flex-direction: column; + position: absolute; + left: 50%; + top: 0; + -webkit-box-shadow: var(--ti-grid-modal-box-shadow); + box-shadow: var(--ti-grid-modal-box-shadow); + border: 1px solid var(--ti-grid-modal-border-color); +} +.tiny-grid-modal__wrapper.type__alert .tiny-grid-modal__box .tiny-grid-modal__header, +.tiny-grid-modal__wrapper.type__confirm .tiny-grid-modal__box .tiny-grid-modal__header, +.tiny-grid-modal__wrapper.type__modal .tiny-grid-modal__box .tiny-grid-modal__header { + cursor: move; +} +.tiny-grid-modal__wrapper.type__modal .tiny-grid-modal__body { + overflow: auto; +} +.tiny-grid-modal__wrapper.type__modal .tiny-grid-modal__body .tiny-grid-modal__content { + overflow: auto; +} +.tiny-grid-modal__wrapper.type__alert .tiny-grid-modal__status-wrapper, +.tiny-grid-modal__wrapper.type__confirm .tiny-grid-modal__status-wrapper { + font-size: var(--ti-grid-modal-alert-font-size); + padding: 0 10px 0 2px; +} +.tiny-grid-modal__wrapper.status__info .tiny-grid-modal__status-wrapper { + color: var(--ti-grid-primary-color); +} +.tiny-grid-modal__wrapper.status__question .tiny-grid-modal__status-wrapper, +.tiny-grid-modal__wrapper.status__warning .tiny-grid-modal__status-wrapper { + color: var(--ti-grid-warning-color); +} +.tiny-grid-modal__wrapper.status__success .tiny-grid-modal__status-wrapper { + color: var(--ti-grid-success-color); +} +.tiny-grid-modal__wrapper.status__error .tiny-grid-modal__status-wrapper { + color: var(--ti-grid-error-color); +} +.tiny-grid-modal__wrapper.status__loading .tiny-grid-modal__status-wrapper { + color: var(--ti-grid-modal-loading-color); +} +.tiny-grid-modal__wrapper.is__maximize .tiny-grid-modal__box .tiny-grid-modal__header { + cursor: default; +} +.tiny-grid-modal__wrapper.is__maximize .tiny-grid-modal__resize .sb-resize, +.tiny-grid-modal__wrapper.is__maximize .tiny-grid-modal__resize .selb-resize, +.tiny-grid-modal__wrapper.is__maximize .tiny-grid-modal__resize .sest-resize, +.tiny-grid-modal__wrapper.is__maximize .tiny-grid-modal__resize .st-resize, +.tiny-grid-modal__wrapper.is__maximize .tiny-grid-modal__resize .swlb-resize, +.tiny-grid-modal__wrapper.is__maximize .tiny-grid-modal__resize .swst-resize, +.tiny-grid-modal__wrapper.is__maximize .tiny-grid-modal__resize .wl-resize, +.tiny-grid-modal__wrapper.is__maximize .tiny-grid-modal__resize .wr-resize { + display: none; +} +.tiny-grid-modal__box { + width: 420px; + background-color: var(--ti-grid-modal-box-background-color); + border: 1px solid var(--ti-grid-modal-box-border-color); + font-size: var(--ti-grid-modal-header-font-size); + text-align: left; + pointer-events: auto; + visibility: hidden; + opacity: 0; +} +.tiny-grid-modal__box.is__drag { + cursor: move; +} +.tiny-grid-modal__box.is__drag .tiny-grid-modal__body:after, +.tiny-grid-modal__box.is__drag .tiny-grid-modal__footer:after { + content: ''; + position: absolute; + top: 0; + left: 0; + width: 100%; + height: 100%; +} +.tiny-grid-modal__box.is__drag .tiny-grid-modal__body { + overflow: hidden; +} +.tiny-grid-modal__box.is__drag .tiny-grid-modal__body .tiny-grid-modal__content { + overflow: hidden; +} +.tiny-grid-modal__status-wrapper { + -ms-flex-negative: 0; + flex-shrink: 0; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; +} +.tiny-grid-modal__status-icon { + font-style: normal; +} +.tiny-grid-modal__content { + -webkit-box-flex: 1; + -ms-flex-positive: 1; + flex-grow: 1; +} +.tiny-grid-modal__body, +.tiny-grid-modal__footer, +.tiny-grid-modal__header { + position: relative; +} +.tiny-grid-modal__body { + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-flex: 1; + -ms-flex-positive: 1; + flex-grow: 1; + padding: 24px; +} +.tiny-grid-modal__header { + -ms-flex-negative: 0; + flex-shrink: 0; + font-size: var(--ti-grid-modal-header-font-size); + font-weight: 700; + padding: 9px 40px 10px 24px; + border-bottom: 1px solid var(--ti-grid-border-color); + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; +} +.tiny-grid-modal__close-btn, +.tiny-grid-modal__zoom-btn { + font-size: var(--ti-grid-modal-header-font-size); + position: absolute; + right: 24px; + top: 13px; + z-index: 1; + color: var(--ti-grid-modal-btn-color); + fill: var(--ti-grid-modal-btn-color); + cursor: pointer; +} +.tiny-grid-modal__close-btn:hover, +.tiny-grid-modal__zoom-btn:hover { + color: var(--ti-grid-primary-color); + fill: var(--ti-grid-primary-color); +} +.tiny-grid-modal__zoom-btn { + right: 44px; + border-color: #c0c4cc; +} +.tiny-grid-modal__zoom-btn:hover { + border-color: #606266; +} +.tiny-grid-modal__footer { + -ms-flex-negative: 0; + flex-shrink: 0; + text-align: center; + padding: 0 24px 24px; +} +.tiny-grid-modal__resize .sb-resize, +.tiny-grid-modal__resize .selb-resize, +.tiny-grid-modal__resize .sest-resize, +.tiny-grid-modal__resize .st-resize, +.tiny-grid-modal__resize .swlb-resize, +.tiny-grid-modal__resize .swst-resize, +.tiny-grid-modal__resize .wl-resize, +.tiny-grid-modal__resize .wr-resize { + position: absolute; + z-index: 100; +} +.tiny-grid-modal__resize .wl-resize, +.tiny-grid-modal__resize .wr-resize { + width: 8px; + height: 100%; + top: 0; + cursor: w-resize; +} +.tiny-grid-modal__resize .wl-resize { + left: -3px; +} +.tiny-grid-modal__resize .wr-resize { + right: -3px; +} +.tiny-grid-modal__resize .selb-resize, +.tiny-grid-modal__resize .sest-resize, +.tiny-grid-modal__resize .swlb-resize, +.tiny-grid-modal__resize .swst-resize { + width: 10px; + height: 10px; + z-index: 101; +} +.tiny-grid-modal__resize .sest-resize, +.tiny-grid-modal__resize .swst-resize { + top: -8px; +} +.tiny-grid-modal__resize .selb-resize, +.tiny-grid-modal__resize .swlb-resize { + bottom: -8px; +} +.tiny-grid-modal__resize .sest-resize, +.tiny-grid-modal__resize .swlb-resize { + cursor: sw-resize; +} +.tiny-grid-modal__resize .selb-resize, +.tiny-grid-modal__resize .swst-resize { + cursor: se-resize; +} +.tiny-grid-modal__resize .swlb-resize, +.tiny-grid-modal__resize .swst-resize { + left: -8px; +} +.tiny-grid-modal__resize .selb-resize, +.tiny-grid-modal__resize .sest-resize { + right: -8px; +} +.tiny-grid-modal__resize .sb-resize, +.tiny-grid-modal__resize .st-resize { + width: 100%; + height: 8px; + left: 0; + cursor: s-resize; +} +.tiny-grid-modal__resize .st-resize { + top: -3px; +} +.tiny-grid-modal__resize .sb-resize { + bottom: -3px; +} +.tiny-grid-toolbar { + padding: 12px 0; +} +.tiny-grid-toolbar:after { + content: ''; + display: block; + clear: both; + height: 0; + overflow: hidden; + visibility: hidden; +} +.tiny-grid-toolbar svg { + fill: var(--ti-grid-primary-color); + font-size: var(--ti-common-font-size-1); +} +.tiny-grid-toolbar.is__loading { + position: relative; +} +.tiny-grid-toolbar.is__loading:before { + content: ''; + position: absolute; + top: 0; + left: 0; + width: 100%; + height: 100%; + z-index: 1; + background-color: var(--ti-grid-loading-background-color); +} +.tiny-grid-toolbar.size__mini, +.tiny-grid-toolbar.size__small { + padding: 8px 0; +} +.tiny-grid-toolbar.size__medium .tiny-grid-custom__setting-btn, +.tiny-grid-toolbar.size__medium .tiny-grid-refresh__btn { + font-size: 17px; +} +.tiny-grid-toolbar.size__small .tiny-grid-custom__setting-btn, +.tiny-grid-toolbar.size__small .tiny-grid-refresh__btn { + font-size: 15px; +} +.tiny-grid-toolbar.size__mini .tiny-grid-custom__setting-btn, +.tiny-grid-toolbar.size__mini .tiny-grid-refresh__btn { + font-size: var(--ti-common-font-size-1); +} +.tiny-grid-toolbar .tiny-grid-custom__wrapper, +.tiny-grid-toolbar .tiny-grid-fullscreen__wrapper, +.tiny-grid-toolbar .tiny-grid-refresh__wrapper, +.tiny-grid-toolbar .tiny-grid-tools__wrapper { + float: right; + width: 30px; + height: 30px; + line-height: 30px; + border: solid 1px var(--ti-grid-border-color); + border-radius: 3px; + text-align: center; + margin: 0 4px; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + -webkit-box-pack: center; + -ms-flex-pack: center; + justify-content: center; +} +.tiny-grid-toolbar .tiny-grid-custom__wrapper { + position: relative; +} +.tiny-grid-toolbar .tiny-grid-custom__wrapper.is__active .tiny-grid-custom__setting-btn { + border-color: var(--ti-grid-primary-color); +} +.tiny-grid-toolbar .tiny-grid-custom__wrapper.is__active .tiny-grid-custom__option-wrapper { + display: block; +} +.tiny-grid-toolbar .tiny-grid-custom__setting-btn, +.tiny-grid-toolbar .tiny-grid-fullscreen__btn, +.tiny-grid-toolbar .tiny-grid-refresh__btn { + font-size: var(--ti-common-font-size-2); + vertical-align: middle; + cursor: pointer; + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; +} +.tiny-grid-toolbar .tiny-grid-custom__setting-btn:hover, +.tiny-grid-toolbar .tiny-grid-fullscreen__btn:hover, +.tiny-grid-toolbar .tiny-grid-refresh__btn:hover { + border-color: var(--ti-grid-primary-color); +} +.tiny-grid-toolbar .tiny-grid-custom__setting-btn > i, +.tiny-grid-toolbar .tiny-grid-fullscreen__btn > i, +.tiny-grid-toolbar .tiny-grid-refresh__btn > i { + display: block; + color: var(--ti-grid-primary-color); + line-height: 28px; +} +.tiny-grid-toolbar .tiny-grid-custom__option-wrapper { + display: none; + position: absolute; + right: 0; + text-align: left; + background-color: var(--ti-grid-light-color); + z-index: 19; + max-height: 210px; + overflow: auto; + -webkit-box-shadow: 0 2px 2px 0 rgba(0, 0, 0, 0.2); + box-shadow: 0 2px 2px 0 rgba(0, 0, 0, 0.2); +} +.tiny-grid-toolbar .tiny-grid-custom__option-wrapper .tiny-grid-custom__option { + padding: 5px 5px; + border: 1px solid var(--ti-grid-border-color); + border-radius: 2px; + font-weight: 700; + font-size: var(--ti-common-font-size-1); +} +.tiny-grid-toolbar .tiny-grid-custom__option-wrapper .tiny-grid-custom__option > .tiny-grid-checkbox { + display: block; + padding: 5px; + margin: 0; + max-width: 180px; + overflow: hidden; + text-overflow: ellipsis; + white-space: nowrap; +} +.tiny-grid__select-toolbar { + position: absolute; + background-color: var(--ti-base-color-light); +} +.tiny-grid__select-toolbar .tiny-grid-toolbar { + padding: 2px 0 2px 6px; +} +.tiny-grid-checkbox { + display: inline-block; + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; + cursor: pointer; +} +.tiny-grid-checkbox.size__mini, +.tiny-grid-checkbox.size__small { + font-size: var(--ti-grid-font-size); +} +.tiny-grid-checkbox.size__mini > input + .tiny-grid-checkbox__icon, +.tiny-grid-checkbox.size__small > input + .tiny-grid-checkbox__icon { + font-size: var(--ti-common-font-size-1); +} +.tiny-grid-checkbox + .tiny-grid-checkbox { + margin-left: 10px; +} +.tiny-grid-checkbox > input { + display: none; +} +.tiny-grid-checkbox > input + .tiny-grid-checkbox__icon { + position: relative; + display: inline-block; + width: 1em; + height: 1em; + border: 1px solid var(--ti-grid-border-color); + background-color: #fff; + vertical-align: middle; + border-radius: var(--ti-grid-border-radius); + font-size: var(--ti-common-font-size-2); +} +.tiny-grid-checkbox > input + .tiny-grid-checkbox__icon:before { + content: ''; + position: absolute; +} +.tiny-grid-checkbox > input + .tiny-grid-checkbox__icon:hover { + border-color: var(--ti-grid-primary-hover-color); +} +.tiny-grid-checkbox > input + .tiny-grid-checkbox__icon + .tiny-grid-checkbox__label { + display: none; +} +.tiny-grid-checkbox > input + .tiny-grid-checkbox__icon > svg.icon-checked-sur { + display: none; +} +.tiny-grid-checkbox > input:checked + .tiny-grid-checkbox__icon { + border: none; +} +.tiny-grid-checkbox > input:checked + .tiny-grid-checkbox__icon + .tiny-grid-checkbox__label { + color: var(--ti-grid-primary-color); +} +.tiny-grid-checkbox > input:checked + .tiny-grid-checkbox__icon > svg { + display: block; + fill: var(--ti-grid-primary-color); +} +.tiny-grid-checkbox.is__indeterminate > input:not(:checked) + .tiny-grid-checkbox__icon { + border: none; +} +.tiny-grid-checkbox.is__indeterminate > input:not(:checked) + .tiny-grid-checkbox__icon > svg { + fill: var(--ti-grid-primary-color); +} +.tiny-grid-checkbox.is__disabled { + cursor: not-allowed; +} +.tiny-grid-checkbox.is__disabled > input + .tiny-grid-checkbox__icon { + border-color: var(--ti-grid-border-color); + background-color: var(--ti-grid-input-disabled-color); +} +.tiny-grid-checkbox.is__disabled > input + .tiny-grid-checkbox__icon:before { + border-color: var(--ti-grid-input-disabled-color); +} +.tiny-grid-checkbox.is__disabled > input + .tiny-grid-checkbox__icon + .tiny-grid-checkbox__label { + color: var(--ti-grid-border-color); +} +.tiny-grid-checkbox.is__disabled > input:checked + .tiny-grid-checkbox__icon { + border-color: var(--ti-grid-disabled-color); + background-color: var(--ti-grid-disabled-color); +} +.tiny-grid-checkbox .tiny-grid-checkbox__label { + padding-left: 5px; + vertical-align: middle; + display: inline-block; +} +.tiny-grid-radio { + display: inline-block; + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; + cursor: pointer; +} +.tiny-grid-radio.size__mini, +.tiny-grid-radio.size__small { + font-size: var(--ti-grid-font-size); +} +.tiny-grid-radio.size__mini > input + .tiny-grid-radio__icon, +.tiny-grid-radio.size__small > input + .tiny-grid-radio__icon { + font-size: var(--ti-common-font-size-1); +} +.tiny-grid-radio.is__disabled { + cursor: not-allowed; +} +.tiny-grid-radio.is__disabled > input + .tiny-grid-radio__icon { + border-color: var(--ti-grid-border-color); + background-color: var(--ti-grid-input-disabled-color); +} +.tiny-grid-radio.is__disabled > input + .tiny-grid-radio__icon:before { + border-color: var(--ti-grid-input-disabled-color); + background-color: var(--ti-grid-input-disabled-color); +} +.tiny-grid-radio.is__disabled > input + .tiny-grid-radio__icon + .tiny-grid-radio__label { + color: var(--ti-grid-border-color); +} +.tiny-grid-radio.is__disabled > input + .tiny-grid-radio__icon:hover { + border-color: var(--ti-grid-border-color); +} +.tiny-grid-radio.is__disabled > input:checked + .tiny-grid-radio__icon { + border-color: var(--ti-grid-disabled-color); + background-color: var(--ti-grid-disabled-color); +} +.tiny-grid-radio > input { + display: none; +} +.tiny-grid-radio > input + .tiny-grid-radio__icon { + position: relative; + display: inline-block; + width: 1em; + height: 1em; + border: 1px solid var(--ti-grid-border-color); + background-color: #fff; + vertical-align: middle; + border-radius: 50%; + font-size: var(--ti-common-font-size-2); +} +.tiny-grid-radio > input + .tiny-grid-radio__icon:hover { + border-color: var(--ti-grid-primary-hover-color); +} +.tiny-grid-radio > input:checked + .tiny-grid-radio__icon { + background-color: var(--ti-grid-primary-color); + border-color: var(--ti-grid-primary-color); +} +.tiny-grid-radio > input:checked + .tiny-grid-radio__icon:before { + content: ''; + position: absolute; + border-width: 0.15em; + border-style: solid; + border-color: #fff; + background-color: #fff; + border-radius: 50%; + height: 0.4em; + width: 0.4em; + top: 50%; + left: 50%; + -webkit-transform: translate(-50%, -50%); + transform: translate(-50%, -50%); +} +.tiny-grid-radio > input:checked + .tiny-grid-radio__icon + .tiny-grid-radio__label { + color: var(--ti-grid-primary-color); +} +.tiny-grid-radio .tiny-grid-radio__label { + padding-left: 5px; + vertical-align: middle; + display: inline-block; +} +.tiny-grid-radio + .tiny-grid-radio { + margin-left: 10px; +} +.tiny-grid-input__wrapper { + font-size: var(--ti-common-font-size-base); + font-size: var(--ti-grid-font-size, 12px); + display: inline-block; +} +.tiny-grid-input__wrapper.type__textarea { + width: 100%; +} +.tiny-grid-input__wrapper .tiny-grid-input, +.tiny-grid-input__wrapper .tiny-grid-textarea { + border-radius: 4px; + outline: 0; + padding: 4px 8px; + width: 100%; + color: var(--ti-grid-font-color); + border: 1px solid var(--ti-grid-border-color); + background-color: #fff; +} +.tiny-grid-input__wrapper .tiny-grid-input:focus, +.tiny-grid-input__wrapper .tiny-grid-textarea:focus { + border: 1px solid var(--ti-grid-primary-color); +} +.tiny-grid-input__wrapper .tiny-grid-input[disabled], +.tiny-grid-input__wrapper .tiny-grid-textarea[disabled] { + cursor: not-allowed; + background-color: var(--ti-grid-input-disabled-color); +} +.tiny-grid-input__wrapper .tiny-grid-input { + height: 32px; +} +.tiny-grid-input__wrapper .tiny-grid-textarea { + height: 100%; +} +.tiny-grid-input__wrapper.size__medium .tiny-grid-input { + height: 36px; +} +.tiny-grid-input__wrapper.size__small .tiny-grid-input { + height: 32px; +} +.tiny-grid-input__wrapper.size__mini .tiny-grid-input { + height: 28px; +} +.tiny-grid-button { + position: relative; + text-align: center; + background-color: var(--ti-grid-light-color); + outline: 0; + font-size: var(--ti-grid-font-size); + white-space: nowrap; + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; + -webkit-appearance: none; + -moz-appearance: none; + appearance: none; +} +.tiny-grid-button.is__disabled { + color: var(--ti-grid-primary-disabled-color); +} +.tiny-grid-button.is__disabled:not(.is__loading) { + cursor: no-drop; +} +.tiny-grid-button:not(.is__disabled) { + color: var(--ti-grid-primary-color); + cursor: pointer; +} +.tiny-grid-button.is__loading:before { + content: ''; + position: absolute; + left: -1px; + top: -1px; + right: -1px; + bottom: -1px; + border-radius: inherit; + background-color: hsla(0, 0%, 100%, 0.35); + pointer-events: none; +} +.tiny-grid-button.type__text { + text-decoration: none; + border: 0; + background-color: transparent; +} +.tiny-grid-button.type__text:not(.is__disabled):hover { + color: var(--ti-grid-primary-hover-color); +} +.tiny-grid-button.type__button { + padding: 0 12px; + line-height: 28px; + border: 1px solid var(--ti-grid-border-color); + border-radius: 2px; +} +.tiny-grid-button.type__button.theme__primary { + color: var(--ti-grid-light-color); + border-color: var(--ti-grid-primary-color); + background-color: var(--ti-grid-primary-color); +} +.tiny-grid-button.type__button.theme__primary:not(.is__disabled):hover { + color: var(--ti-grid-light-color); + background-color: var(--ti-grid-primary-hover-color); + border-color: var(--ti-grid-primary-hover-color); +} +.tiny-grid-button.type__button.theme__primary:not(.is__disabled):active { + color: var(--ti-grid-light-color); + background-color: var(--ti-grid-primary-active-color); + border-color: var(--ti-grid-primary-active-color); +} +.tiny-grid-button.type__button:not(.theme__primary):not(.is__disabled):hover { + color: var(--ti-grid-primary-color); + border-color: var(--ti-grid-primary-color); +} +.tiny-grid-button.type__button:not(.theme__primary):not(.is__disabled):active { + color: var(--ti-grid-primary-active-color); + border-color: var(--ti-grid-primary-active-color); +} +.tiny-grid-button.type__button.size__medium { + padding: 0 14px; + line-height: 28px; +} +.tiny-grid-button.type__button.size__small { + padding: 0 12px; + line-height: 26px; +} +.tiny-grid-button.type__button.size__mini { + padding: 0 10px; + line-height: 24px; +} +.tiny-grid-button.size__mini, +.tiny-grid-button.size__small { + font-size: var(--ti-common-font-size-base); +} +.tiny-grid-button + .tiny-grid-button, +.tiny-grid-button + .tiny-grid-button__dropdown { + margin-left: 8px; +} +.tiny-grid-button + .tiny-grid-button.size__medium, +.tiny-grid-button + .tiny-grid-button__dropdown.size__medium { + margin-left: 8px; +} +.tiny-grid-button + .tiny-grid-button.size__small, +.tiny-grid-button + .tiny-grid-button__dropdown.size__small { + margin-left: 6px; +} +.tiny-grid-button + .tiny-grid-button.size__mini, +.tiny-grid-button + .tiny-grid-button__dropdown.size__mini { + margin-left: 4px; +} +.tiny-grid-button__loading-icon { + margin-right: 5px; +} +.tiny-grid-button__dropdown, +.tiny-grid-button__wrapper { + display: inline-block; +} +.tiny-grid-button__dropdown { + position: relative; +} +.tiny-grid-button__dropdown + .tiny-grid-button, +.tiny-grid-button__dropdown + .tiny-grid-button__dropdown { + margin-left: 8px; +} +.tiny-grid-button__dropdown + .tiny-grid-button.size__medium, +.tiny-grid-button__dropdown + .tiny-grid-button__dropdown.size__medium { + margin-left: 8px; +} +.tiny-grid-button__dropdown + .tiny-grid-button.size__small, +.tiny-grid-button__dropdown + .tiny-grid-button__dropdown.size__small { + margin-left: 6px; +} +.tiny-grid-button__dropdown + .tiny-grid-button.size__mini, +.tiny-grid-button__dropdown + .tiny-grid-button__dropdown.size__mini { + margin-left: 4px; +} +.tiny-grid-button__dropdown.is__active > .tiny-grid-button.theme__primary { + color: var(--ti-grid-light-color); + background-color: var(--ti-grid-primary-hover-color); + border-color: var(--ti-grid-primary-hover-color); +} +.tiny-grid-button__dropdown.is__active > .tiny-grid-button:not(.is__disabled):not(.theme__primary) { + color: var(--ti-grid-primary-color); + border-color: var(--ti-grid-primary-color); +} +.tiny-grid-button__dropdown.is__active .tiny-grid-button__dropdown-wrapper { + display: block; +} +.tiny-grid-button__dropdown.is__active .tiny-grid-button__dropdown-arrow { + -webkit-transform: rotate(315deg); + transform: rotate(315deg); +} +.tiny-grid-button__dropdown.is__active .tiny-grid-button__dropdown-arrow.tiny-grid-icon__arrow-bottom { + margin-top: -2px; +} +.tiny-grid-button__dropdown .tiny-grid-button__dropdown-arrow { + font-size: var(--ti-common-font-size-base); + margin-left: 5px; + -webkit-transition: -webkit-transform 0.2s ease-in-out; + transition: -webkit-transform 0.2s ease-in-out; + transition: transform 0.2s ease-in-out; + transition: transform 0.2s ease-in-out, -webkit-transform 0.2s ease-in-out; +} +.tiny-grid-button__dropdown .tiny-grid-button__dropdown-wrapper { + display: none; + position: absolute; + left: 50%; + -webkit-transform: translateX(-50%); + transform: translateX(-50%); + margin-top: 5px; + z-index: 100; + padding: 5px; + background-color: var(--ti-grid-light-color); + border-radius: 4px; + border: 1px solid var(--ti-grid-border-color); + -webkit-box-shadow: 0 1px 6px rgba(0, 0, 0, 0.2); + box-shadow: 0 1px 6px rgba(0, 0, 0, 0.2); +} +.tiny-grid-button__dropdown .tiny-grid-button__dropdown-wrapper > .tiny-grid-button { + margin: 0; + display: block; + width: 100%; + border: 0; +} +.tiny-grid-button__dropdown .tiny-grid-button__dropdown-wrapper > .tiny-grid-button.type__text { + padding: 2px 8px; +} +.tiny-grid-button__wrapper .tiny-input { + width: 270px; +} +.tiny-grid-button__wrapper .tiny-button, +.tiny-grid-button__wrapper .tiny-input { + vertical-align: middle; +} +.tiny-grid__tooltip-wrapper { + display: none; + position: absolute; + top: -100%; + left: -100%; + font-size: var(--ti-grid-font-size); + max-width: 400px; + border-radius: 4px; + padding: 8px 12px; + white-space: normal; + word-break: break-word; + -webkit-box-shadow: 2px 2px 4px -2px rgba(0, 0, 0, 0.2); + box-shadow: 2px 2px 4px -2px rgba(0, 0, 0, 0.2); + color: var(--ti-grid-font-color); + font-family: var(--ti-grid-font-family); + pointer-events: none; + z-index: 4000; +} +.tiny-grid__tooltip-wrapper.is__visible { + display: block; +} +.tiny-grid__tooltip-wrapper.is__arrow .tiny-grid__tooltip-arrow { + display: block; +} +.tiny-grid__tooltip-wrapper.placement__top .tiny-grid__tooltip-arrow { + bottom: -12px; +} +.tiny-grid__tooltip-wrapper.placement__top .tiny-grid__tooltip-arrow:before { + top: -7px; +} +.tiny-grid__tooltip-wrapper.placement__bottom .tiny-grid__tooltip-arrow { + top: -12px; +} +.tiny-grid__tooltip-wrapper.placement__bottom .tiny-grid__tooltip-arrow:before { + top: -4px; +} +.tiny-grid__tooltip-wrapper.theme__light { + background-color: var(--ti-grid-tooltip-light-background-color); + border: 1px solid var(--ti-grid-border-color); +} +.tiny-grid__tooltip-wrapper.theme__light.placement__top .tiny-grid__tooltip-arrow { + border-top-color: var(--ti-grid-border-color); +} +.tiny-grid__tooltip-wrapper.theme__light.placement__top .tiny-grid__tooltip-arrow:before { + border-top-color: var(--ti-grid-tooltip-light-background-color); +} +.tiny-grid__tooltip-wrapper.theme__light.placement__bottom .tiny-grid__tooltip-arrow { + border-bottom-color: var(--ti-grid-border-color); +} +.tiny-grid__tooltip-wrapper.theme__light.placement__bottom .tiny-grid__tooltip-arrow:before { + border-bottom-color: var(--ti-grid-tooltip-light-background-color); +} +.tiny-grid__tooltip-wrapper.theme__dark { + background: var(--ti-grid-tooltip-dark-background-color); + color: var(--ti-grid-light-color); +} +.tiny-grid__tooltip-wrapper.theme__dark.placement__top .tiny-grid__tooltip-arrow { + border-top-color: var(--ti-grid-tooltip-dark-background-color); +} +.tiny-grid__tooltip-wrapper.theme__dark.placement__top .tiny-grid__tooltip-arrow:before { + border-top-color: var(--ti-grid-tooltip-dark-background-color); +} +.tiny-grid__tooltip-wrapper.theme__dark.placement__bottom .tiny-grid__tooltip-arrow { + border-bottom-color: var(--ti-grid-tooltip-dark-background-color); +} +.tiny-grid__tooltip-wrapper.theme__dark.placement__bottom .tiny-grid__tooltip-arrow:before { + border-bottom-color: var(--ti-grid-tooltip-dark-background-color); +} +.tiny-grid__tooltip-wrapper .tiny-grid__tooltip-arrow { + display: none; + position: absolute; + border-color: transparent; + border-width: 6px; + border-style: solid; + left: 50%; +} +.tiny-grid__tooltip-wrapper .tiny-grid__tooltip-arrow:before { + content: ''; + position: absolute; + border-color: transparent; + border-width: 5px; + border-style: solid; + left: -5px; +} +.tiny-grid__tooltip-wrapper.tiny-grid__valid-error { + background-color: var(--ti-grid-error-color); + color: var(--ti-grid-light-color); +} +.tiny-grid { + --ti-grid-font-family: Helvetica, Arial, 'Microsoft YaHei', sans-serif; + --ti-grid-font-color: var(--ti-base-color-info-normal); + --ti-grid-light-color: var(--ti-base-color-light); + --ti-grid-error-color: var(--ti-base-color-bg-8); + --ti-grid-success-color: var(--ti-base-color-success-normal); + --ti-grid-warning-color: var(--ti-base-color-warning-normal); + --ti-grid-disabled-color: var(--ti-base-color-bg-5); + --ti-grid-normal-color: var(--ti-base-color-placeholder); + --ti-grid-font-size: var(--ti-common-font-size-base); + --ti-grid-border-color: var(--ti-common-color-line-dividing); + --ti-grid-border-radius: var(--ti-common-border-radius-normal); + --ti-grid-header-background-color: var(--ti-common-color-bg-white-emphasize); + --ti-grid-primary-color: var(--ti-base-color-brand-6); + --ti-grid-primary-hover-color: var(--ti-base-color-brand-5); + --ti-grid-primary-active-color: var(--ti-base-color-primary-active); + --ti-grid-primary-disabled-color: #b1b1b1; + --ti-grid-header-column-height: var(--ti-base-size-height-small); + --ti-grid-medium-column-height: 52px; + --ti-grid-default-column-height: 42px; + --ti-grid-small-column-height: 40px; + --ti-grid-mini-column-height: 30px; + --ti-grid-custom-head-height: 40px; + --ti-grid-custom-body-list-height: var(--ti-base-size-height-small); + --ti-icon-fill-active-hover: #fff; + --ti-grid-input-disabled-color: #f5f5f5; + --ti-grid-popup-border-color: #ebeef5; + --ti-grid-row-odd-background-color: #fff; + --ti-grid-row-striped-background-color: #fafafa; + --ti-grid-row-hover-background-color: var(--ti-base-color-hover-background); + --ti-grid-column-hover-background-color: #d7effb; + --ti-grid-column-current-background-color: var(--ti-base-color-hover-background); + --ti-grid-column-icon-border-color: var(--ti-base-color-common-1); + --ti-grid-column-checked-border-width: 2px; + --ti-grid-column-checked-border-color: #d4d4d4; + --ti-grid-loading-background-color: rgba(0, 0, 0, 0.2); + --ti-grid-tooltip-dark-background-color: #303133; + --ti-grid-tooltip-light-background-color: var(--ti-base-color-light); + --ti-grid-modal-loading-color: #78b1eb; + --ti-grid-modal-alert-font-size: 22px; + --ti-grid-modal-header-font-size: var(--ti-common-font-size-1); + --ti-grid-modal-small-btn-font-size: var(--ti-common-font-size-2); + --ti-grid-modal-box-background-color: var(--ti-base-color-light); + --ti-grid-modal-box-border-color: #ebeef5; + --ti-grid-modal-btn-color: #c4c4c4; + --ti-grid-modal-box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.2); + --ti-grid-modal-border-color: rgba(0, 0, 0, 0.2); + --ti-table-td-padding: 2px 8px; + --ti-table-th-spacing-line-color: var(--ti-common-color-text-white); + --ti-grid-header-icon-font-size: var(--ti-common-font-size-2); + --ti-table-nodata-td-bg-img-url: url(''); +} +.tiny-hrapprover { + --ti-hrapprover-error-border-color: var(--ti-base-color-bg-8); + --ti-hrapprover-table-color: var(--ti-base-color-info-normal); + --ti-hrapprover-table-font-size: var(--ti-common-font-size-base); + --ti-hrapprover-tr-bgcolor: #fafafa; + --ti-hrapprover-tr-hover-bgcolor: var(--ti-base-color-hover-background); + --ti-hrapprover-tr-odd-bgcolor: var(--ti-base-color-light); + --ti-hrapprover-th-height: var(--ti-base-size-height-small); + --ti-hrapprover-thead-border-color: var(--ti-base-color-border); + --ti-hrapprover-thead-bgcolor: #f1f1f1; +} +.tiny-hrapprover .tiny-hrapprover__list { + height: 180px; + margin-top: 10px; + overflow: auto; +} +.tiny-hrapprover .tiny-hrapprover__error { + border: solid 1px var(--ti-hrapprover-error-border-color); +} +.tiny-hrapprover table tbody tr { + color: var(--ti-hrapprover-table-color); + background: var(--ti-hrapprover-tr-bgcolor); +} +.tiny-hrapprover table tbody tr:hover { + background: var(--ti-hrapprover-tr-hover-bgcolor); +} +.tiny-hrapprover table tbody tr:nth-child(odd) { + background: var(--ti-hrapprover-tr-odd-bgcolor); +} +.tiny-hrapprover table tr { + display: table-row; + vertical-align: inherit; + border-color: inherit; +} +.tiny-hrapprover table th { + border-left: none; + padding: 2px 0 2px 8px; + height: var(--ti-hrapprover-th-height); +} +.tiny-hrapprover table td { + padding: 2px 0 2px 8px; + height: var(--ti-hrapprover-th-height); + font-size: var(--ti-hrapprover-table-font-size); +} +.tiny-hrapprover table thead { + border-bottom: 1px solid var(--ti-hrapprover-thead-border-color); + text-align: left; + background: var(--ti-hrapprover-thead-bgcolor); + color: var(--ti-hrapprover-table-color); +} +.tiny-hrapprover table thead th { + overflow: hidden; + text-overflow: ellipsis; + white-space: nowrap; + font-size: var(--ti-hrapprover-table-font-size); + color: var(--ti-hrapprover-table-color); +} +.tiny-hrapprover .tiny-input__suffix .tiny-input__icon { + vertical-align: middle; +} +.tiny-image { + --ti-image-error-font-size: var(--ti-common-font-size-1); + --ti-image-error-color: #c0c4cc; + --ti-image-error-background: #f5f7fa; + position: relative; + display: inline-block; + overflow: hidden; +} +.tiny-image__inner { + vertical-align: top; +} +.tiny-image__inner-center { + position: relative; + top: 50%; + left: 50%; + -webkit-transform: translate(-50%, -50%); + transform: translate(-50%, -50%); + display: block; +} +.tiny-image__error { + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-pack: center; + -ms-flex-pack: center; + justify-content: center; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + font-size: var(--ti-image-error-font-size); + color: var(--ti-image-error-color); + vertical-align: middle; +} +.tiny-image__preview { + cursor: pointer; +} +.tiny-image__error, +.tiny-image__placeholder { + background: var(--ti-image-error-background); +} +.tiny-image__error, +.tiny-image__inner, +.tiny-image__placeholder { + width: 100%; + height: 100%; +} +.viewer-fade-enter-active { + -webkit-animation: viewer-fade-in 0.3s; + animation: viewer-fade-in 0.3s; +} +.viewer-fade-leave-active { + -webkit-animation: viewer-fade-out 0.3s; + animation: viewer-fade-out 0.3s; +} +@-webkit-keyframes viewer-fade-in { + 0% { + -webkit-transform: translate3d(0, -20px, 0); + transform: translate3d(0, -20px, 0); + opacity: 0; + } + 100% { + -webkit-transform: translate3d(0, 0, 0); + transform: translate3d(0, 0, 0); + opacity: 1; + } +} +@keyframes viewer-fade-in { + 0% { + -webkit-transform: translate3d(0, -20px, 0); + transform: translate3d(0, -20px, 0); + opacity: 0; + } + 100% { + -webkit-transform: translate3d(0, 0, 0); + transform: translate3d(0, 0, 0); + opacity: 1; + } +} +@-webkit-keyframes viewer-fade-out { + 0% { + -webkit-transform: translate3d(0, 0, 0); + transform: translate3d(0, 0, 0); + opacity: 1; + } + 100% { + -webkit-transform: translate3d(0, -20px, 0); + transform: translate3d(0, -20px, 0); + opacity: 0; + } +} +@keyframes viewer-fade-out { + 0% { + -webkit-transform: translate3d(0, 0, 0); + transform: translate3d(0, 0, 0); + opacity: 1; + } + 100% { + -webkit-transform: translate3d(0, -20px, 0); + transform: translate3d(0, -20px, 0); + opacity: 0; + } +} +.tiny-image { + --ti-image-viewer-color: var(--ti-base-color-light); + --ti-image-viewer-actions-inner-color: var(--ti-base-color-light); + --ti-image-viewer-close-font-size: var(--ti-common-font-size-4); + --ti-image-viewer-close-bgcolor: #606266; + --ti-image-viewer-close-top: 40px; + --ti-image-viewer-close-right: 40px; + --ti-image-viewer-close-width: 40px; + --ti-image-viewer-close-height: 40px; + --ti-image-viewer-close-bgcolor-hover: #606266; + --ti-image-viewer-actions-border-radius: 22px; + --ti-image-viewer-actions-inner-font-size: 23px; + --ti-image-viewer-actions-width: 282px; + --ti-image-viewer-actions-height: 44px; + --ti-image-viewer-actions-bottom: 30px; + --ti-image-viewer-actions-inner-justify-content: space-around; + --ti-image-viewer-next-font-size: var(--ti-common-font-size-5); + --ti-image-viewer-next-width: 44px; + --ti-image-viewer-next-height: 44px; + --ti-image-viewer-mask-background: none; + --ti-image-viewer-btn-opacity: 0.8; + --ti-image-viewer-mask-bgcolor: #000; +} +.tiny-image .tiny-image-viewer__wrapper { + background: var(--ti-image-viewer-mask-background); + position: fixed; + top: 0; + right: 0; + bottom: 0; + left: 0; +} +.tiny-image .tiny-image-viewer__btn { + position: absolute; + z-index: 1; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + -webkit-box-pack: center; + -ms-flex-pack: center; + justify-content: center; + border-radius: 50%; + opacity: var(--ti-image-viewer-btn-opacity); + -webkit-box-sizing: border-box; + box-sizing: border-box; + -ms-user-select: none; + -webkit-user-select: none; + -o-user-select: none; + -moz-user-select: none; + user-select: none; +} +.tiny-image .tiny-image-viewer__btn svg { + fill: var(--ti-image-viewer-color); +} +.tiny-image .tiny-image-viewer__close { + top: var(--ti-image-viewer-close-top); + right: var(--ti-image-viewer-close-right); + width: var(--ti-image-viewer-close-width); + height: var(--ti-image-viewer-close-height); + font-size: var(--ti-image-viewer-close-font-size); + background-color: var(--ti-image-viewer-close-bgcolor); +} +.tiny-image .tiny-image-viewer__close:hover { + cursor: pointer; + background-color: var(--ti-image-viewer-close-bgcolor-hover); +} +.tiny-image .tiny-image-viewer__canvas { + width: 100%; + height: 100%; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-pack: center; + -ms-flex-pack: center; + justify-content: center; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; +} +.tiny-image .tiny-image-viewer__actions { + left: 50%; + bottom: var(--ti-image-viewer-actions-bottom); + -webkit-transform: translateX(-50%); + transform: translateX(-50%); + width: var(--ti-image-viewer-actions-width); + height: var(--ti-image-viewer-actions-height); + padding: 0 23px; + background-color: var(--ti-image-viewer-close-bgcolor); + border-radius: var(--ti-image-viewer-actions-border-radius); +} +.tiny-image .tiny-image-viewer__actions-inner { + width: 100%; + height: 100%; + text-align: justify; + cursor: default; + font-size: var(--ti-image-viewer-actions-inner-font-size); + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + -webkit-box-pack: var(--ti-image-viewer-actions-inner-justify-content); + -ms-flex-pack: var(--ti-image-viewer-actions-inner-justify-content); + justify-content: var(--ti-image-viewer-actions-inner-justify-content); +} +.tiny-image .tiny-image-viewer__actions-inner svg { + fill: var(--ti-image-viewer-actions-inner-color); + margin-right: 20px; +} +.tiny-image .tiny-image-viewer__actions-inner svg:hover { + cursor: pointer; +} +.tiny-image .tiny-image-viewer__next, +.tiny-image .tiny-image-viewer__prev { + top: 50%; + width: var(--ti-image-viewer-next-width); + height: var(--ti-image-viewer-next-height); + font-size: var(--ti-image-viewer-next-font-size); + background-color: var(--ti-image-viewer-close-bgcolor); +} +.tiny-image .tiny-image-viewer__next:hover, +.tiny-image .tiny-image-viewer__prev:hover { + cursor: pointer; + background-color: var(--ti-image-viewer-close-bgcolor-hover); +} +.tiny-image .tiny-image-viewer__prev { + -webkit-transform: translateY(-50%); + transform: translateY(-50%); + left: 40px; +} +.tiny-image .tiny-image-viewer__next { + -webkit-transform: translateY(-50%); + transform: translateY(-50%); + right: 40px; + text-indent: 2px; +} +.tiny-image .tiny-image-viewer__mask { + position: absolute; + width: 100%; + height: 100%; + top: 0; + left: 0; + opacity: 0.5; + background: var(--ti-image-viewer-mask-bgcolor); +} +.tiny-transition-icon-out-in-enter-active { + -webkit-animation: bounce-in 0.3s; + animation: bounce-in 0.3s; +} +.tiny-transition-icon-out-in-leave-active { + animation: bounce-in 0.3s reverse; +} +.tiny-transition-icon-scale-in-enter-active { + -webkit-animation: scale-in 0.3s; + animation: scale-in 0.3s; +} +.tiny-transition-icon-scale-in-leave-active { + animation: scale-in 0.3s reverse; +} +@-webkit-keyframes bounce-in { + 0% { + -webkit-transform: translateY(-50%) scale(0); + transform: translateY(-50%) scale(0); + } + 50% { + -webkit-transform: translateY(-50%) scale(1.2); + transform: translateY(-50%) scale(1.2); + } + 100% { + -webkit-transform: translateY(-50%) scale(1); + transform: translateY(-50%) scale(1); + } +} +@keyframes bounce-in { + 0% { + -webkit-transform: translateY(-50%) scale(0); + transform: translateY(-50%) scale(0); + } + 50% { + -webkit-transform: translateY(-50%) scale(1.2); + transform: translateY(-50%) scale(1.2); + } + 100% { + -webkit-transform: translateY(-50%) scale(1); + transform: translateY(-50%) scale(1); + } +} +@-webkit-keyframes scale-in { + 0% { + -webkit-transform: scale(0); + transform: scale(0); + } + 50% { + -webkit-transform: scale(1.2); + transform: scale(1.2); + } + 100% { + -webkit-transform: scale(1); + transform: scale(1); + } +} +@keyframes scale-in { + 0% { + -webkit-transform: scale(0); + transform: scale(0); + } + 50% { + -webkit-transform: scale(1.2); + transform: scale(1.2); + } + 100% { + -webkit-transform: scale(1); + transform: scale(1); + } +} +.tiny-textarea { + --ti-input-color: var(--ti-base-color-info-normal); + --ti-input-bgcolor: var(--ti-base-color-light); + --ti-input-font-size: var(--ti-common-font-size-base); + --ti-input-height: var(--ti-base-size-height-normal); + --ti-input-border-radius: var(--ti-common-border-radius-normal); + --ti-input-border-color: var(--ti-base-color-border); + --ti-input-hover-border-color: var(--ti-base-color-border-hover); + --ti-input-active-border-color: var(--ti-base-color-brand-5); + --ti-input-placeholder-color: var(--ti-base-color-placeholder); + --ti-input-disabled-color: var(--ti-base-color-placeholder); + --ti-input-medium-height: var(--ti-base-size-height-medium); + --ti-input-small-height: var(--ti-base-size-height-small); + --ti-input-mini-height: var(--ti-base-size-height-mini); + --ti-input-disabled-bgcolor: var(--ti-common-color-bg-disabled); + --ti-input-disabled-border-color: var(--ti-common-color-line-disabled); + --ti-input-exceed-color: var(--ti-base-color-bg-8); + --ti-input-clear-color: #c0c4cc; + --ti-input-icon-font-size: var(--ti-common-font-size-1); + --ti-input-icon-close-color: #bfbfbf; + --ti-input-clear-color-hover: var(--ti-base-color-brand-6); + position: relative; + display: inline-block; + width: 100%; + vertical-align: bottom; + font-size: var(--ti-input-font-size); +} +.tiny-textarea.is-disabled .tiny-textarea__inner { + background-color: var(--ti-input-disabled-bgcolor); + border-color: var(--ti-input-border-color); + color: var(--ti-input-disabled-color); + cursor: not-allowed; +} +.tiny-textarea.is-disabled .tiny-textarea__inner::-moz-placeholder { + color: var(--ti-input-placeholder-color); + opacity: 1; +} +.tiny-textarea.is-disabled .tiny-textarea__inner:-ms-input-placeholder { + color: var(--ti-input-placeholder-color); +} +.tiny-textarea.is-disabled .tiny-textarea__inner::-webkit-input-placeholder { + color: var(--ti-input-placeholder-color); +} +.tiny-textarea.is-disabled .tiny-textarea__inner::-ms-input-placeholder { + color: var(--ti-input-placeholder-color); +} +.tiny-textarea.is-disabled .tiny-textarea__inner::placeholder { + color: var(--ti-input-placeholder-color); +} +.tiny-textarea.is-exceed .tiny-textarea__inner { + border-color: var(--ti-input-exceed-color); +} +.tiny-textarea.is-exceed .tiny-input__count { + color: var(--ti-input-exceed-color); +} +.tiny-textarea .tiny-input__count { + color: #909399; + background: var(--ti-input-bgcolor); + font-size: var(--ti-input-font-size); + position: absolute; + bottom: 5px; + right: 16px; +} +.tiny-textarea__inner { + display: block; + width: 100%; + min-height: 60px; + min-height: calc(var(--ti-input-height, 30px) * 2); + color: var(--ti-input-color); + border: 1px solid var(--ti-input-border-color); + border-radius: var(--ti-input-border-radius); + background: var(--ti-input-bgcolor); + padding: 8px; + line-height: 1.5; + font-size: inherit; + resize: vertical; + -webkit-box-sizing: border-box; + box-sizing: border-box; + -webkit-transition: border-color 0.2s cubic-bezier(0.645, 0.045, 0.355, 1); + transition: border-color 0.2s cubic-bezier(0.645, 0.045, 0.355, 1); +} +.tiny-textarea__inner::-moz-placeholder { + color: var(--ti-input-placeholder-color); + opacity: 1; +} +.tiny-textarea__inner:-ms-input-placeholder { + color: var(--ti-input-placeholder-color); +} +.tiny-textarea__inner::-webkit-input-placeholder { + color: var(--ti-input-placeholder-color); +} +.tiny-textarea__inner::-ms-input-placeholder { + color: var(--ti-input-placeholder-color); +} +.tiny-textarea__inner::placeholder { + color: var(--ti-input-placeholder-color); +} +.tiny-textarea__inner:hover { + border-color: var(--ti-input-hover-border-color); +} +.tiny-textarea__inner:focus { + border-color: var(--ti-input-active-border-color); +} +.tiny-textarea__inner:focus, +.tiny-textarea__inner:hover { + outline: 0; +} +.tiny-input { + --ti-input-color: var(--ti-base-color-info-normal); + --ti-input-bgcolor: var(--ti-base-color-light); + --ti-input-font-size: var(--ti-common-font-size-base); + --ti-input-height: var(--ti-base-size-height-normal); + --ti-input-border-radius: var(--ti-common-border-radius-normal); + --ti-input-border-color: var(--ti-base-color-border); + --ti-input-hover-border-color: var(--ti-base-color-border-hover); + --ti-input-active-border-color: var(--ti-base-color-brand-5); + --ti-input-placeholder-color: var(--ti-base-color-placeholder); + --ti-input-disabled-color: var(--ti-base-color-placeholder); + --ti-input-medium-height: var(--ti-base-size-height-medium); + --ti-input-small-height: var(--ti-base-size-height-small); + --ti-input-mini-height: var(--ti-base-size-height-mini); + --ti-input-disabled-bgcolor: var(--ti-common-color-bg-disabled); + --ti-input-disabled-border-color: var(--ti-common-color-line-disabled); + --ti-input-exceed-color: var(--ti-base-color-bg-8); + --ti-input-clear-color: #c0c4cc; + --ti-input-icon-font-size: var(--ti-common-font-size-1); + --ti-input-icon-close-color: #bfbfbf; + --ti-input-clear-color-hover: var(--ti-base-color-brand-6); + position: relative; + font-size: var(--ti-input-font-size); + display: inline-table; + width: 100%; +} +.tiny-input::-webkit-scrollbar { + z-index: 11; + width: 6px; +} +.tiny-input::-webkit-scrollbar:horizontal { + height: 6px; +} +.tiny-input::-webkit-scrollbar-thumb { + border-radius: 5px; + width: 6px; + background: #b4bccc; +} +.tiny-input::-webkit-scrollbar-corner { + background: #fff; +} +.tiny-input::-webkit-scrollbar-track { + background: #fff; +} +.tiny-input::-webkit-scrollbar-track-piece { + background: #fff; + width: 6px; +} +.tiny-input.is-exceed .tiny-input__suffix .tiny-input__count { + color: var(--ti-input-exceed-color); +} +.tiny-input.is-disabled .tiny-input__inner { + cursor: not-allowed; + border: 1px solid var(--ti-input-disabled-border-color); + color: var(--ti-input-disabled-color); + background: var(--ti-input-disabled-bgcolor); +} +.tiny-input.is-disabled .tiny-input__inner::-moz-placeholder { + color: #999; + opacity: 1; +} +.tiny-input.is-disabled .tiny-input__inner:-ms-input-placeholder { + color: #999; +} +.tiny-input.is-disabled .tiny-input__inner::-webkit-input-placeholder { + color: #999; +} +.tiny-input.is-disabled .tiny-input__inner::-ms-input-placeholder { + color: #999; +} +.tiny-input.is-disabled .tiny-input__inner::placeholder { + color: #999; +} +.tiny-input.is-disabled .tiny-input__icon { + cursor: not-allowed; +} +.tiny-input.is-disabled .tiny-input__icon.tiny-svg, +.tiny-input.is-disabled .tiny-input__icon.tiny-svg:hover { + fill: var(--ti-input-disabled-color); +} +.tiny-input.is-disabled .tiny-input__prefix .tiny-svg, +.tiny-input.is-disabled .tiny-input__prefix .tiny-svg:hover, +.tiny-input.is-disabled .tiny-input__suffix .tiny-svg, +.tiny-input.is-disabled .tiny-input__suffix .tiny-svg:hover { + fill: var(--ti-input-disabled-color); +} +.tiny-input.is-exceed .tiny-input__inner { + border-color: var(--ti-input-exceed-color); +} +.tiny-input .tiny-input__clear { + font-size: var(--ti-input-icon-font-size); + cursor: pointer; + -webkit-transition: color 0.2s cubic-bezier(0.645, 0.045, 0.355, 1); + transition: color 0.2s cubic-bezier(0.645, 0.045, 0.355, 1); +} +.tiny-input .tiny-input__clear, +.tiny-input .tiny-input__clear:hover { + fill: var(--ti-input-icon-close-color); +} +.tiny-input .tiny-input__count { + height: 100%; + display: -webkit-inline-box; + display: -ms-inline-flexbox; + display: inline-flex; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + color: #909399; + font-size: var(--ti-input-font-size); +} +.tiny-input .tiny-input__count .tiny-input__count-inner { + background: var(--ti-input-bgcolor); + line-height: initial; + display: inline-block; +} +.tiny-input__inner { + width: 100%; + border: 1px solid var(--ti-input-border-color); + border-radius: var(--ti-input-border-radius); + color: var(--ti-input-color); + background: var(--ti-input-bgcolor); + font-size: inherit; + height: var(--ti-input-height); + line-height: var(--ti-input-height); + padding: 0 8px; + outline: 0; + display: inline-block; + -webkit-box-sizing: border-box; + box-sizing: border-box; + -webkit-appearance: none; + -moz-appearance: none; + appearance: none; + -webkit-transition: border-color 0.2s cubic-bezier(0.645, 0.045, 0.355, 1); + transition: border-color 0.2s cubic-bezier(0.645, 0.045, 0.355, 1); +} +.tiny-input__inner::-moz-placeholder { + color: var(--ti-input-placeholder-color); + opacity: 1; +} +.tiny-input__inner:-ms-input-placeholder { + color: var(--ti-input-placeholder-color); +} +.tiny-input__inner::-webkit-input-placeholder { + color: var(--ti-input-placeholder-color); +} +.tiny-input__inner::-ms-input-placeholder { + color: var(--ti-input-placeholder-color); +} +.tiny-input__inner::placeholder { + color: var(--ti-input-placeholder-color); +} +.tiny-input__inner:active, +.tiny-input__inner:focus, +.tiny-input__inner:hover { + outline: 0; + border-color: var(--ti-input-hover-border-color); +} +.tiny-input__inner::-ms-clear { + display: none; + width: 0; + height: 0; +} +.tiny-input__prefix, +.tiny-input__suffix { + position: absolute; + top: 50%; + -webkit-transform: translateY(-50%); + transform: translateY(-50%); + -webkit-transition: all 0.3s; + transition: all 0.3s; + text-align: center; + color: var(--ti-input-border-color); + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; +} +.tiny-input.is-active .tiny-input__inner, +.tiny-input__inner:focus { + border-color: var(--ti-input-active-border-color); + outline: 0; +} +.tiny-input__suffix { + right: 8px; + -webkit-transition: all 0.3s; + transition: all 0.3s; + pointer-events: none; +} +.tiny-input__suffix:hover { + cursor: pointer; +} +.tiny-input__suffix-inner { + pointer-events: all; + font-size: var(--ti-common-font-size-1); + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-pack: start; + -ms-flex-pack: start; + justify-content: flex-start; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; +} +.tiny-input__prefix { + left: 8px; + -webkit-transition: all 0.3s; + transition: all 0.3s; + font-size: var(--ti-input-icon-font-size); +} +.tiny-input__prefix > div { + display: -webkit-box; + display: -ms-flexbox; + display: flex; +} +.tiny-input__icon { + height: 100%; + line-height: var(--ti-input-height); + text-align: center; + -webkit-transition: all 0.3s; + transition: all 0.3s; + font-size: var(--ti-input-icon-font-size); + fill: var(--ti-input-hover-border-color); +} +.tiny-input__icon:hover { + fill: var(--ti-input-active-border-color); +} +.tiny-input__icon:after { + content: ''; + height: 100%; + width: 0; + display: inline-block; + vertical-align: middle; +} +.tiny-input__icon .svg-operationfaild, +.tiny-input__icon .svg-operationfaild:hover { + fill: var(--ti-input-icon-close-color); +} +.tiny-input__validateIcon { + pointer-events: none; +} +.tiny-input-suffix .tiny-input__inner { + padding-right: 30px; + padding-left: 8px; +} +.tiny-input-prefix .tiny-input__inner { + padding-left: 30px; + padding-right: 28px; +} +.tiny-input-medium .tiny-input__inner { + height: var(--ti-input-medium-height); + line-height: var(--ti-input-medium-height); +} +.tiny-input-medium .tiny-input__suffix { + line-height: calc(var(--ti-input-medium-height) - 2px); +} +.tiny-input-small .tiny-input__inner { + height: var(--ti-input-small-height); + line-height: var(--ti-input-small-height); +} +.tiny-input-small .tiny-input__suffix { + line-height: calc(var(--ti-input-small-height) - 2px); +} +.tiny-input-mini .tiny-input__inner { + height: var(--ti-input-mini-height); + line-height: var(--ti-input-mini-height); +} +.tiny-input-mini .tiny-input__suffix { + line-height: calc(var(--ti-input-mini-height) - 2px); +} +.tiny-input-group { + --ti-input-color: var(--ti-base-color-info-normal); + --ti-input-bgcolor: var(--ti-base-color-light); + --ti-input-font-size: var(--ti-common-font-size-base); + --ti-input-height: var(--ti-base-size-height-normal); + --ti-input-border-radius: var(--ti-common-border-radius-normal); + --ti-input-border-color: var(--ti-base-color-border); + --ti-input-hover-border-color: var(--ti-base-color-border-hover); + --ti-input-active-border-color: var(--ti-base-color-brand-5); + --ti-input-placeholder-color: var(--ti-base-color-placeholder); + --ti-input-disabled-color: var(--ti-base-color-placeholder); + --ti-input-medium-height: var(--ti-base-size-height-medium); + --ti-input-small-height: var(--ti-base-size-height-small); + --ti-input-mini-height: var(--ti-base-size-height-mini); + --ti-input-disabled-bgcolor: var(--ti-common-color-bg-disabled); + --ti-input-disabled-border-color: var(--ti-common-color-line-disabled); + --ti-input-exceed-color: var(--ti-base-color-bg-8); + --ti-input-clear-color: #c0c4cc; + --ti-input-icon-font-size: var(--ti-common-font-size-1); + --ti-input-icon-close-color: #bfbfbf; + --ti-input-clear-color-hover: var(--ti-base-color-brand-6); + line-height: normal; + display: inline-table; + width: 100%; + border-collapse: separate; + border-spacing: 0; +} +.tiny-input-group > .tiny-input__inner { + vertical-align: middle; + display: table-cell; +} +.tiny-input-group__append, +.tiny-input-group__prepend { + background-color: var(--ti-input-disabled-bgcolor); + color: var(--ti-input-placeholder-color); + border: 1px solid var(--ti-input-border-color); + border-radius: var(--ti-input-border-radius); + padding: 0 20px; + width: 1px; + vertical-align: middle; + display: table-cell; + position: relative; + white-space: nowrap; +} +.tiny-input-group__append:focus, +.tiny-input-group__prepend:focus { + outline: 0; +} +.tiny-input-group__append .tiny-button, +.tiny-input-group__append .tiny-select, +.tiny-input-group__prepend .tiny-button, +.tiny-input-group__prepend .tiny-select { + display: inline-block; + margin: -10px -20px; +} +.tiny-input-group__append .tiny-button, +.tiny-input-group__append .tiny-input, +.tiny-input-group__prepend .tiny-button, +.tiny-input-group__prepend .tiny-input { + font-size: inherit; +} +.tiny-input-group__append button.tiny-button, +.tiny-input-group__append div.tiny-select .tiny-input__inner, +.tiny-input-group__append div.tiny-select:hover .tiny-input__inner, +.tiny-input-group__prepend button.tiny-button, +.tiny-input-group__prepend div.tiny-select .tiny-input__inner, +.tiny-input-group__prepend div.tiny-select:hover .tiny-input__inner { + border-color: transparent; + background-color: transparent; + color: inherit; + border-top: 0; + border-bottom: 0; +} +.tiny-input-group__append .tiny-select .tiny-input.is-focus .tiny-input__inner, +.tiny-input-group__prepend .tiny-select .tiny-input.is-focus .tiny-input__inner { + border-color: transparent; +} +.tiny-input-group-prepend .tiny-input__inner, +.tiny-input-group__append { + border-top-left-radius: 0; + border-bottom-left-radius: 0; +} +.tiny-input-group-append .tiny-input__suffix { + top: calc(50% - 7px); +} +.tiny-input-group-append .tiny-input__inner, +.tiny-input-group__prepend { + border-top-right-radius: 0; + border-bottom-right-radius: 0; +} +.tiny-input-group__prepend { + border-right: 0; +} +.tiny-input-group__append { + border-left: 0; +} +.tiny-icon-loading { + font-size: var(--ti-common-font-size-1); + line-height: 1; + vertical-align: text-top; + -webkit-animation: rotating 2s linear infinite; + animation: rotating 2s linear infinite; +} +@keyframes rotating { + 0% { + -webkit-transform: rotateZ(0); + transform: rotateZ(0); + } + 100% { + -webkit-transform: rotateZ(360deg); + transform: rotateZ(360deg); + } +} +.tiny-ip-address { + --ti-ip-address-normal-height: var(--ti-base-size-height-normal); + --ti-ip-address-normal-color: var(--ti-base-color-info-normal); + --ti-ip-address-icon-color: var(--ti-base-color-info-normal); + --ti-ip-address-normal-disabled-color: var(--ti-base-color-placeholder); + --ti-ip-address-normal-border-color: var(--ti-base-color-border); + --ti-ip-address-normal-background: var(--ti-base-color-light); + --ti-ip-address-radius: var(--ti-common-border-radius-normal); + --ti-ip-address-font-size: var(--ti-common-font-size-base); + --ti-ip-address-border-hover-color: var(--ti-base-color-brand-6); + --ti-ip-address-disabled-background: var(--ti-common-color-bg-disabled); + --ti-ip-address-disabled-border: var(--ti-common-color-line-disabled); + width: 270px; + max-width: 100%; + outline: 0; + display: inline-table; + text-align: left; + -webkit-box-sizing: border-box; + box-sizing: border-box; +} +.tiny-ip-address__input { + position: relative; + padding: 0; + width: 100%; + height: var(--ti-ip-address-normal-height); + border: 1px solid var(--ti-ip-address-normal-border-color); + color: var(--ti-ip-address-normal-color); + border-radius: var(--ti-ip-address-radius); + background: var(--ti-ip-address-normal-background); + font-size: var(--ti-ip-address-font-size); + padding: 0 8px; + display: block; + white-space: nowrap; + background-image: none; + -ms-user-select: auto; + -webkit-user-select: auto; + -o-user-select: auto; + -moz-user-select: auto; + user-select: auto; + -webkit-transition: border 0.3s; + transition: border 0.3s; + outline: 0; + -webkit-box-sizing: border-box; + box-sizing: border-box; +} +.tiny-ip-address__input.readonly, +.tiny-ip-address__input[readonly] { + cursor: not-allowed; + -webkit-box-shadow: none; + box-shadow: none; +} +.tiny-ip-address__input.readonly.active, +.tiny-ip-address__input.readonly:active, +.tiny-ip-address__input.readonly:focus, +.tiny-ip-address__input.readonly:hover, +.tiny-ip-address__input.readonly[active], +.tiny-ip-address__input[readonly].active, +.tiny-ip-address__input[readonly]:active, +.tiny-ip-address__input[readonly]:focus, +.tiny-ip-address__input[readonly]:hover, +.tiny-ip-address__input[readonly][active] { + border-color: var(--ti-ip-address-border-hover-color); +} +.tiny-ip-address__input::-moz-placeholder { + color: var(--ti-ip-address-normal-disabled-color); + opacity: 1; +} +.tiny-ip-address__input:-ms-input-placeholder { + color: var(--ti-ip-address-normal-disabled-color); +} +.tiny-ip-address__input::-webkit-input-placeholder { + color: var(--ti-ip-address-normal-disabled-color); +} +.tiny-ip-address__input::-ms-input-placeholder { + color: var(--ti-ip-address-normal-disabled-color); +} +.tiny-ip-address__input::placeholder { + color: var(--ti-ip-address-normal-disabled-color); +} +.tiny-ip-address__input:hover { + border: 1px solid var(--ti-ip-address-border-hover-color); + color: var(--ti-ip-address-normal-color); +} +.tiny-ip-address__input:hover::-moz-placeholder { + color: var(--ti-ip-address-normal-disabled-color); + opacity: 1; +} +.tiny-ip-address__input:hover:-ms-input-placeholder { + color: var(--ti-ip-address-normal-disabled-color); +} +.tiny-ip-address__input:hover::-webkit-input-placeholder { + color: var(--ti-ip-address-normal-disabled-color); +} +.tiny-ip-address__input:hover::-ms-input-placeholder { + color: var(--ti-ip-address-normal-disabled-color); +} +.tiny-ip-address__input:hover::placeholder { + color: var(--ti-ip-address-normal-disabled-color); +} +.tiny-ip-address__input.active, +.tiny-ip-address__input:active, +.tiny-ip-address__input:focus, +.tiny-ip-address__input[active] { + border: 1px solid var(--ti-ip-address-border-hover-color); + color: var(--ti-ip-address-normal-color); +} +.tiny-ip-address__input:focus::-moz-placeholder { + color: #d9d9d9; + opacity: 1; +} +.tiny-ip-address__input:focus:-ms-input-placeholder { + color: #d9d9d9; +} +.tiny-ip-address__input:focus::-webkit-input-placeholder { + color: #d9d9d9; +} +.tiny-ip-address__input:focus::-ms-input-placeholder { + color: #d9d9d9; +} +.tiny-ip-address__input:focus::placeholder { + color: #d9d9d9; +} +.tiny-ip-address__input.disabled, +.tiny-ip-address__input[disabled] { + cursor: not-allowed; + pointer-events: none; + border: 1px solid var(--ti-ip-address-disabled-border); + color: var(--ti-ip-address-normal-disabled-color); + background: var(--ti-ip-address-disabled-background); + -webkit-box-shadow: none; + box-shadow: none; +} +.tiny-ip-address__input.disabled .tiny-svg, +.tiny-ip-address__input[disabled] .tiny-svg { + fill: var(--ti-ip-address-normal-disabled-color); +} +.tiny-ip-address__input li { + float: left; + overflow: hidden; + width: 25%; + display: -webkit-inline-box; + display: -ms-inline-flexbox; + display: inline-flex; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; +} +.tiny-ip-address__input li > input { + border: none; + text-align: center; + outline: 0; + background: 0 0; + color: var(--ti-ip-address-normal-color); + width: calc(100% - 12px); + float: left; + height: calc(var(--ti-ip-address-normal-height) - 2px); + line-height: calc(var(--ti-ip-address-normal-height) - 2px); + padding: 0; +} +.tiny-ip-address__input li > input.active, +.tiny-ip-address__input li > input:active, +.tiny-ip-address__input li > input:focus, +.tiny-ip-address__input li > input[active] { + color: var(--ti-ip-address-normal-color); +} +.tiny-ip-address__input li > input:hover { + color: var(--ti-ip-address-normal-color); +} +.tiny-ip-address__input li > input.disabled, +.tiny-ip-address__input li > input[disabled] { + color: var(--ti-ip-address-normal-disabled-color); +} +.tiny-ip-address__input li svg { + vertical-align: middle; + fill: var(--ti-ip-address-icon-color); +} +.tiny-ip-address__input li:last-child > svg { + display: none; +} +.tiny-ip-address__input li:last-child > input { + width: 100%; +} +.tiny-ip-address__input li:only-child { + width: 100%; +} +.tiny-ip-address__input li:only-child > input { + width: 100%; + text-align: left; + padding: 0 8px; +} +.tiny-link { + --ti-link-font-size: var(--ti-common-font-size-1); + --ti-link-font-weight: var(--ti-common-font-weight-5); + --ti-link-border-color: var(--ti-base-color-brand-6); + --ti-link-default-color: #606266; + --ti-link-default-border-color: var(--ti-base-color-brand-6); + --ti-link-default-hover-color: var(--ti-base-color-brand-7); + --ti-link-default-disabled-color: #c0c4cc; + --ti-link-primary-color: var(--ti-base-color-brand-6); + --ti-link-primary-border-color: var(--ti-base-color-brand-6); + --ti-link-primary-hover-color: var(--ti-base-color-brand-5); + --ti-link-primary-disabled-color: #a0cfff; + --ti-link-danger-color: var(--ti-base-color-bg-8); + --ti-link-danger-border-color: var(--ti-base-color-bg-8); + --ti-link-danger-hover-color: var(--ti-base-color-bg-7); + --ti-link-danger-disabled-color: var(--ti-base-color-bg-5); + --ti-link-success-color: var(--ti-base-color-success-normal); + --ti-link-success-border-color: var(--ti-base-color-success-normal); + --ti-link-success-hover-color: var(--ti-base-color-success-hover); + --ti-link-success-disabled-color: var(--ti-base-color-bg-5); + --ti-link-warning-color: var(--ti-base-color-warning-normal); + --ti-link-warning-border-color: var(--ti-base-color-warning-normal); + --ti-link-warning-hover-color: var(--ti-base-color-warning-hover); + --ti-link-warning-disabled-color: var(--ti-base-color-bg-5); + --ti-link-info-color: var(--ti-base-color-info-normal); + --ti-link-info-border-color: var(--ti-base-color-info-normal); + --ti-link-info-hover-color: var(--ti-base-color-info-hover); + --ti-link-info-disabled-color: var(--ti-base-color-bg-5); + display: -webkit-inline-box; + display: -ms-inline-flexbox; + display: inline-flex; + -webkit-box-orient: horizontal; + -webkit-box-direction: normal; + -ms-flex-direction: row; + flex-direction: row; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + -webkit-box-pack: center; + -ms-flex-pack: center; + justify-content: center; + vertical-align: middle; + position: relative; + text-decoration: none; + outline: 0; + cursor: pointer; + padding: 0; + font-size: var(--ti-link-font-size); + font-weight: var(--ti-link-font-weight); +} +.tiny-link.is-underline:hover:after { + content: ''; + position: absolute; + left: 0; + right: 0; + height: 0; + bottom: 0; + border-bottom: 1px solid var(--ti-link-border-color); +} +.tiny-link.is-disabled { + cursor: not-allowed; +} +.tiny-link.tiny-link--default { + color: var(--ti-link-default-color); + fill: var(--ti-link-default-color); +} +.tiny-link.tiny-link--default.is-underline:hover:after, +.tiny-link.tiny-link--default:after { + border-color: var(--ti-link-default-border-color); +} +.tiny-link.tiny-link--default:hover { + color: var(--ti-link-default-hover-color); + fill: var(--ti-link-default-hover-color); + text-decoration: none; +} +.tiny-link.tiny-link--default.is-disabled { + color: var(--ti-link-default-disabled-color); + fill: var(--ti-link-default-disabled-color); +} +.tiny-link.tiny-link--primary { + color: var(--ti-link-primary-color); + fill: var(--ti-link-primary-color); +} +.tiny-link.tiny-link--primary.is-underline:hover:after, +.tiny-link.tiny-link--primary:after { + border-color: var(--ti-link-primary-border-color); +} +.tiny-link.tiny-link--primary:hover { + color: var(--ti-link-primary-hover-color); + fill: var(--ti-link-primary-hover-color); + text-decoration: none; +} +.tiny-link.tiny-link--primary.is-disabled { + color: var(--ti-link-primary-disabled-color); + fill: var(--ti-link-primary-disabled-color); +} +.tiny-link.tiny-link--danger { + color: var(--ti-link-danger-color); + fill: var(--ti-link-danger-color); +} +.tiny-link.tiny-link--danger.is-underline:hover:after, +.tiny-link.tiny-link--danger:after { + border-color: var(--ti-link-danger-border-color); +} +.tiny-link.tiny-link--danger:hover { + color: var(--ti-link-danger-hover-color); + fill: var(--ti-link-danger-hover-color); + text-decoration: none; +} +.tiny-link.tiny-link--danger.is-disabled { + color: var(--ti-link-danger-disabled-color); + fill: var(--ti-link-danger-disabled-color); +} +.tiny-link.tiny-link--success { + color: var(--ti-link-success-color); + fill: var(--ti-link-success-color); +} +.tiny-link.tiny-link--success.is-underline:hover:after, +.tiny-link.tiny-link--success:after { + border-color: var(--ti-link-success-border-color); +} +.tiny-link.tiny-link--success:hover { + color: var(--ti-link-success-hover-color); + fill: var(--ti-link-success-hover-color); + text-decoration: none; +} +.tiny-link.tiny-link--success.is-disabled { + color: var(--ti-link-success-disabled-color); + fill: var(--ti-link-success-disabled-color); +} +.tiny-link.tiny-link--warning { + color: var(--ti-link-warning-color); + fill: var(--ti-link-warning-color); +} +.tiny-link.tiny-link--warning.is-underline:hover:after, +.tiny-link.tiny-link--warning:after { + border-color: var(--ti-link-warning-border-color); +} +.tiny-link.tiny-link--warning:hover { + color: var(--ti-link-warning-hover-color); + fill: var(--ti-link-warning-hover-color); + text-decoration: none; +} +.tiny-link.tiny-link--warning.is-disabled { + color: var(--ti-link-warning-disabled-color); + fill: var(--ti-link-warning-disabled-color); +} +.tiny-link.tiny-link--info { + color: var(--ti-link-info-color); + fill: var(--ti-link-info-color); +} +.tiny-link.tiny-link--info.is-underline:hover:after, +.tiny-link.tiny-link--info:after { + border-color: var(--ti-link-info-border-color); +} +.tiny-link.tiny-link--info:hover { + color: var(--ti-link-info-hover-color); + fill: var(--ti-link-info-hover-color); + text-decoration: none; +} +.tiny-link.tiny-link--info.is-disabled { + color: var(--ti-link-info-disabled-color); + fill: var(--ti-link-info-disabled-color); +} +.tiny-link-menu { + --ti-link-menu-nav-item-color: var(--ti-base-color-brand-6); + --ti-link-menu-nav-item-border-color: #c4c4c4; + --ti-link-menu-btn-color: rgba(24, 144, 255, 0.8); + --ti-link-menu-btn-bgcolor: var(--ti-base-color-light); + --ti-link-menu-input-height: var(--ti-base-size-height-normal); + --ti-link-menu-input-font-size: var(--ti-common-font-size-base); + --ti-link-menu-input-color: var(--ti-base-color-info-normal); + --ti-link-menu-input-border-color: var(--ti-base-color-border); + --ti-link-menu-input-border-radius: var(--ti-common-border-radius-normal); + --ti-link-menu-tree-node-color: var(--ti-common-color-text-disabled); +} +.tiny-link-menu__nav .tiny-link-menu__nav-item { + color: var(--ti-link-menu-nav-item-color); + font-size: var(--ti-common-font-size-1); + border-right: 1px solid var(--ti-link-menu-nav-item-border-color); + padding: 0 8px; + line-height: 1; + display: inline-block; + background: 0; + white-space: nowrap; + text-decoration: none; + outline: 0; + text-align: center; + cursor: pointer; +} +.tiny-link-menu__nav .tiny-link-menu__nav-item .tiny-svg { + fill: var(--ti-link-menu-nav-item-color); + margin-right: 4px; +} +.tiny-link-menu__nav .tiny-link-menu__nav-item span { + line-height: 1; + vertical-align: middle; +} +.tiny-link-menu__nav .tiny-link-menu__btn { + color: var(--ti-link-menu-btn-color); + background: var(--ti-link-menu-btn-bgcolor); + padding: 0 8px; + line-height: 1; + outline: 0; + text-align: center; + border: none; + cursor: pointer; +} +.tiny-link-menu__nav .tiny-link-menu__btn .tiny-svg { + fill: var(--ti-link-menu-nav-item-color); + font-size: var(--ti-common-font-size-3); +} +.tiny-link-menu__dialog-btn { + text-align: center; +} +.tiny-link-menu .tiny-input { + width: 270px; + margin-bottom: 5px; +} +.tiny-link-menu .tiny-input .tiny-input__inner { + height: var(--ti-link-menu-input-height); + line-height: var(--ti-link-menu-input-height); + font-size: var(--ti-link-menu-input-font-size); + color: var(--ti-link-menu-input-color); + background: var(--ti-link-menu-btn-bgcolor); + border: 1px solid var(--ti-link-menu-input-border-color); + border-radius: var(--ti-link-menu-input-border-radius); + padding: 0 8px; + display: block; + white-space: nowrap; + -webkit-user-select: auto; + -moz-user-select: auto; + -ms-user-select: auto; + user-select: auto; + -webkit-transition: border 0.3s; + transition: border 0.3s; + outline: 0; + -webkit-box-sizing: border-box; + box-sizing: border-box; +} +.tiny-link-menu .tiny-button:last-child { + color: var(--ti-link-menu-nav-item-color); + background-color: var(--ti-link-menu-btn-bgcolor); + border-color: var(--ti-link-menu-input-border-color); +} +.tiny-link-menu .tiny-tree .tiny-tree-node .tiny-checkbox { + -webkit-transform: translateY(1px); + transform: translateY(1px); +} +.tiny-link-menu .tiny-tree .tiny-tree-node .tree-node-body { + display: block; + text-decoration: none; +} +.tiny-link-menu .tiny-tree .tiny-tree-node .tree-node-body > .tiny-svg { + margin-left: 4px; +} +.tiny-link-menu .tiny-tree .tiny-tree-node .tree-node-name { + color: var(--ti-link-menu-tree-node-color); + font-size: var(--ti-link-menu-input-font-size); + border-radius: var(--ti-link-menu-input-border-radius); + padding-left: 4px; + font-weight: 700; + vertical-align: middle; +} +.tiny-link-menu .tiny-tree .tiny-tree-node.is-focusable .tree-node-name { + color: var(--ti-link-menu-input-color); +} +.tiny-link-menu .tiny-tree.tiny-link-menu__overflow .tree-node { + width: calc(100% - 36px); +} +.tiny-link-menu .tiny-tree.tiny-link-menu__overflow .tree-node-name { + width: 100%; + display: inline-block; + overflow: hidden; + text-overflow: ellipsis; + white-space: nowrap; +} +.tiny-link-menu .tiny-tree.tiny-link-menu__wrap .tiny-tree-node__content { + height: auto; + padding: 2px 0; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-pack: start; + -ms-flex-pack: start; + justify-content: flex-start; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; +} +.tiny-link-menu .tiny-tree.tiny-link-menu__wrap .tiny-tree-node__content .tiny-tree-node__expand-icon { + -webkit-transform: translateY(-3px); + transform: translateY(-3px); +} +.tiny-link-menu .tiny-tree.tiny-link-menu__wrap .tiny-tree-node__content .tiny-tree-node__expand-icon.expanded { + -webkit-transform: translateY(-3px) rotate(90deg); + transform: translateY(-3px) rotate(90deg); +} +.tiny-link-menu .tiny-tree.tiny-link-menu__wrap .tiny-tree-node__content .tree-node { + width: 100%; +} +.tiny-link-menu .tiny-tree.tiny-link-menu__wrap .tree-node-body { + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-pack: start; + -ms-flex-pack: start; + justify-content: flex-start; + -webkit-box-align: start; + -ms-flex-align: start; + align-items: flex-start; + text-decoration: none; +} +.tiny-link-menu .tiny-tree.tiny-link-menu__wrap .tree-node-body .tiny-svg { + -ms-flex-negative: 0; + flex-shrink: 0; + -webkit-transform: translateY(2px); + transform: translateY(2px); +} +.tiny-link-menu .tiny-tree.tiny-link-menu__wrap .tree-node-name { + display: inline-block; + white-space: normal; + line-height: normal; + word-break: break-word; + -webkit-transform: translateY(-2px); + transform: translateY(-2px); +} +.tiny-loading { + --ti-loading-text-color: var(--ti-base-color-brand-6); + --ti-loading-mask-bgcolor: rgba(255, 255, 255, 0.9); + --ti-loading-text-font-size: var(--ti-common-font-size-1); + --ti-loading-spinner-height: 42px; + --ti-loading-spinner-width: 42px; + --ti-loading-fullscreen-height: 50px; + --ti-loading-fullscreen-width: 50px; +} +.tiny-loading__mask { + position: absolute; + z-index: 2000; + background-color: var(--ti-loading-mask-bgcolor); + margin: 0; + top: 0; + right: 0; + bottom: 0; + left: 0; + -webkit-transition: opacity 0.3s; + transition: opacity 0.3s; +} +.tiny-loading__mask.is-fullscreen { + position: fixed; +} +.tiny-loading__mask.is-fullscreen .tiny-loading__spinner { + margin-top: -25px; +} +.tiny-loading__mask.is-fullscreen .tiny-loading__spinner .circular { + height: var(--ti-loading-fullscreen-height); + width: var(--ti-loading-fullscreen-width); +} +.tiny-loading__spinner { + top: 50%; + margin-top: -21px; + width: 100%; + text-align: center; + position: absolute; +} +.tiny-loading__spinner .tiny-loading__text { + color: var(--ti-loading-text-color); + margin: 3px 0; + font-size: var(--ti-loading-text-font-size); +} +.tiny-loading__spinner .circular { + height: var(--ti-loading-spinner-height); + width: var(--ti-loading-spinner-width); + -webkit-animation: loading-rotate 2s linear infinite; + animation: loading-rotate 2s linear infinite; +} +.tiny-loading__spinner .path { + -webkit-animation: loading-dash 1.5s ease-in-out infinite; + animation: loading-dash 1.5s ease-in-out infinite; + stroke-dasharray: 90, 150; + stroke-dashoffset: 0; + stroke-width: 2; + stroke: var(--ti-loading-text-color); + stroke-linecap: round; +} +.tiny-loading__spinner svg { + fill: var(--ti-loading-text-color); +} +.tiny-loading__parent-relative { + position: relative !important; +} +.tiny-loading__parent-hidden { + overflow: hidden !important; +} +.tiny-loading-fade-enter, +.tiny-loading-fade-leave-active { + opacity: 0; +} +@keyframes loading-rotate { + 100% { + -webkit-transform: rotate(360deg); + transform: rotate(360deg); + } +} +@keyframes loading-dash { + 0% { + stroke-dasharray: 1, 200; + stroke-dashoffset: 0; + } + 50% { + stroke-dasharray: 90, 150; + stroke-dashoffset: -40px; + } + 100% { + stroke-dasharray: 90, 150; + stroke-dashoffset: -120px; + } +} +.tiny-icon-loading { + font-size: var(--ti-common-font-size-1); + line-height: 1; + vertical-align: text-top; + -webkit-animation: rotating 2s linear infinite; + animation: rotating 2s linear infinite; +} +@keyframes rotating { + 0% { + -webkit-transform: rotateZ(0); + transform: rotateZ(0); + } + 100% { + -webkit-transform: rotateZ(360deg); + transform: rotateZ(360deg); + } +} +.tiny-logout { + cursor: pointer; + display: inline; +} +.tiny-menu.menu-hor { + --ti-menubar-title-font-size: var(--ti-common-font-size-base-normal); + --ti-menubar-title-color: var(--ti-base-color-light); + --ti-menubar-li-height: var(--ti-common-size-12x); + --ti-menubar-menu-height: var(--ti-base-size-height-large); + --ti-menubar-menu-font-size: var(--ti-common-font-size-1); + --ti-menubar-submenu-normal-color: var(--ti-base-color-info-normal); + --ti-menubar-submenu-hover-color: var(--ti-base-color-hover-background); + --ti-menubar-submenu-active-color: var(--ti-base-color-selected-background); + --ti-menubar-submenu-li-height: var(--ti-common-size-10x); + --ti-menubar-background-normal: var(--ti-base-color-navigation-background); + --ti-menubar-background-active: #474c5e; + --ti-menubar-dropdown-border-color: #c9ccda; + --ti-menubar-dropdown-hover-border-color: #585f7f; + --ti-menubar-dropdown-hover-background: #191b25; + margin-bottom: 0; + min-height: 30px; + min-width: 300px; + font-size: var(--ti-menubar-menu-font-size, 14px); +} +.tiny-menu.menu-hor > ul > li { + display: inline-block; + margin-left: -4px; + position: relative; + text-align: center; + padding: 0; + margin: 0; +} +.tiny-menu.menu-hor > ul > li > a { + display: block; + padding: 0 10px; + min-width: 120px; + margin-right: -1px; + color: var(--ti-menubar-title-color); + font-size: var(--ti-common-font-size-2); +} +.tiny-menu.menu-hor > ul > li > a span.menu-icon { + margin-right: 8px; + top: -2px; +} +.tiny-menu.menu-hor > ul > li .submenu > li > a { + color: var(--ti-menubar-submenu-normal-color); +} +.tiny-menu.menu-hor > ul > li .submenu > li > a:focus, +.tiny-menu.menu-hor > ul > li .submenu > li > a:hover { + background: var(--ti-menubar-submenu-hover-color); +} +.tiny-menu.menu-hor > ul > li .submenu > li > a.active, +.tiny-menu.menu-hor > ul > li .submenu > li > a:active { + background: var(--ti-menubar-submenu-active-color); +} +.tiny-menu.menu-hor > ul > li .submenu > li > span.icon-starActive { + left: 8px; +} +.tiny-menu.menu-hor > ul > li .submenu > li > span.icon-transpond { + right: 8px; +} +.tiny-menu.menu-hor > ul > li.node-selected > a, +.tiny-menu.menu-hor > ul > li:hover > a { + border-right: 0; +} +.tiny-menu.menu-hor > ul > li:last-child > a { + border-right: 0; +} +.tiny-menu.menu-hor > ul li { + padding: 0; + height: var(--ti-menubar-li-height); + line-height: var(--ti-menubar-li-height); + position: relative; +} +.tiny-menu.menu-hor > ul li > a { + min-width: 60px; + width: 100%; + height: 100%; + color: var(--ti-menubar-title-color); +} +.tiny-menu.menu-hor > ul li > a:active, +.tiny-menu.menu-hor > ul li > a:focus, +.tiny-menu.menu-hor > ul li > a:hover { + color: var(--ti-menubar-title-color); + text-decoration: none; + background: var(--ti-menubar-background-active); +} +.tiny-menu.menu-hor ul { + padding: 0; + margin: 0; + background: var(--ti-menubar-background-normal); +} +.tiny-menu.menu-hor .menus-left, +.tiny-menu.menu-hor .menus-left .submenu { + left: auto; + right: 100%; +} +.tiny-menu.menu-hor .node-selected > .submenu { + left: auto; + margin-top: 2px; +} +.tiny-menu.menu-hor .node-selected > .submenu > li.node-selected { + background: var(--ti-menubar-background-active); +} +.tiny-menu.menu-hor .node-selected > .submenu > li.node-selected a { + color: var(--ti-menubar-submenu-normal-color); +} +.tiny-menu.menu-hor .node-selected > .submenu > li.node-selected a:hover { + color: #1890ff; + background: #fff; +} +.tiny-menu.menu-hor .node-selected > .submenu > li .submenu { + margin-top: -40px; + margin-left: 2px; +} +.tiny-menu.menu-hor .node-selected > .submenu .node-selected > .submenu { + left: 100%; +} +.tiny-menu.menu-hor .node-selected .submenu { + background: #fff; + border: 1px solid #d9d9d9; + -webkit-box-shadow: 0 0 4px rgba(0, 0, 0, 0.15); + box-shadow: 0 0 4px rgba(0, 0, 0, 0.15); +} +.tiny-menu.menu-hor .menu-dropdown { + margin-top: 0; +} +.tiny-menu.menu-hor .menu-dropdown .menu-group { + padding: 0 0 0 15px; + display: table-cell; + text-align: left; + word-break: break-all; + min-width: 330px; + max-width: 350px; + font-weight: 400; + vertical-align: top; +} +.tiny-menu.menu-hor .menu-dropdown .menu-group li { + line-height: 30px; + display: inline-block; + margin-right: 8px; +} +.tiny-menu.menu-hor .menu-dropdown .menu-group li.menu-row { + display: block; +} +.tiny-menu.menu-hor .menu-dropdown .menu-group li.menu-row:after, +.tiny-menu.menu-hor .menu-dropdown .menu-group li.menu-row:before { + content: ''; + display: table; +} +.tiny-menu.menu-hor .menu-dropdown .menu-group li.menu-row:after { + clear: both; +} +.tiny-menu.menu-hor .menu-dropdown .menu-group li a { + padding-right: 8px; +} +.tiny-menu.menu-hor .menu-dropdown .menu-group:last-child { + border-right: 0; +} +.tiny-menu.menu-hor .menu-dropdown .memu-group-sub { + font-weight: 400; + border: none; + line-height: 25px; + display: block; +} +.tiny-menu.menu-hor .menu-dropdown .memu-group-sub:after, +.tiny-menu.menu-hor .menu-dropdown .memu-group-sub:before { + content: ''; + display: table; +} +.tiny-menu.menu-hor .menu-dropdown .memu-group-sub:after { + clear: both; +} +.tiny-menu.menu-hor .menu-dropdown .memu-group-sub li { + border: 0; +} +.tiny-menu.menu-hor .submenu { + margin-top: 0; +} +.tiny-menu.menu-hor .submenu li { + padding: 0; + height: var(--ti-menubar-submenu-li-height); + line-height: var(--ti-menubar-submenu-li-height); +} +.tiny-menu.menu-hor .submenu li .starActive-favorite { + color: #e1860a; +} +.tiny-menu.menu-hor .submenu li a { + padding: 0 35px 0 12px; + white-space: nowrap; + text-align: left; +} +.tiny-menu.menu-hor .submenu li span { + position: absolute; + color: var(--ti-menubar-submenu-normal-color); +} +.tiny-menu.menu-hor .menu-dropdown, +.tiny-menu.menu-hor .submenu { + position: absolute; + z-index: 10; + border-top: 0; + margin-top: 0; +} +.tiny-menu.menu-hor span.icon-starActive, +.tiny-menu.menu-hor span.icon-transpond { + position: absolute; +} +.tiny-menu.menu-hor span.icon-transpond { + right: 5px; + margin-right: 0; +} +.tiny-menu.menu-hor span.icon-starActive { + left: 0; +} +.tiny-menu.menu-hor span.icon-starActive + a { + padding-left: 35px; +} +.menu-roll > ul:after, +.menu-roll > ul:before { + content: ''; + display: table; +} +.menu-roll > ul:after { + clear: both; +} +.menu-roll > ul > li { + display: none; + margin-left: 0; +} +.menu-roll > ul > li:after, +.menu-roll > ul > li:before { + content: ''; + display: table; +} +.menu-roll > ul > li:after { + clear: both; +} +.menu-roll > ul > li a { + height: 45px; + font-weight: 700; + min-width: 30px; + margin: 0; + padding: 0 6px; + text-align: left; +} +.menu-roll > ul > li.node-selected > a { + float: left; + width: 100%; +} +.menu-roll .submenu { + text-align: left; + line-height: 30px; + left: 100%; + margin-top: 45px; + min-width: 180px; +} +.menu-roll .submenu .submenu { + margin-top: -31px; + top: inherit; +} +.menu-roll .submenu li { + padding: 0 10px; + height: 45px; + line-height: 45px; +} +.menu-roll .submenu li a { + padding: 0 6px; + display: block; + padding-right: 27px; +} +.menu-roll .submenu li span { + float: right; + margin: 5px 0 0 10px; +} +.menu-roll .submenu li span.tiny-icon { + float: none !important; +} +.menu-roll .submenu li span.icon-starActive, +.menu-roll .submenu li span.icon-transpond { + position: initial; +} +.menu-roll .node-selected { + display: block; +} +.menu-roll .node-selected > .submenu { + display: block; + left: 100%; + margin: 0; + min-width: 720px; +} +.menu-roll .node-selected > .submenu li { + float: left; +} +.roll-popup > ul > li { + display: block; +} +.roll-popup > ul > li > .submenu { + display: none; +} +.hor-dropdown { + position: relative; + z-index: 100; +} +.hor-dropdown .hor-dropdown-content, +.hor-dropdown > ul { + float: left; +} +.hor-dropdown-content { + position: relative; + color: #fff; +} +.hor-dropdown-content > span { + width: 80px; + text-align: center; + display: inline-block; + line-height: 31px; + position: relative; + z-index: 1; + background: var(--ti-menubar-background-normal); + line-height: 46px; +} +.hor-dropdown-content > span i { + width: 15px; + height: 16px; + padding-top: 1px; + border-radius: 2px; + cursor: pointer; + border: 1px solid var(--ti-menubar-dropdown-border-color); +} +.hor-dropdown-content .dropdown-menu { + position: absolute; + min-width: 140px; + padding: 5px; + right: 0; + margin-top: -1px; + background: var(--ti-menubar-background-normal); + padding: 5px 0; +} +.hor-dropdown-content .dropdown-menu li { + line-height: 24px; + padding: 2px 10px; + border: 1px solid var(--ti-menubar-background-normal); +} +.hor-dropdown-content .dropdown-menu li a { + color: #fff; +} +.hor-dropdown-content .dropdown-menu li:hover { + -webkit-box-shadow: inset 0 0 4px rgba(255, 255, 255, 0.6); + box-shadow: inset 0 0 4px rgba(255, 255, 255, 0.6); + border-radius: 3px; + border: 1px solid var(--ti-menubar-dropdown-hover-border-color); + background: var(--ti-menubar-dropdown-hover-background); +} +.menu-horline > ul > li { + position: inherit; +} +.menu-horline > ul > li a { + font-weight: 400; +} +.menu-horline > ul > li a span.tiny-icon { + margin-right: 5px; +} +.menu-horline > ul > li.node-more { + position: relative; +} +.menu-horline > ul > li.node-more > .submenu { + left: 0; +} +.menu-horline > ul > li.node-more > .submenu > li { + float: none; +} +.menu-horline > ul > li.node-more > .submenu > li > a { + text-align: left; +} +.menu-horline > ul > li.node-more > .submenu span.tiny-icon { + margin-left: 5px; +} +.menu-horline > ul > li.node-selected { + position: inherit; +} +.menu-horline .submenu { + min-width: 100%; +} +.menu-horline .submenu li { + float: left; +} +.menu-horline .submenu li a { + padding: 0 8px; + margin: 5px 0; + line-height: 35px; + text-align: center; +} +.menu-horline .submenu li span.tiny-icon { + float: none !important; +} +.menu-horline .submenu li span.icon-starActive, +.menu-horline .submenu li span.icon-transpond { + position: initial; +} +.menu-horline .node-selected > .submenu { + height: 45px; + left: 0; +} +.menu-horline .node-selected > .submenu li { + line-height: 45px; +} +.tiny-milestone { + --ti-milestone-color: var(--ti-base-color-light); + --ti-milestone-font-size: var(--ti-common-font-size-base); + --ti-milestone-icon-width: var(--ti-common-size-5x); + --ti-milestone-icon-height: var(--ti-common-size-5x); + --ti-milestone-line-background: #dbdbdb; + --ti-milestone-status-color: var(--ti-base-color-placeholder); + --ti-milestone-flag-tip-line-height: 20px; + --ti-milestone-flag-tip-background: var(--ti-base-color-border); + --ti-milestone-flag-tip-border-radius: var(--ti-common-border-radius-normal); + --ti-milestone-flag-content-border-radius: var(--ti-common-border-radius-1); + --ti-milestone-flag-content-font-size: var(--ti-common-font-size-1); + overflow: hidden; + padding-top: 38px; +} +.tiny-milestone .tiny-milestone__node { + display: block; + float: left; +} +.tiny-milestone .tiny-milestone__node::before { + content: ''; + width: 28px; + height: 28px; + display: block; + position: relative; + left: calc(50% - 14px); + top: 28px; + z-index: 15; +} +.tiny-milestone .tiny-milestone__node.is-solid::before { + background: var(--ti-milestone-color); +} +.tiny-milestone .tiny-milestone__node.is-solid .tiny-svg { + fill: var(--ti-milestone-color); +} +.tiny-milestone .tiny-milestone__node .iconfix { + font-size: var(--ti-common-font-size-4); +} +.tiny-milestone .tiny-milestone__icon { + background: var(--ti-milestone-color); + width: var(--ti-milestone-icon-width, 20px); + height: var(--ti-milestone-icon-height, 20px); + line-height: var(--ti-milestone-icon-height, 20px); + position: relative; + font-size: var(--ti-milestone-font-size, 12px); + text-align: center; + left: calc(50% - 10px); + top: 4px; + border-radius: 50%; + color: var(--ti-milestone-color); + cursor: pointer; + z-index: 15; +} +.tiny-milestone .tiny-milestone__icon.is-completed { + border: solid 2px; +} +.tiny-milestone .tiny-milestone__icon.is-completed .tiny-svg { + fill: #1890ff; + vertical-align: baseline; +} +.tiny-milestone .tiny-milestone__line { + height: 4px; + left: 50%; + top: -8px; + position: relative; + background: var(--ti-milestone-line-background); +} +.tiny-milestone .tiny-milestone__line-end { + width: 0; +} +.tiny-milestone .tiny-milestone__description { + line-height: 14px; + margin-top: 8px; + position: relative; + overflow: hidden; + text-align: center; +} +.tiny-milestone .tiny-milestone__description-name { + width: 100%; + color: #333; + font-size: var(--ti-milestone-font-size); + float: left; +} +.tiny-milestone .tiny-milestone__description-status { + color: var(--ti-milestone-status-color); + font-size: var(--ti-milestone-font-size); + float: left; + width: 100%; +} +.tiny-milestone .tiny-milestone__flag-tip { + position: fixed; + padding: 2px 4px; + line-height: var(--ti-milestone-flag-tip-line-height); + background: var(--ti-milestone-flag-tip-background); + border-radius: var(--ti-milestone-flag-tip-border-radius); + border: solid 1px var(--ti-milestone-flag-tip-background); + text-align: center; + word-wrap: break-word; +} +.tiny-milestone .tiny-milestone__flag-tip::before { + position: absolute; + width: 0; + height: 0; + border-style: solid; + border: 1px solid; + border-width: 8px 8px 0 8px; + border-color: #d9d9d9 transparent; + content: ''; + left: calc(50% - 4px); + bottom: -6px; +} +.tiny-milestone .tiny-milestone__flag { + position: absolute; + left: calc(50% - 29px); + bottom: 5px; + width: 58px; + text-align: center; + z-index: 1; +} +.tiny-milestone .tiny-milestone__flag:hover { + z-index: 2; +} +.tiny-milestone .tiny-milestone__flag-content { + width: 58px; + height: 34px; + padding: 0; + line-height: 15px; + font-size: var(--ti-milestone-flag-content-font-size); + border-radius: var(--ti-milestone-flag-content-border-radius); + color: var(--ti-milestone-color); + background: #333; + cursor: pointer; + vertical-align: middle; + display: table-cell; +} +.tiny-milestone .tiny-milestone__flag-content p { + color: var(--ti-milestone-color); + width: 58px; + font-size: var(--ti-common-font-size-base); + white-space: nowrap; + text-overflow: ellipsis; + overflow: hidden; + padding: 0 4px; + margin: 0; + -webkit-box-sizing: border-box; + box-sizing: border-box; +} +.tiny-milestone .tiny-milestone__flag-line { + height: 30px; + width: 1px; + margin-left: 50%; + background: #333; +} +.tiny-milestone .tiny-milestone__dot { + display: block; + background: var(--ti-milestone-flag-line-color); + border: solid 1px; + border-radius: 50%; + width: 5px; + height: 5px; + position: relative; + bottom: -29px; + right: 2px; +} +.tiny-modal { + --ti-modal-font-size: var(--ti-common-font-size-base); + --ti-modal-font-color: var(--ti-base-color-info-normal); + --ti-modal-font-family: Helvetica, Arial, 'Microsoft YaHei', sans-serif; + --ti-modal-primary-color: var(--ti-common-color-prompt); + --ti-modal-success-color: var(--ti-common-color-success); + --ti-modal-error-color: var(--ti-common-color-error); + --ti-modal-warning-color: var(--ti-common-color-warn); + --ti-modal-loading-color: var(--ti-common-color-prompt); + --ti-modal-alert-font-size: 22px; + --ti-modal-header-font-size: var(--ti-common-font-size-3); + --ti-modal-header-text-color: var(--ti-common-color-text-primary); + --ti-modal-header-font-weight: var(--ti-base-font-weight-bold); + --ti-modal-header-padding: 32px 32px 12px 32px; + --ti-modal-body-padding: 0 32px; + --ti-modal-footer-padding: 28px 32px 32px; + --ti-modal-footer-btn-border-radius: var(--ti-common-border-radius-normal); + --ti-modal-close-btn-font-size: var(--ti-common-font-size-1); + --ti-modal-close-btn-top: 13px; + --ti-modal-close-btn-scale: scale(1, 1); + --ti-modal-close-btn-padding: 0; + --ti-modal-small-btn-font-size: var(--ti-common-font-size-2); + --ti-modal-box-background-color: var(--ti-base-color-light); + --ti-modal-btn-color: var(--ti-base-color-common-5); + --ti-modal-box-shadow: var(--ti-common-shadow-4-down); + --ti-modal-box-border-radius: var(--ti-common-border-radius-normal); + --ti-modal-border-color: rgba(0, 0, 0, 0.2); + --ti-modal-close-btn-background-color-hover: var(--ti-base-color-light); + --ti-modal-footer-default-button: inline-block; + --ti-modal-box-width: 400px; +} +.tiny-modal__wrapper { + display: none; + position: fixed; + top: 0; + left: 0; + width: 100%; + height: 100%; + font-size: var(--ti-modal-font-size); + color: var(--ti-modal-font-color); + font-family: var(--ti-modal-font-family, Helvetica, Arial, 'Microsoft YaHei', sans-serif); + -webkit-transition: top 0.4s; + transition: top 0.4s; +} +.tiny-modal__wrapper.active { + display: block; +} +.tiny-modal__wrapper.is__visible.is__mask:before { + background-color: rgba(0, 0, 0, 0.3); +} +.tiny-modal__wrapper.is__visible.type__message .tiny-modal__box { + -webkit-transform: translateY(0); + transform: translateY(0); +} +.tiny-modal__wrapper.is__visible:not(.type__message) .tiny-modal__box:not(.is__drag) { + top: 15vh; + -webkit-transition: top 0s ease-in, opacity 0.4s ease-in; + transition: top 0s ease-in, opacity 0.4s ease-in; +} +.tiny-modal__wrapper.is__visible .tiny-modal__box { + opacity: 1; + visibility: visible; +} +.tiny-modal__wrapper:not(.lock__view) { + pointer-events: none; +} +.tiny-modal__wrapper.lock__scroll { + overflow: hidden; +} +.tiny-modal__wrapper:not(.lock__scroll) { + overflow: auto; +} +.tiny-modal__wrapper:not(.type__message) .tiny-modal__text { + font-size: var(--ti-common-font-size-base); + color: var(--ti-common-color-text-secondary); + line-height: var(--ti-common-line-height-number); +} +.tiny-modal__wrapper.is__mask:before, +.tiny-modal__wrapper.lock__view:before { + content: ''; + position: fixed; + top: 0; + left: 0; + width: 100%; + height: 100%; + z-index: -1; + pointer-events: auto; +} +.tiny-modal__wrapper.is__animat.is__mask:before { + -webkit-transition: background-color, 0.2s, ease-in-out; + transition: background-color, 0.2s, ease-in-out; +} +.tiny-modal__wrapper.is__animat.type__message .tiny-modal__box:not(.is__drag) { + -webkit-transition: all, 0.2s, ease-out; + transition: all, 0.2s, ease-out; +} +.tiny-modal__wrapper.size__mini, +.tiny-modal__wrapper.size__small { + font-size: var(--ti-modal-font-size); +} +.tiny-modal__wrapper.size__mini .tiny-modal__box, +.tiny-modal__wrapper.size__small .tiny-modal__box { + padding: 6px 0; +} +.tiny-modal__wrapper.size__mini .tiny-modal__body, +.tiny-modal__wrapper.size__small .tiny-modal__body { + padding: 4px 14px 10px 14px; +} +.tiny-modal__wrapper.size__mini .tiny-modal__footer, +.tiny-modal__wrapper.size__small .tiny-modal__footer { + padding: 4px 14px 8px 14px; +} +.tiny-modal__wrapper.size__mini .tiny-modal__header, +.tiny-modal__wrapper.size__small .tiny-modal__header { + font-size: var(--ti-modal-header-font-size); + padding: 6px 30px 8px 14px; +} +.tiny-modal__wrapper.size__mini .tiny-modal__close-btn, +.tiny-modal__wrapper.size__mini .tiny-modal__zoom-btn, +.tiny-modal__wrapper.size__small .tiny-modal__close-btn, +.tiny-modal__wrapper.size__small .tiny-modal__zoom-btn { + font-size: var(--ti-modal-small-btn-font-size); + top: 10px; +} +.tiny-modal__wrapper.type__alert .tiny-modal__body, +.tiny-modal__wrapper.type__confirm .tiny-modal__body, +.tiny-modal__wrapper.type__message .tiny-modal__body { + white-space: normal; + word-break: break-word; +} +.tiny-modal__wrapper.type__message { + text-align: center; +} +.tiny-modal__wrapper.type__message .tiny-modal__box { + display: inline-block; + padding: 24px; + margin-top: 0; + width: auto; + -webkit-box-shadow: 0 0 8px 0 rgba(0, 0, 0, 0.1); + box-shadow: 0 0 8px 0 rgba(0, 0, 0, 0.1); + -webkit-transform: translateY(-10%); + transform: translateY(-10%); +} +.tiny-modal__wrapper.type__message .tiny-modal__box .tiny-modal__body:after { + content: ''; + display: block; + clear: both; + height: 0; + overflow: hidden; + visibility: hidden; +} +.tiny-modal__wrapper.type__message .tiny-modal__box .tiny-modal__content { + max-width: 800px; + float: left; +} +.tiny-modal__wrapper.type__message .tiny-modal__status-wrapper { + font-size: var(--ti-modal-small-btn-font-size); + padding-right: 10px; +} +.tiny-modal__wrapper.type__alert .tiny-modal__box, +.tiny-modal__wrapper.type__confirm .tiny-modal__box, +.tiny-modal__wrapper.type__modal .tiny-modal__box { + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-orient: vertical; + -webkit-box-direction: normal; + -ms-flex-direction: column; + flex-direction: column; + position: absolute; + left: 50%; + top: 0; + -webkit-box-shadow: var(--ti-modal-box-shadow); + box-shadow: var(--ti-modal-box-shadow); + border: 1px solid var(--ti-modal-border-color); +} +.tiny-modal__wrapper.type__alert .tiny-modal__box .tiny-modal__header, +.tiny-modal__wrapper.type__confirm .tiny-modal__box .tiny-modal__header, +.tiny-modal__wrapper.type__modal .tiny-modal__box .tiny-modal__header { + cursor: move; +} +.tiny-modal__wrapper.type__modal .tiny-modal__body { + overflow: auto; +} +.tiny-modal__wrapper.type__modal .tiny-modal__body .tiny-modal__content { + overflow: auto; +} +.tiny-modal__wrapper.type__alert .tiny-modal__status-wrapper, +.tiny-modal__wrapper.type__confirm .tiny-modal__status-wrapper { + font-size: var(--ti-modal-alert-font-size); + padding: 0 10px 0 2px; +} +.tiny-modal__wrapper.status__info .tiny-modal__status-wrapper { + fill: var(--ti-modal-primary-color); +} +.tiny-modal__wrapper.status__question .tiny-modal__status-wrapper, +.tiny-modal__wrapper.status__warning .tiny-modal__status-wrapper { + fill: var(--ti-modal-warning-color); +} +.tiny-modal__wrapper.status__success .tiny-modal__status-wrapper { + fill: var(--ti-modal-success-color); +} +.tiny-modal__wrapper.status__error .tiny-modal__status-wrapper { + fill: var(--ti-modal-error-color); +} +.tiny-modal__wrapper.status__loading .tiny-modal__status-wrapper { + fill: var(--ti-modal-loading-color); +} +.tiny-modal__wrapper.is__maximize .tiny-modal__box .tiny-modal__header { + cursor: default; +} +.tiny-modal__wrapper.is__maximize .tiny-modal__resize .sb-resize, +.tiny-modal__wrapper.is__maximize .tiny-modal__resize .selb-resize, +.tiny-modal__wrapper.is__maximize .tiny-modal__resize .sest-resize, +.tiny-modal__wrapper.is__maximize .tiny-modal__resize .st-resize, +.tiny-modal__wrapper.is__maximize .tiny-modal__resize .swlb-resize, +.tiny-modal__wrapper.is__maximize .tiny-modal__resize .swst-resize, +.tiny-modal__wrapper.is__maximize .tiny-modal__resize .wl-resize, +.tiny-modal__wrapper.is__maximize .tiny-modal__resize .wr-resize { + display: none; +} +.tiny-modal__box { + width: var(--ti-modal-box-width); + background-color: var(--ti-modal-box-background-color); + border-radius: var(--ti-modal-box-border-radius); + font-size: var(--ti-modal-header-font-size); + -webkit-box-shadow: var(--ti-common-shadow-4-down); + box-shadow: var(--ti-common-shadow-4-down); + text-align: left; + pointer-events: auto; + visibility: hidden; + opacity: 0; +} +.tiny-modal__box.is__drag { + cursor: move; +} +.tiny-modal__box.is__drag .tiny-modal__body:after, +.tiny-modal__box.is__drag .tiny-modal__footer:after { + content: ''; + position: absolute; + top: 0; + left: 0; + width: 100%; + height: 100%; +} +.tiny-modal__box.is__drag .tiny-modal__body { + overflow: hidden; +} +.tiny-modal__box.is__drag .tiny-modal__body .tiny-modal__content { + overflow: hidden; +} +.tiny-modal__status-wrapper { + -ms-flex-negative: 0; + flex-shrink: 0; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; +} +.tiny-modal__status-icon { + font-style: normal; +} +.tiny-modal__content { + width: 100%; + -webkit-box-flex: 1; + -ms-flex-positive: 1; + flex-grow: 1; +} +.tiny-modal__body, +.tiny-modal__footer, +.tiny-modal__header { + position: relative; +} +.tiny-modal__body { + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-flex: 1; + -ms-flex-positive: 1; + flex-grow: 1; + padding: var(--ti-modal-body-padding); +} +.tiny-modal__header { + -ms-flex-negative: 0; + flex-shrink: 0; + color: var(--ti-modal-header-text-color); + font-size: var(--ti-modal-header-font-size); + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + font-weight: var(--ti-modal-header-font-weight); + border-bottom: none; + padding: var(--ti-modal-header-padding); + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; +} +.tiny-modal__close-btn, +.tiny-modal__zoom-btn { + font-size: var(--ti-modal-close-btn-font-size); + position: absolute; + right: 24px; + top: var(--ti-modal-close-btn-top); + z-index: 1; + fill: var(--ti-modal-btn-color); + -webkit-transform: var(--ti-modal-close-btn-scale); + transform: var(--ti-modal-close-btn-scale); + cursor: pointer; + padding: var(--ti-modal-close-btn-padding); + border-radius: 4px; +} +.tiny-modal__close-btn:hover, +.tiny-modal__zoom-btn:hover { + fill: var(--ti-modal-btn-color); + background-color: var(--ti-modal-close-btn-background-color-hover); +} +.tiny-modal__zoom-btn { + right: 44px; + border-color: #c0c4cc; +} +.tiny-modal__zoom-btn:hover { + border-color: #606266; +} +.tiny-modal__footer { + -ms-flex-negative: 0; + flex-shrink: 0; + text-align: center; + padding: var(--ti-modal-footer-padding); +} +.tiny-modal__footer .tiny-button { + border-radius: var(--ti-modal-footer-btn-border-radius); +} +.tiny-modal__footer .tiny-button--default { + display: var(--ti-modal-footer-default-button); +} +.tiny-modal__resize .sb-resize, +.tiny-modal__resize .selb-resize, +.tiny-modal__resize .sest-resize, +.tiny-modal__resize .st-resize, +.tiny-modal__resize .swlb-resize, +.tiny-modal__resize .swst-resize, +.tiny-modal__resize .wl-resize, +.tiny-modal__resize .wr-resize { + position: absolute; + z-index: 100; +} +.tiny-modal__resize .wl-resize, +.tiny-modal__resize .wr-resize { + width: 8px; + height: 100%; + top: 0; + cursor: w-resize; +} +.tiny-modal__resize .wl-resize { + left: -3px; +} +.tiny-modal__resize .wr-resize { + right: -3px; +} +.tiny-modal__resize .selb-resize, +.tiny-modal__resize .sest-resize, +.tiny-modal__resize .swlb-resize, +.tiny-modal__resize .swst-resize { + width: 10px; + height: 10px; + z-index: 101; +} +.tiny-modal__resize .sest-resize, +.tiny-modal__resize .swst-resize { + top: -8px; +} +.tiny-modal__resize .selb-resize, +.tiny-modal__resize .swlb-resize { + bottom: -8px; +} +.tiny-modal__resize .sest-resize, +.tiny-modal__resize .swlb-resize { + cursor: sw-resize; +} +.tiny-modal__resize .selb-resize, +.tiny-modal__resize .swst-resize { + cursor: se-resize; +} +.tiny-modal__resize .swlb-resize, +.tiny-modal__resize .swst-resize { + left: -8px; +} +.tiny-modal__resize .selb-resize, +.tiny-modal__resize .sest-resize { + right: -8px; +} +.tiny-modal__resize .sb-resize, +.tiny-modal__resize .st-resize { + width: 100%; + height: 8px; + left: 0; + cursor: s-resize; +} +.tiny-modal__resize .st-resize { + top: -3px; +} +.tiny-modal__resize .sb-resize { + bottom: -3px; +} +@-webkit-keyframes modal-fade-in { + 0% { + -webkit-transform: translate3d(0, -20px, 0); + transform: translate3d(0, -20px, 0); + opacity: 0; + } + 100% { + -webkit-transform: translate3d(0, 0, 0); + transform: translate3d(0, 0, 0); + opacity: 1; + } +} +@keyframes modal-fade-in { + 0% { + -webkit-transform: translate3d(0, -20px, 0); + transform: translate3d(0, -20px, 0); + opacity: 0; + } + 100% { + -webkit-transform: translate3d(0, 0, 0); + transform: translate3d(0, 0, 0); + opacity: 1; + } +} +@-webkit-keyframes modal-fade-out { + 0% { + -webkit-transform: translate3d(0, 0, 0); + transform: translate3d(0, 0, 0); + opacity: 1; + } + 100% { + -webkit-transform: translate3d(0, -20px, 0); + transform: translate3d(0, -20px, 0); + opacity: 0; + } +} +@keyframes modal-fade-out { + 0% { + -webkit-transform: translate3d(0, 0, 0); + transform: translate3d(0, 0, 0); + opacity: 1; + } + 100% { + -webkit-transform: translate3d(0, -20px, 0); + transform: translate3d(0, -20px, 0); + opacity: 0; + } +} +@keyframes modal-fade-in { + 0% { + -webkit-transform: translate3d(0, -20px, 0); + transform: translate3d(0, -20px, 0); + opacity: 0; + } + 100% { + -webkit-transform: translate3d(0, 0, 0); + transform: translate3d(0, 0, 0); + opacity: 1; + } +} +@keyframes modal-fade-out { + 0% { + -webkit-transform: translate3d(0, 0, 0); + transform: translate3d(0, 0, 0); + opacity: 1; + } + 100% { + -webkit-transform: translate3d(0, -20px, 0); + transform: translate3d(0, -20px, 0); + opacity: 0; + } +} +.tiny-nav-menu { + --ti-nav-menu-height: var(--ti-base-size-height-large); + --ti-nav-menu-background: var(--ti-base-color-navigation-background); + --ti-nav-menu-item-font-size: var(--ti-common-font-size-2); + --ti-nav-menu-item-font-color: var(--ti-base-color-light); + --ti-nav-menu-item-hover-background: #474c5e; + --ti-nav-menu-setting-font-size: 22px; + --ti-nav-menu-popmenu-color: var(--ti-base-color-info-normal); + --ti-nav-menu-popmenu-border-color: var(--ti-base-color-border); + --ti-nav-menu-popmenu-more-item-height: 40px; + --ti-nav-menu-popmenu-more-item-hover-color: var(--ti-base-color-brand-6); + --ti-nav-menu-popmenu-more-item-hover-background: var(--ti-base-color-hover-background); + --ti-nav-menu-popmenu-more-item-active-background: var(--ti-base-color-selected-background); + --ti-nav-menu-popmenu-node-title-font-size: var(--ti-common-font-size-1); + --ti-nav-menu-popmenu-node-item-font-size: var(--ti-common-font-size-base, 12px); + background: var(--ti-nav-menu-background); + height: var(--ti-nav-menu-height); + position: relative; + padding: 0 24px; +} +.tiny-nav-menu > .slot-logo { + float: left; + overflow: hidden; + margin: 0 100px 0 0; + line-height: var(--ti-nav-menu-height); +} +.tiny-nav-menu > .slot-toolbar { + float: right; +} +.tiny-nav-menu > .slot-toolbar > .setting { + position: relative; + float: right; + margin: 0 0 0 24px; +} +.tiny-nav-menu > .slot-toolbar > .setting > .tiny-icon { + font-size: var(--ti-nav-menu-setting-font-size); + line-height: var(--ti-nav-menu-height); + cursor: pointer; + color: #fff; +} +.tiny-nav-menu > .slot-toolbar > .setting > .more-setting { + position: absolute; + right: 0; + min-width: 120px; + background-color: var(--ti-nav-menu-item-font-color); + border: 1px solid #d9d9d9; + -webkit-box-shadow: 0 0 4px rgba(0, 0, 0, 0.15); + box-shadow: 0 0 4px rgba(0, 0, 0, 0.15); +} +.tiny-nav-menu > .slot-toolbar > .setting > .more-setting > .setting-item { + padding: 6px 10px; + color: #333; +} +.tiny-nav-menu > .slot-toolbar > .setting > .more-setting > .setting-item:hover { + background: var(--ti-nav-menu-popmenu-more-item-hover-background); +} +.tiny-nav-menu > .slot-toolbar > .setting > .more-setting > .setting-item:active { + background: var(--ti-nav-menu-popmenu-more-item-active-background); +} +.tiny-nav-menu > .slot-toolbar > .template-toolbar .tiny-selector { + margin-top: 0; +} +.tiny-nav-menu > .menu { + float: left; + height: var(--ti-nav-menu-height); + line-height: var(--ti-nav-menu-height); + overflow: hidden; +} +.tiny-nav-menu > .menu > li { + float: left; +} +.tiny-nav-menu > .menu > li > a, +.tiny-nav-menu > .menu > li > span { + padding: 0 12px; + font-size: var(--ti-nav-menu-item-font-size); + text-align: center; + color: var(--ti-nav-menu-item-font-color); + cursor: pointer; + display: block; + height: var(--ti-nav-menu-height); + line-height: var(--ti-nav-menu-height); + -webkit-box-sizing: border-box; + box-sizing: border-box; +} +.tiny-nav-menu > .menu > li > a.active, +.tiny-nav-menu > .menu > li > a:hover, +.tiny-nav-menu > .menu > li > span.active, +.tiny-nav-menu > .menu > li > span:hover { + color: var(--ti-nav-menu-item-font-color); + background: var(--ti-nav-menu-item-hover-background); + text-decoration: none; +} +.tiny-nav-menu > .menu > li > a.selected, +.tiny-nav-menu > .menu > li > span.selected { + border-bottom: 3px solid #fff; +} +.tiny-nav-menu > .more { + padding: 0 12px; + font-size: var(--ti-nav-menu-item-font-size); + text-align: center; + color: var(--ti-nav-menu-item-font-color); + cursor: pointer; + display: inline-block; + height: var(--ti-nav-menu-height); + line-height: var(--ti-nav-menu-height); +} +.tiny-nav-menu > .more.active, +.tiny-nav-menu > .more.selected, +.tiny-nav-menu > .more:hover { + color: var(--ti-nav-menu-item-font-color); + background: var(--ti-nav-menu-item-hover-background); +} +.tiny-nav-menu > .more.selected { + border-bottom: 3px solid #fff; +} +.tiny-nav-menu > .popmenu { + position: absolute; + background: #fff; + width: 100%; + border: 1px solid var(--ti-nav-menu-popmenu-border-color); + -webkit-box-shadow: 0 0 4px var(--ti-nav-menu-popmenu-border-color); + box-shadow: 0 0 4px var(--ti-nav-menu-popmenu-border-color); + max-height: calc(100vh - var(--ti-nav-menu-height)); + overflow-y: auto; + left: 0; +} +.tiny-nav-menu > .popmenu > .more-menu { + float: left; + width: 160px; + height: 100%; + border-right: 1px solid var(--ti-nav-menu-popmenu-border-color); + -webkit-box-sizing: border-box; + box-sizing: border-box; +} +.tiny-nav-menu > .popmenu > .more-menu > ul { + list-style: none; +} +.tiny-nav-menu > .popmenu > .more-menu > ul > li { + height: var(--ti-nav-menu-popmenu-more-item-height); + line-height: var(--ti-nav-menu-popmenu-more-item-height); + padding: 0 12px 0 24px; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-pack: justify; + -ms-flex-pack: justify; + justify-content: space-between; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; +} +.tiny-nav-menu > .popmenu > .more-menu > ul > li.active, +.tiny-nav-menu > .popmenu > .more-menu > ul > li:hover { + color: var(--ti-nav-menu-popmenu-more-item-hover-color); + background: var(--ti-nav-menu-popmenu-more-item-hover-background); +} +.tiny-nav-menu > .popmenu > .more-menu > ul > li.active .more-icon, +.tiny-nav-menu > .popmenu > .more-menu > ul > li:hover .more-icon { + fill: var(--ti-nav-menu-popmenu-more-item-hover-color); +} +.tiny-nav-menu > .popmenu > .more-menu > ul > li > a { + color: var(--ti-nav-menu-popmenu-color); +} +.tiny-nav-menu > .popmenu > .more-menu > ul > li > a, +.tiny-nav-menu > .popmenu > .more-menu > ul > li > span { + display: block; + height: var(--ti-nav-menu-popmenu-more-item-height); + line-height: var(--ti-nav-menu-popmenu-more-item-height); + font-size: var(--ti-common-font-size-base); + width: 100%; + white-space: nowrap; + overflow: hidden; + text-overflow: ellipsis; +} +.tiny-nav-menu > .popmenu > .more-menu > ul > li > a.showicon, +.tiny-nav-menu > .popmenu > .more-menu > ul > li > span.showicon { + width: calc(100% - 12px); +} +.tiny-nav-menu > .popmenu > .more-menu > ul > li > .more-icon { + font-size: var(--ti-common-font-size-base); +} +.tiny-nav-menu > .popmenu > .sub-menu { + float: left; + width: calc(100% - 160px); + padding-left: 14px; + -webkit-box-sizing: border-box; + box-sizing: border-box; +} +.tiny-nav-menu > .popmenu > .sub-menu.full-width { + width: 100%; + padding: 0 86px; +} +.tiny-nav-menu > .popmenu > .sub-menu > ul { + list-style: none; + overflow: hidden; +} +.tiny-nav-menu > .popmenu > .sub-menu > ul .group { + list-style: none; + margin-bottom: 24px; +} +.tiny-nav-menu > .popmenu > .sub-menu > ul .group:first-child { + margin-top: 18px; +} +.tiny-nav-menu > .popmenu > .sub-menu > ul .group > .tiny-nav-menu__sub-menu-title { + color: var(--ti-nav-menu-popmenu-color); + font-size: var(--ti-nav-menu-popmenu-node-title-font-size); + font-weight: 700; + margin: 0 0 12px 0; + word-break: break-all; +} +.tiny-nav-menu > .popmenu > .sub-menu > ul .group > .tiny-nav-menu__sub-menu-title:only-child { + border-bottom: none; +} +.tiny-nav-menu > .popmenu > .sub-menu > ul .group > .sub-item { + font-size: var(--ti-nav-menu-popmenu-node-item-font-size); + padding: 4px 0; +} +.tiny-nav-menu > .popmenu > .sub-menu > ul .group > .sub-item:hover { + background: var(--ti-nav-menu-popmenu-more-item-hover-background); +} +.tiny-nav-menu > .popmenu > .sub-menu > ul .group > .sub-item.active, +.tiny-nav-menu > .popmenu > .sub-menu > ul .group > .sub-item:active { + background: var(--ti-nav-menu-popmenu-more-item-active-background); +} +.tiny-nav-menu > .popmenu > .sub-menu > ul .group > .sub-item > a { + color: var(--ti-nav-menu-popmenu-color); + white-space: normal; + word-break: break-all; + text-decoration: none; +} +.tiny-nav-menu > .popmenu > .sub-menu > ul .group > .sub-item > span { + color: var(--ti-nav-menu-popmenu-color); + white-space: normal; + word-break: break-all; +} +.tiny-nav-menu > .single { + width: auto; + height: auto; + padding: 0; +} +.tiny-nav-menu > .single > .sub-menu.full-width { + padding: 0; +} +.tiny-nav-menu > .single > .sub-menu.full-width > ul .group { + margin: 0; +} +.tiny-nav-menu > .single > .sub-menu.full-width > ul .group .tiny-nav-menu__sub-menu-title { + padding: 18px 35px 0 12px; +} +.tiny-nav-menu + > .single + > .sub-menu.full-width + > ul + .group + .tiny-nav-menu__sub-menu-title.tiny-nav-menu__sub-menu-title-blank { + padding: 0 35px 0 12px; +} +.tiny-nav-menu > .single > .sub-menu.full-width > ul .group > .title { + margin: 0; + line-height: 40px; + padding: 0 35px 0 12px; +} +.tiny-nav-menu > .single > .sub-menu.full-width > ul .group > .sub-item { + height: 40px; + line-height: 40px; + padding: 0 35px 0 12px; + margin: 0; +} +.tiny-nav-menu > .single > .sub-menu.full-width > ul .group > .sub-item:hover { + background: var(--ti-nav-menu-popmenu-more-item-hover-background); +} +.tiny-nav-menu > .single > .sub-menu.full-width > ul .group > .sub-item.active, +.tiny-nav-menu > .single > .sub-menu.full-width > ul .group > .sub-item:active { + background: var(--ti-nav-menu-popmenu-more-item-active-background); +} +.tiny-nav-menu > .more-button { + float: left; + text-align: center; + padding: 0 12px; + height: var(--ti-nav-menu-height); + line-height: var(--ti-nav-menu-height); + overflow: hidden; + fill: #fff; + font-size: var(--ti-nav-menu-item-font-size); +} +.tiny-nav-menu > .more-button:hover { + background: var(--ti-nav-menu-item-hover-background); +} +.tiny-nav-menu > .more-button.float-right { + float: right; + margin-left: 10px; +} +.tiny-nav-menu > .slot-mobile-menu { + display: none; +} +@media (max-width: 768px) { + .tiny-nav-menu > .more-button.mobile { + display: none; + } + .tiny-nav-menu > .slot-mobile-menu { + display: block; + } + .tiny-nav-menu > .menu { + display: none; + } + .tiny-nav-menu > .popmenu .sub-menu .full-width { + padding: 0; + } +} +.tiny-notify { + --ti-notify-info-background: var(--ti-common-color-prompt-bg); + --ti-notify-info-icon-color: var(--ti-common-color-prompt); + --ti-notify-warning-background: var(--ti-common-color-warn-bg); + --ti-notify-warning-icon-color: var(--ti-common-color-warn); + --ti-notify-error-background: var(--ti-common-color-error-bg); + --ti-notify-error-icon-color: var(--ti-common-color-error); + --ti-notify-success-background: var(--ti-common-color-success-bg); + --ti-notify-success-icon-color: var(--ti-common-color-success); + --ti-notify-color: var(--ti-base-color-brand-6); + --ti-notify-border-radius: var(--ti-common-border-radius-normal); + --ti-notify-title-color: var(--ti-base-color-info-normal); + --ti-notify-title-font-size: var(--ti-common-font-size-1); + --ti-notify-title-font-weight: var(--ti-common-font-weight-7); + --ti-notify-content-font-size: var(--ti-common-font-size-1); + --ti-notify-content-margin: 0; + --ti-notify-message-margin: 0 0 0 10px; + --ti-notify-icon-size: var(--ti-common-font-size-5); + --ti-notify-close-color: var(--ti-base-color-common-7); + --ti-notify-max-width: 400px; + --ti-notify-box-shadow: var(--ti-common-shadow-4-down); + position: fixed; + z-index: 1101; + max-width: var(--ti-notify-max-width); + width: 100%; + -webkit-box-sizing: border-box; + box-sizing: border-box; + -webkit-transition: all 0.3s; + transition: all 0.3s; + overflow: hidden; + white-space: nowrap; + padding: 16px; + background: var(--ti-notify-background); + border-radius: 2px; + border-radius: var(--ti-notify-border-radius); + font-size: var(--ti-common-font-size-base); + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-orient: horizontal; + -webkit-box-direction: normal; + -ms-flex-direction: row; + flex-direction: row; + -webkit-box-align: start; + -ms-flex-align: start; + align-items: flex-start; + -webkit-box-shadow: var(--ti-notify-box-shadow); + box-shadow: var(--ti-notify-box-shadow); +} +.tiny-notify--info { + background: var(--ti-notify-info-background); +} +.tiny-notify--warning { + background: var(--ti-notify-warning-background); +} +.tiny-notify--error { + background: var(--ti-notify-error-background); +} +.tiny-notify--success { + background: var(--ti-notify-success-background); +} +.tiny-notify.top-left { + left: 10px; + top: 25px; +} +.tiny-notify.bottom-left { + left: 10px; + bottom: 25px; +} +.tiny-notify.top-right { + right: 10px; + top: 25px; +} +.tiny-notify.bottom-right { + right: 10px; + bottom: 25px; +} +.tiny-notify .tiny-notify__title { + font-weight: var(--ti-notify-title-font-weight); + font-size: var(--ti-notify-title-font-size); + color: var(--ti-notify-title-color); + line-height: 1.74; +} +.tiny-notify .tiny-notify__icon { + color: var(--ti-notify-color); +} +.tiny-notify .tiny-notify__content { + color: var(--ti-notify-title-color); + font-size: var(--ti-common-font-size-base); + margin: 0; + padding: 0; + font-size: var(--ti-common-font-size-1); + word-break: break-all; + white-space: pre-wrap; +} +.tiny-notify .tiny-notify__closebtn { + cursor: pointer; + color: var(--ti-notify-color); + position: absolute; + top: 50%; + right: 10px; + -webkit-transform: translateY(-50%); + transform: translateY(-50%); +} +.tiny-notify .tiny-notify__icon-zone { + width: 24px; + height: 24px; + font-size: var(--ti-notify-icon-size); +} +.tiny-notify .tiny-notify__message-zone { + width: calc(100% - 40px); + margin: var(--ti-notify-message-margin); +} +.tiny-notify .tiny-notify__close-zone { + width: 16px; + height: 16px; + font-size: var(--ti-common-font-size-2); + cursor: pointer; +} +.tiny-notify--info .tiny-notify__icon-zone { + fill: var(--ti-notify-info-icon-color); +} +.tiny-notify--info .tiny-notify__close-zone { + fill: var(--ti-notify-close-color); +} +.tiny-notify--warning .tiny-notify__icon-zone { + fill: var(--ti-notify-warning-icon-color); +} +.tiny-notify--warning .tiny-notify__close-zone { + fill: var(--ti-notify-close-color); +} +.tiny-notify--error .tiny-notify__icon-zone { + fill: var(--ti-notify-error-icon-color); +} +.tiny-notify--error .tiny-notify__close-zone { + fill: var(--ti-notify-close-color); +} +.tiny-notify--success .tiny-notify__icon-zone { + fill: var(--ti-notify-success-icon-color); +} +.tiny-notify--error .tiny-notify__close-zone { + fill: var(--ti-notify-close-color); +} +.tiny-notify__icon-zone .tiny-notify__icon-status { + position: relative; +} +.tiny-notify--no-close .tiny-notify__message-zone { + width: calc(100% - 24px); +} +.tiny-notify__message-zone .tiny-notify__title-wrapper { + height: 24px; + line-height: 24px; + color: var(--ti-notify-title-color); + font-size: var(--ti-notify-title-font-size); +} +.tiny-notify__message-zone .tiny-notify__content-wrapper { + height: auto; + line-height: 24px; + max-height: 96px; + overflow-y: auto; + font-size: var(--ti-notify-content-font-size); + margin: var(--ti-notify-content-margin); +} +.tiny-notify__close-zone .tiny-notify__icon-close { + position: relative; + top: -5px; +} +.tiny-notify--no-icon .tiny-notify__message-zone { + width: 100%; +} +.tiny-numeric { + --ti-numeric-input-width: 180px; + --ti-numeric-input-radius: var(--ti-common-border-radius-normal); + --ti-numeric-input-normal-border-color: var(--ti-base-color-border); + --ti-numeric-input-normal-color: var(--ti-base-color-info-normal); + --ti-numeric-input-normal-background: var(--ti-base-color-light); + --ti-numeric-input-normal-height: 28px; + --ti-numeric-input-normal-active-border-color: var(--ti-base-color-border-hover); + --ti-numeric-input-placeholder-color: var(--ti-base-color-placeholder); + --ti-numeric-input-disabled-bgcolor: var(--ti-common-color-bg-disabled); + --ti-numeric-input-icon-hover-color: var(--ti-base-color-border-hover); + --ti-numeric-input-icon-disabled-color: var(--ti-common-color-icon-disabled); + --ti-numeric-input-disabled-border-color: var(--ti-common-color-line-disabled); + position: relative; + display: inline-block; + width: var(--ti-numeric-input-width); +} +.tiny-numeric__input { + display: block; + line-height: normal; +} +.tiny-numeric__input.is-disabled .tiny-numeric__input-inner { + cursor: not-allowed; + pointer-events: none; + border: 1px solid var(--ti-numeric-input-disabled-border-color); + color: var(--ti-numeric-input-placeholder-color); + background: var(--ti-numeric-input-disabled-bgcolor); +} +.tiny-numeric__input.is-disabled .tiny-numeric__input-inner::-moz-placeholder { + color: #bfbfbf; + opacity: 1; +} +.tiny-numeric__input.is-disabled .tiny-numeric__input-inner:-ms-input-placeholder { + color: #bfbfbf; +} +.tiny-numeric__input.is-disabled .tiny-numeric__input-inner::-webkit-input-placeholder { + color: #bfbfbf; +} +.tiny-numeric__input.is-disabled .tiny-numeric__input-inner::-ms-input-placeholder { + color: #bfbfbf; +} +.tiny-numeric__input.is-disabled .tiny-numeric__input-inner::placeholder { + color: #bfbfbf; +} +.tiny-numeric__input.is-disabled .tiny-input__icon { + cursor: not-allowed; +} +.tiny-numeric__input.has-unit .tiny-numeric__input-inner { + padding: 0 50px 0 8px; +} +.tiny-numeric__input.text-align-left .tiny-numeric__input-inner { + text-align: left; +} +.tiny-numeric__input-inner { + width: 100%; + height: var(--ti-numeric-input-normal-height); + line-height: var(--ti-numeric-input-normal-height); + border: 1px solid var(--ti-numeric-input-normal-border-color); + border-radius: var(--ti-numeric-input-radius); + color: var(--ti-numeric-input-normal-color); + background: var(--ti-numeric-input-normal-background); + font-size: var(--ti-common-font-size-base); + padding: 0 calc(var(--ti-numeric-input-normal-height) + 8px); + outline: 0; + display: inline-block; + -webkit-box-sizing: border-box; + box-sizing: border-box; + -webkit-appearance: none; + -moz-appearance: none; + appearance: none; + text-align: center; + -webkit-transition: border-color 0.2s cubic-bezier(0.645, 0.045, 0.355, 1); + transition: border-color 0.2s cubic-bezier(0.645, 0.045, 0.355, 1); +} +.tiny-numeric__input-inner::-moz-placeholder { + color: var(--ti-numeric-input-placeholder-color); + opacity: 1; +} +.tiny-numeric__input-inner:-ms-input-placeholder { + color: var(--ti-numeric-input-placeholder-color); +} +.tiny-numeric__input-inner::-webkit-input-placeholder { + color: var(--ti-numeric-input-placeholder-color); +} +.tiny-numeric__input-inner::-ms-input-placeholder { + color: var(--ti-numeric-input-placeholder-color); +} +.tiny-numeric__input-inner::placeholder { + color: var(--ti-numeric-input-placeholder-color); +} +.tiny-numeric__input-inner:hover { + border: 1px solid var(--ti-numeric-input-normal-active-border-color); +} +.tiny-numeric__input-inner:active, +.tiny-numeric__input-inner:focus { + border: 1px solid var(--ti-base-color-brand-6); +} +.tiny-numeric__input-inner:focus { + outline: 0; +} +.tiny-numeric__input-inner:focus::-moz-placeholder { + color: var(--ti-numeric-input-placeholder-color); + opacity: 1; +} +.tiny-numeric__input-inner:focus:-ms-input-placeholder { + color: var(--ti-numeric-input-placeholder-color); +} +.tiny-numeric__input-inner:focus::-webkit-input-placeholder { + color: var(--ti-numeric-input-placeholder-color); +} +.tiny-numeric__input-inner:focus::-ms-input-placeholder { + color: var(--ti-numeric-input-placeholder-color); +} +.tiny-numeric__input-inner:focus::placeholder { + color: var(--ti-numeric-input-placeholder-color); +} +.tiny-numeric__input-inner::-ms-clear { + display: none; + width: 0; + height: 0; +} +.tiny-numeric__decrease, +.tiny-numeric__increase { + position: absolute; + z-index: 1; + top: 1px; + width: 30px; + height: calc(100% - 2px); + line-height: calc(var(--ti-numeric-input-normal-height) - 2px); + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + -webkit-box-pack: center; + -ms-flex-pack: center; + justify-content: center; + font-size: var(--ti-common-font-size-1); + text-align: center; + cursor: pointer; +} +.tiny-numeric__decrease svg, +.tiny-numeric__increase svg { + fill: var(--ti-numeric-input-normal-active-border-color); +} +.tiny-numeric__decrease:hover:not(.is-disabled) ~ .tiny-numeric__input .tiny-numeric__input-inner:not(.is-disabled), +.tiny-numeric__increase:hover:not(.is-disabled) ~ .tiny-numeric__input .tiny-numeric__input-inner:not(.is-disabled) { + border-color: var(--ti-numeric-input-icon-hover-color); +} +.tiny-numeric__decrease:hover:not(.is-disabled) + ~ .tiny-numeric__input.is-disabled + .tiny-numeric__input-inner:not(.is-disabled), +.tiny-numeric__increase:hover:not(.is-disabled) + ~ .tiny-numeric__input.is-disabled + .tiny-numeric__input-inner:not(.is-disabled) { + border-color: var(--ti-numeric-input-normal-border-color); +} +.tiny-numeric__decrease:hover svg, +.tiny-numeric__increase:hover svg { + fill: var(--ti-numeric-input-icon-hover-color); +} +.tiny-numeric__decrease.is-disabled, +.tiny-numeric__increase.is-disabled { + cursor: not-allowed; +} +.tiny-numeric__decrease.is-disabled svg, +.tiny-numeric__increase.is-disabled svg { + fill: var(--ti-numeric-input-icon-disabled-color); +} +.tiny-numeric__increase { + right: 1px; + border-radius: 0 4px 4px 0; + border-left: 1px solid var(--ti-numeric-input-normal-border-color); +} +.tiny-numeric__decrease { + left: 1px; + border-radius: 4px 0 0 4px; + border-right: 1px solid var(--ti-numeric-input-normal-border-color); +} +.tiny-numeric__unit { + right: 0; + position: absolute; + z-index: 1; + top: 1px; + width: 50px; + height: calc(100% - 2px); + color: #666; + font-size: var(--ti-common-font-size-base); + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-pack: center; + -ms-flex-pack: center; + justify-content: center; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + border-left: 1px solid #d9d9d9; + margin: 0 1px 0 0; + background: #f1f1f1; +} +.tiny-numeric.is-disabled .tiny-numeric__decrease, +.tiny-numeric.is-disabled .tiny-numeric__increase { + border-color: var(--ti-numeric-input-disabled-border-color); +} +.tiny-numeric.is-disabled .tiny-numeric__decrease svg, +.tiny-numeric.is-disabled .tiny-numeric__increase svg { + fill: var(--ti-numeric-input-icon-disabled-color); +} +.tiny-numeric.is-disabled .tiny-numeric__decrease:hover, +.tiny-numeric.is-disabled .tiny-numeric__increase:hover { + cursor: not-allowed; +} +.tiny-numeric.is-disabled .tiny-numeric__decrease:hover svg, +.tiny-numeric.is-disabled .tiny-numeric__increase:hover svg { + fill: var(--ti-numeric-input-icon-disabled-color); +} +.tiny-numeric--medium { + width: 270px; +} +.tiny-numeric--medium .tiny-numeric__decrease, +.tiny-numeric--medium .tiny-numeric__increase { + width: 42px; + line-height: 40px; + font-size: var(--ti-common-font-size-2); +} +.tiny-numeric--medium .tiny-numeric__input-inner { + height: 42px; + line-height: 42px; + padding-left: 43px; + padding-right: 43px; +} +.tiny-numeric--small { + width: 200px; +} +.tiny-numeric--small .tiny-numeric__decrease, +.tiny-numeric--small .tiny-numeric__increase { + width: 36px; + line-height: 34px; + font-size: var(--ti-common-font-size-1); +} +.tiny-numeric--small .tiny-numeric__input-inner { + height: 36px; + line-height: 36px; + padding-left: 37px; + padding-right: 37px; +} +.tiny-numeric--mini { + width: 130px; +} +.tiny-numeric--mini .tiny-numeric__decrease, +.tiny-numeric--mini .tiny-numeric__increase { + width: 24px; + line-height: 20px; + font-size: var(--ti-common-font-size-base); +} +.tiny-numeric--mini .tiny-numeric__input-inner { + height: 24px; + line-height: 24px; + padding-left: 35px; + padding-right: 35px; +} +.tiny-numeric.is-without-controls .tiny-numeric__input-inner { + padding-left: 8px; + padding-right: 8px; +} +.tiny-numeric.is-without-controls .tiny-numeric__input.has-unit .tiny-numeric__input-inner { + padding: 0 50px 0 8px; +} +.tiny-numeric.is-without-controls .tiny-numeric__input.text-align-left .tiny-numeric__input-inner { + text-align: left; +} +.tiny-numeric.is-controls-right .tiny-numeric__input-inner { + padding-left: 8px; + padding-right: 38px; +} +.tiny-numeric.is-controls-right .tiny-numeric__decrease, +.tiny-numeric.is-controls-right .tiny-numeric__increase { + height: auto; + line-height: 14px; +} +.tiny-numeric.is-controls-right .tiny-numeric__decrease svg, +.tiny-numeric.is-controls-right .tiny-numeric__increase svg { + -webkit-transform: scale(0.8); + transform: scale(0.8); +} +.tiny-numeric.is-controls-right .tiny-numeric__increase { + border-radius: 0 4px 0 0; + border-bottom: 1px solid var(--ti-numeric-input-normal-border-color); +} +.tiny-numeric.is-controls-right .tiny-numeric__decrease { + right: 1px; + bottom: 1px; + top: auto; + left: auto; + border-right: none; + border-left: 1px solid var(--ti-numeric-input-normal-border-color); + border-radius: 0 0 4px; +} +.tiny-numeric.is-controls-right .tiny-numeric__decrease svg { + -webkit-transform: scale(0.8) translateY(3px); + transform: scale(0.8) translateY(3px); +} +.tiny-numeric.is-controls-right[class*='medium'] [class*='decrease'], +.tiny-numeric.is-controls-right[class*='medium'] [class*='increase'] { + line-height: 20px; +} +.tiny-numeric.is-controls-right[class*='small'] [class*='decrease'], +.tiny-numeric.is-controls-right[class*='small'] [class*='increase'] { + line-height: 17px; +} +.tiny-numeric.is-controls-right[class*='mini'] [class*='decrease'], +.tiny-numeric.is-controls-right[class*='mini'] [class*='increase'] { + line-height: 8px; +} +.tiny-select-dropdown { + --ti-select-dropdown-item-color: var(--ti-base-color-info-normal); + --ti-select-dropdown-item-font-size: var(--ti-common-font-size-base); + --ti-select-dropdown-item-height: var(--ti-base-size-height-minor); + --ti-select-dropdown-item-disabled-color: var(--ti-base-color-placeholder); + --ti-select-dropdown-item-disabled-bgcolor: var(--ti-base-color-light); + --ti-select-dropdown-item-bgcolor: var(--ti-base-color-light); + --ti-select-dropdown-item-hover-bgcolor: var(--ti-base-color-hover-background); + --ti-select-dropdown-item-selected-bgcolor: var(--ti-base-color-selected-background); + --ti-select-dropdown-item-selected-color: var(--ti-base-color-selected-font-color); + --ti-select-dropdown-item-icon-color: var(--ti-common-color-line-normal); + --ti-select-dropdown-item-icon-font-size: var(--ti-common-font-size-2); + --ti-select-dropdown-item-icon-selected-color: var(--ti-base-color-brand-6); +} +.tiny-select-dropdown.is-multiple .tiny-select-dropdown__item.selected { + color: var(--ti-select-dropdown-item-color); + background-color: var(--ti-select-dropdown-item-bgcolor); +} +.tiny-select-dropdown__item { + position: relative; + overflow: hidden; + text-overflow: ellipsis; + white-space: nowrap; + color: var(--ti-select-dropdown-item-color); + font-size: var(--ti-select-dropdown-item-font-size); + height: var(--ti-select-dropdown-item-height); + line-height: var(--ti-select-dropdown-item-height); + cursor: pointer; +} +.tiny-select-dropdown__item.is-disabled { + color: var(--ti-select-dropdown-item-disabled-color); + cursor: not-allowed; +} +.tiny-select-dropdown__item.is-disabled:hover { + background-color: var(--ti-select-dropdown-item-disabled-bgcolor); +} +.tiny-select-dropdown__item.hover, +.tiny-select-dropdown__item:hover { + background-color: var(--ti-select-dropdown-item-hover-bgcolor); +} +.tiny-select-dropdown__item.selected { + color: var(--ti-select-dropdown-item-selected-color); + background-color: var(--ti-select-dropdown-item-selected-bgcolor); +} +.tiny-select-dropdown__item .tiny-svg { + fill: var(--ti-select-dropdown-item-icon-color); + font-size: var(--ti-select-dropdown-item-icon-font-size); + margin-right: 8px; +} +.tiny-select-dropdown__item .checked-sur.tiny-svg, +.tiny-select-dropdown__item .halfselect.tiny-svg, +.tiny-select-dropdown__item.hover .tiny-svg, +.tiny-select-dropdown__item.selected .tiny-svg { + fill: var(--ti-select-dropdown-item-icon-selected-color); +} +.tiny-select-dropdown__item.memorize-highlight { + color: var(--ti-select-dropdown-item-icon-selected-color); +} +.tiny-select-group { + --ti-select-group-wrap-background: #e4e7ed; + --ti-select-group-title-font-size: var(--ti-common-font-size-base); + --ti-select-group-title-color: #909399; + --ti-select-group-title-line-height: var(--ti-base-size-height-minor); + margin: 0; + padding: 0; +} +.tiny-select-group__wrap { + position: relative; + list-style: none; + margin: 0; + padding: 0; +} +.tiny-select-group__wrap:not(:last-of-type) { + padding-bottom: 24px; +} +.tiny-select-group__wrap:not(:last-of-type)::after { + content: ''; + position: absolute; + display: block; + left: 8px; + right: 8px; + bottom: 12px; + height: 1px; + background: var(--ti-select-group-wrap-background); +} +.tiny-select-group__wrap .tiny-select-group__title { + padding-left: 8px; + font-size: var(--ti-select-group-title-font-size); + color: var(--ti-select-group-title-color); + line-height: var(--ti-select-group-title-line-height); +} +.tiny-pager { + --ti-pager-normal-color: var(--ti-base-color-info-normal); + --ti-pager-primary-color: var(--ti-base-color-brand-6); + --ti-pager-primary-hover-color: var(--ti-base-color-brand-5); + --ti-pager-input-border-color: var(--ti-base-color-border); + --ti-pager-input-hover-border-color: var(--ti-common-color-line-hover); + --ti-pager-input-color-disabled: var(--ti-base-color-common-2); + --ti-pager-input-color-hover: var(--ti-base-color-brand-6); + --ti-pager-font-size: var(--ti-common-font-size-base); + --ti-pager-font-color: var(--ti-common-color-text-secondary); + --ti-pager-font-normal: var(--ti-base-color-secondary); + --ti-pager-height: var(--ti-base-size-height-mini); + --ti-pager-input-width: 40px; + --ti-pager-list-padding: 0 6px; + --ti-pager-list-light-shadow: none; + --ti-pager-input-height: var(--ti-base-size-height-mini); + --ti-pager-input-border-radius: var(--ti-common-border-radius-normal); + --ti-pager-poplist-item-hover-bgcolor: var(--ti-base-color-hover-background); + --ti-pager-poplist-item-hover-text-color: var(--ti-common-color-text-highlight); + --ti-pager-poplist-item-selected-bgcolor: var(--ti-common-color-bg-emphasize); + --ti-pager-poplist-item-hover-border: 1px solid transparent; + text-align: left; + padding: 12px 0; + color: var(--ti-pager-font-color); +} +.tiny-pager .tiny-pager__group { + display: inline-block; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + vertical-align: middle; + font-size: var(--ti-pager-font-size); +} +.tiny-pager .tiny-pager__group > span { + display: inline-block; + vertical-align: middle; +} +.tiny-pager .tiny-pager__total { + height: 24px; + line-height: 24px; + font-size: 12px; + color: var(--ti-pager-normal-color); +} +.tiny-pager .tiny-pager__pages { + display: -webkit-inline-box; + display: -ms-inline-flexbox; + display: inline-flex; + font-size: var(--ti-pager-font-size); +} +.tiny-pager .tiny-pager__pages li { + background: 0 0; + display: inline-block; + font-size: var(--ti-pager-font-size); + cursor: pointer; + margin-right: 4px; + text-align: center; + line-height: var(--ti-pager-height); + border-radius: var(--ti-pager-input-border-radius); + height: var(--ti-pager-height); + color: var(--ti-pager-font-color); + padding: var(--ti-pager-list-padding); + -webkit-box-sizing: border-box; + box-sizing: border-box; + border: 1px solid transparent; + -webkit-transition: all 0.5s ease; + transition: all 0.5s ease; +} +.tiny-pager .tiny-pager__pages li a { + color: var(--ti-pager-font-color); +} +.tiny-pager .tiny-pager__pages li svg { + fill: var(--ti-pager-font-color); + vertical-align: middle; +} +.tiny-pager .tiny-pager__pages li:not(.dot):not(.is-active):hover { + color: var(--ti-pager-poplist-item-hover-text-color); + background-color: var(--ti-pager-poplist-item-hover-bgcolor); + -webkit-box-shadow: var(--ti-pager-list-light-shadow); + box-shadow: var(--ti-pager-list-light-shadow); + border: var(--ti-pager-poplist-item-hover-border); +} +.tiny-pager .tiny-pager__pages li:not(.dot):not(.is-active):hover svg { + fill: var(--ti-pager-poplist-item-hover-text-color); +} +.tiny-pager .tiny-pager__pages li.dot .icon { + font-size: 14px; +} +.tiny-pager .tiny-pager__pages li.is-active { + color: #fff; + background-color: var(--ti-pager-primary-color); +} +.tiny-pager__goto { + font-size: 0; +} +.tiny-pager__goto input[type='text'] { + width: var(--ti-pager-input-width); + text-align: center; + vertical-align: middle; + border-radius: var(--ti-pager-input-border-radius); + display: inline-block; + position: inherit; + height: var(--ti-pager-input-height); + line-height: var(--ti-pager-input-height); + border: 1px solid var(--ti-pager-input-border-color); + color: var(--ti-pager-normal-color); + font-size: var(--ti-pager-font-size); + -webkit-transition: border 0.3s; + transition: border 0.3s; + outline: 0; + -webkit-box-sizing: border-box; + box-sizing: border-box; + margin-left: 14px; + margin-right: 4px; +} +.tiny-pager__goto input[type='text']:hover { + border: 1px solid var(--ti-pager-input-hover-border-color); + color: var(--ti-pager-normal-color); +} +.tiny-pager__goto input[type='text'].active, +.tiny-pager__goto input[type='text']:active, +.tiny-pager__goto input[type='text']:focus, +.tiny-pager__goto input[type='text'][active] { + border: 1px solid var(--ti-pager-primary-color); + -webkit-box-shadow: 0 0 0 transparent; + box-shadow: 0 0 0 transparent; +} +.tiny-pager__goto button { + height: var(--ti-pager-input-height); + line-height: var(--ti-pager-input-height); + border: 1px solid #d9d9d9; + color: var(--ti-pager-font-color); + vertical-align: middle; + border-radius: var(--ti-pager-input-border-radius); + background: #fff; + font-size: var(--ti-pager-font-size); + padding: 0 8px; + text-align: center; + display: inline-block; + -webkit-box-sizing: border-box; + box-sizing: border-box; + white-space: nowrap; + overflow: hidden; + text-overflow: ellipsis; + cursor: pointer; + -webkit-transition: border 0.3s, color 0.3s, background 0.3s; + transition: border 0.3s, color 0.3s, background 0.3s; + outline: 0; + -ms-user-select: none; + -webkit-user-select: none; + -o-user-select: none; + -moz-user-select: none; + user-select: none; +} +.tiny-pager__btn-next, +.tiny-pager__btn-prev { + height: var(--ti-pager-height); + width: 24px; + line-height: var(--ti-pager-height); + display: -webkit-inline-box; + display: -ms-inline-flexbox; + display: inline-flex; + -webkit-box-pack: center; + -ms-flex-pack: center; + justify-content: center; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + font-size: var(--ti-pager-font-size); + font-weight: bolder; + color: var(--ti-pagination-prev-next-color); + outline: 0; + border: none; + background: 0 0; + margin-left: 4px; + padding: 0; + vertical-align: middle; + cursor: pointer; +} +.tiny-pager__btn-next span, +.tiny-pager__btn-prev span { + color: var(--ti-pager-primary-color); +} +.tiny-pager__btn-next svg, +.tiny-pager__btn-prev svg { + fill: var(--ti-pager-normal-color); + font-size: var(--ti-pager-font-size); + vertical-align: middle; +} +.tiny-pager__btn-next:hover, +.tiny-pager__btn-prev:hover { + background-color: var(--ti-pager-poplist-item-hover-bgcolor); +} +.tiny-pager__btn-next:hover svg, +.tiny-pager__btn-prev:hover svg { + fill: var(--ti-pager-poplist-item-hover-text-color); +} +.tiny-pager__btn-next[disabled], +.tiny-pager__btn-next[disabled]:hover, +.tiny-pager__btn-prev[disabled], +.tiny-pager__btn-prev[disabled]:hover { + background-color: transparent; + cursor: not-allowed; +} +.tiny-pager__btn-next[disabled] span, +.tiny-pager__btn-prev[disabled] span { + color: var(--ti-pagination-text-color-disabled); +} +.tiny-pager__btn-next[disabled] svg, +.tiny-pager__btn-prev[disabled] svg { + fill: var(--ti-pagination-text-color-disabled); +} +.tiny-pager__selector.tiny-popover.tiny-popper { + width: 60px; + padding: 0; +} +.tiny-pager__selector.tiny-popover.tiny-popper[x-placement^='bottom'] { + margin-top: 2px; +} +.tiny-pager__selector.tiny-popover.tiny-popper[x-placement^='top'] { + margin-bottom: 0; +} +.tiny-pager__selector-body { + max-height: 300px; + overflow-y: auto; + overflow-x: hidden; +} +.tiny-pager__selector-poplist .list-item { + min-height: 30px; + padding: 0 8px; + line-height: 30px; + max-width: 100%; + overflow: hidden; + text-overflow: ellipsis; + white-space: nowrap; +} +.tiny-pager__selector-poplist .list-item:hover { + cursor: pointer; + background: var(--ti-pager-poplist-item-hover-bgcolor); + color: var(--ti-pager-poplist-item-hover-text-color); +} +.tiny-pager__selector-poplist .list-item.is-selected { + background: var(--ti-pager-poplist-item-selected-bgcolor); + color: var(--ti-pager-normal-color); +} +.tiny-pager__selector-poplist .list-item.is-selected:hover { + background: var(--ti-pager-poplist-item-selected-bgcolor); +} +.tiny-pager__selector-poplist .list-item.select-pre { + background: var(--ti-pager-poplist-item-hover-bgcolor); + color: var(--ti-pager-poplist-item-hover-text-color); +} +.tiny-pager__selector-poplist .list-item.select-pre.is-selected { + color: #fff; + background: var(--ti-pager-poplist-item-selected-bgcolor); +} +.tiny-pager .tiny-pager__popover { + margin: 0 4px 0 14px; +} +.tiny-pager .tiny-pager__sizes .tiny-pager__popover { + margin: 0; +} +.tiny-pager .tiny-pager__sizes + .tiny-pager__group { + margin: 0 16px; +} +.tiny-pager .tiny-pager__group + .tiny-pager__sizes { + margin: 0 16px; +} +.tiny-pager__input { + width: 60px; + vertical-align: middle; + position: relative; +} +.tiny-pager__input input { + width: 100%; + height: var(--ti-pager-input-height); + line-height: var(--ti-pager-input-height); + border: 1px solid var(--ti-pager-input-border-color); + color: var(--ti-pager-normal-color); + border-radius: var(--ti-pager-input-border-radius); + background: #fff; + font-size: var(--ti-pager-font-size, 12px); + padding: 0 8px; + display: block; + stop-color: var(--ti-pager-input-color-disabled); + lighting-color: var(--ti-pager-input-color-hover); + padding: 6px 10px; + white-space: nowrap; + -webkit-transition: border 0.3s; + transition: border 0.3s; + outline: 0; + -webkit-box-sizing: border-box; + box-sizing: border-box; + -ms-user-select: none; + -webkit-user-select: none; + -o-user-select: none; + -moz-user-select: none; + user-select: none; +} +.tiny-pager__input input:hover { + outline: 0; + border-color: var(--ti-pager-input-hover-border-color); +} +.tiny-pager__input input:active, +.tiny-pager__input input:focus { + outline: 0; + border-color: var(--ti-pager-input-hover-border-color); +} +.tiny-pager__input-btn { + width: 24px; + height: var(--ti-pager-height); + line-height: var(--ti-pager-height); + position: absolute; + right: 2px; + bottom: 0; + top: 0; + outline: 0; + -webkit-box-sizing: border-box; + box-sizing: border-box; + text-align: center; + overflow: hidden; + cursor: pointer; +} +.tiny-pager__input-btn svg { + font-size: var(--ti-pager-font-size); + fill: var(--ti-pager-font-normal); + vertical-align: middle; +} +.tiny-pager .tiny-popover__reference { + outline: 0; +} +@media (max-width: 768px) { + .tiny-pager { + text-align: left; + } + .tiny-pager .tiny-pager__pull-left { + float: none !important; + } +} +.dialog-pbi { + --ti-pbi-font-size-base: var(--ti-common-font-size-base); + --ti-pbi-selected-color: #138fc7; + --ti-pbi-selected-background: rgba(31, 158, 216, 0.12); + --ti-pbi-list-border-color: #ccc; +} +.dialog-pbi.tiny-dialog .dialog-body { + font-size: var(--ti-pbi-font-size-base); + font-weight: 400; +} +.dialog-pbi .tiny-selected { + color: var(--ti-pbi-selected-color); + background: var(--ti-pbi-selected-background); +} +.dialog-pbi .pbi_col { + width: 200px; + float: left; +} +.dialog-pbi .pbi_list { + height: 460px; + overflow-y: auto; + border: 1px solid var(--ti-pbi-list-border-color); + padding: 4px; +} +.tiny-dialog { + background: var(--ti-dialog-background); + padding: 0; + -webkit-box-shadow: var(--ti-dialog-shadow); + box-shadow: var(--ti-dialog-shadow); + -webkit-animation: dialog-fade-in 0.3s; + animation: dialog-fade-in 0.3s; +} +.tiny-dialog .dialog-head { + background: var(--ti-dialog-head-background); + font-size: var(--ti-dialog-head-font-size); +} +.tiny-dialog .dialog-head .dialog-title { + color: var(--ti-dialog-title-color); + display: inline-block; + font-size: var(--ti-dialog-title-font-size); + font-weight: var(--ti-dialog-title-font-weight); + margin: 0; +} +.tiny-dialog .dialog-head .dialog-operation { + float: right; +} +.tiny-dialog .dialog-head .dialog-operation > a { + color: var(--ti-dialog-operation-color); +} +.tiny-dialog .dialog-head .dialog-operation > a:hover { + color: var(--ti-dialog-operation-hover-color); +} +.tiny-dialog .dialog-head .dialog-operation > a .tiny-small-close { + font-size: var(--ti-dialog-head-font-size); +} +.tiny-dialog .dialog-body { + width: 100%; + padding: var(--ti-dialog-body-padding); + min-height: var(--ti-dialog-body-min-height); + font-size: var(--ti-dialog-body-font-size); + font-weight: 700; + overflow: auto; + overflow-x: hidden; + color: var(--ti-dialog-body-color); + max-height: 55vh !important; +} +.tiny-dialog .dialog-head-alert-confirm { + padding: 0 24px; + height: 40px; + line-height: 40px; + border-bottom: 1px solid #d9d9d9; +} +.tiny-toolbar { + clear: both; + text-align: center; +} +.tiny-transition-timepicker { + -webkit-animation: fadein 0.3s; + animation: fadein 0.3s; +} +.tiny-transition-timepicker-up { + -webkit-animation: fadeup 0.3s; + animation: fadeup 0.3s; +} +@-webkit-keyframes fadein { + 0% { + -webkit-transform: translateY(-200px); + transform: translateY(-200px); + z-index: -999; + } + 100% { + -webkit-transform: translateY(0); + transform: translateY(0); + z-index: 0; + } +} +@keyframes fadein { + 0% { + -webkit-transform: translateY(-200px); + transform: translateY(-200px); + z-index: -999; + } + 100% { + -webkit-transform: translateY(0); + transform: translateY(0); + z-index: 0; + } +} +@-webkit-keyframes fadeup { + 0% { + -webkit-transform: translateY(200px); + transform: translateY(200px); + z-index: -999; + } + 100% { + -webkit-transform: translateY(0); + transform: translateY(0); + z-index: 0; + } +} +@keyframes fadeup { + 0% { + -webkit-transform: translateY(200px); + transform: translateY(200px); + z-index: -999; + } + 100% { + -webkit-transform: translateY(0); + transform: translateY(0); + z-index: 0; + } +} +.tiny-date-table { + font-size: var(--ti-date-picker-font-size); + -ms-user-select: none; + -webkit-user-select: none; + -o-user-select: none; + -moz-user-select: none; + user-select: none; +} +.tiny-date-table.is-week-mode .tiny-date-table__row:hover td.available:hover { + color: var(--ti-date-picker-font-color); +} +.tiny-date-table.is-week-mode .tiny-date-table__row:hover td:first-child div { + margin-left: 5px; + border-top-left-radius: var(--ti-date-table-td-border-radius); + border-bottom-left-radius: var(--ti-date-table-td-border-radius); +} +.tiny-date-table.is-week-mode .tiny-date-table__row:hover td:last-child div { + margin-right: 5px; + border-top-right-radius: var(--ti-date-table-td-border-radius); + border-bottom-right-radius: var(--ti-date-table-td-border-radius); +} +.tiny-date-table.is-week-mode .tiny-date-table__row:hover div { + background-color: var(--ti-date-picker-hover-bgcolor); +} +.tiny-date-table.is-week-mode .tiny-date-table__row.current div { + background-color: var(--ti-date-table-week-current-bgcolor); +} +.tiny-date-table.is-week-mode .tiny-date-table__row.current div:hover { + background-color: var(--ti-date-table-week-current-hover-bgcolor); +} +.tiny-date-table.is-week-mode .tiny-date-table__row.current td.available:hover span { + background-color: transparent; +} +.tiny-date-table.is-week-mode .tiny-date-table__row.current td.available.end-date span, +.tiny-date-table.is-week-mode .tiny-date-table__row.current td.available.start-date span { + background-color: var(--ti-date-picker-current-select-bgcolor); +} +.tiny-date-table td { + width: var(--ti-date-table-td-width); + height: var(--ti-date-table-td-height); + padding: var(--ti-date-table-td-padding); + -webkit-box-sizing: border-box; + box-sizing: border-box; + text-align: center; + cursor: pointer; + position: relative; +} +.tiny-date-table td div { + height: 24px; + min-width: 36px; + padding: 3px 0; + -webkit-box-sizing: border-box; + box-sizing: border-box; +} +.tiny-date-table td span { + min-width: var(--ti-date-table-td-span-width); + height: var(--ti-date-table-td-span-height); + line-height: var(--ti-date-table-td-span-height); + display: block; + margin: 0 auto; + position: absolute; + left: 50%; + top: 5px; + -webkit-transform: translateX(-50%); + transform: translateX(-50%); +} +.tiny-date-table td.next-month, +.tiny-date-table td.pre-month { + color: var(--ti-date-table-td-pre-month-color); + cursor: pointer; +} +.tiny-date-table td.next-month span:hover, +.tiny-date-table td.pre-month span:hover { + background: var(--ti-datetime-beside-day-bg-color-hover); +} +.tiny-date-table td.today { + position: relative; + color: var(--ti-date-table-td-today-color); +} +.tiny-date-table td.today:after { + content: ''; + width: 12px; + height: 1px; + background: var(--ti-date-table-td-today-border-color); + position: absolute; + left: 0; + right: 0; + margin: auto; + bottom: 5px; +} +.tiny-date-table td.today.end-date span, +.tiny-date-table td.today.start-date span { + color: var(--ti-date-table-td-nomal-color); +} +.tiny-date-table td.available:hover span { + background-color: var(--ti-date-picker-hover-bgcolor); + border-radius: var(--ti-date-picker-current-border-radius); +} +.tiny-date-table td.current:not(.disabled) span { + color: var(--ti-date-table-td-nomal-color); + background-color: var(--ti-date-picker-current-select-bgcolor); + border-radius: var(--ti-date-picker-current-border-radius); +} +.tiny-date-table td.end-date div, +.tiny-date-table td.start-date div { + color: var(--ti-date-table-td-nomal-color); +} +.tiny-date-table td.end-date span, +.tiny-date-table td.start-date span { + background-color: var(--ti-date-picker-current-select-bgcolor); +} +.tiny-date-table td.start-date div { + margin-left: 5px; + border-top-left-radius: var(--ti-date-table-td-border-radius); + border-bottom-left-radius: var(--ti-date-table-td-border-radius); +} +.tiny-date-table td.end-date div { + margin-right: 5px; + border-top-right-radius: var(--ti-date-table-td-border-radius); + border-bottom-right-radius: var(--ti-date-table-td-border-radius); +} +.tiny-date-table td.disabled div { + background-color: var(--ti-date-picker-disabled-bgcolor); + opacity: 1; + cursor: not-allowed; + color: var(--ti-date-picker-disabled-color); +} +.tiny-date-table td.in-range div { + background-color: var(--ti-date-picker-range-bgcolor); +} +.tiny-date-table td.in-range div:hover { + background-color: var(--ti-date-picker-range-hover-bgcolor); +} +.tiny-date-table td.in-range.end-date:hover span, +.tiny-date-table td.in-range.start-date:hover span { + background-color: var(--ti-date-picker-current-select-bgcolor); +} +.tiny-date-table td.available { + padding: 0; +} +.tiny-date-table td.selected div { + margin-left: 5px; + margin-right: 5px; + background-color: var(--ti-date-table-td-range-bgcolor); +} +.tiny-date-table td.selected div:hover { + background-color: var(--ti-date-table-td-range-bgcolor); +} +.tiny-date-table td.selected span { + background-color: var(--ti-date-picker-current-select-bgcolor); + color: var(--ti-date-table-td-nomal-color); + border: none; +} +.tiny-date-table td.selected.available:hover span { + background-color: var(--ti-date-picker-current-select-bgcolor); +} +.tiny-date-table td.week { + font-size: 80%; + color: var(--ti-date-picker-font-color); +} +.tiny-date-table th { + color: var(--ti-date-table-th-font-color); + font-weight: 400; +} +.tiny-month-table { + font-size: var(--ti-date-picker-font-size); + margin: -1px; + border-collapse: collapse; +} +.tiny-month-table td { + text-align: center; + padding: 16px 0; + cursor: pointer; +} +.tiny-month-table td div { + height: 32px; + -webkit-box-sizing: border-box; + box-sizing: border-box; +} +.tiny-month-table td.today .cell { + color: var(--ti-month-table-td-color); + font-weight: 700; +} +.tiny-month-table td.today.end-date .cell, +.tiny-month-table td.today.start-date .cell { + color: var(--ti-month-table-td-date-color); +} +.tiny-month-table td.disabled .cell { + background-color: var(--ti-date-picker-disabled-bgcolor); + cursor: not-allowed; + color: var(--ti-date-picker-disabled-color); +} +.tiny-month-table td.disabled .cell:hover { + color: var(--ti-date-picker-disabled-color); +} +.tiny-month-table td .cell { + width: 100%; + height: 32px; + line-height: 32px; + display: block; + color: var(--ti-date-picker-font-color); +} +.tiny-month-table td .cell:hover { + background: var(--ti-date-picker-hover-bgcolor); +} +.tiny-month-table td.in-range div, +.tiny-month-table td.in-range div:hover { + background-color: var(--ti-month-table-td-range-bgcolor); +} +.tiny-month-table td.end-date div, +.tiny-month-table td.start-date div { + color: var(--ti-month-table-td-date-color); +} +.tiny-month-table td.end-date .cell, +.tiny-month-table td.start-date .cell { + color: var(--ti-month-table-td-date-color); + background-color: var(--ti-month-table-td-color); +} +.tiny-month-table td:not(.in-range) { + padding: 16px 4px; +} +.tiny-month-table td:not(.in-range) div { + height: auto; + padding: 0; +} +.tiny-month-table td:not(.in-range) .cell { + width: auto; + height: 32px; + line-height: 32px; + border-radius: 2px; +} +.tiny-month-table td.current:not(.disabled) .cell, +.tiny-month-table td.current:not(.disabled) .cell:hover { + color: var(--ti-date-table-td-nomal-color); + background: var(--ti-month-table-td-color); +} +.tiny-year-table { + font-size: var(--ti-date-picker-font-size); + margin: -1px; + border-collapse: collapse; +} +.tiny-year-table td { + text-align: center; + cursor: pointer; +} +.tiny-year-table td.today .cell { + color: var(--ti-year-table-td-color); + font-weight: 700; +} +.tiny-year-table td.disabled .cell { + background-color: var(--ti-date-picker-disabled-bgcolor); + cursor: not-allowed; + color: var(--ti-date-picker-disabled-color); +} +.tiny-year-table td.disabled .cell:hover { + color: var(--ti-date-picker-disabled-color); +} +.tiny-year-table td .cell { + width: 48px; + height: 24px; + line-height: 24px; + display: block; + color: var(--ti-date-picker-font-color); + margin: 0 auto; + border-radius: 2px; +} +.tiny-year-table td .cell:hover { + background: var(--ti-date-picker-hover-bgcolor); +} +.tiny-year-table td.current:not(.disabled) .cell { + color: var(--ti-date-table-td-nomal-color); + background: var(--ti-date-picker-current-select-bgcolor); +} +.tiny-year-table td.available { + padding: 16px 3px; +} +.tiny-year-table .tiny-icon { + color: var(--ti-year-table-td-icon-color); +} +.tiny-time-spinner__wrapper { + max-height: 190px; + overflow: auto; + display: inline-block; + width: 50%; + vertical-align: top; + position: relative; +} +.tiny-time-spinner__wrapper .tiny-scrollbar__wrap:not(.tiny-scrollbar__wrap--hidden-default) { + padding-bottom: 15px; +} +.tiny-time-spinner__wrapper.is-arrow { + -webkit-box-sizing: border-box; + box-sizing: border-box; + text-align: center; + overflow: hidden; +} +.tiny-time-spinner__wrapper.is-arrow .tiny-time-spinner__list { + -webkit-transform: translateY(-32px); + transform: translateY(-32px); +} +.tiny-time-spinner__wrapper.is-arrow .tiny-time-spinner__item:hover:not(.disabled):not(.active) { + background: var(--ti-date-picker-bgcolor); + cursor: default; +} +.tiny-time-spinner__wrapper .tiny-time-spinner__list { + -webkit-transform: translateY(-6px); + transform: translateY(-6px); +} +.tiny-time-spinner__wrapper:last-child .tiny-time-spinner__list { + border-right: 0; +} +.tiny-time-spinner__arrow { + font-size: var(--ti-date-picker-font-size); + color: var(--ti-time-spinner-arrow-color); + height: 30px; + line-height: 30px; + position: absolute; + left: 0; + width: 100%; + z-index: 1; + text-align: center; + cursor: pointer; +} +.tiny-time-spinner__arrow .tiny-svg { + fill: var(--ti-time-spinner-arrow-color); +} +.tiny-time-spinner__arrow:hover .tiny-svg { + fill: var(--ti-time-spinner-arrow-hover-color); +} +.tiny-time-spinner__arrow.tiny-icon-arrow-up { + top: 10px; +} +.tiny-time-spinner__arrow.tiny-icon-arrow-down { + bottom: 10px; +} +.tiny-time-spinner__arrow.tiny-input { + width: 70%; +} +.tiny-time-spinner__arrow.tiny-input .tiny-input__inner { + padding: 0; + text-align: center; +} +.tiny-time-spinner__list { + padding: 0; + margin: 0; + list-style: none; + text-align: center; + border-right: 1px solid var(--ti-time-spinner-list-border-color); +} +.tiny-time-spinner__list::after, +.tiny-time-spinner__list::before { + content: ''; + display: block; + width: 100%; + height: 80px; +} +.tiny-time-spinner__item { + font-size: var(--ti-date-picker-font-size); + color: var(--ti-date-picker-font-color); + height: 32px; + line-height: 32px; +} +.tiny-time-spinner__item:hover:not(.disabled):not(.active) { + background: var(--ti-date-picker-selected-bgcolor); + cursor: pointer; +} +.tiny-time-spinner__item.active:not(.disabled) { + color: var(--ti-time-spinner-item-active-color); + font-weight: var(--ti-time-spinner-item-font-weight); + background-color: var(--ti-time-spinner-item-bgcolor); +} +.tiny-time-spinner__item.disabled { + color: var(--ti-date-picker-disabled-color); + cursor: not-allowed; +} +.tiny-time-spinner.has-seconds .tiny-time-spinner__wrapper { + width: 33.3%; +} +.tiny-date-editor { + --ti-date-picker-width: 280px; + --ti-date-picker-font-size: var(--ti-common-font-size-base); + --ti-date-picker-font-color: var(--ti-base-color-info-normal); + --ti-date-picker-bgcolor: var(--ti-base-color-light); + --ti-date-picker-border-radius: var(--ti-common-border-radius-normal); + --ti-date-picker-border-color: var(--ti-common-color-line-dividing); + --ti-date-picker-hover-bgcolor: var(--ti-base-color-brand-2); + --ti-date-picker-disabled-color: var(--ti-common-color-text-disabled); + --ti-date-picker-disabled-bgcolor: var(--ti-common-color-bg-disabled); + --ti-date-picker-selected-bgcolor: #f2f2f3; + --ti-date-picker-icon-font-size: var(--ti-common-font-size-1); + --ti-date-picker-current-select-bgcolor: var(--ti-base-color-brand-6); + --ti-date-picker-current-border-color: var(--ti-base-color-brand-6); + --ti-date-picker-current-border-radius: 0; + --ti-date-picker-range-bgcolor: var(--ti-base-color-brand-2); + --ti-date-picker-range-hover-bgcolor: var(--ti-base-color-brand-2); + --ti-date-table-td-width: 36px; + --ti-date-table-td-height: 34px; + --ti-date-table-td-padding: 4px 0; + --ti-date-table-td-span-width: 36px; + --ti-date-table-td-span-height: 24px; + --ti-date-table-th-font-color: var(--ti-base-color-common-2); + --ti-date-table-td-border-radius: 0; + --ti-date-table-td-pre-month-color: var(--ti-base-color-common-2); + --ti-date-table-td-nomal-color: var(--ti-base-color-light); + --ti-date-table-td-range-bgcolor: #f2f6fc; + --ti-date-table-td-today-border-color: var(--ti-base-color-brand-6); + --ti-date-table-td-today-color: var(--ti-date-picker-font-color); + --ti-date-table-week-current-bgcolor: var(--ti-base-color-brand-2); + --ti-date-table-week-current-hover-bgcolor: var(--ti-base-color-brand-3); + --ti-month-table-td-color: var(--ti-base-color-brand-7); + --ti-month-table-td-range-bgcolor: #f2f6fc; + --ti-month-table-td-date-color: var(--ti-base-color-light); + --ti-month-table-td-date-border-radius: 24px; + --ti-year-table-td-color: var(--ti-base-color-brand-7); + --ti-year-table-td-icon-color: #303133; + --ti-time-spinner-arrow-color: #909399; + --ti-time-spinner-arrow-hover-color: var(--ti-base-color-brand-7); + --ti-time-spinner-item-active-color: #303133; + --ti-time-spinner-item-font-weight: 700; + --ti-time-spinner-item-bgcolor: transparent; + --ti-time-spinner-list-border-color: transparent; + --ti-picker-panel-line-height: var(--ti-base-size-height-minor); + --ti-picker-panel-shortcut-font-size: var(--ti-common-font-size-1); + --ti-picker-panel-icon-btn-color: var(--ti-base-color-common-2); + --ti-picker-panel-icon-btn-hover-color: var(--ti-base-color-brand-7); + --ti-picker-panel-icon-btn-disabled-color: var(--ti-base-color-bg-5); + --ti-picker-panel-border-color: rgba(0, 0, 0, 0.15); + --ti-picker-panel-box-shadow: 2px 3px 7px rgba(0, 0, 0, 0.15); + --ti-date-picker-header-label-hover-color: var(--ti-base-color-brand-7); + --ti-date-range-picker-header-font-size: var(--ti-common-font-size-2); + --ti-date-range-picker-time-header-icon-color: #303133; + --ti-time-range-picker-header-font-size: var(--ti-common-font-size-1); + --ti-time-panel-footer-height: 36px; + --ti-time-panel-btn-color: #303133; + --ti-time-panel-btn-confirm-color: var(--ti-base-color-brand-7); + --ti-range-separator-color: #303133; + --ti-time-panel-border-color: var(--ti-date-picker-border-color); + --ti-time-panel-box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.1); + --ti-time-panel-content-split-line-display: block; + --ti-time-panel-btn-cancel-display: inline-block; + --ti-time-panel-btn-bgcolor: transparent; + --ti-time-panel-btn-padding: 0 5px; + --ti-time-panel-btn-radius: var(--ti-common-border-radius-normal); + --ti-time-panel-btn-height: 28px; + --ti-time-panel-btn-min-width: inherit; + --ti-time-panel-btn-font-weight: 800; + --ti-time-panel-btn-confirm-hover-bgcolor: transparent; + --ti-date-editor-input-icon-fill-color: #575d6c; + position: relative; + display: inline-block; + text-align: left; +} +.tiny-date-editor.tiny-input, +.tiny-date-editor.tiny-input__inner { + width: 100%; +} +.tiny-date-editor--monthrange.tiny-input, +.tiny-date-editor--monthrange.tiny-input__inner { + width: 300px; +} +.tiny-date-editor--daterange.tiny-input, +.tiny-date-editor--daterange.tiny-input__inner, +.tiny-date-editor--timerange.tiny-input, +.tiny-date-editor--timerange.tiny-input__inner { + width: 350px; +} +.tiny-date-editor--datetimerange.tiny-input, +.tiny-date-editor--datetimerange.tiny-input__inner { + width: 400px; +} +.tiny-date-editor--dates .tiny-input__inner { + overflow: hidden; + text-overflow: ellipsis; + white-space: nowrap; +} +.tiny-date-editor .tiny-input__icon { + cursor: pointer; + fill: var(--ti-date-editor-input-icon-fill-color); +} +.tiny-date-editor .tiny-input__icon .baseClearicon { + margin-right: 8px; + fill: #252b3a; +} +.tiny-date-editor .tiny-input__icon .baseClearicon:hover { + fill: var(--ti-input-clear-color-hover); +} +.tiny-date-editor .tiny-input__icon:not(.tiny-range__icon) { + display: -webkit-box; + display: -ms-flexbox; + display: flex; +} +.tiny-date-editor .tiny-range__icon { + font-size: var(--ti-date-picker-icon-font-size); + color: #c0c4cc; + margin-left: -5px; + float: left; + line-height: 1; +} +.tiny-date-editor .tiny-range-input, +.tiny-date-editor .tiny-range-separator { + font-size: var(--ti-date-picker-font-size); + height: 100%; + margin: 0; + text-align: center; + display: inline-block; +} +.tiny-date-editor .tiny-range-input { + -webkit-appearance: none; + -moz-appearance: none; + appearance: none; + border: none; + outline: 0; + padding: 0; + width: 39%; + color: var(--ti-date-picker-font-color); + overflow: hidden; + text-overflow: ellipsis; + white-space: nowrap; +} +.tiny-date-editor .tiny-range-input::-moz-placeholder { + color: #999; + opacity: 1; +} +.tiny-date-editor .tiny-range-input:-ms-input-placeholder { + color: #999; +} +.tiny-date-editor .tiny-range-input::-webkit-input-placeholder { + color: #999; +} +.tiny-date-editor .tiny-range-input::-ms-input-placeholder { + color: #999; +} +.tiny-date-editor .tiny-range-input::placeholder { + color: #999; +} +.tiny-date-editor .tiny-range-separator { + padding: 0 5px; + line-height: 22px; + width: 12%; + color: var(--ti-range-separator-color); +} +.tiny-date-editor .tiny-range__close-icon { + font-size: var(--ti-date-picker-icon-font-size); + width: 25px; + float: right; + line-height: 32px; + margin-right: 14px; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-pack: center; + -ms-flex-pack: center; + justify-content: center; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; +} +.tiny-date-editor .tiny-range__close-icon, +.tiny-date-editor .tiny-range__close-icon:hover { + fill: var(--ti-input-icon-close-color); +} +.tiny-range-editor.tiny-input__inner { + display: -webkit-inline-box; + display: -ms-inline-flexbox; + display: inline-flex; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + padding: 3px 10px; +} +.tiny-range-editor .tiny-range-input { + line-height: 1; +} +.tiny-range-editor.is-active, +.tiny-range-editor.is-active:hover { + border-color: var(--ti-date-picker-current-border-color); +} +.tiny-range-editor--medium.tiny-input__inner { + height: 42px; +} +.tiny-range-editor--medium .tiny-range-separator { + line-height: 34px; + font-size: var(--ti-common-font-size-2); +} +.tiny-range-editor--medium .tiny-range-input { + font-size: var(--ti-common-font-size-2); +} +.tiny-range-editor--medium .tiny-range__close-icon, +.tiny-range-editor--medium .tiny-range__icon { + line-height: 34px; +} +.tiny-range-editor--small.tiny-input__inner { + height: 36px; +} +.tiny-range-editor--small .tiny-range-separator { + line-height: 28px; + font-size: var(--ti-common-font-size-1); +} +.tiny-range-editor--small .tiny-range-input { + font-size: var(--ti-common-font-size-1); +} +.tiny-range-editor--small .tiny-range__close-icon, +.tiny-range-editor--small .tiny-range__icon { + line-height: 28px; +} +.tiny-range-editor--mini.tiny-input__inner { + height: 24px; +} +.tiny-range-editor--mini .tiny-range-separator { + line-height: 16px; + font-size: var(--ti-common-font-size-base); +} +.tiny-range-editor--mini .tiny-range-input { + font-size: var(--ti-common-font-size-base); +} +.tiny-range-editor--mini .tiny-range__close-icon, +.tiny-range-editor--mini .tiny-range__icon { + line-height: 16px; +} +.tiny-range-editor.is-disabled { + background-color: var(--ti-date-picker-disabled-bgcolor); + border-color: var(--ti-date-picker-border-color); + color: var(--ti-date-picker-disabled-color); + cursor: not-allowed; +} +.tiny-range-editor.is-disabled:focus, +.tiny-range-editor.is-disabled:hover { + border-color: var(--ti-date-picker-border-color); +} +.tiny-range-editor.is-disabled input { + color: var(--ti-date-picker-disabled-color); + background-color: var(--ti-date-picker-disabled-bgcolor); + cursor: not-allowed; +} +.tiny-range-editor.is-disabled input::-moz-placeholder { + color: #999; + opacity: 1; +} +.tiny-range-editor.is-disabled input:-ms-input-placeholder { + color: #999; +} +.tiny-range-editor.is-disabled input::-webkit-input-placeholder { + color: #999; +} +.tiny-range-editor.is-disabled input::-ms-input-placeholder { + color: #999; +} +.tiny-range-editor.is-disabled input::placeholder { + color: #999; +} +.tiny-range-editor.is-disabled .tiny-range-separator { + color: var(--ti-date-picker-disabled-color); +} +.tiny-picker-panel { + --ti-date-picker-width: 280px; + --ti-date-picker-font-size: var(--ti-common-font-size-base); + --ti-date-picker-font-color: var(--ti-base-color-info-normal); + --ti-date-picker-bgcolor: var(--ti-base-color-light); + --ti-date-picker-border-radius: var(--ti-common-border-radius-normal); + --ti-date-picker-border-color: var(--ti-common-color-line-dividing); + --ti-date-picker-hover-bgcolor: var(--ti-base-color-brand-2); + --ti-date-picker-disabled-color: var(--ti-common-color-text-disabled); + --ti-date-picker-disabled-bgcolor: var(--ti-common-color-bg-disabled); + --ti-date-picker-selected-bgcolor: #f2f2f3; + --ti-date-picker-icon-font-size: var(--ti-common-font-size-1); + --ti-date-picker-current-select-bgcolor: var(--ti-base-color-brand-6); + --ti-date-picker-current-border-color: var(--ti-base-color-brand-6); + --ti-date-picker-current-border-radius: 0; + --ti-date-picker-range-bgcolor: var(--ti-base-color-brand-2); + --ti-date-picker-range-hover-bgcolor: var(--ti-base-color-brand-2); + --ti-date-table-td-width: 36px; + --ti-date-table-td-height: 34px; + --ti-date-table-td-padding: 4px 0; + --ti-date-table-td-span-width: 36px; + --ti-date-table-td-span-height: 24px; + --ti-date-table-th-font-color: var(--ti-base-color-common-2); + --ti-date-table-td-border-radius: 0; + --ti-date-table-td-pre-month-color: var(--ti-base-color-common-2); + --ti-date-table-td-nomal-color: var(--ti-base-color-light); + --ti-date-table-td-range-bgcolor: #f2f6fc; + --ti-date-table-td-today-border-color: var(--ti-base-color-brand-6); + --ti-date-table-td-today-color: var(--ti-date-picker-font-color); + --ti-date-table-week-current-bgcolor: var(--ti-base-color-brand-2); + --ti-date-table-week-current-hover-bgcolor: var(--ti-base-color-brand-3); + --ti-month-table-td-color: var(--ti-base-color-brand-7); + --ti-month-table-td-range-bgcolor: #f2f6fc; + --ti-month-table-td-date-color: var(--ti-base-color-light); + --ti-month-table-td-date-border-radius: 24px; + --ti-year-table-td-color: var(--ti-base-color-brand-7); + --ti-year-table-td-icon-color: #303133; + --ti-time-spinner-arrow-color: #909399; + --ti-time-spinner-arrow-hover-color: var(--ti-base-color-brand-7); + --ti-time-spinner-item-active-color: #303133; + --ti-time-spinner-item-font-weight: 700; + --ti-time-spinner-item-bgcolor: transparent; + --ti-time-spinner-list-border-color: transparent; + --ti-picker-panel-line-height: var(--ti-base-size-height-minor); + --ti-picker-panel-shortcut-font-size: var(--ti-common-font-size-1); + --ti-picker-panel-icon-btn-color: var(--ti-base-color-common-2); + --ti-picker-panel-icon-btn-hover-color: var(--ti-base-color-brand-7); + --ti-picker-panel-icon-btn-disabled-color: var(--ti-base-color-bg-5); + --ti-picker-panel-border-color: rgba(0, 0, 0, 0.15); + --ti-picker-panel-box-shadow: 2px 3px 7px rgba(0, 0, 0, 0.15); + --ti-date-picker-header-label-hover-color: var(--ti-base-color-brand-7); + --ti-date-range-picker-header-font-size: var(--ti-common-font-size-2); + --ti-date-range-picker-time-header-icon-color: #303133; + --ti-time-range-picker-header-font-size: var(--ti-common-font-size-1); + --ti-time-panel-footer-height: 36px; + --ti-time-panel-btn-color: #303133; + --ti-time-panel-btn-confirm-color: var(--ti-base-color-brand-7); + --ti-range-separator-color: #303133; + --ti-time-panel-border-color: var(--ti-date-picker-border-color); + --ti-time-panel-box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.1); + --ti-time-panel-content-split-line-display: block; + --ti-time-panel-btn-cancel-display: inline-block; + --ti-time-panel-btn-bgcolor: transparent; + --ti-time-panel-btn-padding: 0 5px; + --ti-time-panel-btn-radius: var(--ti-common-border-radius-normal); + --ti-time-panel-btn-height: 28px; + --ti-time-panel-btn-min-width: inherit; + --ti-time-panel-btn-font-weight: 800; + --ti-time-panel-btn-confirm-hover-bgcolor: transparent; + --ti-date-editor-input-icon-fill-color: #575d6c; + color: var(--ti-date-picker-font-color); + font-size: var(--ti-date-picker-font-size); + border: 1px solid var(--ti-picker-panel-border-color); + -webkit-box-shadow: var(--ti-picker-panel-box-shadow); + box-shadow: var(--ti-picker-panel-box-shadow); + background: var(--ti-date-picker-bgcolor); + border-radius: var(--ti-common-border-radius-normal); + line-height: var(--ti-picker-panel-line-height); + margin: var(--ti-base-dropdown-gap) 0; +} +.tiny-picker-panel__body-wrapper::after, +.tiny-picker-panel__body::after { + content: ''; + display: table; + clear: both; +} +.tiny-picker-panel__body { + padding-bottom: 8px; +} +.tiny-picker-panel__content { + position: relative; +} +.tiny-picker-panel__footer { + border-top: 1px solid var(--ti-date-picker-border-color); + padding: 6px 16px; + background-color: var(--ti-date-picker-bgcolor); + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-pack: justify; + -ms-flex-pack: justify; + justify-content: space-between; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; +} +.tiny-picker-panel__footer .tiny-button { + min-width: 60px; +} +.tiny-picker-panel__footer .tiny-button:only-child { + float: right; +} +.tiny-picker-panel__footer .tiny-button--text { + text-align: left; +} +.tiny-picker-panel__shortcut { + display: block; + width: 100%; + border: 0; + background-color: transparent; + line-height: 28px; + font-size: var(--ti-picker-panel-shortcut-font-size); + color: var(--ti-date-picker-font-color); + padding-left: 12px; + text-align: left; + outline: 0; + cursor: pointer; +} +.tiny-picker-panel__shortcut:hover { + background-color: var(--ti-date-picker-hover-bgcolor); +} +.tiny-picker-panel__shortcut.active { + background-color: var(--ti-date-picker-selected-bgcolor); +} +.tiny-picker-panel__btn { + color: var(--ti-date-picker-font-color); + border: 1px solid var(--ti-date-picker-border-color); + font-size: var(--ti-date-picker-font-size); + line-height: 24px; + border-radius: var(--ti-date-picker-border-radius); + padding: 0 20px; + cursor: pointer; + outline: 0; + background-color: transparent; +} +.tiny-picker-panel__btn [disabled] { + color: var(--ti-date-picker-disabled-color); + cursor: not-allowed; +} +.tiny-picker-panel__icon-btn { + font-size: var(--ti-date-picker-font-size); + line-height: 30px; + fill: var(--ti-picker-panel-icon-btn-color); + border: 0; + background: 0 0; + cursor: pointer; + outline: 0; +} +.tiny-picker-panel__icon-btn:hover { + fill: var(--ti-picker-panel-icon-btn-hover-color); +} +.tiny-picker-panel__icon-btn.is-disabled { + color: var(--ti-picker-panel-icon-btn-disabled-color); +} +.tiny-picker-panel__icon-btn.is-disabled:hover { + cursor: not-allowed; +} +.tiny-picker-panel__link-btn { + vertical-align: middle; +} +.tiny-picker-panel [slot='sidebar'], +.tiny-picker-panel__sidebar { + position: absolute; + top: 0; + bottom: 0; + width: 110px; + border-right: 1px solid var(--ti-date-picker-border-color); + -webkit-box-sizing: border-box; + box-sizing: border-box; + padding-top: 6px; + background-color: var(--ti-date-picker-bgcolor); + overflow: auto; +} +.tiny-picker-panel [slot='sidebar'] + .tiny-picker-panel__body, +.tiny-picker-panel__sidebar + .tiny-picker-panel__body { + margin-left: 110px; +} +.tiny-picker-panel__timezone { + margin-bottom: 10px; +} +.tiny-picker-panel__timezone .tiny-picker-panel__tzlist { + z-index: 10; + overflow-y: hidden; +} +.tiny-picker-panel__timezone .tiny-picker-panel__tzlist-li { + height: 30px; + line-height: 30px; + white-space: nowrap; + overflow: hidden; + text-overflow: ellipsis; + padding: 0 10px; + border: 1px solid #f4f0f0; + cursor: pointer; +} +.tiny-picker-panel__timezone .tiny-picker-panel__tzlist .tiny-popup { + position: absolute; + width: 238px; + bottom: 77px; + max-height: 260px; + -webkit-box-shadow: 0 -1px 2px 0 rgba(53, 29, 29, 0.5); + box-shadow: 0 -1px 2px 0 rgba(53, 29, 29, 0.5); +} +.tiny-picker-panel__timezone .tiny-input { + position: relative; +} +.tiny-date-picker { + --ti-date-picker-width: 280px; + --ti-date-picker-font-size: var(--ti-common-font-size-base); + --ti-date-picker-font-color: var(--ti-base-color-info-normal); + --ti-date-picker-bgcolor: var(--ti-base-color-light); + --ti-date-picker-border-radius: var(--ti-common-border-radius-normal); + --ti-date-picker-border-color: var(--ti-common-color-line-dividing); + --ti-date-picker-hover-bgcolor: var(--ti-base-color-brand-2); + --ti-date-picker-disabled-color: var(--ti-common-color-text-disabled); + --ti-date-picker-disabled-bgcolor: var(--ti-common-color-bg-disabled); + --ti-date-picker-selected-bgcolor: #f2f2f3; + --ti-date-picker-icon-font-size: var(--ti-common-font-size-1); + --ti-date-picker-current-select-bgcolor: var(--ti-base-color-brand-6); + --ti-date-picker-current-border-color: var(--ti-base-color-brand-6); + --ti-date-picker-current-border-radius: 0; + --ti-date-picker-range-bgcolor: var(--ti-base-color-brand-2); + --ti-date-picker-range-hover-bgcolor: var(--ti-base-color-brand-2); + --ti-date-table-td-width: 36px; + --ti-date-table-td-height: 34px; + --ti-date-table-td-padding: 4px 0; + --ti-date-table-td-span-width: 36px; + --ti-date-table-td-span-height: 24px; + --ti-date-table-th-font-color: var(--ti-base-color-common-2); + --ti-date-table-td-border-radius: 0; + --ti-date-table-td-pre-month-color: var(--ti-base-color-common-2); + --ti-date-table-td-nomal-color: var(--ti-base-color-light); + --ti-date-table-td-range-bgcolor: #f2f6fc; + --ti-date-table-td-today-border-color: var(--ti-base-color-brand-6); + --ti-date-table-td-today-color: var(--ti-date-picker-font-color); + --ti-date-table-week-current-bgcolor: var(--ti-base-color-brand-2); + --ti-date-table-week-current-hover-bgcolor: var(--ti-base-color-brand-3); + --ti-month-table-td-color: var(--ti-base-color-brand-7); + --ti-month-table-td-range-bgcolor: #f2f6fc; + --ti-month-table-td-date-color: var(--ti-base-color-light); + --ti-month-table-td-date-border-radius: 24px; + --ti-year-table-td-color: var(--ti-base-color-brand-7); + --ti-year-table-td-icon-color: #303133; + --ti-time-spinner-arrow-color: #909399; + --ti-time-spinner-arrow-hover-color: var(--ti-base-color-brand-7); + --ti-time-spinner-item-active-color: #303133; + --ti-time-spinner-item-font-weight: 700; + --ti-time-spinner-item-bgcolor: transparent; + --ti-time-spinner-list-border-color: transparent; + --ti-picker-panel-line-height: var(--ti-base-size-height-minor); + --ti-picker-panel-shortcut-font-size: var(--ti-common-font-size-1); + --ti-picker-panel-icon-btn-color: var(--ti-base-color-common-2); + --ti-picker-panel-icon-btn-hover-color: var(--ti-base-color-brand-7); + --ti-picker-panel-icon-btn-disabled-color: var(--ti-base-color-bg-5); + --ti-picker-panel-border-color: rgba(0, 0, 0, 0.15); + --ti-picker-panel-box-shadow: 2px 3px 7px rgba(0, 0, 0, 0.15); + --ti-date-picker-header-label-hover-color: var(--ti-base-color-brand-7); + --ti-date-range-picker-header-font-size: var(--ti-common-font-size-2); + --ti-date-range-picker-time-header-icon-color: #303133; + --ti-time-range-picker-header-font-size: var(--ti-common-font-size-1); + --ti-time-panel-footer-height: 36px; + --ti-time-panel-btn-color: #303133; + --ti-time-panel-btn-confirm-color: var(--ti-base-color-brand-7); + --ti-range-separator-color: #303133; + --ti-time-panel-border-color: var(--ti-date-picker-border-color); + --ti-time-panel-box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.1); + --ti-time-panel-content-split-line-display: block; + --ti-time-panel-btn-cancel-display: inline-block; + --ti-time-panel-btn-bgcolor: transparent; + --ti-time-panel-btn-padding: 0 5px; + --ti-time-panel-btn-radius: var(--ti-common-border-radius-normal); + --ti-time-panel-btn-height: 28px; + --ti-time-panel-btn-min-width: inherit; + --ti-time-panel-btn-font-weight: 800; + --ti-time-panel-btn-confirm-hover-bgcolor: transparent; + --ti-date-editor-input-icon-fill-color: #575d6c; + width: var(--ti-date-picker-width); +} +.tiny-date-picker.has-sidebar.has-time { + width: 434px; +} +.tiny-date-picker.has-sidebar { + width: 398px; +} +.tiny-date-picker.has-time .tiny-picker-panel__body-wrapper { + position: relative; +} +.tiny-date-picker table { + table-layout: fixed; + width: 100%; +} +.tiny-date-picker__editor-wrap { + position: relative; + display: table-cell; + padding: 0 5px; +} +.tiny-date-picker__time-header { + position: relative; + border-bottom: 1px solid var(--ti-date-picker-border-color); + font-size: var(--ti-date-picker-font-size); + padding: 8px 5px 5px; + display: table; + width: 100%; + -webkit-box-sizing: border-box; + box-sizing: border-box; +} +.tiny-date-picker__header { + margin: 12px; + text-align: center; +} +.tiny-date-picker__header--bordered { + margin-bottom: 0; + padding-bottom: 12px; + border-bottom: 1px solid var(--ti-date-picker-border-color); +} +.tiny-date-picker__header--bordered + .tiny-picker-panel__content { + margin-top: 0; +} +.tiny-date-picker__header-label { + font-size: var(--ti-date-picker-font-size); + font-weight: 700; + padding: 0 4px; + text-align: center; + cursor: pointer; + color: var(--ti-date-picker-font-color); + vertical-align: middle; +} +.tiny-date-picker__header-label.active, +.tiny-date-picker__header-label:hover { + color: var(--ti-date-picker-header-label-hover-color); +} +.tiny-date-picker__prev-btn { + float: left; +} +.tiny-date-picker__next-btn { + float: right; +} +.tiny-date-picker__time-wrap { + padding: 10px; + text-align: center; +} +.tiny-date-picker__time-label { + float: left; + cursor: pointer; + line-height: 30px; + margin-left: 10px; +} +.tiny-date-range-picker { + width: 558px; +} +.tiny-date-range-picker.has-sidebar { + width: 668px; +} +.tiny-date-range-picker table { + table-layout: fixed; + width: 100%; +} +.tiny-date-range-picker .tiny-picker-panel__body { + min-width: var(--ti-date-range-picker-body-min-width); +} +.tiny-date-range-picker .tiny-picker-panel__content { + margin: 0; +} +.tiny-date-range-picker__header { + position: relative; + text-align: center; + height: 28px; +} +.tiny-date-range-picker__header [class*='arrow-left'] { + float: left; +} +.tiny-date-range-picker__header [class*='arrow-right'] { + float: right; +} +.tiny-date-range-picker__header div { + font-size: var(--ti-date-range-picker-header-font-size); + font-weight: 500; + margin-right: 50px; +} +.tiny-date-range-picker__content { + float: left; + width: 50%; + -webkit-box-sizing: border-box; + box-sizing: border-box; + margin: 0; + padding: 16px; +} +.tiny-date-range-picker__content.is-left { + border-right: 1px solid var(--ti-date-picker-border-color); +} +.tiny-date-range-picker__content .tiny-date-range-picker__header div { + margin-left: 50px; + margin-right: 50px; +} +.tiny-date-range-picker__editors-wrap { + -webkit-box-sizing: border-box; + box-sizing: border-box; + display: table-cell; +} +.tiny-date-range-picker__editors-wrap.is-right { + text-align: right; +} +.tiny-date-range-picker__time-header { + position: relative; + border-bottom: 1px solid var(--ti-date-picker-border-color); + font-size: var(--ti-date-picker-font-size); + padding: 8px 5px 5px; + display: table; + width: 100%; + -webkit-box-sizing: border-box; + box-sizing: border-box; +} +.tiny-date-range-picker__time-header > .tiny-icon-arrow-right { + font-size: var(--ti-common-font-size-4); + vertical-align: middle; + display: table-cell; + color: var(--ti-date-range-picker-time-header-icon-color); +} +.tiny-date-range-picker__time-picker-wrap { + position: relative; + display: table-cell; + padding: 0 5px; +} +.tiny-date-range-picker__time-picker-wrap .tiny-picker-panel { + position: absolute; + top: 13px; + right: 0; + z-index: 1; + background: var(--ti-date-picker-bgcolor); +} +.tiny-time-range-picker { + width: 354px; + overflow: visible; +} +.tiny-time-range-picker__content { + position: relative; + text-align: center; + padding: 10px; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-pack: start; + -ms-flex-pack: start; + justify-content: flex-start; + -webkit-box-align: start; + -ms-flex-align: start; + align-items: flex-start; +} +.tiny-time-range-picker__cell { + -webkit-box-sizing: border-box; + box-sizing: border-box; + margin: 0; + padding: 4px 7px 7px; + width: 50%; +} +.tiny-time-range-picker__header { + margin-bottom: 5px; + text-align: center; + font-size: var(--ti-time-range-picker-header-font-size); +} +.tiny-time-range-picker__body { + border-radius: var(--ti-date-picker-border-radius); + border: 1px solid var(--ti-date-picker-border-color); +} +.tiny-time-panel { + --ti-date-picker-width: 280px; + --ti-date-picker-font-size: var(--ti-common-font-size-base); + --ti-date-picker-font-color: var(--ti-base-color-info-normal); + --ti-date-picker-bgcolor: var(--ti-base-color-light); + --ti-date-picker-border-radius: var(--ti-common-border-radius-normal); + --ti-date-picker-border-color: var(--ti-common-color-line-dividing); + --ti-date-picker-hover-bgcolor: var(--ti-base-color-brand-2); + --ti-date-picker-disabled-color: var(--ti-common-color-text-disabled); + --ti-date-picker-disabled-bgcolor: var(--ti-common-color-bg-disabled); + --ti-date-picker-selected-bgcolor: #f2f2f3; + --ti-date-picker-icon-font-size: var(--ti-common-font-size-1); + --ti-date-picker-current-select-bgcolor: var(--ti-base-color-brand-6); + --ti-date-picker-current-border-color: var(--ti-base-color-brand-6); + --ti-date-picker-current-border-radius: 0; + --ti-date-picker-range-bgcolor: var(--ti-base-color-brand-2); + --ti-date-picker-range-hover-bgcolor: var(--ti-base-color-brand-2); + --ti-date-table-td-width: 36px; + --ti-date-table-td-height: 34px; + --ti-date-table-td-padding: 4px 0; + --ti-date-table-td-span-width: 36px; + --ti-date-table-td-span-height: 24px; + --ti-date-table-th-font-color: var(--ti-base-color-common-2); + --ti-date-table-td-border-radius: 0; + --ti-date-table-td-pre-month-color: var(--ti-base-color-common-2); + --ti-date-table-td-nomal-color: var(--ti-base-color-light); + --ti-date-table-td-range-bgcolor: #f2f6fc; + --ti-date-table-td-today-border-color: var(--ti-base-color-brand-6); + --ti-date-table-td-today-color: var(--ti-date-picker-font-color); + --ti-date-table-week-current-bgcolor: var(--ti-base-color-brand-2); + --ti-date-table-week-current-hover-bgcolor: var(--ti-base-color-brand-3); + --ti-month-table-td-color: var(--ti-base-color-brand-7); + --ti-month-table-td-range-bgcolor: #f2f6fc; + --ti-month-table-td-date-color: var(--ti-base-color-light); + --ti-month-table-td-date-border-radius: 24px; + --ti-year-table-td-color: var(--ti-base-color-brand-7); + --ti-year-table-td-icon-color: #303133; + --ti-time-spinner-arrow-color: #909399; + --ti-time-spinner-arrow-hover-color: var(--ti-base-color-brand-7); + --ti-time-spinner-item-active-color: #303133; + --ti-time-spinner-item-font-weight: 700; + --ti-time-spinner-item-bgcolor: transparent; + --ti-time-spinner-list-border-color: transparent; + --ti-picker-panel-line-height: var(--ti-base-size-height-minor); + --ti-picker-panel-shortcut-font-size: var(--ti-common-font-size-1); + --ti-picker-panel-icon-btn-color: var(--ti-base-color-common-2); + --ti-picker-panel-icon-btn-hover-color: var(--ti-base-color-brand-7); + --ti-picker-panel-icon-btn-disabled-color: var(--ti-base-color-bg-5); + --ti-picker-panel-border-color: rgba(0, 0, 0, 0.15); + --ti-picker-panel-box-shadow: 2px 3px 7px rgba(0, 0, 0, 0.15); + --ti-date-picker-header-label-hover-color: var(--ti-base-color-brand-7); + --ti-date-range-picker-header-font-size: var(--ti-common-font-size-2); + --ti-date-range-picker-time-header-icon-color: #303133; + --ti-time-range-picker-header-font-size: var(--ti-common-font-size-1); + --ti-time-panel-footer-height: 36px; + --ti-time-panel-btn-color: #303133; + --ti-time-panel-btn-confirm-color: var(--ti-base-color-brand-7); + --ti-range-separator-color: #303133; + --ti-time-panel-border-color: var(--ti-date-picker-border-color); + --ti-time-panel-box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.1); + --ti-time-panel-content-split-line-display: block; + --ti-time-panel-btn-cancel-display: inline-block; + --ti-time-panel-btn-bgcolor: transparent; + --ti-time-panel-btn-padding: 0 5px; + --ti-time-panel-btn-radius: var(--ti-common-border-radius-normal); + --ti-time-panel-btn-height: 28px; + --ti-time-panel-btn-min-width: inherit; + --ti-time-panel-btn-font-weight: 800; + --ti-time-panel-btn-confirm-hover-bgcolor: transparent; + --ti-date-editor-input-icon-fill-color: #575d6c; + margin: 5px 0; + border: 1px solid var(--ti-time-panel-border-color); + background-color: var(--ti-date-picker-bgcolor); + -webkit-box-shadow: var(--ti-time-panel-box-shadow); + box-shadow: var(--ti-time-panel-box-shadow); + border-radius: var(--ti-date-picker-border-radius); + position: absolute; + width: 180px; + left: 0; + z-index: 1000; + -webkit-box-sizing: content-box; + box-sizing: content-box; + -ms-user-select: none; + -webkit-user-select: none; + -o-user-select: none; + -moz-user-select: none; + user-select: none; +} +.tiny-time-panel__content { + font-size: 0; + position: relative; + overflow: hidden; +} +.tiny-time-panel__content:after, +.tiny-time-panel__content:before { + display: var(--ti-time-panel-content-split-line-display); + content: ''; + top: 50%; + position: absolute; + margin-top: -19px; + height: 32px; + z-index: -1; + left: 0; + right: 0; + -webkit-box-sizing: border-box; + box-sizing: border-box; + padding-top: 6px; + text-align: left; + border-top: 1px solid var(--ti-date-picker-border-color); + border-bottom: 1px solid var(--ti-date-picker-border-color); +} +.tiny-time-panel__content:after { + left: 50%; + margin-left: 12%; + margin-right: 12%; +} +.tiny-time-panel__content:before { + padding-left: 50%; + margin-right: 12%; + margin-left: 12%; +} +.tiny-time-panel__content.has-seconds:after { + left: calc(100% / 3 * 2); +} +.tiny-time-panel__content.has-seconds:before { + padding-left: calc(100% / 3); +} +.tiny-time-panel__footer { + border-top: 1px solid var(--ti-date-picker-border-color); + padding: 4px; + height: 36px; + height: var(--ti-time-panel-footer-height, 36px); + line-height: 25px; + text-align: right; + -webkit-box-sizing: border-box; + box-sizing: border-box; +} +.tiny-time-panel__btn { + min-width: var(--ti-time-panel-btn-min-width); + border: none; + line-height: var(--ti-time-panel-btn-height); + padding: var(--ti-time-panel-btn-padding); + margin: 0 5px; + cursor: pointer; + background-color: var(--ti-time-panel-btn-bgcolor); + outline: 0; + font-size: 12px; + color: var(--ti-time-panel-btn-color); + border-radius: var(--ti-time-panel-btn-radius); + -webkit-transition: background-color 0.3s cubic-bezier(0.645, 0.045, 0.355, 1); + transition: background-color 0.3s cubic-bezier(0.645, 0.045, 0.355, 1); +} +.tiny-time-panel__btn.cancel { + display: var(--ti-time-panel-btn-cancel-display); +} +.tiny-time-panel__btn.confirm { + font-weight: var(--ti-time-panel-btn-font-weight); + color: var(--ti-time-panel-btn-confirm-color); +} +.tiny-time-panel__btn.confirm:hover { + background-color: var(--ti-time-panel-btn-confirm-hover-bgcolor); +} +.tiny-time-select .tiny-time-select__item { + color: var(--ti-date-picker-font-color); + font-size: var(--ti-common-font-size-base); + padding: 0 8px; + line-height: var(--ti-base-size-height-normal); + height: var(--ti-base-size-height-normal); +} +.tiny-time-select .tiny-time-select__item:not(.disabled):hover { + background-color: var(--ti-date-picker-hover-bgcolor); + cursor: pointer; +} +.tiny-time-select .tiny-time-select__item.selected:not(.disabled) { + background-color: var(--ti-date-picker-selected-bgcolor); +} +.tiny-time-select .tiny-time-select__item.disabled { + color: var(--ti-date-picker-disabled-color); + cursor: not-allowed; +} +.tiny-scrollbar { + overflow: hidden; + position: relative; +} +.tiny-scrollbar:active > .tiny-scrollbar__bar, +.tiny-scrollbar:focus > .tiny-scrollbar__bar, +.tiny-scrollbar:hover > .tiny-scrollbar__bar { + opacity: 1; + -webkit-transition: opacity 340ms ease-out; + transition: opacity 340ms ease-out; +} +.tiny-scrollbar__wrap { + overflow: scroll; + height: 100%; +} +.tiny-scrollbar__wrap--hidden-default::-webkit-scrollbar { + width: 0; + height: 0; +} +.tiny-scrollbar__thumb { + position: relative; + display: block; + width: 0; + height: 0; + cursor: pointer; + border-radius: inherit; + background-color: rgba(144, 147, 153, 0.3); + -webkit-transition: 0.3s background-color; + transition: 0.3s background-color; +} +.tiny-scrollbar__thumb:hover { + background-color: rgba(144, 147, 153, 0.5); +} +.tiny-scrollbar__bar { + position: absolute; + right: 2px; + bottom: 2px; + z-index: 1; + border-radius: 4px; + opacity: 0; + -webkit-transition: opacity 120ms ease-out; + transition: opacity 120ms ease-out; +} +.tiny-scrollbar__bar.is-vertical { + width: 6px; + top: 2px; +} +.tiny-scrollbar__bar.is-vertical > div { + width: 100%; +} +.tiny-scrollbar__bar.is-horizontal { + height: 6px; + left: 2px; +} +.tiny-scrollbar__bar.is-horizontal > div { + height: 100%; +} +.tiny-fade-in-linear-enter-active, +.tiny-fade-in-linear-leave-active { + -webkit-transition: opacity 0.2s linear; + transition: opacity 0.2s linear; +} +.tiny-fade-in-linear-enter, +.tiny-fade-in-linear-enter-from, +.tiny-fade-in-linear-leave, +.tiny-fade-in-linear-leave-active, +.tiny-fade-in-linear-leave-from { + opacity: 0; +} +.tiny-fade-in-enter-active, +.tiny-fade-in-leave-active { + -webkit-transition: all 0.3s cubic-bezier(0.55, 0, 0.1, 1); + transition: all 0.3s cubic-bezier(0.55, 0, 0.1, 1); +} +.tiny-fade-in-enter, +.tiny-fade-in-enter-from, +.tiny-fade-in-leave-active { + opacity: 0; +} +.tiny-zoom-in-center-enter-active, +.tiny-zoom-in-center-leave-active { + -webkit-transition: all 0.3s cubic-bezier(0.55, 0, 0.1, 1); + transition: all 0.3s cubic-bezier(0.55, 0, 0.1, 1); +} +.tiny-zoom-in-center-enter, +.tiny-zoom-in-center-enter-from, +.tiny-zoom-in-center-leave-active { + opacity: 0; + -webkit-transform: scaleX(0); + transform: scaleX(0); +} +.tiny-zoom-in-top-enter-active, +.tiny-zoom-in-top-leave-active { + opacity: 1; + -webkit-transform: scaleY(1); + transform: scaleY(1); + -webkit-transition: opacity 0.3s cubic-bezier(0.23, 1, 0.32, 1), -webkit-transform 0.3s cubic-bezier(0.23, 1, 0.32, 1); + transition: opacity 0.3s cubic-bezier(0.23, 1, 0.32, 1), -webkit-transform 0.3s cubic-bezier(0.23, 1, 0.32, 1); + transition: transform 0.3s cubic-bezier(0.23, 1, 0.32, 1), opacity 0.3s cubic-bezier(0.23, 1, 0.32, 1); + transition: transform 0.3s cubic-bezier(0.23, 1, 0.32, 1), opacity 0.3s cubic-bezier(0.23, 1, 0.32, 1), + -webkit-transform 0.3s cubic-bezier(0.23, 1, 0.32, 1); + -webkit-transform-origin: center top; + transform-origin: center top; +} +.tiny-zoom-in-top-enter, +.tiny-zoom-in-top-enter-from, +.tiny-zoom-in-top-leave-active { + opacity: 0; + -webkit-transform: scaleY(0); + transform: scaleY(0); +} +.tiny-zoom-in-bottom-enter-active, +.tiny-zoom-in-bottom-leave-active { + opacity: 1; + -webkit-transform: scaleY(1); + transform: scaleY(1); + -webkit-transition: opacity 0.3s cubic-bezier(0.23, 1, 0.32, 1), -webkit-transform 0.3s cubic-bezier(0.23, 1, 0.32, 1); + transition: opacity 0.3s cubic-bezier(0.23, 1, 0.32, 1), -webkit-transform 0.3s cubic-bezier(0.23, 1, 0.32, 1); + transition: transform 0.3s cubic-bezier(0.23, 1, 0.32, 1), opacity 0.3s cubic-bezier(0.23, 1, 0.32, 1); + transition: transform 0.3s cubic-bezier(0.23, 1, 0.32, 1), opacity 0.3s cubic-bezier(0.23, 1, 0.32, 1), + -webkit-transform 0.3s cubic-bezier(0.23, 1, 0.32, 1); + -webkit-transform-origin: center bottom; + transform-origin: center bottom; +} +.tiny-zoom-in-bottom-enter, +.tiny-zoom-in-bottom-enter-from, +.tiny-zoom-in-bottom-leave-active { + opacity: 0; + -webkit-transform: scaleY(0); + transform: scaleY(0); +} +.tiny-zoom-in-left-enter-active, +.tiny-zoom-in-left-leave-active { + opacity: 1; + -webkit-transform: scale(1, 1); + transform: scale(1, 1); + -webkit-transition: opacity 0.3s cubic-bezier(0.23, 1, 0.32, 1), -webkit-transform 0.3s cubic-bezier(0.23, 1, 0.32, 1); + transition: opacity 0.3s cubic-bezier(0.23, 1, 0.32, 1), -webkit-transform 0.3s cubic-bezier(0.23, 1, 0.32, 1); + transition: transform 0.3s cubic-bezier(0.23, 1, 0.32, 1), opacity 0.3s cubic-bezier(0.23, 1, 0.32, 1); + transition: transform 0.3s cubic-bezier(0.23, 1, 0.32, 1), opacity 0.3s cubic-bezier(0.23, 1, 0.32, 1), + -webkit-transform 0.3s cubic-bezier(0.23, 1, 0.32, 1); + -webkit-transform-origin: top left; + transform-origin: top left; +} +.tiny-zoom-in-left-enter, +.tiny-zoom-in-left-enter-from, +.tiny-zoom-in-left-leave-active { + opacity: 0; + -webkit-transform: scale(0.45, 0.45); + transform: scale(0.45, 0.45); +} +.tiny-list-enter-active, +.tiny-list-leave-active { + -webkit-transition: all 1s; + transition: all 1s; +} +.tiny-list-enter, +.tiny-list-enter-from, +.tiny-list-leave-active { + opacity: 0; + -webkit-transform: translateY(-30px); + transform: translateY(-30px); +} +.tiny-opacity-transition { + -webkit-transition: opacity 0.3s cubic-bezier(0.55, 0, 0.1, 1); + transition: opacity 0.3s cubic-bezier(0.55, 0, 0.1, 1); +} +.collapse-transition { + -webkit-transition: 0.3s height ease-in-out, 0.3s padding-top ease-in-out, 0.3s padding-bottom ease-in-out; + transition: 0.3s height ease-in-out, 0.3s padding-top ease-in-out, 0.3s padding-bottom ease-in-out; +} +.horizontal-collapse-transition { + -webkit-transition: 0.3s width ease-in-out, 0.3s padding-left ease-in-out, 0.3s padding-right ease-in-out; + transition: 0.3s width ease-in-out, 0.3s padding-left ease-in-out, 0.3s padding-right ease-in-out; +} +.fade-in-linear-enter, +.fade-in-linear-enter-from, +.fade-in-linear-leave, +.fade-in-linear-leave-active, +.fade-in-linear-leave-from { + opacity: 0; +} +.fade-in-linear-enter-active, +.fade-in-linear-leave-active { + -webkit-transition: opacity 0.2s linear; + transition: opacity 0.2s linear; +} +.tiny-popupload { + --ti-popupload-font-size: var(--ti-common-font-size-base); + --ti-popupload-dialog-table-border-color: var(--ti-base-color-border); + --ti-popupload-dialog-table-header-height: var(--ti-base-size-height-small); + --ti-popupload-dialog-table-header-color: var(--ti-base-color-info-normal); + --ti-popupload-dialog-table-header-background: #f1f1f1; + --ti-popupload-dialog-table-icon-color: var(--ti-base-color-brand-6); + --ti-popupload-dialog-table-icon-hover-color: var(--ti-base-color-bg-8); + font-size: var(--ti-popupload-font-size); + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; +} +.tiny-popupload__dialog { + max-height: 512px; + width: 100%; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-orient: vertical; + -webkit-box-direction: normal; + -ms-flex-direction: column; + flex-direction: column; +} +.tiny-popupload__dialog-header .tiny-alert { + margin-bottom: 10px; +} +.tiny-popupload__dialog-body { + padding-bottom: 24px; +} +.tiny-popupload__dialog-body .tiny-upload-list { + display: none; +} +.tiny-popupload__dialog-footer { + width: 100%; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + -webkit-box-pack: center; + -ms-flex-pack: center; + justify-content: center; + padding-bottom: 24px; +} +.tiny-popupload__dialog-tips { + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-orient: vertical; + -webkit-box-direction: normal; + -ms-flex-direction: column; + flex-direction: column; +} +.tiny-popupload__dialog-table { + height: 280px; + width: 100%; + margin-top: 10px; +} +.tiny-popupload__dialog-table .header-col { + border-right: 1px solid var(--ti-popupload-dialog-table-border-color); + padding: 0 12px; +} +.tiny-popupload__dialog-table .header-col:last-child { + border-right: none; +} +.tiny-popupload__dialog-table .body-col { + padding: 8px 12px; + margin: 0; + line-height: 20px; +} +.tiny-popupload__dialog-table .col1 { + width: 60%; +} +.tiny-popupload__dialog-table .col2 { + width: 20%; +} +.tiny-popupload__dialog-table .col3 { + width: 20%; +} +.tiny-popupload__dialog-table-header { + height: var(--ti-popupload-dialog-table-header-height); + width: 100%; + color: var(--ti-popupload-dialog-table-header-color); + font-weight: 700; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + -webkit-box-pack: justify; + -ms-flex-pack: justify; + justify-content: space-between; + background: var(--ti-popupload-dialog-table-header-background); + border-bottom: 1px solid var(--ti-popupload-dialog-table-border-color); +} +.tiny-popupload__dialog-table-body { + width: 100%; + height: calc(100% - var(--ti-popupload-dialog-table-header-height)); + overflow-y: auto; + border-bottom: 1px solid var(--ti-popupload-dialog-table-border-color); +} +.tiny-popupload__dialog-table-list { + list-style: none; +} +.tiny-popupload__dialog-table-item { + width: 100%; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + -webkit-box-pack: justify; + -ms-flex-pack: justify; + justify-content: space-between; +} +.tiny-popupload__dialog-table-item:nth-child(even) { + background: rgba(51, 51, 51, 0.06); +} +.tiny-popupload__dialog-table-item .delIcon { + height: 17px; + width: 17px; + fill: var(--ti-popupload-dialog-table-icon-color); + cursor: pointer; +} +.tiny-popupload__dialog-table-item .delIcon:hover { + height: 17px; + width: 17px; + fill: var(--ti-popupload-dialog-table-icon-hover-color); +} +.tiny-popupload__modal .tiny-grid-modal__body { + overflow-y: auto; +} +.tiny-popeditor { + --ti-popeditor-border-color: var(--ti-base-color-border); + --ti-popeditor-icon-color: var(--ti-base-color-brand-6); + --ti-popeditor-icon-disabled-color: var(--ti-base-color-placeholder); + --ti-popeditor-icon-hover-color: var(--ti-base-color-brand-5); + --ti-popeditor-tabs-color: var(--ti-base-color-info-normal); + --ti-popeditor-tabs-selected-color: var(--ti-base-color-brand-6); + --ti-popeditor-tabs-li-height: var(--ti-common-size-10x); +} +.tiny-popeditor .tiny-input.tiny-popeditor-readonly .tiny-input__inner:active, +.tiny-popeditor .tiny-input.tiny-popeditor-readonly .tiny-input__inner:focus, +.tiny-popeditor .tiny-input.tiny-popeditor-readonly .tiny-input__inner:hover { + cursor: pointer; + border-color: var(--ti-popeditor-border-color); +} +.tiny-popeditor .tiny-input.is-disabled .tiny-input__inner:active, +.tiny-popeditor .tiny-input.is-disabled .tiny-input__inner:focus, +.tiny-popeditor .tiny-input.is-disabled .tiny-input__inner:hover { + cursor: not-allowed; +} +.tiny-popeditor .tiny-input.is-disabled .tiny-input__inner:active + .tiny-input__suffix .tiny-svg__popeditor, +.tiny-popeditor .tiny-input.is-disabled .tiny-input__inner:focus + .tiny-input__suffix .tiny-svg__popeditor, +.tiny-popeditor .tiny-input.is-disabled .tiny-input__inner:hover + .tiny-input__suffix .tiny-svg__popeditor { + fill: var(--ti-popeditor-icon-disabled-color); +} +.tiny-popeditor .tiny-input.is-disabled .tiny-input__suffix { + cursor: not-allowed; +} +.tiny-popeditor .tiny-input.is-disabled .tiny-input__suffix .tiny-svg__popeditor, +.tiny-popeditor .tiny-input.is-disabled .tiny-input__suffix .tiny-svg__popeditor:hover { + fill: var(--ti-popeditor-icon-disabled-color); + cursor: not-allowed; +} +.tiny-popeditor .tiny-input.suggest .tiny-input__inner { + padding-right: 50px; +} +.tiny-popeditor .tiny-input.suggest .tiny-svg__popeditor.tiny-chevron { + margin-right: 8px; +} +.tiny-popeditor .tiny-input .tiny-input__inner:active + .tiny-input__suffix, +.tiny-popeditor .tiny-input .tiny-input__inner:focus + .tiny-input__suffix, +.tiny-popeditor .tiny-input .tiny-input__inner:hover + .tiny-input__suffix { + cursor: not-allowed; +} +.tiny-popeditor .tiny-input .tiny-input__inner:active + .tiny-input__suffix .tiny-svg__popeditor, +.tiny-popeditor .tiny-input .tiny-input__inner:focus + .tiny-input__suffix .tiny-svg__popeditor, +.tiny-popeditor .tiny-input .tiny-input__inner:hover + .tiny-input__suffix .tiny-svg__popeditor { + fill: var(--ti-popeditor-icon-hover-color); +} +.tiny-popeditor .tiny-input .tiny-input__suffix { + cursor: pointer; +} +.tiny-popeditor .tiny-input .tiny-input__suffix .tiny-svg__popeditor { + height: 30px; + line-height: 30px; + font-size: var(--ti-common-font-size-1); + fill: var(--ti-popeditor-icon-color); + cursor: pointer; +} +.tiny-popeditor .tiny-input .tiny-input__suffix .tiny-svg__popeditor:hover { + fill: var(--ti-popeditor-icon-hover-color); +} +.tiny-popeditor .tiny-dialog-box .tiny-dialog-box__body { + padding: 8px 8px 0; +} +.tiny-popeditor-top .tiny-popeditor__search-lists { + width: 100%; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-pack: justify; + -ms-flex-pack: justify; + justify-content: space-between; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + -ms-flex-wrap: wrap; + flex-wrap: wrap; +} +.tiny-popeditor-top .tiny-popeditor__search-lists .tiny-input { + position: relative; + font-size: var(--ti-common-font-size-base); + display: inline-block; + width: 100%; +} +.tiny-popeditor-top .tiny-popeditor__search-lists .tiny-popeditor__search-item { + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-pack: end; + -ms-flex-pack: end; + justify-content: flex-end; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + margin-bottom: 12px; +} +.tiny-popeditor-top .tiny-popeditor__search-lists .tiny-popeditor__search-item .tiny-popeditor__search-label { + text-align: right; + padding-right: 8px; + font-size: var(--ti-common-font-size-base); +} +.tiny-popeditor-top .tiny-popeditor__search-lists .tiny-popeditor__search-input { + -webkit-box-flex: 1; + -ms-flex: 1; + flex: 1; +} +.tiny-popeditor-top .tiny-popeditor__search-footer { + width: 100%; + text-align: center; + margin: 12px auto; +} +.tiny-popeditor-body { + width: 100%; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-pack: justify; + -ms-flex-pack: justify; + justify-content: space-between; + -webkit-box-align: start; + -ms-flex-align: start; + align-items: flex-start; +} +.tiny-popeditor-body__left, +.tiny-popeditor-body__right { + width: 50%; + padding: 0 4px; + vertical-align: top; +} +.tiny-popeditor-body__left.tiny-popeditor-body__radio, +.tiny-popeditor-body__right.tiny-popeditor-body__radio { + width: 100%; +} +.tiny-popeditor-body .tiny-popeditor__tabs .tiny-popeditor__tabs-head { + white-space: nowrap; + margin: 0; + padding: 0 10px; + overflow: hidden; + height: 40px; + width: 100%; + position: relative; +} +.tiny-popeditor-body .tiny-popeditor__tabs .tiny-popeditor__tabs-head ul { + height: 40px; + border-bottom: 1px solid var(--ti-popeditor-border-color); + -webkit-box-sizing: border-box; + box-sizing: border-box; +} +.tiny-popeditor-body .tiny-popeditor__tabs .tiny-popeditor__tabs-head ul li { + float: left; + margin-right: -1px; + cursor: pointer; + padding: 0 20px; + color: var(--ti-popeditor-tabs-color); + min-width: 90px; + height: var(--ti-popeditor-tabs-li-height); + line-height: var(--ti-popeditor-tabs-li-height); +} +.tiny-popeditor-body .tiny-popeditor__tabs .tiny-popeditor__tabs-head ul li.tiny-popeditor__tabs-selected { + color: var(--ti-popeditor-tabs-selected-color); + border-bottom: 3px solid var(--ti-popeditor-tabs-selected-color); + font-weight: 700; +} +.tiny-popeditor-body .tiny-popeditor__tabs .tiny-popeditor__tabs-body .tabs-body-item { + padding: 12px 12px 0; +} +.tiny-popeditor-body .tiny-popeditor__tabs .tiny-popeditor__tabs-body .tabs-body-item .tiny-pager { + padding-bottom: 0; +} +.tiny-popeditor_filter-input { + margin-bottom: 20px; +} +.tiny-poplist.poplist-user { + min-width: 180px; +} +.tiny-poplist.poplist-user .tiny-icon { + float: right; + margin-left: 5px; +} +.tiny-popover.tiny-popper { + --ti-popover-background: var(--ti-base-color-light); + --ti-popover-color: #606266; + --ti-popover-border-color: #d9d9d9; + --ti-popover-border-radius: var(--ti-common-border-radius-1); + --ti-popover-font-size: var(--ti-common-font-size-1); + --ti-popover-title-color: #303133; + --ti-popover-title-font-size: var(--ti-common-font-size-2); + --ti-popover-arrow-border-width: 6px; + --ti-popover-placement-margin: var(--ti-common-space-3x); + --ti-popover-placement-arrow-after-border-color: var(--ti-base-color-light); + --ti-popover-box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.1); + --ti-popover-arrow-border-color: var(--ti-popover-border-color); + --ti-popover-padding: 11px 15px; + position: absolute; + background: var(--ti-popover-background); + color: var(--ti-popover-color); + border-radius: var(--ti-popover-border-radius); + border: 1px solid var(--ti-popover-border-color); + padding: var(--ti-popover-padding); + z-index: 2000; + line-height: 1.4; + text-align: justify; + font-size: var(--ti-popover-font-size); + -webkit-box-shadow: var(--ti-popover-box-shadow); + box-shadow: var(--ti-popover-box-shadow); + word-break: break-all; +} +.tiny-popover.tiny-popper .popper__arrow, +.tiny-popover.tiny-popper .popper__arrow::after { + position: absolute; + display: block; + width: 0; + height: 0; + border-color: transparent; + border-style: solid; +} +.tiny-popover.tiny-popper .popper__arrow, +.tiny-popover.tiny-popper .tiny-popper .popper__arrow { + border-width: var(--ti-popover-arrow-border-width); + -webkit-filter: drop-shadow(0 2px 12px rgba(0, 0, 0, 0.03)); + filter: drop-shadow(0 2px 12px rgba(0, 0, 0, 0.03)); +} +.tiny-popover.tiny-popper .popper__arrow::after { + content: ' '; + border-width: var(--ti-popover-arrow-border-width); +} +.tiny-popover.tiny-popper[x-placement^='top'] { + margin-bottom: var(--ti-popover-placement-margin); +} +.tiny-popover.tiny-popper[x-placement^='top'] .popper__arrow { + bottom: -6px; + left: 50%; + margin-right: 3px; + border-top-color: var(--ti-popover-arrow-border-color); + border-bottom-width: 0; +} +.tiny-popover.tiny-popper[x-placement^='top'] .popper__arrow::after { + bottom: 1px; + margin-left: -6px; + border-top-color: var(--ti-popover-placement-arrow-after-border-color); + border-bottom-width: 0; +} +.tiny-popover.tiny-popper[x-placement^='bottom'] { + margin-top: var(--ti-popover-placement-margin); +} +.tiny-popover.tiny-popper[x-placement^='bottom'] .popper__arrow { + top: -6px; + left: 50%; + margin-right: 3px; + border-top-width: 0; + border-bottom-color: var(--ti-popover-arrow-border-color); +} +.tiny-popover.tiny-popper[x-placement^='bottom'] .popper__arrow::after { + top: 1px; + margin-left: -6px; + border-top-width: 0; + border-bottom-color: var(--ti-popover-placement-arrow-after-border-color); +} +.tiny-popover.tiny-popper[x-placement^='right'] { + margin-left: var(--ti-popover-placement-margin); +} +.tiny-popover.tiny-popper[x-placement^='right'] .popper__arrow { + top: 50%; + left: -6px; + margin-bottom: 3px; + border-right-color: var(--ti-popover-arrow-border-color); + border-left-width: 0; +} +.tiny-popover.tiny-popper[x-placement^='right'] .popper__arrow::after { + bottom: -6px; + left: 1px; + border-right-color: var(--ti-popover-placement-arrow-after-border-color); + border-left-width: 0; +} +.tiny-popover.tiny-popper[x-placement^='left'] { + margin-right: var(--ti-popover-placement-margin); +} +.tiny-popover.tiny-popper[x-placement^='left'] .popper__arrow { + top: 50%; + right: -6px; + margin-bottom: 3px; + border-right-width: 0; + border-left-color: var(--ti-popover-arrow-border-color); +} +.tiny-popover.tiny-popper[x-placement^='left'] .popper__arrow::after { + right: 1px; + bottom: -6px; + margin-left: -6px; + border-right-width: 0; + border-left-color: var(--ti-popover-placement-arrow-after-border-color); +} +.tiny-popover.tiny-popper .tiny-popover__plain { + padding: 18px 20px; +} +.tiny-popover.tiny-popper .tiny-popover__title { + color: var(--ti-popover-title-color); + font-size: var(--ti-popover-title-font-size); + line-height: 1; + margin-bottom: 12px; +} +.tiny-popover.tiny-popper .tiny-popover__reference:focus:hover, +.tiny-popover.tiny-popper .tiny-popover__reference:focus:not(.focusing), +.tiny-popover.tiny-popper:focus, +.tiny-popover.tiny-popper:focus:active { + outline-width: 0; +} +.tiny-popover__reference { + display: inline-block; +} +.tiny-progress { + --ti-progress-text-color: var(--ti-base-color-info-normal); + --ti-progress-text-font-size: var(--ti-common-font-size-base); + --ti-progress-bar-border-radius: 100px; + --ti-progress-bar-outer-bgcolor: var(--ti-base-color-selected-background); + --ti-progress-bar-inner-bgcolor: var(--ti-base-color-brand-6); + --ti-progress-bar-inner-text-color: var(--ti-base-color-light); + --ti-progress-success-color: var(--ti-base-color-success-normal); + --ti-progress-warning-color: var(--ti-base-color-warning-normal); + --ti-progress-exception-color: var(--ti-base-color-bg-8); + position: relative; + line-height: 1; +} +.tiny-progress.is-success .tiny-progress-bar__inner { + background-color: var(--ti-progress-success-color); +} +.tiny-progress.is-success .tiny-progress__text svg { + fill: var(--ti-progress-success-color); +} +.tiny-progress.is-warning .tiny-progress-bar__inner { + background-color: var(--ti-progress-warning-color); +} +.tiny-progress.is-warning .tiny-progress__text svg { + fill: var(--ti-progress-warning-color); +} +.tiny-progress.is-exception .tiny-progress-bar__inner { + background-color: var(--ti-progress-exception-color); +} +.tiny-progress.is-exception .tiny-progress__text svg { + fill: var(--ti-progress-exception-color); +} +.tiny-progress__text { + font-size: var(--ti-progress-text-font-size); + color: var(--ti-progress-text-color); + display: inline-block; + vertical-align: middle; + margin-left: 12px; + line-height: 1; +} +.tiny-progress__text i { + vertical-align: middle; + display: inline-block; +} +.tiny-progress--circle, +.tiny-progress--dashboard { + display: inline-block; +} +.tiny-progress--circle .tiny-progress__text, +.tiny-progress--dashboard .tiny-progress__text { + top: 50%; + position: absolute; + width: 100%; + text-align: center; + margin: 0; + -webkit-transform: translate(0, -50%); + transform: translate(0, -50%); + left: 0; +} +.tiny-progress--circle .tiny-progress__text i, +.tiny-progress--dashboard .tiny-progress__text i { + display: inline-block; + vertical-align: middle; +} +.tiny-progress--without-text .tiny-progress__text { + display: none; +} +.tiny-progress--without-text .tiny-progress-bar { + padding-right: 0; + margin-right: 0; + display: block; +} +.tiny-progress--text-inside .tiny-progress-bar { + padding-right: 0; + margin-right: 0; +} +.tiny-progress-bar { + padding-right: 50px; + width: 100%; + margin-right: -55px; + -webkit-box-sizing: border-box; + box-sizing: border-box; +} +.tiny-progress-bar__outer { + height: 6px; + border-radius: var(--ti-progress-bar-border-radius); + background-color: var(--ti-progress-bar-outer-bgcolor); + overflow: hidden; + position: relative; + vertical-align: middle; +} +.tiny-progress-bar__inner { + background-color: var(--ti-progress-bar-inner-bgcolor); + text-align: right; + left: 0; + position: absolute; + top: 0; + height: 100%; + border-radius: var(--ti-progress-bar-border-radius); + line-height: 1; + white-space: nowrap; + -webkit-transition: width 0.6s ease; + transition: width 0.6s ease; +} +.tiny-progress-bar__inner::after { + content: ''; + height: 100%; +} +.tiny-progress-bar__innerText { + color: var(--ti-progress-bar-inner-text-color); + font-size: var(--ti-progress-text-font-size); + margin: 0 5px; +} +.tiny-progress-bar, +.tiny-progress-bar__inner::after, +.tiny-progress-bar__innerText { + display: inline-block; + vertical-align: middle; +} +@-webkit-keyframes progress { + 0% { + background-position: 0 0; + } + 100% { + background-position: 32px 0; + } +} +@keyframes progress { + 0% { + background-position: 0 0; + } + 100% { + background-position: 32px 0; + } +} +.tiny-slider { + --ti-slider-bgcolor: var(--ti-base-color-brand-2); + --ti-slider-height: var(--ti-common-size-2x); + --ti-slider-radius: 2px; + --ti-slider-range-height: var(--ti-common-size-4x); + --ti-slider-range-radius: 2px; + --ti-slider-range-bgcolor: var(--ti-base-color-brand-6); + --ti-slider-range-hover-bgcolor: var(--ti-base-color-brand-6); + --ti-slider-range-top: calc(-1 * var(--ti-common-space-base)); + --ti-slider-range-margin-top: calc(-1 * var(--ti-common-space-base)); + --ti-slider-handle-width: var(--ti-common-size-5x); + --ti-slider-handle-height: var(--ti-common-size-7x); + --ti-slider-handle-bgcolor: linear-gradient(153deg, var(--ti-base-color-white), var(--ti-base-color-brand-2) 99%); + --ti-slider-handle-border-color: var(--ti-base-color-brand-6); + --ti-slider-handle-radius: 10px; + --ti-slider-handle-color-hover: var(--ti-common-color-bg-hover); + --ti-slider-handle-box-shadow: 0 1px 4px 0 rgba(0, 0, 0, 0.1); + --ti-slider-handle-top: calc(-1 * var(--ti-common-space-base)); + --ti-slider-handle-border-width: 1px; + --ti-slider-handle-icon-display: inline-block; + --ti-slider-handle-icon-fill-color: var(--ti-slider-handle-border-color); + --ti-slider-handle-icon-fill-color-hover: var(--ti-slider-handle-color-hover); + --ti-slider-handle-transform: scale(1); + --ti-slider-handle-margin: -10px -8px 0; + --ti-slider-input-height: var(--ti-base-size-height-minor, 30px); + --ti-slider-input-width: var(--ti-common-size-10x); + --ti-slider-input-border-radius: var(--ti-common-border-radius-normal, 2px); + --ti-slider-input-border-color: var(--ti-base-color-border, #d9d9d9); + --ti-slider-input-color: var(--ti-base-color-info-normal, #333); + --ti-slider-input-bgcolor: var(--ti-base-color-light, #fff); + --ti-slider-tips-bgcolor: var(--ti-base-color-common-6); + --ti-slider-tips-color: var(--ti-base-color-white); + --ti-slider-tips-margin-left: 3px; + --ti-slider-vertical-margin: -8px 0 -8px -6px; + border-radius: var(--ti-slider-radius); + height: var(--ti-slider-height); + position: relative; + margin: 13px 0; + background: var(--ti-slider-bgcolor); + cursor: pointer; + width: calc(100% - 89px); + display: inline-block; +} +.tiny-slider:hover .tiny-slider__range { + background: var(--ti-slider-range-hover-bgcolor); +} +.tiny-slider:hover .tiny-slider__handle { + border-color: var(--ti-slider-range-hover-bgcolor); +} +.tiny-slider.disabled { + cursor: default; +} +.tiny-slider.disabled .tiny-slider__handle { + cursor: not-allowed; +} +.tiny-slider.tiny-slider__vertical { + width: var(--ti-slider-height); + height: 300px; + display: block; + margin: 0 15px; +} +.tiny-slider.tiny-slider__vertical + .tiny-slider__input { + margin-top: 12px; + float: none; + right: 0; +} +.tiny-slider.tiny-slider__vertical .tiny-slider__range { + border-radius: 10px; + position: absolute; + z-index: 1; + width: var(--ti-slider-height); +} +.tiny-slider.tiny-slider__vertical .tiny-slider__up { + top: 0; +} +.tiny-slider.tiny-slider__vertical .tiny-slider__down { + bottom: 0; +} +.tiny-slider.tiny-slider__vertical .tiny-slider__handle { + margin: var(--ti-slider-vertical-margin); +} +.tiny-slider__range { + border-radius: var(--ti-slider-range-radius); + position: absolute; + z-index: 1; + margin-top: var(--ti-slider-range-margin-top); + height: var(--ti-slider-range-height); + background: var(--ti-slider-range-bgcolor); +} +.tiny-slider__left { + left: 0; +} +.tiny-slider__right { + right: 0; +} +.tiny-slider__handle { + border-radius: var(--ti-slider-handle-radius); + height: var(--ti-slider-handle-height); + width: var(--ti-slider-handle-width); + position: absolute; + margin: var(--ti-slider-handle-margin); + z-index: 2; + outline: 0; + background: var(--ti-slider-handle-bgcolor); + border: var(--ti-slider-handle-border-width) solid var(--ti-slider-handle-border-color); + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + -webkit-box-pack: center; + -ms-flex-pack: center; + justify-content: center; + -webkit-box-shadow: var(--ti-slider-handle-box-shadow); + box-shadow: var(--ti-slider-handle-box-shadow); + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; + cursor: -webkit-grab; + cursor: grab; + text-align: center; +} +.tiny-slider__handle:hover { + color: var(--ti-slider-handle-color-hover); + border-color: var(--ti-slider-handle-color-hover); + -webkit-transform: var(--ti-slider-handle-transform); + transform: var(--ti-slider-handle-transform); +} +.tiny-slider__handle:hover svg { + fill: var(--ti-slider-handle-icon-fill-color-hover); +} +.tiny-slider__handle svg { + display: var(--ti-slider-handle-icon-display); + height: 12px; + margin-left: 4px; + fill: var(--ti-slider-handle-icon-fill-color); +} +.tiny-slider__tips { + text-align: center; + font-size: var(--ti-common-font-size-base); + margin-top: -32px; + margin-left: var(--ti-slider-tips-margin-left); + position: absolute; + padding: 12px 16px; + line-height: 1.5; + z-index: 1010; + word-break: normal; + white-space: nowrap; + background: var(--ti-slider-tips-bgcolor); + border: 1px solid var(--ti-slider-tips-bgcolor); + border-radius: var(--ti-common-border-radius-1); + color: var(--ti-slider-tips-color); +} +.tiny-slider__tips:before { + margin-left: -6px; + bottom: -6px; + content: ''; + left: 50%; + top: auto; + margin-top: 0; + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 6px 6px 0 6px; + border-color: var(--ti-slider-tips-bgcolor) transparent; +} +.tiny-slider__tips:after { + margin-left: -4px; + bottom: -4px; + content: ''; + left: 50%; + top: auto; + margin-top: 0; + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 4px 4px 0 4px; + border-color: var(--ti-slider-tips-bgcolor) transparent; +} +.tiny-slider__input { + display: inline-block; + line-height: var(--ti-slider-input-height); + vertical-align: top; + margin-left: 12px; + font-size: var(--ti-common-font-size-base); +} +.tiny-slider__input input { + width: var(--ti-slider-input-width); + height: var(--ti-slider-input-height); + line-height: var(--ti-slider-input-height); + border: 1px solid var(--ti-slider-input-border-color); + border-radius: var(--ti-slider-input-border-radius); + color: var(--ti-slider-input-color); + background: var(--ti-slider-input-bgcolor); + font-size: inherit; + padding: 0 8px; + outline: 0; + display: inline-block; + -webkit-box-sizing: border-box; + box-sizing: border-box; + text-align: center; +} +.tiny-slider__input span { + padding-left: 8px; +} +.tiny-radio { + --ti-radio-color: var(--ti-base-color-info-normal); + --ti-radio-font-size: var(--ti-common-font-size-base); + --ti-radio-bordered-height: var(var(--ti-common-size-10x)); + --ti-radio-bordered-border-radius: var(--ti-common-border-radius-normal); + --ti-radio-bordered-border-color: var(--ti-base-color-common-2); + --ti-radio-input-disabled-border-color: var(--ti-base-color-common-1); + --ti-radio-bordered-checked-border-color: var(--ti-base-color-brand-6); + --ti-radio-bordered-checked-background-color: var(--ti-base-color-light); + --ti-radio-bordered-hover-border-color: var(--ti-base-color-brand-6); + --ti-radio-bordered-checked-hover-border-color: var(--ti-base-color-brand-6); + --ti-radio-bordered-active-border-color: var(--ti-base-color-primary-active); + --ti-radio-input-disabled-bgcolor: var(--ti-base-color-bg-5); + --ti-radio-input-checked-disabled-color: var(--ti-base-color-bg-5); + --ti-radio-input-disabled-color: var(--ti-base-color-placeholder); + --ti-radio-inner-bgcolor: var(--ti-base-color-light); + --ti-radio-inner-checked-bgcolor: var(--ti-base-color-brand-6); + --ti-radio-medium-height: var(--ti-base-size-height-small); + --ti-radio-medium-inner-height: 14px; + --ti-radio-medium-inner-width: 14px; + --ti-radio-small-height: var(--ti-common-size-8x); + --ti-radio-small-inner-height: var(--ti-common-size-3x); + --ti-radio-small-inner-width: var(--ti-common-size-3x); + --ti-radio-mini-height: var(--ti-common-size-7x); + --ti-radio-mini-inner-height: var(--ti-common-size-3x); + --ti-radio-mini-inner-width: var(--ti-common-size-3x); + --ti-radio-inner-size: 8px; + --ti-radio-inner-checked-disabled-bgcolor: var(--ti-base-color-common-2); + color: var(--ti-radio-color); + font-weight: 500; + margin-right: 30px; + display: -webkit-inline-box; + display: -ms-inline-flexbox; + display: inline-flex; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + position: relative; + cursor: pointer; + -ms-user-select: none; + -webkit-user-select: none; + -o-user-select: none; + -moz-user-select: none; + user-select: none; +} +.tiny-radio:last-child { + margin-right: 0; +} +.tiny-radio.is-bordered { + padding: 4px 12px; + border-radius: var(--ti-radio-bordered-border-radius); + border: 1px solid var(--ti-radio-bordered-border-color); + -webkit-box-sizing: border-box; + box-sizing: border-box; + height: var(--ti-radio-bordered-height); +} +.tiny-radio.is-bordered + .tiny-radio.is-bordered { + margin-left: 10px; +} +.tiny-radio.is-bordered.is-checked { + border-color: var(--ti-radio-bordered-checked-border-color); +} +.tiny-radio.is-bordered.is-disabled { + cursor: not-allowed; + border-color: var(--ti-radio-bordered-border-color); +} +.tiny-radio, +.tiny-radio__input { + white-space: nowrap; + line-height: 1; + outline: 0; +} +.tiny-radio__input { + cursor: pointer; + line-height: 1; + display: -webkit-inline-box; + display: -ms-inline-flexbox; + display: inline-flex; +} +@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) { + .tiny-radio__input { + display: inline-block; + } +} +@supports (-ms-ime-align: auto) { + .tiny-radio__input { + display: inline-block; + } +} +.tiny-radio__input.is-disabled .tiny-radio__inner { + border-color: var(--ti-radio-input-disabled-border-color); +} +.tiny-radio__input.is-disabled .tiny-radio__inner, +.tiny-radio__input.is-disabled .tiny-radio__inner::after { + cursor: not-allowed; + background-color: var(--ti-radio-input-disabled-bgcolor); +} +.tiny-radio__input.is-disabled .tiny-radio__inner + .tiny-radio__label { + cursor: not-allowed; +} +.tiny-radio__input.is-disabled.is-checked .tiny-radio__inner { + background-color: var(--ti-radio-input-checked-disabled-color); + border-color: var(--ti-base-color-common-1); +} +.tiny-radio__input.is-disabled.is-checked .tiny-radio__inner::after { + background-color: var(--ti-radio-inner-checked-disabled-bgcolor); +} +.tiny-radio__input.is-disabled + span.tiny-radio__label { + color: var(--ti-radio-input-disabled-color); + cursor: not-allowed; +} +.tiny-radio__input.is-checked .tiny-radio__inner { + border-color: var(--ti-radio-bordered-checked-border-color); + background: var(--ti-radio-bordered-checked-background-color); +} +.tiny-radio__input.is-checked .tiny-radio__inner::after { + -webkit-transform: translate(-50%, -50%) scale(1); + transform: translate(-50%, -50%) scale(1); + background-color: var(--ti-radio-inner-checked-bgcolor); +} +.tiny-radio__input.is-checked:not(.is-disabled) .tiny-radio__inner:hover { + border-color: var(--ti-radio-bordered-checked-hover-border-color); +} +.tiny-radio__inner { + border: 1px solid var(--ti-radio-bordered-border-color); + border-radius: 100%; + width: 16px; + height: 16px; + background-color: var(--ti-radio-inner-bgcolor); + position: relative; + display: inline-block; + cursor: pointer; + -webkit-box-sizing: border-box; + box-sizing: border-box; + outline: 0; +} +.tiny-radio__inner:hover { + border-color: var(--ti-radio-bordered-hover-border-color); +} +.tiny-radio__inner:active { + border-color: var(--ti-radio-bordered-active-border-color); +} +.tiny-radio__inner::after { + width: var(--ti-radio-inner-size); + height: var(--ti-radio-inner-size); + border-radius: 100%; + background-color: var(--ti-radio-inner-bgcolor); + content: ''; + position: absolute; + left: 50%; + top: 50%; + -webkit-transform: translate(-50%, -50%) scale(0); + transform: translate(-50%, -50%) scale(0); + -webkit-transition: -webkit-transform 0.15s ease-in; + transition: -webkit-transform 0.15s ease-in; + transition: transform 0.15s ease-in; + transition: transform 0.15s ease-in, -webkit-transform 0.15s ease-in; +} +.tiny-radio__original { + opacity: 0; + outline: 0; + position: absolute; + z-index: -1; + margin: 0; + width: 0; + height: 0; +} +.tiny-radio__label { + font-size: var(--ti-radio-font-size); + padding-left: 8px; + vertical-align: middle; +} +.tiny-radio--medium.is-bordered { + border-radius: var(--ti-radio-bordered-border-radius); + height: var(--ti-radio-medium-height); +} +.tiny-radio--medium.is-bordered .tiny-radio__inner { + height: var(--ti-radio-medium-inner-height); + width: var(--ti-radio-medium-inner-width); +} +.tiny-radio--medium.is-bordered .tiny-radio__label { + font-size: var(--ti-radio-font-size); +} +.tiny-radio--small.is-bordered { + border-radius: var(--ti-radio-bordered-border-radius); + height: var(--ti-radio-small-height); +} +.tiny-radio--small.is-bordered .tiny-radio__inner { + height: var(--ti-radio-small-inner-height); + width: var(--ti-radio-small-inner-width); +} +.tiny-radio--small.is-bordered .tiny-radio__label { + font-size: var(--ti-radio-font-size); +} +.tiny-radio--mini.is-bordered { + padding: 0 8px; + border-radius: var(--ti-radio-bordered-border-radius, 2px); + height: var(--ti-radio-mini-height); + line-height: calc(var(--ti-radio-mini-height) - 2px); +} +.tiny-radio--mini.is-bordered .tiny-radio__inner { + height: var(--ti-radio-mini-inner-height); + width: var(--ti-radio-mini-inner-width); +} +.tiny-radio--mini.is-bordered .tiny-radio__inner::after { + width: 4px; + height: 4px; +} +.tiny-radio--mini.is-bordered .tiny-radio__label { + font-size: var(--ti-radio-font-size); +} +.tiny-radio:focus:not(.is-focus):not(:active):not(.is-disabled) .tiny-radio__inner { + -webkit-box-shadow: 0 0 2px 2px var(--ti-radio-bordered-hover-border-color); + box-shadow: 0 0 2px 2px var(--ti-radio-bordered-hover-border-color); +} +.tiny-radio-button { + --ti-radio-button-color: var(--ti-base-color-info-normal); + --ti-radio-button-hover-color: var(--ti-base-color-light); + --ti-radio-button-border-color: var(--ti-base-color-border); + --ti-radio-button-border-radius: var(--ti-common-border-radius-normal); + --ti-radio-button-font-size: var(--ti-common-font-size-base); + --ti-radio-button-bgcolor: var(--ti-base-color-light); + --ti-radio-button-checked-normal-color: var(--ti-base-color-brand-6); + --ti-radio-button-checked-hover-color: var(--ti-base-color-brand-5); + --ti-radio-button-disabled-color: var(--ti-base-color-placeholder); + --ti-radio-button-disabled-bgcolor: var(--ti-base-color-bg-5); + --ti-radio-button-medium-font-size: var(--ti-common-font-size-1); +} +.tiny-radio-button:first-child .tiny-radio-button__inner { + border-left: 1px solid var(--ti-radio-button-border-color); + border-radius: var(--ti-radio-button-border-radius) 0 0 var(--ti-radio-button-border-radius); +} +.tiny-radio-button:first-child .tiny-radio-button__orig-radio:checked + .tiny-radio-button__inner { + -webkit-box-shadow: none; + box-shadow: none; +} +.tiny-radio-button:last-child .tiny-radio-button__inner { + border-radius: 0 var(--ti-radio-button-border-radius) var(--ti-radio-button-border-radius) 0; +} +.tiny-radio-button:first-child:last-child .tiny-radio-button__inner { + border-radius: var(--ti-radio-button-border-radius); +} +.tiny-radio-button, +.tiny-radio-button__inner { + display: inline-block; + position: relative; + outline: 0; +} +.tiny-radio-button__inner { + color: var(--ti-radio-button-color); + font-size: var(--ti-radio-button-font-size); + background: var(--ti-radio-button-bgcolor); + border: 1px solid var(--ti-radio-button-border-color); + padding: 12px 20px; + font-weight: 500; + border-radius: 0; + border-left: 0; + line-height: 1; + white-space: nowrap; + vertical-align: middle; + -webkit-appearance: none; + -moz-appearance: none; + appearance: none; + text-align: center; + -webkit-box-sizing: border-box; + box-sizing: border-box; + margin: 0; + cursor: pointer; + -webkit-transition: all 0.3s cubic-bezier(0.645, 0.045, 0.355, 1); + transition: all 0.3s cubic-bezier(0.645, 0.045, 0.355, 1); +} +.tiny-radio-button__inner.is-round { + padding: 12px 20px; +} +.tiny-radio-button__inner:hover { + color: var(--ti-radio-button-hover-color); + background-color: var(--ti-radio-button-checked-hover-color); + border-color: var(--ti-radio-button-checked-hover-color); + outline: 0; +} +.tiny-radio-button__inner [class*='tiny-icon'] { + line-height: 0.9; +} +.tiny-radio-button__inner [class*='tiny-icon'] + span { + margin-left: 5px; +} +.tiny-radio-button__orig-radio { + opacity: 0; + outline: 0; + position: absolute; + z-index: -1; +} +.tiny-radio-button__orig-radio:checked + .tiny-radio-button__inner { + color: #fff; + background-color: var(--ti-radio-button-checked-normal-color); + border-color: var(--ti-radio-button-checked-normal-color); + -webkit-box-shadow: -1px 0 0 0 var(--ti-radio-button-checked-normal-color); + box-shadow: -1px 0 0 0 var(--ti-radio-button-checked-normal-color); +} +.tiny-radio-button__orig-radio:checked + .tiny-radio-button__inner:hover { + background-color: var(--ti-radio-button-checked-hover-color); + border-color: var(--ti-radio-button-checked-hover-color); + -webkit-box-shadow: -1px 0 0 0 var(--ti-radio-button-checked-hover-color); + box-shadow: -1px 0 0 0 var(--ti-radio-button-checked-hover-color); +} +.tiny-radio-button__orig-radio:disabled + .tiny-radio-button__inner { + color: var(--ti-radio-button-disabled-color); + border-color: var(--ti-radio-button-border-color); + background-color: var(--ti-radio-button-disabled-bgcolor); + background-image: none; + -webkit-box-shadow: none; + box-shadow: none; + cursor: not-allowed; +} +.tiny-radio-button__orig-radio:disabled:checked + .tiny-radio-button__inner { + background-color: var(--ti-radio-input-checked-disabled-color); +} +.tiny-radio-button__orig-radio:disabled:checked + .tiny-radio-button__inner, +.tiny-radio-button__orig-radio:disabled:checked + .tiny-radio-button__inner:hover { + border-color: var(--ti-radio-input-checked-disabled-color); +} +.tiny-radio-button--medium .tiny-radio-button__inner { + font-size: var(--ti-radio-button-medium-font-size); + padding: 10px 20px; + border-radius: 0; +} +.tiny-radio-button--medium .tiny-radio-button__inner.is-round { + padding: 10px 20px; +} +.tiny-radio-button--small .tiny-radio-button__inner { + font-size: var(--ti-radio-button-font-size); + padding: 9px 15px; + border-radius: 0; +} +.tiny-radio-button--small .tiny-radio-button__inner.is-round { + padding: 9px 15px; +} +.tiny-radio-button--mini .tiny-radio-button__inner { + font-size: var(--ti-radio-button-font-size); + padding: 7px 15px; + border-radius: 0; +} +.tiny-radio-button--mini .tiny-radio-button__inner.is-round { + padding: 7px 15px; +} +.tiny-radio-button:focus:not(.is-focus):not(:active):not(.is-disabled) { + -webkit-box-shadow: 0 0 2px 2px var(--ti-radio-bordered-hover-border-color); + box-shadow: 0 0 2px 2px var(--ti-radio-bordered-hover-border-color); +} +.tiny-radio-group { + display: -webkit-inline-box; + display: -ms-inline-flexbox; + display: inline-flex; +} +.tiny-radio-group.list-inline { + -webkit-box-orient: vertical; + -webkit-box-direction: normal; + -ms-flex-direction: column; + flex-direction: column; +} +.tiny-radio-group.list-inline .tiny-radio { + display: -webkit-box; + display: -ms-flexbox; + display: flex; + margin-right: 0; +} +.tiny-radio-group.list-inline .tiny-radio:not(:last-child) { + margin-bottom: 8px; +} +.tiny-radio-group.list-inline .tiny-radio-button { + display: block; +} +.tiny-radio-group.list-inline .tiny-radio-button:first-child .tiny-radio-button__inner { + border-radius: var(--ti-radio-button-border-radius) var(--ti-radio-button-border-radius) 0 0; + border-top: 1px solid var(--ti-radio-button-border-color); +} +.tiny-radio-group.list-inline .tiny-radio-button:last-child .tiny-radio-button__inner { + border-radius: 0 0 var(--ti-radio-button-border-radius) var(--ti-radio-button-border-radius); +} +.tiny-radio-group.list-inline .tiny-radio-button.is-active .tiny-radio-button__inner { + -webkit-box-shadow: none; + box-shadow: none; + border-color: var(--ti-radio-button-checked-normal-color); +} +.tiny-radio-group.list-inline .tiny-radio-button.is-active.is-disabled .tiny-radio-button__inner { + border-color: var(--ti-radio-input-checked-disabled-color); +} +.tiny-radio-group.list-inline .tiny-radio-button__inner { + border-top: 0; + border-left: 1px solid var(--ti-radio-button-border-color); +} +.tiny-rate { + --ti-rate-bottom-font-size: var(--ti-common-font-size-base); + display: -webkit-inline-box; + display: -ms-inline-flexbox; + display: inline-flex; + outline: 0; +} +.tiny-rate:active, +.tiny-rate:focus { + outline-width: 0; +} +.tiny-rate .tiny-rate__star { + position: relative; + display: inline-block; + font-size: 0; + vertical-align: middle; + text-align: center; + line-height: 1; +} +.tiny-rate svg { + -webkit-transition: 0.3s; + transition: 0.3s; +} +.tiny-rate svg.hover { + -webkit-transform: scale(1.15); + transform: scale(1.15); +} +.tiny-rate .tiny-rate__decimal { + display: inline-block; + overflow: hidden; + font-size: var(--ti-common-font-size-2); + position: absolute; + top: 0; + left: 50%; + -webkit-transform: translateX(-50%); + transform: translateX(-50%); +} +.tiny-rate .tiny-rate__text { + vertical-align: middle; + margin-left: 8px; +} +.tiny-rate .tiny-rate__bottom-text { + position: relative; + font-size: var(--ti-rate-bottom-font-size); + text-align: center; + text-overflow: clip; + overflow: hidden; + margin-top: 8px; +} +.tiny-roles { + --ti-roles-poplist-item-height: var(--ti-base-size-height-minor); + --ti-roles-poplist-item-color: var(--ti-base-color-info-normal); + --ti-roles-poplist-item-font-size: var(--ti-common-font-size-base); + --ti-roles-poplist-item-hover-background: var(--ti-base-color-hover-background); + --ti-roles-poplist-item-selected-background: var(--ti-base-color-selected-background); + --ti-roles-poplist-item-selected-font-color: var(--ti-base-color-selected-font-color); +} +.tiny-roles svg { + margin-left: 2px; +} +.tiny-roles__selector.tiny-popover.tiny-popper { + padding: 0; +} +.tiny-roles__selector .tiny-roles__poplist-item { + padding: 0 8px; +} +.tiny-roles__selector-body { + max-height: 300px; + overflow-y: auto; + overflow-x: hidden; +} +.tiny-roles__poplist { + min-width: 180px; +} +.tiny-roles__poplist-item { + min-height: var(--ti-roles-poplist-item-height); + line-height: var(--ti-roles-poplist-item-height); + max-width: 100%; + color: var(--ti-roles-poplist-item-color); + font-size: var(--ti-roles-poplist-item-font-size); + overflow: hidden; + text-overflow: ellipsis; + white-space: nowrap; + cursor: pointer; +} +.tiny-roles__poplist-item:hover { + background: var(--ti-roles-poplist-item-hover-background); +} +.tiny-roles__poplist-item.is-selected, +.tiny-roles__poplist-item.is-selected:hover { + background: var(--ti-roles-poplist-item-selected-background); + color: var(--ti-roles-poplist-item-selected-font-color); +} +.tiny-row { + width: 100%; +} +.tiny-row:after, +.tiny-row:before { + content: ''; + display: table; +} +.tiny-row:after { + clear: both; +} +.tiny-row.row-flex { + display: -webkit-box; + display: -ms-flexbox; + display: flex; +} +.tiny-row.row-justify-start { + -webkit-box-pack: start; + -ms-flex-pack: start; + justify-content: flex-start; +} +.tiny-row.row-justify-end { + -webkit-box-pack: end; + -ms-flex-pack: end; + justify-content: flex-end; +} +.tiny-row.row-justify-center { + -webkit-box-pack: center; + -ms-flex-pack: center; + justify-content: center; +} +.tiny-row.row-justify-space-around { + -ms-flex-pack: distribute; + justify-content: space-around; +} +.tiny-row.row-justify-space-between { + -webkit-box-pack: justify; + -ms-flex-pack: justify; + justify-content: space-between; +} +.tiny-row.row-align-top { + -webkit-box-align: start; + -ms-flex-align: start; + align-items: flex-start; +} +.tiny-row.row-align-middle { + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; +} +.tiny-row.row-align-bottom { + -webkit-box-align: end; + -ms-flex-align: end; + align-items: flex-end; +} +.tiny-scroll-text { + --ti-scroll-text-height: var(--ti-base-size-height-small); + --ti-scroll-text-background: #f1f1f1; + width: 300px; + height: var(--ti-scroll-text-height); + line-height: var(--ti-scroll-text-height); + background: var(--ti-scroll-text-background); + margin: 0 auto; + overflow: hidden; +} +.tiny-scroll-text .tiny-scroll-text__content { + width: -webkit-max-content; + width: -moz-max-content; + width: max-content; + height: 100%; + padding: 0 8px; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + white-space: nowrap; + position: relative; + -webkit-animation: infinite linear; + animation: infinite linear; + -webkit-animation-duration: 7s; + animation-duration: 7s; + -webkit-animation-iteration-count: infinite; + animation-iteration-count: infinite; + -webkit-animation-timing-function: linear; + animation-timing-function: linear; +} +@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) { + .tiny-scroll-text .tiny-scroll-text__content { + display: inline-block; + } +} +@supports (-ms-ime-align: auto) { + .tiny-scroll-text .tiny-scroll-text__content { + display: inline-block; + } +} +.tiny-scroll-text .tiny-scroll-text__content.left { + -webkit-animation-name: moveLeft; + animation-name: moveLeft; +} +.tiny-scroll-text .tiny-scroll-text__content.right { + -webkit-animation-name: moveRight; + animation-name: moveRight; +} +.tiny-scroll-text .tiny-scroll-text__content.up { + -webkit-animation-name: moveUp; + animation-name: moveUp; +} +.tiny-scroll-text .tiny-scroll-text__content.down { + -webkit-animation-name: moveDown; + animation-name: moveDown; +} +.tiny-scroll-text .tiny-scroll-text__content.singleUp { + -webkit-animation-name: singleUp; + animation-name: singleUp; +} +.tiny-scroll-text .tiny-scroll-text__content.stop { + -webkit-animation-play-state: paused; + animation-play-state: paused; +} +.tiny-scroll-text .tiny-scroll-text__content.down, +.tiny-scroll-text .tiny-scroll-text__content.up { + width: 100%; + white-space: normal; +} +.tiny-scroll-text .tiny-scroll-text__content p { + width: auto; + line-height: 1; + margin: 0; +} +@-webkit-keyframes moveLeft { + 0% { + -webkit-transform: translateX(300px); + transform: translateX(300px); + } + 100% { + -webkit-transform: translateX(-100%); + transform: translateX(-100%); + } +} +@keyframes moveLeft { + 0% { + -webkit-transform: translateX(300px); + transform: translateX(300px); + } + 100% { + -webkit-transform: translateX(-100%); + transform: translateX(-100%); + } +} +@-webkit-keyframes moveRight { + 0% { + -webkit-transform: translateX(-100%); + transform: translateX(-100%); + } + 100% { + -webkit-transform: translateX(300px); + transform: translateX(300px); + } +} +@keyframes moveRight { + 0% { + -webkit-transform: translateX(-100%); + transform: translateX(-100%); + } + 100% { + -webkit-transform: translateX(300px); + transform: translateX(300px); + } +} +@-webkit-keyframes moveUp { + 0% { + -webkit-transform: translateY(100%); + transform: translateY(100%); + } + 100% { + -webkit-transform: translateY(-100%); + transform: translateY(-100%); + } +} +@keyframes moveUp { + 0% { + -webkit-transform: translateY(100%); + transform: translateY(100%); + } + 100% { + -webkit-transform: translateY(-100%); + transform: translateY(-100%); + } +} +@-webkit-keyframes moveDown { + 0% { + -webkit-transform: translateY(-100%); + transform: translateY(-100%); + } + 100% { + -webkit-transform: translateY(100%); + transform: translateY(100%); + } +} +@keyframes moveDown { + 0% { + -webkit-transform: translateY(-100%); + transform: translateY(-100%); + } + 100% { + -webkit-transform: translateY(100%); + transform: translateY(100%); + } +} +.tiny-scrollbar { + overflow: hidden; + position: relative; +} +.tiny-scrollbar:active > .tiny-scrollbar__bar, +.tiny-scrollbar:focus > .tiny-scrollbar__bar, +.tiny-scrollbar:hover > .tiny-scrollbar__bar { + opacity: 1; + -webkit-transition: opacity 340ms ease-out; + transition: opacity 340ms ease-out; +} +.tiny-scrollbar__wrap { + overflow: scroll; + height: 100%; + max-height: 200px; +} +.tiny-scrollbar__wrap--hidden-default::-webkit-scrollbar { + width: 0; + height: 0; +} +.tiny-scrollbar__thumb { + position: relative; + display: block; + width: 0; + height: 0; + cursor: pointer; + border-radius: inherit; + background-color: rgba(144, 147, 153, 0.3); + -webkit-transition: 0.3s background-color; + transition: 0.3s background-color; +} +.tiny-scrollbar__thumb:hover { + background-color: rgba(144, 147, 153, 0.5); +} +.tiny-scrollbar__bar { + position: absolute; + right: 2px; + bottom: 2px; + z-index: 1; + border-radius: 4px; + opacity: 0; + -webkit-transition: opacity 120ms ease-out; + transition: opacity 120ms ease-out; +} +.tiny-scrollbar__bar.is-vertical { + width: 6px; + top: 2px; +} +.tiny-scrollbar__bar.is-vertical > div { + width: 100%; +} +.tiny-scrollbar__bar.is-horizontal { + height: 6px; + left: 2px; +} +.tiny-scrollbar__bar.is-horizontal > div { + height: 100%; +} +.tiny-transition-search-line-fade-enter, +.tiny-transition-search-line-fade-enter-from, +.tiny-transition-search-line-fade-leave-to { + opacity: 0; +} +.tiny-transition-search-line-fade-enter-to { + opacity: 0; +} +.tiny-transition-search-line-fade-enter-active, +.tiny-transition-search-line-fade-leave-active { + -webkit-transition: opacity 0.3s; + transition: opacity 0.3s; +} +.tiny-search { + --ti-search-font-size: var(--ti-common-font-size-base); + --ti-search-input-height: var(--ti-base-size-height-normal); + --ti-search-inputinner-height: var(--ti-base-size-height-small); + --ti-search-input-color: var(--ti-base-color-info-normal); + --ti-search-input-background: var(--ti-base-color-light); + --ti-search-input-btn-color: var(--ti-base-color-brand-6); + --ti-search-input-btn-hover-color: var(--ti-base-color-brand-5); + --ti-search-input-btn-font-size: var(--ti-common-font-size-1); + --ti-search-input-border-color: var(--ti-base-color-border); + --ti-search-icon-border-color: #dbdbdb; + --ti-search-icon-color: #c4c4c4; + --ti-search-size-height-normal: var(--ti-base-size-height-normal); + --ti-search-size-height-small: var(--ti-base-size-height-small); + --ti-search-selector-color: var(--ti-base-color-info-normal); + --ti-search-line-hover-color: var(--ti-base-color-border-hover); + --ti-search-list-hover-background: var(--ti-base-color-selected-background); + --ti-search-selector-radius: var(--ti-common-border-radius-normal); + --ti-search-selector-background: var(--ti-base-color-light); + --ti-search-selector-list-height: var(--ti-base-size-height-normal); + position: relative; + display: inline-block; + font-size: var(--ti-search-font-size); + width: 100%; +} +.tiny-search .tiny-search__line { + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + width: 100%; + height: var(--ti-search-input-height); + border: 1px solid var(--ti-search-input-border-color); + border-radius: var(--ti-common-border-radius-normal); + background-color: var(--ti-search-input-background); + -webkit-transition: 0.4s; + transition: 0.4s; + border-collapse: separate; +} +.tiny-search .tiny-search__line:hover { + border-color: var(--ti-search-line-hover-color); +} +.tiny-search .tiny-search__line.focus, +.tiny-search .tiny-search__line:focus { + border-color: var(--ti-search-input-btn-color); +} +.tiny-search .tiny-search__input { + width: 100%; + height: 100%; + line-height: 1; + color: var(--ti-search-input-color); + padding: 0 0 0 8px; + border: 0; + outline: 0; + background: 0 0; +} +.tiny-search .tiny-search__input::-moz-placeholder { + color: #999; + opacity: 1; +} +.tiny-search .tiny-search__input:-ms-input-placeholder { + color: #999; +} +.tiny-search .tiny-search__input::-webkit-input-placeholder { + color: #999; +} +.tiny-search .tiny-search__input::-ms-input-placeholder { + color: #999; +} +.tiny-search .tiny-search__input::placeholder { + color: #999; +} +.tiny-search .tiny-search__input:focus::-moz-placeholder { + color: #d9d9d9; + opacity: 1; +} +.tiny-search .tiny-search__input:focus:-ms-input-placeholder { + color: #d9d9d9; +} +.tiny-search .tiny-search__input:focus::-webkit-input-placeholder { + color: #d9d9d9; +} +.tiny-search .tiny-search__input:focus::-ms-input-placeholder { + color: #d9d9d9; +} +.tiny-search .tiny-search__input:focus::placeholder { + color: #d9d9d9; +} +.tiny-search .tiny-search__input-btn { + text-align: center; +} +.tiny-search .tiny-search__input-btn a { + text-decoration: none; + display: block; + width: var(--ti-search-inputinner-height); + height: 100%; + line-height: var(--ti-search-inputinner-height); +} +.tiny-search .tiny-search__input-btn svg { + fill: var(--ti-search-input-btn-color); + font-size: var(--ti-search-input-btn-font-size); +} +.tiny-search .tiny-search__input-btn:hover svg { + fill: var(--ti-search-input-btn-hover-color); +} +.tiny-search .tiny-search__present { + color: var(--ti-search-selector-color); + line-height: var(--ti-search-size-height-normal); + padding-left: 8px; + white-space: nowrap; +} +.tiny-search .tiny-search__present .icon-outer { + height: calc(var(--ti-search-size-height-normal) - 12px); + line-height: calc(var(--ti-search-size-height-normal) - 12px); + display: inline-block; + padding: 0 8px 0 4px; + border-right: 1px solid var(--ti-search-input-border-color); + cursor: pointer; +} +.tiny-search .tiny-search__present .icon-outer svg { + font-size: var(--ti-search-input-btn-font-size); + fill: var(--ti-search-icon-color); +} +.tiny-search .tiny-search__selector { + position: absolute; + top: 32px; + left: 0; + overflow: hidden; + min-width: 68px; + border: 1px solid var(--ti-search-input-border-color); + border-radius: var(--ti-search-selector-radius); + font-size: var(--ti-search-font-size); + -webkit-box-shadow: var(--ti-base-box-shadow); + box-shadow: var(--ti-base-box-shadow); + background: var(--ti-search-selector-background); + color: var(--ti-search-selector-color); + margin-top: 2px; +} +.tiny-search .tiny-search__selector-body { + max-height: 300px; + overflow-y: auto; + overflow-x: hidden; +} +.tiny-search .tiny-search__poplist-item { + min-height: var(--ti-search-selector-list-height); + padding: 0 8px; + line-height: var(--ti-search-selector-list-height); + max-width: 100%; + font-size: var(--ti-search-font-size); + overflow: hidden; + text-align: left; + text-overflow: ellipsis; + white-space: nowrap; +} +.tiny-search .tiny-search__poplist-item:hover { + background: var(--ti-search-list-hover-background); + cursor: pointer; +} +.tiny-search .tiny-search__poplist-item span { + font-size: var(--ti-search-font-size); +} +.tiny-search .tiny-search__poplist-item .icon-check { + font-size: var(--ti-common-font-size-2); +} +.tiny-search .tiny-search__poplist-item .icon-check:hover { + color: var(--ti-search-input-btn-hover-color); +} +.tiny-search.mini .tiny-search__line { + border-radius: var(--ti-search-input-height); + width: 100%; + float: right; +} +.tiny-search.mini.collapse .tiny-search__input-btn svg { + fill: var(--ti-search-icon-color); +} +.tiny-search.mini .tiny-search__input { + border-radius: var(--ti-search-input-height); +} +.tiny-search.collapse .tiny-search__input { + padding: 0; + width: var(--ti-search-size-height-normal); + float: right; +} +.tiny-search.mini.collapse .tiny-search__line { + width: 30px; + float: right; + background-color: transparent; + border-collapse: separate; +} +.tiny-search.mini.collapse .tiny-search__input, +.tiny-search.mini.collapse .tiny-search__present { + display: none; +} +.tiny-search .fade-enter-to { + opacity: 0; +} +.tiny-search .fade-enter, +.tiny-search .fade-leave-to { + opacity: 0; +} +.tiny-select { + --ti-select-inner-hover-border-color: var(--ti-base-color-brand-5); + --ti-select-input-color: #666; + --ti-select-input-font-size: var(--ti-common-font-size-base); + --ti-select-input-caret-color: var(--ti-base-color-brand-6); + --ti-select-input-caret-hover-color: var(--ti-base-color-brand-5); + --ti-select-input-caret-font-size: var(--ti-common-font-size-1); + --ti-select-input-caret-close-color: var(--ti-base-color-bg-5); + --ti-select-input-caret-close-hover-color: var(--ti-base-color-placeholder); + --ti-select-input-disabled-caret-color: var(--ti-base-color-border); + --ti-select-input-disabled-inner-hover-border-color: #e4e7ed; + --ti-select-input-mini-height: var(--ti-base-size-height-mini); + --ti-select-input-small-height: var(--ti-base-size-height-small); + --ti-select-input-medium-height: var(--ti-base-size-height-medium); + display: inline-block; + position: relative; + width: 100%; + outline: 0; +} +.tiny-select .tiny-select__tags > span { + display: contents; +} +.tiny-select__input { + border: none; + outline: 0; + padding: 0; + margin-left: 8px; + color: var(--ti-select-input-color); + font-size: var(--ti-select-input-font-size); + height: 28px; + -webkit-appearance: none; + -moz-appearance: none; + appearance: none; + background-color: transparent; +} +.tiny-select__input.is-mini { + height: var(--ti-select-input-mini-height); +} +.tiny-select__input.is-small { + height: var(--ti-select-input-small-height); +} +.tiny-select__input.is-medium { + height: var(--ti-select-input-medium-height); +} +@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) { + .tiny-select.tiny-select__multiple:not(.tiny-select__collapse-tags):not(.tiny-select__filterable) + .tiny-select__tags + > span { + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -ms-flex-wrap: wrap; + flex-wrap: wrap; + -webkit-box-pack: start; + -ms-flex-pack: start; + justify-content: flex-start; + -ms-flex-line-pack: start; + align-content: flex-start; + } +} +@supports (-ms-ime-align: auto) { + .tiny-select.tiny-select__multiple:not(.tiny-select__collapse-tags):not(.tiny-select__filterable) + .tiny-select__tags + > span { + width: 100%; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -ms-flex-wrap: wrap; + flex-wrap: wrap; + -webkit-box-pack: start; + -ms-flex-pack: start; + justify-content: flex-start; + -ms-flex-line-pack: start; + align-content: flex-start; + } +} +.tiny-select.tiny-select__collapse-tags .tiny-select__tags > span { + display: -webkit-box; + display: -ms-flexbox; + display: flex; + width: 100%; +} +.tiny-select.tiny-select__collapse-tags .tiny-select__tags > span > span:not(:only-child):first-child { + max-width: 70%; +} +.tiny-select.tiny-select__collapse-tags.tiny-select__filterable .tiny-select__tags > span { + width: auto; + max-width: 76%; +} +.tiny-select.tiny-select__collapse-tags.tiny-select__filterable .tiny-select__tags > span > span:first-child { + -webkit-box-flex: 1; + -ms-flex: 1; + flex: 1; +} +@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) { + .tiny-select.tiny-select__collapse-tags.tiny-select__filterable .tiny-select__tags > span > span:first-child { + -ms-flex-preferred-size: auto; + flex-basis: auto; + } +} +.tiny-select.tiny-select__collapse-tags.tiny-select__filterable + .tiny-select__tags + > span + > span:not(:only-child):first-child, +.tiny-select.tiny-select__collapse-tags.tiny-select__filterable .tiny-select__tags > span > span:only-child { + max-width: 100%; +} +@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) { + .tiny-select.tiny-select__collapse-tags.tiny-select__filterable + .tiny-select__tags + > span + > span:not(:only-child):not(:first-child) { + -ms-flex-negative: 0; + flex-shrink: 0; + -ms-flex-preferred-size: auto; + flex-basis: auto; + } +} +.tiny-select__tags { + position: absolute; + line-height: normal; + white-space: normal; + padding-left: 4px; + z-index: 1; + top: 50%; + -webkit-transform: translateY(-50%); + transform: translateY(-50%); + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + -ms-flex-wrap: wrap; + flex-wrap: wrap; +} +.tiny-select__tags.is-showicon { + padding-left: 24px; +} +.tiny-select__tags .tiny-tag.tiny-tag--info { + white-space: nowrap; + text-overflow: ellipsis; + overflow: hidden; + display: -webkit-inline-box; + display: -ms-inline-flexbox; + display: inline-flex; + -webkit-box-pack: start; + -ms-flex-pack: start; + justify-content: flex-start; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; +} +.tiny-select__tags-text { + width: 100%; + white-space: nowrap; + text-overflow: ellipsis; + overflow: hidden; +} +.tiny-select__tags-text + .tiny-tag__close { + -ms-flex-negative: 0; + flex-shrink: 0; +} +.tiny-select-tip .tiny-select-tipcontent { + max-width: 300px; +} +.tiny-select .tiny-input .tiny-select__caret { + fill: var(--ti-select-input-caret-color); + font-size: var(--ti-select-input-caret-font-size); + -webkit-transition: -webkit-transform 0.3s; + transition: -webkit-transform 0.3s; + transition: transform 0.3s; + transition: transform 0.3s, -webkit-transform 0.3s; + -webkit-transform: rotateZ(180deg); + transform: rotateZ(180deg); + cursor: pointer; +} +.tiny-select .tiny-input .tiny-select__caret:hover { + fill: var(--ti-select-input-caret-hover-color); +} +.tiny-select .tiny-input .tiny-select__caret.is-reverse { + -webkit-transform: rotateZ(0); + transform: rotateZ(0); +} +.tiny-select .tiny-input .tiny-select__caret.is-show-close { + font-size: var(--ti-select-input-font-size); + text-align: center; + -webkit-transform: rotateZ(180deg); + transform: rotateZ(180deg); + border-radius: 100%; + fill: var(--ti-select-input-caret-close-color); + -webkit-transition: fill 0.2s cubic-bezier(0.645, 0.045, 0.355, 1); + transition: fill 0.2s cubic-bezier(0.645, 0.045, 0.355, 1); +} +.tiny-select .tiny-input .tiny-select__caret.is-show-close:hover { + color: var(--ti-select-input-caret-close-hover-color); +} +.tiny-select .tiny-input .tiny-select__copy { + cursor: pointer; +} +.tiny-select .tiny-input.is-disabled .tiny-select__caret { + fill: var(--ti-select-input-disabled-caret-color); + cursor: not-allowed; +} +.tiny-select .tiny-input.is-disabled .tiny-input__inner { + cursor: not-allowed; +} +.tiny-select .tiny-input.is-disabled .tiny-input__inner:hover { + border-color: var(--ti-select-input-disabled-inner-hover-border-color); +} +.tiny-select .tiny-input.is-focus .tiny-input__inner { + border-color: var(--ti-select-inner-hover-border-color); +} +.tiny-select > .tiny-input { + display: block; +} +.tiny-select .tiny-tag { + white-space: nowrap; + -webkit-box-sizing: border-box; + box-sizing: border-box; + border-color: transparent; + margin: 2px 0 2px 4px; + background-color: #f0f2f5; +} +.tiny-select-dropdown { + --ti-select-dropdown-border-color: transparent; + --ti-select-dropdown-border-radius: var(--ti-common-border-radius-normal); + --ti-select-dropdown-bgcolor: var(--ti-base-color-light); + --ti-select-dropdown-empty-color: var(--ti-base-color-placeholder); + --ti-select-dropdown-empty-font-size: var(--ti-common-font-size-1); + --ti-select-dropdown-list-padding: 0 0 6px 0; + --ti-select-dropdown-item-padding: 0 8px; + --ti-select-dropdown-item-gap: 0; + position: absolute; + z-index: 1001; + border: 1px solid var(--ti-select-dropdown-border-color); + border-radius: var(--ti-select-dropdown-border-radius); + background-color: var(--ti-select-dropdown-bgcolor); + -webkit-box-shadow: var(--ti-base-box-shadow); + box-shadow: var(--ti-base-box-shadow); + margin-top: var(--ti-base-dropdown-gap); + -webkit-box-sizing: border-box; + box-sizing: border-box; +} +.tiny-select-dropdown .tiny-tree { + max-height: 300px; + overflow-y: auto; +} +.tiny-select-dropdown.tiny-popper { + margin-top: var(--ti-base-dropdown-gap); +} +.tiny-select-dropdown .tiny-scrollbar.is-empty .tiny-select-dropdown__list { + padding: 0; +} +.tiny-select-dropdown__empty { + padding: 10px 0; + margin: 0; + text-align: center; + color: var(--ti-select-dropdown-empty-color); + font-size: var(--ti-select-dropdown-empty-font-size); +} +.tiny-select-dropdown .tiny-select-dropdown__wrap { + max-height: 197px; + margin-right: -4px; +} +.tiny-select-dropdown .tiny-select-dropdown__list { + list-style: none; + margin: 0; + -webkit-box-sizing: border-box; + box-sizing: border-box; + padding: var(--ti-select-dropdown-list-padding); + text-align: left; +} +.tiny-select-dropdown .tiny-select-dropdown__item { + white-space: nowrap; + -webkit-box-sizing: border-box; + box-sizing: border-box; + padding: var(--ti-select-dropdown-item-padding); + margin-top: var(--ti-select-dropdown-item-gap); + border-radius: var(--ti-common-border-radius-normal); +} +.tiny-select-dropdown .tiny-select-dropdown__wrap.virtual { + position: relative; + margin-right: 0 !important; +} +.tiny-select-dropdown .tiny-select-dropdown__wrap.virtual .tiny-select-dropdown__item { + position: absolute; + width: 100%; +} +.tiny-slide-bar { + --ti-slider-progress-box-border-color: var(--ti-base-color-light); + --ti-slider-progress-box-hover-border-color: rgba(153, 153, 153, 0.7); + --ti-slider-progress-box-arrow-normal: #f2f2f2; + --ti-slider-progress-box-arrow-hover: #808080; + --ti-slider-progress-box-middleline-normal: #ebebeb; + padding: 0 32px; + position: relative; +} +.tiny-slide-bar > .tiny-svg { + position: absolute; + top: 50%; + -webkit-transform: translateY(-50%); + transform: translateY(-50%); + font-size: 2em; + cursor: pointer; + fill: var(--ti-slider-progress-box-arrow-normal); +} +.tiny-slide-bar > .tiny-svg:hover { + fill: var(--ti-slider-progress-box-arrow-hover); +} +.tiny-slide-bar > .tiny-svg.tiny-disabled, +.tiny-slide-bar > .tiny-svg.tiny-disabled:hover { + background: 0 0; + fill: #fff; + cursor: default; +} +.tiny-slide-bar > .icon-chevron-left { + left: 0; +} +.tiny-slide-bar > .icon-chevron-right { + right: 0; +} +.tiny-slide-bar li li div { + margin: 15px 0; + font-size: var(--ti-common-font-size-base); + color: #4e5e67; +} +.tiny-slide-bar li li div:nth-child(2) { + border-bottom: 1px solid var(--ti-slider-progress-box-middleline-normal); +} +.tiny-slide-bar li li div svg { + float: right; + margin: -6px 0 0 0; + background: #fff; + fill: var(--ti-slider-progress-box-middleline-normal); +} +.tiny-slide-bar .tiny-slide-bar__content { + width: 100%; + min-height: 170px; + position: relative; + overflow: hidden; +} +.tiny-slide-bar .tiny-slide-bar__list { + position: absolute; + min-height: 170px; + display: -webkit-box; + display: -ms-flexbox; + display: flex; +} +.tiny-slide-bar .tiny-slide-bar__list > li { + width: 23%; + padding: 20px; + float: left; + margin-left: 2%; + position: relative; + border: 5px solid var(--ti-slider-progress-box-border-color); + -webkit-box-sizing: border-box; + box-sizing: border-box; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; +} +.tiny-slide-bar .tiny-slide-bar__list > li:first-child { + margin-left: 0; +} +.tiny-slide-bar .tiny-slide-bar__list > li:hover { + border-color: var(--ti-slider-progress-box-hover-border-color); +} +.tiny-slide-bar .tiny-slide-bar__list > li > .icon-chevron-down { + position: absolute; + top: 98.8%; + left: 50%; + margin-left: -10px; + font-size: 2em; + width: 22px; + display: none !important; +} +.tiny-slide-bar .tiny-slide-bar__list > li > .icon-chevron-down:before { + content: ''; + position: absolute; + width: 20px; + height: 20px; + border-right: 5px solid var(--ti-slider-progress-box-hover-border-color); + border-bottom: 5px solid var(--ti-slider-progress-box-hover-border-color); + -webkit-transform: rotate(45deg); + transform: rotate(45deg); + background: #fff; + top: -5px; +} +.tiny-slide-bar .tiny-slide-bar__list > li > ul { + width: 100%; + list-style: none; +} +.tiny-slide-bar .tiny-slide-bar__list > li.tiny-slide-bar__select { + border-color: var(--ti-slider-progress-box-hover-border-color); +} +.tiny-slide-bar .tiny-slide-bar__list > li.tiny-slide-bar__select > .icon-chevron-down { + display: block !important; +} +.tiny-slide-bar .tiny-slide-bar__list > li.tiny-slide-bar__select li .tiny-icon { + color: var(--ti-slider-progress-box-hover-border-color); +} +.tiny-slide-bar .tiny-slide-bar__list > li.tiny-slide-bar__select li:nth-child(2) { + border-bottom: 1px solid var(--ti-slider-progress-box-hover-border-color); +} +.tiny-split { + --ti-split-border-color: #d9d9d9; + --ti-split-trigger-background: #d9d9d9; + --ti-split-trigger-bar-background: var(--ti-base-color-secondary); + --ti-split-trigger-hover-background: var(--ti-split-trigger-background); + --ti-split-trigger-bar-hover-background: var(--ti-split-trigger-bar-background); + --ti-split-trigger-bar-con-background: var(--ti-base-color-light); + --ti-split-trigger-size: 4px; + --ti-split-trigger-con-col-cursor: e-resize; + --ti-split-trigger-con-row-cursor: n-resize; +} +.tiny-split-wrapper { + position: relative; + width: 100%; + height: 100%; + overflow: hidden; +} +.tiny-split-pane { + position: absolute; +} +.tiny-split-pane.left-pane, +.tiny-split-pane.right-pane { + top: 0; + bottom: 0; + overflow: hidden; +} +.tiny-split-pane.left-pane { + left: 0; +} +.tiny-split-pane.right-pane { + right: 0; +} +.tiny-split-pane.bottom-pane, +.tiny-split-pane.top-pane { + left: 0; + right: 0; + overflow: hidden; +} +.tiny-split-pane.top-pane { + top: 0; +} +.tiny-split-pane.bottom-pane { + bottom: 0; +} +.tiny-split-pane-moving { + -ms-user-select: none; + -webkit-user-select: none; + -o-user-select: none; + -moz-user-select: none; + user-select: none; +} +.tiny-split-trigger-con { + position: absolute; + -webkit-transform: translate(-50%, -50%); + transform: translate(-50%, -50%); + z-index: 10; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + -webkit-box-pack: center; + -ms-flex-pack: center; + justify-content: center; +} +.tiny-split-trigger-con:hover .tiny-split-trigger { + background: var(--ti-split-trigger-hover-background); +} +.tiny-split-trigger-con:hover .tiny-split-trigger-bar { + background: var(--ti-split-trigger-bar-hover-background); +} +.tiny-split-trigger-bar-con { + position: absolute; + overflow: hidden; + background: var(--ti-split-trigger-bar-con-background); +} +.tiny-split-trigger-bar-con.vertical { + top: 50%; + height: calc(var(--ti-split-trigger-size) * 7); + -webkit-transform: translate(0, -50%); + transform: translate(0, -50%); + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-orient: vertical; + -webkit-box-direction: normal; + -ms-flex-direction: column; + flex-direction: column; +} +.tiny-split-trigger-bar-con.horizontal { + left: 50%; + width: calc(var(--ti-split-trigger-size) * 7); + -webkit-transform: translate(-50%, 0); + transform: translate(-50%, 0); +} +.tiny-split-trigger-vertical { + width: var(--ti-split-trigger-size); + height: 100%; + background: var(--ti-split-trigger-background); +} +.tiny-split-trigger-vertical .tiny-split-trigger-bar { + width: var(--ti-split-trigger-size); + height: var(--ti-split-trigger-size); + background: var(--ti-split-trigger-bar-background); + float: left; + margin-top: var(--ti-split-trigger-size); + border-radius: 50%; +} +.tiny-split-trigger-horizontal { + height: var(--ti-split-trigger-size); + width: 100%; + background: var(--ti-split-trigger-background); +} +.tiny-split-trigger-horizontal .tiny-split-trigger-bar { + height: var(--ti-split-trigger-size); + width: var(--ti-split-trigger-size); + background: var(--ti-split-trigger-bar-background); + float: left; + margin-left: var(--ti-split-trigger-size); + border-radius: 50%; +} +.tiny-split-horizontal .tiny-split-trigger-con { + top: 50%; + height: 100%; + width: 10px; + cursor: var(--ti-split-trigger-con-col-cursor); +} +.tiny-split-horizontal .tiny-split-vertical .tiny-split-trigger-con { + left: 50%; + height: 10px; + width: 100%; +} +.tiny-split-vertical .tiny-split-trigger-con { + left: 50%; + height: 10px; + width: 100%; + cursor: var(--ti-split-trigger-con-row-cursor); +} +.tiny-split-vertical .tiny-split-horizontal .tiny-split-trigger-con { + top: 50%; + height: 100%; + width: 10px; +} +.tiny-split .no-select { + -ms-user-select: none; + -webkit-user-select: none; + -o-user-select: none; + -moz-user-select: none; + user-select: none; +} +.tiny-steps { + --ti-steps-advanced-active-color: var(--ti-base-color-brand-6); + --ti-steps-done-active-color: var(--ti-base-color-brand-6); + --ti-steps-done-icon-fill-color: var(--ti-base-color-brand-6); + --ti-steps-done-icon-color: var(--ti-base-color-light); + --ti-steps-line-background: #dbdbdb; + --ti-steps-done-font-color: var(--ti-base-color-info-normal); + --ti-steps-line-height: var(--ti-common-size-base); + --ti-steps-line-active-color: var(--ti-base-color-brand-6); + --ti-steps-advanced-border-color: var(--ti-base-color-border); + --ti-steps-advanced-text: var(--ti-base-color-placeholder); + --ti-steps-advanced-line-height: 28px; + --ti-steps-advanced-li-color: var(--ti-base-color-light); + --ti-steps-advanced-li-font-color: var(--ti-base-color-light); + --ti-steps-advanced-li-hover-color: var(--ti-base-color-placeholder); + --ti-steps-advanced-li-hover-bgcolor: #f1f1f1; + --ti-steps-advanced-link-font-size: var(--ti-common-font-size-base); + --ti-steps-advanced-dot-height: 12px; + --ti-steps-advanced-dot-width: 12px; + --ti-steps-advanced-dot-done-background: var(--ti-base-color-success-normal); + --ti-steps-advanced-dot-doing-background: #faad14; + --ti-steps-advanced-dot-wait-background: var(--ti-base-color-success-normal); + --ti-steps-advanced-count-bgcolor: var(--ti-base-color-bg-8); + --ti-steps-advanced-count-border-radius: 10px; + --ti-steps-advanced-count-font-size: var(--ti-common-font-size-base); + --ti-steps-advanced-count-height: 18px; + --ti-steps-advanced-border-size: 14px; + --ti-steps-timeline-date-time-font-size: var(--ti-common-font-size-base); + --ti-steps-timeline-name-font-size: var(--ti-common-font-size-1); + --ti-steps-timeline-date-time-color: var(--ti-base-color-placeholder); + --ti-steps-icon-size: var(--ti-common-size-5x); + --ti-steps-font-size-7: var(--ti-common-font-size-7); + --ti-steps-font-size-base: var(--ti-common-font-size-base); + --ti-steps-icon-font-size: var(--ti-common-font-size-base); + --ti-steps-icon-background: #d9d9d9; + --ti-steps-unselected-color: var(--ti-base-color-light); + color: var(--ti-steps-timeline-date-time-color); +} +.tiny-steps .tiny-steps-advanced li { + line-height: var(--ti-steps-advanced-line-height); + display: inline-block; + background: var(--ti-steps-advanced-li-color); + position: relative; +} +.tiny-steps .tiny-steps-advanced li.current a { + background: var(--ti-steps-advanced-active-color); + color: var(--ti-steps-advanced-li-font-color); + font-weight: 700; +} +.tiny-steps .tiny-steps-advanced li.current a::after { + border-left-color: var(--ti-steps-advanced-active-color); +} +.tiny-steps .tiny-steps-advanced li a { + border: solid 1px var(--ti-steps-advanced-border-color); + border-right: none; + display: block; + text-align: center; + position: relative; + text-decoration: none; + color: var(--ti-steps-advanced-text); + font-size: var(--ti-steps-advanced-link-font-size); +} +.tiny-steps .tiny-steps-advanced li a::after { + content: ''; + border-top: 14px solid transparent; + border-bottom: 14px solid transparent; + border-left: 9px solid #fff; + position: absolute; + right: -9px; + top: 0; + z-index: 1; +} +.tiny-steps .tiny-steps-advanced li a::before { + content: ''; + border-top: 14px solid transparent; + border-bottom: 14px solid transparent; + border-left: 9px solid #d7d8da; + position: absolute; + left: 0; + top: 0; +} +.tiny-steps .tiny-steps-advanced li a:hover { + background: var(--ti-steps-advanced-li-hover-bgcolor); + color: var(--ti-steps-advanced-li-hover-color); + text-decoration: none; +} +.tiny-steps .tiny-steps-advanced li a:hover::after { + border-left-color: var(--ti-steps-advanced-li-hover-bgcolor); +} +.tiny-steps .tiny-steps-advanced li:first-child a { + border-top-left-radius: 3px; + border-bottom-left-radius: 3px; +} +.tiny-steps .tiny-steps-advanced li:first-child a::before { + display: none; +} +.tiny-steps .tiny-steps-advanced li:last-child a { + border-right: solid 1px var(--ti-steps-advanced-border-color); + border-top-right-radius: 3px; + border-bottom-right-radius: 3px; +} +.tiny-steps .tiny-steps-advanced li:last-child a::after { + display: none; +} +.tiny-steps .tiny-steps-advanced li .dot { + height: var(--ti-steps-advanced-dot-height); + width: var(--ti-steps-advanced-dot-width); + margin-right: 8px; + padding: 0; + right: 0; + top: 50%; + -webkit-transform: translateY(-50%); + transform: translateY(-50%); + display: -webkit-box; + display: -ms-flexbox; + display: flex; + position: absolute; +} +.tiny-steps .tiny-steps-advanced li .dot svg { + width: 100%; + height: 100%; + fill: var(--ti-steps-advanced-text); +} +.tiny-steps .tiny-steps-advanced li.current .dot svg, +.tiny-steps .tiny-steps-advanced li.current .dot svg:hover { + fill: var(--ti-steps-advanced-li-color); +} +.tiny-steps .tiny-steps-advanced li:hover .dot svg { + fill: var(--ti-steps-advanced-text); +} +.tiny-steps .tiny-steps-advanced .count { + background-color: var(--ti-steps-advanced-count-bgcolor); + border-radius: var(--ti-steps-advanced-count-border-radius); + color: var(--ti-steps-advanced-li-font-color); + display: inline-block; + font-size: var(--ti-steps-advanced-count-font-size); + height: var(--ti-steps-advanced-count-height); + line-height: var(--ti-steps-advanced-count-height); + padding: 0 6px; + text-align: center; + white-space: nowrap; + position: absolute; + top: -10px; + right: 10px; +} +.tiny-steps .line { + background: var(--ti-steps-line-background); +} +.tiny-steps .icon { + width: var(--ti-steps-icon-size); + height: var(--ti-steps-icon-size); + line-height: var(--ti-steps-icon-size); + position: relative; + font-size: var(--ti-steps-icon-font-size); + text-align: center; + left: calc(50% - 10px); + top: 4px; + border-radius: 50%; + background: var(--ti-steps-icon-background); + color: var(--ti-steps-unselected-color); + cursor: pointer; + z-index: 15; +} +.tiny-steps .date-time { + text-align: center; +} +.tiny-steps .node-description { + position: relative; + margin-top: 6px; + overflow: hidden; + text-align: center; +} +.tiny-steps .node-description .name { + font-size: var(--ti-steps-font-size-base); + float: left; + width: 100%; +} +.tiny-steps .node-description .status { + font-size: var(--ti-steps-font-size-base); + float: left; + width: 100%; +} +.tiny-steps .process-done .node-description { + color: var(--ti-steps-done-font-color); +} +.tiny-steps .process-done .icon { + background: var(--ti-steps-done-icon-color); + color: var(--ti-steps-done-icon-fill-color); + width: var(--ti-steps-icon-size); + height: var(--ti-steps-icon-size); + line-height: var(--ti-steps-icon-size); + font-size: var(--ti-steps-icon-size); +} +.tiny-steps .process-done .icon .tiny-svg { + fill: var(--ti-steps-done-icon-fill-color); + vertical-align: baseline; + border: 1px solid var(--ti-steps-done-active-color); + border-radius: 50%; + padding: 2px; +} +.tiny-steps .process-done .line { + background: var(--ti-steps-line-active-color); +} +.tiny-steps .process-current .icon { + background: var(--ti-steps-advanced-active-color); + color: var(--ti-steps-advanced-li-font-color); + font-size: var(--ti-steps-font-size-base); +} +.tiny-steps .reverse .process-current .line { + background: var(--ti-steps-line-active-color); +} +.tiny-steps .tiny-steps-normal { + overflow: hidden; +} +.tiny-steps .tiny-steps-normal .normal { + display: block; + float: left; +} +.tiny-steps .tiny-steps-normal .line { + height: var(--ti-steps-line-height); + left: 50%; + top: -8px; + position: relative; +} +.tiny-steps .tiny-steps-normal .line-end { + width: 0; +} +.tiny-steps .tiny-steps-normal .process-done .line { + background: var(--ti-steps-line-active-color); +} +.tiny-steps .tiny-steps-normal .process-current .name { + color: var(--ti-steps-advanced-active-color); + font-weight: 700; +} +.tiny-steps .tiny-steps-normal .icon span { + display: inline-block; +} +.tiny-steps .tiny-steps-timeline { + overflow: hidden; + font-size: var(--ti-steps-timeline-name-font-size); + color: var(--ti-steps-timeline-date-time-color); +} +.tiny-steps .tiny-steps-timeline .timeline .line { + width: var(--ti-steps-line-height); + float: left; +} +.tiny-steps .tiny-steps-timeline .timeline .line .tiny-svg { + vertical-align: baseline; +} +.tiny-steps .tiny-steps-timeline .timeline .date-time { + width: 100px; + float: left; + padding-right: 20px; + text-align: right; +} +.tiny-steps .tiny-steps-timeline .timeline .date-time .time { + display: block; + line-height: 1; +} +.tiny-steps .tiny-steps-timeline .timeline .date-time .date { + display: block; + line-height: 1; + margin-bottom: 4px; +} +.tiny-steps .tiny-steps-timeline .timeline.process-done { + color: var(--ti-steps-done-font-color); +} +.tiny-steps .tiny-steps-timeline .timeline.process-current { + color: var(--ti-steps-advanced-active-color); +} +.tiny-steps .tiny-steps-timeline .timeline .name { + float: left; + margin-left: 20px; + line-height: 1.45em; +} +.tiny-steps .tiny-steps-timeline .timeline .icon { + top: 0; +} +.tiny-steps.mobile { + padding-left: 10%; +} +.tiny-steps.mobile .tiny-steps-timeline { + overflow: inherit; +} +.tiny-steps.mobile .tiny-steps-timeline .tiny-icon { + font-size: 45px; +} +.tiny-steps.mobile .tiny-steps-timeline .timeline .line .icon { + width: 45px; + line-height: 45px; + height: 45px; + font-size: var(--ti-steps-font-size-7); + position: relative; + left: -20px; +} +.tiny-steps.mobile .tiny-steps-timeline .timeline .name { + margin-left: 30px; + font-size: 26px; +} +.tiny-steps.mobile .tiny-steps-timeline .timeline > div { + margin-left: 20px; +} +.tiny-switch { + --ti-switch-on-bgcolor: var(--ti-base-color-brand-6); + --ti-switch-off-bgcolor: var(--ti-base-color-common-2); + --ti-switch-disabled-bgcolor: var(--ti-base-color-common-1); + --ti-switch-checked-disabled-bgcolor: var(--ti-base-color-brand-3); + --ti-switch-disabled-text-color: var(--ti-base-color-bg-5); + --ti-switch-disabled-dot-color: var(--ti-base-color-bg-5); + --ti-switch-font-color: var(--ti-base-color-light); + --ti-switch-dot-color: var(--ti-base-color-light); + --ti-switch-width: 38px; + --ti-switch-height: 20px; + --ti-switch-border-radius: 24px; + --ti-switch-inner-font-size: var(--ti-common-font-size-base, 12px); + --ti-switch-dot-size: 16px; + --ti-switch-dot-offset: calc(var(--ti-switch-dot-size) + 1px); + --ti-switch-text-width: 45px; + display: inline-block; + width: var(--ti-switch-width); + height: var(--ti-switch-height); + line-height: var(--ti-switch-height); + border-radius: var(--ti-switch-border-radius); + vertical-align: middle; + border: 1px solid var(--ti-switch-off-bgcolor); + background-color: var(--ti-switch-off-bgcolor); + position: relative; + cursor: pointer; + outline: 0; + -webkit-transition: all 0.2s ease-in-out; + transition: all 0.2s ease-in-out; +} +.tiny-switch .tiny-switch-inner { + color: var(--ti-switch-font-color); + font-size: var(--ti-switch-inner-font-size); + position: absolute; + left: calc(var(--ti-switch-dot-size) + 4px); + top: -1px; +} +.tiny-switch__text { + width: var(--ti-switch-text-width); +} +.tiny-switch__text .tiny-switch-inner { + left: calc(var(--ti-switch-dot-size) + 9px); +} +.tiny-switch.mini { + width: calc(var(--ti-switch-width) - 6px); +} +.tiny-switch.disabled, +.tiny-switch.tiny-switch-checked.disabled { + cursor: not-allowed; + background: var(--ti-switch-disabled-bgcolor); + border-color: var(--ti-switch-disabled-bgcolor); +} +.tiny-switch.disabled::after, +.tiny-switch.tiny-switch-checked.disabled::after { + background: var(--ti-switch-disabled-dot-color); + cursor: not-allowed; +} +.tiny-switch.disabled .tiny-switch-inner, +.tiny-switch.tiny-switch-checked.disabled .tiny-switch-inner { + color: var(--ti-switch-disabled-text-color); +} +.tiny-switch.tiny-switch-checked.disabled { + background: var(--ti-switch-checked-disabled-bgcolor); + border-color: var(--ti-switch-checked-disabled-bgcolor); +} +.tiny-switch::after { + content: ''; + width: var(--ti-switch-dot-size); + height: var(--ti-switch-dot-size); + border-radius: 50%; + background-color: var(--ti-switch-dot-color); + position: absolute; + left: 1px; + top: 1px; + cursor: pointer; + -webkit-transition: left 0.2s ease-in-out, width 0.2s ease-in-out; + transition: left 0.2s ease-in-out, width 0.2s ease-in-out; +} +.tiny-switch.tiny-switch-checked { + border-color: var(--ti-switch-on-bgcolor); + background-color: var(--ti-switch-on-bgcolor); +} +.tiny-switch.tiny-switch-checked .tiny-switch-inner { + left: 8px; + width: calc(100% - var(--ti-switch-dot-size)); + overflow: hidden; +} +.tiny-switch.tiny-switch-checked:after { + left: calc(100% - var(--ti-switch-dot-offset)); +} +.tiny-table { + --ti-table-color: var(--ti-base-color-info-normal); + --ti-table-bgcolor: #fafafa; + --ti-table-odd-bgcolor: var(--ti-base-color-light); + --ti-table-hover-bgcolor: var(--ti-base-color-hover-background); + --ti-table-disabled-color: var(--ti-base-color-placeholder); + --ti-table-disabled-bgcolor: #f1f1f1; + --ti-table-nodata-color: #909399; + --ti-table-td-height: var(--ti-base-size-height-medium); + --ti-table-td-font-size: var(--ti-common-font-size-base); + --ti-table-border-color: var(--ti-base-color-border); + --ti-table-thead-bgcolor: var(--ti-base-color-brand-1); + --ti-table-icon-font-size: var(--ti-common-font-size-2); + --ti-table-icon-check-color: var(--ti-base-color-brand-6); +} +.tiny-table.simple table { + table-layout: fixed; +} +.tiny-table.simple table tr { + display: table-row; + vertical-align: inherit; + border-color: inherit; +} +.tiny-table.simple table tbody { + border-bottom: 1px solid var(--ti-table-border-color); +} +.tiny-table.simple table tbody tr { + color: var(--ti-table-color); + background: var(--ti-table-bgcolor); +} +.tiny-table.simple table tbody tr:nth-child(odd) { + background: var(--ti-table-odd-bgcolor); +} +.tiny-table.simple table tbody tr:hover { + background: var(--ti-table-hover-bgcolor); +} +.tiny-table.simple table tbody tr.is-disabled { + background: var(--ti-table-disabled-bgcolor); + color: var(--ti-table-disabled-color); +} +.tiny-table.simple table tbody .noData { + width: 582px; + height: 360px; + text-align: center; + color: var(--ti-table-nodata-color); + margin-bottom: -1px; + border-bottom: 1px solid var(--ti-table-border-color); + padding-top: 10px; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-pack: center; + -ms-flex-pack: center; + justify-content: center; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; +} +.tiny-table.simple table th { + padding: 2px 0 2px 8px; + height: var(--ti-table-td-height); + border-left: none; +} +.tiny-table.simple table td { + padding: 2px 0 2px 8px; + height: var(--ti-table-td-height); + font-size: var(--ti-table-td-font-size); +} +.tiny-table.simple table td .overflow { + white-space: nowrap; + overflow: hidden; + text-overflow: ellipsis; +} +.tiny-table.simple table thead { + border-bottom: 1px solid var(--ti-table-border-color); + text-align: left; + background: var(--ti-table-thead-bgcolor); + color: var(--ti-table-color); +} +.tiny-table.simple table thead th { + overflow: hidden; + text-overflow: ellipsis; + white-space: nowrap; + text-align: left; + font-size: var(--ti-table-td-font-size); + color: var(--ti-table-color); + line-height: 1.7em; +} +.tiny-table.simple table thead th .overflow { + white-space: nowrap; + overflow: hidden; + text-overflow: ellipsis; +} +.tiny-table.simple .tiny-table-header__line { + float: right; + border-left: 1px solid var(--ti-table-border-color); + height: 20px; +} +.tiny-table.simple .tiny-table-cell .tiny-svg { + font-size: var(--ti-common-font-size-2); + font-size: var(--ti-table-icon-font-size); + fill: var(--ti-table-border-color); +} +.tiny-table.simple .tiny-table-cell .tiny-svg.is-check { + fill: var(--ti-table-icon-check-color); +} +.tiny-tabs { + --ti-tabs-header-font-normal: var(--ti-base-color-common-5); + --ti-tabs-header-font-active: var(--ti-base-color-brand-6); + --ti-tabs-header-color: var(--ti-base-color-brand-6); + --ti-tabs-header-background: #f5f5f5; + --ti-tabs-border-color: var(--ti-common-color-line-dividing); + --ti-tabs-height: var(--ti-common-size-10x); + --ti-tabs-item-disabled-color: #b4bccc; + --ti-tabs-icon-close-hover-color: var(--ti-base-color-light); + --ti-tabs-new-height: 18px; + --ti-tabs-new-width: 18px; + --ti-tabs-new-radius: var(--ti-base-radius-large); + --ti-tabs-new-svg-color: var(--ti-base-color-placeholder); + --ti-tabs-font-base-size: var(--ti-common-font-size-base); + --ti-tabs-more-hover-color: var(--ti-base-color-brand-5); + --ti-tabs-more-item-hover-color: var(--ti-base-color-hover-background); + --ti-tabs-dropdown-font-size: var(--ti-common-font-size-1); + --ti-tabs-dropdown-bgcolor: var(--ti-base-color-light); + --ti-tabs-dropdown-border-radius: var(--ti-common-border-radius-normal); + --ti-tabs-dropdown-li-color: var(--ti-base-color-secondary); + --ti-tabs-dropdown-li-border-color: #e6e6e6; + --ti-tabs-small-height: var(--ti-common-size-9x); + --ti-tab-dark-border-radius: var(--ti-common-border-radius-normal) var(--ti-common-border-radius-normal) 0 0; + --ti-tab-dark-text-color-active: var(--ti-base-color-common-7); + --ti-tab-dark-bg-color-avtive: var(--ti-base-color-bg-6); + --ti-tab-dark-text-color-hover: var(--ti-base-color-white); + --ti-tab-dark-bg-color-hover: var(--ti-base-color-common-4); + --ti-tab-dark-text-color: var(--ti-base-color-common-2); + --ti-tabs-header-dark-background: var(--ti-base-color-common-6); + --ti-tabs-item-margin: var(--ti-common-space-10x); + --ti-tabs-item-horizontal-padding: 0 var(--ti-common-space-3x); + --ti-tabs-item-vertical-padding: 0 var(--ti-common-space-5x); + --ti-tabs-item-active-border: 3px solid var(--ti-tabs-header-font-active); + --ti-tabs-item-border-bottom: 1px solid var(--ti-base-color-white); + --ti-tabs-item-card-active-bgcolor: var(--ti-base-color-white); + --ti-tabs-item-card-border-radius: 0; + --ti-tabs-icon-close-default-bgcolor: transparent; + --ti-tabs-icon-close-default-color: var(--ti-tabs-header-font-normal); + --ti-tabs-icon-close-hover-color: var(--ti-tabs-header-font-active); + --ti-tabs-icon-close-size: var(--ti-common-font-size-1); + --ti-tabs-icon-close-margin: 0 0 0 5px; +} +.tiny-tabs--left, +.tiny-tabs--right, +.tiny-tabs__content, +.tiny-tabs__nav-scroll, +.tiny-tabs__nav-wrap { + overflow: hidden; +} +.tiny-tabs__header { + padding: 0; + position: relative; + margin: 0; +} +.tiny-tabs__header .tiny-tabs__active-bar { + position: absolute; + bottom: 0; + left: 0; + height: 2px; + background-color: var(--ti-tabs-header-color); + z-index: 1; + -webkit-transition: -webkit-transform 0.3s cubic-bezier(0.645, 0.045, 0.355, 1); + transition: -webkit-transform 0.3s cubic-bezier(0.645, 0.045, 0.355, 1); + transition: transform 0.3s cubic-bezier(0.645, 0.045, 0.355, 1); + transition: transform 0.3s cubic-bezier(0.645, 0.045, 0.355, 1), + -webkit-transform 0.3s cubic-bezier(0.645, 0.045, 0.355, 1); + list-style: none; +} +.tiny-tabs__header .tiny-tabs__new-tab { + float: right; + border: 1px solid var(--ti-tabs-border-color); + height: var(--ti-tabs-new-height); + line-height: var(--ti-tabs-new-height); + width: var(--ti-tabs-new-width); + margin: 12px 0 9px 10px; + border-radius: var(--ti-tabs-new-radius); + font-size: var(--ti-tabs-font-base-size); + display: -webkit-inline-box; + display: -ms-inline-flexbox; + display: inline-flex; + -webkit-box-pack: center; + -ms-flex-pack: center; + justify-content: center; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + cursor: pointer; + -webkit-transition: all 0.15s; + transition: all 0.15s; + outline: 0; +} +.tiny-tabs__header .tiny-tabs__new-tab svg { + fill: var(--ti-tabs-new-svg-color); +} +.tiny-tabs__header .tiny-tabs__new-tab:hover svg { + fill: var(--ti-tabs-header-color); +} +.tiny-tabs__header .tiny-tabs__nav-wrap { + margin-bottom: -1px; + position: relative; +} +.tiny-tabs__header .tiny-tabs__nav-wrap::after { + content: ''; + position: absolute; + left: 0; + bottom: 0; + width: 100%; + height: 1px; + background-color: var(--ti-tabs-border-color); + z-index: 1; +} +.tiny-tabs__header .tiny-tabs__nav-wrap.is-scrollable { + padding: 0 20px; + -webkit-box-sizing: border-box; + box-sizing: border-box; +} +.tiny-tabs__header .tab-dropdown { + position: absolute; + right: 8px; + z-index: 90; + font-size: var(--ti-tabs-dropdown-font-size); + -webkit-box-shadow: 0 1px 2px 1px rgba(0, 0, 0, 0.18); + box-shadow: 0 1px 2px 1px rgba(0, 0, 0, 0.18); + background: var(--ti-tabs-dropdown-bgcolor); + border-radius: var(--ti-tabs-dropdown-border-radius); +} +.tiny-tabs__header .tab-dropdown:before { + position: absolute; + display: inline-block; + top: -5px; + left: 44%; + width: 0; + height: 0; + content: ''; + border-style: solid; + border-width: 6px; + border-color: #fff #fff transparent transparent; + -webkit-transform: rotate(-45deg); + transform: rotate(-45deg); + -webkit-box-shadow: 1px -1px 1px #e4e4e4; + box-shadow: 1px -1px 1px #e4e4e4; +} +.tiny-tabs__header .tab-dropdown li { + border-bottom: 1px solid var(--ti-tabs-dropdown-li-border-color); +} +.tiny-tabs__header .tab-dropdown li:last-child { + border-bottom: none; +} +.tiny-tabs__header .tab-dropdown li a { + white-space: nowrap; + color: var(--ti-tabs-dropdown-li-color); + line-height: 26px; + padding: 0 10px; + min-width: 100px; + display: block; + font-size: var(--ti-tabs-font-base-size); +} +.tiny-tabs__header .tab-dropdown li a:hover { + color: var(--ti-tabs-more-hover-color); + text-decoration: none; +} +.tiny-tabs__nav-more { + position: absolute; + cursor: pointer; + height: var(--ti-tabs-height); + line-height: var(--ti-tabs-height); + font-size: var(--ti-common-font-size-1); + right: 45px; + z-index: 99; + color: var(--ti-tabs-header-color); +} +.tiny-tabs__nav-next, +.tiny-tabs__nav-prev { + position: absolute; + cursor: pointer; + line-height: var(--ti-tabs-height); + font-size: var(--ti-common-font-size-base); + color: var(--ti-tabs-header-font-normal); +} +.tiny-tabs__nav-next { + right: 0; +} +.tiny-tabs__nav-prev { + left: 0; +} +.tiny-tabs__nav { + white-space: nowrap; + position: relative; + -webkit-transition: -webkit-transform 0.3s; + transition: -webkit-transform 0.3s; + transition: transform 0.3s; + transition: transform 0.3s, -webkit-transform 0.3s; + float: left; + z-index: 2; +} +.tiny-tabs__nav.is-stretch { + min-width: 100%; + display: -webkit-box; + display: -ms-flexbox; + display: flex; +} +.tiny-tabs__nav.is-stretch > * { + -webkit-box-flex: 1; + -ms-flex-positive: 1; + flex-grow: 1; + text-align: center; +} +.tiny-tabs__nav.is-show-active-bar .tiny-tabs__item { + margin-right: var(--ti-tabs-item-margin); +} +.tiny-tabs__nav.is-show-active-bar .tiny-tabs__item.is-active { + border-bottom: var(--ti-tabs-item-active-border); +} +.tiny-tabs__item { + height: var(--ti-tabs-height); + -webkit-box-sizing: border-box; + box-sizing: border-box; + line-height: var(--ti-tabs-height); + display: inline-block; + list-style: none; + font-size: var(--ti-tabs-dropdown-font-size); + color: var(--ti-tabs-header-font-normal); + display: -webkit-inline-box; + display: -ms-inline-flexbox; + display: inline-flex; + -webkit-box-pack: center; + -ms-flex-pack: center; + justify-content: center; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + position: relative; +} +.tiny-tabs__item:active, +.tiny-tabs__item:focus { + outline: 0; +} +.tiny-tabs__item.is-active, +.tiny-tabs__item:hover { + color: var(--ti-tabs-header-font-active); + cursor: pointer; +} +.tiny-tabs__item.is-active .tiny-tabs__icon-close svg, +.tiny-tabs__item:hover .tiny-tabs__icon-close svg { + fill: var(--ti-tabs-icon-close-hover-color); +} +.tiny-tabs__item.is-disabled { + color: var(--ti-tabs-item-disabled-color); + cursor: default; +} +.tiny-tabs__item.is-disabled .tiny-tabs__icon-close, +.tiny-tabs__item.is-disabled .tiny-tabs__icon-close:hover { + background-color: transparent; +} +.tiny-tabs__item.is-disabled .tiny-tabs__icon-close svg, +.tiny-tabs__item.is-disabled .tiny-tabs__icon-close:hover svg { + fill: var(--ti-tabs-item-disabled-color); +} +.tiny-tabs__item.is-closable > div { + display: inline-block; +} +.tiny-tabs__item > div { + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; +} +.tiny-tabs__item .tiny-tabs__icon-close { + border-radius: 50%; + text-align: center; + -webkit-transition: all 0.3s cubic-bezier(0.645, 0.045, 0.355, 1); + transition: all 0.3s cubic-bezier(0.645, 0.045, 0.355, 1); + margin: var(--ti-tabs-icon-close-margin); + display: -webkit-inline-box; + display: -ms-inline-flexbox; + display: inline-flex; + -webkit-box-pack: center; + -ms-flex-pack: center; + justify-content: center; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + vertical-align: middle; + background-color: var(--ti-tabs-icon-close-default-bgcolor); +} +.tiny-tabs__item .tiny-tabs__icon-close svg { + font-size: var(--ti-tabs-font-base-size); + -webkit-transform: scale(0.9); + transform: scale(0.9); + vertical-align: middle; + fill: var(--ti-tabs-icon-close-default-color); +} +.tiny-tabs__item .tiny-tabs__icon-close:hover { + background-color: var(--ti-tabs-icon-close-hover-bgcolor); +} +.tiny-tabs__item .tiny-tabs__icon-close:hover svg { + fill: var(--ti-tabs-icon-close-hover-color); +} +.tiny-tabs__content { + position: relative; + padding: 15px 24px; +} +.tiny-tabs .is-show-more { + padding: 0 48px 0 0; +} +.tiny-tabs__more-container { + position: absolute; + right: 0; + font-size: var(--ti-tabs-font-base-size); + color: var(--ti-tabs-header-font-normal); + line-height: var(--ti-tabs-height); +} +.tiny-tabs__more { + cursor: pointer; + color: var(--ti-tabs-header-color); + font-size: var(--ti-tabs-dropdown-font-size); + outline: 0; +} +.tiny-tabs__more:hover { + color: var(--ti-tabs-more-hover-color); +} +.tiny-tabs__more-popover.tiny-popover.tiny-popper { + padding: 0; + border-radius: var(--ti-tabs-dropdown-border-radius); + -webkit-box-shadow: 0 0 4px rgba(0, 0, 0, 0.15); + box-shadow: 0 0 4px rgba(0, 0, 0, 0.15); +} +.tiny-tabs__more-popover .tiny-tabs__more-item { + cursor: pointer; + padding: 8px 12px; + outline: 0; +} +.tiny-tabs__more-popover .tiny-tabs__more-item:hover { + background: var(--ti-tabs-more-item-hover-color); +} +.tiny-tabs.tiny-tabs--card.tiny-tabs--left .tiny-tabs__nav, +.tiny-tabs.tiny-tabs--card.tiny-tabs--right .tiny-tabs__nav { + width: 120px; +} +.tiny-tabs.tiny-tabs--card.tiny-tabs--top > .tiny-tabs__header .tiny-tabs__item.is-active { + top: -1px; + border-bottom: var(--ti-tabs-item-border-bottom); + border-top: 1px solid var(--ti-tabs-border-color); + border-left: 1px solid var(--ti-tabs-border-color); + border-right: 1px solid var(--ti-tabs-border-color); + background-color: var(--ti-tabs-item-card-active-bgcolor); + border-radius: var(--ti-tabs-item-card-border-radius); +} +.tiny-tabs.tiny-tabs--card.tiny-tabs--top > .tiny-tabs__header .tiny-tabs__item.is-active:before { + left: 0; + top: 0; +} +.tiny-tabs.tiny-tabs--card.tiny-tabs--top > .tiny-tabs__header .tiny-tabs__item.is-active.is-closable { + padding: var(--ti-tabs-item-horizontal-padding); +} +.tiny-tabs.tiny-tabs--card.tiny-tabs--bottom > .tiny-tabs__header .tiny-tabs__item.is-active { + -webkit-box-shadow: 0 -2px 0 0 #fff; + box-shadow: 0 -2px 0 0 #fff; +} +.tiny-tabs.tiny-tabs--card.tiny-tabs--bottom > .tiny-tabs__header .tiny-tabs__item.is-active:before { + left: 0; + bottom: 0; +} +.tiny-tabs.tiny-tabs--card.tiny-tabs--bottom > .tiny-tabs__header .tiny-tabs__item.is-active.is-closable { + padding: var(--ti-tabs-item-horizontal-padding); +} +.tiny-tabs.tiny-tabs--card > .tiny-tabs__header { + border-bottom: 1px solid var(--ti-tabs-border-color); +} +.tiny-tabs.tiny-tabs--card > .tiny-tabs__header .tiny-tabs__item { + border-bottom: 1px solid transparent; + border-left: 1px solid transparent; + border-right: 1px solid transparent; + border-top: 1px solid transparent; + -webkit-transition: color 0.3s cubic-bezier(0.645, 0.045, 0.355, 1), padding 0.3s cubic-bezier(0.645, 0.045, 0.355, 1); + transition: color 0.3s cubic-bezier(0.645, 0.045, 0.355, 1), padding 0.3s cubic-bezier(0.645, 0.045, 0.355, 1); +} +.tiny-tabs.tiny-tabs--card > .tiny-tabs__header .tiny-tabs__item:first-child { + border-left: none; +} +.tiny-tabs.tiny-tabs--card > .tiny-tabs__header .tiny-tabs__nav { + border-bottom: none; + top: 1px; +} +.tiny-tabs.tiny-tabs--border-card { + background: #fff; + border-top: 1px solid var(--ti-tabs-border-color); + -webkit-box-shadow: none; + box-shadow: none; +} +.tiny-tabs.tiny-tabs--border-card > .tiny-tabs__content { + padding: 0 24px 15px; +} +.tiny-tabs.tiny-tabs--border-card > .tiny-tabs__content .tiny-tabs__content { + padding: 15px 0; +} +.tiny-tabs.tiny-tabs--border-card.tiny-tabs--top > .tiny-tabs__header { + background-color: var(--ti-tabs-header-dark-background); + border: none; + margin: 0; +} +.tiny-tabs.tiny-tabs--border-card.tiny-tabs--top > .tiny-tabs__header .tiny-tabs__item { + -webkit-transition: all 0.3s cubic-bezier(0.645, 0.045, 0.355, 1); + transition: all 0.3s cubic-bezier(0.645, 0.045, 0.355, 1); + margin: -1px -1px 0; + color: var(--ti-tab-dark-text-color); + padding: 0 24px; + border: none; + height: 37px; + margin: 5px 4px 0 0; + line-height: 37px; +} +.tiny-tabs.tiny-tabs--border-card.tiny-tabs--top > .tiny-tabs__header .tiny-tabs__item:nth-child(2) { + padding: 0 12px; +} +.tiny-tabs.tiny-tabs--border-card.tiny-tabs--top > .tiny-tabs__header .tiny-tabs__item.is-active { + color: var(--ti-tab-dark-text-color-active); + background-color: var(--ti-tab-dark-bg-color-avtive); + border: none; + border-bottom-color: #fff; + border-radius: var(--ti-tab-dark-border-radius); +} +.tiny-tabs.tiny-tabs--border-card.tiny-tabs--top > .tiny-tabs__header .tiny-tabs__item.is-active:before { + left: 0; + top: 0; +} +.tiny-tabs.tiny-tabs--border-card.tiny-tabs--top > .tiny-tabs__header .tiny-tabs__item.is-active.is-closable { + padding: var(--ti-tabs-item-horizontal-padding); +} +.tiny-tabs.tiny-tabs--border-card.tiny-tabs--top > .tiny-tabs__header .tiny-tabs__item:not(.is-active):hover { + color: var(--ti-tab-dark-text-color-hover); + background: var(--ti-tab-dark-bg-color-hover); +} +.tiny-tabs.tiny-tabs--border-card.tiny-tabs--top > .tiny-tabs__header .tiny-tabs__item:first-child { + margin-left: 20px; +} +.tiny-tabs.tiny-tabs--border-card.tiny-tabs--top > .tiny-tabs__header .tiny-tabs__nav-next, +.tiny-tabs.tiny-tabs--border-card.tiny-tabs--top > .tiny-tabs__header .tiny-tabs__nav-prev { + fill: var(--ti-common-color-icon-white); +} +.tiny-tabs.tiny-tabs--border-card .tiny-tabs--border-card .tiny-tabs--bottom { + border-top: 0; +} +.tiny-tabs.tiny-tabs--border-card.tiny-tabs--bottom > .tiny-tabs__header .tiny-tabs__item.is-active:before, +.tiny-tabs.tiny-tabs--border-card.tiny-tabs--top > .tiny-tabs__header .tiny-tabs__item.is-active:before, +.tiny-tabs.tiny-tabs--card.tiny-tabs--bottom > .tiny-tabs__header .tiny-tabs__item.is-active:before, +.tiny-tabs.tiny-tabs--card.tiny-tabs--top > .tiny-tabs__header .tiny-tabs__item.is-active:before { + position: absolute; + content: ''; + width: 100%; + height: 0; + background: var(--ti-tabs-header-color); +} +.tiny-tabs.tiny-tabs--border-card.tiny-tabs--bottom > .tiny-tabs__header .tiny-tabs__item .tiny-tabs__icon-close, +.tiny-tabs.tiny-tabs--border-card.tiny-tabs--top > .tiny-tabs__header .tiny-tabs__item .tiny-tabs__icon-close, +.tiny-tabs.tiny-tabs--card.tiny-tabs--bottom > .tiny-tabs__header .tiny-tabs__item .tiny-tabs__icon-close, +.tiny-tabs.tiny-tabs--card.tiny-tabs--top > .tiny-tabs__header .tiny-tabs__item .tiny-tabs__icon-close { + display: -webkit-inline-box; + display: -ms-inline-flexbox; + display: inline-flex; + -webkit-box-pack: center; + -ms-flex-pack: center; + justify-content: center; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + width: var(--ti-tabs-icon-close-size); + height: var(--ti-tabs-icon-close-size); + line-height: var(--ti-tabs-icon-close-size); + vertical-align: middle; + overflow: hidden; + -webkit-transform-origin: 100% 50%; + transform-origin: 100% 50%; +} +.tiny-tabs.tiny-tabs--border-card.tiny-tabs--bottom .is-scrollable, +.tiny-tabs.tiny-tabs--border-card.tiny-tabs--top .is-scrollable, +.tiny-tabs.tiny-tabs--card.tiny-tabs--bottom .is-scrollable, +.tiny-tabs.tiny-tabs--card.tiny-tabs--top .is-scrollable { + padding: 0 24px; +} +.tiny-tabs.tiny-tabs--border-card > .tiny-tabs__header .tiny-tabs__nav-wrap:after, +.tiny-tabs.tiny-tabs--card > .tiny-tabs__header .tiny-tabs__nav-wrap:after { + content: none; +} +.tiny-tabs.tiny-tabs--small .tiny-tabs__item { + height: var(--ti-tabs-small-height); + line-height: var(--ti-tabs-small-height); +} +.tiny-tabs.tiny-tabs--left .tiny-tabs__header { + float: left; + margin-bottom: 0; + margin-right: 10px; +} +.tiny-tabs.tiny-tabs--left .tiny-tabs__nav-wrap { + margin-right: -1px; +} +.tiny-tabs.tiny-tabs--left .tiny-tabs__item { + text-align: left; +} +.tiny-tabs.tiny-tabs--left.tiny-tabs--card .tiny-tabs__item { + padding: var(--ti-tabs-item-vertical-padding); +} +.tiny-tabs.tiny-tabs--left.tiny-tabs--card > .tiny-tabs__header .tiny-tabs__item { + border-left: 1px solid var(--ti-tabs-border-color); + border-right: 1px solid var(--ti-tabs-border-color); + border-top: 1px solid var(--ti-tabs-border-color); + background-color: var(--ti-tabs-header-background); +} +.tiny-tabs.tiny-tabs--left.tiny-tabs--card > .tiny-tabs__header .tiny-tabs__item:first-child { + border-top: none; +} +.tiny-tabs.tiny-tabs--left.tiny-tabs--card > .tiny-tabs__header .tiny-tabs__item.is-active { + border-right-color: transparent; + border-left: var(--ti-tabs-item-active-border); + border-bottom: none; + background: 0 0; +} +.tiny-tabs.tiny-tabs--left.tiny-tabs--card > .tiny-tabs__header .tiny-tabs__item.is-active:first-child { + border-top: none; + border-right-color: transparent; +} +.tiny-tabs.tiny-tabs--left.tiny-tabs--card > .tiny-tabs__header .tiny-tabs__item.is-active:last-child { + border-bottom: none; +} +.tiny-tabs.tiny-tabs--left.tiny-tabs--card > .tiny-tabs__header .tiny-tabs__nav { + border-right: none; + border-left: none; +} +.tiny-tabs.tiny-tabs--left.tiny-tabs--card > .tiny-tabs__header .tiny-tabs__new-tab { + float: none; +} +.tiny-tabs.tiny-tabs--left.tiny-tabs--border-card .tiny-tabs__header { + border-right: 1px solid var(--ti-tabs-border-color); +} +.tiny-tabs.tiny-tabs--left.tiny-tabs--border-card .tiny-tabs__item { + border: 1px solid transparent; + margin: -1px -1px -1px 0; +} +.tiny-tabs.tiny-tabs--left.tiny-tabs--border-card .tiny-tabs__item.is-active { + border: 1px solid var(--ti-tabs-border-color); + border-left: none; +} +.tiny-tabs.tiny-tabs--left.tiny-tabs--border-card .tiny-tabs--border-card .tiny-tabs__item { + margin: -1px; +} +.tiny-tabs.tiny-tabs--left.tiny-tabs--border-card .tiny-tabs--border-card .tiny-tabs__item.is-bottom.is-active { + border-left: 1px solid var(--ti-tabs-border-color); +} +.tiny-tabs.tiny-tabs--left .tiny-tabs__active-bar, +.tiny-tabs.tiny-tabs--left .tiny-tabs__nav-wrap::after { + right: auto; + left: 0; +} +.tiny-tabs.tiny-tabs--right .tiny-tabs__nav-scroll { + height: 100%; +} +.tiny-tabs.tiny-tabs--right .tiny-tabs__header { + float: right; + margin-bottom: 0; + margin-left: 10px; +} +.tiny-tabs.tiny-tabs--right .tiny-tabs__header.is-left { + margin-left: 0; +} +.tiny-tabs.tiny-tabs--right .tiny-tabs__nav-wrap { + margin-left: -1px; +} +.tiny-tabs.tiny-tabs--right .tiny-tabs__nav-wrap.is-left { + margin-left: 0; +} +.tiny-tabs.tiny-tabs--right .tiny-tabs__nav-wrap:after { + left: 0; + right: auto; +} +.tiny-tabs.tiny-tabs--right.tiny-tabs--card .tiny-tabs__item { + border-top: 1px solid var(--ti-tabs-border-color); + border-bottom: none; + background-color: var(--ti-tabs-header-background); + padding: var(--ti-tabs-item-vertical-padding); +} +.tiny-tabs.tiny-tabs--right.tiny-tabs--card .tiny-tabs__item.is-active { + border-left-color: transparent; + border-right: var(--ti-tabs-item-active-border); + background: 0 0; +} +.tiny-tabs.tiny-tabs--right.tiny-tabs--card .tiny-tabs__item.is-active:first-child { + border-left: none; +} +.tiny-tabs.tiny-tabs--right.tiny-tabs--card .tiny-tabs__item.is-active:last-child { + border-bottom: none; +} +.tiny-tabs.tiny-tabs--right.tiny-tabs--card .tiny-tabs__item.is-active.is-bottom { + border-top: 0; + border-right: 0; + border-left-color: var(--ti-tabs-border-color); +} +.tiny-tabs.tiny-tabs--right.tiny-tabs--card .tiny-tabs__item.is-active.is-bottom:first-child { + border-left: 1px solid var(--ti-tabs-border-color); +} +.tiny-tabs.tiny-tabs--right.tiny-tabs--card .tiny-tabs__item:first-child { + border-left: 1px solid var(--ti-tabs-border-color); + border-top: none; +} +.tiny-tabs.tiny-tabs--right.tiny-tabs--card .tiny-tabs__item.is-bottom:first-child { + border-top: 1px solid var(--ti-tabs-border-color); +} +.tiny-tabs.tiny-tabs--right.tiny-tabs--card .tiny-tabs__item.is-bottom.is-active:first-child { + border-top: none; +} +.tiny-tabs.tiny-tabs--right.tiny-tabs--card .tiny-tabs__item.is-bottom, +.tiny-tabs.tiny-tabs--right.tiny-tabs--card .tiny-tabs__item.is-top { + background: 0 0; +} +.tiny-tabs.tiny-tabs--right.tiny-tabs--card .tiny-tabs__nav { + border-bottom: 1px solid var(--ti-tabs-border-color); + border-left: none; +} +.tiny-tabs.tiny-tabs--right.tiny-tabs--card .tiny-tabs__nav.is-bottom { + border-top: none; +} +.tiny-tabs.tiny-tabs--right.tiny-tabs--card .tiny-tab-pane .tiny-tabs--top .tiny-tabs__header { + margin-left: 0; +} +.tiny-tabs.tiny-tabs--right.tiny-tabs--card .tiny-tab-pane .tiny-tabs--top .tiny-tabs__item { + border-top: none; + border-bottom: 1px solid var(--ti-tabs-border-color); +} +.tiny-tabs.tiny-tabs--right.tiny-tabs--card .tiny-tab-pane .tiny-tabs--top .tiny-tabs__item.is-active { + top: 0; + border-right: 0; + border-left-color: var(--ti-tabs-border-color); + border-bottom: 1px solid #fff; +} +.tiny-tabs.tiny-tabs--right.tiny-tabs--card .tiny-tab-pane .tiny-tabs--top .tiny-tabs__item.is-active:first-child { + border-left: 1px solid var(--ti-tabs-border-color); +} +.tiny-tabs.tiny-tabs--right.tiny-tabs--card .tiny-tabs--border-card .tiny-tabs__item.is-top { + margin: 0 0 -1px -1px; +} +.tiny-tabs.tiny-tabs--right.tiny-tabs--card .tiny-tabs--border-card .tiny-tabs__item.is-top.is-active { + border-right: 1px solid var(--ti-tabs-border-color); +} +.tiny-tabs.tiny-tabs--right.tiny-tabs--card .tiny-tabs--border-card .tiny-tabs__item.is-bottom { + margin: -1px; +} +.tiny-tabs.tiny-tabs--right.tiny-tabs--card .tiny-tabs--border-card .tiny-tabs__item.is-bottom.is-active { + border-right: 1px solid var(--ti-tabs-border-color); +} +.tiny-tabs.tiny-tabs--right.tiny-tabs--card .tiny-tabs--border-card .tiny-tabs__item.is-right { + margin: -1px 0 -1px 0; +} +.tiny-tabs.tiny-tabs--right.tiny-tabs--card .tiny-tabs--border-card .tiny-tabs__item.is-right.is-active { + border-top: 1px solid var(--ti-tabs-border-color); + border-bottom: 1px solid var(--ti-tabs-border-color); + border-right: 3px solid var(--ti-tabs-header-font-active); +} +.tiny-tabs.tiny-tabs--right.tiny-tabs--card .tiny-tabs--border-card .tiny-tabs__nav.is-bottom { + border-bottom: 0; +} +.tiny-tabs.tiny-tabs--right.tiny-tabs--border-card .tiny-tabs__header { + border-left: 1px solid var(--ti-tabs-border-color); +} +.tiny-tabs.tiny-tabs--right.tiny-tabs--border-card .tiny-tabs__item { + border: 1px solid transparent; + margin: -1px -1px -1px 0; +} +.tiny-tabs.tiny-tabs--right.tiny-tabs--border-card .tiny-tabs__item.is-active { + border-color: var(--ti-tabs-border-color) transparent; +} +.tiny-tabs.tiny-tabs--right:not(.tiny-tabs--card) .tiny-tabs__active-bar { + left: auto; + right: 0; +} +.tiny-tabs.tiny-tabs--right:not(.tiny-tabs--card) .tiny-tabs__active-bar.is-bottom { + left: 0; +} +.tiny-tabs.tiny-tabs--right:not(.tiny-tabs--card) .tiny-tabs__active-bar.is-left { + left: 0; + right: auto; +} +.tiny-tabs.tiny-tabs--right:not(.tiny-tabs--card) .tiny-tabs__nav-wrap::after { + left: auto; + right: 0; +} +.tiny-tabs.tiny-tabs--right:not(.tiny-tabs--card) .tiny-tabs__nav-wrap.is-left::after { + left: 0; + right: auto; +} +.tiny-tabs.tiny-tabs--right .tiny-tab-pane .tiny-tabs__header.is-bottom { + margin-left: 0; +} +.tiny-tabs.tiny-tabs--right + .tiny-tab-pane + .tiny-tabs--top:not(.tiny-tabs--card):not(.tiny-tabs--border-card) + .tiny-tabs__item { + border-bottom: 0; + background-color: transparent; +} +.tiny-tabs.tiny-tabs--right .tiny-tabs--bottom:not(.tiny-tabs--card) .tiny-tabs__item { + border-top: 0; + background-color: transparent; +} +.tiny-tabs.tiny-tabs--right .tiny-tabs--left.tiny-tabs--card .tiny-tabs__item.is-active:first-child { + border-left: 3px solid var(--ti-tabs-header-font-active); + border-right: 0; +} +.tiny-tabs.tiny-tabs--right .tiny-tabs--left:not(.tiny-tabs--card) .tiny-tabs__nav, +.tiny-tabs.tiny-tabs--right .tiny-tabs--right:not(.tiny-tabs--card) .tiny-tabs__nav { + border-bottom: 0; +} +.tiny-tabs.tiny-tabs--right .tiny-tabs--left:not(.tiny-tabs--card) .tiny-tabs__item, +.tiny-tabs.tiny-tabs--right .tiny-tabs--right:not(.tiny-tabs--card) .tiny-tabs__item { + border: 0; + background-color: transparent; +} +.tiny-tabs.tiny-tabs--right .tiny-tabs--left.tiny-tabs--border-card .tiny-tabs__item.is-active { + border: 1px solid var(--ti-tabs-border-color); +} +.tiny-tabs.tiny-tabs--right .tiny-tabs--left.tiny-tabs--border-card .tiny-tabs__item.is-active.is-left { + border-left: 3px solid var(--ti-tabs-header-font-active); +} +.tiny-tabs.tiny-tabs--left .tiny-tabs__header, +.tiny-tabs.tiny-tabs--left .tiny-tabs__nav-wrap, +.tiny-tabs.tiny-tabs--right .tiny-tabs__header, +.tiny-tabs.tiny-tabs--right .tiny-tabs__nav-wrap { + height: 100%; +} +.tiny-tabs.tiny-tabs--left .tiny-tabs__active-bar, +.tiny-tabs.tiny-tabs--right .tiny-tabs__active-bar { + top: 1px; + bottom: auto; + width: 2px; + height: auto; +} +.tiny-tabs.tiny-tabs--left .tiny-tabs__active-bar.is-top, +.tiny-tabs.tiny-tabs--right .tiny-tabs__active-bar.is-top { + height: 3px; + bottom: 0; + left: 0; + top: auto; +} +.tiny-tabs.tiny-tabs--left .tiny-tabs__active-bar.is-bottom, +.tiny-tabs.tiny-tabs--right .tiny-tabs__active-bar.is-bottom { + top: auto; + bottom: 0; + height: 3px; +} +.tiny-tabs.tiny-tabs--left .tiny-tabs__nav-wrap, +.tiny-tabs.tiny-tabs--right .tiny-tabs__nav-wrap { + margin-bottom: 0; +} +.tiny-tabs.tiny-tabs--left .tiny-tabs__nav-wrap.is-scrollable, +.tiny-tabs.tiny-tabs--right .tiny-tabs__nav-wrap.is-scrollable { + padding: 30px 0; +} +.tiny-tabs.tiny-tabs--left .tiny-tabs__nav-wrap::after, +.tiny-tabs.tiny-tabs--right .tiny-tabs__nav-wrap::after { + height: 100%; + width: 2px; + bottom: auto; + top: 0; +} +.tiny-tabs.tiny-tabs--left .tiny-tabs__nav-wrap.is-top::after, +.tiny-tabs.tiny-tabs--right .tiny-tabs__nav-wrap.is-top::after { + left: 0; + bottom: 0; + top: auto; + width: 100%; + height: 1px; +} +.tiny-tabs.tiny-tabs--left .tiny-tabs__nav-wrap.is-bottom:after, +.tiny-tabs.tiny-tabs--right .tiny-tabs__nav-wrap.is-bottom:after { + left: 0; + bottom: 0; + top: auto; + width: 100%; + height: 1px; + background-color: #d9d9d9; + z-index: 1; +} +.tiny-tabs.tiny-tabs--left .tiny-tabs__nav, +.tiny-tabs.tiny-tabs--right .tiny-tabs__nav { + float: none; +} +.tiny-tabs.tiny-tabs--left .tiny-tabs__item, +.tiny-tabs.tiny-tabs--right .tiny-tabs__item { + display: block; + font-size: var(--ti-tabs-font-base-size); +} +.tiny-tabs.tiny-tabs--left .tiny-tabs__nav-next, +.tiny-tabs.tiny-tabs--left .tiny-tabs__nav-prev, +.tiny-tabs.tiny-tabs--right .tiny-tabs__nav-next, +.tiny-tabs.tiny-tabs--right .tiny-tabs__nav-prev { + height: 30px; + line-height: 30px; + width: 100%; + text-align: center; + cursor: pointer; +} +.tiny-tabs.tiny-tabs--left .tiny-tabs__nav-next i, +.tiny-tabs.tiny-tabs--left .tiny-tabs__nav-prev i, +.tiny-tabs.tiny-tabs--right .tiny-tabs__nav-next i, +.tiny-tabs.tiny-tabs--right .tiny-tabs__nav-prev i { + -webkit-transform: rotateZ(90deg); + transform: rotateZ(90deg); +} +.tiny-tabs.tiny-tabs--left .tiny-tabs__nav-prev, +.tiny-tabs.tiny-tabs--right .tiny-tabs__nav-prev { + left: auto; + top: 0; +} +.tiny-tabs.tiny-tabs--left .tiny-tabs__nav-next, +.tiny-tabs.tiny-tabs--right .tiny-tabs__nav-next { + right: auto; + bottom: 0; +} +.tiny-tabs.tiny-tabs--left .tiny-tab-pane .tiny-tabs__header, +.tiny-tabs.tiny-tabs--left .tiny-tab-pane .tiny-tabs__nav-wrap, +.tiny-tabs.tiny-tabs--right .tiny-tab-pane .tiny-tabs__header, +.tiny-tabs.tiny-tabs--right .tiny-tab-pane .tiny-tabs__nav-wrap { + float: inherit; + margin-bottom: -1px; +} +.tiny-tabs.tiny-tabs--left .tiny-tab-pane .tiny-tabs__header.is-bottom, +.tiny-tabs.tiny-tabs--left .tiny-tab-pane .tiny-tabs__header.is-top, +.tiny-tabs.tiny-tabs--left .tiny-tab-pane .tiny-tabs__nav-wrap.is-bottom, +.tiny-tabs.tiny-tabs--left .tiny-tab-pane .tiny-tabs__nav-wrap.is-top, +.tiny-tabs.tiny-tabs--right .tiny-tab-pane .tiny-tabs__header.is-bottom, +.tiny-tabs.tiny-tabs--right .tiny-tab-pane .tiny-tabs__header.is-top, +.tiny-tabs.tiny-tabs--right .tiny-tab-pane .tiny-tabs__nav-wrap.is-bottom, +.tiny-tabs.tiny-tabs--right .tiny-tab-pane .tiny-tabs__nav-wrap.is-top { + float: none; + margin-right: 0; +} +.tiny-tabs.tiny-tabs--left .tiny-tab-pane .tiny-tabs__header.is-left, +.tiny-tabs.tiny-tabs--left .tiny-tab-pane .tiny-tabs__nav-wrap.is-left, +.tiny-tabs.tiny-tabs--right .tiny-tab-pane .tiny-tabs__header.is-left, +.tiny-tabs.tiny-tabs--right .tiny-tab-pane .tiny-tabs__nav-wrap.is-left { + float: left; + margin-bottom: 0; +} +.tiny-tabs.tiny-tabs--left .tiny-tab-pane .tiny-tabs__header.is-right, +.tiny-tabs.tiny-tabs--left .tiny-tab-pane .tiny-tabs__nav-wrap.is-right, +.tiny-tabs.tiny-tabs--right .tiny-tab-pane .tiny-tabs__header.is-right, +.tiny-tabs.tiny-tabs--right .tiny-tab-pane .tiny-tabs__nav-wrap.is-right { + float: right; + margin-bottom: 0; + margin-right: 0; +} +.tiny-tabs.tiny-tabs--left .tiny-tab-pane .tiny-tabs__item, +.tiny-tabs.tiny-tabs--right .tiny-tab-pane .tiny-tabs__item { + display: inline-block; +} +.tiny-tabs.tiny-tabs--left .tiny-tab-pane .tiny-tabs__item.is-left, +.tiny-tabs.tiny-tabs--left .tiny-tab-pane .tiny-tabs__item.is-right, +.tiny-tabs.tiny-tabs--right .tiny-tab-pane .tiny-tabs__item.is-left, +.tiny-tabs.tiny-tabs--right .tiny-tab-pane .tiny-tabs__item.is-right { + display: inherit; +} +.tiny-tabs.tiny-tabs--left .tiny-tab-pane .tiny-tabs__nav, +.tiny-tabs.tiny-tabs--right .tiny-tab-pane .tiny-tabs__nav { + width: -webkit-fit-content; + width: -moz-fit-content; + width: fit-content; +} +.tiny-tabs.tiny-tabs--left.tiny-tabs--border-card, +.tiny-tabs.tiny-tabs--right.tiny-tabs--border-card { + border-top: 0; +} +.tiny-tabs.tiny-tabs--left.tiny-tabs--border-card .tiny-tabs__nav-wrap.is-scrollable, +.tiny-tabs.tiny-tabs--right.tiny-tabs--border-card .tiny-tabs__nav-wrap.is-scrollable { + padding: 0; +} +.tiny-tabs.tiny-tabs--left.tiny-tabs--border-card .tiny-tabs__nav-next, +.tiny-tabs.tiny-tabs--left.tiny-tabs--border-card .tiny-tabs__nav-prev, +.tiny-tabs.tiny-tabs--right.tiny-tabs--border-card .tiny-tabs__nav-next, +.tiny-tabs.tiny-tabs--right.tiny-tabs--border-card .tiny-tabs__nav-prev { + display: none; +} +.tiny-tabs.tiny-tabs--left.tiny-tabs--border-card .tiny-tabs__header, +.tiny-tabs.tiny-tabs--right.tiny-tabs--border-card .tiny-tabs__header { + border: 1px solid var(--ti-tabs-border-color); +} +.tiny-tabs.tiny-tabs--left.tiny-tabs--border-card .tiny-tabs--border-card .is-top.tiny-tabs__header, +.tiny-tabs.tiny-tabs--right.tiny-tabs--border-card .tiny-tabs--border-card .is-top.tiny-tabs__header { + border-top: 0; + border-left: 0; +} +.tiny-tabs.tiny-tabs--left.tiny-tabs--border-card .tiny-tabs--border-card .is-top.tiny-tabs__item.is-active, +.tiny-tabs.tiny-tabs--right.tiny-tabs--border-card .tiny-tabs--border-card .is-top.tiny-tabs__item.is-active { + border-left: 1px solid var(--ti-tabs-border-color); +} +.tiny-tabs.tiny-tabs--left.tiny-tabs--border-card .tiny-tabs--border-card .is-bottom.tiny-tabs__header, +.tiny-tabs.tiny-tabs--right.tiny-tabs--border-card .tiny-tabs--border-card .is-bottom.tiny-tabs__header { + border-left: 0; +} +.tiny-tabs.tiny-tabs--bottom .tiny-tabs__header { + margin-bottom: 0; + margin-top: 10px; +} +.tiny-tabs.tiny-tabs--bottom.tiny-tabs--border-card { + border-top: 0; +} +.tiny-tabs.tiny-tabs--bottom.tiny-tabs--border-card .tiny-tabs__header { + background: var(--ti-tabs-header-background); + border-bottom: 1px solid var(--ti-tabs-border-color); + border-right: 1px solid var(--ti-tabs-border-color); + border-top: 1px solid var(--ti-tabs-border-color); +} +.tiny-tabs.tiny-tabs--bottom.tiny-tabs--border-card .tiny-tabs__nav-wrap { + margin-top: -1px; + margin-bottom: 0; +} +.tiny-tabs.tiny-tabs--bottom.tiny-tabs--border-card .tiny-tabs__nav-wrap.is-top { + margin-bottom: -1px; +} +.tiny-tabs.tiny-tabs--bottom.tiny-tabs--border-card .tiny-tabs__item { + border: 1px solid transparent; + margin: 0 -1px -1px; +} +.tiny-tabs.tiny-tabs--bottom.tiny-tabs--border-card .tiny-tabs__item.is-active { + background-color: var(--ti-tabs-dropdown-bgcolor); + border-right-color: var(--ti-tabs-border-color); + border-left-color: var(--ti-tabs-border-color); +} +.tiny-tabs.tiny-tabs--bottom.tiny-tabs--border-card .tiny-tabs__item.is-active:before { + left: 0; + bottom: 0; +} +.tiny-tabs.tiny-tabs--bottom.tiny-tabs--border-card .tiny-tabs--border-card { + border-top: 0; +} +.tiny-tabs.tiny-tabs--bottom .tiny-tabs:not(.tiny-tabs--border-card):not(.tiny-tabs--card) .tiny-tabs__header { + background: 0 0; + border: 0; +} +.tiny-tabs.tiny-tabs--bottom + .tiny-tabs:not(.tiny-tabs--border-card):not(.tiny-tabs--card) + .tiny-tabs__header.is-left + .tiny-tabs__nav-next, +.tiny-tabs.tiny-tabs--bottom + .tiny-tabs:not(.tiny-tabs--border-card):not(.tiny-tabs--card) + .tiny-tabs__header.is-left + .tiny-tabs__nav-prev, +.tiny-tabs.tiny-tabs--bottom + .tiny-tabs:not(.tiny-tabs--border-card):not(.tiny-tabs--card) + .tiny-tabs__header.is-right + .tiny-tabs__nav-next, +.tiny-tabs.tiny-tabs--bottom + .tiny-tabs:not(.tiny-tabs--border-card):not(.tiny-tabs--card) + .tiny-tabs__header.is-right + .tiny-tabs__nav-prev { + display: none; +} +.tiny-tabs.tiny-tabs--bottom + .tiny-tabs:not(.tiny-tabs--border-card):not(.tiny-tabs--card) + .tiny-tabs__header.is-left + .tiny-tabs__nav-wrap, +.tiny-tabs.tiny-tabs--bottom + .tiny-tabs:not(.tiny-tabs--border-card):not(.tiny-tabs--card) + .tiny-tabs__header.is-right + .tiny-tabs__nav-wrap { + padding: 0; +} +.tiny-tabs.tiny-tabs--bottom .tiny-tabs:not(.tiny-tabs--border-card):not(.tiny-tabs--card) .tiny-tabs__item.is-active { + background-color: transparent; + border: none; +} +.tiny-tabs.tiny-tabs--bottom .tiny-tabs--left .tiny-tabs__item:nth-child(2), +.tiny-tabs.tiny-tabs--bottom .tiny-tabs--right .tiny-tabs__item:nth-child(2), +.tiny-tabs.tiny-tabs--bottom.tiny-tabs--border-card .tiny-tabs__item:nth-child(2), +.tiny-tabs.tiny-tabs--bottom.tiny-tabs--card .tiny-tabs__item, +.tiny-tabs.tiny-tabs--top .tiny-tabs--left .tiny-tabs__item:nth-child(2), +.tiny-tabs.tiny-tabs--top .tiny-tabs--right .tiny-tabs__item:nth-child(2), +.tiny-tabs.tiny-tabs--top.tiny-tabs--border-card .tiny-tabs__item:nth-child(2), +.tiny-tabs.tiny-tabs--top.tiny-tabs--card .tiny-tabs__item { + padding: var(--ti-tabs-item-horizontal-padding); +} +.tiny-tabs.tiny-tabs--bottom:not(.tiny-tabs--card):not(.tiny-tabs--border-card) .tiny-tabs__item, +.tiny-tabs.tiny-tabs--top:not(.tiny-tabs--card):not(.tiny-tabs--border-card) .tiny-tabs__item { + padding-left: 0; +} +.tiny-tabs.tiny-tabs--bottom:not(.tiny-tabs--card):not(.tiny-tabs--border-card) .tiny-tabs__item.is-left, +.tiny-tabs.tiny-tabs--top:not(.tiny-tabs--card):not(.tiny-tabs--border-card) .tiny-tabs__item.is-left { + padding: 0 24px; +} +.tiny-tabs.tiny-tabs--bottom:not(.tiny-tabs--card):not(.tiny-tabs--border-card) .tiny-tabs__item:nth-child(2), +.tiny-tabs.tiny-tabs--top:not(.tiny-tabs--card):not(.tiny-tabs--border-card) .tiny-tabs__item:nth-child(2) { + padding-left: 0; +} +.tiny-tabs .slideInLeft-transition, +.tiny-tabs .slideInRight-transition { + display: inline-block; +} +.tiny-tabs .slideInRight-enter { + -webkit-animation: slideInRight-enter 0.3s; + animation: slideInRight-enter 0.3s; +} +.tiny-tabs .slideInRight-leave { + position: absolute; + left: 0; + right: 0; + -webkit-animation: slideInRight-leave 0.3s; + animation: slideInRight-leave 0.3s; +} +.tiny-tabs .slideInLeft-enter { + -webkit-animation: slideInLeft-enter 0.3s; + animation: slideInLeft-enter 0.3s; +} +.tiny-tabs .slideInLeft-leave { + position: absolute; + left: 0; + right: 0; + -webkit-animation: slideInLeft-leave 0.3s; + animation: slideInLeft-leave 0.3s; +} +@-webkit-keyframes slideInRight-enter { + 0% { + opacity: 0; + -webkit-transform-origin: 0 0; + transform-origin: 0 0; + -webkit-transform: translateX(100%); + transform: translateX(100%); + } + to { + opacity: 1; + -webkit-transform-origin: 0 0; + transform-origin: 0 0; + -webkit-transform: translateX(0); + transform: translateX(0); + } +} +@keyframes slideInRight-enter { + 0% { + opacity: 0; + -webkit-transform-origin: 0 0; + transform-origin: 0 0; + -webkit-transform: translateX(100%); + transform: translateX(100%); + } + to { + opacity: 1; + -webkit-transform-origin: 0 0; + transform-origin: 0 0; + -webkit-transform: translateX(0); + transform: translateX(0); + } +} +@-webkit-keyframes slideInRight-leave { + 0% { + -webkit-transform-origin: 0 0; + transform-origin: 0 0; + -webkit-transform: translateX(0); + transform: translateX(0); + opacity: 1; + } + 100% { + -webkit-transform-origin: 0 0; + transform-origin: 0 0; + -webkit-transform: translateX(100%); + transform: translateX(100%); + opacity: 0; + } +} +@keyframes slideInRight-leave { + 0% { + -webkit-transform-origin: 0 0; + transform-origin: 0 0; + -webkit-transform: translateX(0); + transform: translateX(0); + opacity: 1; + } + 100% { + -webkit-transform-origin: 0 0; + transform-origin: 0 0; + -webkit-transform: translateX(100%); + transform: translateX(100%); + opacity: 0; + } +} +@-webkit-keyframes slideInLeft-enter { + 0% { + opacity: 0; + -webkit-transform-origin: 0 0; + transform-origin: 0 0; + -webkit-transform: translateX(-100%); + transform: translateX(-100%); + } + to { + opacity: 1; + -webkit-transform-origin: 0 0; + transform-origin: 0 0; + -webkit-transform: translateX(0); + transform: translateX(0); + } +} +@keyframes slideInLeft-enter { + 0% { + opacity: 0; + -webkit-transform-origin: 0 0; + transform-origin: 0 0; + -webkit-transform: translateX(-100%); + transform: translateX(-100%); + } + to { + opacity: 1; + -webkit-transform-origin: 0 0; + transform-origin: 0 0; + -webkit-transform: translateX(0); + transform: translateX(0); + } +} +@-webkit-keyframes slideInLeft-leave { + 0% { + -webkit-transform-origin: 0 0; + transform-origin: 0 0; + -webkit-transform: translateX(0); + transform: translateX(0); + opacity: 1; + } + 100% { + -webkit-transform-origin: 0 0; + transform-origin: 0 0; + -webkit-transform: translateX(-100%); + transform: translateX(-100%); + opacity: 0; + } +} +@keyframes slideInLeft-leave { + 0% { + -webkit-transform-origin: 0 0; + transform-origin: 0 0; + -webkit-transform: translateX(0); + transform: translateX(0); + opacity: 1; + } + 100% { + -webkit-transform-origin: 0 0; + transform-origin: 0 0; + -webkit-transform: translateX(-100%); + transform: translateX(-100%); + opacity: 0; + } +} +.tiny-tag { + --ti-tag-height: 22px; + --ti-tag-medium-height: var(--ti-common-size-6x); + --ti-tag-small-height: var(--ti-common-size-5x); + --ti-tag-mini-height: var(--ti-common-size-4x); + --ti-tag-border-color: var(--ti-base-color-border); + --ti-tag-border-radius: var(--ti-base-radius-medium); + --ti-tag-font-size: var(--ti-base-font-size); + --ti-tag-close-font-size: var(--ti-common-font-size-1); + --ti-tag-primary-color: var(--ti-base-color-common-5); + --ti-tag-primary-border-color: var(--ti-base-color-bg-6); + --ti-tag-primary-background-color: var(--ti-base-color-bg-6); + --ti-tag-warning-color: var(--ti-common-color-warn-text); + --ti-tag-warning-border-color: var(--ti-common-color-warn-border); + --ti-tag-warning-background-color: var(--ti-common-color-warn-bg); + --ti-tag-danger-color: var(--ti-common-color-error-text); + --ti-tag-danger-border-color: var(--ti-common-color-error-border-secondary); + --ti-tag-danger-background-color: var(--ti-common-color-error-bg); + --ti-tag-success-color: var(--ti-common-color-text-success); + --ti-tag-success-border-color: var(--ti-common-color-success-border); + --ti-tag-success-background-color: var(--ti-common-color-success-bg); + --ti-tag-info-color: var(--ti-common-color-info-text); + --ti-tag-info-border-color: var(--ti-common-color-info-border); + --ti-tag-info-background-color: var(--ti-common-color-info-bg); + --ti-tag-dark-color: var(--ti-base-color-light); + --ti-tag-dark-bgcolor: var(--ti-common-color-prompt); + --ti-tag-dark-success-bgcolor: var(--ti-common-color-success); + --ti-tag-dark-warning-bgcolor: var(--ti-common-color-warn); + --ti-tag-dark-danger-bgcolor: var(--ti-common-color-error); + --ti-tag-dark-info-bgcolor: var(--ti-common-color-info); + --ti-tag-plain-color: var(--ti-common-color-prompt); + --ti-tag-plain-border-color: var(--ti-common-color-prompt-border); + --ti-tag-plain-background-color: var(--ti-base-color-light); + --ti-tag-plain-info-color: var(--ti-common-color-info); + --ti-tag-plain-info-border-color: var(--ti-common-color-info-border); + --ti-tag-plain-success-color: var(--ti-common-color-success); + --ti-tag-plain-success-border-color: var(--ti-common-color-success-border); + --ti-tag-plain-warning-color: var(--ti-common-color-warn); + --ti-tag-plain-warning-border-color: var(--ti-common-color-warn-border); + --ti-tag-plain-danger-color: var(--ti-common-color-error); + --ti-tag-plain-danger-border-color: var(--ti-common-color-error-border-secondary); + height: var(--ti-tag-height); + line-height: var(--ti-tag-height); + padding: 0 8px; + font-size: var(--ti-tag-font-size); + border-width: 1px; + border-radius: var(--ti-tag-border-radius); + border-style: solid; + -webkit-box-sizing: border-box; + box-sizing: border-box; + white-space: nowrap; + display: -webkit-inline-box; + display: -ms-inline-flexbox; + display: inline-flex; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + color: var(--ti-tag-primary-color); + border-color: var(--ti-tag-primary-border-color); + background-color: var(--ti-tag-primary-background-color); +} +.tiny-tag.is-hit { + border-color: var(--ti-tag-primary-color); +} +.tiny-tag .tiny-tag__close { + fill: var(--ti-tag-primary-color); + opacity: 0.5; +} +.tiny-tag .tiny-tag__close:hover { + opacity: 1; +} +.tiny-tag .tiny-tag__text:hover { + cursor: pointer; + color: #526ecc; +} +.tiny-tag .tiny-tag__close { + font-size: var(--ti-tag-close-font-size); + margin-left: 6px; +} +.tiny-tag .tiny-tag__close:hover { + cursor: pointer; + fill: #5e7ce0; +} +.tiny-tag.tiny-tag--info { + color: var(--ti-tag-info-color); + border-color: var(--ti-tag-info-border-color); + background-color: var(--ti-tag-info-background-color); +} +.tiny-tag.tiny-tag--info.is-hit { + border-color: var(--ti-tag-info-color); +} +.tiny-tag.tiny-tag--info .tiny-tag__close { + fill: var(--ti-tag-info-color); + opacity: 0.5; +} +.tiny-tag.tiny-tag--info .tiny-tag__close:hover { + opacity: 1; +} +.tiny-tag.tiny-tag--success { + color: var(--ti-tag-success-color); + border-color: var(--ti-tag-success-border-color); + background-color: var(--ti-tag-success-background-color); +} +.tiny-tag.tiny-tag--success.is-hit { + border-color: var(--ti-tag-success-color); +} +.tiny-tag.tiny-tag--success .tiny-tag__close { + fill: var(--ti-tag-success-color); + opacity: 0.5; +} +.tiny-tag.tiny-tag--success .tiny-tag__close:hover { + opacity: 1; +} +.tiny-tag.tiny-tag--warning { + color: var(--ti-tag-warning-color); + border-color: var(--ti-tag-warning-border-color); + background-color: var(--ti-tag-warning-background-color); +} +.tiny-tag.tiny-tag--warning.is-hit { + border-color: var(--ti-tag-warning-color); +} +.tiny-tag.tiny-tag--warning .tiny-tag__close { + fill: var(--ti-tag-warning-color); + opacity: 0.5; +} +.tiny-tag.tiny-tag--warning .tiny-tag__close:hover { + opacity: 1; +} +.tiny-tag.tiny-tag--danger { + color: var(--ti-tag-danger-color); + border-color: var(--ti-tag-danger-border-color); + background-color: var(--ti-tag-danger-background-color); +} +.tiny-tag.tiny-tag--danger.is-hit { + border-color: var(--ti-tag-danger-color); +} +.tiny-tag.tiny-tag--danger .tiny-tag__close { + fill: var(--ti-tag-danger-color); + opacity: 0.5; +} +.tiny-tag.tiny-tag--danger .tiny-tag__close:hover { + opacity: 1; +} +.tiny-tag--dark { + color: var(--ti-tag-dark-color); + border-color: var(--ti-tag-dark-bgcolor); + background-color: var(--ti-tag-dark-bgcolor); +} +.tiny-tag--dark.is-hit { + border-color: var(--ti-tag-dark-bgcolor); +} +.tiny-tag--dark .tiny-tag__close { + fill: var(--ti-tag-dark-color); + opacity: 0.5; +} +.tiny-tag--dark .tiny-tag__close:hover { + opacity: 1; +} +.tiny-tag--dark.tiny-tag--info { + color: var(--ti-tag-dark-color); + border-color: var(--ti-tag-dark-info-bgcolor); + background-color: var(--ti-tag-dark-info-bgcolor); +} +.tiny-tag--dark.tiny-tag--info.is-hit { + border-color: var(--ti-tag-dark-info-bgcolor); +} +.tiny-tag--dark.tiny-tag--info .tiny-tag__close { + fill: var(--ti-tag-dark-color); + opacity: 0.5; +} +.tiny-tag--dark.tiny-tag--info .tiny-tag__close:hover { + opacity: 1; +} +.tiny-tag--dark.tiny-tag--success { + color: var(--ti-tag-dark-color); + border-color: var(--ti-tag-dark-success-bgcolor); + background-color: var(--ti-tag-dark-success-bgcolor); +} +.tiny-tag--dark.tiny-tag--success.is-hit { + border-color: var(--ti-tag-dark-success-bgcolor); +} +.tiny-tag--dark.tiny-tag--success .tiny-tag__close { + fill: var(--ti-tag-dark-color); + opacity: 0.5; +} +.tiny-tag--dark.tiny-tag--success .tiny-tag__close:hover { + opacity: 1; +} +.tiny-tag--dark.tiny-tag--warning { + color: var(--ti-tag-dark-color); + border-color: var(--ti-tag-dark-warning-bgcolor); + background-color: var(--ti-tag-dark-warning-bgcolor); +} +.tiny-tag--dark.tiny-tag--warning.is-hit { + border-color: var(--ti-tag-dark-warning-bgcolor); +} +.tiny-tag--dark.tiny-tag--warning .tiny-tag__close { + fill: var(--ti-tag-dark-color); + opacity: 0.5; +} +.tiny-tag--dark.tiny-tag--warning .tiny-tag__close:hover { + opacity: 1; +} +.tiny-tag--dark.tiny-tag--danger { + color: var(--ti-tag-dark-color); + border-color: var(--ti-tag-dark-danger-bgcolor); + background-color: var(--ti-tag-dark-danger-bgcolor); +} +.tiny-tag--dark.tiny-tag--danger.is-hit { + border-color: var(--ti-tag-dark-danger-bgcolor); +} +.tiny-tag--dark.tiny-tag--danger .tiny-tag__close { + fill: var(--ti-tag-dark-color); + opacity: 0.5; +} +.tiny-tag--dark.tiny-tag--danger .tiny-tag__close:hover { + opacity: 1; +} +.tiny-tag--plain { + color: var(--ti-tag-plain-color); + border-color: var(--ti-tag-plain-border-color); + background-color: var(--ti-tag-plain-background-color); +} +.tiny-tag--plain.is-hit { + border-color: var(--ti-tag-plain-color); +} +.tiny-tag--plain .tiny-tag__close { + fill: var(--ti-tag-plain-color); + opacity: 0.5; +} +.tiny-tag--plain .tiny-tag__close:hover { + opacity: 1; +} +.tiny-tag--plain.tiny-tag--info { + color: var(--ti-tag-plain-info-color); + border-color: var(--ti-tag-plain-info-border-color); + background-color: var(--ti-tag-plain-background-color); +} +.tiny-tag--plain.tiny-tag--info.is-hit { + border-color: var(--ti-tag-plain-info-color); +} +.tiny-tag--plain.tiny-tag--info .tiny-tag__close { + fill: var(--ti-tag-plain-info-color); + opacity: 0.5; +} +.tiny-tag--plain.tiny-tag--info .tiny-tag__close:hover { + opacity: 1; +} +.tiny-tag--plain.tiny-tag--success { + color: var(--ti-tag-plain-success-color); + border-color: var(--ti-tag-plain-success-border-color); + background-color: var(--ti-tag-plain-background-color); +} +.tiny-tag--plain.tiny-tag--success.is-hit { + border-color: var(--ti-tag-plain-success-color); +} +.tiny-tag--plain.tiny-tag--success .tiny-tag__close { + fill: var(--ti-tag-plain-success-color); + opacity: 0.5; +} +.tiny-tag--plain.tiny-tag--success .tiny-tag__close:hover { + opacity: 1; +} +.tiny-tag--plain.tiny-tag--warning { + color: var(--ti-tag-plain-warning-color); + border-color: var(--ti-tag-plain-warning-border-color); + background-color: var(--ti-tag-plain-background-color); +} +.tiny-tag--plain.tiny-tag--warning.is-hit { + border-color: var(--ti-tag-plain-warning-color); +} +.tiny-tag--plain.tiny-tag--warning .tiny-tag__close { + fill: var(--ti-tag-plain-warning-color); + opacity: 0.5; +} +.tiny-tag--plain.tiny-tag--warning .tiny-tag__close:hover { + opacity: 1; +} +.tiny-tag--plain.tiny-tag--danger { + color: var(--ti-tag-plain-danger-color); + border-color: var(--ti-tag-plain-danger-border-color); + background-color: var(--ti-tag-plain-background-color); +} +.tiny-tag--plain.tiny-tag--danger.is-hit { + border-color: var(--ti-tag-plain-danger-color); +} +.tiny-tag--plain.tiny-tag--danger .tiny-tag__close { + fill: var(--ti-tag-plain-danger-color); + opacity: 0.5; +} +.tiny-tag--plain.tiny-tag--danger .tiny-tag__close:hover { + opacity: 1; +} +.tiny-tag--medium { + height: var(--ti-tag-medium-height); + line-height: calc(var(--ti-tag-medium-height) - 2px); +} +.tiny-tag--small { + height: var(--ti-tag-small-height); + line-height: calc(var(--ti-tag-small-height) - 2px); +} +.tiny-tag--mini { + height: var(--ti-tag-mini-height); + line-height: calc(var(--ti-tag-mini-height) - 2px); +} +.tiny-tall-storage { + --ti-tall-storage-bgcolor: var(--ti-base-color-light); + --ti-tall-storage-border-radius: var(--ti-common-border-radius-normal); + --ti-tall-storage-item-height: var(--ti-base-size-height-minor); + --ti-tall-storage-item-bgcolor: var(--ti-base-color-hover-background); + position: relative; + margin-top: 2px; +} +.tiny-tall-storage .tiny-storage-list-style { + position: absolute; + background-color: var(--ti-tall-storage-bgcolor); + -webkit-box-shadow: var(--ti-base-box-shadow); + box-shadow: var(--ti-base-box-shadow); + border-radius: var(--ti-tall-storage-border-radius); + width: 100%; + -webkit-box-sizing: border-box; + box-sizing: border-box; + z-index: 10; +} +.tiny-tall-storage .tiny-storage-list-style .tiny-storage-list { + padding: 0; + list-style: none; +} +.tiny-tall-storage .tiny-storage-list-style .tiny-storage-list .tiny-storage-item { + height: var(--ti-tall-storage-item-height); + line-height: var(--ti-tall-storage-item-height); + padding: 0 8px; + white-space: nowrap; +} +.tiny-tall-storage .tiny-storage-list-style .tiny-storage-list .tiny-storage-item.item-hover, +.tiny-tall-storage .tiny-storage-list-style .tiny-storage-list .tiny-storage-item:hover { + cursor: pointer; + background-color: var(--ti-tall-storage-item-bgcolor); +} +.tiny-text-popup { + --ti-text-popup-radius: var(--ti-common-border-radius-normal); + --ti-text-popup-border-color: var(--ti-base-color-border); + --ti-text-popup-hover-border-color: var(--ti-base-color-brand-6); + display: inline-block; +} +.tiny-text-popup .area { + padding: 6px; + width: 100%; + border-radius: var(--ti-text-popup-radius, 2px); + outline: 0; +} +.tiny-text-popup .text { + border: 1px solid var(--ti-text-popup-border-color); + line-height: 1; +} +.tiny-text-popup .text:hover { + border-color: var(--ti-text-popup-hover-border-color); +} +.tiny-text-popup .popup { + resize: none; + -webkit-box-shadow: 0 0 1px 1px rgba(175, 175, 175, 0.3); + box-shadow: 0 0 1px 1px rgba(175, 175, 175, 0.3); + border: 1px solid var(--ti-text-popup-border-color); +} +.tiny-tips { + --ti-tips-normal-color: var(--ti-base-color-secondary); + --ti-tips-normal-font-color: var(--ti-base-color-light); + --ti-tips-error-color: #ff7875; + --ti-tips-error-font-color: var(--ti-base-color-light); + --ti-tips-succeed-color: var(--ti-base-color-success-normal); + --ti-tips-succeed-font-color: var(--ti-base-color-light); + --ti-tips-warning-color: #fa8c16; + --ti-tips-warning-font-color: var(--ti-base-color-light); + --ti-tips-infor-color: var(--ti-base-color-border); + --ti-tips-infor-font-color: var(--ti-base-color-info-normal); + --ti-tips-bgcolor: #ff7875; + --ti-tips-radius: var(--ti-common-border-radius-normal); + --ti-tips-height: 26px; + z-index: 900; + position: absolute; + padding: var(--ti-tips-padding); + background: var(--ti-tips-bgcolor); + border-radius: var(--ti-tips-radius); + color: var(--ti-tips-color-infor); + min-height: var(--ti-tips-height); + text-align: center; + line-height: var(--ti-tips-height); +} +.tiny-tips .tiny-icon { + color: var(--ti-tips-color-infor); + line-height: 36px; +} +.tiny-tips > span { + float: left; + top: -5px; +} +.tiny-tips:before { + content: ''; + left: -4px; + top: 50%; + margin-top: -4px; + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 4px 4px 4px 0; + border-color: transparent var(--ti-tips-bgcolor); +} +.tiny-tips span + p { + max-width: 300px; + max-height: 100px; + word-break: break-all; + -webkit-box-orient: vertical; + -webkit-line-clamp: 3; + overflow: auto; +} +.tiny-tips .tiny-small-close { + position: absolute; + cursor: pointer; + right: 8px; + top: -5px; +} +.tiny-tips .icon-remove + p, +.tiny-tips .icon-successful + p { + margin-left: 0; +} +.tiny-tips.tips-bottom { + top: -5px; + left: 0; +} +.tiny-tips.tips-bottom:before { + content: ''; + left: 50%; + top: -4px; + margin-top: 0; + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 0 4px 4px 4px; + border-color: var(--ti-tips-bgcolor) transparent; + margin-left: -6px; +} +.tiny-tips.tips-left:before { + content: ''; + left: auto; + top: 50%; + margin-top: -4px; + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 4px 0 4px 4px; + border-color: transparent var(--ti-tips-bgcolor); + right: -4px; +} +.tiny-tips.tips-top { + top: -5px; + left: 0; +} +.tiny-tips.tips-top:before { + content: ''; + left: 50%; + top: auto; + margin-top: auto; + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 4px 4px 0 4px; + border-color: var(--ti-tips-bgcolor) transparent; + margin-left: -6px; + bottom: -4px; + margin-bottom: 0; +} +.tiny-tips.tips-top-left { + top: -5px; + left: 0; +} +.tiny-tips.tips-top-left:before { + content: ''; + left: 0; + top: auto; + margin-top: auto; + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 4px 4px 0 4px; + border-color: var(--ti-tips-bgcolor) transparent; + margin-left: 10px; + bottom: -4px; + margin-bottom: 0; +} +.tiny-tips.tips-top-right { + top: -5px; + left: 0; +} +.tiny-tips.tips-top-right:before { + content: ''; + left: 100%; + top: auto; + margin-top: auto; + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 4px 4px 0 4px; + border-color: var(--ti-tips-bgcolor) transparent; + margin-left: -16px; + bottom: -4px; + margin-bottom: 0; +} +.tiny-tips.tips-bottom-left { + top: -5px; + left: 0; +} +.tiny-tips.tips-bottom-left:before { + content: ''; + left: 0; + top: -4px; + margin-top: 0; + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 0 4px 4px 4px; + border-color: var(--ti-tips-bgcolor) transparent; + margin-left: 10px; +} +.tiny-tips.tips-bottom-right { + top: -5px; + left: 0; +} +.tiny-tips.tips-bottom-right:before { + content: ''; + left: 100%; + top: -4px; + margin-top: 0; + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 0 4px 4px 4px; + border-color: var(--ti-tips-bgcolor) transparent; + margin-left: -16px; +} +.tiny-tips.tips-error { + background: var(--ti-tips-error-color); + color: var(--ti-tips-error-font-color); + border-radius: var(--ti-tips-radius-large, 3px); + -webkit-box-shadow: 0 0 4px var(--ti-tips-error-color); + box-shadow: 0 0 4px var(--ti-tips-error-color); + margin-top: 0; +} +.tiny-tips.tips-error:before { + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 4px 4px 4px 0; + border-color: transparent var(--ti-tips-error-color); +} +.tiny-tips.tips-error.tips-bottom:before { + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 0 4px 4px 4px; + border-color: var(--ti-tips-error-color) transparent; +} +.tiny-tips.tips-error.tips-left:before { + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 4px 0 4px 4px; + border-color: transparent var(--ti-tips-error-color); +} +.tiny-tips.tips-error.tips-top:before { + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 4px 4px 0 4px; + border-color: var(--ti-tips-error-color) transparent; +} +.tiny-tips.tips-error.tips-bottom-left:before { + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 0 4px 4px 4px; + border-color: var(--ti-tips-error-color) transparent; +} +.tiny-tips.tips-error.tips-bottom-right:before { + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 0 4px 4px 4px; + border-color: var(--ti-tips-error-color) transparent; +} +.tiny-tips.tips-error.tips-top-left:before { + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 4px 4px 0 4px; + border-color: var(--ti-tips-error-color) transparent; +} +.tiny-tips.tips-error.tips-top-right:before { + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 4px 4px 0 4px; + border-color: var(--ti-tips-error-color) transparent; +} +.tiny-tips.tips-warning { + background: var(--ti-tips-warning-color); + color: var(--ti-tips-warning-font-color); + border-radius: var(--ti-tips-radius-large, 3px); + -webkit-box-shadow: 0 0 4px var(--ti-tips-warning-color); + box-shadow: 0 0 4px var(--ti-tips-warning-color); + margin-top: 0; +} +.tiny-tips.tips-warning:before { + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 4px 4px 4px 0; + border-color: transparent var(--ti-tips-warning-color); +} +.tiny-tips.tips-warning.tips-bottom:before { + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 0 4px 4px 4px; + border-color: var(--ti-tips-warning-color) transparent; +} +.tiny-tips.tips-warning.tips-left:before { + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 4px 0 4px 4px; + border-color: transparent var(--ti-tips-warning-color); +} +.tiny-tips.tips-warning.tips-top:before { + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 4px 4px 0 4px; + border-color: var(--ti-tips-warning-color) transparent; +} +.tiny-tips.tips-warning.tips-bottom-left:before { + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 0 4px 4px 4px; + border-color: var(--ti-tips-warning-color) transparent; +} +.tiny-tips.tips-warning.tips-bottom-right:before { + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 0 4px 4px 4px; + border-color: var(--ti-tips-warning-color) transparent; +} +.tiny-tips.tips-warning.tips-top-left:before { + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 4px 4px 0 4px; + border-color: var(--ti-tips-warning-color) transparent; +} +.tiny-tips.tips-warning.tips-top-right:before { + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 4px 4px 0 4px; + border-color: var(--ti-tips-warning-color) transparent; +} +.tiny-tips.tips-succeed { + background: var(--ti-tips-succeed-color); + color: var(--ti-tips-succeed-font-color); + border-radius: var(--ti-tips-radius-large, 3px); + -webkit-box-shadow: 0 0 4px var(--ti-tips-succeed-color); + box-shadow: 0 0 4px var(--ti-tips-succeed-color); + margin-top: 0; +} +.tiny-tips.tips-succeed:before { + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 4px 4px 4px 0; + border-color: transparent var(--ti-tips-succeed-color); +} +.tiny-tips.tips-succeed.tips-bottom:before { + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 0 4px 4px 4px; + border-color: var(--ti-tips-succeed-color) transparent; +} +.tiny-tips.tips-succeed.tips-left:before { + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 4px 0 4px 4px; + border-color: transparent var(--ti-tips-succeed-color); +} +.tiny-tips.tips-succeed.tips-top:before { + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 4px 4px 0 4px; + border-color: var(--ti-tips-succeed-color) transparent; +} +.tiny-tips.tips-succeed.tips-bottom-left:before { + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 0 4px 4px 4px; + border-color: var(--ti-tips-succeed-color) transparent; +} +.tiny-tips.tips-succeed.tips-bottom-right:before { + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 0 4px 4px 4px; + border-color: var(--ti-tips-succeed-color) transparent; +} +.tiny-tips.tips-succeed.tips-top-left:before { + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 4px 4px 0 4px; + border-color: var(--ti-tips-succeed-color) transparent; +} +.tiny-tips.tips-succeed.tips-top-right:before { + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 4px 4px 0 4px; + border-color: var(--ti-tips-succeed-color) transparent; +} +.tiny-tips.tips-infor { + background: var(--ti-tips-infor-color); + color: var(--ti-tips-infor-font-color); + border-radius: var(--ti-tips-radius-large, 3px); + -webkit-box-shadow: 0 0 4px var(--ti-tips-infor-color); + box-shadow: 0 0 4px var(--ti-tips-infor-color); + margin-top: 0; +} +.tiny-tips.tips-infor:before { + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 4px 4px 4px 0; + border-color: transparent var(--ti-tips-infor-color); +} +.tiny-tips.tips-infor.tips-bottom:before { + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 0 4px 4px 4px; + border-color: var(--ti-tips-infor-color) transparent; +} +.tiny-tips.tips-infor.tips-left:before { + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 4px 0 4px 4px; + border-color: transparent var(--ti-tips-infor-color); +} +.tiny-tips.tips-infor.tips-top:before { + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 4px 4px 0 4px; + border-color: var(--ti-tips-infor-color) transparent; +} +.tiny-tips.tips-infor.tips-bottom-left:before { + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 0 4px 4px 4px; + border-color: var(--ti-tips-infor-color) transparent; +} +.tiny-tips.tips-infor.tips-bottom-right:before { + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 0 4px 4px 4px; + border-color: var(--ti-tips-infor-color) transparent; +} +.tiny-tips.tips-infor.tips-top-left:before { + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 4px 4px 0 4px; + border-color: var(--ti-tips-infor-color) transparent; +} +.tiny-tips.tips-infor.tips-top-right:before { + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 4px 4px 0 4px; + border-color: var(--ti-tips-infor-color) transparent; +} +.tiny-tips.tips-normal { + background: var(--ti-tips-normal-color); + color: var(--ti-tips-normal-font-color); + border-radius: var(--ti-tips-radius-large, 3px); + -webkit-box-shadow: 0 0 4px var(--ti-tips-normal-color); + box-shadow: 0 0 4px var(--ti-tips-normal-color); + margin-top: 0; +} +.tiny-tips.tips-normal:before { + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 4px 4px 4px 0; + border-color: transparent var(--ti-tips-normal-color); +} +.tiny-tips.tips-normal.tips-bottom:before { + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 0 4px 4px 4px; + border-color: var(--ti-tips-normal-color) transparent; +} +.tiny-tips.tips-normal.tips-left:before { + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 4px 0 4px 4px; + border-color: transparent var(--ti-tips-normal-color); +} +.tiny-tips.tips-normal.tips-top:before { + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 4px 4px 0 4px; + border-color: var(--ti-tips-normal-color) transparent; +} +.tiny-tips.tips-normal.tips-bottom-left:before { + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 0 4px 4px 4px; + border-color: var(--ti-tips-normal-color) transparent; +} +.tiny-tips.tips-normal.tips-bottom-right:before { + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 0 4px 4px 4px; + border-color: var(--ti-tips-normal-color) transparent; +} +.tiny-tips.tips-normal.tips-top-left:before { + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 4px 4px 0 4px; + border-color: var(--ti-tips-normal-color) transparent; +} +.tiny-tips.tips-normal.tips-top-right:before { + position: absolute; + width: 0; + height: 0; + border-style: solid; + border-width: 4px 4px 0 4px; + border-color: var(--ti-tips-normal-color) transparent; +} +.tiny-tips .grid-innercell .grid-simplesort { + display: none; +} +.tiny-toggle-menu { + --ti-toggle-menu-width: 210px; + --ti-toggle-menu-font-size: var(--ti-common-font-size-base); + --ti-toggle-menu-name-color: var(--ti-base-color-info-normal); + --ti-toggle-menu-tree-node-height: var(--ti-common-size-7x); + --ti-toggle-menu-filter-search-size: 30px; + --ti-toggle-menu-filter-search-font-size: var(--ti-common-font-size-2); + --ti-toggle-menu-filter-search-icon-color: var(--ti-base-color-brand-6); + --ti-toggle-menu-toggle-icon-color: var(--ti-base-color-brand-6); + --ti-toggle-menu-toggle-icon-hover-color: var(--ti-base-color-brand-5); + --ti-toggle-menu-toggle-bgcolor: var(--ti-base-color-border); + width: var(--ti-toggle-menu-width); + position: relative; +} +.tiny-toggle-menu .tiny-toggle-menu__body { + cursor: pointer; + line-height: 1; + padding-left: 4px; + width: 100%; +} +.tiny-toggle-menu .tiny-toggle-menu__body, +.tiny-toggle-menu .tiny-toggle-menu__body:hover { + text-decoration: none; +} +.tiny-toggle-menu .tiny-toggle-menu__name { + color: var(--ti-toggle-menu-name-color); + font-size: var(--ti-toggle-menu-font-size); +} +.tiny-toggle-menu .tiny-toggle-menu__tree { + position: relative; +} +.tiny-toggle-menu .tiny-toggle-menu__filter { + position: relative; + margin-bottom: 4px; + width: calc(100% - 16px); +} +.tiny-toggle-menu .tiny-toggle-menu__filter-search { + width: var(--ti-toggle-menu-filter-search-size); + height: var(--ti-toggle-menu-filter-search-size); + line-height: var(--ti-toggle-menu-filter-search-size); + display: block; + text-align: center; + position: absolute; + right: 0; + top: 0; +} +.tiny-toggle-menu .tiny-toggle-menu__filter-search .tiny-svg { + fill: var(--ti-toggle-menu-filter-search-icon-color); + font-size: var(--ti-toggle-menu-filter-search-font-size); +} +.tiny-toggle-menu .tiny-toggle-menu__toggle { + position: absolute; + top: 0; + left: calc(100% - 14px); + z-index: 2; + width: 14px; + height: var(--ti-toggle-menu-filter-search-size); + line-height: var(--ti-toggle-menu-filter-search-size); + background: var(--ti-toggle-menu-toggle-bgcolor); + cursor: pointer; + -webkit-transition: 0.2s linear; + transition: 0.2s linear; +} +.tiny-toggle-menu .tiny-toggle-menu__toggle .tiny-svg { + fill: var(--ti-toggle-menu-toggle-icon-color); +} +.tiny-toggle-menu .tiny-toggle-menu__toggle:hover .tiny-svg { + fill: var(--ti-toggle-menu-toggle-icon-hover-color); +} +.tiny-toggle-menu .tiny-toggle-menu__link { + width: 100%; +} +.tiny-toggle-menu.is-toggle-right { + width: 80px; +} +.tiny-toggle-menu.is-toggle-right .tiny-tree-node.is-current .tiny-tree-node__content { + background: 0 0; +} +.tiny-toggle-menu.is-toggle-right .tiny-tree-node__content:hover { + background: 0 0; +} +.tiny-toggle-menu.is-toggle-right .tiny-tree-node__content:hover .tiny-svg { + fill: var(--ti-toggle-menu-toggle-icon-hover-color); +} +.tiny-toggle-menu.is-toggle-right .tiny-toggle-menu__toggle { + position: relative; + left: 0; +} +.tiny-toggle-menu.is-toggle-right .tiny-toggle-menu__filter { + display: none; +} +.tiny-toggle-menu .tiny-tree.is-wrap .tiny-tree-node__content { + height: auto; +} +.tiny-toggle-menu .tiny-tree.is-wrap .tiny-toggle-menu__name { + display: inline-block; + white-space: normal; + line-height: normal; + word-break: break-word; +} +.tiny-toggle-menu .tiny-tree.is-overflow .tiny-toggle-menu__name { + width: calc(100% - 18px); + vertical-align: middle; + display: inline-block; + white-space: nowrap; + overflow: hidden; + text-overflow: ellipsis; +} +.tiny-toggle-menu .tiny-tree.is-node-hide .tiny-toggle-menu__body, +.tiny-toggle-menu .tiny-tree.is-node-hide .tiny-tree-node__children { + display: none; +} +.tiny-toggle-menu .tiny-input__inner { + font-size: var(--ti-toggle-menu-font-size); + padding-right: 30px; + border-radius: 0; + border-top: 0; + border-left: 0; + border-right: 0; +} +.tiny-toggle-menu .tiny-tree-node__content { + height: var(--ti-toggle-menu-tree-node-height); + line-height: var(--ti-toggle-menu-tree-node-height); + font-size: var(--ti-toggle-menu-font-size); + padding-left: 0; + margin-left: 0; +} +.tiny-tooltip { + --ti-tooltip-popper-border-radius: var(--ti-common-border-radius-1); + --ti-tooltip-popper-font-size: var(--ti-common-font-size-base); + --ti-tooltip-popper-border-color: var(--ti-base-color-common-6); + --ti-tooltip-popper-normal-background: var(--ti-base-color-secondary); + --ti-tooltip-popper-normal-color: var(--ti-base-color-light); + --ti-tooltip-popper-normal-border-color: var(--ti-base-color-secondary); + --ti-tooltip-popper-info-background: #69c0ff; + --ti-tooltip-popper-info-color: var(--ti-base-color-light); + --ti-tooltip-popper-info-border-color: #69c0ff; + --ti-tooltip-popper-error-background: var(--ti-base-color-common-6); + --ti-tooltip-popper-error-color: var(--ti-base-color-light); + --ti-tooltip-popper-error-border-color: var(--ti-base-color-common-6); + --ti-tooltip-popper-warning-background: #ffd666; + --ti-tooltip-popper-warning-color: var(--ti-base-color-light); + --ti-tooltip-popper-warning-border-color: #ffd666; + --ti-tooltip-popper-success-background: #95de64; + --ti-tooltip-popper-success-color: var(--ti-base-color-light); + --ti-tooltip-popper-success-border-color: #95de64; + --ti-tooltip-popper-dark-background: var(--ti-base-color-common-6); + --ti-tooltip-popper-dark-color: var(--ti-base-color-light); + --ti-tooltip-popper-light-background: var(--ti-base-color-light); + --ti-tooltip-popper-light-color: var(--ti-base-color-common-6); + --ti-tooltip-popper-light-border-color: var(--ti-base-color-common-6); + --ti-tooltip-box-shadow: 0 4px 16px 0 rgba(0, 0, 0, 0.2); + --ti-tooltip-padding: 11px 15px; +} +.tiny-tooltip:focus:hover, +.tiny-tooltip:focus:not(.focusing) { + outline-width: 0; +} +.tiny-tooltip.tiny-tooltip__popper { + position: absolute; + left: -9999px; + border-radius: var(--ti-tooltip-popper-border-radius); + padding: var(--ti-tooltip-padding); + font-size: var(--ti-tooltip-popper-font-size); + line-height: 1.2; + min-width: 10px; + max-width: 450px; + z-index: 2000; + word-wrap: break-word; + -webkit-box-shadow: var(--ti-tooltip-box-shadow); + box-shadow: var(--ti-tooltip-box-shadow); +} +.tiny-tooltip.tiny-tooltip__popper .popper__arrow, +.tiny-tooltip.tiny-tooltip__popper .popper__arrow::after { + position: absolute; + display: block; + width: 0; + height: 0; + border-color: transparent; + border-style: solid; +} +.tiny-tooltip.tiny-tooltip__popper .popper__arrow { + border-width: 6px; +} +.tiny-tooltip.tiny-tooltip__popper .popper__arrow::after { + content: ' '; + border-width: 5px; +} +.tiny-tooltip.tiny-tooltip__popper[x-placement^='top'] { + margin-bottom: 12px; +} +.tiny-tooltip.tiny-tooltip__popper[x-placement^='top'] .popper__arrow { + bottom: -6px; + border-top-color: var(--ti-tooltip-popper-border-color); + border-bottom-width: 0; +} +.tiny-tooltip.tiny-tooltip__popper[x-placement^='top'] .popper__arrow::after { + bottom: 1px; + margin-left: -5px; + border-top-color: var(--ti-tooltip-popper-border-color); + border-bottom-width: 0; +} +.tiny-tooltip.tiny-tooltip__popper[x-placement^='bottom'] { + margin-top: 12px; +} +.tiny-tooltip.tiny-tooltip__popper[x-placement^='bottom'] .popper__arrow { + top: -6px; + border-top-width: 0; + border-bottom-color: var(--ti-tooltip-popper-border-color); +} +.tiny-tooltip.tiny-tooltip__popper[x-placement^='bottom'] .popper__arrow::after { + top: 1px; + margin-left: -5px; + border-top-width: 0; + border-bottom-color: var(--ti-tooltip-popper-border-color); +} +.tiny-tooltip.tiny-tooltip__popper[x-placement^='right'] { + margin-left: 12px; +} +.tiny-tooltip.tiny-tooltip__popper[x-placement^='right'] .popper__arrow { + left: -6px; + border-right-color: var(--ti-tooltip-popper-border-color); + border-left-width: 0; +} +.tiny-tooltip.tiny-tooltip__popper[x-placement^='right'] .popper__arrow::after { + bottom: -5px; + left: 1px; + border-right-color: var(--ti-tooltip-popper-border-color); + border-left-width: 0; +} +.tiny-tooltip.tiny-tooltip__popper[x-placement^='left'] { + margin-right: 12px; +} +.tiny-tooltip.tiny-tooltip__popper[x-placement^='left'] .popper__arrow { + right: -6px; + border-right-width: 0; + border-left-color: var(--ti-tooltip-popper-border-color); +} +.tiny-tooltip.tiny-tooltip__popper[x-placement^='left'] .popper__arrow::after { + right: 1px; + bottom: -5px; + margin-left: -5px; + border-right-width: 0; + border-left-color: var(--ti-tooltip-popper-border-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-normal { + background: var(--ti-tooltip-popper-normal-background); + color: var(--ti-tooltip-popper-normal-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-normal[x-placement^='top'] .popper__arrow { + border-top-color: var(--ti-tooltip-popper-normal-border-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-normal[x-placement^='top'] .popper__arrow::after { + border-top-color: var(--ti-tooltip-popper-normal-border-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-normal[x-placement^='bottom'] .popper__arrow { + border-bottom-color: var(--ti-tooltip-popper-normal-border-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-normal[x-placement^='bottom'] .popper__arrow::after { + border-bottom-color: var(--ti-tooltip-popper-normal-border-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-normal[x-placement^='left'] .popper__arrow { + border-left-color: var(--ti-tooltip-popper-normal-border-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-normal[x-placement^='left'] .popper__arrow::after { + border-left-color: var(--ti-tooltip-popper-normal-border-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-normal[x-placement^='right'] .popper__arrow { + border-right-color: var(--ti-tooltip-popper-normal-border-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-normal[x-placement^='right'] .popper__arrow::after { + border-right-color: var(--ti-tooltip-popper-normal-border-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-info { + background: var(--ti-tooltip-popper-info-background); + color: var(--ti-tooltip-popper-info-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-info[x-placement^='top'] .popper__arrow { + border-top-color: var(--ti-tooltip-popper-info-border-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-info[x-placement^='top'] .popper__arrow::after { + border-top-color: var(--ti-tooltip-popper-info-border-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-info[x-placement^='bottom'] .popper__arrow { + border-bottom-color: var(--ti-tooltip-popper-info-border-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-info[x-placement^='bottom'] .popper__arrow::after { + border-bottom-color: var(--ti-tooltip-popper-info-border-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-info[x-placement^='left'] .popper__arrow { + border-left-color: var(--ti-tooltip-popper-info-border-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-info[x-placement^='left'] .popper__arrow::after { + border-left-color: var(--ti-tooltip-popper-info-border-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-info[x-placement^='right'] .popper__arrow { + border-right-color: var(--ti-tooltip-popper-info-border-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-info[x-placement^='right'] .popper__arrow::after { + border-right-color: var(--ti-tooltip-popper-info-border-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-error { + background: var(--ti-tooltip-popper-error-background); + color: var(--ti-tooltip-popper-error-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-error[x-placement^='top'] .popper__arrow { + border-top-color: var(--ti-tooltip-popper-error-border-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-error[x-placement^='top'] .popper__arrow::after { + border-top-color: var(--ti-tooltip-popper-error-border-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-error[x-placement^='bottom'] .popper__arrow { + border-bottom-color: var(--ti-tooltip-popper-error-border-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-error[x-placement^='bottom'] .popper__arrow::after { + border-bottom-color: var(--ti-tooltip-popper-error-border-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-error[x-placement^='left'] .popper__arrow { + border-left-color: var(--ti-tooltip-popper-error-border-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-error[x-placement^='left'] .popper__arrow::after { + border-left-color: var(--ti-tooltip-popper-error-border-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-error[x-placement^='right'] .popper__arrow { + border-right-color: var(--ti-tooltip-popper-error-border-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-error[x-placement^='right'] .popper__arrow::after { + border-right-color: var(--ti-tooltip-popper-error-border-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-warning { + background: var(--ti-tooltip-popper-warning-background); + color: var(--ti-tooltip-popper-warning-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-warning[x-placement^='top'] .popper__arrow { + border-top-color: var(--ti-tooltip-popper-warning-border-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-warning[x-placement^='top'] .popper__arrow::after { + border-top-color: var(--ti-tooltip-popper-warning-border-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-warning[x-placement^='bottom'] .popper__arrow { + border-bottom-color: var(--ti-tooltip-popper-warning-border-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-warning[x-placement^='bottom'] .popper__arrow::after { + border-bottom-color: var(--ti-tooltip-popper-warning-border-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-warning[x-placement^='left'] .popper__arrow { + border-left-color: var(--ti-tooltip-popper-warning-border-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-warning[x-placement^='left'] .popper__arrow::after { + border-left-color: var(--ti-tooltip-popper-warning-border-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-warning[x-placement^='right'] .popper__arrow { + border-right-color: var(--ti-tooltip-popper-warning-border-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-warning[x-placement^='right'] .popper__arrow::after { + border-right-color: var(--ti-tooltip-popper-warning-border-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-success { + background: var(--ti-tooltip-popper-success-background); + color: var(--ti-tooltip-popper-success-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-success[x-placement^='top'] .popper__arrow { + border-top-color: var(--ti-tooltip-popper-success-border-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-success[x-placement^='top'] .popper__arrow::after { + border-top-color: var(--ti-tooltip-popper-success-border-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-success[x-placement^='bottom'] .popper__arrow { + border-bottom-color: var(--ti-tooltip-popper-success-border-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-success[x-placement^='bottom'] .popper__arrow::after { + border-bottom-color: var(--ti-tooltip-popper-success-border-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-success[x-placement^='left'] .popper__arrow { + border-left-color: var(--ti-tooltip-popper-success-border-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-success[x-placement^='left'] .popper__arrow::after { + border-left-color: var(--ti-tooltip-popper-success-border-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-success[x-placement^='right'] .popper__arrow { + border-right-color: var(--ti-tooltip-popper-success-border-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-success[x-placement^='right'] .popper__arrow::after { + border-right-color: var(--ti-tooltip-popper-success-border-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-dark { + background: var(--ti-tooltip-popper-dark-background); + color: var(--ti-tooltip-popper-dark-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-light { + background: var(--ti-tooltip-popper-light-background); + color: var(--ti-tooltip-popper-light-color); + border: 1px solid var(--ti-tooltip-popper-light-border-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-light[x-placement^='top'] .popper__arrow { + border-top-color: var(--ti-tooltip-popper-light-border-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-light[x-placement^='top'] .popper__arrow::after { + border-top-color: var(--ti-tooltip-popper-light-background); +} +.tiny-tooltip.tiny-tooltip__popper.is-light[x-placement^='bottom'] .popper__arrow { + border-bottom-color: var(--ti-tooltip-popper-light-border-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-light[x-placement^='bottom'] .popper__arrow::after { + border-bottom-color: var(--ti-tooltip-popper-light-background); +} +.tiny-tooltip.tiny-tooltip__popper.is-light[x-placement^='left'] .popper__arrow { + border-left-color: var(--ti-tooltip-popper-light-border-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-light[x-placement^='left'] .popper__arrow::after { + border-left-color: var(--ti-tooltip-popper-light-background); +} +.tiny-tooltip.tiny-tooltip__popper.is-light[x-placement^='right'] .popper__arrow { + border-right-color: var(--ti-tooltip-popper-light-border-color); +} +.tiny-tooltip.tiny-tooltip__popper.is-light[x-placement^='right'] .popper__arrow::after { + border-right-color: var(--ti-tooltip-popper-light-background); +} +.tiny-tooltip.tiny-tooltip__popper.is-blank-content { + display: none; +} +.tiny-fade-in-linear-enter-active, +.tiny-fade-in-linear-leave-active { + -webkit-transition: opacity 0.2s linear; + transition: opacity 0.2s linear; +} +.tiny-fade-in-linear-enter, +.tiny-fade-in-linear-enter-from, +.tiny-fade-in-linear-leave, +.tiny-fade-in-linear-leave-active, +.tiny-fade-in-linear-leave-from { + opacity: 0; +} +.tiny-fade-in-enter-active, +.tiny-fade-in-leave-active { + -webkit-transition: all 0.3s cubic-bezier(0.55, 0, 0.1, 1); + transition: all 0.3s cubic-bezier(0.55, 0, 0.1, 1); +} +.tiny-fade-in-enter, +.tiny-fade-in-enter-from, +.tiny-fade-in-leave-active { + opacity: 0; +} +.tiny-top-box { + --ti-top-box-background: var(--ti-base-color-light); + --ti-top-box-icon-font-size: var(--ti-common-font-size-5); + --ti-top-box-success-icon-color: var(--ti-base-color-success-normal); + --ti-top-box-error-icon-color: var(--ti-base-color-bg-8); + --ti-top-box-warning-icon-color: var(--ti-base-color-warning-normal); + --ti-top-box-help-icon-color: var(--ti-base-color-brand-6); + --ti-top-box-info-icon-color: var(--ti-base-color-info-normal); + position: fixed; + top: 20px; + left: 50%; + -webkit-transform: translateX(-50%); + transform: translateX(-50%); + width: 400px; + max-height: 600px; + background: var(--ti-top-box-background); + padding: 24px; + -webkit-box-shadow: 0 0 5px 0 rgba(0, 0, 0, 0.2); + box-shadow: 0 0 5px 0 rgba(0, 0, 0, 0.2); + -webkit-transition: opacity 0.3s, top 0.4s, -webkit-transform 0.4s; + transition: opacity 0.3s, top 0.4s, -webkit-transform 0.4s; + transition: opacity 0.3s, transform 0.4s, top 0.4s; + transition: opacity 0.3s, transform 0.4s, top 0.4s, -webkit-transform 0.4s; +} +.tiny-top-box .tiny-top-box__icon { + font-size: var(--ti-top-box-icon-font-size, 24px); + vertical-align: middle; +} +.tiny-top-box .tiny-top-box__content { + display: inline-block; + padding: 0 16px; + vertical-align: middle; +} +.tiny-top-box .tiny-top-box__closeBtn { + position: absolute; + top: 14px; + right: 12px; + cursor: pointer; + fill: rgba(51, 51, 51, 0.5); + display: none; +} +.tiny-top-box .tiny-top-box__closeBtn:hover { + fill: #333; +} +.tiny-top-box .tiny-top-box__toolbar { + float: right; + margin-top: 24px; +} +.tiny-top-box.is-closable .tiny-top-box__closeBtn { + display: inline-block; +} +.tiny-top-box.is-center { + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-pack: center; + -ms-flex-pack: center; + justify-content: center; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; +} +.tiny-top-box--success .tiny-top-box__icon { + fill: var(--ti-top-box-success-icon-color); +} +.tiny-top-box--error .tiny-top-box__icon { + fill: var(--ti-top-box-error-icon-color); +} +.tiny-top-box--warning .tiny-top-box__icon { + fill: var(--ti-top-box-warning-icon-color); +} +.tiny-top-box--help .tiny-top-box__icon { + fill: var(--ti-top-box-help-icon-color); +} +.tiny-top-box--info .tiny-top-box__icon { + fill: var(--ti-top-box-info-icon-color); +} +.tiny-top-box-fade-enter, +.tiny-top-box-fade-leave-active { + opacity: 0; + -webkit-transform: translate(-50%, -100%); + transform: translate(-50%, -100%); +} +.tiny-transition-transfer-fade-enter-active, +.tiny-transition-transfer-fade-leave-active { + -webkit-transition: all 0.3s; + transition: all 0.3s; +} +.tiny-transition-transfer-fade-leave-active { + position: absolute; +} +.tiny-transition-transfer-fade-enter, +.tiny-transition-transfer-fade-enter-from, +.tiny-transition-transfer-fade-leave-to { + opacity: 0; + -webkit-transform: translateX(30px); + transform: translateX(30px); +} +.tiny-transfer { + --ti-transfer-font-size: var(--ti-common-font-size-1); + --ti-transfer-button-bgcolor: var(--ti-base-color-brand-6); + --ti-transfer-button-border-radius: var(--ti-common-border-radius-normal); + --ti-transfer-button-disabled-color: var(--ti-base-color-placeholder); + --ti-transfer-button-disabled-border-color: var(--ti-base-color-border); + --ti-transfer-button-disabled-bgcolor: var(--ti-common-color-bg-disabled); + --ti-transfer-panel-background: var(--ti-base-color-light); + --ti-transfer-panel-body-height: 260px; + --ti-transfer-panel-border-color: var(--ti-base-color-border); + --ti-transfer-panel-border-radius: var(--ti-common-border-radius-normal); + --ti-transfer-panel-item-height: var(--ti-base-size-height-minor); + --ti-transfer-panel-item-color: var(--ti-base-color-info-normal); + --ti-transfer-panel-item-hover-font-color: var(--ti-base-color-brand-6); + --ti-transfer-panel-item-hover-bgcolor: var(--ti-base-color-hover-background); + --ti-transfer-panel-filter-height: var(--ti-base-size-height-minor); + --ti-transfer-panel-filter-font-size: var(--ti-common-font-size-base); + --ti-transfer-panel-filter-border-radius: var(--ti-common-border-radius-normal); + --ti-transfer-panel-body-filter-height: 216px; + --ti-transfer-panel-width: 200px; + --ti-transfer-header-height: 40px; + --ti-transfer-header-background: var(--ti-base-color-hover-background); + --ti-transfer-header-border-color: var(--ti-base-color-border); + --ti-transfer-header-color: var(--ti-base-color-info-normal); + --ti-transfer-header-span-color: var(--ti-base-color-info-normal); + --ti-transfer-header-font-size: var(--ti-common-font-size-base); + --ti-transfer-header-sort-width: var(--ti-common-size-5x); + --ti-transfer-header-sort-color: var(--ti-base-color-brand-6); + --ti-transfer-footer-height: var(--ti-common-size-10x); + --ti-transfer-footer-background: var(--ti-base-color-light); + --ti-transfer-footer-border-color: var(--ti-base-color-border); + --ti-transfer-footer-color: #606266; + --ti-transfer-empty-height: var(--ti-base-size-height-minor); + --ti-transfer-empty-color: #909399; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-pack: start; + -ms-flex-pack: start; + justify-content: flex-start; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + font-size: var(--ti-transfer-font-size); +} +.tiny-transfer__buttons { + padding: 0 16px; +} +.tiny-transfer__buttons .defaultButton { + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-orient: vertical; + -webkit-box-direction: normal; + -ms-flex-direction: column; + flex-direction: column; +} +.tiny-transfer__buttons .defaultButton .tiny-button + .tiny-button { + margin-left: 0; +} +.tiny-transfer__buttons .defaultButton + .tiny-button { + margin: 12px 0 0; +} +.tiny-transfer__buttons .tiny-button { + min-width: auto; + margin: 0 0 8px 0; +} +.tiny-transfer__button { + display: block; + margin: 0 auto; + border-color: var(--ti-transfer-button-bgcolor); + background-color: var(--ti-transfer-button-bgcolor); + min-width: 30px; + min-height: 30px; + border-radius: var(--ti-transfer-button-border-radius); + line-height: normal; + padding: 8px; +} +.tiny-transfer__button.is-with-texts { + border-radius: var(--ti-transfer-button-border-radius); + min-width: 60px; +} +.tiny-transfer__button.tiny-button:not(.is-circle) .tiny-svg { + margin-right: 0; +} +.tiny-transfer__button:first-child { + margin-bottom: 12px; +} +.tiny-transfer__button:nth-child(2) { + margin: 0; +} +.tiny-transfer__button i, +.tiny-transfer__button span { + font-size: var(--ti-transfer-font-size); +} +.tiny-transfer__button [class*='tiny-icon'] + span { + margin-left: 0; +} +.tiny-transfer .tiny-transfer__button.is-disabled, +.tiny-transfer .tiny-transfer__button.is-disabled:hover { + border: 1px solid var(--ti-transfer-button-disabled-border-color); + background-color: var(--ti-transfer-button-disabled-bgcolor); + color: var(--ti-transfer-button-disabled-color); + line-height: 1; +} +.tiny-transfer .tiny-transfer__button.is-disabled .tiny-svg, +.tiny-transfer .tiny-transfer__button.is-disabled:hover .tiny-svg { + fill: var(--ti-transfer-button-disabled-color); +} +.tiny-transfer-panel { + border: 1px solid var(--ti-transfer-panel-border-color); + border-radius: var(--ti-transfer-panel-border-radius); + overflow: hidden; + background: var(--ti-transfer-panel-background); + width: var(--ti-transfer-panel-width); + max-height: 100%; + vertical-align: middle; + -webkit-box-sizing: border-box; + box-sizing: border-box; + position: relative; +} +.tiny-transfer-panel__body { + position: relative; + height: var(--ti-transfer-panel-body-height); + text-align: left; + padding-right: 2px; +} +.tiny-transfer-panel__body.is-with-footer { + padding-bottom: 40px; + height: calc(100% - 40px); +} +.tiny-transfer-panel__body .tiny-tree { + height: 100%; + padding: 0 8px 8px; + overflow: auto; +} +.tiny-transfer-panel__body .tiny-tree::-webkit-scrollbar { + width: 8px; + height: 8px; +} +.tiny-transfer-panel__body .tiny-tree::-webkit-scrollbar-track-piece { + background: #fafafa; +} +.tiny-transfer-panel__body .tiny-tree::-webkit-scrollbar-thumb { + background: #bfbfbf; + border-radius: calc(8px / 2); +} +.tiny-transfer-panel__body .tiny-tree::-webkit-scrollbar-thumb:hover { + background: #999; +} +.tiny-transfer-panel__body .tiny-tree::-webkit-scrollbar-thumb:active { + background: #999; +} +.tiny-transfer-panel__body .tiny-transfer-panel__filter ~ .tiny-tree { + height: calc(100% - 46px); +} +.tiny-transfer-panel__list { + margin: 0; + padding: 6px 0; + list-style: none; + height: var(--ti-transfer-panel-body-height); + overflow: auto; + -webkit-box-sizing: border-box; + box-sizing: border-box; + display: block; +} +.tiny-transfer-panel__list.tiny-checkbox-group { + display: block; +} +.tiny-transfer-panel__list.is-filterable { + height: var(--ti-transfer-panel-body-filter-height); + padding-top: 0; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-orient: vertical; + -webkit-box-direction: normal; + -ms-flex-direction: column; + flex-direction: column; +} +@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) { + .tiny-transfer-panel__list.is-filterable .tiny-transfer-panel__item { + -ms-flex-negative: 0; + flex-shrink: 0; + } +} +.tiny-transfer-panel .tiny-transfer-panel__list::-webkit-scrollbar { + width: 8px; + height: 8px; +} +.tiny-transfer-panel .tiny-transfer-panel__list::-webkit-scrollbar-track-piece { + background: #fafafa; +} +.tiny-transfer-panel .tiny-transfer-panel__list::-webkit-scrollbar-thumb { + background: #bfbfbf; + border-radius: calc(8px / 2); +} +.tiny-transfer-panel .tiny-transfer-panel__list::-webkit-scrollbar-thumb:hover { + background: #999; +} +.tiny-transfer-panel .tiny-transfer-panel__list::-webkit-scrollbar-thumb:active { + background: #999; +} +.tiny-transfer-panel__item { + line-height: var(--ti-transfer-panel-item-height); + padding-left: 8px; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-transition: all 0.5s; + transition: all 0.5s; +} +.tiny-transfer-panel__item + .tiny-transfer-panel__item { + margin-left: 0; + display: -webkit-box; + display: -ms-flexbox; + display: flex; +} +.tiny-transfer-panel__item.tiny-checkbox { + color: var(--ti-transfer-panel-item-color); + line-height: var(--ti-transfer-panel-item-height); + margin: 0; + display: -webkit-box; + display: -ms-flexbox; + display: flex; +} +.tiny-transfer-panel__item.tiny-checkbox.tiny-checkbox__label { + width: 100%; + overflow: hidden; + text-overflow: ellipsis; + white-space: nowrap; + display: block; + -webkit-box-sizing: border-box; + box-sizing: border-box; + padding-left: 22px; + line-height: var(--ti-transfer-panel-item-height); +} +.tiny-transfer-panel__item.tiny-checkbox .tiny-checkbox__input { + line-height: 1; +} +.tiny-transfer-panel__item:hover { + background: var(--ti-transfer-panel-item-hover-bgcolor); + color: var(--ti-transfer-panel-item-hover-font-color); +} +.tiny-transfer-panel__item.is-disabled:hover { + background: 0; +} +.tiny-transfer-panel__item.tiny-checkbox__input { + position: absolute; + top: 7px; +} +.tiny-transfer-panel__filter { + text-align: center; + padding: 8px; + -webkit-box-sizing: border-box; + box-sizing: border-box; + display: block; + width: auto; +} +.tiny-transfer-panel__filter .tiny-input__inner { + height: var(--ti-transfer-panel-filter-height); + line-height: var(--ti-transfer-panel-filter-height); + width: 100%; + font-size: var(--ti-transfer-panel-filter-font-size); + display: inline-block; + -webkit-box-sizing: border-box; + box-sizing: border-box; + border-radius: var(--ti-transfer-panel-filter-border-radius); + padding-right: 30px; + padding-left: 8px; +} +.tiny-transfer-panel__filter .tiny-input__icon { + margin-left: 5px; +} +.tiny-transfer-panel__filter .tiny-icon-circle-close { + cursor: pointer; +} +.tiny-transfer-panel .tiny-transfer-panel__header { + height: var(--ti-transfer-header-height); + line-height: var(--ti-transfer-header-height); + background: var(--ti-transfer-header-background); + margin: 0; + padding: 0 8px; + border-bottom: 1px solid var(--ti-transfer-header-border-color); + -webkit-box-sizing: border-box; + box-sizing: border-box; + color: var(--ti-transfer-header-color); + position: relative; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-pack: start; + -ms-flex-pack: start; + justify-content: flex-start; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; +} +.tiny-transfer-panel .tiny-transfer-panel__header .tiny-checkbox { + width: 100%; + line-height: 1; + text-align: left; +} +.tiny-transfer-panel .tiny-transfer-panel__header .tiny-checkbox .tiny-checkbox__label { + font-size: var(--ti-transfer-header-font-size); + color: var(--ti-transfer-header-color); + font-weight: 400; + width: calc(100% - 38px); + overflow: hidden; + text-overflow: ellipsis; + white-space: nowrap; +} +.tiny-transfer-panel .tiny-transfer-panel__header .tiny-checkbox .tiny-checkbox__label span { + position: absolute; + right: 0; + color: var(--ti-transfer-header-span-color); + font-size: var(--ti-transfer-header-font-size); + font-weight: 400; +} +.tiny-transfer-panel .tiny-transfer-panel__header .headSort { + position: absolute; + left: 50%; + top: 50%; + -webkit-transform: translateY(-50%); + transform: translateY(-50%); +} +.tiny-transfer-panel .tiny-transfer-panel__header .headSort div { + width: var(--ti-transfer-header-sort-width); + height: var(--ti-transfer-header-sort-width); + line-height: var(--ti-transfer-header-sort-width); + margin-right: 8px; + text-align: center; + border: 1px solid; + border-radius: 50%; + color: var(--ti-transfer-header-sort-color); + display: inline-block; + cursor: pointer; +} +.tiny-transfer-panel .tiny-transfer-panel__header .headSort div i { + width: calc(var(--ti-transfer-header-sort-width) - 2px); + height: calc(var(--ti-transfer-header-sort-width) - 2px); + display: block; +} +.tiny-transfer-panel .tiny-transfer-panel__footer { + height: var(--ti-transfer-footer-height); + background: var(--ti-transfer-footer-background); + margin: 0; + padding: 0; + border-top: 1px solid var(--ti-transfer-footer-border-color); + position: absolute; + bottom: 0; + left: 0; + width: 100%; + z-index: 1; +} +.tiny-transfer-panel .tiny-transfer-panel__footer::after { + display: inline-block; + content: ''; + height: 100%; + vertical-align: middle; +} +.tiny-transfer-panel .tiny-transfer-panel__footer .tiny-checkbox { + padding-left: 20px; + color: var(--ti-transfer-footer-color); +} +.tiny-transfer-panel .tiny-transfer-panel__empty { + position: absolute; + width: 100%; + top: calc(50% - 33px); + margin: 0; + height: var(--ti-transfer-empty-height); + line-height: var(--ti-transfer-empty-height); + padding: 6px 15px 0; + color: var(--ti-transfer-empty-color); + text-align: center; +} +.tiny-transfer-panel.transferGrid { + width: 600px; +} +.tiny-transfer-panel.transferGrid .tiny-transfer-panel__body { + height: 100%; +} +.tiny-transfer-panel.transferGrid .tiny-table.simple { + width: 100%; + padding: 0 8px; + height: 400px; + overflow-y: auto; +} +.tiny-transfer-panel.transferGrid .tiny-table.simple table { + width: 100%; +} +.tiny-transfer-panel.transferGrid .tiny-pager { + padding: 10px; +} +.tiny-transfer-panel .tiny-checkbox__label { + padding-left: 8px; +} +.tiny-tree { + --ti-tree-color: var(--ti-base-color-info-normal); + --ti-tree-bgcolor: var(--ti-base-color-light); + --ti-tree-empty-text-color: #909399; + --ti-tree-node-content-current-bgcolor: var(--ti-base-color-brand-2); + --ti-tree-node-content-hover-bgcolor: var(--ti-base-color-hover-background); + --ti-tree-node-label-font-size: var(--ti-common-font-size-1); + --ti-tree-node-label-margin-left: var(--ti-common-space-base); + --ti-tree-node-label-bgcolor: var(--ti-base-color-brand-5); + --ti-tree-node-label-font-color: var(--ti-base-color-light); + --ti-tree-node-icon-font-size: var(--ti-common-font-size-1); + --ti-tree-node-icon-loading-color: #1890ff; + --ti-tree-node-icon-expand-color: var(--ti-base-color-info-normal); + --ti-tree-node-checked-icon-color: var(--ti-base-color-brand-6); + position: relative; + cursor: default; + background: var(--ti-tree-bgcolor); + color: var(--ti-tree-color); +} +.tiny-tree__empty-block { + position: relative; + min-height: 60px; + text-align: center; + width: 100%; + height: 100%; +} +.tiny-tree__empty-text { + position: absolute; + left: 50%; + top: 50%; + -webkit-transform: translate(-50%, -50%); + transform: translate(-50%, -50%); + color: var(--ti-tree-empty-text-color); +} +.tiny-tree__drop-indicator { + position: absolute; + left: 0; + right: 0; + height: 1px; + background-color: #40a9ff; +} +.tiny-tree.is-dragging .tiny-tree-node__content { + cursor: move; +} +.tiny-tree.is-dragging .tiny-tree-node__content * { + pointer-events: none; +} +.tiny-tree.is-dragging.is-drop-not-allow .tiny-tree-node__content { + cursor: not-allowed; +} +.tiny-tree--highlight-current .tiny-tree-node.is-current > .tiny-tree-node__content { + background-color: #f0f7ff; +} +.tiny-tree-node { + white-space: nowrap; + outline: 0; +} +.tiny-tree-node:focus > .tiny-tree-node__content { + background-color: var(--ti-tree-node-content-hover-bgcolor); +} +.tiny-tree-node.is-current > .tiny-tree-node__content { + background-color: var(--ti-tree-node-content-current-bgcolor); +} +.tiny-tree-node.is-drop-inner > .tiny-tree-node__content .tiny-tree-node__label { + background-color: var(--ti-tree-node-label-bgcolor); + color: var(--ti-tree-node-label-font-color); +} +.tiny-tree-node.is-checked .tiny-tree-node__expand-icon, +.tiny-tree-node.is-expanded .tiny-tree-node__expand-icon, +.tiny-tree-node.is-indeterminate .tiny-tree-node__expand-icon { + fill: var(--ti-tree-node-checked-icon-color); +} +.tiny-tree-node__content { + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + height: 30px; + cursor: pointer; + border-radius: var(--ti-common-border-radius-normal); +} +.tiny-tree-node__content:hover { + background-color: var(--ti-tree-node-content-hover-bgcolor); +} +.tiny-tree-node__content > label.tiny-checkbox { + margin-left: var(--ti-tree-node-label-margin-left); +} +.tiny-tree-node__expand-icon { + cursor: pointer; + fill: var(--ti-tree-node-icon-expand-color); + font-size: var(--ti-tree-node-icon-font-size); + -webkit-transform: rotate(0); + transform: rotate(0); + -webkit-transition: -webkit-transform 0.3s ease-in-out; + transition: -webkit-transform 0.3s ease-in-out; + transition: transform 0.3s ease-in-out; + transition: transform 0.3s ease-in-out, -webkit-transform 0.3s ease-in-out; + -ms-flex-negative: 0; + flex-shrink: 0; +} +.tiny-tree-node__expand-icon.expanded { + -webkit-transform: rotate(90deg); + transform: rotate(90deg); +} +.tiny-tree-node__expand-icon.is-leaf { + visibility: hidden; +} +.tiny-tree-node__label { + font-size: var(--ti-tree-node-label-font-size); + margin-left: var(--ti-tree-node-label-margin-left); +} +.tiny-tree-node__loading.circular { + margin-right: 4px; + margin-left: var(--ti-tree-node-label-margin-left); + font-size: var(--ti-tree-node-icon-font-size); + fill: var(--ti-tree-node-icon-loading-color); + -webkit-animation: loading-rotate 2s linear infinite; + animation: loading-rotate 2s linear infinite; +} +.tiny-tree-node__loading.circular .path { + -webkit-animation: loading-dash 1.5s ease-in-out infinite; + animation: loading-dash 1.5s ease-in-out infinite; + stroke-dasharray: 90, 150; + stroke-dashoffset: 0; + stroke-width: 2; + stroke: #1890ff; + stroke-linecap: round; +} +.tiny-tree-node > .tiny-tree-node__children { + overflow: hidden; + background-color: transparent; +} +.tiny-tree-node.is-expanded > .tiny-tree-node__children { + display: block; +} +.tiny-tree-node__menu { + position: absolute; + top: 0; + left: 0; + z-index: 5000; + font-size: var(--ti-common-font-size-base); + -webkit-box-shadow: 2px 2px 4px -2px #000; + box-shadow: 2px 2px 4px -2px #000; + padding: 0 1px; + color: #606266; + font-family: Helvetica, Arial, 'Microsoft YaHei', sans-serif; + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; +} +.tiny-tree-node .tiny-radio { + margin-right: 0; +} +.tiny-tree-node .tiny-radio .tiny-radio__label { + display: none; +} +.tiny-tree-node .collapse-transition { + -webkit-transition: 0.3s height ease-in-out, 0.3s padding-top ease-in-out, 0.3s padding-bottom ease-in-out; + transition: 0.3s height ease-in-out, 0.3s padding-top ease-in-out, 0.3s padding-bottom ease-in-out; +} +@keyframes loading-rotate { + 100% { + -webkit-transform: rotate(360deg); + transform: rotate(360deg); + } +} +@keyframes loading-dash { + 0% { + stroke-dasharray: 1, 200; + stroke-dashoffset: 0; + } + 50% { + stroke-dasharray: 90, 150; + stroke-dashoffset: -40px; + } + 100% { + stroke-dasharray: 90, 150; + stroke-dashoffset: -120px; + } +} +.tiny-tree-menu { + --ti-tree-menu-width: 210px; + --ti-tree-menu-font-size: var(--ti-common-font-size-base); + --ti-tree-menu-border-color: #d9d9d9; + --ti-tree-menu-node-height: var(--ti-common-size-10x); + --ti-tree-menu-node-hover-bgcolor: var(--ti-base-color-white); + --ti-tree-menu-node-current-color: var(--ti-base-color-brand-6); + --ti-tree-menu-node-body-color: var(--ti-base-color-info-normal); + --ti-tree-minus-square-color: var(--ti-base-color-brand-6); + width: var(--ti-tree-menu-width); + position: relative; + font-size: var(--ti-tree-menu-font-size); +} +.tiny-tree-menu:before { + content: ''; + border-right: 1px solid var(--ti-tree-menu-border-color); + position: absolute; + top: 0; + right: 0; + height: 100%; + z-index: 1; +} +.tiny-tree-menu .tiny-input .tiny-input__inner { + border: none; + border-bottom: 1px solid var(--ti-tree-menu-border-color); +} +.tiny-tree-menu .tiny-tree .tiny-tree-node .tiny-tree-node__content { + height: var(--ti-tree-menu-node-height); + line-height: var(--ti-tree-menu-node-height); + overflow: hidden; +} +.tiny-tree-menu .tiny-tree .tiny-tree-node .tiny-tree-node__content .tree-node-icon { + -webkit-box-ordinal-group: 2; + -ms-flex-order: 1; + order: 1; + margin-right: 8px; +} +.tiny-tree-menu .tiny-tree .tiny-tree-node .tiny-tree-node__content .tree-node { + width: 100%; +} +.tiny-tree-menu .tiny-tree .tiny-tree-node .tiny-tree-node__content .tree-node-name { + padding: 0 24px; +} +.tiny-tree-menu .tiny-tree .tiny-tree-node.is-current > .tiny-tree-node__content { + background-color: var(--ti-tree-menu-node-hover-bgcolor); + position: relative; +} +.tiny-tree-menu .tiny-tree .tiny-tree-node.is-current > .tiny-tree-node__content .tree-node-name { + border-left: 2px solid var(--ti-tree-minus-square-color); +} +.tiny-tree-menu .tiny-tree .tiny-tree-node.is-current > .tiny-tree-node__content .tree-node-body { + color: var(--ti-tree-menu-node-current-color); +} +.tiny-tree-menu .tiny-tree .tiny-tree-node .tree-node-body { + color: var(--ti-tree-menu-node-body-color); + display: block; +} +.tiny-tree-menu .tiny-tree .tiny-tree-node .tree-node-body, +.tiny-tree-menu .tiny-tree .tiny-tree-node .tree-node-body:hover { + text-decoration: none; +} +.tiny-tree-menu .tiny-tree .tiny-tree-node.is-loading .tiny-tree-node__content .tree-node-name { + padding-left: 0; +} +.tiny-tree-menu .tiny-tree-menu__overflow.tiny-tree .tiny-tree-node .tiny-tree-node__content .tree-node-name { + white-space: nowrap; + overflow: hidden; + text-overflow: ellipsis; + display: block; + padding-right: 0; +} +.tiny-tree-menu .tiny-tree-menu__overflow.tiny-tree .tiny-tree-node .tiny-tree-node__content .tree-node { + width: calc(100% - 24px); +} +.tiny-tree-menu .tiny-tree-menu__wrap.tiny-tree .tiny-tree-node__content { + min-height: var(--ti-tree-menu-node-height); + height: auto; +} +.tiny-tree-menu .tiny-tree-menu__wrap.tiny-tree .tree-node-body { + min-height: 40px; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; +} +@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) { + .tiny-tree-menu .tiny-tree-menu__wrap.tiny-tree .tiny-tree-node__label { + display: -webkit-box; + display: -ms-flexbox; + display: flex; + } +} +.tiny-tree-menu .tiny-tree-menu__wrap.tiny-tree .tree-node-name { + white-space: normal; + line-height: normal; + display: block; + word-break: break-all; +} +.tiny-upload { + --ti-upload-tip-font-size: var(--ti-common-font-size-base); + --ti-upload-tip-color: #666; + --ti-upload-picture-card-bgcolor: #fbfdff; + --ti-upload-picture-card-border-color: #c0ccda; + --ti-upload-picture-card-border-radius: 6px; + --ti-upload-picture-card-hover-color: var(--ti-base-color-brand-5); + --ti-upload-picture-card-icon-font-size: 28px; + --ti-upload-picture-card-icon-color: #8c939d; + display: inline-block; + text-align: center; + cursor: pointer; + outline: 0; +} +.tiny-upload__input { + display: none; +} +.tiny-upload__tip { + font-size: var(--ti-upload-tip-font-size); + color: var(--ti-upload-tip-color); + margin-top: 8px; +} +.tiny-upload--picture-card { + width: 148px; + height: 148px; + line-height: 146px; + background-color: var(--ti-upload-picture-card-bgcolor); + border: 1px dashed var(--ti-upload-picture-card-border-color); + border-radius: var(--ti-upload-picture-card-border-radius); + -webkit-box-sizing: border-box; + box-sizing: border-box; + vertical-align: top; +} +.tiny-upload--picture-card svg { + font-size: var(--ti-upload-picture-card-icon-font-size); + fill: var(--ti-upload-picture-card-icon-color); +} +.tiny-upload--picture-card:hover, +.tiny-upload:focus { + border-color: var(--ti-upload-picture-card-hover-color); + color: var(--ti-upload-picture-card-hover-color); +} +.tiny-upload:focus .tiny-upload-dragger { + border-color: var(--ti-upload-picture-card-hover-color); +} +.tiny-upload-cover__title, +.tiny-upload-list__item-name { + overflow: hidden; + text-overflow: ellipsis; + white-space: nowrap; +} +.tiny-upload--picture-card, +.tiny-upload-dragger { + -webkit-box-sizing: border-box; + box-sizing: border-box; + cursor: pointer; +} +.tiny-upload iframe { + position: absolute; + z-index: -1; + top: 0; + left: 0; + opacity: 0; +} +.tiny-upload input[type='file'] { + display: none; +} +.tiny-upload-cover { + position: absolute; + left: 0; + top: 0; + width: 100%; + height: 100%; + overflow: hidden; + z-index: 10; + cursor: default; +} +.tiny-upload-cover::after { + display: inline-block; + content: ''; + height: 100%; + vertical-align: middle; +} +.tiny-upload-cover img { + display: block; + width: 100%; + height: 100%; +} +.tiny-upload-cover__label { + position: absolute; + right: -15px; + top: -6px; + width: 40px; + height: 24px; + background: #13ce66; + text-align: center; + -webkit-transform: rotate(45deg); + transform: rotate(45deg); + -webkit-box-shadow: 0 0 1pc 1px rgba(0, 0, 0, 0.2); + box-shadow: 0 0 1pc 1px rgba(0, 0, 0, 0.2); +} +.tiny-upload-cover__label i { + color: #fff; + font-size: var(--ti-common-font-size-base); + margin-top: 11px; + -webkit-transform: rotate(-45deg); + transform: rotate(-45deg); +} +.tiny-upload-cover__progress { + display: inline-block; + vertical-align: middle; + position: static; + width: 243px; +} +.tiny-upload-cover__progress + .tiny-upload__inner { + opacity: 0; +} +.tiny-upload-cover__content { + position: absolute; + top: 0; + left: 0; + width: 100%; + height: 100%; +} +.tiny-upload-cover__interact { + position: absolute; + bottom: 0; + left: 0; + width: 100%; + height: 100%; + background-color: rgba(0, 0, 0, 0.72); + text-align: center; +} +.tiny-upload-cover__interact .btn { + display: inline-block; + color: #fff; + font-size: var(--ti-common-font-size-1); + cursor: pointer; + vertical-align: middle; + -webkit-transition: opacity 0.3s cubic-bezier(0.23, 1, 0.32, 1), -webkit-transform 0.3s cubic-bezier(0.23, 1, 0.32, 1); + transition: opacity 0.3s cubic-bezier(0.23, 1, 0.32, 1), -webkit-transform 0.3s cubic-bezier(0.23, 1, 0.32, 1); + transition: transform 0.3s cubic-bezier(0.23, 1, 0.32, 1), opacity 0.3s cubic-bezier(0.23, 1, 0.32, 1); + transition: transform 0.3s cubic-bezier(0.23, 1, 0.32, 1), opacity 0.3s cubic-bezier(0.23, 1, 0.32, 1), + -webkit-transform 0.3s cubic-bezier(0.23, 1, 0.32, 1); + margin-top: 60px; +} +.tiny-upload-cover__interact .btn span { + opacity: 0; + -webkit-transition: opacity 0.15s linear; + transition: opacity 0.15s linear; +} +.tiny-upload-cover__interact .btn i { + color: #fff; + display: block; + font-size: var(--ti-common-font-size-5); + line-height: inherit; + margin: 0 auto 5px; +} +.tiny-upload-cover__interact .btn:not(:first-child) { + margin-left: 35px; +} +.tiny-upload-cover__interact .btn:hover { + -webkit-transform: translateY(-13px); + transform: translateY(-13px); +} +.tiny-upload-cover__interact .btn:hover span { + opacity: 1; +} +.tiny-upload-cover__title { + position: absolute; + bottom: 0; + left: 0; + background-color: #fff; + width: 100%; + height: 36px; + line-height: 36px; + font-weight: 400; + padding: 0 10px; + margin: 0; + font-size: var(--ti-common-font-size-1); + color: #303133; + text-align: left; +} +.tiny-upload-cover + .tiny-upload__inner { + opacity: 0; + position: relative; + z-index: 1; +} +.tiny-upload-dragger { + --ti-upload-dragger-width: 360px; + --ti-upload-dragger-height: 180px; + --ti-upload-dragger-bgcolor: #fafafa; + --ti-upload-dragger-border-color: var(--ti-base-color-border); + --ti-upload-dragger-border-radius: var(--ti-common-border-radius-normal); + --ti-upload-dragger-hover-color: var(--ti-base-color-brand-5); + --ti-upload-dragger-dragover-bgcolor: rgba(32, 159, 255, 0.06); + --ti-upload-dragger-icon-color: var(--ti-base-color-placeholder); + --ti-upload-dragger-icon-font-size: var(--ti-common-font-size-7); + --ti-upload-dragger-text-color: var(--ti-base-color-secondary); + --ti-upload-dragger-text-font-size: var(--ti-common-font-size-base); + --ti-upload-dragger-files-border-color: #dcdfe6; + width: var(--ti-upload-dragger-width); + height: var(--ti-upload-dragger-height); + background-color: var(--ti-upload-dragger-bgcolor); + border: 1px dashed var(--ti-upload-dragger-border-color); + border-radius: var(--ti-upload-dragger-border-radius); + -webkit-box-sizing: border-box; + box-sizing: border-box; + text-align: center; + overflow: hidden; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-orient: vertical; + -webkit-box-direction: normal; + -ms-flex-direction: column; + flex-direction: column; + -webkit-box-pack: center; + -ms-flex-pack: center; + justify-content: center; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; +} +.tiny-upload-dragger:hover { + border-color: var(--ti-upload-dragger-hover-color); +} +.tiny-upload-dragger.is-dragover { + background-color: var(--ti-upload-dragger-dragover-bgcolor, rgba(32, 159, 255, 0.06)); + border: 2px dashed var(--ti-upload-dragger-hover-color); +} +.tiny-upload-dragger .icon-fileupload { + font-size: var(--ti-upload-dragger-icon-font-size); + fill: var(--ti-upload-dragger-icon-color); +} +.tiny-upload-dragger .tiny-upload__text { + color: var(--ti-upload-dragger-text-color); + font-size: var(--ti-upload-dragger-text-font-size); + text-align: center; +} +.tiny-upload-dragger .tiny-upload__text em { + color: var(--ti-upload-dragger-hover-color); + font-style: normal; +} +.tiny-upload-dragger + .tiny-upload__tip { + text-align: center; +} +.tiny-upload-dragger ~ .tiny-upload__files { + border-top: 1px solid var(--ti-upload-dragger-files-border-color); + margin-top: 7px; + padding-top: 5px; +} +.tiny-upload-list { + --ti-upload-list-item-font-size: var(--ti-common-font-size-1); + --ti-upload-list-item-color: var(--ti-base-color-info-normal); + --ti-upload-list-item-border-radius: var(--ti-common-border-radius-normal); + --ti-upload-list-item-hover-background-color: #f5f7fa; + --ti-upload-list-item-hover-color: var(--ti-base-color-brand-5); + --ti-upload-list-item-name-icon-color: #909399; + --ti-upload-list-item-name-icon-font-size: var(--ti-common-font-size-2); + --ti-upload-list-svg-icon-close-color: #606266; + --ti-upload-list-svg-icon-font-size: var(--ti-common-font-size-base); + --ti-upload-list-successful-icon-font-size: var(--ti-common-font-size-1); + --ti-upload-list-picture-card-item-border-color: var(--ti-base-color-border); + --ti-upload-list-picture-card-item-bgcolor: var(--ti-base-color-light); + --ti-upload-list-successful-status-color: var(--ti-base-color-success-normal); + margin: 0; + padding: 0; + list-style: none; +} +.tiny-upload-list__item { + -webkit-transition: all 0.5s cubic-bezier(0.55, 0, 0.1, 1); + transition: all 0.5s cubic-bezier(0.55, 0, 0.1, 1); + font-size: var(--ti-upload-list-item-font-size); + color: var(--ti-upload-list-item-color); + line-height: 1.8; + margin-top: 8px; + position: relative; + -webkit-box-sizing: border-box; + box-sizing: border-box; + border-radius: var(--ti-upload-list-item-border-radius); + width: 100%; + outline: 0; +} +.tiny-upload-list__item:hover { + background-color: var(--ti-upload-list-item-hover-background-color); +} +.tiny-upload-list__item:hover .tiny-svg.icon-close, +.tiny-upload-list__item:hover .tiny-svg.icon-refres { + display: inline-block; +} +.tiny-upload-list__item:hover .tiny-progress__text { + display: none; +} +.tiny-upload-list__item.is-success .tiny-upload-list__item-status-label { + display: block; +} +.tiny-upload-list__item.is-success .tiny-upload-list__item-name:focus, +.tiny-upload-list__item.is-success .tiny-upload-list__item-name:hover { + color: var(--ti-upload-list-item-hover-color); + cursor: pointer; + text-decoration: none; +} +.tiny-upload-list__item.is-success:focus:not(:hover) .tiny-icon-close-tip { + display: inline-block; +} +.tiny-upload-list__item.is-success:active, +.tiny-upload-list__item.is-success:not(.focusing):focus { + outline-width: 0; +} +.tiny-upload-list__item.is-success:active .tiny-icon-close-tip, +.tiny-upload-list__item.is-success:focus .tiny-upload-list__item-status-label, +.tiny-upload-list__item.is-success:hover .tiny-upload-list__item-status-label, +.tiny-upload-list__item.is-success:not(.focusing):focus .tiny-icon-close-tip { + display: none; +} +.tiny-upload-list__item.is-disabled .tiny-upload-list__item:hover .tiny-upload-list__item-status-label { + display: block; +} +.tiny-upload-list__item.isEdm .tiny-upload-list__item-name { + display: inline-block; +} +.tiny-upload-list__item.isEdm .tiny-upload-list__item-name.isFail { + color: red; +} +.tiny-upload-list__item.isEdm .tiny-upload-list__item-edminfo { + margin-right: 46px; +} +.tiny-upload-list__item.isEdm .tiny-upload-list__item-status-label { + right: 16px; +} +.tiny-upload-list__item.isEdm:not(.showUpdate) .icon-refres { + display: none; +} +.tiny-upload-list__item.isEdm:not(.showDel) .icon-close { + display: none; +} +.tiny-upload-list__item.isEdm.showUpdate .icon-refres { + right: 16px; +} +.tiny-upload-list__item.isEdm.showDel .icon-close { + right: 16px; +} +.tiny-upload-list__item.isEdm.showUpdate.showDel .icon-refres { + right: 28px; +} +.tiny-upload-list__item.isEdm.showUpdate.showDel .icon-close { + right: 8px; +} +.tiny-upload-list__item.isEdm:not(.showUpdate):not(.showDel) .tiny-upload-list__item-status-label { + display: block; +} +.tiny-upload-list__item .tiny-progress { + position: absolute; + top: 20px; + width: 100%; +} +.tiny-upload-list__item .tiny-progress__text { + position: absolute; + right: 0; + top: -13px; +} +.tiny-upload-list__item .tiny-progress-bar { + margin-right: 0; + padding-right: 0; +} +.tiny-upload-list__item .tiny-svg.icon-successful { + font-size: var(--ti-upload-list-successful-icon-font-size); + fill: var(--ti-upload-list-successful-status-color); +} +.tiny-upload-list__item .tiny-svg.icon-close { + display: none; + position: absolute; + top: 50%; + right: 8px; + -webkit-transform: translateY(-50%); + transform: translateY(-50%); + fill: var(--ti-upload-list-svg-icon-close-color); + font-size: var(--ti-upload-list-svg-icon-font-size); + opacity: 0.75; + cursor: pointer; +} +.tiny-upload-list__item .tiny-svg.icon-close:hover { + opacity: 1; +} +.tiny-upload-list__item .tiny-svg.icon-refres { + display: none; + position: absolute; + top: 50%; + right: 28px; + -webkit-transform: translateY(-50%); + transform: translateY(-50%); + fill: #606266; + font-size: var(--ti-common-font-size-base); + opacity: 0.75; + cursor: pointer; +} +.tiny-upload-list__item .tiny-svg.icon-refres:hover { + opacity: 1; +} +.tiny-upload-list__item .tiny-icon-close-tip { + display: none; + position: absolute; + top: 5px; + right: 5px; + font-size: var(--ti-upload-list-svg-icon-font-size); + cursor: pointer; + opacity: 1; + color: var(--ti-upload-list-item-hover-color); +} +.tiny-upload-list__item-edminfo, +.tiny-upload-list__item-folder { + display: inline-block; + vertical-align: top; +} +.tiny-upload-list__item-edminfo { + margin-right: 20px; +} +.tiny-upload-list__item-edminfo span { + display: inline-block; + margin-right: 10px; +} +.tiny-upload-list__item-edminfo.isFail span { + color: #f5222d; +} +.tiny-upload-list__item-name { + color: var(--ti-upload-list-item-color); + display: block; + margin-right: 40px; + padding-left: 4px; + -webkit-transition: color 0.3s; + transition: color 0.3s; +} +.tiny-upload-list__item-name .tiny-svg { + font-size: var(--ti-upload-list-item-name-icon-font-size); + margin-right: 4px; + fill: var(--ti-upload-list-item-name-icon-color); +} +.tiny-upload-list__item-status-label { + position: absolute; + right: 5px; + top: 0; + line-height: inherit; + display: none; +} +.tiny-upload-list__item-delete { + position: absolute; + right: 10px; + top: 0; + font-size: var(--ti-upload-list-svg-icon-font-size); + color: var(--ti-upload-list-svg-icon-close-color); + display: none; +} +.tiny-upload-list__item-delete:hover { + color: var(--ti-upload-list-item-hover-color); +} +.tiny-upload-list--picture-card { + margin: 0; + display: inline; + vertical-align: top; +} +.tiny-upload-list--picture-card .tiny-upload-list__item { + overflow: hidden; + background-color: var(--ti-upload-list-picture-card-item-bgcolor); + border: 1px solid var(--ti-upload-list-picture-card-item-border-color); + border-radius: var(--ti-upload-list-item-border-radius); + -webkit-box-sizing: border-box; + box-sizing: border-box; + width: 148px; + height: 148px; + margin: 0 8px 8px 0; + display: inline-block; +} +.tiny-upload-list--picture-card .tiny-upload-list__item .tiny-icon-check { + fill: var(--ti-upload-list-picture-card-item-bgcolor); +} +.tiny-upload-list--picture-card .tiny-upload-list__item .tiny-svg.icon-close, +.tiny-upload-list--picture-card .tiny-upload-list__item .tiny-svg.icon-refres, +.tiny-upload-list--picture-card .tiny-upload-list__item:hover .tiny-upload-list__item-status-label { + display: none; +} +.tiny-upload-list--picture-card .tiny-upload-list__item:hover .tiny-progress__text { + display: block; +} +.tiny-upload-list--picture-card .tiny-upload-list__item-name { + display: none; +} +.tiny-upload-list--picture-card .tiny-upload-list__item-thumbnail { + width: 100%; + height: 100%; +} +.tiny-upload-list--picture-card .tiny-upload-list__item-status-label { + position: absolute; + right: -15px; + top: -6px; + width: 40px; + height: 24px; + background: var(--ti-upload-list-successful-status-color); + text-align: center; + -webkit-transform: rotate(45deg); + transform: rotate(45deg); + -webkit-box-shadow: 0 0 1pc 1px rgba(0, 0, 0, 0.2); + box-shadow: 0 0 1pc 1px rgba(0, 0, 0, 0.2); +} +.tiny-upload-list--picture-card .tiny-upload-list__item-status-label .tiny-svg { + font-size: var(--ti-upload-list-svg-icon-font-size, 12px); + margin-top: 11px; + -webkit-transform: rotate(-45deg); + transform: rotate(-45deg); +} +.tiny-upload-list--picture-card .tiny-upload-list__item-actions { + position: absolute; + width: 100%; + height: 100%; + left: 0; + top: 0; + cursor: default; + text-align: center; + color: var(--ti-upload-list-picture-card-item-bgcolor); + opacity: 0; + font-size: var(--ti-common-font-size-4); + background-color: rgba(0, 0, 0, 0.5); + -webkit-transition: opacity 0.3s; + transition: opacity 0.3s; +} +.tiny-upload-list--picture-card .tiny-upload-list__item-actions::after { + display: inline-block; + content: ''; + height: 100%; + vertical-align: middle; +} +.tiny-upload-list--picture-card .tiny-upload-list__item-actions:hover { + opacity: 1; +} +.tiny-upload-list--picture-card .tiny-upload-list__item-actions:hover span { + display: inline-block; +} +.tiny-upload-list--picture-card .tiny-upload-list__item-actions span { + display: none; + cursor: pointer; +} +.tiny-upload-list--picture-card .tiny-upload-list__item-actions span + span { + margin-left: 15px; +} +.tiny-upload-list--picture-card .tiny-upload-list__item-actions .tiny-upload-list__item-delete, +.tiny-upload-list--picture-card .tiny-upload-list__item-actions .tiny-upload-list__item-refres { + position: static; + font-size: inherit; + color: inherit; +} +.tiny-upload-list--picture-card .tiny-progress { + top: 50%; + left: 50%; + -webkit-transform: translate(-50%, -50%); + transform: translate(-50%, -50%); + bottom: auto; + width: 126px; +} +.tiny-upload-list--picture-card .tiny-progress .tiny-progress__text { + top: 50%; +} +.tiny-upload-list--picture .tiny-upload-list__item { + overflow: hidden; + z-index: 0; + background-color: var(--ti-upload-list-picture-card-item-bgcolor); + -webkit-box-sizing: border-box; + box-sizing: border-box; + margin-top: 8px; + outline: 0; +} +.tiny-upload-list--picture .tiny-upload-list__item .tiny-icon-check { + fill: var(--ti-upload-list-picture-card-item-bgcolor); +} +.tiny-upload-list--picture .tiny-upload-list__item:hover .tiny-upload-list__item-status-label { + background: 0 0; + -webkit-box-shadow: none; + box-shadow: none; + top: -2px; + right: -12px; +} +.tiny-upload-list--picture .tiny-upload-list__item:hover .tiny-progress__text { + display: block; +} +.tiny-upload-list--picture .tiny-upload-list__item.is-success .tiny-upload-list__item-name { + line-height: 56px; + margin-top: 0; +} +.tiny-upload-list--picture .tiny-upload-list__item.is-success .tiny-upload-list__item-name .tiny-svg { + display: none; +} +.tiny-upload-list--picture .tiny-upload-list__item-thumbnail { + width: 56px; + height: 56px; + border: 1px solid var(--ti-upload-list-picture-card-item-border-color); + border-radius: var(--ti-upload-list-item-border-radius); + float: left; + position: relative; + z-index: 1; + vertical-align: middle; + margin-right: 12px; +} +.tiny-upload-list--picture .tiny-upload-list__item-name { + display: block; + line-height: 56px; +} +.tiny-upload-list--picture .tiny-upload-list__item-name .tiny-svg { + font-size: var(--ti-common-font-size-1); +} +.tiny-upload-list--picture .tiny-upload-list__item-status-label { + position: absolute; + right: -17px; + top: -7px; + width: 46px; + height: 26px; + background: var(--ti-upload-list-successful-status-color); + text-align: center; + -webkit-transform: rotate(45deg); + transform: rotate(45deg); + -webkit-box-shadow: 0 1px 1px #ccc; + box-shadow: 0 1px 1px #ccc; +} +.tiny-upload-list--picture .tiny-upload-list__item-status-label .tiny-svg { + font-size: var(--ti-upload-list-svg-icon-font-size); + margin-top: 12px; + -webkit-transform: rotate(-45deg); + transform: rotate(-45deg); +} +.tiny-upload-list--picture .tiny-progress { + position: relative; + top: -7px; +} +.tiny-user { + --ti-user-font-size: var(--ti-common-font-size-base); + --ti-user-tag-background: var(--ti-base-color-hover-background); + --ti-user-svg-color: var(--ti-base-color-brand-6); +} +.tiny-user.mini { + height: 30px; +} +.tiny-user .tiny-user__select { + width: 100%; +} +.tiny-user .tiny-user__select .tiny-input .tiny-svg { + fill: var(--ti-user-svg-color); +} +.tiny-user .tiny-user__select .tiny-input.is-disabled .tiny-svg { + fill: var(--ti-input-normal-disabled-color); +} +.tiny-user .tiny-user__select .tiny-select__input { + height: 20px; +} +.tiny-user .tiny-user__ghost.tiny-tag { + background: var(--ti-user-tag-background); +} +.tiny-user_select { + max-width: 50%; + width: auto; + font-size: var(--ti-user-font-size); + white-space: nowrap; + overflow: hidden; + text-overflow: ellipsis; +} +.tiny-user_select.left { + float: left; + margin-right: 4px; +} +.tiny-user_select.right { + float: right; + margin-left: 4px; +} +.tiny-user__select-dropdown { + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-pack: start; + -ms-flex-pack: start; + justify-content: flex-start; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; +} +.tiny-user-contact { + --ti-user-account-padding: 0 var(--ti-common-space-2x); + --ti-user-account-line-height: 36px; +} +.tiny-user-contact__main .user-account-pop { + padding: var(--ti-user-account-padding); +} +.tiny-user-contact__main .user-account-custom { + line-height: var(--ti-user-account-line-height); +} +.tiny-user-contact__main .tiny-logout { + line-height: var(--ti-user-account-line-height); +} +.tiny-card { + --ti-usercard-border-color: var(--ti-base-color-border); + --ti-usercard-image-radius: var(--ti-base-radius-large); + --ti-usercard-state-online: #33cc00; + --ti-usercard-state-busy: #ff3300; + --ti-usercard-state-goaway: #ffae00; + --ti-usercard-state-offline: #aeaeae; + border: 1px solid var(--ti-usercard-border-color); + -webkit-box-shadow: 2px 3px 7px rgba(0, 0, 0, 0.15); + box-shadow: 2px 3px 7px rgba(0, 0, 0, 0.15); +} +.tiny-card .dialog-foot { + display: block; +} +.tiny-card .dialog-foot > div { + width: 100%; + text-align: center; +} +.tiny-card h5, +.tiny-card p { + margin: 5px 0; +} +.tiny-card .card-top { + margin-bottom: 10px; +} +.tiny-card .card-top img { + width: 80px; + height: 80px; + border-radius: var(--ti-usercard-image-radius, 3px); +} +.tiny-card .card-top .card-top-text { + padding: 5px 10px; + overflow: hidden; +} +.tiny-card .card-top .card-top-img, +.tiny-card .card-top .card-top-text { + display: inline-block; + vertical-align: middle; +} +.tiny-card .card-bottom { + text-align: center; + display: block; + height: 20px; + margin: 0 -20px -20px; +} +.tiny-card .espace-online { + color: var(--ti-usercard-state-online); +} +.tiny-card .espace-busy { + color: var(--ti-usercard-state-busy); + font-size: 23px; + vertical-align: middle; + margin-top: -5px; +} +.tiny-card .espace-goaway { + color: var(--ti-usercard-state-goaway); + background: #fff; + border-radius: 50%; + font-size: 13px; +} +.tiny-card .espace-offline { + color: var(--ti-usercard-state-offline); + font-size: 23px; + vertical-align: middle; + margin-top: -5px; +} +.tiny-user-contact { + --ti-user-contact-roleInfo-color: var(--ti-base-color-info-normal); + --ti-user-contact-roleInfo-font-size: var(--ti-common-font-size-base); + --ti-user-contact-card-message-color: var(--ti-base-color-placeholder); + --ti-user-contact-card-border-color: #ddd; + --ti-user-contact-card-header-background: #3f4251; + --ti-user-contact-card-header-role-color: var(--ti-base-color-light); + --ti-user-contact-card-header-role-font-size: var(--ti-common-font-size-2); + --ti-user-contact-card-header-roleNumber-color: #b9babc; + --ti-user-contact-card-espace-color: var(--ti-base-color-placeholder); + position: relative; + display: inline-block; + font-size: 0; +} +.tiny-user-contact .tiny-user-contact__main { + width: 300px; + overflow: visible; + font-size: var(--ti-user-contact-roleInfo-font-size); +} +.tiny-user-contact .tiny-user-contact__main .tiny-user-head { + height: 100%; + width: 86px; + float: left; +} +.tiny-user-contact .tiny-user-contact__main .tiny-user-head__portrait { + margin-top: 16px; + width: 54px; + height: 54px; + line-height: 54px; + margin-left: 20px; +} +.tiny-user-contact .tiny-user-contact__main .tiny-user-contact__role { + height: 100%; + width: auto; + float: left; + margin-left: 0; +} +.tiny-user-contact .tiny-user-contact__main .tiny-user-contact__role-name { + display: block; + width: 100%; + color: var(--ti-user-contact-card-header-role-color); + margin: 16px 0 6px; + height: 24px; + overflow: hidden; + text-overflow: ellipsis; + white-space: nowrap; + font-size: var(--ti-user-contact-card-header-role-font-size); + text-align: left; +} +.tiny-user-contact .tiny-user-contact__main .tiny-user-contact__role-number { + display: block; + color: var(--ti-user-contact-card-header-roleNumber-color); +} +.tiny-user-contact .tiny-user-contact__main .tiny-espace svg { + fill: var(--ti-user-contact-card-message-left-color); +} +.tiny-user-contact .tiny-user-contact__main .card-tools { + display: none; +} +.tiny-user-contact .tiny-user-contact__header { + line-height: 1.42857143; + border: 1px solid var(--ti-user-contact-card-border-color); + height: 86px; + background: var(--ti-user-contact-card-header-background); + opacity: 0.9; +} +.tiny-user-contact .tiny-user-contact__title { + display: block; + height: 100%; + font-size: var(--ti-user-contact-roleInfo-font-size); + font-weight: 400; + line-height: 46px; +} +.tiny-user-contact .tiny-user-contact__role { + display: inline-block; + color: var(--ti-user-contact-roleInfo-color); + margin-left: 8px; + vertical-align: middle; + font-size: var(--ti-user-contact-roleInfo-font-size); + line-height: 1.5; +} +.tiny-user-contact .tiny-user-contact__arrow { + margin-left: 4px; + font-size: var(--ti-user-contact-roleInfo-font-size); + vertical-align: middle; + fill: var(--ti-user-contact-roleInfo-color); +} +.tiny-user-contact .tiny-user-contact__message { + padding: 10px 20px; +} +.tiny-user-contact .tiny-user-contact__state { + text-align: left; + margin-bottom: 0; +} +.tiny-user-contact .tiny-user-contact__state:nth-of-type(2) { + margin-top: 3px; +} +.tiny-user-contact .tiny-user-contact__state:nth-of-type(3) { + margin-top: 3px; +} +.tiny-user-contact .tiny-user-contact__state-left { + color: var(--ti-user-contact-card-message-color); + opacity: 1; + font-size: var(--ti-common-font-size-base); + font-family: MicrosoftYaHei; + line-height: 16px; + text-align: left; + width: auto; + margin-right: 0; +} +.tiny-user-contact .tiny-user-contact__state-right { + color: var(--ti-user-contact-card-message-color); + opacity: 1; + font-size: var(--ti-common-font-size-base); + font-family: MicrosoftYaHei; + line-height: 16px; +} +.tiny-user-contact.tiny-popover.tiny-popper { + padding: 0; + border: 0; + border-radius: 0; +} +.tiny-user-contact .tiny-card-template__header.is-line { + height: auto; + border-bottom: 0; + padding: 0; +} +.tiny-user-contact .tiny-card-template__body { + padding: 0; + border: 1px solid var(--ti-user-contact-card-border-color); +} +.tiny-user-contact .tiny-user-head { + position: relative; + display: inline-block; + vertical-align: middle; +} +.tiny-user-contact .tiny-espace { + padding: 0 20px 10px; +} +.tiny-user-contact .tiny-espace .item-call, +.tiny-user-contact .tiny-espace .item-email, +.tiny-user-contact .tiny-espace .item-talk { + color: var(--ti-user-contact-card-espace-color); +} +.tiny-user-contact.show-arrow .tiny-user-contact__main { + width: auto; +} +.tiny-user-contact.show-arrow .tiny-user-contact__main .user-account-custom { + line-height: 30px; +} +.tiny-user-contact.show-arrow .tiny-user-contact__main .tiny-logout { + line-height: 30px; +} +.tiny-user-contact.show-arrow .tiny-card-template__body { + min-width: 180px; + border-radius: 4px; +} +.tiny-user-head { + --ti-userhead-head-size-normal: var(--ti-common-size-18x); + --ti-userhead-head-size-small: 30px; + --ti-userhead-head-icon-normal: var(--ti-common-size-10x); + --ti-userhead-head-icon-small: 14px; + --ti-userhead-head-radius: var(--ti-common-border-radius-1); + display: inline-block; + position: relative; +} +.tiny-user-head__portrait { + overflow: hidden; + width: var(--ti-userhead-head-size-normal); + height: var(--ti-userhead-head-size-normal); + line-height: var(--ti-userhead-head-size-normal); + text-align: center; + border-radius: var(--ti-userhead-head-radius); + background-position: center center; + background-repeat: no-repeat; + background-size: cover; +} +.tiny-user-head__portrait.round { + border-radius: 50%; +} +.tiny-user-head__portrait.min { + width: var(--ti-userhead-head-size-small); + height: var(--ti-userhead-head-size-small); + line-height: var(--ti-userhead-head-size-small); +} +.tiny-user-head__portrait.icon { + font-size: var(--ti-userhead-head-icon-normal); +} +.tiny-user-head__portrait.icon.min { + font-size: var(--ti-userhead-head-icon-small); +} +.tiny-user-head__portrait.icon svg { + position: absolute; + top: 50%; + left: 50%; + -webkit-transform: translate(-50%, -50%); + transform: translate(-50%, -50%); +} +.tiny-user-head__portrait.label > span { + overflow: hidden; + width: calc(100% - 6px); + display: block; + margin: 0 3px; +} +.tiny-user-head__message { + position: absolute; + top: -9px; + left: 63px; + height: 18px; + line-height: 16px; + min-width: 18px; + width: auto; + border-radius: 9px; + background: red; + color: #fff; + text-align: center; + padding: 0 2px; + border: 2px solid #fff; + font-size: var(--ti-common-font-size-base); + word-break: initial; +} +.tiny-user-head__message.round { + top: 0; + left: 54px; +} +.tiny-user-head__message.min { + top: -9px; + left: 21px; +} +.tiny-user-head__message.basic { + top: -4px; + left: 68px; + height: 8px; + width: 8px; + min-width: 8px; + line-height: 0; + border-radius: 4px; +} +.tiny-user-head__message.basic.round { + top: 10px; + left: 64px; +} +.tiny-user-head__message.basic.min { + top: -4px; + left: 26px; +} +.tiny-user-head__message.basic.min.round { + top: 0; +} +.tiny-userlink { + --ti-user-link-font-size: var(--ti-common-font-size-base); + --ti-user-link-color: var(--ti-base-color-info-normal); + --ti-user-link-font-weight: var(--ti-common-font-weight-7); + --ti-user-link-border-radius: var(--ti-base-radius-large); +} +.tiny-userlink li { + float: left; + list-style: none; +} +.tiny-userlink li .tiny-popover__reference { + font-size: var(--ti-common-font-size-base); + color: #1890ff; +} +.tiny-userlink li .tiny-popover__reference:hover { + color: #40a9ff; + text-decoration: none; + cursor: pointer; +} +.tiny-userlink .tiny-user-card { + width: 600px; +} +.tiny-user-card .card-box { + font-size: var(--ti-user-link-font-size); + color: var(--ti-user-link-color); + font-weight: var(--ti-user-link-font-weight); +} +.tiny-user-card .card-box .card-box__body .card-top-img, +.tiny-user-card .card-box .card-box__body .card-top-text { + display: inline-block; + vertical-align: middle; +} +.tiny-user-card .card-box .card-box__body .card-top-img { + width: 80px; + border-radius: var(--ti-user-link-border-radius); +} +.tiny-user-card .card-box .card-box__body .card-top-img img { + width: 100%; +} +.tiny-user-card .card-box .card-box__body .card-top-text { + padding: 5px 10px; + overflow: hidden; +} +.tiny-user-card .card-box .card-box__body .card-center { + margin-top: 10px; +} +.tiny-user-card .card-box .box__footer { + text-align: center; + cursor: pointer; +} +.tiny-user-card .card-box p { + margin: 5px 0; +} +.tiny-user-card.tiny-popover.tiny-popper { + padding: 24px; +} +.tiny-wizard { + --ti-wizard-font-size: var(--ti-common-font-size-base); + --ti-wizard-color: var(--ti-base-color-info-normal); + --ti-wizard-icon-color: var(--ti-base-color-light); + --ti-wizard-icon-bgcolor: var(--ti-base-color-brand-6); + --ti-wizard-detail-border-radius: var(--ti-common-border-radius-normal); + --ti-wizard-detail-background: var(--ti-base-color-warning-normal); + --ti-wizard-chart-icon-bgcolor: #d9d9d9; +} +.tiny-wizard .tiny-wizard__nomarl .tiny-wizard__steps { + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; +} +.tiny-wizard .tiny-wizard__nomarl .tiny-wizard__chart span { + display: inline-block; +} +.tiny-wizard .tiny-wizard__nomarl .tiny-wizard__name { + margin-top: 6px; + overflow: hidden; + text-align: center; +} +.tiny-wizard .tiny-wizard__nomarl .tiny-wizard__name .name { + font-size: var(--ti-wizard-font-size); + width: 100%; +} +.tiny-wizard .tiny-wizard__nomarl .tiny-wizard__button { + margin-top: 10px; + text-align: right; +} +.tiny-wizard .tiny-wizard__vertical .tiny-wizard__steps-item.is-doing .tiny-wizard__chart-icon { + color: var(--ti-wizard-icon-color); + background: var(--ti-wizard-icon-bgcolor); + border-color: var(--ti-wizard-icon-bgcolor); +} +.tiny-wizard .tiny-wizard__vertical .tiny-wizard__steps-item.is-doing .tiny-wizard__chart-icon .tiny-wizard__chart-line, +.tiny-wizard + .tiny-wizard__vertical + .tiny-wizard__steps-item.is-doing + .tiny-wizard__chart-icon + .tiny-wizard__chart-line.is-time-line { + background: var(--ti-wizard-icon-bgcolor); + border-color: var(--ti-wizard-icon-bgcolor); +} +.tiny-wizard .tiny-wizard__vertical .tiny-wizard__steps-item:last-child > ul .tiny-wizard__chart-line { + background: 0 0; +} +.tiny-wizard .tiny-wizard__vertical .tiny-wizard__chart-line { + height: 88px; + width: 4px; + top: 0; + position: relative; + display: inline-block; +} +.tiny-wizard .tiny-wizard__vertical .tiny-wizard__chart-name { + font-size: var(--ti-common-font-size-1); + margin-left: 15px; + display: -webkit-inline-box; + display: -ms-inline-flexbox; + display: inline-flex; + -webkit-box-orient: vertical; + -webkit-box-direction: normal; + -ms-flex-direction: column; + flex-direction: column; + -webkit-transform: translateY(-50%); + transform: translateY(-50%); + position: relative; + top: -5px; +} +.tiny-wizard .tiny-wizard__vertical .tiny-wizard__chart-icon { + position: relative; + left: 50%; + top: -14px; + -webkit-transform: translateX(-50%); + transform: translateX(-50%); +} +.tiny-wizard .tiny-wizard__vertical .tiny-wizard__time-wrapper { + position: relative; + left: 50%; + top: -14px; + -webkit-transform: translateX(-50%); + transform: translateX(-50%); + fill: var(--ti-wizard-icon-bgcolor); + font-size: var(--ti-common-font-size-5); + -webkit-box-sizing: border-box; + box-sizing: border-box; + width: 24px; + height: 24px; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + border-radius: 50%; + text-align: center; + background: var(--ti-wizard-icon-color); + border: 2px solid var(--ti-wizard-icon-bgcolor); + -webkit-box-pack: center; + -ms-flex-pack: center; + justify-content: center; +} +.tiny-wizard .tiny-wizard__vertical .tiny-wizard__time-wrapper .tiny-svg { + width: 16px; + height: 20px; +} +.tiny-wizard .tiny-wizard__vertical .tiny-wizard__chart-children { + position: relative; +} +.tiny-wizard .tiny-wizard__vertical .tiny-wizard__chart-children .children-name { + position: absolute; + margin-left: 15px; +} +.tiny-wizard .tiny-wizard__date { + min-width: 100px; + width: auto; + color: var(--ti-wizard-color); + font-size: var(--ti-wizard-font-size); + line-height: 1.2em; + display: inline-block; + text-align: right; + position: relative; + top: -24px; + right: 15px; +} +.tiny-wizard .tiny-wizard__date .date-icon { + margin-left: 4px; +} +.tiny-wizard .tiny-wizard__date span { + vertical-align: middle; +} +.tiny-wizard .tiny-wizard__date.time-line-text { + top: -14px; +} +.tiny-wizard .tiny-wizard__steps-item.is-ready .name { + color: var(--ti-wizard-icon-bgcolor); +} +.tiny-wizard .tiny-wizard__steps-item.is-ready .tiny-wizard__chart-icon { + color: var(--ti-wizard-icon-color); + background: var(--ti-wizard-icon-bgcolor); + border-color: var(--ti-wizard-icon-bgcolor); +} +.tiny-wizard .tiny-wizard__steps-item.is-ready .tiny-wizard__chart-line { + background: var(--ti-wizard-icon-bgcolor); + border-color: var(--ti-wizard-icon-bgcolor); +} +.tiny-wizard .tiny-wizard__steps-item ul { + list-style: none; +} +.tiny-wizard .tiny-wizard__chart { + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-pack: start; + -ms-flex-pack: start; + justify-content: flex-start; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; +} +.tiny-wizard .tiny-wizard__chart > .tiny-wizard__chart-svg > .tiny-svg { + font-size: var(--ti-common-font-size-4); + fill: var(--ti-wizard-icon-bgcolor); +} +.tiny-wizard .tiny-wizard__chart-children.is-doing .tiny-wizard__chart-icon, +.tiny-wizard .tiny-wizard__chart-children.is-ready .tiny-wizard__chart-icon, +.tiny-wizard .tiny-wizard__steps-item.is-doing .tiny-wizard__chart-icon, +.tiny-wizard .tiny-wizard__steps-item.is-ready .tiny-wizard__chart-icon { + color: var(--ti-wizard-icon-color); + background: var(--ti-wizard-icon-bgcolor); + border-color: var(--ti-wizard-icon-bgcolor); +} +.tiny-wizard .tiny-wizard__chart-children.is-doing .tiny-wizard__chart-line, +.tiny-wizard .tiny-wizard__steps-item.is-doing .tiny-wizard__chart-line { + background: var(--ti-wizard-icon-bgcolor); + border-color: var(--ti-wizard-icon-bgcolor); +} +.tiny-wizard .tiny-wizard__chart-children.is-ready .tiny-wizard__chart-line, +.tiny-wizard .tiny-wizard__chart-line.is-time-line { + background: var(--ti-wizard-icon-bgcolor); + border-color: var(--ti-wizard-icon-bgcolor); +} +.tiny-wizard .tiny-wizard__chart-detail { + padding: 4px 8px; + border-radius: 2px; + border-radius: var(--ti-wizard-detail-border-radius, 2px); + min-height: 26px; + height: auto; + line-height: 1; + margin-left: 12px; + text-align: center; + display: inline-block; + position: absolute; + top: -14px; +} +.tiny-wizard .tiny-wizard__chart-detail:hover { + background: var(--ti-wizard-detail-background); +} +.tiny-wizard .tiny-wizard__chart-detail:hover::before { + content: ''; + width: 0; + height: 0; + margin-top: -4px; + border-style: solid; + border-width: 4px 4px 4px 0; + border-color: transparent var(--ti-wizard-detail-background); + position: absolute; + left: -4px; + top: 10px; +} +.tiny-wizard .tiny-wizard__chart-detail:hover .detail-title, +.tiny-wizard .tiny-wizard__chart-detail:hover .tiny-user-contact__role { + color: var(--ti-wizard-icon-color); +} +.tiny-wizard .tiny-wizard__chart-detail .detail-title { + color: var(--ti-wizard-color); + font-size: var(--ti-common-font-size-1); + font-weight: 700; + margin-bottom: 8px; +} +.tiny-wizard .tiny-wizard__chart-icon { + width: 20px; + height: 20px; + line-height: 20px; + border-radius: 50%; + font-size: var(--ti-common-font-size-base); + text-align: center; + background: var(--ti-wizard-chart-icon-bgcolor); + color: var(--ti-wizard-icon-color); + -webkit-box-sizing: content-box; + box-sizing: content-box; + display: inline-block; +} +.tiny-wizard .tiny-wizard__chart-icon.time-line-icon { + width: 10px; + height: 10px; + line-height: 10px; +} +.tiny-wizard .tiny-svg, +.tiny-wizard .tiny-wizard__chart-icon, +.tiny-wizard .tiny-wizard__chart-name, +.tiny-wizard .tiny-wizard__date { + cursor: pointer; +} +.tiny-wizard .tiny-wizard__chart-line { + height: 4px; + background: #c2c4c7; + width: 50px; +} +.tiny-wizard .tiny-wizard__chart-line .tiny-wizard__chart-icon-time { + font-size: var(--ti-common-font-size-4); + fill: var(--ti-wizard-icon-bgcolor); + background: var(--ti-wizard-icon-color); +} +.tiny-wizard .tiny-user-contact .dropdown-part .tiny-user-head, +.tiny-wizard .tiny-user-contact .tiny-svg { + display: none; +} +.tiny-wizard .tiny-user-contact .tiny-user-contact__role span { + display: inline-block; +} diff --git a/mockServer/assets/images/0055f57e0a38d45ced54e1b2b566cb29_308x180.jpg b/mockServer/assets/images/0055f57e0a38d45ced54e1b2b566cb29_308x180.jpg new file mode 100644 index 000000000..f5ef0583a Binary files /dev/null and b/mockServer/assets/images/0055f57e0a38d45ced54e1b2b566cb29_308x180.jpg differ diff --git a/mockServer/assets/images/0cfe4680-dd6c-11ec-a115-b53bbc5cfe9d.png b/mockServer/assets/images/0cfe4680-dd6c-11ec-a115-b53bbc5cfe9d.png new file mode 100644 index 000000000..8c3fd36c1 Binary files /dev/null and b/mockServer/assets/images/0cfe4680-dd6c-11ec-a115-b53bbc5cfe9d.png differ diff --git a/mockServer/assets/images/120.jpg b/mockServer/assets/images/120.jpg new file mode 100644 index 000000000..cf9b61def Binary files /dev/null and b/mockServer/assets/images/120.jpg differ diff --git a/mockServer/assets/images/24b520f0-dd5d-11ec-9e28-e51c91ead705.png b/mockServer/assets/images/24b520f0-dd5d-11ec-9e28-e51c91ead705.png new file mode 100644 index 000000000..3290557f3 Binary files /dev/null and b/mockServer/assets/images/24b520f0-dd5d-11ec-9e28-e51c91ead705.png differ diff --git a/mockServer/assets/images/27f7f9d26edd98f6bb1ed8d594d408d9_100x100.jpg b/mockServer/assets/images/27f7f9d26edd98f6bb1ed8d594d408d9_100x100.jpg new file mode 100644 index 000000000..157b258c5 Binary files /dev/null and b/mockServer/assets/images/27f7f9d26edd98f6bb1ed8d594d408d9_100x100.jpg differ diff --git a/mockServer/assets/images/627366463067fa2f1a59d7db4ac55885_308x100.jpg b/mockServer/assets/images/627366463067fa2f1a59d7db4ac55885_308x100.jpg new file mode 100644 index 000000000..8280a90f7 Binary files /dev/null and b/mockServer/assets/images/627366463067fa2f1a59d7db4ac55885_308x100.jpg differ diff --git a/mockServer/assets/images/777aad0c570f653f0a95b48b898c7b4b_308x180.jpg b/mockServer/assets/images/777aad0c570f653f0a95b48b898c7b4b_308x180.jpg new file mode 100644 index 000000000..c7bf5fa9d Binary files /dev/null and b/mockServer/assets/images/777aad0c570f653f0a95b48b898c7b4b_308x180.jpg differ diff --git a/mockServer/assets/images/bbb35cd0-db30-11ec-a1c4-7b3b3de0a1d8.png b/mockServer/assets/images/bbb35cd0-db30-11ec-a1c4-7b3b3de0a1d8.png new file mode 100644 index 000000000..5fca3cee4 Binary files /dev/null and b/mockServer/assets/images/bbb35cd0-db30-11ec-a1c4-7b3b3de0a1d8.png differ diff --git a/mockServer/assets/images/e4f27d446aef8318e4b4989f1f816b1e_220x220.png b/mockServer/assets/images/e4f27d446aef8318e4b4989f1f816b1e_220x220.png new file mode 100644 index 000000000..8c3fd36c1 Binary files /dev/null and b/mockServer/assets/images/e4f27d446aef8318e4b4989f1f816b1e_220x220.png differ diff --git a/mockServer/assets/images/f750dc319828b039af713c643aad02bd_222x134.png b/mockServer/assets/images/f750dc319828b039af713c643aad02bd_222x134.png new file mode 100644 index 000000000..32659baf1 Binary files /dev/null and b/mockServer/assets/images/f750dc319828b039af713c643aad02bd_222x134.png differ diff --git a/mockServer/assets/images/logo.png b/mockServer/assets/images/logo.png new file mode 100644 index 000000000..6271b2d81 Binary files /dev/null and b/mockServer/assets/images/logo.png differ diff --git a/mockServer/assets/js/1005web-components.es.js b/mockServer/assets/js/1005web-components.es.js new file mode 100644 index 000000000..689d20a98 --- /dev/null +++ b/mockServer/assets/js/1005web-components.es.js @@ -0,0 +1,95 @@ +/** + * Copyright (c) 2023 - present TinyEngine Authors. + * Copyright (c) 2023 - present Huawei Cloud Computing Technologies Co., Ltd. + * + * Use of this source code is governed by an MIT-style license. + * + * THE OPEN SOURCE SOFTWARE IN THIS PRODUCT IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, + * BUT WITHOUT ANY WARRANTY, WITHOUT EVEN THE IMPLIED WARRANTY OF MERCHANTABILITY OR FITNESS FOR + * A PARTICULAR PURPOSE. SEE THE APPLICABLE LICENSES FOR MORE DETAILS. + * + */ + +import { defineCustomElement } from '@opentiny/tiny-engine-webcomponent-core' +import * as vue from 'vue' +import { resolveComponent, openBlock, createElementBlock, createElementVNode, createVNode, toDisplayString } from 'vue' +import { I18nInjectionKey } from 'vue-i18n' +import { IconChevronLeft } from '@opentiny/vue-icon' +Object.freeze({}) +Object.freeze([]) +const cacheStringFunction = (fn) => { + const cache = /* @__PURE__ */ Object.create(null) + return (str) => { + const hit = cache[str] + return hit || (cache[str] = fn(str)) + } +} +const hyphenateRE = /\B([A-Z])/g +const hyphenate = cacheStringFunction((str) => str.replace(hyphenateRE, '-$1').toLowerCase()) +const _export_sfc = (sfc, props) => { + const target = sfc.__vccOpts || sfc + for (const [key, val] of props) { + target[key] = val + } + return target +} +const _sfc_main = { + components: { + TinyIconChevronLeft: IconChevronLeft() + }, + props: { + blockName: { type: String, default: 'MT0526-React 1.0' } + }, + setup(props, context) { + const { t, lowcodeWrap } = vue.inject(I18nInjectionKey).lowcode() + const wrap = lowcodeWrap(props, context, t) + const state = vue.reactive({}) + const attrs = wrap({ + state + }) + return attrs + } +} +const _hoisted_1 = { + style: { 'font-size': '18px', height: '40px', 'border-bottom': '1px solid rgb(223, 225, 230)', 'margin-top': '20px' } +} +const _hoisted_2 = /* @__PURE__ */ createElementVNode( + 'span', + { style: { 'margin-left': '10px', 'font-weight': 'bold' } }, + '\u7F16\u8F91\u7269\u6599\u8D44\u4EA7\u5305 | ', + -1 +) +const _hoisted_3 = { style: { 'margin-left': '10px', 'font-weight': 'bold' } } +function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) { + const _component_tiny_icon_chevron_left = resolveComponent('tiny-icon-chevron-left') + return ( + openBlock(), + createElementBlock('div', null, [ + createElementVNode('div', _hoisted_1, [ + createVNode(_component_tiny_icon_chevron_left), + _hoisted_2, + createElementVNode('span', _hoisted_3, toDisplayString($props.blockName), 1) + ]) + ]) + ) +} +const block = /* @__PURE__ */ _export_sfc(_sfc_main, [ + ['render', _sfc_render], + ['__file', 'D:/tmp/buildground/buildground_1673597935715/src/block/generated/components/PortalBlock.vue'] +]) +window.TinyLowcodeResource = window.TinyLowcodeResource || {} +const blockName = hyphenate('PortalBlock') +block.blockId = 1005 +block.blockVersion = '1.0.0' +if (customElements.get(blockName)) { + if (window.TinyLowcodeResource[blockName]) { + Object.assign(window.TinyLowcodeResource[blockName], block) + } +} else { + block.links = { + VUE_APP_UI_LIB_FULL_STYLE_FILE_URL: ['//localhost:9090/assets/css/0.1.20/index.css'] + }.VUE_APP_UI_LIB_FULL_STYLE_FILE_URL + window.TinyLowcodeResource[blockName] = block + customElements.define(blockName, defineCustomElement(block)) +} +export { block as default } diff --git a/mockServer/assets/js/1005web-components.umd.js b/mockServer/assets/js/1005web-components.umd.js new file mode 100644 index 000000000..049e2961b --- /dev/null +++ b/mockServer/assets/js/1005web-components.umd.js @@ -0,0 +1,137 @@ +/** + * Copyright (c) 2023 - present TinyEngine Authors. + * Copyright (c) 2023 - present Huawei Cloud Computing Technologies Co., Ltd. + * + * Use of this source code is governed by an MIT-style license. + * + * THE OPEN SOURCE SOFTWARE IN THIS PRODUCT IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, + * BUT WITHOUT ANY WARRANTY, WITHOUT EVEN THE IMPLIED WARRANTY OF MERCHANTABILITY OR FITNESS FOR + * A PARTICULAR PURPOSE. SEE THE APPLICABLE LICENSES FOR MORE DETAILS. + * + */ + +;(function (global, factory) { + if (typeof exports === 'object' && typeof module !== 'undefined') { + module.exports = factory( + require('@opentiny/tiny-engine-webcomponent-core'), + require('vue'), + require('vue-i18n'), + require('@opentiny/vue-icon') + ) + } else if (typeof define === 'function' && define.amd) { + define(['@opentiny/tiny-engine-webcomponent-core', 'vue', 'vue-i18n', '@opentiny/vue-icon'], factory) + } else { + ;(global = typeof globalThis !== 'undefined' ? globalThis : global || self), + (global.TinyVueBlock = factory(global.TinyWebcomponentCore, global.Vue, global.VueI18n, global.TinyVueIcon)) + } +})(this, (tinyWebcomponentCore, vue, vueI18n, tinyVue3Icon) => { + function _interopNamespace(e) { + if (e && e.__esModule) return e + const n = Object.create(null, { [Symbol.toStringTag]: { value: 'Module' } }) + if (e) { + Object.keys(e).forEach((k) => { + if (k !== 'default') { + const d = Object.getOwnPropertyDescriptor(e, k) + Object.defineProperty( + n, + k, + d.get + ? d + : { + enumerable: true, + get: function () { + return e[k] + } + } + ) + } + }) + } + n.default = e + return Object.freeze(n) + } + const vue__namespace = /* @__PURE__ */ _interopNamespace(vue) + Object.freeze({}) + Object.freeze([]) + const cacheStringFunction = (fn) => { + const cache = /* @__PURE__ */ Object.create(null) + return (str) => { + const hit = cache[str] + return hit || (cache[str] = fn(str)) + } + } + const hyphenateRE = /\B([A-Z])/g + const hyphenate = cacheStringFunction((str) => str.replace(hyphenateRE, '-$1').toLowerCase()) + const _export_sfc = (sfc, props) => { + const target = sfc.__vccOpts || sfc + for (const [key, val] of props) { + target[key] = val + } + return target + } + const _sfc_main = { + components: { + TinyIconChevronLeft: tinyVue3Icon.IconChevronLeft() + }, + props: { + blockName: { type: String, default: 'MT0526-React 1.0' } + }, + setup(props, context) { + const { t, lowcodeWrap } = vue__namespace.inject(vueI18n.I18nInjectionKey).lowcode() + const wrap = lowcodeWrap(props, context, t) + const state = vue__namespace.reactive({}) + const attrs = wrap({ + state + }) + return attrs + } + } + const _hoisted_1 = { + style: { + 'font-size': '18px', + height: '40px', + 'border-bottom': '1px solid rgb(223, 225, 230)', + 'margin-top': '20px' + } + } + const _hoisted_2 = /* @__PURE__ */ vue.createElementVNode( + 'span', + { style: { 'margin-left': '10px', 'font-weight': 'bold' } }, + '\u7F16\u8F91\u7269\u6599\u8D44\u4EA7\u5305 | ', + -1 + ) + const _hoisted_3 = { style: { 'margin-left': '10px', 'font-weight': 'bold' } } + function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) { + const _component_tiny_icon_chevron_left = vue.resolveComponent('tiny-icon-chevron-left') + return ( + vue.openBlock(), + vue.createElementBlock('div', null, [ + vue.createElementVNode('div', _hoisted_1, [ + vue.createVNode(_component_tiny_icon_chevron_left), + _hoisted_2, + vue.createElementVNode('span', _hoisted_3, vue.toDisplayString($props.blockName), 1) + ]) + ]) + ) + } + const block = /* @__PURE__ */ _export_sfc(_sfc_main, [ + ['render', _sfc_render], + ['__file', 'D:/tmp/buildground/buildground_1673597935715/src/block/generated/components/PortalBlock.vue'] + ]) + window.TinyLowcodeResource = window.TinyLowcodeResource || {} + const blockName = hyphenate('PortalBlock') + block.blockId = 1005 + block.blockVersion = '1.0.0' + if (customElements.get(blockName)) { + if (window.TinyLowcodeResource[blockName]) { + Object.assign(window.TinyLowcodeResource[blockName], block) + } + } else { + block.links = { + VUE_APP_UI_LIB_FULL_STYLE_FILE_URL: ['//localhost:9090/assets/css/0.1.20/index.css'] + }.VUE_APP_UI_LIB_FULL_STYLE_FILE_URL + window.TinyLowcodeResource[blockName] = block + customElements.define(blockName, tinyWebcomponentCore.defineCustomElement(block)) + } + return block +}) diff --git a/mockServer/assets/js/1505web-components.es.js b/mockServer/assets/js/1505web-components.es.js new file mode 100644 index 000000000..1d33e4e1c --- /dev/null +++ b/mockServer/assets/js/1505web-components.es.js @@ -0,0 +1,81 @@ +/** +* Copyright (c) 2023 - present TinyEngine Authors. +* Copyright (c) 2023 - present Huawei Cloud Computing Technologies Co., Ltd. +* +* Use of this source code is governed by an MIT-style license. +* +* THE OPEN SOURCE SOFTWARE IN THIS PRODUCT IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, +* BUT WITHOUT ANY WARRANTY, WITHOUT EVEN THE IMPLIED WARRANTY OF MERCHANTABILITY OR FITNESS FOR +* A PARTICULAR PURPOSE. SEE THE APPLICABLE LICENSES FOR MORE DETAILS. +* +*/ + +import { + CarouselItem, + CheckboxButton, + Tree, + Popover, + Tooltip, + Col, + DropdownItem, + Pager, + Search, + Row, + FormItem, + Alert, + Input, + Tabs, + DropdownMenu, + DialogBox, + Switch, + TimeLine, + TabItem, + Radio, + Form, + Grid, + Numeric, + CheckboxGroup, + Select, + ButtonGroup, + Carousel, + Popeditor, + DatePicker, + Dropdown, + ChartHistogram +} from '@opentiny/vue' +const Mapper = { + TinyCarouselItem: CarouselItem, + TinyCheckboxButton: CheckboxButton, + TinyTree: Tree, + TinyPopover: Popover, + TinyTooltip: Tooltip, + TinyCol: Col, + TinyDropdownItem: DropdownItem, + TinyPager: Pager, + TinySearch: Search, + TinyRow: Row, + TinyFormItem: FormItem, + TinyAlert: Alert, + TinyInput: Input, + TinyTabs: Tabs, + TinyDropdownMenu: DropdownMenu, + TinyDialogBox: DialogBox, + TinySwitch: Switch, + TinyTimeLine: TimeLine, + TinyTabItem: TabItem, + TinyRadio: Radio, + TinyForm: Form, + TinyGrid: Grid, + TinyNumeric: Numeric, + TinyCheckboxGroup: CheckboxGroup, + TinySelect: Select, + TinyButtonGroup: ButtonGroup, + TinyCarousel: Carousel, + TinyPopeditor: Popeditor, + TinyDatePicker: DatePicker, + TinyDropdown: Dropdown, + TinyChartHistogram: ChartHistogram +} +Mapper.TinyTabs.isGroup = true +Mapper.TinyGrid.isGroup = true +export { Mapper as default } diff --git a/mockServer/assets/js/1505web-components.umd.js b/mockServer/assets/js/1505web-components.umd.js new file mode 100644 index 000000000..baf686393 --- /dev/null +++ b/mockServer/assets/js/1505web-components.umd.js @@ -0,0 +1,60 @@ +/** + * Copyright (c) 2023 - present TinyEngine Authors. + * Copyright (c) 2023 - present Huawei Cloud Computing Technologies Co., Ltd. + * + * Use of this source code is governed by an MIT-style license. + * + * THE OPEN SOURCE SOFTWARE IN THIS PRODUCT IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, + * BUT WITHOUT ANY WARRANTY, WITHOUT EVEN THE IMPLIED WARRANTY OF MERCHANTABILITY OR FITNESS FOR + * A PARTICULAR PURPOSE. SEE THE APPLICABLE LICENSES FOR MORE DETAILS. + * + */ + +;(function (global, factory) { + if (typeof exports === 'object' && typeof module !== 'undefined') { + module.exports = factory(require('@opentiny/vue')) + } else if (typeof define === 'function' && define.amd) { + define(['@opentiny/vue'], factory) + } else { + ;(global = typeof globalThis !== 'undefined' ? globalThis : global || self), + (global.TinyLowcodeComponent = factory(global.TinyVue)) + } +})(this, (tinyVue3) => { + 'use strict' + const Mapper = { + TinyCarouselItem: tinyVue3.CarouselItem, + TinyCheckboxButton: tinyVue3.CheckboxButton, + TinyTree: tinyVue3.Tree, + TinyPopover: tinyVue3.Popover, + TinyTooltip: tinyVue3.Tooltip, + TinyCol: tinyVue3.Col, + TinyDropdownItem: tinyVue3.DropdownItem, + TinyPager: tinyVue3.Pager, + TinySearch: tinyVue3.Search, + TinyRow: tinyVue3.Row, + TinyFormItem: tinyVue3.FormItem, + TinyAlert: tinyVue3.Alert, + TinyInput: tinyVue3.Input, + TinyTabs: tinyVue3.Tabs, + TinyDropdownMenu: tinyVue3.DropdownMenu, + TinyDialogBox: tinyVue3.DialogBox, + TinySwitch: tinyVue3.Switch, + TinyTimeLine: tinyVue3.TimeLine, + TinyTabItem: tinyVue3.TabItem, + TinyRadio: tinyVue3.Radio, + TinyForm: tinyVue3.Form, + TinyGrid: tinyVue3.Grid, + TinyNumeric: tinyVue3.Numeric, + TinyCheckboxGroup: tinyVue3.CheckboxGroup, + TinySelect: tinyVue3.Select, + TinyButtonGroup: tinyVue3.ButtonGroup, + TinyCarousel: tinyVue3.Carousel, + TinyPopeditor: tinyVue3.Popeditor, + TinyDatePicker: tinyVue3.DatePicker, + TinyDropdown: tinyVue3.Dropdown, + TinyChartHistogram: tinyVue3.ChartHistogram + } + Mapper.TinyTabs.isGroup = true + Mapper.TinyGrid.isGroup = true + return Mapper +}) diff --git a/mockServer/assets/js/989web-components.es.js b/mockServer/assets/js/989web-components.es.js new file mode 100644 index 000000000..338fa190f --- /dev/null +++ b/mockServer/assets/js/989web-components.es.js @@ -0,0 +1,246 @@ +/** + * Copyright (c) 2023 - present TinyEngine Authors. + * Copyright (c) 2023 - present Huawei Cloud Computing Technologies Co., Ltd. + * + * Use of this source code is governed by an MIT-style license. + * + * THE OPEN SOURCE SOFTWARE IN THIS PRODUCT IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, + * BUT WITHOUT ANY WARRANTY, WITHOUT EVEN THE IMPLIED WARRANTY OF MERCHANTABILITY OR FITNESS FOR + * A PARTICULAR PURPOSE. SEE THE APPLICABLE LICENSES FOR MORE DETAILS. + * + */ + +import { defineCustomElement } from '@opentiny/tiny-engine-webcomponent-core' +import * as vue from 'vue' +import { + resolveComponent, + openBlock, + createElementBlock, + createElementVNode, + createVNode, + withCtx, + pushScopeId, + popScopeId +} from 'vue' +import { I18nInjectionKey } from 'vue-i18n' +import { Button, Col, Row } from '@opentiny/vue' +Object.freeze({}) +Object.freeze([]) +const cacheStringFunction = (fn) => { + const cache = /* @__PURE__ */ Object.create(null) + return (str) => { + const hit = cache[str] + return hit || (cache[str] = fn(str)) + } +} +const hyphenateRE = /\B([A-Z])/g +const hyphenate = cacheStringFunction((str) => str.replace(hyphenateRE, '-$1').toLowerCase()) +var _style_0 = + '\n.home-content[data-v-5d023d19] {\r\n display: flex;\r\n flex-direction: column;\r\n justify-content: center;\r\n align-items: center;\r\n text-align: center;\r\n height: calc(100vh - 262px);\n}\n.home-content .btn[data-v-5d023d19] {\r\n margin-top: 24px;\n}\n.home-content .btn button[data-v-5d023d19] {\r\n border: none;\r\n border-radius: 30px;\r\n background: #5e7ce0;\r\n \r\n font-size: 14px;\r\n color: #fff;\r\n \r\n cursor: pointer;\n}\n.home-content .text[data-v-5d023d19] {\r\n font-size: 18px;\n}\n.home-content .account[data-v-5d023d19] {\r\n margin-top: 16px;\n}\n.home-content .account .sub-text[data-v-5d023d19] {\r\n color: #575d6c;\n}\n.home-content .account .login[data-v-5d023d19] {\r\n color: #1890ff;\r\n cursor: pointer;\n}\n.home-content .logo img[data-v-5d023d19]{\r\n border-radius: 50%;\r\n overflow: hidden;\n}\n' +var _export_sfc = (sfc, props) => { + const target = sfc.__vccOpts || sfc + for (const [key, val] of props) { + target[key] = val + } + return target +} +const _sfc_main = { + components: { + TinyButton: Button, + TinyCol: Col, + TinyRow: Row + }, + props: {}, + emits: ['goto-home'], + setup(props, context) { + const { t, lowcodeWrap } = vue.inject(I18nInjectionKey).lowcode() + const wrap = lowcodeWrap(props, context, t) + const state = vue.reactive({ + logoUrl: + '', + loginImgUrl: + '' + }) + const handleClick = wrap(function (event) { + this.emit('goto-home', event) + }) + const attrs = wrap({ + state, + handleClick + }) + return attrs + } +} +const _withScopeId = (n) => (pushScopeId('data-v-5d023d19'), (n = n()), popScopeId(), n) +const _hoisted_1 = { + class: 'home', + style: { height: '100vh', display: 'flex' } +} +const _hoisted_2 = { style: { width: '90%', height: '50%' } } +const _hoisted_3 = ['src'] +const _hoisted_4 = { + class: 'home-content', + style: { 'font-size': '14px' } +} +const _hoisted_5 = { class: 'text' } +const _hoisted_6 = { style: { 'font-size': '16px' } } +const _hoisted_7 = { class: 'logo' } +const _hoisted_8 = ['src'] +const _hoisted_9 = { + style: { + display: 'block', + 'font-size': '28px', + 'margin-top': '12px', + 'margin-bottom': '12px', + 'font-weight': 'bold' + }, + ref: '', + class: 'title' +} +const _hoisted_10 = /* @__PURE__ */ _withScopeId(() => + /* @__PURE__ */ createElementVNode( + 'span', + { style: { display: 'block', 'margin-bottom': '12px' } }, + '\u81F4\u529B\u4E8E\u901A\u8FC7\u53CB\u597D\u7684\u7528\u6237\u4EA4\u4E92\u63D0\u5347\u4E1A\u52A1\u7684\u5F00\u53D1\u6548\u7387', + -1 + ) +) +const _hoisted_11 = /* @__PURE__ */ _withScopeId(() => + /* @__PURE__ */ createElementVNode( + 'span', + { style: { 'margin-top': '12px' } }, + '\u6B22\u8FCE\u4E00\u8D77\u6765\u89E3\u9501~~', + -1 + ) +) +const _hoisted_12 = { class: 'btn' } +const _hoisted_13 = { class: 'account' } +const _hoisted_14 = { style: { 'font-size': '14px', 'margin-top': '4px' } } +const _hoisted_15 = /* @__PURE__ */ _withScopeId(() => + /* @__PURE__ */ createElementVNode('span', { style: { color: '#777777' } }, '\u5DF2\u6709\u56E2\u961F\uFF1F', -1) +) +function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) { + const _component_tiny_col = resolveComponent('tiny-col') + const _component_tiny_button = resolveComponent('tiny-button') + const _component_tiny_row = resolveComponent('tiny-row') + return ( + openBlock(), + createElementBlock('div', null, [ + createElementVNode('div', _hoisted_1, [ + createVNode( + _component_tiny_row, + { + align: 'middle', + flex: true, + style: {} + }, + { + default: withCtx(() => [ + createVNode( + _component_tiny_col, + { + span: 6, + style: { 'text-align': 'center', display: 'flex', 'justify-content': 'center' } + }, + { + default: withCtx(() => [ + createElementVNode('div', _hoisted_2, [ + createElementVNode( + 'img', + { + style: { width: '100%', height: '100%' }, + src: _ctx.state.loginImgUrl + }, + null, + 8, + _hoisted_3 + ) + ]) + ]), + _: 1 + } + ), + createVNode( + _component_tiny_col, + { + span: '6', + style: { 'text-align': 'center' } + }, + { + default: withCtx(() => [ + createElementVNode('div', _hoisted_4, [ + createElementVNode('div', _hoisted_5, [ + createElementVNode('div', _hoisted_6, [ + createElementVNode('div', _hoisted_7, [ + createElementVNode( + 'img', + { + style: { width: '105px', height: '105px', 'border-radius': '100px' }, + src: _ctx.state.logoUrl + }, + null, + 8, + _hoisted_8 + ) + ]), + createElementVNode('span', _hoisted_9, 'TinyLowCode \u4F4E\u4EE3\u7801\u5E73\u53F0', 512), + _hoisted_10, + _hoisted_11 + ]), + createElementVNode('div', _hoisted_12, [ + createVNode(_component_tiny_button, { + text: '\u7ACB\u5373\u4F53\u9A8C', + round: true, + type: 'primary', + style: { 'margin-top': '40px' } + }), + createElementVNode('div', _hoisted_13, [ + createElementVNode('div', _hoisted_14, [ + _hoisted_15, + createElementVNode( + 'span', + { + style: { color: '#5e7ce0' }, + onClick: _cache[0] || (_cache[0] = ($event) => _ctx.handleClick(_ctx.event)) + }, + '\u7ACB\u5373\u8FDB\u5165' + ) + ]) + ]) + ]) + ]) + ]) + ]), + _: 1 + } + ) + ]), + _: 1 + } + ) + ]) + ]) + ) +} +var block = /* @__PURE__ */ _export_sfc(_sfc_main, [ + ['render', _sfc_render], + ['styles', [_style_0]], + ['__scopeId', 'data-v-5d023d19'], + ['__file', 'D:/tmp/buildground/buildground_1673597486053/src/block/generated/components/PortalHome.vue'] +]) +window.TinyLowcodeResource = window.TinyLowcodeResource || {} +const blockName = hyphenate('PortalHome') +block.blockId = 989 +block.blockVersion = '1.0.0' +if (customElements.get(blockName)) { + if (window.TinyLowcodeResource[blockName]) { + Object.assign(window.TinyLowcodeResource[blockName], block) + } +} else { + block.links = { + VUE_APP_UI_LIB_FULL_STYLE_FILE_URL: ['//localhost:9090/assets/css/0.1.20/index.css'] + }.VUE_APP_UI_LIB_FULL_STYLE_FILE_URL + window.TinyLowcodeResource[blockName] = block + customElements.define(blockName, defineCustomElement(block)) +} +export { block as default } diff --git a/mockServer/assets/js/989web-components.umd.js b/mockServer/assets/js/989web-components.umd.js new file mode 100644 index 000000000..b98d7d83a --- /dev/null +++ b/mockServer/assets/js/989web-components.umd.js @@ -0,0 +1,283 @@ +/** + * Copyright (c) 2023 - present TinyEngine Authors. + * Copyright (c) 2023 - present Huawei Cloud Computing Technologies Co., Ltd. + * + * Use of this source code is governed by an MIT-style license. + * + * THE OPEN SOURCE SOFTWARE IN THIS PRODUCT IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, + * BUT WITHOUT ANY WARRANTY, WITHOUT EVEN THE IMPLIED WARRANTY OF MERCHANTABILITY OR FITNESS FOR + * A PARTICULAR PURPOSE. SEE THE APPLICABLE LICENSES FOR MORE DETAILS. + * + */ + +;(function (global, factory) { + typeof exports === 'object' && typeof module !== 'undefined' + ? (module.exports = factory( + require('@opentiny/tiny-engine-webcomponent-core'), + require('vue'), + require('vue-i18n'), + require('@opentiny/vue') + )) + : typeof define === 'function' && define.amd + ? define(['@opentiny/tiny-engine-webcomponent-core', 'vue', 'vue-i18n', '@opentiny/vue'], factory) + : ((global = typeof globalThis !== 'undefined' ? globalThis : global || self), + (global.TinyVueBlock = factory(global.TinyWebcomponentCore, global.Vue, global.VueI18n, global.TinyVue))) +})(this, function (tinyWebcomponentCore, vue, vueI18n, tinyVue3) { + 'use strict' + function _interopNamespace(e) { + if (e && e.__esModule) return e + var n = Object.create(null, { [Symbol.toStringTag]: { value: 'Module' } }) + if (e) { + Object.keys(e).forEach(function (k) { + if (k !== 'default') { + var d = Object.getOwnPropertyDescriptor(e, k) + Object.defineProperty( + n, + k, + d.get + ? d + : { + enumerable: true, + get: function () { + return e[k] + } + } + ) + } + }) + } + n['default'] = e + return Object.freeze(n) + } + var vue__namespace = /* @__PURE__ */ _interopNamespace(vue) + Object.freeze({}) + Object.freeze([]) + const cacheStringFunction = (fn) => { + const cache = /* @__PURE__ */ Object.create(null) + return (str) => { + const hit = cache[str] + return hit || (cache[str] = fn(str)) + } + } + const hyphenateRE = /\B([A-Z])/g + const hyphenate = cacheStringFunction((str) => str.replace(hyphenateRE, '-$1').toLowerCase()) + var _style_0 = + '\n.home-content[data-v-5d023d19] {\r\n display: flex;\r\n flex-direction: column;\r\n justify-content: center;\r\n align-items: center;\r\n text-align: center;\r\n height: calc(100vh - 262px);\n}\n.home-content .btn[data-v-5d023d19] {\r\n margin-top: 24px;\n}\n.home-content .btn button[data-v-5d023d19] {\r\n border: none;\r\n border-radius: 30px;\r\n background: #5e7ce0;\r\n \r\n font-size: 14px;\r\n color: #fff;\r\n \r\n cursor: pointer;\n}\n.home-content .text[data-v-5d023d19] {\r\n font-size: 18px;\n}\n.home-content .account[data-v-5d023d19] {\r\n margin-top: 16px;\n}\n.home-content .account .sub-text[data-v-5d023d19] {\r\n color: #575d6c;\n}\n.home-content .account .login[data-v-5d023d19] {\r\n color: #1890ff;\r\n cursor: pointer;\n}\n.home-content .logo img[data-v-5d023d19]{\r\n border-radius: 50%;\r\n overflow: hidden;\n}\n' + var _export_sfc = (sfc, props) => { + const target = sfc.__vccOpts || sfc + for (const [key, val] of props) { + target[key] = val + } + return target + } + const _sfc_main = { + components: { + TinyButton: tinyVue3.Button, + TinyCol: tinyVue3.Col, + TinyRow: tinyVue3.Row + }, + props: {}, + emits: ['goto-home'], + setup(props, context) { + const { t, lowcodeWrap } = vue__namespace.inject(vueI18n.I18nInjectionKey).lowcode() + const wrap = lowcodeWrap(props, context, t) + const state = vue__namespace.reactive({ + logoUrl: + '', + loginImgUrl: + '' + }) + const handleClick = wrap(function (event) { + this.emit('goto-home', event) + }) + const attrs = wrap({ + state, + handleClick + }) + return attrs + } + } + const _withScopeId = (n) => (vue.pushScopeId('data-v-5d023d19'), (n = n()), vue.popScopeId(), n) + const _hoisted_1 = { + class: 'home', + style: { height: '100vh', display: 'flex' } + } + const _hoisted_2 = { style: { width: '90%', height: '50%' } } + const _hoisted_3 = ['src'] + const _hoisted_4 = { + class: 'home-content', + style: { 'font-size': '14px' } + } + const _hoisted_5 = { class: 'text' } + const _hoisted_6 = { style: { 'font-size': '16px' } } + const _hoisted_7 = { class: 'logo' } + const _hoisted_8 = ['src'] + const _hoisted_9 = { + style: { + display: 'block', + 'font-size': '28px', + 'margin-top': '12px', + 'margin-bottom': '12px', + 'font-weight': 'bold' + }, + ref: '', + class: 'title' + } + const _hoisted_10 = /* @__PURE__ */ _withScopeId(() => + /* @__PURE__ */ vue.createElementVNode( + 'span', + { style: { display: 'block', 'margin-bottom': '12px' } }, + '\u81F4\u529B\u4E8E\u901A\u8FC7\u53CB\u597D\u7684\u7528\u6237\u4EA4\u4E92\u63D0\u5347\u4E1A\u52A1\u7684\u5F00\u53D1\u6548\u7387', + -1 + ) + ) + const _hoisted_11 = /* @__PURE__ */ _withScopeId(() => + /* @__PURE__ */ vue.createElementVNode( + 'span', + { style: { 'margin-top': '12px' } }, + '\u6B22\u8FCE\u4E00\u8D77\u6765\u89E3\u9501~~', + -1 + ) + ) + const _hoisted_12 = { class: 'btn' } + const _hoisted_13 = { class: 'account' } + const _hoisted_14 = { style: { 'font-size': '14px', 'margin-top': '4px' } } + const _hoisted_15 = /* @__PURE__ */ _withScopeId(() => + /* @__PURE__ */ vue.createElementVNode( + 'span', + { style: { color: '#777777' } }, + '\u5DF2\u6709\u56E2\u961F\uFF1F', + -1 + ) + ) + function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) { + const _component_tiny_col = vue.resolveComponent('tiny-col') + const _component_tiny_button = vue.resolveComponent('tiny-button') + const _component_tiny_row = vue.resolveComponent('tiny-row') + return ( + vue.openBlock(), + vue.createElementBlock('div', null, [ + vue.createElementVNode('div', _hoisted_1, [ + vue.createVNode( + _component_tiny_row, + { + align: 'middle', + flex: true, + style: {} + }, + { + default: vue.withCtx(() => [ + vue.createVNode( + _component_tiny_col, + { + span: 6, + style: { 'text-align': 'center', display: 'flex', 'justify-content': 'center' } + }, + { + default: vue.withCtx(() => [ + vue.createElementVNode('div', _hoisted_2, [ + vue.createElementVNode( + 'img', + { + style: { width: '100%', height: '100%' }, + src: _ctx.state.loginImgUrl + }, + null, + 8, + _hoisted_3 + ) + ]) + ]), + _: 1 + } + ), + vue.createVNode( + _component_tiny_col, + { + span: '6', + style: { 'text-align': 'center' } + }, + { + default: vue.withCtx(() => [ + vue.createElementVNode('div', _hoisted_4, [ + vue.createElementVNode('div', _hoisted_5, [ + vue.createElementVNode('div', _hoisted_6, [ + vue.createElementVNode('div', _hoisted_7, [ + vue.createElementVNode( + 'img', + { + style: { width: '105px', height: '105px', 'border-radius': '100px' }, + src: _ctx.state.logoUrl + }, + null, + 8, + _hoisted_8 + ) + ]), + vue.createElementVNode( + 'span', + _hoisted_9, + 'TinyLowCode \u4F4E\u4EE3\u7801\u5E73\u53F0', + 512 + ), + _hoisted_10, + _hoisted_11 + ]), + vue.createElementVNode('div', _hoisted_12, [ + vue.createVNode(_component_tiny_button, { + text: '\u7ACB\u5373\u4F53\u9A8C', + round: true, + type: 'primary', + style: { 'margin-top': '40px' } + }), + vue.createElementVNode('div', _hoisted_13, [ + vue.createElementVNode('div', _hoisted_14, [ + _hoisted_15, + vue.createElementVNode( + 'span', + { + style: { color: '#5e7ce0' }, + onClick: _cache[0] || (_cache[0] = ($event) => _ctx.handleClick(_ctx.event)) + }, + '\u7ACB\u5373\u8FDB\u5165' + ) + ]) + ]) + ]) + ]) + ]) + ]), + _: 1 + } + ) + ]), + _: 1 + } + ) + ]) + ]) + ) + } + var block = /* @__PURE__ */ _export_sfc(_sfc_main, [ + ['render', _sfc_render], + ['styles', [_style_0]], + ['__scopeId', 'data-v-5d023d19'], + ['__file', 'D:/tmp/buildground/buildground_1673597486053/src/block/generated/components/PortalHome.vue'] + ]) + window.TinyLowcodeResource = window.TinyLowcodeResource || {} + const blockName = hyphenate('PortalHome') + block.blockId = 989 + block.blockVersion = '1.0.0' + if (customElements.get(blockName)) { + if (window.TinyLowcodeResource[blockName]) { + Object.assign(window.TinyLowcodeResource[blockName], block) + } + } else { + block.links = { + VUE_APP_UI_LIB_FULL_STYLE_FILE_URL: ['//localhost:9090/assets/css/0.1.20/index.css'] + }.VUE_APP_UI_LIB_FULL_STYLE_FILE_URL + window.TinyLowcodeResource[blockName] = block + customElements.define(blockName, tinyWebcomponentCore.defineCustomElement(block)) + } + return block +}) diff --git a/mockServer/assets/js/998web-components.es.js b/mockServer/assets/js/998web-components.es.js new file mode 100644 index 000000000..173aa1786 --- /dev/null +++ b/mockServer/assets/js/998web-components.es.js @@ -0,0 +1,664 @@ +/** + * Copyright (c) 2023 - present TinyEngine Authors. + * Copyright (c) 2023 - present Huawei Cloud Computing Technologies Co., Ltd. + * + * Use of this source code is governed by an MIT-style license. + * + * THE OPEN SOURCE SOFTWARE IN THIS PRODUCT IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, + * BUT WITHOUT ANY WARRANTY, WITHOUT EVEN THE IMPLIED WARRANTY OF MERCHANTABILITY OR FITNESS FOR + * A PARTICULAR PURPOSE. SEE THE APPLICABLE LICENSES FOR MORE DETAILS. + * + */ + +import { defineCustomElement } from '@opentiny/tiny-engine-webcomponent-core' +import * as vue from 'vue' +import { + resolveComponent, + openBlock, + createElementBlock, + createElementVNode, + Fragment, + renderList, + toDisplayString, + normalizeClass, + createVNode, + withCtx, + createBlock, + createCommentVNode, + pushScopeId, + popScopeId +} from 'vue' +import { I18nInjectionKey } from 'vue-i18n' +import { IconCheckOut, IconDeltaDown, IconGroup, IconHelpQuery, IconSetting, IconYes } from '@opentiny/vue-icon' +import { Popover, Tooltip } from '@opentiny/vue' +Object.freeze({}) +Object.freeze([]) +const cacheStringFunction = (fn) => { + const cache = /* @__PURE__ */ Object.create(null) + return (str) => { + const hit = cache[str] + return hit || (cache[str] = fn(str)) + } +} +const hyphenateRE = /\B([A-Z])/g +const hyphenate = cacheStringFunction((str) => str.replace(hyphenateRE, '-$1').toLowerCase()) +const _style_0 = + '\n.team-list-item.active[data-v-b66e3972] {\r\n border: 1px solid #38acff;\n}\n.toolbars-item[data-v-b66e3972]:hover {\r\n cursor: pointer;\r\n background-color: #f1f2f3;\n}\n.toolbars-item.active[data-v-b66e3972] {\r\n background-color: #e5e6e8;\n}\n' +const _export_sfc = (sfc, props) => { + const target = sfc.__vccOpts || sfc + for (const [key, val] of props) { + target[key] = val + } + return target +} +const _sfc_main = { + components: { + TinyIconCheckOut: IconCheckOut(), + TinyIconDeltaDown: IconDeltaDown(), + TinyIconGroup: IconGroup(), + TinyIconHelpQuery: IconHelpQuery(), + TinyIconSetting: IconSetting(), + TinyIconYes: IconYes(), + TinyPopover: Popover, + TinyTooltip: Tooltip + }, + props: { + tenant: { type: Object, default: () => "{tenant_id: 'public'}" } + }, + emits: ['handle-route'], + setup(props, context) { + const { t, lowcodeWrap } = vue.inject(I18nInjectionKey).lowcode() + const wrap = lowcodeWrap(props, context, t) + const state = vue.reactive({ + menuData: [ + { + label: '\u9996\u9875', + url: '/home' + }, + { + label: '\u6211\u7684\u5E94\u7528', + url: '/home' + }, + { + label: '\u5E94\u7528\u4E2D\u5FC3', + url: '/home' + }, + { + label: '\u6211\u7684\u5E73\u53F0', + url: '/home' + }, + { + label: '\u5E73\u53F0\u4E2D\u5FC3', + url: '/home' + }, + { + label: '\u6211\u7684\u7269\u6599', + url: '/home' + }, + { + label: '\u751F\u6001\u4E2D\u5FC3', + url: '/home' + }, + { + label: '\u76D1\u63A7\u4E2D\u5FC3', + url: '/home' + } + ], + tenants: [ + { + id: 1, + tenant_id: 'public', + name_cn: '\u516C\u5171\u79DF\u6237', + name_en: 'Public Tenant', + description: 'Default tenant for new user to explore.', + published_at: '2021-12-28T11:39:10.000Z', + created_by: null, + updated_by: null, + created_at: '2021-12-28T11:39:10.000Z', + updated_at: '2022-06-27T03:52:15.000Z', + createdBy: null + }, + { + id: 2, + tenant_id: 'crm', + name_cn: '\u5BA2\u6237\u5173\u7CFB\u7BA1\u7406\u7CFB\u7EDF', + name_en: 'Cloud CRM', + description: null, + published_at: '2021-12-30T07:39:19.000Z', + created_by: null, + created_at: '2021-12-30T14:41:57.000Z', + updated_at: '2022-06-14T06:28:08.000Z', + createdBy: null + }, + { + id: 3, + tenant_id: 'tinyMock', + name_cn: 'mock\u5E73\u53F0', + name_en: null, + description: null, + published_at: '2022-05-26T07:13:28.000Z', + created_by: null, + updated_by: null, + created_at: '2022-05-26T07:13:29.000Z', + updated_at: '2022-05-26T07:13:29.000Z', + createdBy: null, + updatedBy: null + }, + { + id: 4, + tenant_id: 'tinyStage', + name_cn: '\u5F00\u53D1\u5DE5\u5177\u96C6', + name_en: 'toolkits', + description: null, + published_at: '2022-05-18T07:56:55.000Z', + created_by: null, + updated_by: null, + created_at: '2022-05-18T07:56:55.000Z', + updated_at: '2022-05-18T07:56:55.000Z' + }, + { + id: 5, + tenant_id: 'tinyUI', + name_cn: 'UI\u7EC4\u4EF6', + name_en: 'components', + description: null, + published_at: '2022-05-18T08:29:32.000Z', + created_by: null, + updated_by: null, + created_at: '2022-05-18T08:29:32.000Z', + updated_at: '2022-05-18T08:29:33.000Z' + }, + { + id: 6, + tenant_id: 'tinyGate', + name_cn: '\u95E8\u7981\u7CFB\u7EDF', + name_en: 'gate', + description: null, + published_at: '2022-06-23T10:15:42.000Z', + created_by: null, + updated_by: null, + created_at: '2022-05-23T10:40:14.000Z', + updated_at: '2022-05-23T10:40:14.000Z', + createdBy: null, + updatedBy: null + }, + { + id: 7, + tenant_id: 'guestGroup', + name_cn: '\u6E38\u5BA2\u56E2\u961F', + name_en: 'guest', + description: null, + published_at: '2022-06-23T10:15:38.000Z', + created_by: null, + updated_by: null, + created_at: '2022-06-22T14:58:22.000Z', + updated_at: '2022-06-22T14:58:22.000Z' + }, + { + id: 265, + tenant_id: 'myteam', + name_cn: null, + name_en: null, + description: null, + published_at: '2022-06-14T06:49:58.000Z', + created_by: null, + updated_by: null, + created_at: '2022-06-14T06:49:58.000Z', + updated_at: '2022-06-14T06:49:58.000Z' + }, + { + id: 267, + tenant_id: 'test', + name_cn: null, + name_en: null, + description: null, + published_at: '2022-06-15T03:35:14.000Z', + created_by: null, + updated_by: null, + created_at: '2022-06-15T03:35:14.000Z', + updated_at: '2022-06-15T03:35:14.000Z' + }, + { + id: 268, + tenant_id: 'zzcTest', + name_cn: null, + name_en: null, + description: null, + published_at: '2022-06-17T08:47:17.000Z', + created_by: null, + updated_by: null, + created_at: '2022-06-17T08:47:17.000Z', + updated_at: '2022-06-17T08:47:17.000Z' + } + ] + }) + const openHomePage = wrap(function openHomePage2(event) { + this.router.push('/team-home') + }) + const gotoRouter = wrap(function gotoRouter2(event) { + this.emit('handle-route', event) + }) + const attrs = wrap({ + state, + openHomePage, + gotoRouter + }) + return attrs + } +} +const _withScopeId = (n) => (pushScopeId('data-v-b66e3972'), (n = n()), popScopeId(), n) +const _hoisted_1 = { + style: { + display: 'flex', + 'justify-content': 'space-between', + 'align-items': 'center', + height: '50px', + 'border-radius': '0px' + } +} +const _hoisted_2 = /* @__PURE__ */ _withScopeId(() => + /* @__PURE__ */ createElementVNode( + 'img', + { + src: 'http://localhost:9090/assets/images/bbb35cd0-db30-11ec-a1c4-7b3b3de0a1d8.png', + style: { display: 'block', width: '48px', height: 'auto', 'margin-left': '10px' } + }, + null, + -1 + ) +) +const _hoisted_3 = /* @__PURE__ */ _withScopeId(() => + /* @__PURE__ */ createElementVNode('span', { style: { 'font-weight': 'bolder', color: '#000000' } }, 'TinyEngine', -1) +) +const _hoisted_4 = [_hoisted_2, _hoisted_3] +const _hoisted_5 = { + style: { + width: '230px', + height: '50px', + display: 'flex', + 'justify-content': 'space-around', + 'align-items': 'center', + 'margin-right': '10px', + 'border-radius': '0px' + }, + class: 'toolbars' +} +const _hoisted_6 = /* @__PURE__ */ _withScopeId(() => + /* @__PURE__ */ createElementVNode('div', { placeholder: '\u89E6\u53D1\u6E90' }, null, -1) +) +const _hoisted_7 = { + style: { + 'padding-top': '6px', + 'padding-left': '6px', + 'padding-right': '6px', + 'padding-bottom': '6px', + 'margin-left': '8px', + 'border-radius': '6px' + } +} +const _hoisted_8 = /* @__PURE__ */ _withScopeId(() => + /* @__PURE__ */ createElementVNode('div', { placeholder: '\u89E6\u53D1\u6E90' }, null, -1) +) +const _hoisted_9 = { + style: { + 'padding-top': '6px', + 'padding-left': '6px', + 'padding-right': '6px', + 'padding-bottom': '6px', + 'margin-left': '8px', + 'border-radius': '6px' + } +} +const _hoisted_10 = /* @__PURE__ */ _withScopeId(() => + /* @__PURE__ */ createElementVNode('div', { placeholder: '\u89E6\u53D1\u6E90' }, null, -1) +) +const _hoisted_11 = /* @__PURE__ */ _withScopeId(() => + /* @__PURE__ */ createElementVNode( + 'span', + { + class: 'split', + style: { margin: '0 8px', 'font-size': '16px', 'border-radius': '0px', color: '#e5e6e8' } + }, + '|', + -1 + ) +) +const _hoisted_12 = { placeholder: '\u89E6\u53D1\u6E90' } +const _hoisted_13 = { + class: 'toolbars-item', + style: { padding: '6px', 'border-radius': '6px', display: 'flex', 'align-items': 'center' } +} +const _hoisted_14 = /* @__PURE__ */ _withScopeId(() => + /* @__PURE__ */ createElementVNode('span', { style: { 'border-radius': '0px' } }, 'public', -1) +) +const _hoisted_15 = { + placeholder: '\u63D0\u793A\u5185\u5BB9', + style: { 'border-radius': '0px' } +} +const _hoisted_16 = { + style: { 'border-radius': '0px' }, + class: 'team-list' +} +const _hoisted_17 = /* @__PURE__ */ _withScopeId(() => + /* @__PURE__ */ createElementVNode( + 'div', + { + class: 'team-list-title', + style: { + 'font-size': '16px', + 'line-height': '22px', + 'font-weight': '500', + 'text-overflow': 'ellipsis', + 'white-space': 'nowrap', + overflow: 'hidden' + } + }, + [/* @__PURE__ */ createElementVNode('span', null, '\u7EC4\u7EC7/\u56E2\u961F')], + -1 + ) +) +const _hoisted_18 = { + class: 'team-list-group', + style: { height: 'auto', 'max-height': '335px', overflow: 'auto', 'margin-top': '16px', 'border-radius': '0px' } +} +const _hoisted_19 = { + class: 'team-list-item-logo', + style: { + height: '28px', + width: '28px', + 'border-radius': '8px', + 'font-size': '16px', + color: '#fff', + background: '#38acff', + 'margin-right': '12px', + display: 'flex', + 'align-items': 'center', + 'justify-content': 'center' + } +} +const _hoisted_20 = { + style: { + height: '22px', + 'font-size': '14px', + 'line-height': '22px', + color: 'rgba(0, 0, 0, 0.8)', + flex: '1', + 'margin-right': '5px', + overflow: 'hidden', + 'text-overflow': 'ellipsis', + 'white-space': 'nowrap', + 'border-radius': '0px' + } +} +const _hoisted_21 = { + style: { 'border-radius': '0px' }, + class: 'team-list-item-icon' +} +const _hoisted_22 = /* @__PURE__ */ _withScopeId(() => + /* @__PURE__ */ createElementVNode( + 'img', + { + style: { width: '40px', height: 'auto', 'border-radius': '50px' }, + src: 'https://localhost:9090/assets/images/120' + }, + null, + -1 + ) +) +function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) { + let _a + const _component_tiny_icon_setting = resolveComponent('tiny-icon-setting') + const _component_tiny_tooltip = resolveComponent('tiny-tooltip') + const _component_tiny_icon_check_out = resolveComponent('tiny-icon-check-out') + const _component_tiny_icon_help_query = resolveComponent('tiny-icon-help-query') + const _component_tiny_icon_delta_down = resolveComponent('tiny-icon-delta-down') + const _component_tiny_icon_group = resolveComponent('tiny-icon-group') + const _component_tiny_icon_yes = resolveComponent('tiny-icon-yes') + const _component_tiny_popover = resolveComponent('tiny-popover') + return ( + openBlock(), + createElementBlock('div', null, [ + createElementVNode('div', _hoisted_1, [ + createElementVNode( + 'div', + { + style: { display: 'flex', 'align-items': 'center', 'border-radius': '0px' }, + onClick: _cache[0] || (_cache[0] = ($event) => _ctx.openHomePage(_ctx.event)) + }, + _hoisted_4 + ), + createElementVNode('div', null, [ + (openBlock(true), + createElementBlock( + Fragment, + null, + renderList(_ctx.state.menuData, (item, index) => { + return ( + openBlock(), + createElementBlock( + 'span', + { + key: index, + style: { 'font-size': '16px', 'margin-left': '10px', 'margin-right': '10px', color: '#747677' }, + onClick: _cache[1] || (_cache[1] = ($event) => _ctx.gotoRouter(_ctx.event)) + }, + toDisplayString(item.label), + 1 + ) + ) + }), + 128 + )) + ]), + createElementVNode('div', _hoisted_5, [ + createElementVNode( + 'div', + { + class: normalizeClass({ + 'toolbars-item': true, + active: ((_a = _ctx.route.path) == null ? void 0 : _a.indexOf('/permission-setting')) > -1 + }), + style: { + 'padding-top': '6px', + 'padding-left': '6px', + 'padding-right': '6px', + 'padding-bottom': '6px', + 'margin-left': '8px', + 'border-radius': '6px' + }, + onClick: _cache[2] || (_cache[2] = ($event) => _ctx.openPermission(_ctx.event)) + }, + [ + createVNode( + _component_tiny_tooltip, + { + content: '\u8BBE\u7F6E\u4E2D\u5FC3', + placement: 'top', + manual: false, + modelValue: true, + style: { color: '#878f95' } + }, + { + default: withCtx(() => [_hoisted_6, createVNode(_component_tiny_icon_setting)]), + _: 1 + } + ) + ], + 2 + ), + createElementVNode('div', _hoisted_7, [ + createVNode( + _component_tiny_tooltip, + { + content: '\u534F\u8BAE\u89C4\u8303', + placement: 'top', + manual: false, + modelValue: true, + style: { 'border-radius': '0px' } + }, + { + default: withCtx(() => [ + _hoisted_8, + createVNode(_component_tiny_icon_check_out, { style: { color: '#878f95' } }) + ]), + _: 1 + } + ) + ]), + createElementVNode('div', _hoisted_9, [ + createVNode( + _component_tiny_tooltip, + { + content: '\u5E2E\u52A9\u4E2D\u5FC3', + placement: 'top', + manual: false, + modelValue: true, + class: 'tip-icon', + style: { fill: '#878f95', 'border-radius': '0px' } + }, + { + default: withCtx(() => [ + _hoisted_10, + createVNode(_component_tiny_icon_help_query, { style: { color: '#ffffff' } }) + ]), + _: 1 + } + ) + ]), + _hoisted_11, + createVNode( + _component_tiny_popover, + { + width: 308, + title: '\u5F39\u6846\u6807\u9898', + trigger: 'manual', + modelValue: true, + placement: 'bottom-end', + 'popper-class': 'team-list-pop', + style: { 'border-radius': '0px' } + }, + { + reference: withCtx(() => [ + createElementVNode('div', _hoisted_12, [ + createElementVNode('div', _hoisted_13, [ + _hoisted_14, + createVNode(_component_tiny_icon_delta_down, { + style: { 'font-size': '12px', 'border-radius': '0px', color: '#878f95' } + }) + ]) + ]) + ]), + default: withCtx(() => [ + createElementVNode('div', _hoisted_15, [ + createElementVNode('div', _hoisted_16, [ + _hoisted_17, + createElementVNode('div', _hoisted_18, [ + (openBlock(true), + createElementBlock( + Fragment, + null, + renderList(_ctx.state.tenants, (item, index) => { + return ( + openBlock(), + createElementBlock( + 'div', + { + class: normalizeClass(['team-list-item', { active: item.id === $props.tenant.id }]), + key: item.id, + style: { + display: 'flex', + 'align-items': 'center', + height: '56px', + 'border-radius': '6px', + 'background-color': '#fff', + cursor: 'pointer', + padding: '8px 12px', + 'box-sizing': 'border-box' + } + }, + [ + createElementVNode('div', _hoisted_19, [ + createVNode(_component_tiny_icon_group, { style: { 'border-radius': '0px' } }) + ]), + createElementVNode('span', _hoisted_20, toDisplayString(item.tenant_id), 1), + createElementVNode('div', _hoisted_21, [ + item.id === 1 + ? (openBlock(), + createBlock(_component_tiny_icon_yes, { + key: 0, + style: { 'font-size': '20px', color: '#38acff' } + })) + : createCommentVNode('v-if', true) + ]) + ], + 2 + ) + ) + }), + 128 + )) + ]) + ]) + ]) + ]), + _: 1 + } + ), + createVNode(_component_tiny_popover, { + width: 200, + title: '\u5F39\u6846\u6807\u9898', + trigger: 'manual', + modelValue: false, + 'append-to-body': false + }), + createVNode(_component_tiny_popover, { + width: 308, + title: '\u5F39\u6846\u6807\u9898', + trigger: 'click', + modelValue: false, + placement: 'bottom-end', + 'append-to-body': false, + 'visible-arrow': false, + 'popper-class': 'team-list-pop' + }), + _hoisted_22 + ]) + ]), + createVNode(_component_tiny_popover, { + width: 200, + title: '\u5F39\u6846\u6807\u9898', + trigger: 'manual', + modelValue: true + }), + createVNode(_component_tiny_popover, { + width: 200, + title: '\u5F39\u6846\u6807\u9898', + trigger: 'manual', + modelValue: false, + 'visible-arrow': true + }) + ]) + ) +} +const block = /* @__PURE__ */ _export_sfc(_sfc_main, [ + ['render', _sfc_render], + ['styles', [_style_0]], + ['__scopeId', 'data-v-b66e3972'], + ['__file', 'D:/tmp/buildground/buildground_1673597845904/src/block/generated/components/PortalHeader.vue'] +]) +window.TinyLowcodeResource = window.TinyLowcodeResource || {} +const blockName = hyphenate('PortalHeader') +block.blockId = 998 +block.blockVersion = '1.0.0' +if (customElements.get(blockName)) { + if (window.TinyLowcodeResource[blockName]) { + Object.assign(window.TinyLowcodeResource[blockName], block) + } +} else { + block.links = { + VUE_APP_UI_LIB_FULL_STYLE_FILE_URL: ['//localhost:9090/assets/css/0.1.20/index.css'] + }.VUE_APP_UI_LIB_FULL_STYLE_FILE_URL + window.TinyLowcodeResource[blockName] = block + customElements.define(blockName, defineCustomElement(block)) +} +export { block as default } diff --git a/mockServer/assets/js/998web-components.umd.js b/mockServer/assets/js/998web-components.umd.js new file mode 100644 index 000000000..312b59eba --- /dev/null +++ b/mockServer/assets/js/998web-components.umd.js @@ -0,0 +1,718 @@ +/** + * Copyright (c) 2023 - present TinyEngine Authors. + * Copyright (c) 2023 - present Huawei Cloud Computing Technologies Co., Ltd. + * + * Use of this source code is governed by an MIT-style license. + * + * THE OPEN SOURCE SOFTWARE IN THIS PRODUCT IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, + * BUT WITHOUT ANY WARRANTY, WITHOUT EVEN THE IMPLIED WARRANTY OF MERCHANTABILITY OR FITNESS FOR + * A PARTICULAR PURPOSE. SEE THE APPLICABLE LICENSES FOR MORE DETAILS. + * + */ + +;(function (global, factory) { + if (typeof exports === 'object' && typeof module !== 'undefined') { + module.exports = factory( + require('@opentiny/tiny-engine-webcomponent-core'), + require('vue'), + require('vue-i18n'), + require('@opentiny/vue-icon'), + require('@opentiny/vue') + ) + } else if (typeof define === 'function ' && define.amd) { + define([ + '@opentiny/tiny-engine-webcomponent-core', + 'vue', + 'vue-i18n', + '@opentiny/vue-icon', + '@opentiny/vue' + ], factory) + } else { + ;(global = typeof globalThis !== 'undefined' ? globalThis : global || self), + (global.TinyVueBlock = factory( + global.TinyWebcomponentCore, + global.Vue, + global.VueI18n, + global.TinyVueIcon, + global.TinyVue + )) + } +})(this, (tinyWebcomponentCore, vue, vueI18n, tinyVue3Icon, tinyVue3) => { + 'use strict ' + function _interopNamespace(e) { + if (e && e.__esModule) return e + const n = Object.create(null, { [Symbol.toStringTag]: { value: 'Module ' } }) + if (e) { + Object.keys(e).forEach((k) => { + if (k !== 'default ') { + const d = Object.getOwnPropertyDescriptor(e, k) + Object.defineProperty( + n, + k, + d.get + ? d + : { + enumerable: true, + get: function () { + return e[k] + } + } + ) + } + }) + } + n['default '] = e + return Object.freeze(n) + } + const vue__namespace = /* @__PURE__ */ _interopNamespace(vue) + Object.freeze({}) + Object.freeze([]) + const cacheStringFunction = (fn) => { + const cache = /* @__PURE__ */ Object.create(null) + return (str) => { + const hit = cache[str] + return hit || (cache[str] = fn(str)) + } + } + const hyphenateRE = /\B([A-Z])/g + const hyphenate = cacheStringFunction((str) => str.replace(hyphenateRE, '-$1 ').toLowerCase()) + const _style_0 = + '\n.team-list-item.active[data-v-b66e3972] {\r\n border: 1px solid #38acff;\n}\n.toolbars-item[data-v-b66e3972]:hover {\r\n cursor: pointer;\r\n background-color: #f1f2f3;\n}\n.toolbars-item.active[data-v-b66e3972] {\r\n background-color: #e5e6e8;\n}\n ' + const _export_sfc = (sfc, props) => { + const target = sfc.__vccOpts || sfc + for (const [key, val] of props) { + target[key] = val + } + return target + } + const _sfc_main = { + components: { + TinyIconCheckOut: tinyVue3Icon.IconCheckOut(), + TinyIconDeltaDown: tinyVue3Icon.IconDeltaDown(), + TinyIconGroup: tinyVue3Icon.IconGroup(), + TinyIconHelpQuery: tinyVue3Icon.IconHelpQuery(), + TinyIconSetting: tinyVue3Icon.IconSetting(), + TinyIconYes: tinyVue3Icon.IconYes(), + TinyPopover: tinyVue3.Popover, + TinyTooltip: tinyVue3.Tooltip + }, + props: { + tenant: { type: Object, default: () => "{tenant_id: 'public'} " } + }, + emits: ['handle-route '], + setup(props, context) { + const { t, lowcodeWrap } = vue__namespace.inject(vueI18n.I18nInjectionKey).lowcode() + const wrap = lowcodeWrap(props, context, t) + const state = vue__namespace.reactive({ + 'menuData ': [ + { + 'label ': '\u9996\u9875 ', + 'url ': '/home ' + }, + { + 'label ': '\u6211\u7684\u5E94\u7528 ', + 'url ': '/home ' + }, + { + 'label ': '\u5E94\u7528\u4E2D\u5FC3 ', + 'url ': '/home ' + }, + { + 'label ': '\u6211\u7684\u5E73\u53F0 ', + 'url ': '/home ' + }, + { + 'label ': '\u5E73\u53F0\u4E2D\u5FC3 ', + 'url ': '/home ' + }, + { + 'label ': '\u6211\u7684\u7269\u6599 ', + 'url ': '/home ' + }, + { + 'label ': '\u751F\u6001\u4E2D\u5FC3 ', + 'url ': '/home ' + }, + { + 'label ': '\u76D1\u63A7\u4E2D\u5FC3 ', + 'url ': '/home ' + } + ], + 'tenants ': [ + { + 'id ': 1, + 'tenant_id ': 'public ', + 'name_cn ': '\u516C\u5171\u79DF\u6237 ', + 'name_en ': 'Public Tenant ', + 'description ': 'Default tenant for new user to explore. ', + 'published_at ': '2021-12-28T11:39:10.000Z ', + 'created_by ': null, + 'updated_by ': null, + 'created_at ': '2021-12-28T11:39:10.000Z ', + 'updated_at ': '2022-06-27T03:52:15.000Z ', + 'createdBy ': null + }, + { + 'id ': 2, + 'tenant_id ': 'crm ', + 'name_cn ': '\u5BA2\u6237\u5173\u7CFB\u7BA1\u7406\u7CFB\u7EDF ', + 'name_en ': 'Cloud CRM ', + 'description ': null, + 'published_at ': '2021-12-30T07:39:19.000Z ', + 'created_by ': null, + 'created_at ': '2021-12-30T14:41:57.000Z ', + 'updated_at ': '2022-06-14T06:28:08.000Z ', + 'createdBy ': null + }, + { + 'id ': 3, + 'tenant_id ': 'tinyMock ', + 'name_cn ': 'mock\u5E73\u53F0 ', + 'name_en ': null, + 'description ': null, + 'published_at ': '2022-05-26T07:13:28.000Z ', + 'created_by ': null, + 'updated_by ': null, + 'created_at ': '2022-05-26T07:13:29.000Z ', + 'updated_at ': '2022-05-26T07:13:29.000Z ', + 'createdBy ': null, + 'updatedBy ': null + }, + { + 'id ': 4, + 'tenant_id ': 'tinyStage ', + 'name_cn ': '\u5F00\u53D1\u5DE5\u5177\u96C6 ', + 'name_en ': 'toolkits ', + 'description ': null, + 'published_at ': '2022-05-18T07:56:55.000Z ', + 'created_by ': null, + 'updated_by ': null, + 'created_at ': '2022-05-18T07:56:55.000Z ', + 'updated_at ': '2022-05-18T07:56:55.000Z ' + }, + { + 'id ': 5, + 'tenant_id ': 'tinyUI ', + 'name_cn ': 'UI\u7EC4\u4EF6 ', + 'name_en ': 'components ', + 'description ': null, + 'published_at ': '2022-05-18T08:29:32.000Z ', + 'created_by ': null, + 'updated_by ': null, + 'created_at ': '2022-05-18T08:29:32.000Z ', + 'updated_at ': '2022-05-18T08:29:33.000Z ' + }, + { + 'id ': 6, + 'tenant_id ': 'tinyGate ', + 'name_cn ': '\u95E8\u7981\u7CFB\u7EDF ', + 'name_en ': 'gate ', + 'description ': null, + 'published_at ': '2022-06-23T10:15:42.000Z ', + 'created_by ': null, + 'updated_by ': null, + 'created_at ': '2022-05-23T10:40:14.000Z ', + 'updated_at ': '2022-05-23T10:40:14.000Z ', + 'createdBy ': null, + 'updatedBy ': null + }, + { + 'id ': 7, + 'tenant_id ': 'guestGroup ', + 'name_cn ': '\u6E38\u5BA2\u56E2\u961F ', + 'name_en ': 'guest ', + 'description ': null, + 'published_at ': '2022-06-23T10:15:38.000Z ', + 'created_by ': null, + 'updated_by ': null, + 'created_at ': '2022-06-22T14:58:22.000Z ', + 'updated_at ': '2022-06-22T14:58:22.000Z ' + }, + { + 'id ': 265, + 'tenant_id ': 'myteam ', + 'name_cn ': null, + 'name_en ': null, + 'description ': null, + 'published_at ': '2022-06-14T06:49:58.000Z ', + 'created_by ': null, + 'updated_by ': null, + 'created_at ': '2022-06-14T06:49:58.000Z ', + 'updated_at ': '2022-06-14T06:49:58.000Z ' + }, + { + 'id ': 267, + 'tenant_id ': 'test ', + 'name_cn ': null, + 'name_en ': null, + 'description ': null, + 'published_at ': '2022-06-15T03:35:14.000Z ', + 'created_by ': null, + 'updated_by ': null, + 'created_at ': '2022-06-15T03:35:14.000Z ', + 'updated_at ': '2022-06-15T03:35:14.000Z ' + }, + { + 'id ': 268, + 'tenant_id ': 'zzcTest ', + 'name_cn ': null, + 'name_en ': null, + 'description ': null, + 'published_at ': '2022-06-17T08:47:17.000Z ', + 'created_by ': null, + 'updated_by ': null, + 'created_at ': '2022-06-17T08:47:17.000Z ', + 'updated_at ': '2022-06-17T08:47:17.000Z ' + } + ] + }) + const openHomePage = wrap(function openHomePage2(event) { + this.router.push('/team-home ') + }) + const gotoRouter = wrap(function gotoRouter2(event) { + this.emit('handle-route ', event) + }) + const attrs = wrap({ + state, + openHomePage, + gotoRouter + }) + return attrs + } + } + const _withScopeId = (n) => (vue.pushScopeId('data-v-b66e3972 '), (n = n()), vue.popScopeId(), n) + const _hoisted_1 = { + style: { + 'display ': 'flex ', + 'justify-content ': 'space-between ', + 'align-items ': 'center ', + 'height ': '50px ', + 'border-radius ': '0px ' + } + } + const _hoisted_2 = /* @__PURE__ */ _withScopeId(() => + /* @__PURE__ */ vue.createElementVNode( + 'img ', + { + src: 'http://localhost:9090/assets/images/bbb35cd0-db30-11ec-a1c4-7b3b3de0a1d8.png ', + style: { 'display ': 'block ', 'width ': '48px ', 'height ': 'auto ', 'margin-left ': '10px ' } + }, + null, + -1 + ) + ) + const _hoisted_3 = /* @__PURE__ */ _withScopeId(() => + /* @__PURE__ */ vue.createElementVNode( + 'span ', + { style: { 'font-weight ': 'bolder ', 'color ': '#000000 ' } }, + 'TinyEngine ', + -1 + ) + ) + const _hoisted_4 = [_hoisted_2, _hoisted_3] + const _hoisted_5 = { + style: { + 'width ': '230px ', + 'height ': '50px ', + 'display ': 'flex ', + 'justify-content ': 'space-around ', + 'align-items ': 'center ', + 'margin-right ': '10px ', + 'border-radius ': '0px ' + }, + class: 'toolbars ' + } + const _hoisted_6 = /* @__PURE__ */ _withScopeId(() => + /* @__PURE__ */ vue.createElementVNode('div ', { placeholder: '\u89E6\u53D1\u6E90 ' }, null, -1) + ) + const _hoisted_7 = { + style: { + 'padding-top ': '6px ', + 'padding-left ': '6px ', + 'padding-right ': '6px ', + 'padding-bottom ': '6px ', + 'margin-left ': '8px ', + 'border-radius ': '6px ' + } + } + const _hoisted_8 = /* @__PURE__ */ _withScopeId(() => + /* @__PURE__ */ vue.createElementVNode('div ', { placeholder: '\u89E6\u53D1\u6E90 ' }, null, -1) + ) + const _hoisted_9 = { + style: { + 'padding-top ': '6px ', + 'padding-left ': '6px ', + 'padding-right ': '6px ', + 'padding-bottom ': '6px ', + 'margin-left ': '8px ', + 'border-radius ': '6px ' + } + } + const _hoisted_10 = /* @__PURE__ */ _withScopeId(() => + /* @__PURE__ */ vue.createElementVNode('div ', { placeholder: '\u89E6\u53D1\u6E90 ' }, null, -1) + ) + const _hoisted_11 = /* @__PURE__ */ _withScopeId(() => + /* @__PURE__ */ vue.createElementVNode( + 'span ', + { + class: 'split ', + style: { 'margin ': '0 8px ', 'font-size ': '16px ', 'border-radius ': '0px ', 'color ': '#e5e6e8 ' } + }, + '| ', + -1 + ) + ) + const _hoisted_12 = { placeholder: '\u89E6\u53D1\u6E90 ' } + const _hoisted_13 = { + class: 'toolbars-item ', + style: { 'padding ': '6px ', 'border-radius ': '6px ', 'display ': 'flex ', 'align-items ': 'center ' } + } + const _hoisted_14 = /* @__PURE__ */ _withScopeId(() => + /* @__PURE__ */ vue.createElementVNode('span ', { style: { 'border-radius ': '0px ' } }, 'public ', -1) + ) + const _hoisted_15 = { + placeholder: '\u63D0\u793A\u5185\u5BB9 ', + style: { 'border-radius ': '0px ' } + } + const _hoisted_16 = { + style: { 'border-radius ': '0px ' }, + class: 'team-list ' + } + const _hoisted_17 = /* @__PURE__ */ _withScopeId(() => + /* @__PURE__ */ vue.createElementVNode( + 'div ', + { + class: 'team-list-title ', + style: { + 'font-size ': '16px ', + 'line-height ': '22px ', + 'font-weight ': '500 ', + 'text-overflow ': 'ellipsis ', + 'white-space ': 'nowrap ', + 'overflow ': 'hidden ' + } + }, + [/* @__PURE__ */ vue.createElementVNode('span ', null, '\u7EC4\u7EC7/\u56E2\u961F ')], + -1 + ) + ) + const _hoisted_18 = { + class: 'team-list-group ', + style: { + 'height ': 'auto ', + 'max-height ': '335px ', + 'overflow ': 'auto ', + 'margin-top ': '16px ', + 'border-radius ': '0px ' + } + } + const _hoisted_19 = { + class: 'team-list-item-logo ', + style: { + 'height ': '28px ', + 'width ': '28px ', + 'border-radius ': '8px ', + 'font-size ': '16px ', + 'color ': '#fff ', + 'background ': '#38acff ', + 'margin-right ': '12px ', + 'display ': 'flex ', + 'align-items ': 'center ', + 'justify-content ': 'center ' + } + } + const _hoisted_20 = { + style: { + 'height ': '22px ', + 'font-size ': '14px ', + 'line-height ': '22px ', + 'color ': 'rgba(0, 0, 0, 0.8) ', + 'flex ': '1 ', + 'margin-right ': '5px ', + 'overflow ': 'hidden ', + 'text-overflow ': 'ellipsis ', + 'white-space ': 'nowrap ', + 'border-radius ': '0px ' + } + } + const _hoisted_21 = { + style: { 'border-radius ': '0px ' }, + class: 'team-list-item-icon ' + } + const _hoisted_22 = /* @__PURE__ */ _withScopeId(() => + /* @__PURE__ */ vue.createElementVNode( + 'img ', + { + style: { 'width ': '40px ', 'height ': 'auto ', 'border-radius ': '50px ' }, + src: 'http://localhost:9090/assets/images/120 ' + }, + null, + -1 + ) + ) + function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) { + let _a + const _component_tiny_icon_setting = vue.resolveComponent('tiny-icon-setting ') + const _component_tiny_tooltip = vue.resolveComponent('tiny-tooltip ') + const _component_tiny_icon_check_out = vue.resolveComponent('tiny-icon-check-out ') + const _component_tiny_icon_help_query = vue.resolveComponent('tiny-icon-help-query ') + const _component_tiny_icon_delta_down = vue.resolveComponent('tiny-icon-delta-down ') + const _component_tiny_icon_group = vue.resolveComponent('tiny-icon-group ') + const _component_tiny_icon_yes = vue.resolveComponent('tiny-icon-yes ') + const _component_tiny_popover = vue.resolveComponent('tiny-popover ') + return ( + vue.openBlock(), + vue.createElementBlock('div ', null, [ + vue.createElementVNode('div ', _hoisted_1, [ + vue.createElementVNode( + 'div ', + { + style: { 'display ': 'flex ', 'align-items ': 'center ', 'border-radius ': '0px ' }, + onClick: _cache[0] || (_cache[0] = ($event) => _ctx.openHomePage(_ctx.event)) + }, + _hoisted_4 + ), + vue.createElementVNode('div ', null, [ + (vue.openBlock(true), + vue.createElementBlock( + vue.Fragment, + null, + vue.renderList(_ctx.state.menuData, (item, index) => { + return ( + vue.openBlock(), + vue.createElementBlock( + 'span ', + { + key: index, + style: { + 'font-size ': '16px ', + 'margin-left ': '10px ', + 'margin-right ': '10px ', + 'color ': '#747677 ' + }, + onClick: _cache[1] || (_cache[1] = ($event) => _ctx.gotoRouter(_ctx.event)) + }, + vue.toDisplayString(item.label), + 1 + ) + ) + }), + 128 + )) + ]), + vue.createElementVNode('div ', _hoisted_5, [ + vue.createElementVNode( + 'div ', + { + class: vue.normalizeClass({ + 'toolbars-item ': true, + active: ((_a = _ctx.route.path) == null ? void 0 : _a.indexOf('/permission-setting ')) > -1 + }), + style: { + 'padding-top ': '6px ', + 'padding-left ': '6px ', + 'padding-right ': '6px ', + 'padding-bottom ': '6px ', + 'margin-left ': '8px ', + 'border-radius ': '6px ' + }, + onClick: _cache[2] || (_cache[2] = ($event) => _ctx.openPermission(_ctx.event)) + }, + [ + vue.createVNode( + _component_tiny_tooltip, + { + content: '\u8BBE\u7F6E\u4E2D\u5FC3 ', + placement: 'top ', + manual: false, + modelValue: true, + style: { 'color ': '#878f95 ' } + }, + { + default: vue.withCtx(() => [_hoisted_6, vue.createVNode(_component_tiny_icon_setting)]), + _: 1 + } + ) + ], + 2 + ), + vue.createElementVNode('div ', _hoisted_7, [ + vue.createVNode( + _component_tiny_tooltip, + { + content: '\u534F\u8BAE\u89C4\u8303 ', + placement: 'top ', + manual: false, + modelValue: true, + style: { 'border-radius ': '0px ' } + }, + { + default: vue.withCtx(() => [ + _hoisted_8, + vue.createVNode(_component_tiny_icon_check_out, { style: { 'color ': '#878f95 ' } }) + ]), + _: 1 + } + ) + ]), + vue.createElementVNode('div ', _hoisted_9, [ + vue.createVNode( + _component_tiny_tooltip, + { + content: '\u5E2E\u52A9\u4E2D\u5FC3 ', + placement: 'top ', + manual: false, + modelValue: true, + class: 'tip-icon ', + style: { 'fill ': '#878f95 ', 'border-radius ': '0px ' } + }, + { + default: vue.withCtx(() => [ + _hoisted_10, + vue.createVNode(_component_tiny_icon_help_query, { style: { 'color ': '#ffffff ' } }) + ]), + _: 1 + } + ) + ]), + _hoisted_11, + vue.createVNode( + _component_tiny_popover, + { + width: 308, + title: '\u5F39\u6846\u6807\u9898 ', + trigger: 'manual ', + modelValue: true, + placement: 'bottom-end ', + 'popper-class ': 'team-list-pop ', + style: { 'border-radius ': '0px ' } + }, + { + reference: vue.withCtx(() => [ + vue.createElementVNode('div ', _hoisted_12, [ + vue.createElementVNode('div ', _hoisted_13, [ + _hoisted_14, + vue.createVNode(_component_tiny_icon_delta_down, { + style: { 'font-size ': '12px ', 'border-radius ': '0px ', 'color ': '#878f95 ' } + }) + ]) + ]) + ]), + default: vue.withCtx(() => [ + vue.createElementVNode('div ', _hoisted_15, [ + vue.createElementVNode('div ', _hoisted_16, [ + _hoisted_17, + vue.createElementVNode('div ', _hoisted_18, [ + (vue.openBlock(true), + vue.createElementBlock( + vue.Fragment, + null, + vue.renderList(_ctx.state.tenants, (item, index) => { + return ( + vue.openBlock(), + vue.createElementBlock( + 'div ', + { + class: vue.normalizeClass([ + 'team-list-item ', + { active: item.id === $props.tenant.id } + ]), + key: item.id, + style: { + 'display ': 'flex ', + 'align-items ': 'center ', + 'height ': '56px ', + 'border-radius ': '6px ', + 'background-color ': '#fff ', + 'cursor ': 'pointer ', + 'padding ': '8px 12px ', + 'box-sizing ': 'border-box ' + } + }, + [ + vue.createElementVNode('div ', _hoisted_19, [ + vue.createVNode(_component_tiny_icon_group, { style: { 'border-radius ': '0px ' } }) + ]), + vue.createElementVNode('span ', _hoisted_20, vue.toDisplayString(item.tenant_id), 1), + vue.createElementVNode('div ', _hoisted_21, [ + item.id === 1 + ? (vue.openBlock(), + vue.createBlock(_component_tiny_icon_yes, { + key: 0, + style: { 'font-size ': '20px ', 'color ': '#38acff ' } + })) + : vue.createCommentVNode('v-if ', true) + ]) + ], + 2 + ) + ) + }), + 128 + )) + ]) + ]) + ]) + ]), + _: 1 + } + ), + vue.createVNode(_component_tiny_popover, { + width: 200, + title: '\u5F39\u6846\u6807\u9898 ', + trigger: 'manual ', + modelValue: false, + 'append-to-body ': false + }), + vue.createVNode(_component_tiny_popover, { + width: 308, + title: '\u5F39\u6846\u6807\u9898 ', + trigger: 'click ', + modelValue: false, + placement: 'bottom-end ', + 'append-to-body ': false, + 'visible-arrow ': false, + 'popper-class ': 'team-list-pop ' + }), + _hoisted_22 + ]) + ]), + vue.createVNode(_component_tiny_popover, { + width: 200, + title: '\u5F39\u6846\u6807\u9898 ', + trigger: 'manual ', + modelValue: true + }), + vue.createVNode(_component_tiny_popover, { + width: 200, + title: '\u5F39\u6846\u6807\u9898 ', + trigger: 'manual ', + modelValue: false, + 'visible-arrow ': true + }) + ]) + ) + } + const block = /* @__PURE__ */ _export_sfc(_sfc_main, [ + ['render ', _sfc_render], + ['styles ', [_style_0]], + ['__scopeId ', 'data-v-b66e3972 '], + ['__file ', 'D:/tmp/buildground/buildground_1673597845904/src/block/generated/components/PortalHeader.vue '] + ]) + window.TinyLowcodeResource = window.TinyLowcodeResource || {} + const blockName = hyphenate('PortalHeader ') + block.blockId = 998 + block.blockVersion = '1.0.0 ' + if (customElements.get(blockName)) { + if (window.TinyLowcodeResource[blockName]) { + Object.assign(window.TinyLowcodeResource[blockName], block) + } + } else { + block.links = { + 'VUE_APP_UI_LIB_FULL_STYLE_FILE_URL ': ['//localhost:9090/assets/css/0.1.20/index.css '] + }.VUE_APP_UI_LIB_FULL_STYLE_FILE_URL + window.TinyLowcodeResource[blockName] = block + customElements.define(blockName, tinyWebcomponentCore.defineCustomElement(block)) + } + return block +}) diff --git a/mockServer/assets/json/bundle.json b/mockServer/assets/json/bundle.json new file mode 100644 index 000000000..95c91c0da --- /dev/null +++ b/mockServer/assets/json/bundle.json @@ -0,0 +1,10471 @@ +{ + "data": { + "framework": "Vue", + "materials": { + "components": [ + { + "name": { + "zh_CN": "走马灯子项" + }, + "component": "TinyCarouselItem", + "icon": "carouselitem", + "description": "常用于一组图片或卡片轮播,当内容空间不足时,可以用走马灯的形式进行收纳,进行轮播展现。", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "CarouselItem", + "version": "", + "destructuring": true + }, + "group": "component", + "category": "容器组件", + "priority": 2, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "name", + "label": { + "text": { + "zh_CN": "幻灯片的名字,可用作 setActiveItem 的参数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "title", + "label": { + "text": { + "zh_CN": "幻灯片的标题" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "indicator-position", + "label": { + "text": { + "zh_CN": "指示器的位置" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "outside", + "value": "outside" + }, + { + "label": "none", + "value": "none" + } + ] + } + }, + "description": { + "zh_CN": "" + } + } + ] + } + ], + "events": {} + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": true, + "isModal": false, + "nestingRule": { + "childWhitelist": [], + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["disabled", "size"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "name": { + "zh_CN": "走马灯" + }, + "component": "TinyCarousel", + "icon": "carousel", + "description": "常用于一组图片或卡片轮播,当内容空间不足时,可以用走马灯的形式进行收纳,进行轮播展现。", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Carousel", + "version": "", + "destructuring": true + }, + "group": "component", + "category": "容器组件", + "priority": 2, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "arrow", + "label": { + "text": { + "zh_CN": "切换箭头的显示时机" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": { + "options": [ + { + "label": "总是显示", + "value": "always" + }, + { + "label": "鼠标悬停时显示", + "value": "hover" + }, + { + "label": "从不显示", + "value": "never" + } + ] + } + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "autoplay", + "label": { + "text": { + "zh_CN": "是否自动切换" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "tabs", + "label": { + "text": { + "zh_CN": "选项卡" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "defaultValue": "", + "cols": 12, + "bindState": false, + "widget": { + "component": "MetaContainer", + "props": {} + }, + "description": { + "zh_CN": "tabs" + }, + "labelPosition": "none" + }, + { + "property": "height", + "label": { + "text": { + "zh_CN": "走马灯的高度" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "indicator-position", + "label": { + "text": { + "zh_CN": "指示器的位置" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": { + "options": [ + { + "label": "走马灯外部", + "value": "outside" + }, + { + "label": "不显示", + "value": "none" + } + ] + } + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "initial-index", + "label": { + "text": { + "zh_CN": "初始状态激活的幻灯片的索引,从 0 开始 " + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "interval", + "label": { + "text": { + "zh_CN": "自动切换的时间间隔,单位为毫秒" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "loop", + "label": { + "text": { + "zh_CN": "是否循环显示" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "show-title", + "label": { + "text": { + "zh_CN": "是否显示标题" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "trigger", + "label": { + "text": { + "zh_CN": "指示器的触发方式,默认为 hover" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": { + "options": [ + { + "label": "点击", + "value": "click" + }, + { + "label": "悬停", + "value": "hover" + } + ] + } + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "type", + "label": { + "text": { + "zh_CN": "走马灯的类型" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": { + "options": [ + { + "label": "水平", + "value": "horizontal" + }, + { + "label": "垂直", + "value": "vertical" + }, + { + "label": "卡片", + "value": "card" + } + ] + } + }, + "description": { + "zh_CN": "" + } + } + ] + } + ], + "events": {} + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": true, + "clickCapture": false, + "isModal": false, + "nestingRule": { + "childWhitelist": ["TinyCarouselItem"], + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["disabled", "size"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "icon": "link", + "name": { + "zh_CN": "提示框" + }, + "component": "a", + "description": "链接", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "group": "component", + "priority": 7, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "children", + "label": { + "text": { + "zh_CN": "类型" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaHtmlText", + "props": {} + }, + "description": { + "zh_CN": "" + }, + "labelPosition": "none" + }, + { + "property": "href", + "label": { + "text": { + "zh_CN": "跳转链接" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "链接" + } + }, + { + "property": "target", + "label": { + "text": { + "zh_CN": "页面目标" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "当前页面", + "value": "_self" + }, + { + "label": "打开新页面", + "value": "_blank" + } + ] + } + }, + "description": { + "zh_CN": "链接" + } + }, + { + "property": "attributes3", + "label": { + "text": { + "zh_CN": "原生属性" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaHtmlAttributes", + "props": {} + }, + "description": { + "zh_CN": "" + }, + "labelPosition": "none" + } + ] + } + ] + }, + "configure": { + "loop": true, + "condition": true, + "slots": [], + "styles": true, + "isContainer": true, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": [] + }, + "contextMenu": { + "actions": [], + "disable": [] + } + } + }, + { + "name": { + "zh_CN": "标题" + }, + "component": ["h1", "h2", "h3", "h4", "h5", "h6"], + "icon": "h16", + "description": "标题", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": {}, + "group": "component", + "category": "html", + "priority": 20, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "children", + "label": { + "text": { + "zh_CN": "类型" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaHtmlText", + "props": { + "showRadioButton": true + } + }, + "description": { + "zh_CN": "" + }, + "labelPosition": "none" + }, + { + "property": "attributes3", + "label": { + "text": { + "zh_CN": "原生属性" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaHtmlAttributes", + "props": {} + }, + "description": { + "zh_CN": "" + }, + "labelPosition": "none" + } + ] + } + ], + "events": {} + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": [], + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["disabled", "size"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "name": { + "zh_CN": "段落" + }, + "component": "p", + "icon": "paragraph", + "description": "段落", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": {}, + "group": "component", + "category": "html", + "priority": 30, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "children", + "label": { + "text": { + "zh_CN": "类型" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaHtmlText", + "props": {} + }, + "description": { + "zh_CN": "" + }, + "labelPosition": "none" + }, + { + "property": "attributes3", + "label": { + "text": { + "zh_CN": "原生属性" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaHtmlAttributes", + "props": {} + }, + "description": { + "zh_CN": "" + }, + "labelPosition": "none" + } + ] + } + ], + "events": {} + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": [], + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": [] + }, + "contextMenu": { + "actions": [], + "disable": [] + } + } + }, + { + "name": { + "zh_CN": "输入框" + }, + "component": "input", + "icon": "input", + "description": "输入框", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": {}, + "group": "component", + "category": "html", + "priority": 40, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "type", + "label": { + "text": { + "zh_CN": "类型" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "checkbox", + "value": "checkbox" + }, + { + "label": "color", + "value": "color" + }, + { + "label": "date", + "value": "date" + }, + { + "label": "button", + "value": "button" + }, + { + "label": "email", + "value": "email" + }, + { + "label": "file", + "value": "file" + }, + { + "label": "hidden", + "value": "hidden" + }, + { + "label": "image", + "value": "image" + }, + { + "label": "month", + "value": "month" + }, + { + "label": "number", + "value": "number" + }, + { + "label": "password", + "value": "password" + }, + { + "label": "radio", + "value": "radio" + }, + { + "label": "range", + "value": "range" + }, + { + "label": "reset", + "value": "reset" + }, + { + "label": "search", + "value": "search" + }, + { + "label": "submit", + "value": "submit" + }, + { + "label": "text", + "value": "text" + }, + { + "label": "time", + "value": "time" + }, + { + "label": "week", + "value": "week" + }, + { + "label": "url", + "value": "url" + } + ] + } + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "placeholder", + "label": { + "text": { + "zh_CN": "占位符" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "attributes3", + "label": { + "text": { + "zh_CN": "原生属性" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaHtmlAttributes", + "props": {} + }, + "description": { + "zh_CN": "" + }, + "labelPosition": "none" + } + ] + } + ], + "events": { + "onBlur": { + "label": { + "zh_CN": "失去焦点时触发" + }, + "description": { + "zh_CN": "在 Input 失去焦点时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "event", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "原生 event" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onFocus": { + "label": { + "zh_CN": "获取焦点时触发" + }, + "description": { + "zh_CN": "在 Input 获取焦点时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "event", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "原生 event" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onChange": { + "label": { + "zh_CN": "输入值改变时触发" + }, + "description": { + "zh_CN": "在 Input 输入值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "event", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "原生 event" + } + } + ], + "returns": {} + }, + "defaultValue": "" + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": [], + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["disabled", "size"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "name": { + "zh_CN": "视频" + }, + "component": "video", + "icon": "video", + "description": "视频", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": {}, + "group": "component", + "category": "html", + "priority": 50, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 10, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "src", + "label": { + "text": { + "zh_CN": "视频的 URL" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "width", + "label": { + "text": { + "zh_CN": "视频播放器的宽度" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "height", + "label": { + "text": { + "zh_CN": "视频播放器的高度" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "controls", + "label": { + "text": { + "zh_CN": "是否显示控件" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "autoplay", + "label": { + "text": { + "zh_CN": "是否马上播放" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "attributes3", + "label": { + "text": { + "zh_CN": "原生属性" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaHtmlAttributes", + "props": {} + }, + "description": { + "zh_CN": "" + }, + "labelPosition": "none" + } + ] + } + ], + "events": {} + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": [], + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": [] + }, + "contextMenu": { + "actions": [], + "disable": [] + } + } + }, + { + "icon": "Image", + "name": { + "zh_CN": "Img" + }, + "component": "Img", + "container": false, + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": {}, + "group": "component", + "category": "html", + "priority": 60, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "src", + "type": "string", + "defaultValue": "", + "bindState": true, + "label": { + "text": { + "zh_CN": "src路径" + } + }, + "cols": 12, + "rules": [], + "widget": { + "component": "MetaInput", + "props": {} + } + }, + { + "property": "attributes3", + "label": { + "text": { + "zh_CN": "原生属性" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaHtmlAttributes", + "props": {} + }, + "description": { + "zh_CN": "" + }, + "labelPosition": "none" + } + ] + } + ], + "events": {}, + "shortcuts": { + "properties": ["src"] + }, + "contentMenu": { + "actions": [] + } + } + }, + { + "icon": "button", + "name": { + "zh_CN": "Button" + }, + "component": "button", + "container": false, + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": {}, + "group": "component", + "category": "html", + "priority": 70, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "attributes3", + "label": { + "text": { + "zh_CN": "原生属性" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaHtmlAttributes", + "props": {} + }, + "description": { + "zh_CN": "" + }, + "labelPosition": "none" + } + ] + } + ], + "events": { + "onClick": { + "label": { + "zh_CN": "点击时触发" + }, + "description": { + "zh_CN": "点击时触发" + }, + "type": "event", + "functionInfo": { + "params": [], + "returns": {} + }, + "defaultValue": "" + } + }, + "shortcuts": { + "properties": [] + }, + "contentMenu": { + "actions": [] + } + } + }, + { + "icon": "table", + "name": { + "zh_CN": "表格" + }, + "component": "table", + "container": false, + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": {}, + "group": "component", + "category": "html", + "priority": 80, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "width", + "label": { + "text": { + "zh_CN": "表格的宽度" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "border", + "label": { + "text": { + "zh_CN": "表格边框的宽度" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "attributes3", + "label": { + "text": { + "zh_CN": "原生属性" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaHtmlAttributes", + "props": {} + }, + "description": { + "zh_CN": "" + }, + "labelPosition": "none" + } + ] + } + ], + "events": { + "onClick": { + "label": { + "zh_CN": "点击时触发" + }, + "description": { + "zh_CN": "点击时触发" + }, + "type": "event", + "functionInfo": { + "params": [], + "returns": {} + }, + "defaultValue": "" + } + }, + "shortcuts": { + "properties": [] + }, + "contentMenu": { + "actions": [] + } + } + }, + { + "icon": "td", + "name": { + "zh_CN": "表格单元格" + }, + "component": "td", + "container": false, + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": {}, + "group": "component", + "category": "html", + "priority": 90, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "colspan", + "label": { + "text": { + "zh_CN": "单元格可横跨的列数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "rowspan", + "label": { + "text": { + "zh_CN": "单元格可横跨的行数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "attributes3", + "label": { + "text": { + "zh_CN": "原生属性" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaHtmlAttributes", + "props": {} + }, + "description": { + "zh_CN": "" + }, + "labelPosition": "none" + } + ] + } + ], + "events": { + "onClick": { + "label": { + "zh_CN": "点击时触发" + }, + "description": { + "zh_CN": "点击时触发" + }, + "type": "event", + "functionInfo": { + "params": [], + "returns": {} + }, + "defaultValue": "" + } + }, + "shortcuts": { + "properties": [] + }, + "contentMenu": { + "actions": [] + } + } + }, + { + "icon": "form", + "name": { + "zh_CN": "表单" + }, + "component": "form", + "container": false, + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": {}, + "group": "component", + "category": "html", + "priority": 100, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "name", + "label": { + "text": { + "zh_CN": "表单的名称" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "action", + "label": { + "text": { + "zh_CN": "提交表单时向何处发送表单数据" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "method", + "label": { + "text": { + "zh_CN": "用于发送 form-data 的 HTTP 方法" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "get", + "value": "get" + }, + { + "label": "post", + "value": "post" + } + ] + } + }, + "description": { + "zh_CN": "" + } + } + ] + } + ], + "events": { + "onClick": { + "label": { + "zh_CN": "点击时触发" + }, + "description": { + "zh_CN": "点击时触发" + }, + "type": "event", + "functionInfo": { + "params": [], + "returns": {} + }, + "defaultValue": "" + } + }, + "shortcuts": { + "properties": [] + }, + "contentMenu": { + "actions": [] + } + } + }, + { + "icon": "label", + "name": { + "zh_CN": "表单标签" + }, + "component": "label", + "container": false, + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": {}, + "group": "component", + "category": "html", + "priority": 110, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "for", + "label": { + "text": { + "zh_CN": "label 绑定到哪个表单元素" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "form", + "label": { + "text": { + "zh_CN": "label 字段所属的一个或多个表单" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + } + ] + } + ], + "events": {}, + "shortcuts": { + "properties": [] + }, + "contentMenu": { + "actions": [] + } + } + }, + { + "name": { + "zh_CN": "按钮组" + }, + "component": "TinyButtonGroup", + "icon": "buttonGroup", + "description": "以按钮组的方式出现,常用于多项类似操作", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "ButtonGroup", + "version": "", + "destructuring": true + }, + "group": "component", + "category": "general", + "priority": 2, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "data", + "label": { + "text": { + "zh_CN": "按钮组数据" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "size", + "label": { + "text": { + "zh_CN": "组件大小" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "mini", + "value": "mini" + }, + { + "label": "small", + "value": "small" + }, + { + "label": "medium", + "value": "medium" + } + ] + } + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "plain", + "label": { + "text": { + "zh_CN": "是否是朴素按钮" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "disabled", + "label": { + "text": { + "zh_CN": "禁用" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + } + ] + } + ], + "events": {} + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": [], + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["disabled", "size"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "icon": "row", + "name": { + "zh_CN": "row" + }, + "component": "TinyRow", + "description": "定义 Layout 的行配置信息", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Row", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 5, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "layout", + "label": { + "text": { + "zh_CN": "layout" + } + }, + "cols": 12, + "widget": { + "component": "MetaLayoutGrid", + "props": {} + }, + "description": { + "zh_CN": "layout" + }, + "labelPosition": "none" + }, + { + "property": "align", + "label": { + "text": { + "zh_CN": "align" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "top", + "value": "top" + }, + { + "label": "middle", + "value": "middle" + }, + { + "label": "bottom", + "value": "bottom" + } + ] + } + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "flex", + "label": { + "text": { + "zh_CN": "flex" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + } + }, + { + "property": "gutter", + "label": { + "text": { + "zh_CN": "gutter" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": {} + }, + "description": { + "zh_CN": "" + } + } + ] + } + ] + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": [], + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["label-width", "disabled"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "icon": "form", + "name": { + "zh_CN": "表单" + }, + "component": "TinyForm", + "description": "由按钮、输入框、选择器、单选框、多选框等控件组成,用以收集、校验、提交数据", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Form", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 5, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "disabled", + "label": { + "text": { + "zh_CN": "是否禁用" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "label-width", + "label": { + "text": { + "zh_CN": "标签宽度" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "表单中标签占位宽度,默认为 80px" + }, + "labelPosition": "left" + }, + { + "property": "inline", + "label": { + "text": { + "zh_CN": "行内布局" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "行内布局模式,默认为 false" + } + }, + { + "property": "label-align", + "label": { + "text": { + "zh_CN": "必填标识是否占位" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "必填标识 * 是否占位" + }, + "labelPosition": "left" + }, + { + "property": "label-suffix", + "label": { + "text": { + "zh_CN": "标签后缀" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "表单中标签后缀" + } + }, + { + "property": "label-position", + "label": { + "text": { + "zh_CN": "标签位置" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "right", + "value": "right" + }, + { + "label": "left ", + "value": "left " + }, + { + "label": "top", + "value": "top" + } + ] + } + }, + "description": { + "zh_CN": "表单中标签的布局位置" + } + } + ] + }, + { + "name": "1", + "label": { + "zh_CN": "校验属性" + }, + "content": [ + { + "property": "model", + "label": { + "text": { + "zh_CN": "表单校验对象" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "表单数据对象" + }, + "labelPosition": "left" + }, + { + "property": "rules", + "label": { + "text": { + "zh_CN": "校验规则" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "表单验证规则" + } + } + ], + "description": { + "zh_CN": "" + } + } + ], + "events": { + "onValidate": { + "label": { + "zh_CN": "表单项被校验后触发" + }, + "description": { + "zh_CN": "表单项被校验后触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "function", + "type": "Function", + "defaultValue": "(valid) => {}", + "description": { + "zh_CN": "校验回调函数" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onInput": { + "label": { + "zh_CN": "输入值改变时触发" + }, + "description": { + "zh_CN": "在 Input 输入值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "输入框输入的值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onBlur": { + "label": { + "zh_CN": "失去焦点时触发" + }, + "description": { + "zh_CN": "在 Input 失去焦点时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "event", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "原生 event" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onFocus": { + "label": { + "zh_CN": "获取焦点时触发" + }, + "description": { + "zh_CN": "在 Input 获取焦点时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "event", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "原生 event" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onClear": { + "label": { + "zh_CN": "点击清空按钮时触发" + }, + "description": { + "zh_CN": "点击清空按钮时触发" + }, + "type": "event", + "functionInfo": { + "params": [], + "returns": {} + }, + "defaultValue": "" + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": [], + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["label-width", "disabled"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "icon": "formitem", + "name": { + "zh_CN": "表单项" + }, + "component": "TinyFormItem", + "description": "由按钮、输入框、选择器、单选框、多选框等控件组成,用以收集、校验、提交数据", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "FormItem", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 12, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "label", + "label": { + "text": { + "zh_CN": "标签文本" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "defaultValue": "标签", + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "标签文本" + }, + "labelPosition": "left" + }, + { + "property": "prop", + "label": { + "text": { + "zh_CN": "校验字段" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "表单域 model 字段,在使用 validate、resetFields 方法的情况下,该属性是必填的" + } + }, + { + "property": "required", + "label": { + "text": { + "zh_CN": "必填" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否必填" + }, + "labelPosition": "left" + } + ] + } + ], + "events": {}, + "slots": { + "label": { + "label": { + "zh_CN": "字段名" + }, + "description": { + "zh_CN": "自定义显示字段名称" + } + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": true, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": ["TinyForm"], + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["label", "rules"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "icon": "col", + "name": { + "zh_CN": "col" + }, + "component": "TinyCol", + "description": "列配置信息", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Col", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 2, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "span", + "label": { + "text": { + "zh_CN": "栅格列格数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "整行", + "value": 12 + }, + { + "label": "6格", + "value": 6 + }, + { + "label": "4格", + "value": 4 + }, + { + "label": "3格", + "value": 3 + }, + { + "label": "1格", + "value": 1 + } + ] + } + }, + "description": { + "zh_CN": "当一行分为12格时,一列可占位多少格" + } + }, + { + "property": "move", + "label": { + "text": { + "zh_CN": "栅格左右移动格数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": { + "min": -12, + "max": 12 + } + }, + "description": { + "zh_CN": "栅格左右移动格数(正数向右,负数向左)" + } + }, + { + "property": "no", + "label": { + "text": { + "zh_CN": "排序编号" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": { + "max": 12 + } + }, + "description": { + "zh_CN": "排序编号(row中启用order生效)" + } + }, + { + "property": "offset", + "label": { + "text": { + "zh_CN": "间隔格数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": { + "min": 0, + "max": 12 + } + }, + "description": { + "zh_CN": "栅格左侧的间隔格数" + } + }, + { + "property": "xs", + "label": { + "text": { + "zh_CN": "超小屏格数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": { + "min": 1, + "max": 12 + } + }, + "description": { + "zh_CN": "<768px 响应式栅格数" + } + }, + { + "property": "sm", + "label": { + "text": { + "zh_CN": "小屏格数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": { + "min": 1, + "max": 12 + } + }, + "description": { + "zh_CN": "≥768px 响应式栅格数" + } + }, + { + "property": "md", + "label": { + "text": { + "zh_CN": "中屏格数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": { + "min": 1, + "max": 12 + } + }, + "description": { + "zh_CN": "≥992px 响应式栅格数" + } + }, + { + "property": "lg", + "label": { + "text": { + "zh_CN": "大屏格数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": { + "min": 1, + "max": 12 + } + }, + "description": { + "zh_CN": "≥1200px 响应式栅格数" + } + }, + { + "property": "xl", + "label": { + "text": { + "zh_CN": "超大屏格数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": { + "min": 1, + "max": 12 + } + }, + "description": { + "zh_CN": "≥1920px 响应式栅格数" + } + } + ] + } + ], + "events": {} + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": true, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["label", "rules"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "name": { + "zh_CN": "按钮" + }, + "component": "TinyButton", + "icon": "button", + "description": "常用的操作按钮,提供包括默认按钮、图标按钮、图片按钮、下拉按钮等类型", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Button", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 2, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "text", + "type": "string", + "defaultValue": "按钮文案", + "label": { + "text": { + "zh_CN": "按钮文字" + } + }, + "cols": 12, + "hidden": false, + "required": true, + "readOnly": false, + "disabled": false, + "widget": { + "component": "MetaBindI18n", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "size", + "type": "select", + "label": { + "text": { + "zh_CN": "大小" + } + }, + "cols": 12, + "rules": [], + "hidden": false, + "required": true, + "readOnly": false, + "disabled": false, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "large", + "value": "large" + }, + { + "label": "medium", + "value": "medium" + }, + { + "label": "small", + "value": "small" + }, + { + "label": "mini", + "value": "mini" + } + ] + } + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "disabled", + "label": { + "text": { + "zh_CN": "禁用" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否被禁用" + }, + "labelPosition": "left" + }, + { + "property": "type", + "label": { + "text": { + "zh_CN": "类型" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "primary", + "value": "primary" + }, + { + "label": "success", + "value": "success" + }, + { + "label": "info", + "value": "info" + }, + { + "label": "warning", + "value": "warning" + }, + { + "label": "danger", + "value": "danger" + }, + { + "label": "text", + "value": "text" + } + ] + } + }, + "description": { + "zh_CN": "设置不同的主题样式" + }, + "labelPosition": "left" + } + ] + }, + { + "name": "1", + "label": { + "zh_CN": "其他" + }, + "content": [ + { + "property": "round", + "label": { + "text": { + "zh_CN": "圆角" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否圆角按钮" + }, + "labelPosition": "left" + }, + { + "property": "plain", + "label": { + "text": { + "zh_CN": "朴素按钮" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否为朴素按钮" + }, + "labelPosition": "left" + }, + { + "property": "reset-time", + "label": { + "text": { + "zh_CN": "禁用时间" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": {} + }, + "description": { + "zh_CN": "设置禁用时间,防止重复提交,单位毫秒" + } + }, + { + "property": "circle", + "label": { + "text": { + "zh_CN": "圆角" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否圆形按钮" + }, + "labelPosition": "left" + }, + { + "property": "autofocus", + "label": { + "text": { + "zh_CN": "聚焦" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否默认聚焦" + }, + "labelPosition": "left" + }, + { + "property": "loading", + "label": { + "text": { + "zh_CN": "加载中" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否展示位加载中样式" + }, + "labelPosition": "left" + } + ], + "description": { + "zh_CN": "" + } + } + ], + "events": { + "onClick": { + "label": { + "zh_CN": "点击事件" + }, + "description": { + "zh_CN": "按钮被点击时触发的回调函数" + }, + "type": "event", + "functionInfo": { + "params": [], + "returns": {} + }, + "defaultValue": "" + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": true, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["text", "size"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "name": { + "zh_CN": "输入框" + }, + "component": "TinyInput", + "icon": "input", + "description": "通过鼠标或键盘输入字符", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Input", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 1, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "modelValue", + "label": { + "text": { + "zh_CN": "绑定值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaBindI18n", + "props": {} + }, + "description": { + "zh_CN": "双向绑定值" + }, + "labelPosition": "left" + }, + { + "property": "type", + "label": { + "text": { + "zh_CN": "类型" + } + }, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "textarea", + "value": "textarea" + }, + { + "label": "text", + "value": "text" + }, + { + "label": "password", + "value": "password" + } + ] + } + }, + "description": { + "zh_CN": "设置input框的type属性" + } + }, + { + "property": "rows", + "label": { + "text": { + "zh_CN": "行数" + } + }, + "widget": { + "component": "MetaNumber" + }, + "description": { + "zh_CN": "输入框行数,只对 type='textarea' 有效" + } + }, + { + "property": "placeholder", + "label": { + "text": { + "zh_CN": "占位文本" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaBindI18n", + "props": {} + }, + "description": { + "zh_CN": "输入框占位文本" + }, + "labelPosition": "left" + }, + { + "property": "clearable", + "label": { + "text": { + "zh_CN": "清除按钮" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否显示清除按钮" + }, + "labelPosition": "left" + }, + { + "property": "disabled", + "label": { + "text": { + "zh_CN": "是否禁用" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "size", + "label": { + "text": { + "zh_CN": "尺寸" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "medium", + "value": "medium" + }, + { + "label": "small", + "value": "small" + }, + { + "label": "mini", + "value": "mini" + } + ] + } + }, + "description": { + "zh_CN": "输入框尺寸。该属性的可选值为 medium / small / mini" + } + } + ] + }, + { + "name": "1", + "label": { + "zh_CN": "其他" + }, + "content": [ + { + "property": "maxlength", + "label": { + "text": { + "zh_CN": "最大长度" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": {} + }, + "description": { + "zh_CN": "设置 input 框的maxLength" + }, + "labelPosition": "left" + }, + { + "property": "autofocus", + "label": { + "text": { + "zh_CN": "聚焦" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "自动获取焦点" + }, + "labelPosition": "left" + } + ], + "description": { + "zh_CN": "" + } + } + ], + "events": { + "onChange": { + "label": { + "zh_CN": "值改变时触发" + }, + "description": { + "zh_CN": "在 Input 值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "输入框改变后的值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onInput": { + "label": { + "zh_CN": "输入值改变时触发" + }, + "description": { + "zh_CN": "在 Input 输入值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "输入框输入的值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onUpdate:modelValue": { + "label": { + "zh_CN": "双向绑定的值改变时触发" + }, + "description": { + "zh_CN": "在 Input 输入值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "双向绑定的值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onBlur": { + "label": { + "zh_CN": "失去焦点时触发" + }, + "description": { + "zh_CN": "在 Input 失去焦点时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "event", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "原生 event" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onFocus": { + "label": { + "zh_CN": "获取焦点时触发" + }, + "description": { + "zh_CN": "在 Input 获取焦点时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "event", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "原生 event" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onClear": { + "label": { + "zh_CN": "点击清空按钮时触发" + }, + "description": { + "zh_CN": "点击清空按钮时触发" + }, + "type": "event", + "functionInfo": { + "params": [], + "returns": {} + }, + "defaultValue": "" + } + }, + "slots": { + "prefix": { + "label": { + "zh_CN": "前置内容" + } + }, + "suffix": { + "label": { + "zh_CN": "后置内容" + } + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": true, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["value", "disabled"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "icon": "radio", + "name": { + "zh_CN": "单选" + }, + "component": "TinyRadio", + "description": "用于配置不同场景的选项,在一组备选项中进行单选", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Radio", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 3, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "text", + "label": { + "text": { + "zh_CN": "文本" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "label", + "label": { + "text": { + "zh_CN": "单选框的值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "modelValue", + "label": { + "text": { + "zh_CN": "绑定值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "双向绑定的当前选中值" + } + }, + { + "property": "disabled", + "label": { + "text": { + "zh_CN": "禁用" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + } + ] + }, + { + "label": { + "zh_CN": "其他" + }, + "description": { + "zh_CN": "" + }, + "content": [ + { + "property": "border", + "label": { + "text": { + "zh_CN": "显示边框" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "size", + "label": { + "text": { + "zh_CN": "单选框的尺寸" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "name", + "label": { + "text": { + "zh_CN": "原生 name 属性" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + } + ] + } + ], + "events": { + "onChange": { + "label": { + "zh_CN": "值变化事件" + }, + "description": { + "zh_CN": "绑定值变化时触发的事件" + } + }, + "onUpdate:modelValue": { + "label": { + "zh_CN": "双向绑定的值改变时触发" + }, + "description": { + "zh_CN": "当前选中的值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "双向绑定的当前选中值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["visible", "width"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "icon": "select", + "name": { + "zh_CN": "下拉框" + }, + "component": "TinySelect", + "description": "Select 选择器是一种通过点击弹出下拉列表展示数据并进行选择的 UI 组件", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Select", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 8, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 10, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "modelValue", + "label": { + "text": { + "zh_CN": "绑定值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "双向绑定的当前选中值" + }, + "labelPosition": "left" + }, + { + "property": "placeholder", + "label": { + "text": { + "zh_CN": "占位文本" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "输入框占位文本" + }, + "labelPosition": "left" + }, + { + "property": "clearable", + "label": { + "text": { + "zh_CN": "清除按钮" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否显示清除按钮" + }, + "labelPosition": "left" + }, + { + "property": "searchable", + "label": { + "text": { + "zh_CN": "下拉面板可搜索" + } + }, + "required": false, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "下拉面板是否可搜索" + }, + "labelPosition": "left" + }, + { + "property": "disabled", + "label": { + "text": { + "zh_CN": "是否禁用" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "options", + "label": { + "text": { + "zh_CN": "下拉数据" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": { + "language": "json" + } + }, + "description": { + "zh_CN": "配置 Select 下拉数据项" + }, + "labelPosition": "left" + }, + { + "property": "multiple", + "label": { + "text": { + "zh_CN": "多选" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否允许输入框输入或选择多个项" + }, + "labelPosition": "left" + } + ] + }, + { + "name": "1", + "label": { + "zh_CN": "其他" + }, + "content": [ + { + "property": "multiple-limit", + "label": { + "text": { + "zh_CN": "最大可选值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": {} + }, + "description": { + "zh_CN": "多选时用户最多可以选择的项目数,为 0 则不限制" + }, + "labelPosition": "left" + }, + { + "property": "popper-class", + "label": { + "text": { + "zh_CN": "下拉框的类名" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "设置下拉框自定义的类名" + }, + "labelPosition": "left" + }, + { + "property": "collapse-tags", + "label": { + "text": { + "zh_CN": "多选展示" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "多选时是否将选中值按文字的形式展示" + }, + "labelPosition": "left" + } + ], + "description": { + "zh_CN": "" + } + } + ], + "events": { + "onChange": { + "label": { + "zh_CN": "值改变时触发" + }, + "description": { + "zh_CN": "在下拉框值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "下拉框选中项的值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onUpdate:modelValue": { + "label": { + "zh_CN": "双向绑定的值改变时触发" + }, + "description": { + "zh_CN": "当前选中的值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "双向绑定的当前选中值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onBlur": { + "label": { + "zh_CN": "失去焦点时触发" + }, + "description": { + "zh_CN": "在 Input 失去焦点时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "event", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "原生 event" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onFocus": { + "label": { + "zh_CN": "获取焦点时触发" + }, + "description": { + "zh_CN": "在 Input 获取焦点时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "event", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "原生 event" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onClear": { + "label": { + "zh_CN": "点击清空按钮时触发" + }, + "description": { + "zh_CN": "点击清空按钮时触发" + }, + "type": "event", + "functionInfo": { + "params": [], + "returns": {} + }, + "defaultValue": "" + }, + "onRemoveTag": { + "label": { + "zh_CN": "多选模式下移除tag时触发" + }, + "description": { + "zh_CN": "多选模式下移除tag时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "被移除Tag对应数据项的值字段" + } + } + ], + "returns": {} + }, + "defaultValue": "" + } + }, + "onBeforeMount": "console.log('table on load'); this.options = source.data" + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["multiple", "options"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "icon": "switch", + "name": { + "zh_CN": "开关" + }, + "component": "TinySwitch", + "description": "Switch 在两种状态间切换选择", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Switch", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 9, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "disabled", + "label": { + "text": { + "zh_CN": "禁用" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否被禁用" + }, + "labelPosition": "left" + }, + { + "property": "modelValue", + "label": { + "text": { + "zh_CN": "绑定值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "绑定默认值" + } + }, + { + "property": "true-value", + "label": { + "text": { + "zh_CN": "打开时的值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "设置打开时的值(Boolean / String / Number)" + }, + "labelPosition": "left" + }, + { + "property": "false-value", + "label": { + "text": { + "zh_CN": "关闭时的值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "设置关闭时的值(Boolean / String / Number)" + }, + "labelPosition": "left" + }, + { + "property": "mini", + "label": { + "text": { + "zh_CN": "迷你尺寸" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否显示为 mini 模式" + }, + "labelPosition": "left" + } + ] + } + ], + "events": { + "onChange": { + "label": { + "zh_CN": "点击事件" + }, + "description": { + "zh_CN": "按钮被点击时触发的回调函数" + }, + "type": "event", + "functionInfo": { + "params": [], + "returns": {} + }, + "defaultValue": "" + }, + "onUpdate:modelValue": { + "label": { + "zh_CN": "双向绑定的值改变时触发" + }, + "description": { + "zh_CN": "开关的状态值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "双向绑定的开关状态值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["disabled", "mini"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "icon": "search", + "name": { + "zh_CN": "搜索框" + }, + "component": "TinySearch", + "description": "指定条件对象进行搜索数据", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Search", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 2, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "modelValue", + "label": { + "text": { + "zh_CN": "默认值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "输入框内的默认搜索值" + }, + "labelPosition": "left" + }, + { + "property": "disabled", + "label": { + "text": { + "zh_CN": "禁用" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否被禁用" + }, + "labelPosition": "left" + }, + { + "property": "placeholder", + "label": { + "text": { + "zh_CN": "占位文本 " + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "输入框内的提示占位文本" + }, + "labelPosition": "left" + }, + { + "property": "clearable", + "label": { + "text": { + "zh_CN": "清空按钮" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "设置显示清空图标按钮" + }, + "labelPosition": "left" + }, + { + "property": "isEnterSearch", + "label": { + "text": { + "zh_CN": "是否Enter键触发search事件" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否在按下键盘Enter键的时候触发search事件" + }, + "labelPosition": "left" + } + ] + }, + { + "name": "1", + "label": { + "zh_CN": "其他配置" + }, + "content": [ + { + "property": "mini", + "label": { + "text": { + "zh_CN": "迷你尺寸" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "迷你模式,配置为true时,搜索默认显示为一个带图标的圆形按钮,点击后展开" + }, + "labelPosition": "left" + }, + { + "property": "transparent", + "label": { + "text": { + "zh_CN": "透明模式" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "配置为true时,边框变为透明且收缩后半透明显示,一般用在带有背景的场景,默认 false" + }, + "labelPosition": "left" + } + ], + "description": { + "zh_CN": "" + } + } + ], + "events": { + "onChange": { + "label": { + "zh_CN": "输入完成时触发" + }, + "description": { + "zh_CN": "在 input 框中输入完成时触发的回调函数" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "type", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "搜索类型,默认值为 {} " + } + }, + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "当前input框中值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onSearch": { + "label": { + "zh_CN": "点击搜索按钮时触发" + }, + "description": { + "zh_CN": "展开状态点击搜索按钮时触发的回调函数" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "type", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "搜索类型,默认值为 {} " + } + }, + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "当前input框中值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["clearable", "mini"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "icon": "checkbox", + "name": { + "zh_CN": "复选框" + }, + "component": "TinyCheckbox", + "description": "用于配置不同场景的选项,提供用户可在一组选项中进行多选", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Checkbox", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 4, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "modelValue", + "label": { + "text": { + "zh_CN": "绑定值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "双向绑定值" + }, + "labelPosition": "left" + }, + { + "property": "disabled", + "label": { + "text": { + "zh_CN": "是否禁用" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "checked", + "label": { + "text": { + "zh_CN": "勾选" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "当前是否勾选" + }, + "labelPosition": "left" + }, + { + "property": "text", + "label": { + "text": { + "zh_CN": "文本" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "复选框的文本" + }, + "labelPosition": "left" + } + ] + }, + { + "name": "1", + "label": { + "zh_CN": "其他" + }, + "content": [ + { + "property": "border", + "label": { + "text": { + "zh_CN": "边框" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否显示边框" + } + }, + { + "property": "false-label", + "label": { + "text": { + "zh_CN": "未选中的值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "没有选中时的值" + } + }, + { + "property": "true-label", + "label": { + "text": { + "zh_CN": "选择时的值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "选中时的值" + } + } + ], + "description": { + "zh_CN": "" + } + } + ], + "events": { + "onChange": { + "label": { + "zh_CN": "勾选值改变后将触发" + }, + "description": { + "zh_CN": "勾选值改变后将触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "选中项的值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onUpdate:modelValue": { + "label": { + "zh_CN": "双向绑定的值改变时触发" + }, + "description": { + "zh_CN": "当前选中的值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "双向绑定的当前选中值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["border", "disabled"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "icon": "checkboxbutton", + "name": { + "zh_CN": "复选按钮" + }, + "component": "TinyCheckboxButton", + "description": "用于配置不同场景的选项,提供用户可在一组选项中进行多选", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "CheckboxButton", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 1, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "modelValue", + "label": { + "text": { + "zh_CN": "绑定值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "双向绑定的当前选中值" + }, + "labelPosition": "left" + }, + { + "property": "disabled", + "label": { + "text": { + "zh_CN": "是否禁用" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "checked", + "label": { + "text": { + "zh_CN": "勾选" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "当前是否勾选" + }, + "labelPosition": "left" + }, + { + "property": "text", + "label": { + "text": { + "zh_CN": "文本" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "按钮文本" + }, + "labelPosition": "left" + } + ] + } + ], + "events": { + "onChange": { + "label": { + "zh_CN": "勾选值改变后将触发" + }, + "description": { + "zh_CN": "勾选值改变后将触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "选中项的值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onUpdate:modelValue": { + "label": { + "zh_CN": "双向绑定的值改变时触发" + }, + "description": { + "zh_CN": "当前选中的值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "array", + "defaultValue": "", + "description": { + "zh_CN": "双向绑定的当前选中值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": true, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["text", "size"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "icon": "checkboxgroup", + "name": { + "zh_CN": "复选按钮组" + }, + "component": "TinyCheckboxGroup", + "description": "用于配置不同场景的选项,提供用户可在一组选项中进行多选", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "CheckboxGroup", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 2, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "modelValue", + "label": { + "text": { + "zh_CN": "绑定值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": { + "dataType": "Array" + } + }, + "description": { + "zh_CN": "双向绑定的当前选中值" + }, + "labelPosition": "left" + }, + { + "property": "disabled", + "label": { + "text": { + "zh_CN": "是否禁用" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "options", + "label": { + "text": { + "zh_CN": "数据列表" + } + }, + "defaultValue": [ + { + "label": "标签2" + }, + { + "label": "标签2" + } + ], + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "checkbox组件列表" + } + }, + { + "property": "type", + "label": { + "text": { + "zh_CN": "类型" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "button", + "value": "button" + }, + { + "label": "checkbox", + "value": "checkbox" + } + ] + } + }, + "description": { + "zh_CN": "checkbox组件类型(button/checkbox),该属性的默认值为 checkbox,配合 options 属性一起使用" + }, + "labelPosition": "left" + } + ] + } + ], + "events": { + "onChange": { + "label": { + "zh_CN": "勾选值改变后将触发" + }, + "description": { + "zh_CN": "勾选值改变后将触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "选中项的值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onUpdate:modelValue": { + "label": { + "zh_CN": "双向绑定的值改变时触发" + }, + "description": { + "zh_CN": "当前选中的值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "array", + "defaultValue": "", + "description": { + "zh_CN": "双向绑定的当前选中值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": true, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["disabled", "type"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "icon": "dialogbox", + "name": { + "zh_CN": "对话框" + }, + "component": "TinyDialogBox", + "description": "模态对话框,在浮层中显示,引导用户进行相关操作。", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "DialogBox", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 4, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "title", + "label": { + "text": { + "zh_CN": "标题" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "弹出框标题" + }, + "labelPosition": "left" + }, + { + "property": "visible", + "label": { + "text": { + "zh_CN": "显示与隐藏" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "控制弹出框显示与关闭" + }, + "labelPosition": "left" + }, + { + "property": "width", + "label": { + "text": { + "zh_CN": "宽度" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "弹出框的宽度" + }, + "labelPosition": "left" + }, + { + "property": "draggable", + "label": { + "text": { + "zh_CN": "可拖拽" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否开启弹窗的拖拽功能,默认值为 false 。" + } + }, + { + "property": "center", + "label": { + "text": { + "zh_CN": "居中" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "弹出框的头部与底部内容会自动居中" + }, + "labelPosition": "left" + }, + { + "property": "dialog-class", + "label": { + "text": { + "zh_CN": "自定义类" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "自定义配置弹窗类名" + }, + "labelPosition": "left" + }, + { + "property": "append-to-body", + "label": { + "text": { + "zh_CN": "插入到 Body " + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "DialogBox 本身是否插入到 body 上,嵌套的 Dialog 必须指定该属性并赋值为 true" + }, + "labelPosition": "left" + }, + { + "property": "show-close", + "label": { + "text": { + "zh_CN": "关闭按钮" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否显示关闭按钮,默认值为 true 。" + } + } + ] + } + ], + "selector": ".TinyDialogBox", + "events": { + "onClose": { + "label": { + "zh_CN": "关闭弹窗时触发" + }, + "description": { + "zh_CN": "Dialog 关闭的回调" + }, + "type": "event", + "functionInfo": { + "params": [], + "returns": {} + }, + "defaultValue": "" + }, + "onUpdate:visible": { + "label": { + "zh_CN": "双向绑定的状态改变时触发" + }, + "description": { + "zh_CN": "显示或隐藏的状态值,发生改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "boolean", + "defaultValue": "", + "description": { + "zh_CN": "双向绑定的显示或隐藏的状态值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + } + }, + "slots": { + "title": { + "label": { + "zh_CN": "标题区" + }, + "description": { + "zh_CN": "Dialog 标题区的内容" + } + }, + "footer": { + "label": { + "zh_CN": "按钮操作区" + }, + "description": { + "zh_CN": "Dialog 按钮操作区的内容" + } + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": true, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": ".tiny-dialog-box", + "shortcuts": { + "properties": ["visible", "width"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "icon": "tabs", + "name": { + "zh_CN": "标签页" + }, + "component": "TinyTabs", + "description": "分隔内容上有关联但属于不同类别的数据集合", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Tabs", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 10, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "showEditIcon", + "label": { + "text": { + "zh_CN": "显示编辑ICON " + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否显示标题后编辑 ICON" + }, + "labelPosition": "left" + }, + { + "property": "tabs", + "label": { + "text": { + "zh_CN": "选项卡" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "defaultValue": "", + "cols": 12, + "bindState": false, + "widget": { + "component": "MetaContainer", + "props": {} + }, + "description": { + "zh_CN": "tabs" + }, + "labelPosition": "none" + }, + { + "property": "modelValue", + "label": { + "text": { + "zh_CN": "绑定值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "绑定值,选中选项卡的 name" + }, + "labelPosition": "left" + }, + { + "property": "with-add", + "label": { + "text": { + "zh_CN": "可新增" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "标签是否可增加" + }, + "labelPosition": "left" + }, + { + "property": "with-close", + "label": { + "text": { + "zh_CN": "可关闭" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "标签是否可关闭" + }, + "labelPosition": "left" + }, + { + "property": "tab-style", + "label": { + "text": { + "zh_CN": "标签页样式" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "card", + "value": "card" + }, + { + "label": "border-card", + "value": "border-card" + } + ] + } + }, + "description": { + "zh_CN": "标签页样式" + }, + "labelPosition": "left" + } + ] + } + ], + "events": { + "onClick": { + "label": { + "zh_CN": "点击页签时触发事件" + }, + "description": { + "zh_CN": "在 Input 值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "component", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "当前点击的页签对象" + } + }, + { + "name": "event", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "原生 event" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onEdit": { + "label": { + "zh_CN": "点击新增按钮或关闭按钮或者编辑按钮后触发" + }, + "description": { + "zh_CN": "点击新增按钮或关闭按钮或者编辑按钮后触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "tab", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "当前操作的页签对象" + } + }, + { + "name": "type", + "type": "String", + "defaultValue": "", + "description": { + "zh_CN": "当前操作的类型(remove || add || edit)" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onClose": { + "label": { + "zh_CN": "关闭页签时触发" + }, + "description": { + "zh_CN": "关闭页签时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "name", + "type": "String", + "defaultValue": "", + "description": { + "zh_CN": "页签名称" + } + } + ], + "returns": {} + }, + "defaultValue": "" + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": true, + "clickCapture": false, + "isModal": false, + "nestingRule": { + "childWhitelist": ["TinyTabItem"], + "parentWhitelist": [], + "descendantBlacklist": [], + "ancestorWhitelist": [] + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["size", "tab-style"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "icon": "tabitem", + "name": { + "zh_CN": "tab页签" + }, + "component": "TinyTabItem", + "description": "tab 标签页", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "TabItem", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 2, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "name", + "label": { + "text": { + "zh_CN": "唯一表示" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "唯一表示" + } + }, + { + "property": "title", + "label": { + "text": { + "zh_CN": "标题" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "标题" + } + } + ] + } + ], + "events": {}, + "slots": { + "title": { + "label": { + "zh_CN": "标题" + }, + "description": { + "zh_CN": "自定义标题" + } + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": true, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": ["TinyTab"], + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["name", "title"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "icon": "breadcrumb", + "name": { + "zh_CN": "面包屑" + }, + "component": "TinyBreadcrumb", + "description": "告诉访问者他们目前在网站中的位置以及如何返回", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Select", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 1, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "separator", + "label": { + "text": { + "zh_CN": "分隔符" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "自定义分隔符" + }, + "labelPosition": "left" + }, + { + "property": "options", + "label": { + "text": { + "zh_CN": "options" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "textField", + "label": { + "text": { + "zh_CN": "textField" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + } + } + ] + } + ], + "events": { + "onSelect": { + "label": { + "zh_CN": "选择 breadcrumb 时触发" + }, + "description": { + "zh_CN": "选择 breadcrumb 时触发" + }, + "type": "event", + "functionInfo": { + "params": [], + "returns": {} + }, + "defaultValue": "" + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": true, + "clickCapture": false, + "isModal": false, + "nestingRule": { + "childWhitelist": ["TinyBreadcrumbItem"], + "parentWhitelist": [], + "descendantBlacklist": [], + "ancestorWhitelist": [] + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["separator"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "icon": "breadcrumb", + "name": { + "zh_CN": "面包屑项" + }, + "component": "TinyBreadcrumbItem", + "description": "", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "BreadcrumbItem", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 1, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "to", + "label": { + "text": { + "zh_CN": "路由路径" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "面包屑项" + } + } + ] + } + ], + "slots": { + "default": { + "label": { + "zh_CN": "面包屑项标签" + }, + "description": { + "zh_CN": "面包屑项" + } + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": true, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": ["TinyBreadcrumb"], + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["to"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "icon": "collapse", + "name": { + "zh_CN": "折叠面板" + }, + "component": "TinyCollapse", + "description": "内容区可指定动态页面或自定义 html 等,支持展开收起操作", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Collapse", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 3, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "modelValue", + "label": { + "text": { + "zh_CN": "当前激活的面板" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "双向绑定当前激活的面板" + }, + "labelPosition": "left" + } + ] + } + ], + "events": { + "onChange": { + "label": { + "zh_CN": "激活面板改变时触发" + }, + "description": { + "zh_CN": "当前激活面板改变时触发(如果是手风琴模式,参数 activeNames 类型为string,否则为array)" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "data", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "当前激活面板的值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onUpdate:modelValue": { + "label": { + "zh_CN": "双向绑定的值改变时触发" + }, + "description": { + "zh_CN": "当前激活面板的值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "双向绑定的值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["label-width", "disabled"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "icon": "collapseitem", + "name": { + "zh_CN": "折叠面板项" + }, + "component": "TinyCollapseItem", + "description": "内容区可指定动态页面或自定义 html 等,支持展开收起操作", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "CollapseItem", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 2, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "name", + "label": { + "text": { + "zh_CN": "唯一标志符" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "唯一标志符;String | Number" + }, + "labelPosition": "left" + }, + { + "property": "title", + "label": { + "text": { + "zh_CN": "面板标题" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "面板标题" + }, + "labelPosition": "left" + } + ] + } + ], + "events": {}, + "slots": { + "title": { + "label": { + "zh_CN": "标题" + }, + "description": { + "zh_CN": "自定义标题" + } + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": true, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["label-width", "disabled"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "icon": "grid", + "name": { + "zh_CN": "表格" + }, + "component": "TinyGrid", + "description": "提供了非常强大数据表格功能,可以展示数据列表,可以对数据列表进行选择、编辑等", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Grid", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 2, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础属性" + }, + "description": { + "zh_CN": "基础属性" + }, + "collapse": { + "number": 15, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "data", + "label": { + "text": { + "zh_CN": "表格数据" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": { + "language": "json" + } + }, + "onChange": "this.delProp('fetchData')", + "description": { + "zh_CN": "设置表格的数据" + } + }, + { + "property": "columns", + "label": { + "text": { + "zh_CN": "表格列" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "properties": [ + { + "label": { + "zh_CN": "默认分组" + }, + "content": [ + { + "property": "title", + "type": "string", + "defaultValue": "", + "label": { + "text": { + "zh_CN": "列标题" + } + }, + "widget": { + "component": "MetaBindI18n", + "props": {} + } + }, + { + "property": "field", + "type": "string", + "defaultValue": "", + "label": { + "text": { + "zh_CN": "列键值" + } + }, + "widget": { + "component": "MetaInput", + "props": {} + } + }, + { + "property": "sortable", + "type": "boolean", + "defaultValue": true, + "label": { + "text": { + "zh_CN": "是否排序" + } + }, + "widget": { + "component": "MetaSwitch", + "props": {} + } + }, + { + "property": "width", + "type": "string", + "defaultValue": "", + "label": { + "text": { + "zh_CN": "列宽" + } + }, + "widget": { + "component": "MetaNumber", + "props": {} + } + }, + { + "property": "formatText", + "type": "string", + "defaultValue": "", + "label": { + "text": { + "zh_CN": "内置渲染器" + } + }, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "整数", + "value": "integer" + }, + { + "label": "小数", + "value": "number" + }, + { + "label": "金额", + "value": "money" + }, + { + "label": "百分比", + "value": "rate" + }, + { + "label": "布尔", + "value": "boole" + }, + { + "label": "年月日", + "value": "date" + }, + { + "label": "年月日时分", + "value": "dateTime" + }, + { + "label": "时间", + "value": "time" + }, + { + "label": "省略", + "value": "ellipsis" + } + ] + } + } + }, + { + "property": "renderer", + "type": "object", + "defaultValue": "", + "label": { + "text": { + "zh_CN": "渲染函数" + } + }, + "widget": { + "component": "MetaCodeEditor", + "props": { + "dataType": "JSFunction" + } + } + }, + { + "property": "slots", + "type": "object", + "defaultValue": "", + "label": { + "text": { + "zh_CN": "插槽" + } + }, + "labelPosition": "none", + "widget": { + "component": "MetaJsSlot", + "props": { + "slots": ["header", "default"] + } + } + }, + { + "property": "type", + "label": { + "text": { + "zh_CN": "列类型" + } + }, + "required": false, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "索引列", + "value": "index" + }, + { + "label": "单选列", + "value": "radio" + }, + { + "label": "多选列", + "value": "selection" + }, + { + "label": "展开列", + "value": "expand" + } + ], + "clearable": true + } + }, + "description": { + "zh_CN": "设置内置列的类型,该属性的可选值为 index(序号)/ selection(复选框)/ radio(单选框)/ expand(展开行)" + }, + "labelPosition": "left" + }, + { + "property": "editor", + "label": { + "text": { + "zh_CN": "编辑配置" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": { + "language": "json" + } + }, + "description": { + "zh_CN": "单元格编辑渲染配置项,也可以是函数 Function(h, params)" + }, + "labelPosition": "left" + }, + { + "property": "filter", + "label": { + "text": { + "zh_CN": "筛选配置" + } + }, + "required": false, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": { + "language": "json" + } + }, + "description": { + "zh_CN": "设置表格列的筛选配置信息。默认值为 false 不配置筛选信息" + } + }, + { + "property": "showOverflow", + "label": { + "text": { + "zh_CN": "内容超出部分省略号配置" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "只显示省略号", + "value": "ellipsis" + }, + { + "label": "显示为原生 title", + "value": "title" + }, + { + "label": "显示为 tooltip 提示", + "value": "tooltip" + } + ], + "clearable": true + } + }, + "description": { + "zh_CN": "设置内置列的内容超出部分显示省略号配置,该属性的可选值为 ellipsis(只显示省略号)/ title(显示为原生 title)/ tooltip(显示为 tooltip 提示)" + }, + "labelPosition": "left" + } + ] + } + ], + "widget": { + "component": "MetaArrayItem", + "props": { + "type": "object", + "textField": "title", + "language": "json", + "buttonText": "编辑列配置", + "title": "编辑列配置", + "expand": true + } + }, + "description": { + "zh_CN": "表格列的配置信息" + }, + "labelPosition": "left" + }, + { + "property": "fetchData", + "label": { + "text": { + "zh_CN": "服务端数据" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "onChange": "this.delProp('data')", + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": { + "name": "fetchData", + "dataType": "JSExpression" + } + }, + "description": { + "zh_CN": "服务端数据查询方法" + } + }, + { + "property": "pager", + "label": { + "text": { + "zh_CN": "分页配置" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "defaultValue": { + "attrs": { + "currentPage": 1 + } + }, + "widget": { + "component": "MetaCodeEditor", + "props": { + "name": "pager", + "dataType": "JSExpression" + } + }, + "description": { + "zh_CN": "分页配置" + } + }, + { + "property": "resizable", + "label": { + "text": { + "zh_CN": "调整列宽" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否允许调整列宽" + }, + "labelPosition": "left" + }, + { + "property": "row-id", + "label": { + "text": { + "zh_CN": "行数据唯一标识的字段名" + } + }, + "required": false, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": { + "placeholder": "比如:id" + } + }, + "description": { + "zh_CN": "行数据唯一标识的字段名" + }, + "labelPosition": "left" + }, + { + "property": "select-config", + "label": { + "text": { + "zh_CN": "复选框配置" + } + }, + "required": false, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": { + "dataType": "JSExpression" + } + }, + "description": { + "zh_CN": "表格行数据复选框配置项" + }, + "labelPosition": "left" + }, + { + "property": "edit-rules", + "label": { + "text": { + "zh_CN": "校验规则" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "表格校验规则配置项" + }, + "labelPosition": "left" + }, + { + "property": "edit-config", + "label": { + "text": { + "zh_CN": "编辑配置项" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "表格编辑配置项" + } + }, + { + "property": "expand-config", + "label": { + "text": { + "zh_CN": "复选框配置项" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "复选框配置项" + }, + "labelPosition": "left" + }, + { + "property": "sortable", + "label": { + "text": { + "zh_CN": "可排序" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否允许列数据排序。默认为 true 可排序" + }, + "labelPosition": "left" + } + ] + }, + { + "label": { + "zh_CN": "其他属性" + }, + "description": { + "zh_CN": "其他属性" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "auto-resize", + "label": { + "text": { + "zh_CN": "可排序" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否允许列数据排序。默认为 true 可排序" + }, + "labelPosition": "left" + }, + { + "property": "border", + "label": { + "text": { + "zh_CN": "边框" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否带有纵向边框" + }, + "labelPosition": "left" + }, + { + "property": "seq-serial", + "label": { + "text": { + "zh_CN": "行号连续" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "设置行序号是否连续,开启分页时有效,该属性的默认值为 false" + }, + "labelPosition": "left" + }, + { + "property": "highlight-current-row", + "label": { + "text": { + "zh_CN": "高亮当前行" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "高亮当前行" + }, + "labelPosition": "left" + }, + { + "property": "highlight-hover-row", + "label": { + "text": { + "zh_CN": "hover 时候高亮" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "鼠标移到行是否要高亮显示" + }, + "labelPosition": "left" + }, + { + "property": "row-class-name", + "label": { + "text": { + "zh_CN": "hover 高亮" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "给行附加 className,也可以是函数 Function({seq, row, rowIndex, $rowIndex})" + }, + "labelPosition": "left" + }, + { + "property": "max-height", + "label": { + "text": { + "zh_CN": "最大高度" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "设置表格内容区域(不含表格头部,底部)的最大高度。" + }, + "labelPosition": "left" + }, + { + "property": "row-span", + "label": { + "text": { + "zh_CN": "行合并" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "设置行合并,该属性仅适用于普通表格,不可与 tree-config 同时使用" + }, + "labelPosition": "left" + } + ] + } + ], + "events": { + "onFilterChange": { + "label": { + "zh_CN": "筛选条件改变时触发改事件" + }, + "description": { + "zh_CN": "配置 remote-filter 开启服务端过滤,服务端过滤会调用表格 fetch-data 进行查询,filter-change 服务端过滤后触发的事件" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "table", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "{$table,filters} 包含 table 实例对象和过滤条件的对象" + } + } + ], + "returns": {} + }, + "defaultValue": "function onClick(e) {}" + }, + "onSortChange": { + "label": { + "zh_CN": "点击列头,执行数据排序前触发的事件" + }, + "description": { + "zh_CN": "配置 remote-filter 开启服务端过滤,服务端过滤会调用表格 fetch-data 进行查询,filter-change 服务端过滤后触发的事件" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "table", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "{$table,filters} 包含 table 实例对象和过滤条件的对象" + } + } + ], + "returns": {} + }, + "defaultValue": "function onClick(e) {}" + }, + "onSelectAll": { + "label": { + "zh_CN": "当手动勾选全选时触发的事件" + }, + "description": { + "zh_CN": "只对 type=selection 有效,当手动勾选全选时触发的事件" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "table", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": " 包含 table 实例对象" + } + }, + { + "name": "checked", + "type": "boolean", + "defaultValue": "", + "description": { + "zh_CN": "勾选状态" + } + }, + { + "name": "selction", + "type": "Array", + "defaultValue": "", + "description": { + "zh_CN": "选中的表格数据数组" + } + } + ], + "returns": {} + }, + "defaultValue": "function onClick(e) {}" + }, + "onSelectChange": { + "label": { + "zh_CN": "手动勾选并且值发生改变时触发的事件" + }, + "description": { + "zh_CN": "只对 type=selection 有效,当手动勾选并且值发生改变时触发的事件" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "table", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": " table 实例对象" + } + }, + { + "name": "event", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": " 原生 Event" + } + } + ], + "returns": {} + }, + "defaultValue": "function onClick(e) {}" + }, + "onToggleExpandChange": { + "label": { + "zh_CN": "当行展开或收起时会触发该事件" + }, + "description": { + "zh_CN": "当行展开或收起时会触发该事件" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "table", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "{$table,row,rowIndex} 包含 table 实例对象和当前行数据的对象" + } + }, + { + "name": "event", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": " 原生 Event" + } + } + ], + "returns": {} + }, + "defaultValue": "function onClick(e) {}" + }, + "onCurrentChange": { + "label": { + "zh_CN": "行点击时触发" + }, + "description": { + "zh_CN": "行点击时触发" + }, + "type": "event", + "functionInfo": { + "params": [], + "returns": {} + }, + "defaultValue": "" + } + }, + "shortcuts": { + "properties": ["sortable", "columns"] + }, + "contentMenu": { + "actions": ["create symbol"] + }, + "onBeforeMount": "console.log('table on load'); this.pager = source.pager; this.fetchData = source.fetchData; this.data = source.data ;this.columns = source.columns" + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["sortable", "columns"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "name": { + "zh_CN": "分页" + }, + "component": "TinyPager", + "icon": "pager", + "description": "当数据量过多时,使用分页分解数据,常用于 Grid 和 Repeater 组件", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Pager", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 1, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 10, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "currentPage", + "label": { + "text": { + "zh_CN": "当前页数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": {} + }, + "description": { + "zh_CN": "当前页数,支持 .sync 修饰符" + }, + "labelPosition": "left" + }, + { + "property": "pageSize", + "label": { + "text": { + "zh_CN": "每页条数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": {} + }, + "description": { + "zh_CN": "每页显示条目个数" + }, + "labelPosition": "left" + }, + { + "property": "pageSizes", + "label": { + "text": { + "zh_CN": "可选每页条数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "设置可选择的每页显示条数" + } + }, + { + "property": "total", + "label": { + "text": { + "zh_CN": "总条数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": {} + }, + "description": { + "zh_CN": "数据总条数" + }, + "labelPosition": "left" + }, + { + "property": "layout", + "label": { + "text": { + "zh_CN": "布局" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "defaultValue": "total,sizes,prev, pager, next", + "widget": { + "component": "MetaInput", + "props": { + "type": "textarea" + } + }, + "description": { + "zh_CN": "组件布局,子组件名用逗号分隔" + }, + "labelPosition": "left" + } + ] + } + ], + "events": { + "onCurrentChange ": { + "label": { + "zh_CN": "切换页码时触发" + }, + "description": { + "zh_CN": "切换页码时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "当前页的值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onPrevClick ": { + "label": { + "zh_CN": "点击上一页按钮时触发" + }, + "description": { + "zh_CN": "点击上一页按钮时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "page", + "type": "String", + "defaultValue": "", + "description": { + "zh_CN": "当前页的页码值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onNextClick": { + "label": { + "zh_CN": "点击下一页按钮时触发" + }, + "description": { + "zh_CN": "点击上一页按钮时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "page", + "type": "String", + "defaultValue": "", + "description": { + "zh_CN": "当前页的页码值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["currentPage", "total"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "name": { + "zh_CN": "弹出编辑" + }, + "component": "TinyPopeditor", + "icon": "popEditor", + "description": "该组件只能在弹出的面板中选择数据,不能手动输入数据;弹出面板中显示为 Tree 组件或者 Grid 组件", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "PopEditor", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 6, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "modelValue", + "label": { + "text": { + "zh_CN": "绑定值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "双向绑定值" + }, + "labelPosition": "left" + }, + { + "property": "placeholder", + "label": { + "text": { + "zh_CN": "占位文本" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "输入框占位文本" + }, + "labelPosition": "left" + }, + { + "property": "show-clear-btn", + "label": { + "text": { + "zh_CN": "清除按钮" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否显示清除按钮" + }, + "labelPosition": "left" + }, + { + "property": "disabled", + "label": { + "text": { + "zh_CN": "是否禁用" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + } + ] + }, + { + "name": "1", + "label": { + "zh_CN": "其他" + }, + "content": [ + { + "property": "width", + "label": { + "text": { + "zh_CN": "宽度" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": {} + }, + "description": { + "zh_CN": "设置弹出面板的宽度(单位像素)" + }, + "labelPosition": "left" + }, + { + "property": "conditions", + "label": { + "text": { + "zh_CN": "过滤条件" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "当弹出面板配置的是表格时,设置弹出面板中的过滤条件" + }, + "labelPosition": "left" + }, + { + "property": "grid-op", + "label": { + "text": { + "zh_CN": "表格配置" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "设置弹出面板中表格组件的配置信息" + }, + "labelPosition": "left" + }, + { + "property": "pager-op", + "label": { + "text": { + "zh_CN": "分页配置" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "设置弹出编辑框中分页配置" + }, + "labelPosition": "left" + }, + { + "property": "multi", + "label": { + "text": { + "zh_CN": "多选" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "设置弹出面板中的数据是否可多选" + }, + "labelPosition": "left" + }, + { + "property": "show-pager", + "label": { + "text": { + "zh_CN": "启用分页" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "当 popseletor 为 grid 时才能生效,配置为 true 后还需配置 pagerOp 属性" + } + } + ], + "description": { + "zh_CN": "" + } + } + ], + "events": { + "onChange": { + "label": { + "zh_CN": "选中值改变时触发" + }, + "description": { + "zh_CN": "在 Input 值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "当前选中项的值" + } + }, + { + "name": "value", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "当前选中对象" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onUpdate:modelValue": { + "label": { + "zh_CN": "双向绑定的值改变时触发" + }, + "description": { + "zh_CN": "当前选中的值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "双向绑定的当前选中值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onClose": { + "label": { + "zh_CN": "弹框关闭时触发的事件" + }, + "description": { + "zh_CN": "弹框关闭时触发的事件" + }, + "type": "event", + "functionInfo": { + "params": [], + "returns": {} + }, + "defaultValue": "" + }, + "onPageChange": { + "label": { + "zh_CN": "分页切换事件" + }, + "description": { + "zh_CN": "表格模式下分页切换事件" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "String", + "defaultValue": "", + "description": { + "zh_CN": "当前页码数" + } + } + ], + "returns": {} + }, + "defaultValue": "" + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["modelValue", "disabled"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "icon": "tree", + "name": { + "zh_CN": "树" + }, + "component": "TinyTree", + "description": "可进行展示有父子层级的数据,支持选择,异步加载等功能。但不推荐用它来展示菜单,展示菜单推荐使用树菜单", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Tree", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 12, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "show-checkbox", + "label": { + "text": { + "zh_CN": "多选" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "设置接口是否可以多选" + }, + "labelPosition": "left" + }, + { + "property": "data", + "label": { + "text": { + "zh_CN": "数据源" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "defaultValue": [ + { + "label": "一级 1", + "children": [ + { + "label": "二级 1-1" + } + ] + } + ], + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "可配置静态数据源和动态数据源" + } + }, + { + "property": "node-key", + "label": { + "text": { + "zh_CN": "唯一标识" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "节点唯一标识属性名称" + }, + "labelPosition": "left" + }, + { + "property": "icon-trigger-click-node", + "label": { + "text": { + "zh_CN": "触发NodeClick 事件" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "点击图标展开节点时是否触发 node-click 事件" + }, + "labelPosition": "left" + }, + { + "property": "expand-icon", + "label": { + "text": { + "zh_CN": "展开图标" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "节点展开图标" + }, + "labelPosition": "left" + }, + { + "property": "shrink-icon", + "label": { + "text": { + "zh_CN": "收缩图标" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "节点收缩的图标" + }, + "labelPosition": "left" + } + ] + }, + { + "name": "1", + "label": { + "zh_CN": "其他" + }, + "content": [ + { + "property": "check-on-click-node", + "label": { + "text": { + "zh_CN": "点击节点选中" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否在点击节点的时候选中节点,默认值为 false,即只有在点击复选框时才会选中节点" + }, + "labelPosition": "left" + }, + { + "property": "filter-node-method", + "label": { + "text": { + "zh_CN": "筛选函数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "节点筛选函数" + }, + "labelPosition": "left" + } + ], + "description": { + "zh_CN": "" + } + } + ], + "events": { + "onCheck": { + "label": { + "zh_CN": "勾选节点后的事件" + }, + "description": { + "zh_CN": "勾选节点后的事件" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "data", + "type": "object", + "defaultValue": "", + "description": { + "zh_CN": "当前选中节点信息" + } + }, + { + "name": "currentNode", + "type": "object", + "defaultValue": "", + "description": { + "zh_CN": "树组件目前的选中状态信息,包含 checkedNodes、checkedKeys、halfCheckedNodes、halfCheckedKeys 四个属性" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onNodeClick": { + "label": { + "zh_CN": "点击节点后的事件" + }, + "description": { + "zh_CN": "点击节点后的事件" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "data", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "当前选中节点信息" + } + }, + { + "name": "node", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "树组件目前的选中状态信息,包含 checkedNodes、checkedKeys、halfCheckedNodes、halfCheckedKeys 四个属性" + } + }, + { + "name": "vm", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "树组件实例" + } + } + ], + "returns": {} + }, + "defaultValue": "" + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["data", "show-checkbox"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "icon": "timeline", + "name": { + "zh_CN": "时间线" + }, + "component": "TinyTimeLine", + "description": "TimeLine 时间线", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "TimeLine", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 3, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "horizontal", + "type": "Boolean", + "defaultValue": { + "type": "i18n", + "zh_CN": "布局", + "en_US": "layout", + "key": "" + }, + "label": { + "text": { + "zh_CN": "水平布局" + } + }, + "cols": 12, + "rules": [], + "hidden": false, + "required": true, + "readOnly": false, + "disabled": false, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "节点和文字横向布局" + } + }, + { + "property": "vertical", + "type": "Boolean", + "defaultValue": { + "type": "i18n", + "zh_CN": "垂直布局", + "en_US": "layout", + "key": "" + }, + "label": { + "text": { + "zh_CN": "垂直布局" + } + }, + "cols": 12, + "rules": [], + "hidden": false, + "required": true, + "readOnly": false, + "disabled": false, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "节点和文字垂直布局" + } + }, + { + "property": "active", + "label": { + "text": { + "zh_CN": "选中值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": {} + }, + "description": { + "zh_CN": "步骤条的选中步骤值" + }, + "labelPosition": "left" + }, + { + "property": "data", + "label": { + "text": { + "zh_CN": "数据" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "defaultValue": [ + { + "name": "配置基本信息", + "status": "ready" + }, + { + "name": "配置报价", + "status": "wait" + }, + { + "name": "完成报价", + "status": "wait" + } + ], + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "时间线步骤条数据" + }, + "labelPosition": "left" + } + ] + } + ], + "events": { + "onClick": { + "label": { + "zh_CN": "节点的点击时触发" + }, + "description": { + "zh_CN": "节点的点击时触发的回调函数" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "type", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "点击节点的下标" + } + }, + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "当前节点对象:{ name: 节点名称, time: 时间 }" + } + } + ], + "returns": {} + }, + "defaultValue": "" + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["active", "data"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "icon": "tooltip", + "name": { + "zh_CN": "文字提示框" + }, + "component": "TinyTooltip", + "description": "动态显示提示信息,一般通过鼠标事件进行响应;提供 warning、error、info、success 四种类型显示不同类别的信", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Tooltip", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 11, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 20, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "placement", + "label": { + "text": { + "zh_CN": "提示位置" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "top", + "value": "top" + }, + { + "label": "top-start", + "value": "top-start" + }, + { + "label": "top-end", + "value": "top-end" + }, + { + "label": "bottom", + "value": "bottom" + }, + { + "label": "bottom-start", + "value": "bottom-start" + }, + { + "label": "bottom-end", + "value": "bottom-end" + }, + { + "label": "left", + "value": "left" + }, + { + "label": "left-start", + "value": "left-start" + }, + { + "label": "left-end", + "value": "left-end" + }, + { + "label": "right", + "value": "right" + }, + { + "label": "right-start", + "value": "right-start" + }, + { + "label": "right-end", + "value": "right-end" + } + ] + } + }, + "description": { + "zh_CN": "Tooltip 的出现位置" + }, + "labelPosition": "left" + }, + { + "property": "content", + "label": { + "text": { + "zh_CN": "内容" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "defaultValue": "提示信息", + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "显示的内容,也可以通过 slot#content 传入 DOM" + } + }, + { + "property": "modelValue", + "label": { + "text": { + "zh_CN": "是否可见" + } + }, + "defaultValue": true, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "状态是否可见" + } + }, + { + "property": "manual", + "label": { + "text": { + "zh_CN": "手动控制" + } + }, + "defaultValue": true, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "手动控制模式,设置为 true 后,mouseenter 和 mouseleave 事件将不会生效" + } + } + ] + } + ], + "events": {}, + "slots": { + "content": { + "label": { + "zh_CN": "提示内容" + }, + "description": { + "zh_CN": "自定义提示内容" + } + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": true, + "isModal": false, + "isPopper": true, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["disabled", "content"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "icon": "popover", + "name": { + "zh_CN": "提示框" + }, + "component": "TinyPopover", + "description": "Popover可通过对一个触发源操作触发弹出框,支持自定义弹出内容,延迟触发和渐变动画", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Popover", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 7, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "modelValue", + "label": { + "text": { + "zh_CN": "绑定值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "双向绑定,手动控制是否可见的状态值" + }, + "labelPosition": "left" + }, + { + "property": "placement", + "label": { + "text": { + "zh_CN": "位置" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "top", + "value": "top" + }, + { + "label": "top-start", + "value": "top-start" + }, + { + "label": "top-end", + "value": "top-end" + }, + { + "label": "bottom", + "value": "bottom" + }, + { + "label": "bottom-start", + "value": "bottom-start" + }, + { + "label": "bottom-end", + "value": "bottom-end" + }, + { + "label": "left", + "value": "left" + }, + { + "label": "left-start", + "value": "left-start" + }, + { + "label": "left-end", + "value": "left-end" + }, + { + "label": "right", + "value": "right" + }, + { + "label": "right-start", + "value": "right-start" + }, + { + "label": "right-end", + "value": "right-end" + } + ] + } + }, + "description": { + "zh_CN": "" + }, + "labelPosition": "left" + }, + { + "property": "trigger", + "label": { + "text": { + "zh_CN": "触发方式" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "click", + "value": "click" + }, + { + "label": "focus", + "value": "focus" + }, + { + "label": "hover", + "value": "hover" + }, + { + "label": "manual", + "value": "manual" + } + ] + } + }, + "description": { + "zh_CN": "触发方式,该属性的可选值为 click / focus / hover / manual,该属性的默认值为 click" + } + }, + { + "property": "popper-class", + "label": { + "text": { + "zh_CN": "自定义类" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "为 popper 添加类名" + }, + "labelPosition": "left" + }, + { + "property": "visible-arrow", + "label": { + "text": { + "zh_CN": "显示箭头" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否显示 Tooltip 箭头" + } + }, + { + "property": "append-to-body", + "label": { + "text": { + "zh_CN": "添加到body上" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "Popover弹窗是否添加到body上" + } + }, + { + "property": "arrow-offset", + "label": { + "text": { + "zh_CN": "箭头的位置偏移" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": {} + }, + "description": { + "zh_CN": "箭头的位置偏移,该属性的默认值为 0" + } + }, + { + "property": "close-delay", + "label": { + "text": { + "zh_CN": "隐藏延迟" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": {} + }, + "description": { + "zh_CN": "触发方式为 hover 时的隐藏延迟,单位为毫秒" + } + }, + { + "property": "content", + "label": { + "text": { + "zh_CN": "显示的内容" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "显示的内容,也可以通过 slot 传入 DOM" + } + }, + { + "property": "disabled", + "label": { + "text": { + "zh_CN": "禁用" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "Popover 是否可用" + } + }, + { + "property": "offset", + "label": { + "text": { + "zh_CN": "位置偏移量" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": {} + }, + "description": { + "zh_CN": "出现位置的偏移量" + } + }, + { + "property": "open-delay", + "label": { + "text": { + "zh_CN": "显示延迟" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": {} + }, + "description": { + "zh_CN": "触发方式为 hover 时的显示延迟,单位为毫秒" + } + }, + { + "property": "popper-options", + "label": { + "text": { + "zh_CN": "popper.js的参数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "popper.js 的参数" + } + }, + { + "property": "title", + "label": { + "text": { + "zh_CN": "标题" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "标题" + } + }, + { + "property": "transform-origin", + "label": { + "text": { + "zh_CN": "旋转中心点" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "组件的旋转中心点,组件的旋转中心点" + } + }, + { + "property": "transition", + "label": { + "text": { + "zh_CN": "定义渐变动画" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "该属性的默认值为 fade-in-linear" + } + }, + { + "property": "width", + "label": { + "text": { + "zh_CN": "宽度" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": {} + }, + "description": { + "zh_CN": "宽度" + } + } + ] + } + ], + "events": { + "onUpdate:modelValue": { + "label": { + "zh_CN": "双向绑定的值改变时触发" + }, + "description": { + "zh_CN": "手动控制是否可见的状态值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "boolean", + "defaultValue": "", + "description": { + "zh_CN": "双向绑定的可见状态值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": true, + "isModal": false, + "isPopper": true, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["visible", "width"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + } + ], + "blocks": [], + "snippets": [ + { + "group": "html", + "children": [ + { + "name": { + "zh_CN": "段落" + }, + "icon": "paragraph", + "screenshot": "", + "snippetName": "p", + "schema": { + "componentName": "p", + "children": "TinyEngine 前端可视化设计器致力于通过友好的用户交互提升业务应用的开发效率。" + } + }, + { + "name": { + "zh_CN": "链接" + }, + "icon": "link", + "screenshot": "", + "snippetName": "a", + "schema": { + "componentName": "a", + "children": "链接" + } + }, + { + "name": { + "zh_CN": "分隔线" + }, + "icon": "hr", + "screenshot": "", + "snippetName": "hr", + "schema": {} + }, + { + "name": { + "zh_CN": "标题" + }, + "icon": "h16", + "screenshot": "", + "snippetName": "h1", + "schema": { + "componentName": "h1", + "props": {}, + "children": "Heading" + } + }, + { + "name": { + "zh_CN": "输入框" + }, + "icon": "input", + "screenshot": "", + "snippetName": "input", + "schema": { + "componentName": "input", + "props": { + "type": "text", + "placeholder": "请输入" + } + } + }, + { + "name": { + "zh_CN": "视频" + }, + "icon": "video", + "screenshot": "", + "snippetName": "video", + "schema": { + "componentName": "video", + "props": { + "src": "img/webNova.jpg", + "width": "200", + "height": "100", + "style": "border:1px solid #ccc" + } + } + }, + { + "name": { + "zh_CN": "图片" + }, + "icon": "Image", + "screenshot": "", + "snippetName": "img", + "schema": { + "componentName": "img", + "props": { + "src": "img/webNova.jpg", + "width": "200", + "height": "100" + } + } + }, + { + "name": { + "zh_CN": "按钮" + }, + "icon": "button", + "screenshot": "", + "snippetName": "button", + "schema": { + "componentName": "button", + "props": {}, + "children": [ + { + "componentName": "Text", + "props": { + "text": "按钮文案" + } + } + ] + } + }, + { + "name": { + "zh_CN": "表格" + }, + "icon": "table", + "screenshot": "", + "snippetName": "table", + "schema": { + "componentName": "table", + "props": { + "border": "1" + }, + "children": [ + { + "componentName": "tr", + "children": [ + { + "componentName": "td", + "children": "Month" + }, + { + "componentName": "td", + "children": "Savings" + } + ] + }, + { + "componentName": "tr", + "children": [ + { + "componentName": "td", + "children": "January" + }, + { + "componentName": "td", + "children": "100" + } + ] + } + ] + } + }, + { + "name": { + "zh_CN": "表单" + }, + "icon": "form", + "screenshot": "", + "snippetName": "form", + "schema": { + "componentName": "form", + "props": { + "action": "action" + }, + "children": [ + { + "componentName": "label", + "props": { + "for": "male" + }, + "children": "male" + }, + { + "componentName": "input", + "props": { + "type": "text" + } + }, + { + "componentName": "br" + }, + { + "componentName": "label", + "props": { + "for": "Female" + }, + "children": "Female" + }, + { + "componentName": "input", + "props": { + "type": "text" + } + } + ] + } + } + ] + }, + { + "group": "content", + "children": [ + { + "name": { + "zh_CN": "走马灯" + }, + "screenshot": "", + "snippetName": "tiny-carousel", + "icon": "carousel", + "schema": { + "componentName": "TinyCarousel", + "props": { + "height": "180px" + }, + "children": [ + { + "componentName": "TinyCarouselItem", + "children": [ + { + "componentName": "div", + "props": { + "style": "margin:10px 0 0 30px" + } + } + ] + }, + { + "componentName": "TinyCarouselItem", + "children": [ + { + "componentName": "div", + "props": { + "style": "margin:10px 0 0 30px" + } + } + ] + } + ] + } + }, + { + "name": { + "zh_CN": "表单" + }, + "screenshot": "", + "snippetName": "tiny-form", + "icon": "form", + "schema": { + "componentName": "TinyForm", + "props": { + "labelWidth": "80px", + "labelPosition": "top" + }, + "children": [ + { + "componentName": "TinyFormItem", + "props": { + "label": "人员" + }, + "children": [ + { + "componentName": "TinyInput", + "props": { + "placeholder": "请输入", + "modelValue": "" + } + } + ] + }, + { + "componentName": "TinyFormItem", + "props": { + "label": "密码" + }, + "children": [ + { + "componentName": "TinyInput", + "props": { + "placeholder": "请输入", + "modelValue": "", + "type": "password" + } + } + ] + }, + { + "componentName": "TinyFormItem", + "props": { + "label": "" + }, + "children": [ + { + "componentName": "TinyButton", + "props": { + "text": "提交", + "type": "primary", + "style": "margin-right: 10px" + } + }, + { + "componentName": "TinyButton", + "props": { + "text": "重置", + "type": "primary" + } + } + ] + } + ] + } + }, + { + "name": { + "zh_CN": "下拉框" + }, + "icon": "select", + "screenshot": "", + "snippetName": "TinySelect", + "schema": { + "componentName": "TinySelect", + "props": { + "modelValue": "", + "placeholder": "请选择", + "options": [ + { + "value": "1", + "label": "黄金糕" + }, + { + "value": "2", + "label": "双皮奶" + } + ] + } + } + }, + { + "name": { + "zh_CN": "开关" + }, + "icon": "switch", + "screenshot": "", + "snippetName": "TinySwitch", + "schema": { + "componentName": "TinySwitch", + "props": { + "modelValue": "" + } + } + }, + { + "name": { + "zh_CN": "复选框组" + }, + "icon": "checkboxs", + "screenshot": "", + "snippetName": "TinyCheckboxGroup", + "schema": { + "componentName": "TinyCheckboxGroup", + "props": { + "modelValue": ["name1", "name2"], + "type": "checkbox", + "options": [ + { + "text": "复选框1", + "label": "name1" + }, + { + "text": "复选框2", + "label": "name2" + }, + { + "text": "复选框3", + "label": "name3" + } + ] + } + } + }, + { + "name": { + "zh_CN": "复选框拖拽按钮组" + }, + "icon": "checkboxgroup", + "screenshot": "", + "snippetName": "TinyCheckboxbuttonGroup", + "schema": { + "componentName": "TinyCheckboxGroup", + "props": { + "modelValue": [] + }, + "children": [ + { + "componentName": "TinyCheckboxButton", + "children": [ + { + "componentName": "div" + } + ] + } + ] + } + }, + { + "name": { + "zh_CN": "对话框" + }, + "screenshot": "", + "snippetName": "TinyDialogBox", + "icon": "dialogbox", + "schema": { + "componentName": "TinyDialogBox", + "props": { + "visible": true, + "show-close": true, + "title": "dialogBox title" + }, + "children": [ + { + "componentName": "div" + } + ] + } + }, + { + "name": { + "zh_CN": "标签页" + }, + "icon": "tabs", + "screenshot": "", + "group": true, + "snippetName": "TinyTabs", + "schema": { + "componentName": "TinyTabs", + "props": { + "modelValue": "first" + }, + "children": [ + { + "componentName": "TinyTabItem", + "props": { + "title": "标签页1", + "name": "first" + }, + "children": [ + { + "componentName": "div", + "props": { + "style": "margin:10px 0 0 30px" + } + } + ] + }, + { + "componentName": "TinyTabItem", + "props": { + "title": "标签页2", + "name": "second" + }, + "children": [ + { + "componentName": "div", + "props": { + "style": "margin:10px 0 0 30px" + } + } + ] + } + ] + } + }, + { + "name": { + "zh_CN": "折叠面板" + }, + "screenshot": "", + "snippetName": "TinyCollapse", + "icon": "collapse", + "schema": { + "componentName": "TinyCollapse", + "props": { + "modelValue": "collapse1" + }, + "children": [ + { + "componentName": "TinyCollapseItem", + "props": { + "name": "collapse1", + "title": "折叠项1" + }, + "children": [ + { + "componentName": "div" + } + ] + }, + { + "componentName": "TinyCollapseItem", + "props": { + "name": "collapse2", + "title": "折叠项2" + }, + "children": [ + { + "componentName": "div" + } + ] + }, + { + "componentName": "TinyCollapseItem", + "props": { + "name": "collapse3", + "title": "折叠项3" + }, + "children": [ + { + "componentName": "div" + } + ] + } + ] + } + }, + { + "name": { + "zh_CN": "表格" + }, + "icon": "grid", + "screenshot": "", + "snippetName": "tinyGrid", + "schema": { + "componentName": "TinyGrid", + "props": { + "editConfig": { + "trigger": "click", + "mode": "cell", + "showStatus": true + }, + "columns": [ + { + "type": "index", + "width": 60 + }, + { + "type": "selection", + "width": 60 + }, + { + "field": "employees", + "title": "员工数" + }, + { + "field": "created_date", + "title": "创建日期" + }, + { + "field": "city", + "title": "城市" + } + ], + "data": [ + { + "id": "1", + "name": "GFD科技有限公司", + "city": "福州", + "employees": 800, + "created_date": "2014-04-30 00:56:00", + "boole": false + }, + { + "id": "2", + "name": "WWW科技有限公司", + "city": "深圳", + "employees": 300, + "created_date": "2016-07-08 12:36:22", + "boole": true + } + ] + } + } + }, + { + "name": { + "zh_CN": "弹出编辑" + }, + "icon": "popeditor", + "screenshot": "", + "snippetName": "TinyPopeditor", + "schema": { + "componentName": "TinyPopeditor", + "props": { + "modelValue": "", + "placeholder": "请选择", + "gridOp": { + "columns": [ + { + "field": "id", + "title": "ID", + "width": 40 + }, + { + "field": "name", + "title": "名称", + "showOverflow": "tooltip" + }, + { + "field": "province", + "title": "省份", + "width": 80 + }, + { + "field": "city", + "title": "城市", + "width": 80 + } + ], + "data": [ + { + "id": "1", + "name": "GFD科技有限公司GFD科技有限公司GFD科技有限公司GFD科技有限公司GFD科技有限公司GFD科技有限公司GFD科技有限公司", + "city": "福州", + "province": "福建" + }, + { + "id": "2", + "name": "WWW科技有限公司", + "city": "深圳", + "province": "广东" + }, + { + "id": "3", + "name": "RFV有限责任公司", + "city": "中山", + "province": "广东" + }, + { + "id": "4", + "name": "TGB科技有限公司", + "city": "龙岩", + "province": "福建" + }, + { + "id": "5", + "name": "YHN科技有限公司", + "city": "韶关", + "province": "广东" + }, + { + "id": "6", + "name": "WSX科技有限公司", + "city": "黄冈", + "province": "武汉" + } + ] + } + } + } + }, + { + "name": { + "zh_CN": "树" + }, + "icon": "tree", + "screenshot": "", + "snippetName": "TinyTree", + "schema": { + "componentName": "TinyTree", + "props": { + "data": [ + { + "label": "一级 1", + "children": [ + { + "label": "二级 1-1", + "children": [ + { + "label": "三级 1-1-1" + } + ] + } + ] + }, + { + "label": "一级 2", + "children": [ + { + "label": "二级 2-1", + "children": [ + { + "label": "三级 2-1-1" + } + ] + }, + { + "label": "二级 2-2", + "children": [ + { + "label": "三级 2-2-1" + } + ] + } + ] + } + ] + } + } + }, + { + "name": { + "zh_CN": "文字提示框" + }, + "icon": "tooltip", + "screenshot": "", + "snippetName": "TinyTooltip", + "schema": { + "componentName": "TinyTooltip", + "props": { + "content": "Top Left 提示文字", + "placement": "top-start", + "manual": true, + "modelValue": true + }, + "children": [ + { + "componentName": "span", + "children": [ + { + "componentName": "div", + "props": {} + } + ] + }, + { + "componentName": "Template", + "props": { + "slot": "content" + }, + "children": [ + { + "componentName": "span", + "children": [ + { + "componentName": "div", + "props": { + "placeholder": "提示内容" + } + } + ] + } + ] + } + ] + } + }, + { + "name": { + "zh_CN": "提示框" + }, + "icon": "popover", + "screenshot": "", + "snippetName": "TinyPopover", + "schema": { + "componentName": "TinyPopover", + "props": { + "width": 200, + "title": "弹框标题", + "trigger": "manual", + "modelValue": true + }, + "children": [ + { + "componentName": "Template", + "props": { + "slot": "reference" + }, + "children": [ + { + "componentName": "div", + "props": { + "placeholder": "触发源" + } + } + ] + }, + { + "componentName": "Template", + "props": { + "slot": "default" + }, + "children": [ + { + "componentName": "div", + "props": { + "placeholder": "提示内容" + } + } + ] + } + ] + } + }, + { + "name": { + "zh_CN": "分页" + }, + "icon": "pager", + "screenshot": "", + "snippetName": "TinyPager", + "schema": { + "componentName": "TinyPager", + "props": { + "layout": "total, sizes, prev, pager, next", + "total": 100, + "pageSize": 10, + "currentPage": 1 + } + } + }, + { + "name": { + "zh_CN": "面包屑" + }, + "icon": "breadcrumb", + "screenshot": "", + "snippetName": "TinyBreadcrumb", + "schema": { + "componentName": "TinyBreadcrumb", + "props": { + "options": [ + { + "to": "{ path: '/' }", + "label": "首页" + }, + { + "to": "{ path: '/breadcrumb' }", + "label": "产品" + }, + { + "replace": "true", + "label": "软件" + } + ] + } + } + } + ] + }, + { + "group": "general", + "children": [ + { + "name": { + "zh_CN": "Row" + }, + "icon": "row", + "screenshot": "", + "snippetName": "TinyRow", + "schema": { + "componentName": "TinyRow", + "props": {}, + "children": [ + { + "componentName": "TinyCol", + "props": { + "span": 3 + } + }, + { + "componentName": "TinyCol", + "props": { + "span": 3 + } + }, + { + "componentName": "TinyCol", + "props": { + "span": 3 + } + }, + { + "componentName": "TinyCol", + "props": { + "span": 3 + } + } + ] + } + }, + { + "name": { + "zh_CN": "Col" + }, + "icon": "col", + "screenshot": "", + "snippetName": "TinyCol", + "schema": { + "componentName": "TinyCol", + "props": { + "span": 12, + "style": { + "height": "30px", + "border": "1px solid #ccc" + } + } + } + }, + { + "name": { + "zh_CN": "按钮" + }, + "icon": "button", + "screenshot": "", + "snippetName": "TinyButton", + "schema": { + "componentName": "TinyButton", + "props": { + "text": "按钮文案" + } + } + }, + { + "name": { + "zh_CN": "按钮组" + }, + "icon": "buttons", + "snippetName": "TinyButtons", + "screenshot": "", + "schema": { + "componentName": "div", + "props": {}, + "children": [ + { + "componentName": "TinyButton", + "props": { + "text": "提交", + "type": "primary", + "style": { + "margin": "0 5px 0 5px" + } + } + }, + { + "componentName": "TinyButton", + "props": { + "text": "重置", + "style": { + "margin": "0 5px 0 5px" + } + } + }, + { + "componentName": "TinyButton", + "props": { + "text": "取消" + } + } + ] + }, + "configure": { + "isContainer": true + } + }, + { + "name": { + "zh_CN": "互斥按钮组" + }, + "icon": "buttons", + "snippetName": "TinyButtonGroup", + "screenshot": "", + "schema": { + "componentName": "TinyButtonGroup", + "props": { + "data": [ + { + "text": "Button1", + "value": "1" + }, + { + "text": "Button2", + "value": "2" + }, + { + "text": "Button3", + "value": "3" + } + ], + "modelValue": "1" + } + } + }, + { + "name": { + "zh_CN": "输入框" + }, + "icon": "input", + "screenshot": "", + "snippetName": "TinyInput", + "schema": { + "componentName": "TinyInput", + "props": { + "placeholder": "请输入", + "modelValue": "" + } + } + }, + { + "name": { + "zh_CN": "单选" + }, + "icon": "radio", + "screenshot": "", + "snippetName": "TinyRadio", + "schema": { + "componentName": "TinyRadio", + "props": { + "label": "1", + "text": "单选文本" + } + } + }, + { + "name": { + "zh_CN": "复选框" + }, + "icon": "checkbox", + "screenshot": "", + "snippetName": "TinyCheckbox", + "schema": { + "componentName": "TinyCheckbox", + "props": { + "text": "复选框文案" + } + } + } + ] + }, + { + "group": "navigation", + "children": [ + { + "name": { + "zh_CN": "搜索框" + }, + "icon": "search", + "screenshot": "", + "snippetName": "TinySearch", + "schema": { + "componentName": "TinySearch", + "props": { + "modelValue": "", + "placeholder": "输入关键词" + } + } + }, + { + "name": { + "zh_CN": "时间线" + }, + "icon": "timeline", + "screenshot": "", + "snippetName": "TinyTimeLine", + "schema": { + "componentName": "TinyTimeLine", + "props": { + "active": "2", + "data": [ + { + "name": "已下单" + }, + { + "name": "运输中" + }, + { + "name": "已签收" + } + ] + } + } + } + ] + } + ] + } + } +} diff --git a/mockServer/assets/uploads/.gitkeep b/mockServer/assets/uploads/.gitkeep new file mode 100644 index 000000000..d00491fd7 --- /dev/null +++ b/mockServer/assets/uploads/.gitkeep @@ -0,0 +1 @@ +1 diff --git a/mockServer/build/dev-server.js b/mockServer/build/dev-server.js new file mode 100644 index 000000000..f32a8a0b6 --- /dev/null +++ b/mockServer/build/dev-server.js @@ -0,0 +1,14 @@ +/** +* Copyright (c) 2023 - present TinyEngine Authors. +* Copyright (c) 2023 - present Huawei Cloud Computing Technologies Co., Ltd. +* +* Use of this source code is governed by an MIT-style license. +* +* THE OPEN SOURCE SOFTWARE IN THIS PRODUCT IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, +* BUT WITHOUT ANY WARRANTY, WITHOUT EVEN THE IMPLIED WARRANTY OF MERCHANTABILITY OR FITNESS FOR +* A PARTICULAR PURPOSE. SEE THE APPLICABLE LICENSES FOR MORE DETAILS. +* +*/ + +require('@babel/register') +require('../src/app') diff --git a/mockServer/config/config.js b/mockServer/config/config.js new file mode 100644 index 000000000..dcd70e9a1 --- /dev/null +++ b/mockServer/config/config.js @@ -0,0 +1,16 @@ +/** + * Copyright (c) 2023 - present TinyEngine Authors. + * Copyright (c) 2023 - present Huawei Cloud Computing Technologies Co., Ltd. + * + * Use of this source code is governed by an MIT-style license. + * + * THE OPEN SOURCE SOFTWARE IN THIS PRODUCT IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, + * BUT WITHOUT ANY WARRANTY, WITHOUT EVEN THE IMPLIED WARRANTY OF MERCHANTABILITY OR FITNESS FOR + * A PARTICULAR PURPOSE. SEE THE APPLICABLE LICENSES FOR MORE DETAILS. + * + */ + +module.exports = { + port: process.env.MOCK_PORT || 9090, + env: process.env.NODE_ENV || 'development' // Current mode +} diff --git a/mockServer/gulpfile.js b/mockServer/gulpfile.js new file mode 100644 index 000000000..c49d674db --- /dev/null +++ b/mockServer/gulpfile.js @@ -0,0 +1,109 @@ +/** +* Copyright (c) 2023 - present TinyEngine Authors. +* Copyright (c) 2023 - present Huawei Cloud Computing Technologies Co., Ltd. +* +* Use of this source code is governed by an MIT-style license. +* +* THE OPEN SOURCE SOFTWARE IN THIS PRODUCT IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, +* BUT WITHOUT ANY WARRANTY, WITHOUT EVEN THE IMPLIED WARRANTY OF MERCHANTABILITY OR FITNESS FOR +* A PARTICULAR PURPOSE. SEE THE APPLICABLE LICENSES FOR MORE DETAILS. +* +*/ + +const gulp = require('gulp') +const eslint = require('gulp-eslint') +const nodemon = require('gulp-nodemon') +const friendlyFormatter = require('eslint-friendly-formatter') + +let jsScript = 'node' +if (process.env.npm_config_argv !== undefined && process.env.npm_config_argv.indexOf('debug') > 0) { + jsScript = 'node debug' +} + +function lintOne(aims) { + return gulp + .src(aims) + .pipe(eslint({ configFile: './.eslintrc.js' })) + .pipe(eslint.format(friendlyFormatter)) + .pipe( + eslint.results((results) => { + // Called once for all ESLint results. + }) + ) +} + +gulp.task('ESlint', () => { + return gulp + .src(['src/**/*.js', '!node_modules/**']) + .pipe(eslint({ configFile: './.eslintrc.js' })) + .pipe(eslint.format(friendlyFormatter)) + .pipe(eslint.results((results) => {})) +}) + +gulp.task( + 'ESlint_nodemon', + gulp.series('ESlint', () => { + const stream = nodemon({ + script: 'build/dev-server.js', + execMap: { + js: jsScript + }, + tasks: function (changedFiles) { + lintOne(changedFiles) + return [] + }, + verbose: true, + ignore: ['build/*.js', 'dist/*.js', 'nodemon.json', '.git', 'node_modules/**/node_modules', 'gulpfile.js'], + env: { + NODE_ENV: 'development' + }, + ext: 'js json' + }) + + return stream + .on('restart', () => { + // 重启项目 + }) + .on('crash', () => { + // 重启工程:restart the server in 20 seconds:stream.emit('restart', 20) + }) + }) +) + +gulp.task('nodemon', () => { + return nodemon({ + script: 'build/dev-server.js', + execMap: { + js: jsScript + }, + verbose: true, + ignore: ['build/*.js', 'dist/*.js', 'nodemon.json', '.git', 'node_modules/**/node_modules', 'gulpfile.js'], + env: { + NODE_ENV: 'development' + }, + ext: 'js json' + }) +}) + +gulp.task('default', () => { + const stream = nodemon({ + script: 'build/dev-server.js', + execMap: { + js: jsScript + }, + verbose: true, + ignore: ['build/*.js', 'dist/*.js', 'nodemon.json', '.git', 'node_modules/**/node_modules', 'gulpfile.js'], + env: { + NODE_ENV: 'development' + }, + ext: 'js json' + }) + + return stream + .on('restart', () => { + // 重启项目 + }) + .on('crash', () => { + // 重启工程:restart the server in 20 seconds:stream.emit('restart', 20) + }) +}) diff --git a/mockServer/logs/out.log b/mockServer/logs/out.log new file mode 100644 index 000000000..9766475a4 --- /dev/null +++ b/mockServer/logs/out.log @@ -0,0 +1 @@ +ok diff --git a/mockServer/package.json b/mockServer/package.json new file mode 100644 index 000000000..7b51d4daf --- /dev/null +++ b/mockServer/package.json @@ -0,0 +1,69 @@ +{ + "name": "@opentiny/tiny-engine-mock", + "version": "1.0.3", + "publishConfig": { + "access": "public" + }, + "description": "mock服务", + "repository": { + "type": "git", + "url": "https://github.com/opentiny/tiny-engine", + "directory": "mockServer" + }, + "bugs": { + "url": "https://github.com/opentiny/tiny-engine/issues" + }, + "author": "OpenTiny Team", + "license": "MIT", + "homepage": "https://opentiny.design/tiny-engine", + "scripts": { + "start": "gulp nodemon", + "dev": "gulp", + "build": "babel src -d dist", + "production": "node dist/app.js", + "test": "jest", + "lint": "eslint --fix ." + }, + "dependencies": { + "@opentiny/tiny-engine-dsl-vue": "^1.0.3", + "@seald-io/nedb": "^4.0.2", + "fs-extra": "^11.1.1", + "glob": "^10.3.4", + "koa": "^2.11.0", + "koa-body": "^4.1.1", + "koa-compose": "^4.1.0", + "koa-jwt": "^3.6.0", + "koa-router": "^8.0.8", + "koa-static2": "^0.1.8" + }, + "devDependencies": { + "@babel/cli": "^7.8.4", + "@babel/core": "^7.9.0", + "@babel/plugin-external-helpers": "^7.8.3", + "@babel/plugin-transform-runtime": "^7.9.0", + "@babel/preset-env": "^7.9.5", + "@babel/register": "^7.9.0", + "@babel/runtime": "^7.9.2", + "babel-core": "^7.0.0-bridge.0", + "babel-eslint": "^10.1.0", + "babel-jest": "^25.3.0", + "eslint": "^6.8.0", + "eslint-config-standard": "^14.1.1", + "eslint-friendly-formatter": "^4.0.1", + "eslint-plugin-html": "^6.0.1", + "eslint-plugin-import": "^2.20.2", + "eslint-plugin-jest": "^23.8.2", + "eslint-plugin-node": "^11.1.0", + "eslint-plugin-promise": "^4.2.1", + "eslint-plugin-standard": "^4.0.1", + "gulp": "^4.0.2", + "gulp-eslint": "^6.0.0", + "gulp-nodemon": "^2.5.0", + "jest": "^25.3.0", + "koa-logger": "^3.2.1" + }, + "engines": { + "node": ">= 7.8.0", + "npm": ">= 4.2.0" + } +} diff --git a/mockServer/pm2.js b/mockServer/pm2.js new file mode 100644 index 000000000..b4de90cfc --- /dev/null +++ b/mockServer/pm2.js @@ -0,0 +1,31 @@ +/** +* Copyright (c) 2023 - present TinyEngine Authors. +* Copyright (c) 2023 - present Huawei Cloud Computing Technologies Co., Ltd. +* +* Use of this source code is governed by an MIT-style license. +* +* THE OPEN SOURCE SOFTWARE IN THIS PRODUCT IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, +* BUT WITHOUT ANY WARRANTY, WITHOUT EVEN THE IMPLIED WARRANTY OF MERCHANTABILITY OR FITNESS FOR +* A PARTICULAR PURPOSE. SEE THE APPLICABLE LICENSES FOR MORE DETAILS. +* +*/ + +module.exports = { + apps: [ + { + name: 'RESRful API Server', + script: './dist/app.js', + watch: false, // 默认关闭watch 可替换为 ['src'] + ignoreWatch: ['node_modules', 'build', 'logs'], + outFile: '/logs/out.log', // 日志输出 + errorFile: '/logs/error.log', // 错误日志 + maxMemoryRestart: '2G', // 超过多大内存自动重启,仅防止内存泄露有意义,需要根据自己的业务设置 + env: { + NODE_ENV: 'production' + }, + execMode: 'cluster', // 开启多线程模式,用于负载均衡 + instances: 'max', // 启用多少个实例,可用于负载均衡 + autorestart: true // 程序崩溃后自动重启 + } + ] +} diff --git a/mockServer/src/app.js b/mockServer/src/app.js new file mode 100644 index 000000000..26c5b341c --- /dev/null +++ b/mockServer/src/app.js @@ -0,0 +1,61 @@ +/** +* Copyright (c) 2023 - present TinyEngine Authors. +* Copyright (c) 2023 - present Huawei Cloud Computing Technologies Co., Ltd. +* +* Use of this source code is governed by an MIT-style license. +* +* THE OPEN SOURCE SOFTWARE IN THIS PRODUCT IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, +* BUT WITHOUT ANY WARRANTY, WITHOUT EVEN THE IMPLIED WARRANTY OF MERCHANTABILITY OR FITNESS FOR +* A PARTICULAR PURPOSE. SEE THE APPLICABLE LICENSES FOR MORE DETAILS. +* +*/ + +import Koa2 from 'koa' +import KoaBody from 'koa-body' +import KoaStatic from 'koa-static2' +import path from 'path' +import { env, port } from '../config/config' +import ErrorRoutesCatch from './middleware/ErrorRoutesCatch' +import ErrorRoutes from './routes/error-routes' +import MainRoutes from './routes/main-routes' + +const app = new Koa2() +app + .use((ctx, next) => { + ctx.set('Access-Control-Allow-Origin', '*') + ctx.set('Access-Control-Allow-Headers', 'Origin, X-Requested-With, Content-Type, Accept') + ctx.set('Access-Control-Allow-Methods', 'PUT, POST, GET, DELETE, OPTIONS') + ctx.set('Access-Control-Allow-Credentials', true) // 允许带上 cookie + return next() + }) + .use(ErrorRoutesCatch()) + .use(KoaStatic('assets', path.resolve(__dirname, '../assets'))) // Static resource + .use( + KoaBody({ + multipart: true, + parsedMethods: ['POST', 'PUT', 'PATCH', 'GET', 'HEAD', 'DELETE'], // parse GET, HEAD, DELETE requests + formidable: { + uploadDir: path.join(__dirname, '../assets/uploads/tmp') + }, + jsonLimit: '50mb', + formLimit: '50mb', + textLimit: '50mb' + }) + ) // Processing request + .use(MainRoutes.routes()) + .use(MainRoutes.allowedMethods()) + .use(ErrorRoutes()) + +if (env === 'development') { + // logger + app.use((ctx, next) => { + const start = new Date() + return next().then(() => { + const ms = new Date() - start + }) + }) +} + +app.listen(port) + +export default app diff --git a/mockServer/src/database/blockCategories.db b/mockServer/src/database/blockCategories.db new file mode 100644 index 000000000..85744f5a5 --- /dev/null +++ b/mockServer/src/database/blockCategories.db @@ -0,0 +1,3 @@ +{"id":"L0fyFYECrNiRZMiX","app":{"id":918,"name":"portal-app","app_website":null,"platform":{"id":897,"name":"portal-platform"},"obs_url":"","created_by":null,"updated_by":null,"created_at":"2022-06-08T07:19:01.000Z","updated_at":"2023-09-04T08:55:40.000Z","state":null,"published":false,"createdBy":86,"updatedBy":564,"tenant":1,"home_page":"NTJ4MjvqoVj8OVsc","css":null,"config":{},"git_group":"","project_name":"","constants":null,"data_handler":{"type":"JSFunction","value":"function dataHanlder(res){\n return res;\n}"},"description":"demo应用","latest":22,"platform_history":null,"editor_url":"","branch":"develop","visit_url":null,"is_demo":null,"image_url":"","is_default":true,"template_type":null,"set_template_time":null,"set_template_by":null,"set_default_by":169,"framework":"Vue","global_state":[],"default_lang":null,"extend_config":{"business":{"serviceName":"","endpointName":"cce","endpointId":"ee","serviceId":"ee","router":"ee"},"env":{"alpha":{"regions":[{"name":"","baseUrl":"","isDefault":false}],"isDefault":true}},"type":"console"},"assets_url":"","data_hash":"ae128e37f6bc378f1b9c21d75bd05551","can_associate":true,"data_source_global":{"dataHandler":{"type":"JSFunction","value":"function dataHanlder(res){\n return res;\n}"}}},"name":"我的分类","desc":"","blocks":["ALvDb0JD8atzd3nA"],"category_id":"qukuaifenlei","_id":"L0fyFYECrNiRZMiX"} +{"$$indexCreated":{"fieldName":"name","unique":true,"sparse":false}} +{"$$indexCreated":{"fieldName":"name","unique":true}} diff --git a/mockServer/src/database/blockGroups.db b/mockServer/src/database/blockGroups.db new file mode 100644 index 000000000..fe904aae8 --- /dev/null +++ b/mockServer/src/database/blockGroups.db @@ -0,0 +1,3 @@ +{"id":"b57MCCORYPGjgL23","app":{"id":918,"name":"portal-app","app_website":null,"platform":{"id":897,"name":"portal-platform"},"obs_url":"","created_by":null,"updated_by":null,"created_at":"2022-06-08T07:19:01.000Z","updated_at":"2023-09-04T08:55:40.000Z","state":null,"published":false,"createdBy":86,"updatedBy":564,"tenant":1,"home_page":"NTJ4MjvqoVj8OVsc","css":null,"config":{},"git_group":"","project_name":"","constants":null,"data_handler":{"type":"JSFunction","value":"function dataHanlder(res){\n return res;\n}"},"description":"demo应用","latest":22,"platform_history":null,"editor_url":"","branch":"develop","visit_url":null,"is_demo":null,"image_url":"","is_default":true,"template_type":null,"set_template_time":null,"set_template_by":null,"set_default_by":169,"framework":"Vue","global_state":[],"default_lang":null,"extend_config":{"business":{"serviceName":"","endpointName":"cce","endpointId":"ee","serviceId":"ee","router":"ee"},"env":{"alpha":{"regions":[{"name":"","baseUrl":"","isDefault":false}],"isDefault":true}},"type":"console"},"assets_url":"","data_hash":"ae128e37f6bc378f1b9c21d75bd05551","can_associate":true,"data_source_global":{"dataHandler":{"type":"JSFunction","value":"function dataHanlder(res){\n return res;\n}"}}},"name":"我的区块","desc":"","blocks":["ALvDb0JD8atzd3nA"],"_id":"b57MCCORYPGjgL23"} +{"$$indexCreated":{"fieldName":"name","unique":true,"sparse":false}} +{"$$indexCreated":{"fieldName":"name","unique":true}} diff --git a/mockServer/src/database/blocks.db b/mockServer/src/database/blocks.db new file mode 100644 index 000000000..387c640b2 --- /dev/null +++ b/mockServer/src/database/blocks.db @@ -0,0 +1,4 @@ +{"id":"ALvDb0JD8atzd3nA","label":"PortalHome","name_cn":null,"framework":"Vue","content":{"state":{"logoUrl":"","loginImgUrl":""},"componentName":"Block","css":".home-content {\r\n display: flex;\r\n flex-direction: column;\r\n justify-content: center;\r\n align-items: center;\r\n text-align: center;\r\n height: calc(100vh - 262px);\r\n \r\n}\r\n.home-content .btn {\r\n margin-top: 24px;\r\n \r\n }\r\n .home-content .btn button {\r\n border: none;\r\n border-radius: 30px;\r\n background: #5e7ce0;\r\n \r\n font-size: 14px;\r\n color: #fff;\r\n \r\n cursor: pointer;\r\n }\r\n\r\n .home-content .text {\r\n font-size: 18px;\r\n }\r\n\r\n .home-content .account {\r\n margin-top: 16px;\r\n \r\n \r\n }\r\n\r\n .home-content .account .sub-text {\r\n color: #575d6c;\r\n }\r\n .home-content .account .login {\r\n color: #1890ff;\r\n cursor: pointer;\r\n }\r\n .home-content .logo img{\r\n border-radius: 50%;\r\n overflow: hidden;\r\n }","props":{},"children":[{"componentName":"div","props":{"className":"home","style":"height: 100vh; display: flex;"},"id":"357534ab","children":[{"componentName":"TinyRow","props":{"align":"middle","flex":true,"style":""},"children":[{"componentName":"TinyCol","props":{"span":6,"style":"text-align: center; display: flex; justify-content: center;"},"id":"f01b66ea","children":[{"componentName":"div","props":{"style":"width: 90%; height: 50%;"},"id":"8197d016","children":[{"componentName":"Img","props":{"style":"width: 100%; height: 100%;","src":{"type":"JSExpression","value":"this.state.loginImgUrl"}},"id":"471e30f3"}]}]},{"componentName":"TinyCol","props":{"span":"6","style":"text-align: center;"},"id":"781d5b46","children":[{"componentName":"div","props":{"className":"home-content","style":"font-size: 14px;"},"id":"08638b8a","children":[{"componentName":"div","props":{"className":"text"},"id":"18712ee2","children":[{"componentName":"div","props":{"style":"font-size: 16px;"},"id":"07e6794c","children":[{"componentName":"div","props":{"className":"logo"},"id":"07cad264","children":[{"componentName":"Img","props":{"style":"width: 105px; height: 105px; border-radius: 100px;","src":{"type":"JSExpression","value":"this.state.logoUrl"}},"id":"f4489e27"}]},{"componentName":"Text","props":{"text":"TinyLowCode 低代码平台","style":"display: block; font-size: 28px; margin-top: 12px; margin-bottom: 12px; font-weight: bold;","ref":"","className":"title"},"id":"e82108ce"},{"componentName":"Text","props":{"text":"致力于通过友好的用户交互提升业务的开发效率","style":"display: block; margin-bottom: 12px;"},"id":"65a2f1ad"},{"componentName":"Text","props":{"text":"欢迎一起来解锁~~","style":"margin-top: 12px;"},"id":"bb879abb"}]},{"componentName":"div","props":{"className":"btn"},"id":"44b2bcbd","children":[{"componentName":"TinyButton","props":{"text":"立即体验","round":true,"type":"primary","style":"margin-top: 40px;"},"id":"9580c5e7"},{"componentName":"div","props":{"className":"account"},"id":"6a8ffa3e","children":[{"componentName":"div","props":{"style":"font-size: 14px; margin-top: 4px;"},"id":"bfc6eb6c","children":[{"componentName":"Text","props":{"text":"已有团队?","style":"color: #777777;"},"id":"3d993264"},{"componentName":"Text","props":{"text":"立即进入","style":"color: #5e7ce0;","onClick":{"type":"JSExpression","value":"this.handleClick(event)"}},"id":"21390118"}]}]}]}]}]}]}],"id":"4545fea2"}]}],"methods":{"handleClick":{"type":"JSFunction","value":"function (event) {this.emit('goto-home', event)\n}"}},"fileName":"PortalHome","meta":{"id":1722,"parentId":"0","group":"staticPages","title":null,"occupier":null,"isHome":false,"description":"","router":"/","rootElement":"div","creator":"开发者","gmt_create":"2022-06-08 03:25:51","gmt_modified":"2022-06-09 05:19:09"},"id":1722,"schema":{"properties":[{"label":{"zh_CN":"基础信息"},"description":{"zh_CN":"基础信息"},"collapse":{"number":6,"text":{"zh_CN":"显示更多"}},"content":[]}],"events":{"onGotoHome":{"label":{"zh_CN":"点击立即进入触发方法"},"description":{"zh_CN":"点击立即进入触发方法"},"type":"event","functionInfo":{"params":[],"returns":{}},"defaultValue":"","linked":{"id":"21390118","componentName":"Text","event":"onClick"}}},"slots":{}},"dataSource":{},"i18n":{}},"description":null,"path":"common/components/home","screenshot":"","created_app":null,"tags":"","categories":[],"occupier":null,"isDefault":null,"isOfficial":true,"created_at":"2022-06-13T07:56:51.000Z","updated_at":"2023-01-13T08:12:51.000Z","assets":{"material":[],"scripts":["http://localhost:9090/assets/js/989web-components.es.js","http://localhost:9090/assets/js/989web-components.umd.js"],"styles":[]},"createdBy":86,"current_history":1655,"public":1,"tiny_reserved":false,"author":null,"content_blocks":null,"current_version":"x","is_published":true,"_id":"ALvDb0JD8atzd3nA"} +{"id":"V85zd9sWEya25Kxh","label":"PortalBlock","name_cn":null,"framework":"Vue","content":{"state":{},"methods":{},"componentName":"Block","fileName":"PortalBlock","css":"","props":{},"children":[{"componentName":"div","props":{"style":"font-size: 18px; height: 40px; border-bottom: 1px solid rgb(223, 225, 230); margin-top: 20px;"},"id":"d38cea57","children":[{"componentName":"Icon","props":{"name":"IconChevronLeft"},"id":"86c6e6b0"},{"componentName":"Text","props":{"text":"编辑物料资产包 | ","style":"margin-left: 10px; font-weight: bold;"},"id":"38d9fbc8"},{"componentName":"Text","props":{"text":{"type":"JSExpression","value":"this.props.blockName"},"style":"margin-left: 10px; font-weight: bold;"},"id":"6cd76396"}]}],"schema":{"properties":[{"label":{"zh_CN":"基础信息"},"description":{"zh_CN":"基础信息"},"collapse":{"number":6,"text":{"zh_CN":"显示更多"}},"content":[{"property":"blockName","type":"String","defaultValue":"MT0526-React 1.0","label":{"text":{"zh_CN":"区块名称"}},"cols":12,"rules":[],"handle":{"getter":"","setter":""},"hidden":false,"required":true,"readOnly":false,"disabled":false,"widget":{"component":"MetaInput","props":{"modelValue":"MT0526-React 1.0"}}}]}],"events":{},"slots":{}},"dataSource":{}},"description":null,"path":"portal","screenshot":"","created_app":null,"tags":null,"categories":[],"occupier":{"id":86,"username":"开发者","resetPasswordToken":"developer"},"isDefault":null,"isOfficial":null,"created_at":"2022-06-28T08:59:54.000Z","updated_at":"2023-01-13T08:20:09.000Z","assets":{"material":[],"scripts":["http://localhost:9090/assets/js/1005web-components.es.js","http://localhost:9090/assets/js/1005web-components.umd.js"],"styles":[]},"createdBy":{"id":86,"username":"开发者","resetPasswordToken":"developer"},"current_history":1665,"public":1,"tiny_reserved":false,"author":null,"content_blocks":null,"public_scope_tenants":[],"histories_length":1,"is_published":true,"_id":"V85zd9sWEya25Kxh"} +{"$$indexCreated":{"fieldName":"label","unique":true,"sparse":false}} +{"$$indexCreated":{"fieldName":"label","unique":true}} diff --git a/mockServer/src/database/defaultData/default.db b/mockServer/src/database/defaultData/default.db new file mode 100644 index 000000000..e9fbf4960 --- /dev/null +++ b/mockServer/src/database/defaultData/default.db @@ -0,0 +1,4 @@ +{"name":"createVm","id":"NTJ4MjvqoVj8OVsc","app":"918","route":"createVm","page_content":{"state":{"dataDisk":[1,2,3]},"methods":{},"componentName":"Page","css":"body {\r\n background-color:#eef0f5 ;\r\n margin-bottom: 80px;\r\n}","props":{},"children":[{"componentName":"div","props":{"style":"padding-bottom: 10px; padding-top: 10px;"},"id":"2b2cabf0","children":[{"componentName":"TinyTimeLine","props":{"active":"2","data":[{"name":"基础配置"},{"name":"网络配置"},{"name":"高级配置"},{"name":"确认配置"}],"horizontal":true,"style":"border-radius: 0px;"},"id":"dd764b17"}]},{"componentName":"div","props":{"style":"border-width: 1px; border-style: solid; border-radius: 4px; border-color: #fff; padding-top: 10px; padding-bottom: 10px; padding-left: 10px; padding-right: 10px; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px; background-color: #fff; margin-bottom: 10px;"},"id":"30c94cc8","children":[{"componentName":"TinyForm","props":{"labelWidth":"80px","labelPosition":"top","inline":false,"label-position":"left ","label-width":"150px","style":"border-radius: 0px;"},"children":[{"componentName":"TinyFormItem","props":{"label":"计费模式"},"children":[{"componentName":"TinyButtonGroup","props":{"data":[{"text":"包年/包月","value":"1"},{"text":"按需计费","value":"2"}],"modelValue":"1"},"id":"a8d84361"}],"id":"9f39f3e7"},{"componentName":"TinyFormItem","props":{"label":"区域"},"children":[{"componentName":"TinyButtonGroup","props":{"data":[{"text":"乌兰察布二零一","value":"1"}],"modelValue":"1","style":"border-radius: 0px; margin-right: 10px;"},"id":"c97ccd99"},{"componentName":"Text","props":{"text":"温馨提示:页面左上角切换区域","style":"background-color: [object Event]; color: #8a8e99; font-size: 12px;"},"id":"20923497"},{"componentName":"Text","props":{"text":"不同区域的云服务产品之间内网互不相通;请就近选择靠近您业务的区域,可减少网络时延,提高访问速度","style":"display: block; color: #8a8e99; border-radius: 0px; font-size: 12px;"},"id":"54780a26"}],"id":"4966384d"},{"componentName":"TinyFormItem","props":{"label":"可用区","style":"border-radius: 0px;"},"children":[{"componentName":"TinyButtonGroup","props":{"data":[{"text":"可用区1","value":"1"},{"text":"可用区2","value":"2"},{"text":"可用区3","value":"3"}],"modelValue":"1"},"id":"6184481b"}],"id":"690837bf"}],"id":"b6a425d4"}]},{"componentName":"div","props":{"style":"border-width: 1px; border-style: solid; border-radius: 4px; border-color: #fff; padding-top: 10px; padding-bottom: 10px; padding-left: 10px; padding-right: 10px; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px; background-color: #fff; margin-bottom: 10px;"},"children":[{"componentName":"TinyForm","props":{"labelWidth":"80px","labelPosition":"top","inline":false,"label-position":"left ","label-width":"150px","style":"border-radius: 0px;"},"children":[{"componentName":"TinyFormItem","props":{"label":"CPU架构"},"children":[{"componentName":"TinyButtonGroup","props":{"data":[{"text":"x86计算","value":"1"},{"text":"鲲鹏计算","value":"2"}],"modelValue":"1"},"id":"7d33ced7"}],"id":"05ed5a79"},{"componentName":"TinyFormItem","props":{"label":"区域"},"children":[{"componentName":"div","props":{"style":"display: flex; justify-content: flex-start; align-items: center;"},"id":"606edf78","children":[{"componentName":"div","props":{"style":"display: flex; align-items: center; margin-right: 10px;"},"id":"f3f98246","children":[{"componentName":"Text","props":{"text":"vCPUs","style":"width: 80px;"},"id":"c287437e"},{"componentName":"TinySelect","props":{"modelValue":"","placeholder":"请选择","options":[{"value":"1","label":"黄金糕"},{"value":"2","label":"双皮奶"}]},"id":"4c43286b"}]},{"componentName":"div","props":{"style":"display: flex; align-items: center; margin-right: 10px;"},"children":[{"componentName":"Text","props":{"text":"内存","style":"width: 80px; border-radius: 0px;"},"id":"38b8fa1f"},{"componentName":"TinySelect","props":{"modelValue":"","placeholder":"请选择","options":[{"value":"1","label":"黄金糕"},{"value":"2","label":"双皮奶"}]},"id":"cd33328e"}],"id":"2b2c678f"},{"componentName":"div","props":{"style":"display: flex; align-items: center;"},"children":[{"componentName":"Text","props":{"text":"规格名称","style":"width: 80px;"},"id":"d3eb6352"},{"componentName":"TinySearch","props":{"modelValue":"","placeholder":"输入关键词"},"id":"21cb9282"}],"id":"b8e0f35c"}]},{"componentName":"div","props":{"style":"border-radius: 0px;"},"id":"5000c83e","children":[{"componentName":"TinyButtonGroup","props":{"data":[{"text":"通用计算型","value":"1"},{"text":"通用计算增强型","value":"2"},{"text":"内存优化型","value":"3"},{"text":"内存优化型","value":"4"},{"text":"磁盘增强型","value":"5"},{"text":"超高I/O型","value":"6"},{"text":"GPU加速型","value":"7"}],"modelValue":"1","style":"border-radius: 0px; margin-top: 12px;"},"id":"b8724703"},{"componentName":"TinyGrid","props":{"editConfig":{"trigger":"click","mode":"cell","showStatus":true},"columns":[{"type":"radio","width":60},{"field":"employees","title":"规格名称"},{"field":"created_date","title":"vCPUs | 内存(GiB)","sortable":true},{"field":"city","title":"CPU","sortable":true},{"title":"基准 / 最大带宽\t","sortable":true},{"title":"内网收发包","sortable":true}],"data":[{"id":"1","name":"GFD科技有限公司","city":"福州","employees":800,"created_date":"2014-04-30 00:56:00","boole":false},{"id":"2","name":"WWW科技有限公司","city":"深圳","employees":300,"created_date":"2016-07-08 12:36:22","boole":true}],"style":"margin-top: 12px; border-radius: 0px;","auto-resize":true},"id":"77701c25"},{"componentName":"div","props":{"style":"margin-top: 12px; border-radius: 0px;"},"id":"3339838b","children":[{"componentName":"Text","props":{"text":"当前规格","style":"width: 150px; display: inline-block;"},"id":"203b012b"},{"componentName":"Text","props":{"text":"通用计算型 | Si2.large.2 | 2vCPUs | 4 GiB","style":"font-weight: 700;"},"id":"87723f52"}]}]}],"id":"657fb2fc"}],"id":"d19b15cf"}],"id":"9991228b"},{"componentName":"div","props":{"style":"border-width: 1px; border-style: solid; border-radius: 4px; border-color: #fff; padding-top: 10px; padding-bottom: 10px; padding-left: 10px; padding-right: 10px; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px; background-color: #fff; margin-bottom: 10px;"},"children":[{"componentName":"TinyForm","props":{"labelWidth":"80px","labelPosition":"top","inline":false,"label-position":"left ","label-width":"150px","style":"border-radius: 0px;"},"children":[{"componentName":"TinyFormItem","props":{"label":"镜像","style":"border-radius: 0px;"},"children":[{"componentName":"TinyButtonGroup","props":{"data":[{"text":"公共镜像","value":"1"},{"text":"私有镜像","value":"2"},{"text":"共享镜像","value":"3"}],"modelValue":"1"},"id":"922b14cb"},{"componentName":"div","props":{"style":"display: flex; margin-top: 12px; border-radius: 0px;"},"id":"6b679524","children":[{"componentName":"TinySelect","props":{"modelValue":"","placeholder":"请选择","options":[{"value":"1","label":"黄金糕"},{"value":"2","label":"双皮奶"}],"style":"width: 170px; margin-right: 10px;"},"id":"4851fff7"},{"componentName":"TinySelect","props":{"modelValue":"","placeholder":"请选择","options":[{"value":"1","label":"黄金糕"},{"value":"2","label":"双皮奶"}],"style":"width: 340px;"},"id":"a7183eb7"}]},{"componentName":"div","props":{"style":"margin-top: 12px;"},"id":"57aee314","children":[{"componentName":"Text","props":{"text":"请注意操作系统的语言类型。","style":"color: #e37d29;"},"id":"56d36c27"}]}],"id":"e3b02436"}],"id":"59aebf2b"}],"id":"87ff7b99"},{"componentName":"div","props":{"style":"border-width: 1px; border-style: solid; border-radius: 4px; border-color: #fff; padding-top: 10px; padding-bottom: 10px; padding-left: 10px; padding-right: 10px; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px; background-color: #fff; margin-bottom: 10px;"},"children":[{"componentName":"TinyForm","props":{"labelWidth":"80px","labelPosition":"top","inline":false,"label-position":"left ","label-width":"150px","style":"border-radius: 0px;"},"children":[{"componentName":"TinyFormItem","props":{"label":"系统盘","style":"border-radius: 0px;"},"children":[{"componentName":"div","props":{"style":"display: flex;"},"id":"cddba5b8","children":[{"componentName":"TinySelect","props":{"modelValue":"","placeholder":"请选择","options":[{"value":"1","label":"黄金糕"},{"value":"2","label":"双皮奶"}],"style":"width: 200px; margin-right: 10px;"},"id":"a97fbe15"},{"componentName":"TinyInput","props":{"placeholder":"请输入","modelValue":"","style":"width: 120px; margin-right: 10px;"},"id":"1cde4c0f"},{"componentName":"Text","props":{"text":"GiB \nIOPS上限240,IOPS突发上限5,000","style":"color: #575d6c; font-size: 12px;"},"id":"2815d82d"}]}],"id":"50239a3a"}],"id":"e8582986"},{"componentName":"TinyForm","props":{"labelWidth":"80px","labelPosition":"top","inline":false,"label-position":"left ","label-width":"150px","style":"border-radius: 0px;"},"children":[{"componentName":"TinyFormItem","props":{"label":"数据盘","style":"border-radius: 0px;"},"children":[{"componentName":"div","props":{"style":"margin-top: 12px; display: flex;"},"id":"728c9825","children":[{"componentName":"Icon","props":{"style":"margin-right: 10px; width: 16px; height: 16px;","name":"IconPanelMini"},"id":"fded6930"},{"componentName":"TinySelect","props":{"modelValue":"","placeholder":"请选择","options":[{"value":"1","label":"黄金糕"},{"value":"2","label":"双皮奶"}],"style":"width: 200px; margin-right: 10px;"},"id":"62734e3f"},{"componentName":"TinyInput","props":{"placeholder":"请输入","modelValue":"","style":"width: 120px; margin-right: 10px;"},"id":"667c7926"},{"componentName":"Text","props":{"text":"GiB \nIOPS上限600,IOPS突发上限5,000","style":"color: #575d6c; font-size: 12px; margin-right: 10px;"},"id":"e7bc36d6"},{"componentName":"TinyInput","props":{"placeholder":"请输入","modelValue":"","style":"width: 120px;"},"id":"1bd56dc0"}],"loop":{"type":"JSExpression","value":"this.state.dataDisk"}},{"componentName":"div","props":{"style":"display: flex; margin-top: 12px; border-radius: 0px;"},"children":[{"componentName":"Icon","props":{"name":"IconPlus","style":"width: 16px; height: 16px; margin-right: 10px;"},"id":"65c89f2b"},{"componentName":"Text","props":{"text":"增加一块数据盘","style":"font-size: 12px; border-radius: 0px; margin-right: 10px;"},"id":"cb344071"},{"componentName":"Text","props":{"text":"您还可以挂载 21 块磁盘(云硬盘)","style":"color: #8a8e99; font-size: 12px;"},"id":"80eea996"}],"id":"e9e530ab"}],"id":"078e03ef"}],"id":"ccef886e"}],"id":"0fb7bd74"},{"componentName":"div","props":{"style":"border-width: 1px; border-style: solid; border-color: #ffffff; padding-top: 10px; padding-left: 10px; padding-right: 10px; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px; background-color: #fff; position: fixed; inset: auto 0% 0% 0%; height: 80px; line-height: 80px; border-radius: 0px;"},"children":[{"componentName":"TinyForm","props":{"labelWidth":"80px","labelPosition":"top","inline":false,"label-position":"left ","label-width":"150px","style":"border-radius: 0px;"},"children":[],"id":"21ed4475"},{"componentName":"TinyRow","props":{"style":"border-radius: 0px; height: 100%;"},"children":[{"componentName":"TinyCol","props":{"span":"8"},"id":"b9d051a5","children":[{"componentName":"TinyRow","props":{"style":"border-radius: 0px;"},"children":[{"componentName":"TinyCol","props":{"span":"5","style":"display: flex;"},"id":"02352776","children":[{"componentName":"Text","props":{"text":"购买量","style":"margin-right: 10px;"},"id":"0cd9ed5c"},{"componentName":"TinyInput","props":{"placeholder":"请输入","modelValue":"","style":"width: 120px; margin-right: 10px;"},"id":"2f9cf442"},{"componentName":"Text","props":{"text":"台"},"id":"facd4481"}]},{"componentName":"TinyCol","props":{"span":"7"},"id":"82b6c659","children":[{"componentName":"div","props":{},"id":"9cd65874","children":[{"componentName":"Text","props":{"text":"配置费用","style":"font-size: 12px;"},"id":"b5a0a0da"},{"componentName":"Text","props":{"text":"¥1.5776","style":"padding-left: 10px; padding-right: 10px; color: #de504e;"},"id":"d9464214"},{"componentName":"Text","props":{"text":"/小时","style":"font-size: 12px;"},"id":"af7cc5e6"}]},{"componentName":"div","props":{},"id":"89063830","children":[{"componentName":"Text","props":{"text":"参考价格,具体扣费请以账单为准。","style":"font-size: 12px; border-radius: 0px;"},"id":"d8995fbc"},{"componentName":"Text","props":{"text":"了解计费详情","style":"font-size: 12px; color: #344899;"},"id":"b383c3e2"}]}]}],"id":"94fc0e43"}]},{"componentName":"TinyCol","props":{"span":"4","style":"display: flex; flex-direction: row-reverse; border-radius: 0px; height: 100%; justify-content: flex-start; align-items: center;"},"id":"10b73009","children":[{"componentName":"TinyButton","props":{"text":"下一步: 网络配置","type":"danger","style":"max-width: unset;"},"id":"0b584011"}]}],"id":"d414a473"}],"id":"e8ec029b"}],"fileName":"createVm"},"tenant":1,"isBody":false,"parentId":"0","group":"staticPages","depth":0,"isPage":true,"isDefault":false,"occupier":{"id":86,"username":"开发者","email":"developer@lowcode.com","resetPasswordToken":"developer","confirmationToken":"dfb2c162-351f-4f44-ad5f-8998","is_admin":true},"isHome":false,"_id":"NTJ4MjvqoVj8OVsc"} +{"name":"ComponentsSetting","id":"fh7U0xYetFGA5Ieu","app":"918","route":"componentsSetting","page_content":{"state":{"components":[{"name":"表单","text":"由按钮、输入框、选择器、单选框、多选框等控件组成..."},{"name":"按钮","text":"常用的操作按钮,提供包括默认按钮、图标按钮、图片按钮..."},{"name":"按钮","text":"常用的操作按钮,提供包括默认按钮、图标按钮、图片按钮..."},{"name":"按钮","text":"常用的操作按钮,提供包括默认按钮、图标按钮、图片按钮..."},{"name":"按钮","text":"常用的操作按钮,提供包括默认按钮、图标按钮、图片按钮..."},{"name":"按钮","text":"常用的操作按钮,提供包括默认按钮、图标按钮、图片按钮..."},{"name":"按钮","text":"常用的操作按钮,提供包括默认按钮、图标按钮、图片按钮..."},{"name":"按钮","text":"常用的操作按钮,提供包括默认按钮、图标按钮、图片按钮..."},{"name":"按钮","text":"常用的操作按钮,提供包括默认按钮、图标按钮、图片按钮..."},{"name":"按钮","text":"常用的操作按钮,提供包括默认按钮、图标按钮、图片按钮..."},{"name":"按钮","text":"常用的操作按钮,提供包括默认按钮、图标按钮、图片按钮..."},{"name":"按钮","text":"常用的操作按钮,提供包括默认按钮、图标按钮、图片按钮..."},{"name":"按钮","text":"常用的操作按钮,提供包括默认按钮、图标按钮、图片按钮..."},{"name":"按钮","text":"常用的操作按钮,提供包括默认按钮、图标按钮、图片按钮..."},{"name":"按钮","text":"常用的操作按钮,提供包括默认按钮、图标按钮、图片按钮..."},{"name":"按钮","text":"常用的操作按钮,提供包括默认按钮、图标按钮、图片按钮..."}],"pageConfig":{"component":{"type":"JSResource","value":"this.utils.Pager"},"attrs":{"currentPage":1,"pageSize":50,"pageSizes":[10,20,50],"total":0,"layout":"sizes,total, prev, pager, next, jumper"}},"componentsTotal":0,"renderf5956ed2":[{"label":"按更新时间","value":"updata","_RID":"row_6"},{"label":"按创建时间","value":"create"}],"renderb52aeac9":[{"framework":"","materials":"","name":"表单","description":"由按钮、输入框、选择器、单选框、多选框等控件组成,用以收集、校验、提交数据","id":"021fd6b6","_RID":"row_1"},{"framework":"","materials":"","name":"按钮","description":"常用的操作按钮,提供包括默认按钮、图标按钮、图片按钮、下拉按钮等类型","id":"84d239bb","_RID":"row_2"},{"framework":"","materials":"","name":"表单项","description":"Form 组件下的 FormItem 配置","id":"490f8a00","_RID":"row_3"},{"framework":"","materials":"","name":"开关","description":"关闭或打开","id":"c259b8b3","_RID":"row_4"},{"framework":"","materials":"","name":"互斥按钮组","description":"以按钮组的方式出现,常用于多项类似操作","id":"083ed9c7","_RID":"row_5"},{"framework":"","materials":"","name":"提示框","description":"Popover可通过对一个触发源操作触发弹出框,支持自定义弹出内容,延迟触发和渐变动画","id":"09136cea","_RID":"row_6"},{"framework":"","materials":"","name":"文字提示框","description":"动态显示提示信息,一般通过鼠标事件进行响应;提供 warning、error、info、success 四种类型显示不同类别的信","id":"a63b57d5","_RID":"row_7"},{"framework":"","materials":"","name":"树","description":"可进行展示有父子层级的数据,支持选择,异步加载等功能。但不推荐用它来展示菜单,展示菜单推荐使用树菜单","id":"a0f6e8a3","_RID":"row_8"},{"framework":"","materials":"","name":"分页","description":"当数据量过多时,使用分页分解数据,常用于 Grid 和 Repeater 组件","id":"d1aa18fc","_RID":"row_9"},{"framework":"","materials":"","name":"表格","description":"提供了非常强大数据表格功能,可以展示数据列表,可以对数据列表进行选择、编辑等","id":"ca49cc52","_RID":"row_10"},{"framework":"","materials":"","name":"搜索框","description":"指定条件对象进行搜索数据","id":"4e20ecc9"},{"framework":"","materials":"","name":"折叠面板","description":"内容区可指定动态页面或自定义 html 等,支持展开收起操作","id":"6b093ee5"},{"framework":"","materials":"","name":"对话框","description":"模态对话框,在浮层中显示,引导用户进行相关操作","id":"0a09abc0"},{"framework":"","materials":"","name":"标签页签项","description":"tab页签","id":"f814b901"},{"framework":"","materials":"","name":"单选","description":"用于配置不同场景的选项,在一组备选项中进行单选","id":"c5ae797c"},{"framework":"","materials":"","name":"弹出编辑","description":"该组件只能在弹出的面板中选择数据,不能手动输入数据;弹出面板中显示为 Tree 组件或者 Grid 组件","id":"33d0c590"},{"framework":"","materials":"","name":"下拉框","description":"Select 选择器是一种通过点击弹出下拉列表展示数据并进行选择的 UI 组件","id":"16711dfa"},{"framework":"","materials":"","name":"折叠面板项","description":"内容区可指定动态页面或自定义 html 等,支持展开收起操作","id":"a9fd190a"},{"framework":"","materials":"","name":"复选框","description":"用于配置不同场景的选项,提供用户可在一组选项中进行多选","id":"a7dfa9ec"},{"framework":"","materials":"","name":"复选框按钮","description":"用于配置不同场景的选项,提供用户可在一组选项中进行多选","id":"c9071a7b"},{"framework":"","materials":"","name":"输入框","description":"通过鼠标或键盘输入字符","id":"d4bb8330"},{"framework":"","materials":"","name":"时间线","description":"时间线","id":"ced3dc83"}],"render7e97d9c7":[{"name":"标签页","description":"分隔内容上有关联但属于不同类别的数据集合","id":"a2b3e681","_RID":"row_1"},{"name":"走马灯","description":"常用于一组图片或卡片轮播,当内容空间不足时,可以用走马灯的形式进行收纳,进行轮播展现","id":"311fd1ae","_RID":"row_2"},{"name":"日期选择器","description":"用于设置/选择日期,包括年月/年月日/年月日时分/年月日时分秒日期格式","id":"8d38b248","_RID":"row_3"},{"name":"布局列","description":"列配置信息","id":"1f6940d8"}]},"methods":{"linkClick":{"type":"JSFunction","value":"function linkClick() {\n location.href = 'http://10.37.114.118:3000/my-platform/create';\n}"},"query":{"type":"JSFunction","value":"function query(name) {\n this.state.components.fillter((e) => {\n return e.name !== name;\n });\n}"},"getTableData":{"type":"JSFunction","value":"function getTableData() {\n return new Promise((resolve, reject) => {\n this.dataSourceMap['timeData'].load().then((res) => {\n resolve({ result: [], page: { total: 0 } });\n });\n });\n}"},"clearSelected":{"type":"JSFunction","value":"function clearSelected(event) {\n this.dataSourceMap['selectedComponents'] = this.dataSourceMap['selectedComponents'] || [];\n this.dataSourceMap['selectedComponents']?.map((e) => {\n this.dataSourceMap['componentList'].push(e);\n });\n this.dataSourceMap['selectedComponents'] = [];\n}"}},"componentName":"Page","css":".components-box{\r\n height:900px;\r\n display: flex;\r\n}\r\n.components-box-left{\r\n width: 270px;\r\n}\r\n.components-box-right{\r\n width:50%;\r\n}\r\n.components-box-right-add{\r\n width: 100%;\r\n height: 200px;\r\n}\r\n.mgr20{\r\n margin-right: 20px;\r\n}","props":{},"children":[{"componentName":"div","props":{},"id":"2a5d4622","children":[{"componentName":"TinyGrid","props":{"editConfig":{"trigger":"click","mode":"cell","showStatus":true},"columns":[{"type":"index","width":60},{"type":"selection","width":60},{"field":"employees","title":"员工数"},{"field":"created_date","title":"创建日期"},{"field":"city","title":"城市"}],"data":[{"id":"1","name":"GFD科技有限公司","city":"福州","employees":800,"created_date":"2014-04-30 00:56:00","boole":false},{"id":"2","name":"WWW科技有限公司","city":"深圳","employees":300,"created_date":"2016-07-08 12:36:22","boole":true}]},"id":"3635454e"}]},{"componentName":"PortalHeader","props":{},"componentType":"Block","id":"60284cf1"},{"componentName":"portalBlock","props":{},"componentType":"Block","id":"6911db84"},{"componentName":"div","props":{"style":"height: 80px; width: 87%; margin: 0 auto; margin-bottom: 20px; margin-top: 20px; padding-left: 20px; padding-top: 30px; background: rgb(242, 245, 252);"},"id":"436ecc4a","children":[{"componentName":"Text","props":{"text":" 物料资产包简介","style":"color: rgb(138, 142, 153);"},"id":"16ad7aa9"},{"componentName":"Text","props":{"text":"调试构建报错","style":"margin-left: 10px; margin-right: 10px;"},"id":"ab44d8ea"},{"componentName":"Icon","props":{"name":"IconEdit"},"id":"8b6be3c2"},{"componentName":"div","props":{},"id":"848e3e8a","children":[{"componentName":"Text","props":{"text":"发布地址","style":"color: rgb(138, 142, 153);"},"id":"cd51ad2c"},{"componentName":"Text","props":{"text":"http://10.37.114.118:3000/my-platform/create","style":"margin-left: 20px; margin-right: 10px; color: rgb(36, 150, 255);","onClick":{"type":"JSExpression","value":"this.linkClick"}},"id":"3ed13633"},{"componentName":"Icon","props":{"name":"IconEdit"},"id":"16b75d9f"}]}]},{"componentName":"div","props":{"className":"components-box","style":"width: 88%; margin: 0 auto; border-width: 1px; border-color: rgb(223, 225, 230); border-style: solid; padding-top: 40px; padding-bottom: 40px; height: 1200px;"},"id":"c880007b","children":[{"componentName":"div","props":{"className":"components-box-left","style":"border-right-width: 2px; border-right-style: solid; border-color: rgb(223, 225, 230); position: relative;"},"id":"3525fc52","children":[{"componentName":"TinyTimeLine","props":{"active":"1","data":[{"name":"添加组件"},{"name":"添加区块"}],"horizontal":false,"className":"components-box-left","vertical":true},"id":"1e391ed7"},{"componentName":"div","props":{},"id":"81ccd767","children":[{"componentName":"div","props":{"style":"height: 300px; position: absolute; bottom: 20px; left: 20px;"},"id":"bc11d593","children":[{"componentName":"div","props":{},"id":"50ed6e39","children":[{"componentName":"Text","props":{"text":"组件示意图 "},"id":"fa6b920c"}]},{"componentName":"div","props":{},"id":"9ca346e6","children":[{"componentName":"Text","props":{"text":"组件是构建物料资产包的必要元素\n","style":"margin-top: 10px; color: rgb(173, 176, 184); margin-bottom: 20px;"},"id":"d0ac5a34"}]},{"componentName":"Img","props":{"src":"http://localhost:9090/assets/images/f750dc319828b039af713c643aad02bd_222x134.png","style":"margin-top: 20px; width: 95%;"},"id":"3eac458c"}]}]}]},{"componentName":"div","props":{"className":".components-box-right","style":"padding-left: 50px; border-radius: 0px; height: 100%;"},"id":"d0890144","children":[{"componentName":"div","props":{"className":"components-box-right-add"},"id":"0c79b824","children":[{"componentName":"div","props":{"style":"height: 50px;"},"id":"5dd75633","children":[{"componentName":"Text","props":{"text":"已添加","style":"font-size: 16px; font-weight: bold;"},"id":"e534646e"},{"componentName":"div","props":{"style":"display: inline-block;","onClick":{"type":"JSExpression","value":"this.clearSelected(event)"}},"id":"1f3f03e5","children":[{"componentName":"Icon","props":{"name":"IconUndelete","style":"margin-left: 10px; font-size: 20px; color:rgb(94, 124, 224);"},"id":"1ea6eea4"},{"componentName":"Text","props":{"text":"清空默认","style":"color: rgb(94, 124, 224); border-radius: 0px;"},"id":"4f143cd5"}]}]},{"componentName":"Collection","props":{"style":"height: 140px; display: flex; border-radius: 0px;","dataSource":151},"id":"9b4f4898","children":[{"componentName":"div","props":{"style":"width: 300px; height: 70px; margin-top: 20px; border-top-width: 1px; border-right-width: 1px; border-bottom-width: 1px; border-left-width: 1px; border-width: 1px; border-style: solid; border-color: #dfe1e6; display: flex; flex-direction: row; padding-right: 0px; padding-left: 0px; margin-right: 25px; margin-left: 0px; padding-top: 20px; margin-bottom: 20px; position: relative; background: rgb(242, 245, 252); border-radius: 2px;"},"id":"b5f585f9","children":[{"componentName":"Img","props":{"style":"width: 50px; height: 50px; margin-left: 20px; margin-top: 0px;","src":"http://localhost:9090/assets/images/24b520f0-dd5d-11ec-9e28-e51c91ead705.png"},"id":"ee90fa60"},{"componentName":"div","props":{"style":"width: 200px; margin-left: 12px;"},"id":"7735e4da","children":[{"componentName":"Text","props":{"text":{"type":"JSExpression","value":"item.name"},"style":"font-weight: bold;"},"id":"068127b6"},{"componentName":"Text","props":{"text":"默认","style":"position: absolute; right: 2px; top: 2px; font-family: \"Microsoft YaHei\"; color: rgb(255, 255, 255); background: rgb(80, 212, 171); border-radius: 4.5px 0px;"},"id":"6d0281d2"},{"componentName":"TinyCheckbox","props":{"text":"","style":"position: absolute; right: 10px; bottom: 10px; color: rgb(82, 110, 204);","checked":{"type":"JSExpression","value":"item.isSelected"},"modelValue":true},"id":"622d9bdf"},{"componentName":"Text","props":{"text":{"type":"JSExpression","value":"item.description"},"style":"display: block; margin-top: 10px; text-overflow: ellipsis; width: 90%; overflow: hidden; white-space: nowrap;"},"id":"eb87da78"}]}],"loop":{"type":"JSExpression","value":"this.state.render7e97d9c7"}}]}]},{"componentName":"div","props":{"style":"width: 98%; display: flex; margin-bottom: 22px; justify-content: space-between; margin-right: 0px; padding-right: 0px;"},"id":"c7f80c55","children":[{"componentName":"Text","props":{"text":"选择组件","style":"font-size: 16px; font-weight: bold;"},"id":"2ebef929"},{"componentName":"div","props":{"style":"display: flex;"},"id":"00a6fb16","children":[{"componentName":"TinySearch","props":{"modelValue":"","placeholder":"输入关键词","style":"width: 295px; margin-right: 12px;","onChange":{"type":"JSExpression","value":"this.query"}},"id":"d7364e4d"},{"componentName":"Collection","props":{"dataSource":129},"id":"03a2f95b","children":[{"componentName":"TinySelect","props":{"modelValue":"","placeholder":"请选择","options":{"type":"JSExpression","value":"this.state.renderf5956ed2"},"style":"border-radius: 0px; margin-right: 0px;"},"id":"181b5ab7"}]}]}]},{"componentName":"Collection","props":{"dataSource":150,"style":"margin-left: 0px; margin-right: 314px; display: flex; justify-content: flex-start; flex-wrap: wrap; width: 98%; over-flow: hidden; border-radius: 0px;"},"id":"2b24a6d3","children":[{"componentName":"div","props":{"style":"padding-top: 20px; padding-left: 12px; padding-right: 12px; width: 280px; height: 92px; background: rgb(255, 255, 255); border-width: 1px; border-color: rgb(223, 225, 230); border-style: solid; border-radius: 2px; padding-bottom: 20px; display: flex; margin-right: 0px; margin-bottom: 20px; margin-left: 20px;"},"id":"8a6e5b83","children":[{"componentName":"Img","props":{"style":"width: 40px; height: 40px;","src":"http://localhost:9090/assets/images/0cfe4680-dd6c-11ec-a115-b53bbc5cfe9d.png"},"id":"474ffcb2"},{"componentName":"div","props":{"style":"margin-left: 12px; border-radius: 0px; width: 90%;"},"id":"99944a57","children":[{"componentName":"div","props":{"style":"display: flex; justify-content: space-between;"},"id":"b5c88120","children":[{"componentName":"Text","props":{"text":{"type":"JSExpression","value":"item.name"},"style":"font-weight: bold; border-radius: 0px;"},"id":"a747169d"},{"componentName":"TinyCheckbox","props":{"text":"","checked":false,"modelValue":{"type":"JSExpression","value":"item.isSelected","model":true},"style":"border-radius: 0px;"},"id":"72cee0e5"}]},{"componentName":"Text","props":{"style":"display: block; font-size: 12px; line-height: 17px; color: #333333; margin-top: 10px;","text":{"type":"JSExpression","value":"item.description"}},"id":"1aed3258"}]}],"loop":{"type":"JSExpression","value":"this.state.renderb52aeac9"},"condition":true,"loopArgs":["item","idx"]}]},{"componentName":"TinyPager","props":{"layout":"sizes,total, prev, pager, next","total":{"type":"JSExpression","value":"this.state.componentsTotal"},"pageSize":10,"currentPage":1,"style":"margin-left: 314px; margin-right: 314px;"},"id":"ff96cc4e"}]}]},{"componentName":"div","props":{"style":"height: 100px; background: rgb(255, 255, 255); filter: drop-shadow(rgba(0, 0, 0, 0.1) 0px -1px 4px); text-align: center;"},"id":"616d5f40","children":[{"componentName":"TinyButton","props":{"text":"创建物料资产包","style":"background: rgb(245, 245, 246); border-width: 1px; border-color: rgb(173, 176, 184); border-style: solid; border-radius: 2.5px; opacity: 0.6; margin: 0 auto; width: 200px; height: 32px; margin-top: 30px; max-width: none; margin-bottom: 10px;"},"id":"e6abff72"},{"componentName":"Text","props":{"style":"display: block; color: rgb(173, 176, 184); margin-top: 5px; width: 380px; margin: 0 auto;","text":"组件或区块未添加,请切换左侧步骤条去完成添加"},"id":"f3a123ba","children":[{"componentName":"Icon","props":{}}]}]}],"fileName":"componentsSetting"},"tenant":1,"isBody":false,"parentId":"0","group":"staticPages","depth":0,"isPage":true,"isDefault":false,"occupier":{"id":86,"username":"开发者","email":"developer@lowcode.com","resetPasswordToken":"developer","confirmationToken":"dfb2c162-351f-4f44-ad5f-8998","is_admin":true},"isHome":true,"_id":"fh7U0xYetFGA5Ieu"} +{"$$indexCreated":{"fieldName":"route","unique":true,"sparse":false}} +{"$$indexCreated":{"fieldName":"route","unique":true}} diff --git a/mockServer/src/database/pages.db b/mockServer/src/database/pages.db new file mode 100644 index 000000000..103c88610 --- /dev/null +++ b/mockServer/src/database/pages.db @@ -0,0 +1,4 @@ +{"name":"DemoPage","id":"5bhD7p5FUsUOTFRN","app":"918","route":"demopage","page_content":{"state":{},"methods":{},"componentName":"Page","css":"","props":{},"lifeCycles":{},"children":[{"componentName":"div","props":{},"id":"85375559","children":[{"componentName":"TinySwitch","props":{"modelValue":""},"id":"33433546"}]}],"dataSource":{"list":[]},"utils":[],"bridge":[],"inputs":[],"outputs":[],"fileName":"DemoPage"},"tenant":1,"isBody":false,"parentId":"0","group":"staticPages","depth":0,"isPage":true,"isDefault":false,"occupier":{"id":86,"username":"开发者","email":"developer@lowcode.com","resetPasswordToken":"developer","confirmationToken":"dfb2c162-351f-4f44-ad5f-8998","is_admin":true},"isHome":false,"message":"Page auto save","_id":"5bhD7p5FUsUOTFRN"} +{"name":"createVm","id":"NTJ4MjvqoVj8OVsc","app":"918","route":"createVm","page_content":{"state":{"dataDisk":[1,2,3]},"methods":{},"componentName":"Page","css":"body {\r\n background-color:#eef0f5 ;\r\n margin-bottom: 80px;\r\n}","props":{},"children":[{"componentName":"div","props":{"style":"padding-bottom: 10px; padding-top: 10px;"},"id":"2b2cabf0","children":[{"componentName":"TinyTimeLine","props":{"active":"2","data":[{"name":"基础配置"},{"name":"网络配置"},{"name":"高级配置"},{"name":"确认配置"}],"horizontal":true,"style":"border-radius: 0px;"},"id":"dd764b17"}]},{"componentName":"div","props":{"style":"border-width: 1px; border-style: solid; border-radius: 4px; border-color: #fff; padding-top: 10px; padding-bottom: 10px; padding-left: 10px; padding-right: 10px; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px; background-color: #fff; margin-bottom: 10px;"},"id":"30c94cc8","children":[{"componentName":"TinyForm","props":{"labelWidth":"80px","labelPosition":"top","inline":false,"label-position":"left ","label-width":"150px","style":"border-radius: 0px;"},"children":[{"componentName":"TinyFormItem","props":{"label":"计费模式"},"children":[{"componentName":"TinyButtonGroup","props":{"data":[{"text":"包年/包月","value":"1"},{"text":"按需计费","value":"2"}],"modelValue":"1"},"id":"a8d84361"}],"id":"9f39f3e7"},{"componentName":"TinyFormItem","props":{"label":"区域"},"children":[{"componentName":"TinyButtonGroup","props":{"data":[{"text":"乌兰察布二零一","value":"1"}],"modelValue":"1","style":"border-radius: 0px; margin-right: 10px;"},"id":"c97ccd99"},{"componentName":"Text","props":{"text":"温馨提示:页面左上角切换区域","style":"background-color: [object Event]; color: #8a8e99; font-size: 12px;"},"id":"20923497"},{"componentName":"Text","props":{"text":"不同区域的云服务产品之间内网互不相通;请就近选择靠近您业务的区域,可减少网络时延,提高访问速度","style":"display: block; color: #8a8e99; border-radius: 0px; font-size: 12px;"},"id":"54780a26"}],"id":"4966384d"},{"componentName":"TinyFormItem","props":{"label":"可用区","style":"border-radius: 0px;"},"children":[{"componentName":"TinyButtonGroup","props":{"data":[{"text":"可用区1","value":"1"},{"text":"可用区2","value":"2"},{"text":"可用区3","value":"3"}],"modelValue":"1"},"id":"6184481b"}],"id":"690837bf"}],"id":"b6a425d4"}]},{"componentName":"div","props":{"style":"border-width: 1px; border-style: solid; border-radius: 4px; border-color: #fff; padding-top: 10px; padding-bottom: 10px; padding-left: 10px; padding-right: 10px; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px; background-color: #fff; margin-bottom: 10px;"},"children":[{"componentName":"TinyForm","props":{"labelWidth":"80px","labelPosition":"top","inline":false,"label-position":"left ","label-width":"150px","style":"border-radius: 0px;"},"children":[{"componentName":"TinyFormItem","props":{"label":"CPU架构"},"children":[{"componentName":"TinyButtonGroup","props":{"data":[{"text":"x86计算","value":"1"},{"text":"鲲鹏计算","value":"2"}],"modelValue":"1"},"id":"7d33ced7"}],"id":"05ed5a79"},{"componentName":"TinyFormItem","props":{"label":"区域"},"children":[{"componentName":"div","props":{"style":"display: flex; justify-content: flex-start; align-items: center;"},"id":"606edf78","children":[{"componentName":"div","props":{"style":"display: flex; align-items: center; margin-right: 10px;"},"id":"f3f98246","children":[{"componentName":"Text","props":{"text":"vCPUs","style":"width: 80px;"},"id":"c287437e"},{"componentName":"TinySelect","props":{"modelValue":"","placeholder":"请选择","options":[{"value":"1","label":"黄金糕"},{"value":"2","label":"双皮奶"}]},"id":"4c43286b"}]},{"componentName":"div","props":{"style":"display: flex; align-items: center; margin-right: 10px;"},"children":[{"componentName":"Text","props":{"text":"内存","style":"width: 80px; border-radius: 0px;"},"id":"38b8fa1f"},{"componentName":"TinySelect","props":{"modelValue":"","placeholder":"请选择","options":[{"value":"1","label":"黄金糕"},{"value":"2","label":"双皮奶"}]},"id":"cd33328e"}],"id":"2b2c678f"},{"componentName":"div","props":{"style":"display: flex; align-items: center;"},"children":[{"componentName":"Text","props":{"text":"规格名称","style":"width: 80px;"},"id":"d3eb6352"},{"componentName":"TinySearch","props":{"modelValue":"","placeholder":"输入关键词"},"id":"21cb9282"}],"id":"b8e0f35c"}]},{"componentName":"div","props":{"style":"border-radius: 0px;"},"id":"5000c83e","children":[{"componentName":"TinyButtonGroup","props":{"data":[{"text":"通用计算型","value":"1"},{"text":"通用计算增强型","value":"2"},{"text":"内存优化型","value":"3"},{"text":"内存优化型","value":"4"},{"text":"磁盘增强型","value":"5"},{"text":"超高I/O型","value":"6"},{"text":"GPU加速型","value":"7"}],"modelValue":"1","style":"border-radius: 0px; margin-top: 12px;"},"id":"b8724703"},{"componentName":"TinyGrid","props":{"editConfig":{"trigger":"click","mode":"cell","showStatus":true},"columns":[{"type":"radio","width":60},{"field":"employees","title":"规格名称"},{"field":"created_date","title":"vCPUs | 内存(GiB)","sortable":true},{"field":"city","title":"CPU","sortable":true},{"title":"基准 / 最大带宽\t","sortable":true},{"title":"内网收发包","sortable":true}],"data":[{"id":"1","name":"GFD科技有限公司","city":"福州","employees":800,"created_date":"2014-04-30 00:56:00","boole":false},{"id":"2","name":"WWW科技有限公司","city":"深圳","employees":300,"created_date":"2016-07-08 12:36:22","boole":true}],"style":"margin-top: 12px; border-radius: 0px;","auto-resize":true},"id":"77701c25"},{"componentName":"div","props":{"style":"margin-top: 12px; border-radius: 0px;"},"id":"3339838b","children":[{"componentName":"Text","props":{"text":"当前规格","style":"width: 150px; display: inline-block;"},"id":"203b012b"},{"componentName":"Text","props":{"text":"通用计算型 | Si2.large.2 | 2vCPUs | 4 GiB","style":"font-weight: 700;"},"id":"87723f52"}]}]}],"id":"657fb2fc"}],"id":"d19b15cf"}],"id":"9991228b"},{"componentName":"div","props":{"style":"border-width: 1px; border-style: solid; border-radius: 4px; border-color: #fff; padding-top: 10px; padding-bottom: 10px; padding-left: 10px; padding-right: 10px; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px; background-color: #fff; margin-bottom: 10px;"},"children":[{"componentName":"TinyForm","props":{"labelWidth":"80px","labelPosition":"top","inline":false,"label-position":"left ","label-width":"150px","style":"border-radius: 0px;"},"children":[{"componentName":"TinyFormItem","props":{"label":"镜像","style":"border-radius: 0px;"},"children":[{"componentName":"TinyButtonGroup","props":{"data":[{"text":"公共镜像","value":"1"},{"text":"私有镜像","value":"2"},{"text":"共享镜像","value":"3"}],"modelValue":"1"},"id":"922b14cb"},{"componentName":"div","props":{"style":"display: flex; margin-top: 12px; border-radius: 0px;"},"id":"6b679524","children":[{"componentName":"TinySelect","props":{"modelValue":"","placeholder":"请选择","options":[{"value":"1","label":"黄金糕"},{"value":"2","label":"双皮奶"}],"style":"width: 170px; margin-right: 10px;"},"id":"4851fff7"},{"componentName":"TinySelect","props":{"modelValue":"","placeholder":"请选择","options":[{"value":"1","label":"黄金糕"},{"value":"2","label":"双皮奶"}],"style":"width: 340px;"},"id":"a7183eb7"}]},{"componentName":"div","props":{"style":"margin-top: 12px;"},"id":"57aee314","children":[{"componentName":"Text","props":{"text":"请注意操作系统的语言类型。","style":"color: #e37d29;"},"id":"56d36c27"}]}],"id":"e3b02436"}],"id":"59aebf2b"}],"id":"87ff7b99"},{"componentName":"div","props":{"style":"border-width: 1px; border-style: solid; border-radius: 4px; border-color: #fff; padding-top: 10px; padding-bottom: 10px; padding-left: 10px; padding-right: 10px; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px; background-color: #fff; margin-bottom: 10px;"},"children":[{"componentName":"TinyForm","props":{"labelWidth":"80px","labelPosition":"top","inline":false,"label-position":"left ","label-width":"150px","style":"border-radius: 0px;"},"children":[{"componentName":"TinyFormItem","props":{"label":"系统盘","style":"border-radius: 0px;"},"children":[{"componentName":"div","props":{"style":"display: flex;"},"id":"cddba5b8","children":[{"componentName":"TinySelect","props":{"modelValue":"","placeholder":"请选择","options":[{"value":"1","label":"黄金糕"},{"value":"2","label":"双皮奶"}],"style":"width: 200px; margin-right: 10px;"},"id":"a97fbe15"},{"componentName":"TinyInput","props":{"placeholder":"请输入","modelValue":"","style":"width: 120px; margin-right: 10px;"},"id":"1cde4c0f"},{"componentName":"Text","props":{"text":"GiB \nIOPS上限240,IOPS突发上限5,000","style":"color: #575d6c; font-size: 12px;"},"id":"2815d82d"}]}],"id":"50239a3a"}],"id":"e8582986"},{"componentName":"TinyForm","props":{"labelWidth":"80px","labelPosition":"top","inline":false,"label-position":"left ","label-width":"150px","style":"border-radius: 0px;"},"children":[{"componentName":"TinyFormItem","props":{"label":"数据盘","style":"border-radius: 0px;"},"children":[{"componentName":"div","props":{"style":"margin-top: 12px; display: flex;"},"id":"728c9825","children":[{"componentName":"Icon","props":{"style":"margin-right: 10px; width: 16px; height: 16px;","name":"IconPanelMini"},"id":"fded6930"},{"componentName":"TinySelect","props":{"modelValue":"","placeholder":"请选择","options":[{"value":"1","label":"黄金糕"},{"value":"2","label":"双皮奶"}],"style":"width: 200px; margin-right: 10px;"},"id":"62734e3f"},{"componentName":"TinyInput","props":{"placeholder":"请输入","modelValue":"","style":"width: 120px; margin-right: 10px;"},"id":"667c7926"},{"componentName":"Text","props":{"text":"GiB \nIOPS上限600,IOPS突发上限5,000","style":"color: #575d6c; font-size: 12px; margin-right: 10px;"},"id":"e7bc36d6"},{"componentName":"TinyInput","props":{"placeholder":"请输入","modelValue":"","style":"width: 120px;"},"id":"1bd56dc0"}],"loop":{"type":"JSExpression","value":"this.state.dataDisk"}},{"componentName":"div","props":{"style":"display: flex; margin-top: 12px; border-radius: 0px;"},"children":[{"componentName":"Icon","props":{"name":"IconPlus","style":"width: 16px; height: 16px; margin-right: 10px;"},"id":"65c89f2b"},{"componentName":"Text","props":{"text":"增加一块数据盘","style":"font-size: 12px; border-radius: 0px; margin-right: 10px;"},"id":"cb344071"},{"componentName":"Text","props":{"text":"您还可以挂载 21 块磁盘(云硬盘)","style":"color: #8a8e99; font-size: 12px;"},"id":"80eea996"}],"id":"e9e530ab"}],"id":"078e03ef"}],"id":"ccef886e"}],"id":"0fb7bd74"},{"componentName":"div","props":{"style":"border-width: 1px; border-style: solid; border-color: #ffffff; padding-top: 10px; padding-left: 10px; padding-right: 10px; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px; background-color: #fff; position: fixed; inset: auto 0% 0% 0%; height: 80px; line-height: 80px; border-radius: 0px;"},"children":[{"componentName":"TinyForm","props":{"labelWidth":"80px","labelPosition":"top","inline":false,"label-position":"left ","label-width":"150px","style":"border-radius: 0px;"},"children":[],"id":"21ed4475"},{"componentName":"TinyRow","props":{"style":"border-radius: 0px; height: 100%;"},"children":[{"componentName":"TinyCol","props":{"span":"8"},"id":"b9d051a5","children":[{"componentName":"TinyRow","props":{"style":"border-radius: 0px;"},"children":[{"componentName":"TinyCol","props":{"span":"5","style":"display: flex;"},"id":"02352776","children":[{"componentName":"Text","props":{"text":"购买量","style":"margin-right: 10px;"},"id":"0cd9ed5c"},{"componentName":"TinyInput","props":{"placeholder":"请输入","modelValue":"","style":"width: 120px; margin-right: 10px;"},"id":"2f9cf442"},{"componentName":"Text","props":{"text":"台"},"id":"facd4481"}]},{"componentName":"TinyCol","props":{"span":"7"},"id":"82b6c659","children":[{"componentName":"div","props":{},"id":"9cd65874","children":[{"componentName":"Text","props":{"text":"配置费用","style":"font-size: 12px;"},"id":"b5a0a0da"},{"componentName":"Text","props":{"text":"¥1.5776","style":"padding-left: 10px; padding-right: 10px; color: #de504e;"},"id":"d9464214"},{"componentName":"Text","props":{"text":"/小时","style":"font-size: 12px;"},"id":"af7cc5e6"}]},{"componentName":"div","props":{},"id":"89063830","children":[{"componentName":"Text","props":{"text":"参考价格,具体扣费请以账单为准。","style":"font-size: 12px; border-radius: 0px;"},"id":"d8995fbc"},{"componentName":"Text","props":{"text":"了解计费详情","style":"font-size: 12px; color: #344899;"},"id":"b383c3e2"}]}]}],"id":"94fc0e43"}]},{"componentName":"TinyCol","props":{"span":"4","style":"display: flex; flex-direction: row-reverse; border-radius: 0px; height: 100%; justify-content: flex-start; align-items: center;"},"id":"10b73009","children":[{"componentName":"TinyButton","props":{"text":"下一步: 网络配置","type":"danger","style":"max-width: unset;"},"id":"0b584011"}]}],"id":"d414a473"}],"id":"e8ec029b"}],"fileName":"createVm"},"tenant":1,"isBody":false,"parentId":"0","group":"staticPages","depth":0,"isPage":true,"isDefault":false,"occupier":{"id":86,"username":"开发者","email":"developer@lowcode.com","resetPasswordToken":"developer","confirmationToken":"dfb2c162-351f-4f44-ad5f-8998","is_admin":true},"isHome":false,"_id":"NTJ4MjvqoVj8OVsc"} +{"$$indexCreated":{"fieldName":"route","unique":true,"sparse":false}} +{"$$indexCreated":{"fieldName":"route","unique":true}} diff --git a/mockServer/src/middleware/ErrorRoutesCatch.js b/mockServer/src/middleware/ErrorRoutesCatch.js new file mode 100644 index 000000000..b1d42440a --- /dev/null +++ b/mockServer/src/middleware/ErrorRoutesCatch.js @@ -0,0 +1,22 @@ +/** +* Copyright (c) 2023 - present TinyEngine Authors. +* Copyright (c) 2023 - present Huawei Cloud Computing Technologies Co., Ltd. +* +* Use of this source code is governed by an MIT-style license. +* +* THE OPEN SOURCE SOFTWARE IN THIS PRODUCT IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, +* BUT WITHOUT ANY WARRANTY, WITHOUT EVEN THE IMPLIED WARRANTY OF MERCHANTABILITY OR FITNESS FOR +* A PARTICULAR PURPOSE. SEE THE APPLICABLE LICENSES FOR MORE DETAILS. +* +*/ + +const { getResponseData } = require('../tool/Common') + +module.exports = function () { + return function (ctx, next) { + return next().catch((err) => { + ctx.status = 200 + ctx.body = getResponseData(null, err) + }) + } +} diff --git a/mockServer/src/mock/get/app-center/apps/detail/918.json b/mockServer/src/mock/get/app-center/apps/detail/918.json new file mode 100644 index 000000000..efd46d535 --- /dev/null +++ b/mockServer/src/mock/get/app-center/apps/detail/918.json @@ -0,0 +1,78 @@ +{ + "data": { + "id": 918, + "name": "portal-app", + "app_website": null, + "platform": { + "id": 897, + "name": "portal-platform" + }, + "obs_url": "", + "created_by": null, + "updated_by": null, + "created_at": "2022-06-08T07:19:01.000Z", + "updated_at": "2023-09-04T08:55:40.000Z", + "state": null, + "published": false, + "createdBy": 86, + "updatedBy": 564, + "tenant": 1, + "home_page": "NTJ4MjvqoVj8OVsc", + "css": null, + "config": {}, + "git_group": "", + "project_name": "", + "constants": null, + "data_handler": { + "type": "JSFunction", + "value": "function dataHanlder(res){\n return res;\n}" + }, + "description": "demo应用", + "latest": 22, + "platform_history": null, + "editor_url": "", + "branch": "develop", + "visit_url": null, + "is_demo": null, + "image_url": "", + "is_default": true, + "template_type": null, + "set_template_time": null, + "set_template_by": null, + "set_default_by": 169, + "framework": "Vue", + "global_state": [], + "default_lang": null, + "extend_config": { + "business": { + "serviceName": "", + "endpointName": "cce", + "endpointId": "ee", + "serviceId": "ee", + "router": "ee" + }, + "env": { + "alpha": { + "regions": [ + { + "name": "", + "baseUrl": "", + "isDefault": false + } + ], + "isDefault": true + } + }, + "type": "console" + }, + "assets_url": "", + "data_hash": "ae128e37f6bc378f1b9c21d75bd05551", + "can_associate": true, + "data_source_global": { + "dataHandler": { + "type": "JSFunction", + "value": "function dataHanlder(res){\n return res;\n}" + } + } + } +} diff --git a/mockServer/src/mock/get/app-center/apps/extension/delete.json b/mockServer/src/mock/get/app-center/apps/extension/delete.json new file mode 100644 index 000000000..a41dcbbb3 --- /dev/null +++ b/mockServer/src/mock/get/app-center/apps/extension/delete.json @@ -0,0 +1,20 @@ +{ + "data": { + "id": 245824, + "name": "Input", + "type": "npm", + "content": { + "package": "@opentiny/vue", + "version": "", + "exportName": "Input", + "subName": "", + "destructuring": true, + "main": "" + }, + "app": 918, + "category": "utils", + "created_at": "2023-09-04T08:32:38.000Z", + "updated_at": "2023-09-04T08:32:38.000Z" + }, + "locale": "zh-cn" +} diff --git a/mockServer/src/mock/get/app-center/apps/extension/list.json b/mockServer/src/mock/get/app-center/apps/extension/list.json new file mode 100644 index 000000000..d3f2008dd --- /dev/null +++ b/mockServer/src/mock/get/app-center/apps/extension/list.json @@ -0,0 +1,127 @@ +{ + "data": [ + { + "id": 176, + "name": "axios", + "type": "npm", + "content": { + "type": "JSFunction", + "value": "", + "package": "axios", + "destructuring": false, + "exportName": "axios" + }, + "app": 918, + "category": "utils", + "created_at": "2022-10-27T11:02:26.000Z", + "updated_at": "2022-10-27T11:02:26.000Z" + }, + { + "id": 104, + "name": "Button", + "type": "npm", + "content": { + "package": "@opentiny/vue", + "version": "", + "exportName": "Button", + "subName": "", + "destructuring": true, + "main": "" + }, + "app": 918, + "category": "utils", + "created_at": "2022-07-06T10:17:31.000Z", + "updated_at": "2022-07-06T10:17:31.000Z" + }, + { + "id": 101, + "name": "Menu", + "type": "npm", + "content": { + "type": "JSFunction", + "value": "", + "package": "@opentiny/vue", + "exportName": "NavMenu", + "destructuring": true + }, + "app": 918, + "category": "utils", + "created_at": "2022-06-24T06:40:52.000Z", + "updated_at": "2022-06-24T08:03:13.000Z" + }, + { + "id": 103, + "name": "Modal ", + "type": "npm", + "content": { + "package": "@opentiny/vue", + "version": "", + "exportName": "Modal ", + "subName": "", + "destructuring": true, + "main": "" + }, + "app": 918, + "category": "utils", + "created_at": "2022-07-01T03:21:19.000Z", + "updated_at": "2022-07-01T03:21:19.000Z" + }, + { + "id": 146, + "name": "npm", + "type": "function", + "content": { + "type": "JSFunction", + "value": "''" + }, + "app": 918, + "category": "utils", + "created_at": "2022-08-29T06:54:02.000Z", + "updated_at": "2023-01-05T01:00:52.000Z" + }, + { + "id": 102, + "name": "Pager", + "type": "npm", + "content": { + "package": "@opentiny/vue", + "version": "", + "exportName": "Pager", + "subName": "", + "destructuring": true, + "main": "" + }, + "app": 918, + "category": "utils", + "created_at": "2022-06-28T08:17:38.000Z", + "updated_at": "2023-03-21T12:13:04.000Z" + }, + { + "id": 106, + "name": "test", + "type": "function", + "content": { + "type": "JSFunction", + "value": "function test() {\r\n return 'test'\r\n}" + }, + "app": 918, + "category": "utils", + "created_at": "2022-07-06T10:21:02.000Z", + "updated_at": "2023-03-21T12:12:49.000Z" + }, + { + "id": 97, + "name": "util", + "type": "function", + "content": { + "type": "JSFunction", + "value": "function util () {\r\n console.log(321)\r\n}" + }, + "app": 918, + "category": "utils", + "created_at": "2022-06-23T11:13:07.000Z", + "updated_at": "2023-04-06T02:31:44.000Z" + } + ], + "locale": "zh-cn" +} diff --git a/mockServer/src/mock/get/app-center/i18n/entries.json b/mockServer/src/mock/get/app-center/i18n/entries.json new file mode 100644 index 000000000..84127ff5d --- /dev/null +++ b/mockServer/src/mock/get/app-center/i18n/entries.json @@ -0,0 +1,33 @@ +{ + "data": { + "locales": [ + { + "lang": "en_US", + "label": "美式英文" + }, + { + "lang": "zh_CN", + "label": "简体中文" + } + ], + "messages": { + "en_US": { + "lowcode.c257d5e8": "search", + "lowcode.61c8ac8c": "testi18n", + "lowcode.f53187a0": "test", + "lowcode.97ad00dd": "createMaterial", + "common.index.fullName": "zhangsan", + "other.utileName": "getName" + }, + "zh_CN": { + "lowcode.c257d5e8": "查询", + "lowcode.61c8ac8c": "地方", + "lowcode.f53187a0": "测试", + "lowcode.97ad00dd": "创建物料资产包", + "common.index.fullName": "张三", + "other.utileName": "获取名称" + } + } + }, + "locale": "zh-cn" +} diff --git a/mockServer/src/mock/get/app-center/source_tpl.json b/mockServer/src/mock/get/app-center/source_tpl.json new file mode 100644 index 000000000..9c6b044fe --- /dev/null +++ b/mockServer/src/mock/get/app-center/source_tpl.json @@ -0,0 +1 @@ +{ "data": [], "locale": "zh-cn" } diff --git a/mockServer/src/mock/get/app-center/sources/list/918.json b/mockServer/src/mock/get/app-center/sources/list/918.json new file mode 100644 index 000000000..632927979 --- /dev/null +++ b/mockServer/src/mock/get/app-center/sources/list/918.json @@ -0,0 +1,671 @@ +{ + "data": [ + { + "id": 132, + "name": "getAllComponent", + "data": { + "data": [], + "type": "array" + }, + "tpl": null, + "app": "918", + "desc": null, + "created_at": "2022-06-28T06:26:26.000Z", + "updated_at": "2022-06-28T07:02:30.000Z" + }, + { + "id": 133, + "name": "getAllList", + "data": { + "columns": [ + { + "name": "test", + "title": "测试", + "field": "test", + "type": "string", + "format": {} + }, + { + "name": "test1", + "title": "测试1", + "field": "test1", + "type": "string", + "format": {} + } + ], + "type": "array", + "data": [ + { + "test": "test1", + "test1": "test1", + "_id": "341efc48" + }, + { + "test": "test2", + "test1": "test1", + "_id": "b86b516c" + }, + { + "test": "test3", + "test1": "test1", + "_id": "f680cd78" + } + ], + "options": { + "uri": "", + "method": "GET" + }, + "dataHandler": { + "type": "JSFunction", + "value": "function dataHandler(data) { \n return data \n}" + }, + "willFetch": { + "type": "JSFunction", + "value": "function willFetch(option) {\n return option \n}" + }, + "shouldFetch": { + "type": "JSFunction", + "value": "function shouldFetch(option) {\n return true \n}" + }, + "errorHandler": { + "type": "JSFunction", + "value": "function errorHandler(err) {}" + } + }, + "tpl": null, + "app": "918", + "desc": null, + "created_at": "2022-06-28T07:32:16.000Z", + "updated_at": "2023-01-19T03:29:11.000Z" + }, + { + "id": 135, + "name": "getAllMaterialList", + "data": { + "columns": [ + { + "name": "id", + "title": "id", + "field": "id", + "type": "string", + "format": {} + }, + { + "name": "name", + "title": "name", + "field": "name", + "type": "string", + "format": {} + }, + { + "name": "framework", + "title": "framework", + "field": "framework", + "type": "string", + "format": { + "required": true + } + }, + { + "name": "components", + "title": "components", + "field": "components", + "type": "string", + "format": {} + }, + { + "name": "content", + "title": "content", + "field": "content", + "type": "string", + "format": {} + }, + { + "name": "url", + "title": "url", + "field": "url", + "type": "string", + "format": {} + }, + { + "name": "published_at", + "title": "published_at", + "field": "published_at", + "type": "string", + "format": {} + }, + { + "name": "created_at", + "title": "created_at", + "field": "created_at", + "type": "string", + "format": {} + }, + { + "name": "updated_at", + "title": "updated_at", + "field": "updated_at", + "type": "string", + "format": {} + }, + { + "name": "published", + "title": "published", + "field": "published", + "type": "string", + "format": {} + }, + { + "name": "last_build_info", + "title": "last_build_info", + "field": "last_build_info", + "type": "string", + "format": {} + }, + { + "name": "tenant", + "title": "tenant", + "field": "tenant", + "type": "string", + "format": {} + }, + { + "name": "version", + "title": "version", + "field": "version", + "type": "string", + "format": {} + }, + { + "name": "description", + "title": "description", + "field": "description", + "type": "string", + "format": {} + } + ], + "type": "array", + "data": [ + { + "id": "f37123ec", + "url": "", + "name": "ng-material", + "tenant": "", + "content": "", + "version": "1.0.0", + "framework": "Angular", + "published": "", + "components": "", + "created_at": "2021-11-02T11:32:22.000Z", + "updated_at": "2021-11-02T11:32:22.000Z", + "description": "angular组件库物料", + "published_at": "2021-11-02T11:32:22.000Z", + "last_build_info": "", + "_id": "2a23e653" + }, + { + "id": "f37123ec", + "url": "", + "name": "ng-material", + "tenant": "", + "content": "", + "version": "1.0.0", + "framework": "Angular", + "published": "", + "components": "", + "created_at": "2021-11-02T11:32:22.000Z", + "updated_at": "2021-11-02T11:32:22.000Z", + "description": "angular组件库物料", + "published_at": "2021-11-02T11:32:22.000Z", + "last_build_info": "", + "_id": "06b253be" + }, + { + "id": "f37123ec", + "url": "", + "name": "ng-material", + "tenant": "", + "content": "", + "version": "1.0.0", + "framework": "Angular", + "published": "", + "components": "", + "created_at": "2021-11-02T11:32:22.000Z", + "updated_at": "2021-11-02T11:32:22.000Z", + "description": "angular组件库物料", + "published_at": "2021-11-02T11:32:22.000Z", + "last_build_info": "", + "_id": "c55a41ed" + }, + { + "id": "f37123ec", + "url": "", + "name": "ng-material", + "tenant": "", + "content": "", + "version": "1.0.0", + "framework": "Angular", + "published": "", + "components": "", + "created_at": "2021-11-02T11:32:22.000Z", + "updated_at": "2021-11-02T11:32:22.000Z", + "description": "angular组件库物料", + "published_at": "2021-11-02T11:32:22.000Z", + "last_build_info": "", + "_id": "f37123ec" + }, + { + "id": "7a63c1a2", + "url": "", + "name": "tiny-vue", + "tenant": "", + "content": "Tiny Vue物料", + "version": "1.0.0", + "framework": "Vue", + "published": "", + "components": "", + "created_at": "", + "updated_at": "", + "description": "Tiny Vue物料", + "published_at": "", + "last_build_info": "", + "_id": "7a63c1a2" + } + ], + "options": { + "uri": "", + "method": "GET" + }, + "willFetch": { + "type": "JSFunction", + "value": "function willFetch(option) {\n return option \n}" + }, + "dataHandler": { + "type": "JSFunction", + "value": "function dataHandler(data) { \n return data \n}" + }, + "shouldFetch": { + "type": "JSFunction", + "value": "function shouldFetch(option) {\n return true \n}" + }, + "errorHandler": { + "type": "JSFunction", + "value": "function errorHandler(err) {}" + } + }, + "tpl": null, + "app": "918", + "desc": null, + "created_at": "2022-06-29T00:57:50.000Z", + "updated_at": "2023-05-15T02:37:12.000Z" + }, + { + "id": 139, + "name": "treedata", + "data": { + "data": [ + { + "label": "level111", + "value": "111", + "id": "f6609643", + "pid": "", + "_RID": "row_4" + }, + { + "label": "level1-son", + "value": "111-1", + "id": "af1f937f", + "pid": "f6609643", + "_RID": "row_5" + }, + { + "label": "level222", + "value": "222", + "id": "28e3709c", + "pid": "", + "_RID": "row_6" + }, + { + "label": "level2-son", + "value": "222-1", + "id": "6b571bef", + "pid": "28e3709c", + "_RID": "row_5" + }, + { + "id": "6317c2cc", + "pid": "fdfa", + "label": "fsdfaa", + "value": "fsadf", + "_RID": "row_6" + }, + { + "id": "9cce369f", + "pid": "test", + "label": "test1", + "value": "001" + } + ], + "type": "tree" + }, + "tpl": null, + "app": "918", + "desc": null, + "created_at": "2022-06-30T06:13:57.000Z", + "updated_at": "2022-07-29T03:14:55.000Z" + }, + { + "id": 150, + "name": "componentList", + "data": { + "data": [ + { + "_RID": "row_1", + "name": "表单", + "isSelected": "true", + "description": "由按钮、输入框、选择器、单选框、多选框等控件组成,用以收集、校验、提交数据" + }, + { + "name": "按钮", + "isSelected": "false", + "description": "常用的操作按钮,提供包括默认按钮、图标按钮、图片按钮、下拉按钮等类型" + }, + { + "id": "490f8a00", + "_RID": "row_3", + "name": "表单项", + "framework": "", + "materials": "", + "description": "Form 组件下的 FormItem 配置" + }, + { + "id": "c259b8b3", + "_RID": "row_4", + "name": "开关", + "framework": "", + "materials": "", + "description": "关闭或打开" + }, + { + "id": "083ed9c7", + "_RID": "row_5", + "name": "互斥按钮组", + "framework": "", + "materials": "", + "description": "以按钮组的方式出现,常用于多项类似操作" + }, + { + "id": "09136cea", + "_RID": "row_6", + "name": "提示框", + "framework": "", + "materials": "", + "description": "Popover可通过对一个触发源操作触发弹出框,支持自定义弹出内容,延迟触发和渐变动画" + }, + { + "id": "a63b57d5", + "_RID": "row_7", + "name": "文字提示框", + "framework": "", + "materials": "", + "description": "动态显示提示信息,一般通过鼠标事件进行响应;提供 warning、error、info、success 四种类型显示不同类别的信" + }, + { + "id": "a0f6e8a3", + "_RID": "row_8", + "name": "树", + "framework": "", + "materials": "", + "description": "可进行展示有父子层级的数据,支持选择,异步加载等功能。但不推荐用它来展示菜单,展示菜单推荐使用树菜单" + }, + { + "id": "d1aa18fc", + "_RID": "row_9", + "name": "分页", + "framework": "", + "materials": "", + "description": "当数据量过多时,使用分页分解数据,常用于 Grid 和 Repeater 组件" + }, + { + "id": "ca49cc52", + "_RID": "row_10", + "name": "表格", + "framework": "", + "materials": "", + "description": "提供了非常强大数据表格功能,可以展示数据列表,可以对数据列表进行选择、编辑等" + }, + { + "id": "4e20ecc9", + "name": "搜索框", + "framework": "", + "materials": "", + "description": "指定条件对象进行搜索数据" + }, + { + "id": "6b093ee5", + "name": "折叠面板", + "framework": "", + "materials": "", + "description": "内容区可指定动态页面或自定义 html 等,支持展开收起操作" + }, + { + "id": "0a09abc0", + "name": "对话框", + "framework": "", + "materials": "", + "description": "模态对话框,在浮层中显示,引导用户进行相关操作" + }, + { + "id": "f814b901", + "name": "标签页签项", + "framework": "", + "materials": "", + "description": "tab页签" + }, + { + "id": "c5ae797c", + "name": "单选", + "framework": "", + "materials": "", + "description": "用于配置不同场景的选项,在一组备选项中进行单选" + }, + { + "id": "33d0c590", + "_RID": "row_13", + "name": "弹出编辑", + "framework": "", + "materials": "", + "description": "该组件只能在弹出的面板中选择数据,不能手动输入数据;弹出面板中显示为 Tree 组件或者 Grid 组件" + }, + { + "id": "16711dfa", + "_RID": "row_14", + "name": "下拉框", + "framework": "", + "materials": "", + "description": "Select 选择器是一种通过点击弹出下拉列表展示数据并进行选择的 UI 组件" + }, + { + "id": "a9fd190a", + "_RID": "row_15", + "name": "折叠面板项", + "framework": "", + "materials": "", + "description": "内容区可指定动态页面或自定义 html 等,支持展开收起操作" + }, + { + "id": "a7dfa9ec", + "_RID": "row_16", + "name": "复选框", + "framework": "", + "materials": "", + "description": "用于配置不同场景的选项,提供用户可在一组选项中进行多选" + }, + { + "id": "d4bb8330", + "name": "输入框", + "framework": "", + "materials": "", + "description": "通过鼠标或键盘输入字符" + }, + { + "id": "ced3dc83", + "name": "时间线", + "framework": "", + "materials": "", + "description": "时间线" + } + ], + "type": "array", + "columns": [ + { + "name": "name", + "type": "string", + "field": "name", + "title": "name", + "format": { + "max": 0, + "min": 0, + "dateTime": false, + "required": false, + "stringType": "" + } + }, + { + "name": "description", + "type": "string", + "field": "description", + "title": "description", + "format": { + "max": 0, + "min": 0, + "dateTime": false, + "required": false, + "stringType": "" + } + }, + { + "name": "isSelected", + "type": "string", + "field": "isSelected", + "title": "isSelected", + "format": { + "max": 0, + "min": 0, + "dateTime": false, + "required": false, + "stringType": "" + } + } + ], + "options": { + "uri": "http://localhost:9090/assets/json/bundle.json", + "method": "GET" + }, + "willFetch": { + "type": "JSFunction", + "value": "function willFetch(option) {\n return option \n}" + }, + "dataHandler": { + "type": "JSFunction", + "value": "function dataHandler(data) { \n return data \n}" + }, + "shouldFetch": { + "type": "JSFunction", + "value": "function shouldFetch(option) {\n return true \n}" + }, + "errorHandler": { + "type": "JSFunction", + "value": "function errorHandler(err) {}" + } + }, + "tpl": null, + "app": "918", + "desc": null, + "created_at": "2022-07-04T02:20:07.000Z", + "updated_at": "2022-07-04T06:25:29.000Z" + }, + { + "id": 151, + "name": "selectedComponents", + "data": { + "columns": [ + { + "name": "name", + "title": "name", + "field": "name", + "type": "string", + "format": { + "required": false, + "stringType": "", + "min": 0, + "max": 0, + "dateTime": false + } + }, + { + "name": "description", + "title": "description", + "field": "description", + "type": "string", + "format": { + "required": false, + "stringType": "", + "min": 0, + "max": 0, + "dateTime": false + } + }, + { + "name": "isSelected", + "title": "isSelected", + "field": "isSelected", + "type": "string", + "format": { + "required": false, + "stringType": "", + "min": 0, + "max": 0, + "dateTime": false + } + } + ], + "type": "array", + "data": [ + { + "name": "标签页", + "description": "分隔内容上有关联但属于不同类别的数据集合", + "isSelected": "true", + "_RID": "row_2" + }, + { + "name": "布局列", + "description": "列配置信息", + "isSelected": "true", + "id": "76a7080a", + "_RID": "row_4" + }, + { + "name": "日期选择器", + "description": "用于设置/选择日期,包括年月/年月日/年月日时分/年月日时分秒日期格式", + "isSelected": "true", + "id": "76b20d73", + "_RID": "row_1" + }, + { + "name": "走马灯", + "description": "常用于一组图片或卡片轮播,当内容空间不足时,可以用走马灯的形式进行收纳,进行轮播展现", + "isSelected": "true", + "id": "4c884c3d" + } + ] + }, + "tpl": null, + "app": "918", + "desc": null, + "created_at": "2022-07-04T03:04:05.000Z", + "updated_at": "2022-07-04T03:43:40.000Z" + } + ], + "locale": "zh-cn" +} diff --git a/mockServer/src/mock/get/app-center/v1/apps/schema/918.json b/mockServer/src/mock/get/app-center/v1/apps/schema/918.json new file mode 100644 index 000000000..24abb5191 --- /dev/null +++ b/mockServer/src/mock/get/app-center/v1/apps/schema/918.json @@ -0,0 +1,2096 @@ +{ + "data": { + "meta": { + "name": "portal-app", + "tenant": 1, + "git_group": "", + "project_name": "", + "description": "demo应用", + "branch": "develop", + "is_demo": null, + "global_state": [], + "appId": "918", + "creator": "", + "gmt_create": "2022-06-08 03:19:01", + "gmt_modified": "2023-08-23 10:22:28" + }, + "dataSource": { + "list": [ + { + "id": 132, + "name": "getAllComponent", + "data": { + "data": [], + "type": "array" + }, + "tpl": null, + "app": "918", + "desc": null, + "created_at": "2022-06-28T06:26:26.000Z", + "updated_at": "2022-06-28T07:02:30.000Z" + }, + { + "id": 133, + "name": "getAllList", + "data": { + "columns": [ + { + "name": "test", + "title": "测试", + "field": "test", + "type": "string", + "format": {} + }, + { + "name": "test1", + "title": "测试1", + "field": "test1", + "type": "string", + "format": {} + } + ], + "type": "array", + "data": [ + { + "test": "test1", + "test1": "test1", + "_id": "341efc48" + }, + { + "test": "test2", + "test1": "test1", + "_id": "b86b516c" + }, + { + "test": "test3", + "test1": "test1", + "_id": "f680cd78" + } + ], + "options": { + "uri": "", + "method": "GET" + }, + "dataHandler": { + "type": "JSFunction", + "value": "function dataHandler(data) { \n return data \n}" + }, + "willFetch": { + "type": "JSFunction", + "value": "function willFetch(option) {\n return option \n}" + }, + "shouldFetch": { + "type": "JSFunction", + "value": "function shouldFetch(option) {\n return true \n}" + }, + "errorHandler": { + "type": "JSFunction", + "value": "function errorHandler(err) {}" + } + }, + "tpl": null, + "app": "918", + "desc": null, + "created_at": "2022-06-28T07:32:16.000Z", + "updated_at": "2023-01-19T03:29:11.000Z" + }, + { + "id": 135, + "name": "getAllMaterialList", + "data": { + "columns": [ + { + "name": "id", + "title": "id", + "field": "id", + "type": "string", + "format": {} + }, + { + "name": "name", + "title": "name", + "field": "name", + "type": "string", + "format": {} + }, + { + "name": "framework", + "title": "framework", + "field": "framework", + "type": "string", + "format": { + "required": true + } + }, + { + "name": "components", + "title": "components", + "field": "components", + "type": "string", + "format": {} + }, + { + "name": "content", + "title": "content", + "field": "content", + "type": "string", + "format": {} + }, + { + "name": "url", + "title": "url", + "field": "url", + "type": "string", + "format": {} + }, + { + "name": "published_at", + "title": "published_at", + "field": "published_at", + "type": "string", + "format": {} + }, + { + "name": "created_at", + "title": "created_at", + "field": "created_at", + "type": "string", + "format": {} + }, + { + "name": "updated_at", + "title": "updated_at", + "field": "updated_at", + "type": "string", + "format": {} + }, + { + "name": "published", + "title": "published", + "field": "published", + "type": "string", + "format": {} + }, + { + "name": "last_build_info", + "title": "last_build_info", + "field": "last_build_info", + "type": "string", + "format": {} + }, + { + "name": "tenant", + "title": "tenant", + "field": "tenant", + "type": "string", + "format": {} + }, + { + "name": "version", + "title": "version", + "field": "version", + "type": "string", + "format": {} + }, + { + "name": "description", + "title": "description", + "field": "description", + "type": "string", + "format": {} + } + ], + "type": "array", + "data": [ + { + "id": "f37123ec", + "url": "", + "name": "ng-material", + "tenant": "", + "content": "", + "version": "1.0.0", + "framework": "Angular", + "published": "", + "components": "", + "created_at": "2021-11-02T11:32:22.000Z", + "updated_at": "2021-11-02T11:32:22.000Z", + "description": "angular组件库物料", + "published_at": "2021-11-02T11:32:22.000Z", + "last_build_info": "", + "_id": "2a23e653" + }, + { + "id": "f37123ec", + "url": "", + "name": "ng-material", + "tenant": "", + "content": "", + "version": "1.0.0", + "framework": "Angular", + "published": "", + "components": "", + "created_at": "2021-11-02T11:32:22.000Z", + "updated_at": "2021-11-02T11:32:22.000Z", + "description": "angular组件库物料", + "published_at": "2021-11-02T11:32:22.000Z", + "last_build_info": "", + "_id": "06b253be" + }, + { + "id": "f37123ec", + "url": "", + "name": "ng-material", + "tenant": "", + "content": "", + "version": "1.0.0", + "framework": "Angular", + "published": "", + "components": "", + "created_at": "2021-11-02T11:32:22.000Z", + "updated_at": "2021-11-02T11:32:22.000Z", + "description": "angular组件库物料", + "published_at": "2021-11-02T11:32:22.000Z", + "last_build_info": "", + "_id": "c55a41ed" + }, + { + "id": "f37123ec", + "url": "", + "name": "ng-material", + "tenant": "", + "content": "", + "version": "1.0.0", + "framework": "Angular", + "published": "", + "components": "", + "created_at": "2021-11-02T11:32:22.000Z", + "updated_at": "2021-11-02T11:32:22.000Z", + "description": "angular组件库物料", + "published_at": "2021-11-02T11:32:22.000Z", + "last_build_info": "", + "_id": "f37123ec" + }, + { + "id": "7a63c1a2", + "url": "", + "name": "tiny-vue", + "tenant": "", + "content": "Tiny Vue物料", + "version": "1.0.0", + "framework": "Vue", + "published": "", + "components": "", + "created_at": "", + "updated_at": "", + "description": "Tiny Vue物料", + "published_at": "", + "last_build_info": "", + "_id": "7a63c1a2" + } + ], + "options": { + "uri": "", + "method": "GET" + }, + "willFetch": { + "type": "JSFunction", + "value": "function willFetch(option) {\n return option \n}" + }, + "dataHandler": { + "type": "JSFunction", + "value": "function dataHandler(data) { \n return data \n}" + }, + "shouldFetch": { + "type": "JSFunction", + "value": "function shouldFetch(option) {\n return true \n}" + }, + "errorHandler": { + "type": "JSFunction", + "value": "function errorHandler(err) {}" + } + }, + "tpl": null, + "app": "918", + "desc": null, + "created_at": "2022-06-29T00:57:50.000Z", + "updated_at": "2023-05-15T02:37:12.000Z" + }, + { + "id": 139, + "name": "treedata", + "data": { + "data": [ + { + "label": "level111", + "value": "111", + "id": "f6609643", + "pid": "", + "_RID": "row_4" + }, + { + "label": "level1-son", + "value": "111-1", + "id": "af1f937f", + "pid": "f6609643", + "_RID": "row_5" + }, + { + "label": "level222", + "value": "222", + "id": "28e3709c", + "pid": "", + "_RID": "row_6" + }, + { + "label": "level2-son", + "value": "222-1", + "id": "6b571bef", + "pid": "28e3709c", + "_RID": "row_5" + }, + { + "id": "6317c2cc", + "pid": "fdfa", + "label": "fsdfaa", + "value": "fsadf", + "_RID": "row_6" + }, + { + "id": "9cce369f", + "pid": "test", + "label": "test1", + "value": "001" + } + ], + "type": "tree" + }, + "tpl": null, + "app": "918", + "desc": null, + "created_at": "2022-06-30T06:13:57.000Z", + "updated_at": "2022-07-29T03:14:55.000Z" + }, + { + "id": 150, + "name": "componentList", + "data": { + "data": [ + { + "_RID": "row_1", + "name": "表单", + "isSelected": "true", + "description": "由按钮、输入框、选择器、单选框、多选框等控件组成,用以收集、校验、提交数据" + }, + { + "name": "按钮", + "isSelected": "false", + "description": "常用的操作按钮,提供包括默认按钮、图标按钮、图片按钮、下拉按钮等类型" + }, + { + "id": "490f8a00", + "_RID": "row_3", + "name": "表单项", + "framework": "", + "materials": "", + "description": "Form 组件下的 FormItem 配置" + }, + { + "id": "c259b8b3", + "_RID": "row_4", + "name": "开关", + "framework": "", + "materials": "", + "description": "关闭或打开" + }, + { + "id": "083ed9c7", + "_RID": "row_5", + "name": "互斥按钮组", + "framework": "", + "materials": "", + "description": "以按钮组的方式出现,常用于多项类似操作" + }, + { + "id": "09136cea", + "_RID": "row_6", + "name": "提示框", + "framework": "", + "materials": "", + "description": "Popover可通过对一个触发源操作触发弹出框,支持自定义弹出内容,延迟触发和渐变动画" + }, + { + "id": "a63b57d5", + "_RID": "row_7", + "name": "文字提示框", + "framework": "", + "materials": "", + "description": "动态显示提示信息,一般通过鼠标事件进行响应;提供 warning、error、info、success 四种类型显示不同类别的信" + }, + { + "id": "a0f6e8a3", + "_RID": "row_8", + "name": "树", + "framework": "", + "materials": "", + "description": "可进行展示有父子层级的数据,支持选择,异步加载等功能。但不推荐用它来展示菜单,展示菜单推荐使用树菜单" + }, + { + "id": "d1aa18fc", + "_RID": "row_9", + "name": "分页", + "framework": "", + "materials": "", + "description": "当数据量过多时,使用分页分解数据,常用于 Grid 和 Repeater 组件" + }, + { + "id": "ca49cc52", + "_RID": "row_10", + "name": "表格", + "framework": "", + "materials": "", + "description": "提供了非常强大数据表格功能,可以展示数据列表,可以对数据列表进行选择、编辑等" + }, + { + "id": "4e20ecc9", + "name": "搜索框", + "framework": "", + "materials": "", + "description": "指定条件对象进行搜索数据" + }, + { + "id": "6b093ee5", + "name": "折叠面板", + "framework": "", + "materials": "", + "description": "内容区可指定动态页面或自定义 html 等,支持展开收起操作" + }, + { + "id": "0a09abc0", + "name": "对话框", + "framework": "", + "materials": "", + "description": "模态对话框,在浮层中显示,引导用户进行相关操作" + }, + { + "id": "f814b901", + "name": "标签页签项", + "framework": "", + "materials": "", + "description": "tab页签" + }, + { + "id": "c5ae797c", + "name": "单选", + "framework": "", + "materials": "", + "description": "用于配置不同场景的选项,在一组备选项中进行单选" + }, + { + "id": "33d0c590", + "_RID": "row_13", + "name": "弹出编辑", + "framework": "", + "materials": "", + "description": "该组件只能在弹出的面板中选择数据,不能手动输入数据;弹出面板中显示为 Tree 组件或者 Grid 组件" + }, + { + "id": "16711dfa", + "_RID": "row_14", + "name": "下拉框", + "framework": "", + "materials": "", + "description": "Select 选择器是一种通过点击弹出下拉列表展示数据并进行选择的 UI 组件" + }, + { + "id": "a9fd190a", + "_RID": "row_15", + "name": "折叠面板项", + "framework": "", + "materials": "", + "description": "内容区可指定动态页面或自定义 html 等,支持展开收起操作" + }, + { + "id": "a7dfa9ec", + "_RID": "row_16", + "name": "复选框", + "framework": "", + "materials": "", + "description": "用于配置不同场景的选项,提供用户可在一组选项中进行多选" + }, + { + "id": "d4bb8330", + "name": "输入框", + "framework": "", + "materials": "", + "description": "通过鼠标或键盘输入字符" + }, + { + "id": "ced3dc83", + "name": "时间线", + "framework": "", + "materials": "", + "description": "时间线" + } + ], + "type": "array", + "columns": [ + { + "name": "name", + "type": "string", + "field": "name", + "title": "name", + "format": { + "max": 0, + "min": 0, + "dateTime": false, + "required": false, + "stringType": "" + } + }, + { + "name": "description", + "type": "string", + "field": "description", + "title": "description", + "format": { + "max": 0, + "min": 0, + "dateTime": false, + "required": false, + "stringType": "" + } + }, + { + "name": "isSelected", + "type": "string", + "field": "isSelected", + "title": "isSelected", + "format": { + "max": 0, + "min": 0, + "dateTime": false, + "required": false, + "stringType": "" + } + } + ], + "options": { + "uri": "http://localhost:9090/assets/json/bundle.json", + "method": "GET" + }, + "willFetch": { + "type": "JSFunction", + "value": "function willFetch(option) {\n return option \n}" + }, + "dataHandler": { + "type": "JSFunction", + "value": "function dataHandler(data) { \n return data \n}" + }, + "shouldFetch": { + "type": "JSFunction", + "value": "function shouldFetch(option) {\n return true \n}" + }, + "errorHandler": { + "type": "JSFunction", + "value": "function errorHandler(err) {}" + } + }, + "tpl": null, + "app": "918", + "desc": null, + "created_at": "2022-07-04T02:20:07.000Z", + "updated_at": "2022-07-04T06:25:29.000Z" + }, + { + "id": 151, + "name": "selectedComponents", + "data": { + "columns": [ + { + "name": "name", + "title": "name", + "field": "name", + "type": "string", + "format": { + "required": false, + "stringType": "", + "min": 0, + "max": 0, + "dateTime": false + } + }, + { + "name": "description", + "title": "description", + "field": "description", + "type": "string", + "format": { + "required": false, + "stringType": "", + "min": 0, + "max": 0, + "dateTime": false + } + }, + { + "name": "isSelected", + "title": "isSelected", + "field": "isSelected", + "type": "string", + "format": { + "required": false, + "stringType": "", + "min": 0, + "max": 0, + "dateTime": false + } + } + ], + "type": "array", + "data": [ + { + "name": "标签页", + "description": "分隔内容上有关联但属于不同类别的数据集合", + "isSelected": "true", + "_RID": "row_2" + }, + { + "name": "布局列", + "description": "列配置信息", + "isSelected": "true", + "id": "76a7080a", + "_RID": "row_4" + }, + { + "name": "日期选择器", + "description": "用于设置/选择日期,包括年月/年月日/年月日时分/年月日时分秒日期格式", + "isSelected": "true", + "id": "76b20d73", + "_RID": "row_1" + }, + { + "name": "走马灯", + "description": "常用于一组图片或卡片轮播,当内容空间不足时,可以用走马灯的形式进行收纳,进行轮播展现", + "isSelected": "true", + "id": "4c884c3d" + } + ] + }, + "tpl": null, + "app": "918", + "desc": null, + "created_at": "2022-07-04T03:04:05.000Z", + "updated_at": "2022-07-04T03:43:40.000Z" + } + ], + "dataHandler": { + "type": "JSFunction", + "value": "function dataHanlder(res){\n return res;\n}" + } + }, + "i18n": { + "zh_CN": { + "lowcode.cca8d0ea": "应用", + "lowcode.c257d5e8": "查询", + "lowcode.61c8ac8c": "地方", + "lowcode.f53187a0": "测试", + "lowcode.97ad00dd": "创建物料资产包", + "lowcode.61dcef52": "terterere", + "lowcode.45f4c42a": "gdfgdf", + "lowcode.c6f5a652": "fsdaf", + "lowcode.34923432": "fdsafdsa", + "lowcode.48521e45": "fdsfds", + "lowcode.6534943e": "fdsafds", + "lowcode.44252642": "fdsafds", + "lowcode.2a743651": "sda", + "lowcode.24315357": "fdsafds", + "lowcode.44621691": "fdsafsd", + "lowcode.65636226": "fdsaf", + "lowcode.6426a4e2": "sd", + "lowcode.e41c6636": "aa", + "lowcode.51c23164": "aa", + "lowcode.17245b46": "aa", + "lowcode.4573143c": "aa", + "lowcode.56432442": "aa", + "lowcode.33566643": "aa", + "lowcode.565128f3": "aa", + "lowcode.56643835": "aa", + "lowcode.33311134": "aa", + "lowcode.44326643": "aa", + "lowcode.36223242": "aa" + }, + "en_US": { + "lowcode.cca8d0ea": "app", + "lowcode.c257d5e8": "search", + "lowcode.61c8ac8c": "dsdsa", + "lowcode.f53187a0": "test", + "lowcode.97ad00dd": "createMaterial", + "lowcode.61dcef52": "sadasda", + "lowcode.45f4c42a": "gfdgfd", + "lowcode.c6f5a652": "fsdafds", + "lowcode.34923432": "fdsafds", + "lowcode.6534943e": "fdsafdsa", + "lowcode.44252642": "aaaa", + "lowcode.2a743651": "fdsaf", + "lowcode.24315357": "fsdafds", + "lowcode.44621691": "sd", + "lowcode.65636226": "fdsfsd", + "lowcode.6426a4e2": "fdsafsd", + "lowcode.e41c6636": "aa", + "lowcode.51c23164": "aa", + "lowcode.17245b46": "aa", + "lowcode.4573143c": "a", + "lowcode.56432442": "aa", + "lowcode.33566643": "aa", + "lowcode.565128f3": "aa", + "lowcode.56643835": "aa", + "lowcode.33311134": "aa", + "lowcode.44326643": "aa", + "lowcode.36223242": "aa" + } + }, + "componentsTree": [ + { + "state": { + "dataDisk": [1, 2, 3] + }, + "methods": {}, + "componentName": "Page", + "css": "body {\r\n background-color:#eef0f5 ;\r\n margin-bottom: 80px;\r\n}", + "props": {}, + "children": [ + { + "componentName": "div", + "props": { + "style": "padding-bottom: 10px; padding-top: 10px;" + }, + "id": "2b2cabf0", + "children": [ + { + "componentName": "TinyTimeLine", + "props": { + "active": "2", + "data": [ + { + "name": "基础配置" + }, + { + "name": "网络配置" + }, + { + "name": "高级配置" + }, + { + "name": "确认配置" + } + ], + "horizontal": true, + "style": "border-radius: 0px;" + }, + "id": "dd764b17" + } + ] + }, + { + "componentName": "div", + "props": { + "style": "border-width: 1px; border-style: solid; border-radius: 4px; border-color: #fff; padding-top: 10px; padding-bottom: 10px; padding-left: 10px; padding-right: 10px; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px; background-color: #fff; margin-bottom: 10px;" + }, + "id": "30c94cc8", + "children": [ + { + "componentName": "TinyForm", + "props": { + "labelWidth": "80px", + "labelPosition": "top", + "inline": false, + "label-position": "left ", + "label-width": "150px", + "style": "border-radius: 0px;" + }, + "children": [ + { + "componentName": "TinyFormItem", + "props": { + "label": "计费模式" + }, + "children": [ + { + "componentName": "TinyButtonGroup", + "props": { + "data": [ + { + "text": "包年/包月", + "value": "1" + }, + { + "text": "按需计费", + "value": "2" + } + ], + "modelValue": "1" + }, + "id": "a8d84361" + } + ], + "id": "9f39f3e7" + }, + { + "componentName": "TinyFormItem", + "props": { + "label": "区域" + }, + "children": [ + { + "componentName": "TinyButtonGroup", + "props": { + "data": [ + { + "text": "乌兰察布二零一", + "value": "1" + } + ], + "modelValue": "1", + "style": "border-radius: 0px; margin-right: 10px;" + }, + "id": "c97ccd99" + }, + { + "componentName": "Text", + "props": { + "text": "温馨提示:页面左上角切换区域", + "style": "background-color: [object Event]; color: #8a8e99; font-size: 12px;" + }, + "id": "20923497" + }, + { + "componentName": "Text", + "props": { + "text": "不同区域的云服务产品之间内网互不相通;请就近选择靠近您业务的区域,可减少网络时延,提高访问速度", + "style": "display: block; color: #8a8e99; border-radius: 0px; font-size: 12px;" + }, + "id": "54780a26" + } + ], + "id": "4966384d" + }, + { + "componentName": "TinyFormItem", + "props": { + "label": "可用区", + "style": "border-radius: 0px;" + }, + "children": [ + { + "componentName": "TinyButtonGroup", + "props": { + "data": [ + { + "text": "可用区1", + "value": "1" + }, + { + "text": "可用区2", + "value": "2" + }, + { + "text": "可用区3", + "value": "3" + } + ], + "modelValue": "1" + }, + "id": "6184481b" + } + ], + "id": "690837bf" + } + ], + "id": "b6a425d4" + } + ] + }, + { + "componentName": "div", + "props": { + "style": "border-width: 1px; border-style: solid; border-radius: 4px; border-color: #fff; padding-top: 10px; padding-bottom: 10px; padding-left: 10px; padding-right: 10px; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px; background-color: #fff; margin-bottom: 10px;" + }, + "children": [ + { + "componentName": "TinyForm", + "props": { + "labelWidth": "80px", + "labelPosition": "top", + "inline": false, + "label-position": "left ", + "label-width": "150px", + "style": "border-radius: 0px;" + }, + "children": [ + { + "componentName": "TinyFormItem", + "props": { + "label": "CPU架构" + }, + "children": [ + { + "componentName": "TinyButtonGroup", + "props": { + "data": [ + { + "text": "x86计算", + "value": "1" + }, + { + "text": "鲲鹏计算", + "value": "2" + } + ], + "modelValue": "1" + }, + "id": "7d33ced7" + } + ], + "id": "05ed5a79" + }, + { + "componentName": "TinyFormItem", + "props": { + "label": "区域" + }, + "children": [ + { + "componentName": "div", + "props": { + "style": "display: flex; justify-content: flex-start; align-items: center;" + }, + "id": "606edf78", + "children": [ + { + "componentName": "div", + "props": { + "style": "display: flex; align-items: center; margin-right: 10px;" + }, + "id": "f3f98246", + "children": [ + { + "componentName": "Text", + "props": { + "text": "vCPUs", + "style": "width: 80px;" + }, + "id": "c287437e" + }, + { + "componentName": "TinySelect", + "props": { + "modelValue": "", + "placeholder": "请选择", + "options": [ + { + "value": "1", + "label": "黄金糕" + }, + { + "value": "2", + "label": "双皮奶" + } + ] + }, + "id": "4c43286b" + } + ] + }, + { + "componentName": "div", + "props": { + "style": "display: flex; align-items: center; margin-right: 10px;" + }, + "children": [ + { + "componentName": "Text", + "props": { + "text": "内存", + "style": "width: 80px; border-radius: 0px;" + }, + "id": "38b8fa1f" + }, + { + "componentName": "TinySelect", + "props": { + "modelValue": "", + "placeholder": "请选择", + "options": [ + { + "value": "1", + "label": "黄金糕" + }, + { + "value": "2", + "label": "双皮奶" + } + ] + }, + "id": "cd33328e" + } + ], + "id": "2b2c678f" + }, + { + "componentName": "div", + "props": { + "style": "display: flex; align-items: center;" + }, + "children": [ + { + "componentName": "Text", + "props": { + "text": "规格名称", + "style": "width: 80px;" + }, + "id": "d3eb6352" + }, + { + "componentName": "TinySearch", + "props": { + "modelValue": "", + "placeholder": "输入关键词" + }, + "id": "21cb9282" + } + ], + "id": "b8e0f35c" + } + ] + }, + { + "componentName": "div", + "props": { + "style": "border-radius: 0px;" + }, + "id": "5000c83e", + "children": [ + { + "componentName": "TinyButtonGroup", + "props": { + "data": [ + { + "text": "通用计算型", + "value": "1" + }, + { + "text": "通用计算增强型", + "value": "2" + }, + { + "text": "内存优化型", + "value": "3" + }, + { + "text": "内存优化型", + "value": "4" + }, + { + "text": "磁盘增强型", + "value": "5" + }, + { + "text": "超高I/O型", + "value": "6" + }, + { + "text": "GPU加速型", + "value": "7" + } + ], + "modelValue": "1", + "style": "border-radius: 0px; margin-top: 12px;" + }, + "id": "b8724703" + }, + { + "componentName": "TinyGrid", + "props": { + "editConfig": { + "trigger": "click", + "mode": "cell", + "showStatus": true + }, + "columns": [ + { + "type": "radio", + "width": 60 + }, + { + "field": "employees", + "title": "规格名称" + }, + { + "field": "created_date", + "title": "vCPUs | 内存(GiB)", + "sortable": true + }, + { + "field": "city", + "title": "CPU", + "sortable": true + }, + { + "title": "基准 / 最大带宽\t", + "sortable": true + }, + { + "title": "内网收发包", + "sortable": true + } + ], + "data": [ + { + "id": "1", + "name": "GFD科技有限公司", + "city": "福州", + "employees": 800, + "created_date": "2014-04-30 00:56:00", + "boole": false + }, + { + "id": "2", + "name": "WWW科技有限公司", + "city": "深圳", + "employees": 300, + "created_date": "2016-07-08 12:36:22", + "boole": true + } + ], + "style": "margin-top: 12px; border-radius: 0px;", + "auto-resize": true + }, + "id": "77701c25" + }, + { + "componentName": "div", + "props": { + "style": "margin-top: 12px; border-radius: 0px;" + }, + "id": "3339838b", + "children": [ + { + "componentName": "Text", + "props": { + "text": "当前规格", + "style": "width: 150px; display: inline-block;" + }, + "id": "203b012b" + }, + { + "componentName": "Text", + "props": { + "text": "通用计算型 | Si2.large.2 | 2vCPUs | 4 GiB", + "style": "font-weight: 700;" + }, + "id": "87723f52" + } + ] + } + ] + } + ], + "id": "657fb2fc" + } + ], + "id": "d19b15cf" + } + ], + "id": "9991228b" + }, + { + "componentName": "div", + "props": { + "style": "border-width: 1px; border-style: solid; border-radius: 4px; border-color: #fff; padding-top: 10px; padding-bottom: 10px; padding-left: 10px; padding-right: 10px; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px; background-color: #fff; margin-bottom: 10px;" + }, + "children": [ + { + "componentName": "TinyForm", + "props": { + "labelWidth": "80px", + "labelPosition": "top", + "inline": false, + "label-position": "left ", + "label-width": "150px", + "style": "border-radius: 0px;" + }, + "children": [ + { + "componentName": "TinyFormItem", + "props": { + "label": "镜像", + "style": "border-radius: 0px;" + }, + "children": [ + { + "componentName": "TinyButtonGroup", + "props": { + "data": [ + { + "text": "公共镜像", + "value": "1" + }, + { + "text": "私有镜像", + "value": "2" + }, + { + "text": "共享镜像", + "value": "3" + } + ], + "modelValue": "1" + }, + "id": "922b14cb" + }, + { + "componentName": "div", + "props": { + "style": "display: flex; margin-top: 12px; border-radius: 0px;" + }, + "id": "6b679524", + "children": [ + { + "componentName": "TinySelect", + "props": { + "modelValue": "", + "placeholder": "请选择", + "options": [ + { + "value": "1", + "label": "黄金糕" + }, + { + "value": "2", + "label": "双皮奶" + } + ], + "style": "width: 170px; margin-right: 10px;" + }, + "id": "4851fff7" + }, + { + "componentName": "TinySelect", + "props": { + "modelValue": "", + "placeholder": "请选择", + "options": [ + { + "value": "1", + "label": "黄金糕" + }, + { + "value": "2", + "label": "双皮奶" + } + ], + "style": "width: 340px;" + }, + "id": "a7183eb7" + } + ] + }, + { + "componentName": "div", + "props": { + "style": "margin-top: 12px;" + }, + "id": "57aee314", + "children": [ + { + "componentName": "Text", + "props": { + "text": "请注意操作系统的语言类型。", + "style": "color: #e37d29;" + }, + "id": "56d36c27" + } + ] + } + ], + "id": "e3b02436" + } + ], + "id": "59aebf2b" + } + ], + "id": "87ff7b99" + }, + { + "componentName": "div", + "props": { + "style": "border-width: 1px; border-style: solid; border-radius: 4px; border-color: #fff; padding-top: 10px; padding-bottom: 10px; padding-left: 10px; padding-right: 10px; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px; background-color: #fff; margin-bottom: 10px;" + }, + "children": [ + { + "componentName": "TinyForm", + "props": { + "labelWidth": "80px", + "labelPosition": "top", + "inline": false, + "label-position": "left ", + "label-width": "150px", + "style": "border-radius: 0px;" + }, + "children": [ + { + "componentName": "TinyFormItem", + "props": { + "label": "系统盘", + "style": "border-radius: 0px;" + }, + "children": [ + { + "componentName": "div", + "props": { + "style": "display: flex;" + }, + "id": "cddba5b8", + "children": [ + { + "componentName": "TinySelect", + "props": { + "modelValue": "", + "placeholder": "请选择", + "options": [ + { + "value": "1", + "label": "黄金糕" + }, + { + "value": "2", + "label": "双皮奶" + } + ], + "style": "width: 200px; margin-right: 10px;" + }, + "id": "a97fbe15" + }, + { + "componentName": "TinyInput", + "props": { + "placeholder": "请输入", + "modelValue": "", + "style": "width: 120px; margin-right: 10px;" + }, + "id": "1cde4c0f" + }, + { + "componentName": "Text", + "props": { + "text": "GiB \nIOPS上限240,IOPS突发上限5,000", + "style": "color: #575d6c; font-size: 12px;" + }, + "id": "2815d82d" + } + ] + } + ], + "id": "50239a3a" + } + ], + "id": "e8582986" + }, + { + "componentName": "TinyForm", + "props": { + "labelWidth": "80px", + "labelPosition": "top", + "inline": false, + "label-position": "left ", + "label-width": "150px", + "style": "border-radius: 0px;" + }, + "children": [ + { + "componentName": "TinyFormItem", + "props": { + "label": "数据盘", + "style": "border-radius: 0px;" + }, + "children": [ + { + "componentName": "div", + "props": { + "style": "margin-top: 12px; display: flex;" + }, + "id": "728c9825", + "children": [ + { + "componentName": "Icon", + "props": { + "style": "margin-right: 10px; width: 16px; height: 16px;", + "name": "IconPanelMini" + }, + "id": "fded6930" + }, + { + "componentName": "TinySelect", + "props": { + "modelValue": "", + "placeholder": "请选择", + "options": [ + { + "value": "1", + "label": "黄金糕" + }, + { + "value": "2", + "label": "双皮奶" + } + ], + "style": "width: 200px; margin-right: 10px;" + }, + "id": "62734e3f" + }, + { + "componentName": "TinyInput", + "props": { + "placeholder": "请输入", + "modelValue": "", + "style": "width: 120px; margin-right: 10px;" + }, + "id": "667c7926" + }, + { + "componentName": "Text", + "props": { + "text": "GiB \nIOPS上限600,IOPS突发上限5,000", + "style": "color: #575d6c; font-size: 12px; margin-right: 10px;" + }, + "id": "e7bc36d6" + }, + { + "componentName": "TinyInput", + "props": { + "placeholder": "请输入", + "modelValue": "", + "style": "width: 120px;" + }, + "id": "1bd56dc0" + } + ], + "loop": { + "type": "JSExpression", + "value": "this.state.dataDisk" + } + }, + { + "componentName": "div", + "props": { + "style": "display: flex; margin-top: 12px; border-radius: 0px;" + }, + "children": [ + { + "componentName": "Icon", + "props": { + "name": "IconPlus", + "style": "width: 16px; height: 16px; margin-right: 10px;" + }, + "id": "65c89f2b" + }, + { + "componentName": "Text", + "props": { + "text": "增加一块数据盘", + "style": "font-size: 12px; border-radius: 0px; margin-right: 10px;" + }, + "id": "cb344071" + }, + { + "componentName": "Text", + "props": { + "text": "您还可以挂载 21 块磁盘(云硬盘)", + "style": "color: #8a8e99; font-size: 12px;" + }, + "id": "80eea996" + } + ], + "id": "e9e530ab" + } + ], + "id": "078e03ef" + } + ], + "id": "ccef886e" + } + ], + "id": "0fb7bd74" + }, + { + "componentName": "div", + "props": { + "style": "border-width: 1px; border-style: solid; border-color: #ffffff; padding-top: 10px; padding-left: 10px; padding-right: 10px; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px; background-color: #fff; position: fixed; inset: auto 0% 0% 0%; height: 80px; line-height: 80px; border-radius: 0px;" + }, + "children": [ + { + "componentName": "TinyForm", + "props": { + "labelWidth": "80px", + "labelPosition": "top", + "inline": false, + "label-position": "left ", + "label-width": "150px", + "style": "border-radius: 0px;" + }, + "children": [], + "id": "21ed4475" + }, + { + "componentName": "TinyRow", + "props": { + "style": "border-radius: 0px; height: 100%;" + }, + "children": [ + { + "componentName": "TinyCol", + "props": { + "span": "8" + }, + "id": "b9d051a5", + "children": [ + { + "componentName": "TinyRow", + "props": { + "style": "border-radius: 0px;" + }, + "children": [ + { + "componentName": "TinyCol", + "props": { + "span": "5", + "style": "display: flex;" + }, + "id": "02352776", + "children": [ + { + "componentName": "Text", + "props": { + "text": "购买量", + "style": "margin-right: 10px;" + }, + "id": "0cd9ed5c" + }, + { + "componentName": "TinyInput", + "props": { + "placeholder": "请输入", + "modelValue": "", + "style": "width: 120px; margin-right: 10px;" + }, + "id": "2f9cf442" + }, + { + "componentName": "Text", + "props": { + "text": "台" + }, + "id": "facd4481" + } + ] + }, + { + "componentName": "TinyCol", + "props": { + "span": "7" + }, + "id": "82b6c659", + "children": [ + { + "componentName": "div", + "props": {}, + "id": "9cd65874", + "children": [ + { + "componentName": "Text", + "props": { + "text": "配置费用", + "style": "font-size: 12px;" + }, + "id": "b5a0a0da" + }, + { + "componentName": "Text", + "props": { + "text": "¥1.5776", + "style": "padding-left: 10px; padding-right: 10px; color: #de504e;" + }, + "id": "d9464214" + }, + { + "componentName": "Text", + "props": { + "text": "/小时", + "style": "font-size: 12px;" + }, + "id": "af7cc5e6" + } + ] + }, + { + "componentName": "div", + "props": {}, + "id": "89063830", + "children": [ + { + "componentName": "Text", + "props": { + "text": "参考价格,具体扣费请以账单为准。", + "style": "font-size: 12px; border-radius: 0px;" + }, + "id": "d8995fbc" + }, + { + "componentName": "Text", + "props": { + "text": "了解计费详情", + "style": "font-size: 12px; color: #344899;" + }, + "id": "b383c3e2" + } + ] + } + ] + } + ], + "id": "94fc0e43" + } + ] + }, + { + "componentName": "TinyCol", + "props": { + "span": "4", + "style": "display: flex; flex-direction: row-reverse; border-radius: 0px; height: 100%; justify-content: flex-start; align-items: center;" + }, + "id": "10b73009", + "children": [ + { + "componentName": "TinyButton", + "props": { + "text": "下一步: 网络配置", + "type": "danger", + "style": "max-width: unset;" + }, + "id": "0b584011" + } + ] + } + ], + "id": "d414a473" + } + ], + "id": "e8ec029b" + } + ], + "fileName": "createVm", + "meta": { + "id": 1977, + "parentId": "0", + "group": "staticPages", + "occupier": { + "id": 86, + "username": "开发者", + "email": "developer@lowcode.com", + "provider": null, + "password": null, + "resetPasswordToken": "developer", + "confirmationToken": "dfb2c162-351f-4f44-ad5f-899831311129", + "confirmed": true, + "blocked": null, + "role": null, + "created_by": null, + "updated_by": null, + "created_at": "2022-05-27T16:50:44.000Z", + "updated_at": "2022-05-27T16:50:44.000Z", + "block": null, + "is_admin": true, + "is_public": null + }, + "isHome": false, + "router": "createVm", + "rootElement": "div", + "creator": "", + "gmt_create": "2022-07-21 03:08:20", + "gmt_modified": "2022-07-21 05:18:26" + } + } + ], + "componentsMap": [ + { + "componentName": "TinyCarouselItem", + "package": "@opentiny/vue", + "exportName": "CarouselItem", + "destructuring": true, + "version": "0.1.16" + }, + { + "componentName": "TinyCheckboxButton", + "package": "@opentiny/vue", + "exportName": "CheckboxButton", + "destructuring": true, + "version": "0.1.17" + }, + { + "componentName": "TinyTree", + "package": "@opentiny/vue", + "exportName": "Tree", + "destructuring": true, + "version": "0.1.16" + }, + { + "componentName": "TinyPopover", + "package": "@opentiny/vue", + "exportName": "Popover", + "destructuring": true, + "version": "0.1.16" + }, + { + "componentName": "TinyTooltip", + "package": "@opentiny/vue", + "exportName": "Tooltip", + "destructuring": true, + "version": "3.2.0" + }, + { + "componentName": "TinyCol", + "package": "@opentiny/vue", + "exportName": "Col", + "destructuring": true, + "version": "0.1.16" + }, + { + "componentName": "TinyDropdownItem", + "package": "@opentiny/vue", + "exportName": "DropdownItem", + "destructuring": true, + "version": "0.1.16" + }, + { + "componentName": "TinyPager", + "package": "@opentiny/vue", + "exportName": "Pager", + "destructuring": true, + "version": "0.1.16" + }, + { + "componentName": "TinyPlusAccessdeclined", + "package": "@opentiny/vue", + "exportName": "AccessDeclined", + "destructuring": true, + "version": "3.4.1" + }, + { + "componentName": "TinyPlusFrozenPage", + "package": "@opentiny/vuee", + "exportName": "FrozenPage", + "destructuring": true, + "version": "3.4.1" + }, + { + "componentName": "TinyPlusNonSupportRegion", + "package": "@opentiny/vue", + "exportName": "NonSupportRegion", + "destructuring": true, + "version": "3.4.1" + }, + { + "componentName": "TinyPlusBeta", + "package": "@opentiny/vue", + "exportName": "Beta", + "destructuring": true, + "version": "3.4.1" + }, + { + "componentName": "TinySearch", + "package": "@opentiny/vue", + "exportName": "Search", + "destructuring": true, + "version": "0.1.13" + }, + { + "componentName": "TinyRow", + "package": "@opentiny/vue", + "exportName": "Row", + "destructuring": true, + "version": "0.1.16" + }, + { + "componentName": "TinyFormItem", + "package": "@opentiny/vue", + "exportName": "FormItem", + "destructuring": true, + "version": "0.1.16" + }, + { + "componentName": "TinyAlert", + "package": "@opentiny/vue", + "exportName": "Alert", + "destructuring": true, + "version": "3.2.0" + }, + { + "componentName": "TinyInput", + "package": "@opentiny/vue", + "exportName": "Input", + "destructuring": true, + "version": "0.1.16" + }, + { + "componentName": "TinyTabs", + "package": "@opentiny/vue", + "exportName": "Tabs", + "destructuring": true, + "version": "0.1.16" + }, + { + "componentName": "TinyDropdownMenu", + "package": "@opentiny/vue", + "exportName": "DropdownMenu", + "destructuring": true, + "version": "0.1.16" + }, + { + "componentName": "TinyDialogBox", + "package": "@opentiny/vue", + "exportName": "DialogBox", + "destructuring": true, + "version": "3.2.0" + }, + { + "componentName": "TinySwitch", + "package": "@opentiny/vue", + "exportName": "Switch", + "destructuring": true, + "version": "0.1.16" + }, + { + "componentName": "TinyTimeLine", + "package": "@opentiny/vue", + "exportName": "TimeLine", + "destructuring": true, + "version": "0.1.16" + }, + { + "componentName": "TinyTabItem", + "package": "@opentiny/vue", + "exportName": "TabItem", + "destructuring": true, + "version": "0.1.16" + }, + { + "componentName": "TinyRadio", + "package": "@opentiny/vue", + "exportName": "Radio", + "destructuring": true, + "version": "0.1.16" + }, + { + "componentName": "TinyForm", + "package": "@opentiny/vue", + "exportName": "Form", + "destructuring": true, + "version": "0.1.16" + }, + { + "componentName": "TinyGrid", + "package": "@opentiny/vue", + "exportName": "Grid", + "destructuring": true, + "version": "0.1.16" + }, + { + "componentName": "TinyNumeric", + "package": "@opentiny/vue", + "exportName": "Numeric", + "destructuring": true, + "version": "0.1.16" + }, + { + "componentName": "TinyCheckboxGroup", + "package": "@opentiny/vue", + "exportName": "CheckboxGroup", + "destructuring": true, + "version": "0.1.17" + }, + { + "componentName": "TinySelect", + "package": "@opentiny/vue", + "exportName": "Select", + "destructuring": true, + "version": "0.1.16" + }, + { + "componentName": "TinyButtonGroup", + "package": "@opentiny/vue", + "exportName": "ButtonGroup", + "destructuring": true, + "version": "0.1.16" + }, + { + "componentName": "TinyCarousel", + "package": "@opentiny/vue", + "exportName": "Carousel", + "destructuring": true, + "version": "0.1.16" + }, + { + "componentName": "TinyPopeditor", + "package": "@opentiny/vue", + "exportName": "Popeditor", + "destructuring": true, + "version": "0.1.16" + }, + { + "componentName": "TinyDatePicker", + "package": "@opentiny/vue", + "exportName": "DatePicker", + "destructuring": true, + "version": "0.1.16" + }, + { + "componentName": "TinyDropdown", + "package": "@opentiny/vue", + "exportName": "Dropdown", + "destructuring": true, + "version": "0.1.20" + }, + { + "componentName": "TinyChartHistogram", + "package": "@opentiny/vue", + "exportName": "ChartHistogram", + "destructuring": true, + "version": "0.1.16" + }, + { + "componentName": "PortalHome", + "main": "common/components/home", + "destructuring": false, + "version": "1.0.0" + }, + { + "componentName": "PreviewBlock1", + "main": "preview", + "destructuring": false, + "version": "1.0.0" + }, + { + "componentName": "PortalHeader", + "main": "common", + "destructuring": false, + "version": "1.0.0" + }, + { + "componentName": "PortalBlock", + "main": "portal", + "destructuring": false, + "version": "1.0.0" + }, + { + "componentName": "PortalPermissionBlock", + "main": "", + "destructuring": false, + "version": "1.0.0" + } + ], + "bridge": [], + "utils": [ + { + "name": "axios", + "type": "npm", + "content": { + "type": "JSFunction", + "value": "", + "package": "axios", + "destructuring": false, + "exportName": "axios" + } + }, + { + "name": "Button", + "type": "npm", + "content": { + "package": "@opentiny/vue", + "version": "", + "exportName": "Button", + "subName": "", + "destructuring": true, + "main": "" + } + }, + { + "name": "Menu", + "type": "npm", + "content": { + "type": "JSFunction", + "value": "", + "package": "@opentiny/vue", + "exportName": "NavMenu", + "destructuring": true + } + }, + { + "name": "Modal ", + "type": "npm", + "content": { + "package": "@opentiny/vue", + "version": "", + "exportName": "Modal ", + "subName": "", + "destructuring": true, + "main": "" + } + }, + { + "name": "npm", + "type": "function", + "content": { + "type": "JSFunction", + "value": "''" + } + }, + { + "name": "Pager", + "type": "npm", + "content": { + "package": "@opentiny/vue", + "version": "", + "exportName": "Pager", + "subName": "", + "destructuring": true, + "main": "" + } + }, + { + "name": "test", + "type": "function", + "content": { + "type": "JSFunction", + "value": "function test() {\r\n return 'test'\r\n}" + } + }, + { + "name": "util", + "type": "function", + "content": { + "type": "JSFunction", + "value": "function util () {\r\n console.log(321)\r\n}" + } + } + ], + "config": { + "sdkVersion": "1.0.3", + "historyMode": "hash", + "targetRootID": "app" + }, + "constants": "", + "css": "", + "version": "" + }, + "locale": "zh-cn" +} diff --git a/mockServer/src/mock/get/platform-center/courses.json b/mockServer/src/mock/get/platform-center/courses.json new file mode 100644 index 000000000..dcd1c3bc6 --- /dev/null +++ b/mockServer/src/mock/get/platform-center/courses.json @@ -0,0 +1,148 @@ +{ + "data": [ + { + "id": 37, + "createdBy": { + "id": 86, + "username": "开发者", + "email": "developer@lowcode.com", + "resetPasswordToken": "developer", + "blocked": null, + "created_at": "2022-05-27T16:50:44.000Z", + "updated_at": "2022-05-27T16:50:44.000Z", + "block": null, + "is_admin": true, + "is_public": null + }, + "updatedBy": { + "id": 86, + "username": "开发者", + "email": "developer@lowcode.com", + "resetPasswordToken": "developer", + "blocked": null, + "created_at": "2022-05-27T16:50:44.000Z", + "updated_at": "2022-05-27T16:50:44.000Z", + "block": null, + "is_admin": true, + "is_public": null + }, + "created_at": "2023-08-17T02:40:06.000Z", + "updated_at": "2023-08-17T02:40:21.000Z", + "category": "appDev", + "name": "ai生成简单页面教程", + "desc": "", + "poster": "http://localhost:9090/assets/images/0055f57e0a38d45ced54e1b2b566cb29_308x180.jpg", + "type": "advanced", + "tags": "", + "variety": "solution", + "videos": [], + "progress": 0 + }, + { + "id": 34, + "createdBy": { + "id": 108, + "username": "张三", + "email": "xyz@email.com", + "resetPasswordToken": "工号xxxxxx", + "blocked": null, + "created_at": "2022-06-22T08:20:55.000Z", + "updated_at": "2022-12-08T07:29:41.000Z", + "block": null, + "is_admin": false, + "is_public": null + }, + "updatedBy": { + "id": 108, + "username": "张三", + "email": "xyz@email.com", + "resetPasswordToken": "工号xxxxxx", + "blocked": null, + "created_at": "2022-06-22T08:20:55.000Z", + "updated_at": "2022-12-08T07:29:41.000Z", + "block": null, + "is_admin": false, + "is_public": null + }, + "created_at": "2022-08-27T07:29:49.000Z", + "updated_at": "2022-08-27T07:29:49.000Z", + "category": "appDev", + "name": "如何加入组织", + "desc": "讲解如何加入已有组织,如何创建自己的组织", + "poster": "http://localhost:9090/assets/images/627366463067fa2f1a59d7db4ac55885_308x100.jpg", + "type": "introductory", + "tags": ["入门", "最新"], + "variety": "manual", + "videos": [ + { + "id": 72, + "courseId": 34, + "title": "申请加入组织", + "video": "http://localhost:9090/assets/videos/tiny-engine.mp4", + "docs": "TinyEngine简介", + "created_at": "2022-08-27T07:29:49.000Z", + "updated_at": "2022-08-27T07:29:49.000Z" + }, + { + "id": 73, + "courseId": 34, + "title": "创建平台", + "video": "http://localhost:9090/assets/videos/tiny-engine.mp4", + "docs": "fdsa", + "created_at": "2022-08-27T07:29:49.000Z", + "updated_at": "2022-08-27T07:29:49.000Z" + } + ], + "progress": 0 + }, + { + "id": 28, + "createdBy": { + "id": 169, + "username": "张三", + "email": "xyz@email.com", + "resetPasswordToken": "工号xxxxxx", + "blocked": null, + "created_at": "2022-07-04T07:25:53.000Z", + "updated_at": "2022-09-27T11:48:34.000Z", + "block": null, + "is_admin": true, + "is_public": true + }, + "updatedBy": { + "id": 169, + "username": "张三", + "email": "xyz@email.com", + "resetPasswordToken": "工号xxxxxx", + "blocked": null, + "created_at": "2022-07-04T07:25:53.000Z", + "updated_at": "2022-09-27T11:48:34.000Z", + "block": null, + "is_admin": true, + "is_public": true + }, + "created_at": "2022-08-10T08:38:06.000Z", + "updated_at": "2022-08-11T03:44:28.000Z", + "category": "appDev", + "name": "实战课程", + "desc": "实战课程", + "poster": "http://localhost:9090/assets/images/777aad0c570f653f0a95b48b898c7b4b_308x180.jpg", + "type": "practical", + "tags": "", + "variety": "manual", + "videos": [ + { + "id": 66, + "courseId": 28, + "title": "从零搭建一个页面", + "video": "http://localhost:9090/assets/videos/in-action.mp4", + "docs": "", + "created_at": "2022-08-10T08:38:06.000Z", + "updated_at": "2022-08-10T08:38:06.000Z" + } + ], + "progress": 0 + } + ], + "locale": "zh-cn" +} diff --git a/mockServer/src/mock/get/platform-center/user/me.json b/mockServer/src/mock/get/platform-center/user/me.json new file mode 100644 index 000000000..c1876b8df --- /dev/null +++ b/mockServer/src/mock/get/platform-center/user/me.json @@ -0,0 +1,57 @@ +{ + "data": { + "id": 86, + "username": "开发者", + "email": "developer@lowcode.com", + "provider": null, + "password": null, + "resetPasswordToken": "developer", + "confirmationToken": "uuid~dfafasdfasdfa", + "confirmed": true, + "blocked": null, + "role": null, + "created_by": null, + "updated_by": null, + "created_at": "2021-11-11T13:52:21.000Z", + "updated_at": "2022-11-01T01:39:30.000Z", + "block": null, + "is_admin": true, + "is_public": null, + "tenant": { + "id": "1" + }, + "auths": [ + { + "id": 265, + "unit": { + "type": "tenant", + "id": 1, + "name": "public" + }, + "auth_type": null, + "expired_time": null, + "role": { + "name": "Tinybuilder_Tenant_Admin", + "id": 6, + "description": "组织管理员" + } + } + ], + "tenants": [ + { + "id": 1, + "tenant_id": "public", + "name_cn": "公共租户", + "name_en": "Public Tenant", + "description": "Default tenant for new user to explore.", + "created_by": null, + "updated_by": null, + "created_at": "2021-12-28T11:39:10.000Z", + "updated_at": "2023-02-09T08:23:00.000Z", + "createdBy": null, + "updatedBy": 86 + } + ] + }, + "locale": "zh-cn" +} diff --git a/mockServer/src/mock/post/app-center/apps/extension/create.json b/mockServer/src/mock/post/app-center/apps/extension/create.json new file mode 100644 index 000000000..9c6b044fe --- /dev/null +++ b/mockServer/src/mock/post/app-center/apps/extension/create.json @@ -0,0 +1 @@ +{ "data": [], "locale": "zh-cn" } diff --git a/mockServer/src/mock/post/app-center/apps/extension/update.json b/mockServer/src/mock/post/app-center/apps/extension/update.json new file mode 100644 index 000000000..9c6b044fe --- /dev/null +++ b/mockServer/src/mock/post/app-center/apps/extension/update.json @@ -0,0 +1 @@ +{ "data": [], "locale": "zh-cn" } diff --git a/mockServer/src/mock/post/app-center/apps/update/918.json b/mockServer/src/mock/post/app-center/apps/update/918.json new file mode 100644 index 000000000..9c6b044fe --- /dev/null +++ b/mockServer/src/mock/post/app-center/apps/update/918.json @@ -0,0 +1 @@ +{ "data": [], "locale": "zh-cn" } diff --git a/mockServer/src/mock/post/app-center/i18n/entries/bulk/delete.json b/mockServer/src/mock/post/app-center/i18n/entries/bulk/delete.json new file mode 100644 index 000000000..9c6b044fe --- /dev/null +++ b/mockServer/src/mock/post/app-center/i18n/entries/bulk/delete.json @@ -0,0 +1 @@ +{ "data": [], "locale": "zh-cn" } diff --git a/mockServer/src/mock/post/app-center/i18n/entries/update.json b/mockServer/src/mock/post/app-center/i18n/entries/update.json new file mode 100644 index 000000000..9c6b044fe --- /dev/null +++ b/mockServer/src/mock/post/app-center/i18n/entries/update.json @@ -0,0 +1 @@ +{ "data": [], "locale": "zh-cn" } diff --git a/mockServer/src/mock/post/app-center/sources/create.json b/mockServer/src/mock/post/app-center/sources/create.json new file mode 100644 index 000000000..9c6b044fe --- /dev/null +++ b/mockServer/src/mock/post/app-center/sources/create.json @@ -0,0 +1 @@ +{ "data": [], "locale": "zh-cn" } diff --git a/mockServer/src/mock/post/app-center/sources/delete.json b/mockServer/src/mock/post/app-center/sources/delete.json new file mode 100644 index 000000000..9c6b044fe --- /dev/null +++ b/mockServer/src/mock/post/app-center/sources/delete.json @@ -0,0 +1 @@ +{ "data": [], "locale": "zh-cn" } diff --git a/mockServer/src/mock/post/app-center/sources/update.json b/mockServer/src/mock/post/app-center/sources/update.json new file mode 100644 index 000000000..284dfe680 --- /dev/null +++ b/mockServer/src/mock/post/app-center/sources/update.json @@ -0,0 +1,69 @@ +{ + "data": { + "id": 133, + "name": "getAllList", + "data": { + "columns": [ + { + "name": "test", + "title": "测试", + "field": "test", + "type": "string", + "format": {} + }, + { + "name": "test1", + "title": "测试1", + "field": "test1", + "type": "string", + "format": {} + } + ], + "type": "array", + "data": [ + { + "test": "test1", + "test1": "test1", + "_id": "341efc48" + }, + { + "test": "test2", + "test1": "test1", + "_id": "b86b516c" + }, + { + "test": "test3", + "test1": "test1", + "_id": "f680cd78" + } + ], + "options": { + "uri": "/app-center/api/sources/list/918", + "isSync": true, + "method": "GET" + }, + "dataHandler": { + "type": "JSFunction", + "value": "function dataHandler(data) { \n return data \n}" + }, + "willFetch": { + "type": "JSFunction", + "value": "function willFetch(option) {\n return option \n}" + }, + "shouldFetch": { + "type": "JSFunction", + "value": "function shouldFetch(option) {\n return true \n}" + }, + "errorHandler": { + "type": "JSFunction", + "value": "function errorHandler(err) {}" + } + }, + "tpl": null, + "app": "918", + "desc": null, + "created_at": "2022-06-28T07:32:16.000Z", + "updated_at": "2023-01-19T03:29:11.000Z" + }, + "locale": "zh-cn" +} diff --git a/mockServer/src/routes/error-routes.js b/mockServer/src/routes/error-routes.js new file mode 100644 index 000000000..aca35329c --- /dev/null +++ b/mockServer/src/routes/error-routes.js @@ -0,0 +1,24 @@ +/** +* Copyright (c) 2023 - present TinyEngine Authors. +* Copyright (c) 2023 - present Huawei Cloud Computing Technologies Co., Ltd. +* +* Use of this source code is governed by an MIT-style license. +* +* THE OPEN SOURCE SOFTWARE IN THIS PRODUCT IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, +* BUT WITHOUT ANY WARRANTY, WITHOUT EVEN THE IMPLIED WARRANTY OF MERCHANTABILITY OR FITNESS FOR +* A PARTICULAR PURPOSE. SEE THE APPLICABLE LICENSES FOR MORE DETAILS. +* +*/ + +module.exports = function () { + return function (ctx, next) { + switch (ctx.status) { + case 404: + ctx.body = '没有找到内容 - 404' + break + default: + break + } + return next() + } +} diff --git a/mockServer/src/routes/main-routes.js b/mockServer/src/routes/main-routes.js new file mode 100644 index 000000000..06280c494 --- /dev/null +++ b/mockServer/src/routes/main-routes.js @@ -0,0 +1,227 @@ +/** + * Copyright (c) 2023 - present TinyEngine Authors. + * Copyright (c) 2023 - present Huawei Cloud Computing Technologies Co., Ltd. + * + * Use of this source code is governed by an MIT-style license. + * + * THE OPEN SOURCE SOFTWARE IN THIS PRODUCT IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, + * BUT WITHOUT ANY WARRANTY, WITHOUT EVEN THE IMPLIED WARRANTY OF MERCHANTABILITY OR FITNESS FOR + * A PARTICULAR PURPOSE. SEE THE APPLICABLE LICENSES FOR MORE DETAILS. + * + */ + +import fs from 'fs-extra' +import * as glob from 'glob' +import KoaRouter from 'koa-router' +import path from 'path' +import MockService from '../services/mockService' +import { getResponseData } from '../tool/Common' + +const router = new KoaRouter() +export const mockService = new MockService() +const getJsonPathData = (jpath, method = 'get') => { + const usefulPath = jpath.split(`${method}${path.sep}`)[1] + const apipath = usefulPath.split(path.sep) + const lastSegment = apipath[apipath.length - 1] + const lastdirname = lastSegment.split('.')[0] + apipath[apipath.length - 1] = lastdirname + const [center, version, ...routes] = apipath + let api = '' + if (version === 'v1') { + api = `/${center}/${version}/api/${routes.join('/')}` + } else { + api = `/${center}/api/${version}/${routes.join('/')}` + } + const data = fs.readJSONSync(path.resolve(__dirname, path.relative(__dirname, jpath))) + return { + api, + data + } +} + +const mockPath = path.resolve(__dirname, '../mock') +// 注册路由 +glob.globSync(`${mockPath}/get/**/*.json`).forEach((jpath) => { + const { api, data } = getJsonPathData(jpath) + router.get(api, (ctx, next) => { + ctx.body = data + }) +}) + +glob.globSync(`${mockPath}/post/**/*.json`).forEach((jpath) => { + const { api, data } = getJsonPathData(jpath, 'post') + router.post(api, (ctx, next) => { + ctx.body = data + }) +}) + +router.get('/app-center/api/apps/canvas/lock', async (ctx) => { + ctx.body = await mockService.appService.lock(ctx.request.query) +}) + +router.post('/app-center/api/schema2code', (ctx) => { + const { pageInfo } = ctx.request.body + ctx.body = mockService.schema2codeService.schema2code(pageInfo) +}) + +router.get('/app-center/api/preview/metadata', (ctx) => { + ctx.body = mockService.appService.getAppPreviewMetaData() +}) + +router.post('/app-center/api/pages/create', async (ctx) => { + ctx.body = await mockService.pageService.create(ctx.request.body) +}) + +router.post('/app-center/api/pages/update/:id', async (ctx) => { + const { id } = ctx.params + const { body } = ctx.request + ctx.body = await mockService.pageService.update(id, body) +}) + +router.get('/app-center/api/pages/list/:appId', async (ctx) => { + const { appId } = ctx.params + ctx.body = await mockService.pageService.list(appId) +}) + +router.get('/app-center/api/pages/detail/:id', async (ctx) => { + const { id } = ctx.params + ctx.body = await mockService.pageService.detail(id) +}) + +router.get('/app-center/api/pages/delete/:id', async (ctx) => { + const { id } = ctx.params + ctx.body = await mockService.pageService.delete(id) +}) + +router.get('/material-center/api/block/detail/:id', async (ctx) => { + const { id } = ctx.params + ctx.body = await mockService.blockService.detail(id) +}) + +router.get('/material-center/api/blocks', async (ctx) => { + const { appId } = ctx.params + ctx.body = await mockService.blockService.list(appId) +}) + +router.post('/material-center/api/block/create', async (ctx) => { + const result = mockService.blockService.create(ctx.request.body) + const categoriesId = ctx.request.body.categories[0] + const _id = result.id + await mockService.blockCategoryService.update(categoriesId, { _id }) + ctx.body = getResponseData(result) +}) + +router.post('/material-center/api/block/update/:id', async (ctx) => { + const { id } = ctx.params + const { body } = ctx.request + ctx.body = await mockService.blockService.update(id, body) +}) + +router.get('/material-center/api/block/delete/:id', async (ctx) => { + const { id } = ctx.params + ctx.body = await mockService.blockService.delete(id) +}) + +router.post('/material-center/api/block-groups/create', async (ctx) => { + ctx.body = await mockService.blockGroupService.create(ctx.request.body) +}) + +router.post('/material-center/api/block-groups/update/:id', async (ctx) => { + const { id } = ctx.params + const { body } = ctx.request + ctx.body = await mockService.blockGroupService.update(id, body) +}) + +router.get('/material-center/api/block-groups/delete/:id', async (ctx) => { + const { id } = ctx.params + ctx.body = await mockService.blockGroupService.delete(id) +}) + +router.get('/material-center/api/block-groups', async (ctx) => { + const result = await mockService.blockGroupService.find(ctx.query) + let blockGroup + if (result.data.length === 0) { + ctx.body = result + } else if (result.data.length > 1) { + blockGroup = await Promise.all( + result.data.map(async (group) => { + group.blocks = await Promise.all( + group.blocks.map(async (block) => { + const blockData = await mockService.blockService.detail(block.id) + return blockData + }) + ) + return group + }) + ) + ctx.body = getResponseData(blockGroup) + } else if (result.data.length === 1) { + blockGroup = result.data[0] + const blocks = await Promise.all( + blockGroup.blocks.map(async (item) => { + const blockData = await mockService.blockService.detail(item) + return blockData + }) + ) + + blockGroup.blocks = blocks + ctx.body = getResponseData([blockGroup]) + } +}) + +router.post('/material-center/api/block-categories', async (ctx) => { + ctx.body = await mockService.blockCategoryService.create(ctx.request.body) +}) + +router.put('/material-center/api/block-categories/:id', async (ctx) => { + const { id } = ctx.params + const { body } = ctx.request + ctx.body = await mockService.blockCategoryService.update(id, body) +}) + +router.delete('/material-center/api/block-categories/:id', async (ctx) => { + const { id } = ctx.params + ctx.body = await mockService.blockCategoryService.delete(id) +}) + +router.get('/material-center/api/block-categories', async (ctx) => { + const result = await mockService.blockCategoryService.find(ctx.query) + const blockCategories = await Promise.all( + result.data.map(async (group) => { + const blocks = await Promise.all( + group.blocks.map(async (block) => { + const blockData = await mockService.blockService.detail(block) + return blockData + }) + ) + group.blocks = blocks + return group + }) + ) + ctx.body = getResponseData(blockCategories) +}) + +router.get('/app-center/api/sources/detail/:id', async (ctx) => { + const { id } = ctx.params + ctx.body = await mockService.sourceService.detail(id) +}) + +router.post('/material-center/api/block/deploy', async (ctx) => { + ctx.body = await mockService.blockBuildService.build(ctx.request.body) +}) + +router.get('/material-center/api/tasks/:id', async (ctx) => { + const { id } = ctx.params + ctx.body = await mockService.taskService.detail(id) +}) + +router.get('/block-history', async (ctx) => { + const { id } = ctx.params + ctx.body = await mockService.blockHistoryService.find(id) +}) + +router.post('block-history/create', async (ctx) => { + ctx.body = await mockService.blockHistoryService.create(ctx.request.body) +}) + +export default router diff --git a/mockServer/src/services/.gitkeep b/mockServer/src/services/.gitkeep new file mode 100644 index 000000000..d00491fd7 --- /dev/null +++ b/mockServer/src/services/.gitkeep @@ -0,0 +1 @@ +1 diff --git a/mockServer/src/services/app.js b/mockServer/src/services/app.js new file mode 100644 index 000000000..60821e43d --- /dev/null +++ b/mockServer/src/services/app.js @@ -0,0 +1,73 @@ +/** +* Copyright (c) 2023 - present TinyEngine Authors. +* Copyright (c) 2023 - present Huawei Cloud Computing Technologies Co., Ltd. +* +* Use of this source code is governed by an MIT-style license. +* +* THE OPEN SOURCE SOFTWARE IN THIS PRODUCT IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, +* BUT WITHOUT ANY WARRANTY, WITHOUT EVEN THE IMPLIED WARRANTY OF MERCHANTABILITY OR FITNESS FOR +* A PARTICULAR PURPOSE. SEE THE APPLICABLE LICENSES FOR MORE DETAILS. +* +*/ + +import { pageService } from '../routes/main-routes' +import { getResponseData } from '../tool/Common' +export default class AppService { + async lock(query) { + const { id, state } = query + const occupier = state === 'occupy' ? pageService.userInfo : null + await pageService.update(id, { occupier }) + return getResponseData({ + operate: 'success', + occupier + }) + } + + // 获取应用预览数据 + getAppPreviewMetaData() { + const appMetaData = require('./appinfo.json') + + const { i18n: i18nEntries, source = [], extension = [], app } = appMetaData + // 拼装数据源 + const dataSource = { + list: source, + dataHandler: app.data_handler + } + // 拼装工具类 + const utils = [] + extension.forEach((item) => { + const { name, type, content, category } = item + const data = { name, type, content } + if (category === 'utils') { + utils.push(data) + } + }) + // 拼装国际化词条 + const entriesData = getResponseData(i18nEntries) + const i18n = this.formatI18nEntrites(entriesData) + return getResponseData({ + dataSource, + globalState: app.global_state, + utils, + i18n + }) + } + + formatI18nEntrites(entriesData) { + const entries = entriesData.data + // 中文和英文作为全局国际化语言,并没有和应用/区块建立关联关系 + const defaultLang = [{ lang: 'en_US' }, { lang: 'zh_CN' }] + + const res = {} + entries.forEach((entry) => { + const { + key, + lang: { lang }, + content + } = entry + res[lang] = res[lang] || {} + res[lang][key] = content + }) + return res + } +} diff --git a/mockServer/src/services/appinfo.json b/mockServer/src/services/appinfo.json new file mode 100644 index 000000000..ab75552f6 --- /dev/null +++ b/mockServer/src/services/appinfo.json @@ -0,0 +1,29712 @@ +{ + "i18n": [ + { + "id": 123, + "key": "lowcode.c257d5e8", + "content": "search", + "host": 918, + "host_type": "app", + "lang": { + "id": 2, + "lang": "en_US", + "label": "美式英文", + "created_by": null, + "updated_by": null, + "created_at": "2022-03-08T08:01:16.000Z", + "updated_at": "2022-03-08T08:01:16.000Z" + }, + "created_by": null, + "updated_by": null, + "created_at": "2022-06-13T08:17:17.000Z", + "updated_at": "2023-05-15T00:48:10.000Z" + }, + { + "id": 124, + "key": "lowcode.c257d5e8", + "content": "查询", + "host": 918, + "host_type": "app", + "lang": { + "id": 1, + "lang": "zh_CN", + "label": "简体中文", + "created_by": null, + "updated_by": null, + "created_at": "2022-03-08T08:00:54.000Z", + "updated_at": "2022-03-08T08:00:54.000Z" + }, + "created_by": null, + "updated_by": null, + "created_at": "2022-06-13T08:17:17.000Z", + "updated_at": "2023-05-15T00:48:10.000Z" + }, + { + "id": 211, + "key": "lowcode.61c8ac8c", + "content": "地方", + "host": 918, + "host_type": "app", + "lang": { + "id": 1, + "lang": "zh_CN", + "label": "简体中文", + "created_by": null, + "updated_by": null, + "created_at": "2022-03-08T08:00:54.000Z", + "updated_at": "2022-03-08T08:00:54.000Z" + }, + "created_by": null, + "updated_by": null, + "created_at": "2022-06-30T08:06:59.000Z", + "updated_at": "2023-05-04T08:06:48.000Z" + }, + { + "id": 212, + "key": "lowcode.61c8ac8c", + "content": "dsdsa", + "host": 918, + "host_type": "app", + "lang": { + "id": 2, + "lang": "en_US", + "label": "美式英文", + "created_by": null, + "updated_by": null, + "created_at": "2022-03-08T08:01:16.000Z", + "updated_at": "2022-03-08T08:01:16.000Z" + }, + "created_by": null, + "updated_by": null, + "created_at": "2022-06-30T08:06:59.000Z", + "updated_at": "2023-05-04T08:06:48.000Z" + }, + { + "id": 229, + "key": "lowcode.f53187a0", + "content": "测试", + "host": 918, + "host_type": "app", + "lang": { + "id": 1, + "lang": "zh_CN", + "label": "简体中文", + "created_by": null, + "updated_by": null, + "created_at": "2022-03-08T08:00:54.000Z", + "updated_at": "2022-03-08T08:00:54.000Z" + }, + "created_by": null, + "updated_by": null, + "created_at": "2022-07-06T11:19:17.000Z", + "updated_at": "2023-07-18T12:33:31.000Z" + }, + { + "id": 230, + "key": "lowcode.f53187a0", + "content": "test", + "host": 918, + "host_type": "app", + "lang": { + "id": 2, + "lang": "en_US", + "label": "美式英文", + "created_by": null, + "updated_by": null, + "created_at": "2022-03-08T08:01:16.000Z", + "updated_at": "2022-03-08T08:01:16.000Z" + }, + "created_by": null, + "updated_by": null, + "created_at": "2022-07-06T11:19:17.000Z", + "updated_at": "2023-07-18T12:33:31.000Z" + }, + { + "id": 231, + "key": "lowcode.97ad00dd", + "content": "创建物料资产包", + "host": 918, + "host_type": "app", + "lang": { + "id": 1, + "lang": "zh_CN", + "label": "简体中文", + "created_by": null, + "updated_by": null, + "created_at": "2022-03-08T08:00:54.000Z", + "updated_at": "2022-03-08T08:00:54.000Z" + }, + "created_by": null, + "updated_by": null, + "created_at": "2022-07-06T11:21:54.000Z", + "updated_at": "2022-07-06T11:21:54.000Z" + }, + { + "id": 232, + "key": "lowcode.97ad00dd", + "content": "createMaterial", + "host": 918, + "host_type": "app", + "lang": { + "id": 2, + "lang": "en_US", + "label": "美式英文", + "created_by": null, + "updated_by": null, + "created_at": "2022-03-08T08:01:16.000Z", + "updated_at": "2022-03-08T08:01:16.000Z" + }, + "created_by": null, + "updated_by": null, + "created_at": "2022-07-06T11:21:54.000Z", + "updated_at": "2022-07-06T11:21:54.000Z" + }, + { + "id": 31985, + "key": "lowcode.61dcef52", + "content": "terterere", + "host": 918, + "host_type": "app", + "lang": { + "id": 1, + "lang": "zh_CN", + "label": "简体中文", + "created_by": null, + "updated_by": null, + "created_at": "2022-03-08T08:00:54.000Z", + "updated_at": "2022-03-08T08:00:54.000Z" + }, + "created_by": null, + "updated_by": null, + "created_at": "2023-05-04T08:07:15.000Z", + "updated_at": "2023-05-04T08:07:15.000Z" + }, + { + "id": 31986, + "key": "lowcode.61dcef52", + "content": "sadasda", + "host": 918, + "host_type": "app", + "lang": { + "id": 2, + "lang": "en_US", + "label": "美式英文", + "created_by": null, + "updated_by": null, + "created_at": "2022-03-08T08:01:16.000Z", + "updated_at": "2022-03-08T08:01:16.000Z" + }, + "created_by": null, + "updated_by": null, + "created_at": "2023-05-04T08:07:15.000Z", + "updated_at": "2023-05-04T08:07:15.000Z" + }, + { + "id": 36011, + "key": "lowcode.45f4c42a", + "content": "gfdgfd", + "host": 918, + "host_type": "app", + "lang": { + "id": 2, + "lang": "en_US", + "label": "美式英文", + "created_by": null, + "updated_by": null, + "created_at": "2022-03-08T08:01:16.000Z", + "updated_at": "2022-03-08T08:01:16.000Z" + }, + "created_by": null, + "updated_by": null, + "created_at": "2023-05-06T08:18:35.000Z", + "updated_at": "2023-05-06T08:20:01.000Z" + }, + { + "id": 36012, + "key": "lowcode.45f4c42a", + "content": "gdfgdf", + "host": 918, + "host_type": "app", + "lang": { + "id": 1, + "lang": "zh_CN", + "label": "简体中文", + "created_by": null, + "updated_by": null, + "created_at": "2022-03-08T08:00:54.000Z", + "updated_at": "2022-03-08T08:00:54.000Z" + }, + "created_by": null, + "updated_by": null, + "created_at": "2023-05-06T08:18:35.000Z", + "updated_at": "2023-05-06T08:20:01.000Z" + }, + { + "id": 45420, + "key": "lowcode.c6f5a652", + "content": "fsdaf", + "host": 918, + "host_type": "app", + "lang": { + "id": 1, + "lang": "zh_CN", + "label": "简体中文", + "created_by": null, + "updated_by": null, + "created_at": "2022-03-08T08:00:54.000Z", + "updated_at": "2022-03-08T08:00:54.000Z" + }, + "created_by": null, + "updated_by": null, + "created_at": "2023-06-17T08:50:24.000Z", + "updated_at": "2023-07-18T12:33:28.000Z" + }, + { + "id": 45421, + "key": "lowcode.c6f5a652", + "content": "fsdafds", + "host": 918, + "host_type": "app", + "lang": { + "id": 2, + "lang": "en_US", + "label": "美式英文", + "created_by": null, + "updated_by": null, + "created_at": "2022-03-08T08:01:16.000Z", + "updated_at": "2022-03-08T08:01:16.000Z" + }, + "created_by": null, + "updated_by": null, + "created_at": "2023-06-17T08:50:24.000Z", + "updated_at": "2023-07-18T12:33:28.000Z" + }, + { + "id": 55726, + "key": "lowcode.34923432", + "content": "fdsafdsa", + "host": 918, + "host_type": "app", + "lang": { + "id": 1, + "lang": "zh_CN", + "label": "简体中文", + "created_by": null, + "updated_by": null, + "created_at": "2022-03-08T08:00:54.000Z", + "updated_at": "2022-03-08T08:00:54.000Z" + }, + "created_by": null, + "updated_by": null, + "created_at": "2023-08-15T07:01:19.000Z", + "updated_at": "2023-08-15T07:01:19.000Z" + }, + { + "id": 55727, + "key": "lowcode.34923432", + "content": "fdsafds", + "host": 918, + "host_type": "app", + "lang": { + "id": 2, + "lang": "en_US", + "label": "美式英文", + "created_by": null, + "updated_by": null, + "created_at": "2022-03-08T08:01:16.000Z", + "updated_at": "2022-03-08T08:01:16.000Z" + }, + "created_by": null, + "updated_by": null, + "created_at": "2023-08-15T07:01:19.000Z", + "updated_at": "2023-08-15T07:01:19.000Z" + }, + { + "id": 55728, + "key": "lowcode.48521e45", + "content": "fdsfds", + "host": 918, + "host_type": "app", + "lang": { + "id": 1, + "lang": "zh_CN", + "label": "简体中文", + "created_by": null, + "updated_by": null, + "created_at": "2022-03-08T08:00:54.000Z", + "updated_at": "2022-03-08T08:00:54.000Z" + }, + "created_by": null, + "updated_by": null, + "created_at": "2023-08-15T07:03:02.000Z", + "updated_at": "2023-08-15T07:03:02.000Z" + }, + { + "id": 55729, + "key": "lowcode.6534943e", + "content": "fdsafds", + "host": 918, + "host_type": "app", + "lang": { + "id": 1, + "lang": "zh_CN", + "label": "简体中文", + "created_by": null, + "updated_by": null, + "created_at": "2022-03-08T08:00:54.000Z", + "updated_at": "2022-03-08T08:00:54.000Z" + }, + "created_by": null, + "updated_by": null, + "created_at": "2023-08-15T07:04:22.000Z", + "updated_at": "2023-08-15T07:04:22.000Z" + }, + { + "id": 55730, + "key": "lowcode.6534943e", + "content": "fdsafdsa", + "host": 918, + "host_type": "app", + "lang": { + "id": 2, + "lang": "en_US", + "label": "美式英文", + "created_by": null, + "updated_by": null, + "created_at": "2022-03-08T08:01:16.000Z", + "updated_at": "2022-03-08T08:01:16.000Z" + }, + "created_by": null, + "updated_by": null, + "created_at": "2023-08-15T07:04:22.000Z", + "updated_at": "2023-08-15T07:04:22.000Z" + }, + { + "id": 55731, + "key": "lowcode.44252642", + "content": "fdsafds", + "host": 918, + "host_type": "app", + "lang": { + "id": 1, + "lang": "zh_CN", + "label": "简体中文", + "created_by": null, + "updated_by": null, + "created_at": "2022-03-08T08:00:54.000Z", + "updated_at": "2022-03-08T08:00:54.000Z" + }, + "created_by": null, + "updated_by": null, + "created_at": "2023-08-15T07:04:53.000Z", + "updated_at": "2023-08-15T07:04:53.000Z" + }, + { + "id": 55732, + "key": "lowcode.44252642", + "content": "aaaa", + "host": 918, + "host_type": "app", + "lang": { + "id": 2, + "lang": "en_US", + "label": "美式英文", + "created_by": null, + "updated_by": null, + "created_at": "2022-03-08T08:01:16.000Z", + "updated_at": "2022-03-08T08:01:16.000Z" + }, + "created_by": null, + "updated_by": null, + "created_at": "2023-08-15T07:04:53.000Z", + "updated_at": "2023-08-15T07:04:53.000Z" + }, + { + "id": 64792, + "key": "lowcode.2a743651", + "content": "sda", + "host": 918, + "host_type": "app", + "lang": { + "id": 1, + "lang": "zh_CN", + "label": "简体中文", + "created_by": null, + "updated_by": null, + "created_at": "2022-03-08T08:00:54.000Z", + "updated_at": "2022-03-08T08:00:54.000Z" + }, + "created_by": null, + "updated_by": null, + "created_at": "2023-08-21T00:58:35.000Z", + "updated_at": "2023-08-21T00:58:35.000Z" + }, + { + "id": 64793, + "key": "lowcode.2a743651", + "content": "fdsaf", + "host": 918, + "host_type": "app", + "lang": { + "id": 2, + "lang": "en_US", + "label": "美式英文", + "created_by": null, + "updated_by": null, + "created_at": "2022-03-08T08:01:16.000Z", + "updated_at": "2022-03-08T08:01:16.000Z" + }, + "created_by": null, + "updated_by": null, + "created_at": "2023-08-21T00:58:35.000Z", + "updated_at": "2023-08-21T00:58:35.000Z" + }, + { + "id": 64794, + "key": "lowcode.24315357", + "content": "fdsafds", + "host": 918, + "host_type": "app", + "lang": { + "id": 1, + "lang": "zh_CN", + "label": "简体中文", + "created_by": null, + "updated_by": null, + "created_at": "2022-03-08T08:00:54.000Z", + "updated_at": "2022-03-08T08:00:54.000Z" + }, + "created_by": null, + "updated_by": null, + "created_at": "2023-08-21T02:51:56.000Z", + "updated_at": "2023-08-21T02:51:56.000Z" + }, + { + "id": 64795, + "key": "lowcode.24315357", + "content": "fsdafds", + "host": 918, + "host_type": "app", + "lang": { + "id": 2, + "lang": "en_US", + "label": "美式英文", + "created_by": null, + "updated_by": null, + "created_at": "2022-03-08T08:01:16.000Z", + "updated_at": "2022-03-08T08:01:16.000Z" + }, + "created_by": null, + "updated_by": null, + "created_at": "2023-08-21T02:51:56.000Z", + "updated_at": "2023-08-21T02:51:56.000Z" + }, + { + "id": 64796, + "key": "lowcode.44621691", + "content": "fdsafsd", + "host": 918, + "host_type": "app", + "lang": { + "id": 1, + "lang": "zh_CN", + "label": "简体中文", + "created_by": null, + "updated_by": null, + "created_at": "2022-03-08T08:00:54.000Z", + "updated_at": "2022-03-08T08:00:54.000Z" + }, + "created_by": null, + "updated_by": null, + "created_at": "2023-08-21T02:52:00.000Z", + "updated_at": "2023-08-21T02:52:00.000Z" + }, + { + "id": 64797, + "key": "lowcode.44621691", + "content": "sd", + "host": 918, + "host_type": "app", + "lang": { + "id": 2, + "lang": "en_US", + "label": "美式英文", + "created_by": null, + "updated_by": null, + "created_at": "2022-03-08T08:01:16.000Z", + "updated_at": "2022-03-08T08:01:16.000Z" + }, + "created_by": null, + "updated_by": null, + "created_at": "2023-08-21T02:52:00.000Z", + "updated_at": "2023-08-21T02:52:00.000Z" + }, + { + "id": 64798, + "key": "lowcode.65636226", + "content": "fdsaf", + "host": 918, + "host_type": "app", + "lang": { + "id": 1, + "lang": "zh_CN", + "label": "简体中文", + "created_by": null, + "updated_by": null, + "created_at": "2022-03-08T08:00:54.000Z", + "updated_at": "2022-03-08T08:00:54.000Z" + }, + "created_by": null, + "updated_by": null, + "created_at": "2023-08-21T02:52:04.000Z", + "updated_at": "2023-08-21T02:52:04.000Z" + }, + { + "id": 64799, + "key": "lowcode.65636226", + "content": "fdsfsd", + "host": 918, + "host_type": "app", + "lang": { + "id": 2, + "lang": "en_US", + "label": "美式英文", + "created_by": null, + "updated_by": null, + "created_at": "2022-03-08T08:01:16.000Z", + "updated_at": "2022-03-08T08:01:16.000Z" + }, + "created_by": null, + "updated_by": null, + "created_at": "2023-08-21T02:52:04.000Z", + "updated_at": "2023-08-21T02:52:04.000Z" + }, + { + "id": 64800, + "key": "lowcode.6426a4e2", + "content": "sd", + "host": 918, + "host_type": "app", + "lang": { + "id": 1, + "lang": "zh_CN", + "label": "简体中文", + "created_by": null, + "updated_by": null, + "created_at": "2022-03-08T08:00:54.000Z", + "updated_at": "2022-03-08T08:00:54.000Z" + }, + "created_by": null, + "updated_by": null, + "created_at": "2023-08-21T02:52:08.000Z", + "updated_at": "2023-08-21T02:52:08.000Z" + }, + { + "id": 64801, + "key": "lowcode.6426a4e2", + "content": "fdsafsd", + "host": 918, + "host_type": "app", + "lang": { + "id": 2, + "lang": "en_US", + "label": "美式英文", + "created_by": null, + "updated_by": null, + "created_at": "2022-03-08T08:01:16.000Z", + "updated_at": "2022-03-08T08:01:16.000Z" + }, + "created_by": null, + "updated_by": null, + "created_at": "2023-08-21T02:52:08.000Z", + "updated_at": "2023-08-21T02:52:08.000Z" + }, + { + "id": 64802, + "key": "lowcode.e41c6636", + "content": "aa", + "host": 918, + "host_type": "app", + "lang": { + "id": 1, + "lang": "zh_CN", + "label": "简体中文", + "created_by": null, + "updated_by": null, + "created_at": "2022-03-08T08:00:54.000Z", + "updated_at": "2022-03-08T08:00:54.000Z" + }, + "created_by": null, + "updated_by": null, + "created_at": "2023-08-21T02:52:11.000Z", + "updated_at": "2023-08-21T02:52:11.000Z" + }, + { + "id": 64803, + "key": "lowcode.e41c6636", + "content": "aa", + "host": 918, + "host_type": "app", + "lang": { + "id": 2, + "lang": "en_US", + "label": "美式英文", + "created_by": null, + "updated_by": null, + "created_at": "2022-03-08T08:01:16.000Z", + "updated_at": "2022-03-08T08:01:16.000Z" + }, + "created_by": null, + "updated_by": null, + "created_at": "2023-08-21T02:52:11.000Z", + "updated_at": "2023-08-21T02:52:11.000Z" + }, + { + "id": 64804, + "key": "lowcode.51c23164", + "content": "aa", + "host": 918, + "host_type": "app", + "lang": { + "id": 1, + "lang": "zh_CN", + "label": "简体中文", + "created_by": null, + "updated_by": null, + "created_at": "2022-03-08T08:00:54.000Z", + "updated_at": "2022-03-08T08:00:54.000Z" + }, + "created_by": null, + "updated_by": null, + "created_at": "2023-08-21T02:52:15.000Z", + "updated_at": "2023-08-21T02:52:15.000Z" + }, + { + "id": 64805, + "key": "lowcode.51c23164", + "content": "aa", + "host": 918, + "host_type": "app", + "lang": { + "id": 2, + "lang": "en_US", + "label": "美式英文", + "created_by": null, + "updated_by": null, + "created_at": "2022-03-08T08:01:16.000Z", + "updated_at": "2022-03-08T08:01:16.000Z" + }, + "created_by": null, + "updated_by": null, + "created_at": "2023-08-21T02:52:15.000Z", + "updated_at": "2023-08-21T02:52:15.000Z" + }, + { + "id": 64806, + "key": "lowcode.17245b46", + "content": "aa", + "host": 918, + "host_type": "app", + "lang": { + "id": 1, + "lang": "zh_CN", + "label": "简体中文", + "created_by": null, + "updated_by": null, + "created_at": "2022-03-08T08:00:54.000Z", + "updated_at": "2022-03-08T08:00:54.000Z" + }, + "created_by": null, + "updated_by": null, + "created_at": "2023-08-21T02:52:21.000Z", + "updated_at": "2023-08-21T02:52:21.000Z" + }, + { + "id": 64807, + "key": "lowcode.17245b46", + "content": "aa", + "host": 918, + "host_type": "app", + "lang": { + "id": 2, + "lang": "en_US", + "label": "美式英文", + "created_by": null, + "updated_by": null, + "created_at": "2022-03-08T08:01:16.000Z", + "updated_at": "2022-03-08T08:01:16.000Z" + }, + "created_by": null, + "updated_by": null, + "created_at": "2023-08-21T02:52:21.000Z", + "updated_at": "2023-08-21T02:52:21.000Z" + }, + { + "id": 64808, + "key": "lowcode.4573143c", + "content": "aa", + "host": 918, + "host_type": "app", + "lang": { + "id": 1, + "lang": "zh_CN", + "label": "简体中文", + "created_by": null, + "updated_by": null, + "created_at": "2022-03-08T08:00:54.000Z", + "updated_at": "2022-03-08T08:00:54.000Z" + }, + "created_by": null, + "updated_by": null, + "created_at": "2023-08-21T02:52:22.000Z", + "updated_at": "2023-08-21T02:52:22.000Z" + }, + { + "id": 64809, + "key": "lowcode.4573143c", + "content": "a", + "host": 918, + "host_type": "app", + "lang": { + "id": 2, + "lang": "en_US", + "label": "美式英文", + "created_by": null, + "updated_by": null, + "created_at": "2022-03-08T08:01:16.000Z", + "updated_at": "2022-03-08T08:01:16.000Z" + }, + "created_by": null, + "updated_by": null, + "created_at": "2023-08-21T02:52:22.000Z", + "updated_at": "2023-08-21T02:52:22.000Z" + }, + { + "id": 64810, + "key": "lowcode.56432442", + "content": "aa", + "host": 918, + "host_type": "app", + "lang": { + "id": 1, + "lang": "zh_CN", + "label": "简体中文", + "created_by": null, + "updated_by": null, + "created_at": "2022-03-08T08:00:54.000Z", + "updated_at": "2022-03-08T08:00:54.000Z" + }, + "created_by": null, + "updated_by": null, + "created_at": "2023-08-21T02:52:25.000Z", + "updated_at": "2023-09-04T08:45:49.000Z" + }, + { + "id": 64811, + "key": "lowcode.56432442", + "content": "aa", + "host": 918, + "host_type": "app", + "lang": { + "id": 2, + "lang": "en_US", + "label": "美式英文", + "created_by": null, + "updated_by": null, + "created_at": "2022-03-08T08:01:16.000Z", + "updated_at": "2022-03-08T08:01:16.000Z" + }, + "created_by": null, + "updated_by": null, + "created_at": "2023-08-21T02:52:25.000Z", + "updated_at": "2023-09-04T08:45:49.000Z" + }, + { + "id": 64812, + "key": "lowcode.33566643", + "content": "aa", + "host": 918, + "host_type": "app", + "lang": { + "id": 1, + "lang": "zh_CN", + "label": "简体中文", + "created_by": null, + "updated_by": null, + "created_at": "2022-03-08T08:00:54.000Z", + "updated_at": "2022-03-08T08:00:54.000Z" + }, + "created_by": null, + "updated_by": null, + "created_at": "2023-08-21T02:52:28.000Z", + "updated_at": "2023-08-21T02:52:28.000Z" + }, + { + "id": 64813, + "key": "lowcode.33566643", + "content": "aa", + "host": 918, + "host_type": "app", + "lang": { + "id": 2, + "lang": "en_US", + "label": "美式英文", + "created_by": null, + "updated_by": null, + "created_at": "2022-03-08T08:01:16.000Z", + "updated_at": "2022-03-08T08:01:16.000Z" + }, + "created_by": null, + "updated_by": null, + "created_at": "2023-08-21T02:52:28.000Z", + "updated_at": "2023-08-21T02:52:28.000Z" + }, + { + "id": 64814, + "key": "lowcode.565128f3", + "content": "aa", + "host": 918, + "host_type": "app", + "lang": { + "id": 1, + "lang": "zh_CN", + "label": "简体中文", + "created_by": null, + "updated_by": null, + "created_at": "2022-03-08T08:00:54.000Z", + "updated_at": "2022-03-08T08:00:54.000Z" + }, + "created_by": null, + "updated_by": null, + "created_at": "2023-08-21T02:52:32.000Z", + "updated_at": "2023-08-21T02:52:32.000Z" + }, + { + "id": 64815, + "key": "lowcode.565128f3", + "content": "aa", + "host": 918, + "host_type": "app", + "lang": { + "id": 2, + "lang": "en_US", + "label": "美式英文", + "created_by": null, + "updated_by": null, + "created_at": "2022-03-08T08:01:16.000Z", + "updated_at": "2022-03-08T08:01:16.000Z" + }, + "created_by": null, + "updated_by": null, + "created_at": "2023-08-21T02:52:32.000Z", + "updated_at": "2023-08-21T02:52:32.000Z" + }, + { + "id": 64816, + "key": "lowcode.56643835", + "content": "aa", + "host": 918, + "host_type": "app", + "lang": { + "id": 1, + "lang": "zh_CN", + "label": "简体中文", + "created_by": null, + "updated_by": null, + "created_at": "2022-03-08T08:00:54.000Z", + "updated_at": "2022-03-08T08:00:54.000Z" + }, + "created_by": null, + "updated_by": null, + "created_at": "2023-08-21T02:52:34.000Z", + "updated_at": "2023-08-21T02:52:34.000Z" + }, + { + "id": 64817, + "key": "lowcode.56643835", + "content": "aa", + "host": 918, + "host_type": "app", + "lang": { + "id": 2, + "lang": "en_US", + "label": "美式英文", + "created_by": null, + "updated_by": null, + "created_at": "2022-03-08T08:01:16.000Z", + "updated_at": "2022-03-08T08:01:16.000Z" + }, + "created_by": null, + "updated_by": null, + "created_at": "2023-08-21T02:52:34.000Z", + "updated_at": "2023-08-21T02:52:34.000Z" + } + ], + "source": [ + { + "id": 132, + "name": "getAllComponent", + "data": { + "data": [], + "type": "array" + }, + "tpl": null, + "app": "918", + "desc": null, + "created_at": "2022-06-28T06:26:26.000Z", + "updated_at": "2022-06-28T07:02:30.000Z" + }, + { + "id": 133, + "name": "getAllList", + "data": { + "columns": [ + { + "name": "test", + "title": "测试", + "field": "test", + "type": "string", + "format": {} + }, + { + "name": "test1", + "title": "测试1", + "field": "test1", + "type": "string", + "format": {} + } + ], + "type": "array", + "data": [ + { + "test": "test1", + "test1": "test1", + "_id": "341efc48" + }, + { + "test": "test2", + "test1": "test1", + "_id": "b86b516c" + }, + { + "test": "test3", + "test1": "test1", + "_id": "f680cd78" + } + ], + "options": { + "uri": "", + "method": "GET" + }, + "dataHandler": { + "type": "JSFunction", + "value": "function dataHandler(data) { \n return data \n}" + }, + "willFetch": { + "type": "JSFunction", + "value": "function willFetch(option) {\n return option \n}" + }, + "shouldFetch": { + "type": "JSFunction", + "value": "function shouldFetch(option) {\n return true \n}" + }, + "errorHandler": { + "type": "JSFunction", + "value": "function errorHandler(err) {}" + } + }, + "tpl": null, + "app": "918", + "desc": null, + "created_at": "2022-06-28T07:32:16.000Z", + "updated_at": "2023-01-19T03:29:11.000Z" + }, + { + "id": 135, + "name": "getAllMaterialList", + "data": { + "columns": [ + { + "name": "id", + "title": "id", + "field": "id", + "type": "string", + "format": {} + }, + { + "name": "name", + "title": "name", + "field": "name", + "type": "string", + "format": {} + }, + { + "name": "framework", + "title": "framework", + "field": "framework", + "type": "string", + "format": { + "required": true + } + }, + { + "name": "components", + "title": "components", + "field": "components", + "type": "string", + "format": {} + }, + { + "name": "content", + "title": "content", + "field": "content", + "type": "string", + "format": {} + }, + { + "name": "url", + "title": "url", + "field": "url", + "type": "string", + "format": {} + }, + { + "name": "published_at", + "title": "published_at", + "field": "published_at", + "type": "string", + "format": {} + }, + { + "name": "created_at", + "title": "created_at", + "field": "created_at", + "type": "string", + "format": {} + }, + { + "name": "updated_at", + "title": "updated_at", + "field": "updated_at", + "type": "string", + "format": {} + }, + { + "name": "published", + "title": "published", + "field": "published", + "type": "string", + "format": {} + }, + { + "name": "last_build_info", + "title": "last_build_info", + "field": "last_build_info", + "type": "string", + "format": {} + }, + { + "name": "tenant", + "title": "tenant", + "field": "tenant", + "type": "string", + "format": {} + }, + { + "name": "version", + "title": "version", + "field": "version", + "type": "string", + "format": {} + }, + { + "name": "description", + "title": "description", + "field": "description", + "type": "string", + "format": {} + } + ], + "type": "array", + "data": [ + { + "id": "f37123ec", + "url": "", + "name": "ng-material", + "tenant": "", + "content": "", + "version": "1.0.0", + "framework": "Angular", + "published": "", + "components": "", + "created_at": "2021-11-02T11:32:22.000Z", + "updated_at": "2021-11-02T11:32:22.000Z", + "description": "angular组件库物料", + "published_at": "2021-11-02T11:32:22.000Z", + "last_build_info": "", + "_id": "2a23e653" + }, + { + "id": "f37123ec", + "url": "", + "name": "ng-material", + "tenant": "", + "content": "", + "version": "1.0.0", + "framework": "Angular", + "published": "", + "components": "", + "created_at": "2021-11-02T11:32:22.000Z", + "updated_at": "2021-11-02T11:32:22.000Z", + "description": "angular组件库物料", + "published_at": "2021-11-02T11:32:22.000Z", + "last_build_info": "", + "_id": "06b253be" + }, + { + "id": "f37123ec", + "url": "", + "name": "ng-material", + "tenant": "", + "content": "", + "version": "1.0.0", + "framework": "Angular", + "published": "", + "components": "", + "created_at": "2021-11-02T11:32:22.000Z", + "updated_at": "2021-11-02T11:32:22.000Z", + "description": "angular组件库物料", + "published_at": "2021-11-02T11:32:22.000Z", + "last_build_info": "", + "_id": "c55a41ed" + }, + { + "id": "f37123ec", + "url": "", + "name": "ng-material", + "tenant": "", + "content": "", + "version": "1.0.0", + "framework": "Angular", + "published": "", + "components": "", + "created_at": "2021-11-02T11:32:22.000Z", + "updated_at": "2021-11-02T11:32:22.000Z", + "description": "angular组件库物料", + "published_at": "2021-11-02T11:32:22.000Z", + "last_build_info": "", + "_id": "f37123ec" + }, + { + "id": "7a63c1a2", + "url": "", + "name": "tiny-vue", + "tenant": "", + "content": "Tiny Vue物料", + "version": "1.0.0", + "framework": "Vue", + "published": "", + "components": "", + "created_at": "", + "updated_at": "", + "description": "Tiny Vue物料", + "published_at": "", + "last_build_info": "", + "_id": "7a63c1a2" + } + ], + "options": { + "uri": "", + "method": "GET" + }, + "willFetch": { + "type": "JSFunction", + "value": "function willFetch(option) {\n return option \n}" + }, + "dataHandler": { + "type": "JSFunction", + "value": "function dataHandler(data) { \n return data \n}" + }, + "shouldFetch": { + "type": "JSFunction", + "value": "function shouldFetch(option) {\n return true \n}" + }, + "errorHandler": { + "type": "JSFunction", + "value": "function errorHandler(err) {}" + } + }, + "tpl": null, + "app": "918", + "desc": null, + "created_at": "2022-06-29T00:57:50.000Z", + "updated_at": "2023-05-15T02:37:12.000Z" + }, + { + "id": 139, + "name": "treedata", + "data": { + "data": [ + { + "label": "level111", + "value": "111", + "id": "f6609643", + "pid": "", + "_RID": "row_4" + }, + { + "label": "level1-son", + "value": "111-1", + "id": "af1f937f", + "pid": "f6609643", + "_RID": "row_5" + }, + { + "label": "level222", + "value": "222", + "id": "28e3709c", + "pid": "", + "_RID": "row_6" + }, + { + "label": "level2-son", + "value": "222-1", + "id": "6b571bef", + "pid": "28e3709c", + "_RID": "row_5" + }, + { + "id": "6317c2cc", + "pid": "fdfa", + "label": "fsdfaa", + "value": "fsadf", + "_RID": "row_6" + }, + { + "id": "9cce369f", + "pid": "test", + "label": "test1", + "value": "001" + } + ], + "type": "tree" + }, + "tpl": null, + "app": "918", + "desc": null, + "created_at": "2022-06-30T06:13:57.000Z", + "updated_at": "2022-07-29T03:14:55.000Z" + }, + { + "id": 150, + "name": "componentList", + "data": { + "data": [ + { + "_RID": "row_1", + "name": "表单", + "isSelected": "true", + "description": "由按钮、输入框、选择器、单选框、多选框等控件组成,用以收集、校验、提交数据" + }, + { + "name": "按钮", + "isSelected": "false", + "description": "常用的操作按钮,提供包括默认按钮、图标按钮、图片按钮、下拉按钮等类型" + }, + { + "id": "490f8a00", + "_RID": "row_3", + "name": "表单项", + "framework": "", + "materials": "", + "description": "Form 组件下的 FormItem 配置" + }, + { + "id": "c259b8b3", + "_RID": "row_4", + "name": "开关", + "framework": "", + "materials": "", + "description": "关闭或打开" + }, + { + "id": "083ed9c7", + "_RID": "row_5", + "name": "互斥按钮组", + "framework": "", + "materials": "", + "description": "以按钮组的方式出现,常用于多项类似操作" + }, + { + "id": "09136cea", + "_RID": "row_6", + "name": "提示框", + "framework": "", + "materials": "", + "description": "Popover可通过对一个触发源操作触发弹出框,支持自定义弹出内容,延迟触发和渐变动画" + }, + { + "id": "a63b57d5", + "_RID": "row_7", + "name": "文字提示框", + "framework": "", + "materials": "", + "description": "动态显示提示信息,一般通过鼠标事件进行响应;提供 warning、error、info、success 四种类型显示不同类别的信" + }, + { + "id": "a0f6e8a3", + "_RID": "row_8", + "name": "树", + "framework": "", + "materials": "", + "description": "可进行展示有父子层级的数据,支持选择,异步加载等功能。但不推荐用它来展示菜单,展示菜单推荐使用树菜单" + }, + { + "id": "d1aa18fc", + "_RID": "row_9", + "name": "分页", + "framework": "", + "materials": "", + "description": "当数据量过多时,使用分页分解数据,常用于 Grid 和 Repeater 组件" + }, + { + "id": "ca49cc52", + "_RID": "row_10", + "name": "表格", + "framework": "", + "materials": "", + "description": "提供了非常强大数据表格功能,可以展示数据列表,可以对数据列表进行选择、编辑等" + }, + { + "id": "4e20ecc9", + "name": "搜索框", + "framework": "", + "materials": "", + "description": "指定条件对象进行搜索数据" + }, + { + "id": "6b093ee5", + "name": "折叠面板", + "framework": "", + "materials": "", + "description": "内容区可指定动态页面或自定义 html 等,支持展开收起操作" + }, + { + "id": "0a09abc0", + "name": "对话框", + "framework": "", + "materials": "", + "description": "模态对话框,在浮层中显示,引导用户进行相关操作" + }, + { + "id": "f814b901", + "name": "标签页签项", + "framework": "", + "materials": "", + "description": "tab页签" + }, + { + "id": "c5ae797c", + "name": "单选", + "framework": "", + "materials": "", + "description": "用于配置不同场景的选项,在一组备选项中进行单选" + }, + { + "id": "33d0c590", + "_RID": "row_13", + "name": "弹出编辑", + "framework": "", + "materials": "", + "description": "该组件只能在弹出的面板中选择数据,不能手动输入数据;弹出面板中显示为 Tree 组件或者 Grid 组件" + }, + { + "id": "16711dfa", + "_RID": "row_14", + "name": "下拉框", + "framework": "", + "materials": "", + "description": "Select 选择器是一种通过点击弹出下拉列表展示数据并进行选择的 UI 组件" + }, + { + "id": "a9fd190a", + "_RID": "row_15", + "name": "折叠面板项", + "framework": "", + "materials": "", + "description": "内容区可指定动态页面或自定义 html 等,支持展开收起操作" + }, + { + "id": "a7dfa9ec", + "_RID": "row_16", + "name": "复选框", + "framework": "", + "materials": "", + "description": "用于配置不同场景的选项,提供用户可在一组选项中进行多选" + }, + { + "id": "d4bb8330", + "name": "输入框", + "framework": "", + "materials": "", + "description": "通过鼠标或键盘输入字符" + }, + { + "id": "ced3dc83", + "name": "时间线", + "framework": "", + "materials": "", + "description": "时间线" + } + ], + "type": "array", + "columns": [ + { + "name": "name", + "type": "string", + "field": "name", + "title": "name", + "format": { + "max": 0, + "min": 0, + "dateTime": false, + "required": false, + "stringType": "" + } + }, + { + "name": "description", + "type": "string", + "field": "description", + "title": "description", + "format": { + "max": 0, + "min": 0, + "dateTime": false, + "required": false, + "stringType": "" + } + }, + { + "name": "isSelected", + "type": "string", + "field": "isSelected", + "title": "isSelected", + "format": { + "max": 0, + "min": 0, + "dateTime": false, + "required": false, + "stringType": "" + } + } + ], + "options": { + "uri": "http://localhost:9090/assets/json/bundle.json", + "method": "GET" + }, + "willFetch": { + "type": "JSFunction", + "value": "function willFetch(option) {\n return option \n}" + }, + "dataHandler": { + "type": "JSFunction", + "value": "function dataHandler(data) { \n return data \n}" + }, + "shouldFetch": { + "type": "JSFunction", + "value": "function shouldFetch(option) {\n return true \n}" + }, + "errorHandler": { + "type": "JSFunction", + "value": "function errorHandler(err) {}" + } + }, + "tpl": null, + "app": "918", + "desc": null, + "created_at": "2022-07-04T02:20:07.000Z", + "updated_at": "2022-07-04T06:25:29.000Z" + }, + { + "id": 151, + "name": "selectedComponents", + "data": { + "columns": [ + { + "name": "name", + "title": "name", + "field": "name", + "type": "string", + "format": { + "required": false, + "stringType": "", + "min": 0, + "max": 0, + "dateTime": false + } + }, + { + "name": "description", + "title": "description", + "field": "description", + "type": "string", + "format": { + "required": false, + "stringType": "", + "min": 0, + "max": 0, + "dateTime": false + } + }, + { + "name": "isSelected", + "title": "isSelected", + "field": "isSelected", + "type": "string", + "format": { + "required": false, + "stringType": "", + "min": 0, + "max": 0, + "dateTime": false + } + } + ], + "type": "array", + "data": [ + { + "name": "标签页", + "description": "分隔内容上有关联但属于不同类别的数据集合", + "isSelected": "true", + "_RID": "row_2" + }, + { + "name": "布局列", + "description": "列配置信息", + "isSelected": "true", + "id": "76a7080a", + "_RID": "row_4" + }, + { + "name": "日期选择器", + "description": "用于设置/选择日期,包括年月/年月日/年月日时分/年月日时分秒日期格式", + "isSelected": "true", + "id": "76b20d73", + "_RID": "row_1" + }, + { + "name": "走马灯", + "description": "常用于一组图片或卡片轮播,当内容空间不足时,可以用走马灯的形式进行收纳,进行轮播展现", + "isSelected": "true", + "id": "4c884c3d" + } + ] + }, + "tpl": null, + "app": "918", + "desc": null, + "created_at": "2022-07-04T03:04:05.000Z", + "updated_at": "2022-07-04T03:43:40.000Z" + } + ], + "extension": [ + { + "id": 176, + "name": "axios", + "type": "npm", + "content": { + "type": "JSFunction", + "value": "", + "package": "axios", + "destructuring": false, + "exportName": "axios" + }, + "app": 918, + "category": "utils", + "created_by": null, + "updated_by": null, + "created_at": "2022-10-27T11:02:26.000Z", + "updated_at": "2022-10-27T11:02:26.000Z" + }, + { + "id": 104, + "name": "Button", + "type": "npm", + "content": { + "package": "@opentiny/vue", + "version": "", + "exportName": "Button", + "subName": "", + "destructuring": true, + "main": "" + }, + "app": 918, + "category": "utils", + "created_by": null, + "updated_by": null, + "created_at": "2022-07-06T10:17:31.000Z", + "updated_at": "2022-07-06T10:17:31.000Z" + }, + { + "id": 101, + "name": "Menu", + "type": "npm", + "content": { + "type": "JSFunction", + "value": "", + "package": "@opentiny/vue", + "exportName": "NavMenu", + "destructuring": true + }, + "app": 918, + "category": "utils", + "created_by": null, + "updated_by": null, + "created_at": "2022-06-24T06:40:52.000Z", + "updated_at": "2022-06-24T08:03:13.000Z" + }, + { + "id": 103, + "name": "Modal ", + "type": "npm", + "content": { + "package": "@opentiny/vue", + "version": "", + "exportName": "Modal ", + "subName": "", + "destructuring": true, + "main": "" + }, + "app": 918, + "category": "utils", + "created_by": null, + "updated_by": null, + "created_at": "2022-07-01T03:21:19.000Z", + "updated_at": "2022-07-01T03:21:19.000Z" + }, + { + "id": 146, + "name": "npm", + "type": "function", + "content": { + "type": "JSFunction", + "value": "''" + }, + "app": 918, + "category": "utils", + "created_by": null, + "updated_by": null, + "created_at": "2022-08-29T06:54:02.000Z", + "updated_at": "2023-01-05T01:00:52.000Z" + }, + { + "id": 102, + "name": "Pager", + "type": "npm", + "content": { + "package": "@opentiny/vue", + "version": "", + "exportName": "Pager", + "subName": "", + "destructuring": true, + "main": "" + }, + "app": 918, + "category": "utils", + "created_by": null, + "updated_by": null, + "created_at": "2022-06-28T08:17:38.000Z", + "updated_at": "2023-03-21T12:13:04.000Z" + }, + { + "id": 106, + "name": "test", + "type": "function", + "content": { + "type": "JSFunction", + "value": "function test() {\r\n return 'test'\r\n}" + }, + "app": 918, + "category": "utils", + "created_by": null, + "updated_by": null, + "created_at": "2022-07-06T10:21:02.000Z", + "updated_at": "2023-03-21T12:12:49.000Z" + }, + { + "id": 97, + "name": "util", + "type": "function", + "content": { + "type": "JSFunction", + "value": "function util () {\r\n console.log(321)\r\n}" + }, + "app": 918, + "category": "utils", + "created_by": null, + "updated_by": null, + "created_at": "2022-06-23T11:13:07.000Z", + "updated_at": "2023-04-06T02:31:44.000Z" + } + ], + "pages": [ + { + "name": "createVm", + "id": "NTJ4MjvqoVj8OVsc", + "app": "918", + "route": "createVm", + "page_content": { + "state": { + "dataDisk": [1, 2, 3] + }, + "methods": {}, + "componentName": "Page", + "css": "body {\r\n background-color:#eef0f5 ;\r\n margin-bottom: 80px;\r\n}", + "props": {}, + "children": [ + { + "componentName": "div", + "props": { + "style": "padding-bottom: 10px; padding-top: 10px;" + }, + "id": "2b2cabf0", + "children": [ + { + "componentName": "TinyTimeLine", + "props": { + "active": "2", + "data": [ + { + "name": "基础配置" + }, + { + "name": "网络配置" + }, + { + "name": "高级配置" + }, + { + "name": "确认配置" + } + ], + "horizontal": true, + "style": "border-radius: 0px;" + }, + "id": "dd764b17" + } + ] + }, + { + "componentName": "div", + "props": { + "style": "border-width: 1px; border-style: solid; border-radius: 4px; border-color: #fff; padding-top: 10px; padding-bottom: 10px; padding-left: 10px; padding-right: 10px; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px; background-color: #fff; margin-bottom: 10px;" + }, + "id": "30c94cc8", + "children": [ + { + "componentName": "TinyForm", + "props": { + "labelWidth": "80px", + "labelPosition": "top", + "inline": false, + "label-position": "left ", + "label-width": "150px", + "style": "border-radius: 0px;" + }, + "children": [ + { + "componentName": "TinyFormItem", + "props": { + "label": "计费模式" + }, + "children": [ + { + "componentName": "TinyButtonGroup", + "props": { + "data": [ + { + "text": "包年/包月", + "value": "1" + }, + { + "text": "按需计费", + "value": "2" + } + ], + "modelValue": "1" + }, + "id": "a8d84361" + } + ], + "id": "9f39f3e7" + }, + { + "componentName": "TinyFormItem", + "props": { + "label": "区域" + }, + "children": [ + { + "componentName": "TinyButtonGroup", + "props": { + "data": [ + { + "text": "乌兰察布二零一", + "value": "1" + } + ], + "modelValue": "1", + "style": "border-radius: 0px; margin-right: 10px;" + }, + "id": "c97ccd99" + }, + { + "componentName": "Text", + "props": { + "text": "温馨提示:页面左上角切换区域", + "style": "background-color: [object Event]; color: #8a8e99; font-size: 12px;" + }, + "id": "20923497" + }, + { + "componentName": "Text", + "props": { + "text": "不同区域的云服务产品之间内网互不相通;请就近选择靠近您业务的区域,可减少网络时延,提高访问速度", + "style": "display: block; color: #8a8e99; border-radius: 0px; font-size: 12px;" + }, + "id": "54780a26" + } + ], + "id": "4966384d" + }, + { + "componentName": "TinyFormItem", + "props": { + "label": "可用区", + "style": "border-radius: 0px;" + }, + "children": [ + { + "componentName": "TinyButtonGroup", + "props": { + "data": [ + { + "text": "可用区1", + "value": "1" + }, + { + "text": "可用区2", + "value": "2" + }, + { + "text": "可用区3", + "value": "3" + } + ], + "modelValue": "1" + }, + "id": "6184481b" + } + ], + "id": "690837bf" + } + ], + "id": "b6a425d4" + } + ] + }, + { + "componentName": "div", + "props": { + "style": "border-width: 1px; border-style: solid; border-radius: 4px; border-color: #fff; padding-top: 10px; padding-bottom: 10px; padding-left: 10px; padding-right: 10px; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px; background-color: #fff; margin-bottom: 10px;" + }, + "children": [ + { + "componentName": "TinyForm", + "props": { + "labelWidth": "80px", + "labelPosition": "top", + "inline": false, + "label-position": "left ", + "label-width": "150px", + "style": "border-radius: 0px;" + }, + "children": [ + { + "componentName": "TinyFormItem", + "props": { + "label": "CPU架构" + }, + "children": [ + { + "componentName": "TinyButtonGroup", + "props": { + "data": [ + { + "text": "x86计算", + "value": "1" + }, + { + "text": "鲲鹏计算", + "value": "2" + } + ], + "modelValue": "1" + }, + "id": "7d33ced7" + } + ], + "id": "05ed5a79" + }, + { + "componentName": "TinyFormItem", + "props": { + "label": "区域" + }, + "children": [ + { + "componentName": "div", + "props": { + "style": "display: flex; justify-content: flex-start; align-items: center;" + }, + "id": "606edf78", + "children": [ + { + "componentName": "div", + "props": { + "style": "display: flex; align-items: center; margin-right: 10px;" + }, + "id": "f3f98246", + "children": [ + { + "componentName": "Text", + "props": { + "text": "vCPUs", + "style": "width: 80px;" + }, + "id": "c287437e" + }, + { + "componentName": "TinySelect", + "props": { + "modelValue": "", + "placeholder": "请选择", + "options": [ + { + "value": "1", + "label": "黄金糕" + }, + { + "value": "2", + "label": "双皮奶" + } + ] + }, + "id": "4c43286b" + } + ] + }, + { + "componentName": "div", + "props": { + "style": "display: flex; align-items: center; margin-right: 10px;" + }, + "children": [ + { + "componentName": "Text", + "props": { + "text": "内存", + "style": "width: 80px; border-radius: 0px;" + }, + "id": "38b8fa1f" + }, + { + "componentName": "TinySelect", + "props": { + "modelValue": "", + "placeholder": "请选择", + "options": [ + { + "value": "1", + "label": "黄金糕" + }, + { + "value": "2", + "label": "双皮奶" + } + ] + }, + "id": "cd33328e" + } + ], + "id": "2b2c678f" + }, + { + "componentName": "div", + "props": { + "style": "display: flex; align-items: center;" + }, + "children": [ + { + "componentName": "Text", + "props": { + "text": "规格名称", + "style": "width: 80px;" + }, + "id": "d3eb6352" + }, + { + "componentName": "TinySearch", + "props": { + "modelValue": "", + "placeholder": "输入关键词" + }, + "id": "21cb9282" + } + ], + "id": "b8e0f35c" + } + ] + }, + { + "componentName": "div", + "props": { + "style": "border-radius: 0px;" + }, + "id": "5000c83e", + "children": [ + { + "componentName": "TinyButtonGroup", + "props": { + "data": [ + { + "text": "通用计算型", + "value": "1" + }, + { + "text": "通用计算增强型", + "value": "2" + }, + { + "text": "内存优化型", + "value": "3" + }, + { + "text": "内存优化型", + "value": "4" + }, + { + "text": "磁盘增强型", + "value": "5" + }, + { + "text": "超高I/O型", + "value": "6" + }, + { + "text": "GPU加速型", + "value": "7" + } + ], + "modelValue": "1", + "style": "border-radius: 0px; margin-top: 12px;" + }, + "id": "b8724703" + }, + { + "componentName": "TinyGrid", + "props": { + "editConfig": { + "trigger": "click", + "mode": "cell", + "showStatus": true + }, + "columns": [ + { + "type": "radio", + "width": 60 + }, + { + "field": "employees", + "title": "规格名称" + }, + { + "field": "created_date", + "title": "vCPUs | 内存(GiB)", + "sortable": true + }, + { + "field": "city", + "title": "CPU", + "sortable": true + }, + { + "title": "基准 / 最大带宽\t", + "sortable": true + }, + { + "title": "内网收发包", + "sortable": true + } + ], + "data": [ + { + "id": "1", + "name": "GFD科技有限公司", + "city": "福州", + "employees": 800, + "created_date": "2014-04-30 00:56:00", + "boole": false + }, + { + "id": "2", + "name": "WWW科技有限公司", + "city": "深圳", + "employees": 300, + "created_date": "2016-07-08 12:36:22", + "boole": true + } + ], + "style": "margin-top: 12px; border-radius: 0px;", + "auto-resize": true + }, + "id": "77701c25" + }, + { + "componentName": "div", + "props": { + "style": "margin-top: 12px; border-radius: 0px;" + }, + "id": "3339838b", + "children": [ + { + "componentName": "Text", + "props": { + "text": "当前规格", + "style": "width: 150px; display: inline-block;" + }, + "id": "203b012b" + }, + { + "componentName": "Text", + "props": { + "text": "通用计算型 | Si2.large.2 | 2vCPUs | 4 GiB", + "style": "font-weight: 700;" + }, + "id": "87723f52" + } + ] + } + ] + } + ], + "id": "657fb2fc" + } + ], + "id": "d19b15cf" + } + ], + "id": "9991228b" + }, + { + "componentName": "div", + "props": { + "style": "border-width: 1px; border-style: solid; border-radius: 4px; border-color: #fff; padding-top: 10px; padding-bottom: 10px; padding-left: 10px; padding-right: 10px; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px; background-color: #fff; margin-bottom: 10px;" + }, + "children": [ + { + "componentName": "TinyForm", + "props": { + "labelWidth": "80px", + "labelPosition": "top", + "inline": false, + "label-position": "left ", + "label-width": "150px", + "style": "border-radius: 0px;" + }, + "children": [ + { + "componentName": "TinyFormItem", + "props": { + "label": "镜像", + "style": "border-radius: 0px;" + }, + "children": [ + { + "componentName": "TinyButtonGroup", + "props": { + "data": [ + { + "text": "公共镜像", + "value": "1" + }, + { + "text": "私有镜像", + "value": "2" + }, + { + "text": "共享镜像", + "value": "3" + } + ], + "modelValue": "1" + }, + "id": "922b14cb" + }, + { + "componentName": "div", + "props": { + "style": "display: flex; margin-top: 12px; border-radius: 0px;" + }, + "id": "6b679524", + "children": [ + { + "componentName": "TinySelect", + "props": { + "modelValue": "", + "placeholder": "请选择", + "options": [ + { + "value": "1", + "label": "黄金糕" + }, + { + "value": "2", + "label": "双皮奶" + } + ], + "style": "width: 170px; margin-right: 10px;" + }, + "id": "4851fff7" + }, + { + "componentName": "TinySelect", + "props": { + "modelValue": "", + "placeholder": "请选择", + "options": [ + { + "value": "1", + "label": "黄金糕" + }, + { + "value": "2", + "label": "双皮奶" + } + ], + "style": "width: 340px;" + }, + "id": "a7183eb7" + } + ] + }, + { + "componentName": "div", + "props": { + "style": "margin-top: 12px;" + }, + "id": "57aee314", + "children": [ + { + "componentName": "Text", + "props": { + "text": "请注意操作系统的语言类型。", + "style": "color: #e37d29;" + }, + "id": "56d36c27" + } + ] + } + ], + "id": "e3b02436" + } + ], + "id": "59aebf2b" + } + ], + "id": "87ff7b99" + }, + { + "componentName": "div", + "props": { + "style": "border-width: 1px; border-style: solid; border-radius: 4px; border-color: #fff; padding-top: 10px; padding-bottom: 10px; padding-left: 10px; padding-right: 10px; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px; background-color: #fff; margin-bottom: 10px;" + }, + "children": [ + { + "componentName": "TinyForm", + "props": { + "labelWidth": "80px", + "labelPosition": "top", + "inline": false, + "label-position": "left ", + "label-width": "150px", + "style": "border-radius: 0px;" + }, + "children": [ + { + "componentName": "TinyFormItem", + "props": { + "label": "系统盘", + "style": "border-radius: 0px;" + }, + "children": [ + { + "componentName": "div", + "props": { + "style": "display: flex;" + }, + "id": "cddba5b8", + "children": [ + { + "componentName": "TinySelect", + "props": { + "modelValue": "", + "placeholder": "请选择", + "options": [ + { + "value": "1", + "label": "黄金糕" + }, + { + "value": "2", + "label": "双皮奶" + } + ], + "style": "width: 200px; margin-right: 10px;" + }, + "id": "a97fbe15" + }, + { + "componentName": "TinyInput", + "props": { + "placeholder": "请输入", + "modelValue": "", + "style": "width: 120px; margin-right: 10px;" + }, + "id": "1cde4c0f" + }, + { + "componentName": "Text", + "props": { + "text": "GiB \nIOPS上限240,IOPS突发上限5,000", + "style": "color: #575d6c; font-size: 12px;" + }, + "id": "2815d82d" + } + ] + } + ], + "id": "50239a3a" + } + ], + "id": "e8582986" + }, + { + "componentName": "TinyForm", + "props": { + "labelWidth": "80px", + "labelPosition": "top", + "inline": false, + "label-position": "left ", + "label-width": "150px", + "style": "border-radius: 0px;" + }, + "children": [ + { + "componentName": "TinyFormItem", + "props": { + "label": "数据盘", + "style": "border-radius: 0px;" + }, + "children": [ + { + "componentName": "div", + "props": { + "style": "margin-top: 12px; display: flex;" + }, + "id": "728c9825", + "children": [ + { + "componentName": "Icon", + "props": { + "style": "margin-right: 10px; width: 16px; height: 16px;", + "name": "IconPanelMini" + }, + "id": "fded6930" + }, + { + "componentName": "TinySelect", + "props": { + "modelValue": "", + "placeholder": "请选择", + "options": [ + { + "value": "1", + "label": "黄金糕" + }, + { + "value": "2", + "label": "双皮奶" + } + ], + "style": "width: 200px; margin-right: 10px;" + }, + "id": "62734e3f" + }, + { + "componentName": "TinyInput", + "props": { + "placeholder": "请输入", + "modelValue": "", + "style": "width: 120px; margin-right: 10px;" + }, + "id": "667c7926" + }, + { + "componentName": "Text", + "props": { + "text": "GiB \nIOPS上限600,IOPS突发上限5,000", + "style": "color: #575d6c; font-size: 12px; margin-right: 10px;" + }, + "id": "e7bc36d6" + }, + { + "componentName": "TinyInput", + "props": { + "placeholder": "请输入", + "modelValue": "", + "style": "width: 120px;" + }, + "id": "1bd56dc0" + } + ], + "loop": { + "type": "JSExpression", + "value": "this.state.dataDisk" + } + }, + { + "componentName": "div", + "props": { + "style": "display: flex; margin-top: 12px; border-radius: 0px;" + }, + "children": [ + { + "componentName": "Icon", + "props": { + "name": "IconPlus", + "style": "width: 16px; height: 16px; margin-right: 10px;" + }, + "id": "65c89f2b" + }, + { + "componentName": "Text", + "props": { + "text": "增加一块数据盘", + "style": "font-size: 12px; border-radius: 0px; margin-right: 10px;" + }, + "id": "cb344071" + }, + { + "componentName": "Text", + "props": { + "text": "您还可以挂载 21 块磁盘(云硬盘)", + "style": "color: #8a8e99; font-size: 12px;" + }, + "id": "80eea996" + } + ], + "id": "e9e530ab" + } + ], + "id": "078e03ef" + } + ], + "id": "ccef886e" + } + ], + "id": "0fb7bd74" + }, + { + "componentName": "div", + "props": { + "style": "border-width: 1px; border-style: solid; border-color: #ffffff; padding-top: 10px; padding-left: 10px; padding-right: 10px; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px; background-color: #fff; position: fixed; inset: auto 0% 0% 0%; height: 80px; line-height: 80px; border-radius: 0px;" + }, + "children": [ + { + "componentName": "TinyForm", + "props": { + "labelWidth": "80px", + "labelPosition": "top", + "inline": false, + "label-position": "left ", + "label-width": "150px", + "style": "border-radius: 0px;" + }, + "children": [], + "id": "21ed4475" + }, + { + "componentName": "TinyRow", + "props": { + "style": "border-radius: 0px; height: 100%;" + }, + "children": [ + { + "componentName": "TinyCol", + "props": { + "span": "8" + }, + "id": "b9d051a5", + "children": [ + { + "componentName": "TinyRow", + "props": { + "style": "border-radius: 0px;" + }, + "children": [ + { + "componentName": "TinyCol", + "props": { + "span": "5", + "style": "display: flex;" + }, + "id": "02352776", + "children": [ + { + "componentName": "Text", + "props": { + "text": "购买量", + "style": "margin-right: 10px;" + }, + "id": "0cd9ed5c" + }, + { + "componentName": "TinyInput", + "props": { + "placeholder": "请输入", + "modelValue": "", + "style": "width: 120px; margin-right: 10px;" + }, + "id": "2f9cf442" + }, + { + "componentName": "Text", + "props": { + "text": "台" + }, + "id": "facd4481" + } + ] + }, + { + "componentName": "TinyCol", + "props": { + "span": "7" + }, + "id": "82b6c659", + "children": [ + { + "componentName": "div", + "props": {}, + "id": "9cd65874", + "children": [ + { + "componentName": "Text", + "props": { + "text": "配置费用", + "style": "font-size: 12px;" + }, + "id": "b5a0a0da" + }, + { + "componentName": "Text", + "props": { + "text": "¥1.5776", + "style": "padding-left: 10px; padding-right: 10px; color: #de504e;" + }, + "id": "d9464214" + }, + { + "componentName": "Text", + "props": { + "text": "/小时", + "style": "font-size: 12px;" + }, + "id": "af7cc5e6" + } + ] + }, + { + "componentName": "div", + "props": {}, + "id": "89063830", + "children": [ + { + "componentName": "Text", + "props": { + "text": "参考价格,具体扣费请以账单为准。", + "style": "font-size: 12px; border-radius: 0px;" + }, + "id": "d8995fbc" + }, + { + "componentName": "Text", + "props": { + "text": "了解计费详情", + "style": "font-size: 12px; color: #344899;" + }, + "id": "b383c3e2" + } + ] + } + ] + } + ], + "id": "94fc0e43" + } + ] + }, + { + "componentName": "TinyCol", + "props": { + "span": "4", + "style": "display: flex; flex-direction: row-reverse; border-radius: 0px; height: 100%; justify-content: flex-start; align-items: center;" + }, + "id": "10b73009", + "children": [ + { + "componentName": "TinyButton", + "props": { + "text": "下一步: 网络配置", + "type": "danger", + "style": "max-width: unset;" + }, + "id": "0b584011" + } + ] + } + ], + "id": "d414a473" + } + ], + "id": "e8ec029b" + } + ], + "fileName": "createVm" + }, + "tenant": 1, + "isBody": false, + "parentId": "0", + "group": "staticPages", + "depth": 0, + "isPage": true, + "isDefault": false, + "occupier": { + "id": 86, + "username": "开发者", + "email": "developer@lowcode.com", + "resetPasswordToken": "developer", + "confirmationToken": "dfb2c162-351f-4f44-ad5f-8998", + "is_admin": true + }, + "isHome": false, + "_id": "NTJ4MjvqoVj8OVsc" + }, + { + "name": "ComponentsSetting", + "id": "fh7U0xYetFGA5Ieu", + "app": "918", + "route": "componentsSetting", + "page_content": { + "state": { + "components": [ + { + "name": "表单", + "text": "由按钮、输入框、选择器、单选框、多选框等控件组成..." + }, + { + "name": "按钮", + "text": "常用的操作按钮,提供包括默认按钮、图标按钮、图片按钮..." + }, + { + "name": "按钮", + "text": "常用的操作按钮,提供包括默认按钮、图标按钮、图片按钮..." + }, + { + "name": "按钮", + "text": "常用的操作按钮,提供包括默认按钮、图标按钮、图片按钮..." + }, + { + "name": "按钮", + "text": "常用的操作按钮,提供包括默认按钮、图标按钮、图片按钮..." + }, + { + "name": "按钮", + "text": "常用的操作按钮,提供包括默认按钮、图标按钮、图片按钮..." + }, + { + "name": "按钮", + "text": "常用的操作按钮,提供包括默认按钮、图标按钮、图片按钮..." + }, + { + "name": "按钮", + "text": "常用的操作按钮,提供包括默认按钮、图标按钮、图片按钮..." + }, + { + "name": "按钮", + "text": "常用的操作按钮,提供包括默认按钮、图标按钮、图片按钮..." + }, + { + "name": "按钮", + "text": "常用的操作按钮,提供包括默认按钮、图标按钮、图片按钮..." + }, + { + "name": "按钮", + "text": "常用的操作按钮,提供包括默认按钮、图标按钮、图片按钮..." + }, + { + "name": "按钮", + "text": "常用的操作按钮,提供包括默认按钮、图标按钮、图片按钮..." + }, + { + "name": "按钮", + "text": "常用的操作按钮,提供包括默认按钮、图标按钮、图片按钮..." + }, + { + "name": "按钮", + "text": "常用的操作按钮,提供包括默认按钮、图标按钮、图片按钮..." + }, + { + "name": "按钮", + "text": "常用的操作按钮,提供包括默认按钮、图标按钮、图片按钮..." + }, + { + "name": "按钮", + "text": "常用的操作按钮,提供包括默认按钮、图标按钮、图片按钮..." + } + ], + "pageConfig": { + "component": { + "type": "JSResource", + "value": "this.utils.Pager" + }, + "attrs": { + "currentPage": 1, + "pageSize": 50, + "pageSizes": [10, 20, 50], + "total": 0, + "layout": "sizes,total, prev, pager, next, jumper" + } + }, + "componentsTotal": 0, + "renderf5956ed2": [ + { + "label": "按更新时间", + "value": "updata", + "_RID": "row_6" + }, + { + "label": "按创建时间", + "value": "create" + } + ], + "renderb52aeac9": [ + { + "framework": "", + "materials": "", + "name": "表单", + "description": "由按钮、输入框、选择器、单选框、多选框等控件组成,用以收集、校验、提交数据", + "id": "021fd6b6", + "_RID": "row_1" + }, + { + "framework": "", + "materials": "", + "name": "按钮", + "description": "常用的操作按钮,提供包括默认按钮、图标按钮、图片按钮、下拉按钮等类型", + "id": "84d239bb", + "_RID": "row_2" + }, + { + "framework": "", + "materials": "", + "name": "表单项", + "description": "Form 组件下的 FormItem 配置", + "id": "490f8a00", + "_RID": "row_3" + }, + { + "framework": "", + "materials": "", + "name": "开关", + "description": "关闭或打开", + "id": "c259b8b3", + "_RID": "row_4" + }, + { + "framework": "", + "materials": "", + "name": "互斥按钮组", + "description": "以按钮组的方式出现,常用于多项类似操作", + "id": "083ed9c7", + "_RID": "row_5" + }, + { + "framework": "", + "materials": "", + "name": "提示框", + "description": "Popover可通过对一个触发源操作触发弹出框,支持自定义弹出内容,延迟触发和渐变动画", + "id": "09136cea", + "_RID": "row_6" + }, + { + "framework": "", + "materials": "", + "name": "文字提示框", + "description": "动态显示提示信息,一般通过鼠标事件进行响应;提供 warning、error、info、success 四种类型显示不同类别的信", + "id": "a63b57d5", + "_RID": "row_7" + }, + { + "framework": "", + "materials": "", + "name": "树", + "description": "可进行展示有父子层级的数据,支持选择,异步加载等功能。但不推荐用它来展示菜单,展示菜单推荐使用树菜单", + "id": "a0f6e8a3", + "_RID": "row_8" + }, + { + "framework": "", + "materials": "", + "name": "分页", + "description": "当数据量过多时,使用分页分解数据,常用于 Grid 和 Repeater 组件", + "id": "d1aa18fc", + "_RID": "row_9" + }, + { + "framework": "", + "materials": "", + "name": "表格", + "description": "提供了非常强大数据表格功能,可以展示数据列表,可以对数据列表进行选择、编辑等", + "id": "ca49cc52", + "_RID": "row_10" + }, + { + "framework": "", + "materials": "", + "name": "搜索框", + "description": "指定条件对象进行搜索数据", + "id": "4e20ecc9" + }, + { + "framework": "", + "materials": "", + "name": "折叠面板", + "description": "内容区可指定动态页面或自定义 html 等,支持展开收起操作", + "id": "6b093ee5" + }, + { + "framework": "", + "materials": "", + "name": "对话框", + "description": "模态对话框,在浮层中显示,引导用户进行相关操作", + "id": "0a09abc0" + }, + { + "framework": "", + "materials": "", + "name": "标签页签项", + "description": "tab页签", + "id": "f814b901" + }, + { + "framework": "", + "materials": "", + "name": "单选", + "description": "用于配置不同场景的选项,在一组备选项中进行单选", + "id": "c5ae797c" + }, + { + "framework": "", + "materials": "", + "name": "弹出编辑", + "description": "该组件只能在弹出的面板中选择数据,不能手动输入数据;弹出面板中显示为 Tree 组件或者 Grid 组件", + "id": "33d0c590" + }, + { + "framework": "", + "materials": "", + "name": "下拉框", + "description": "Select 选择器是一种通过点击弹出下拉列表展示数据并进行选择的 UI 组件", + "id": "16711dfa" + }, + { + "framework": "", + "materials": "", + "name": "折叠面板项", + "description": "内容区可指定动态页面或自定义 html 等,支持展开收起操作", + "id": "a9fd190a" + }, + { + "framework": "", + "materials": "", + "name": "复选框", + "description": "用于配置不同场景的选项,提供用户可在一组选项中进行多选", + "id": "a7dfa9ec" + }, + { + "framework": "", + "materials": "", + "name": "复选框按钮", + "description": "用于配置不同场景的选项,提供用户可在一组选项中进行多选", + "id": "c9071a7b" + }, + { + "framework": "", + "materials": "", + "name": "输入框", + "description": "通过鼠标或键盘输入字符", + "id": "d4bb8330" + }, + { + "framework": "", + "materials": "", + "name": "时间线", + "description": "时间线", + "id": "ced3dc83" + } + ], + "render7e97d9c7": [ + { + "name": "标签页", + "description": "分隔内容上有关联但属于不同类别的数据集合", + "id": "a2b3e681", + "_RID": "row_1" + }, + { + "name": "走马灯", + "description": "常用于一组图片或卡片轮播,当内容空间不足时,可以用走马灯的形式进行收纳,进行轮播展现", + "id": "311fd1ae", + "_RID": "row_2" + }, + { + "name": "日期选择器", + "description": "用于设置/选择日期,包括年月/年月日/年月日时分/年月日时分秒日期格式", + "id": "8d38b248", + "_RID": "row_3" + }, + { + "name": "布局列", + "description": "列配置信息", + "id": "1f6940d8" + } + ] + }, + "methods": { + "linkClick": { + "type": "JSFunction", + "value": "function linkClick() {\n location.href = '';\n}" + }, + "query": { + "type": "JSFunction", + "value": "function query(name) {\n this.state.components.fillter((e) => {\n return e.name !== name;\n });\n}" + }, + "getTableData": { + "type": "JSFunction", + "value": "function getTableData() {\n return new Promise((resolve, reject) => {\n this.dataSourceMap['timeData'].load().then((res) => {\n resolve({ result: [], page: { total: 0 } });\n });\n });\n}" + }, + "clearSelected": { + "type": "JSFunction", + "value": "function clearSelected(event) {\n this.dataSourceMap['selectedComponents'].map((e) => {\n this.dataSourceMap['selectedComponents'] = this.dataSourceMap['selectedComponents'] || [];\n this.dataSourceMap['componentList'].push(e);\n });\n this.dataSourceMap['selectedComponents'] = [];\n}" + } + }, + "componentName": "Page", + "css": ".components-box{\r\n height:900px;\r\n display: flex;\r\n}\r\n.components-box-left{\r\n width: 270px;\r\n}\r\n.components-box-right{\r\n width:50%;\r\n}\r\n.components-box-right-add{\r\n width: 100%;\r\n height: 200px;\r\n}\r\n.mgr20{\r\n margin-right: 20px;\r\n}", + "props": {}, + "children": [ + { + "componentName": "div", + "props": {}, + "id": "2a5d4622", + "children": [ + { + "componentName": "TinyGrid", + "props": { + "editConfig": { + "trigger": "click", + "mode": "cell", + "showStatus": true + }, + "columns": [ + { + "type": "index", + "width": 60 + }, + { + "type": "selection", + "width": 60 + }, + { + "field": "employees", + "title": "员工数" + }, + { + "field": "created_date", + "title": "创建日期" + }, + { + "field": "city", + "title": "城市" + } + ], + "data": [ + { + "id": "1", + "name": "GFD科技有限公司", + "city": "福州", + "employees": 800, + "created_date": "2014-04-30 00:56:00", + "boole": false + }, + { + "id": "2", + "name": "WWW科技有限公司", + "city": "深圳", + "employees": 300, + "created_date": "2016-07-08 12:36:22", + "boole": true + } + ] + }, + "id": "3635454e" + } + ] + }, + { + "componentName": "div", + "props": { + "style": "height: 80px; width: 87%; margin: 0 auto; margin-bottom: 20px; margin-top: 20px; padding-left: 20px; padding-top: 30px; background: rgb(242, 245, 252);" + }, + "id": "436ecc4a", + "children": [ + { + "componentName": "Text", + "props": { + "text": " 物料资产包简介", + "style": "color: rgb(138, 142, 153);" + }, + "id": "16ad7aa9" + }, + { + "componentName": "Text", + "props": { + "text": "调试构建报错", + "style": "margin-left: 10px; margin-right: 10px;" + }, + "id": "ab44d8ea" + }, + { + "componentName": "Icon", + "props": { + "name": "IconEdit" + }, + "id": "8b6be3c2" + }, + { + "componentName": "div", + "props": {}, + "id": "848e3e8a", + "children": [ + { + "componentName": "Text", + "props": { + "text": "发布地址", + "style": "color: rgb(138, 142, 153);" + }, + "id": "cd51ad2c" + }, + { + "componentName": "Text", + "props": { + "text": "", + "style": "margin-left: 20px; margin-right: 10px; color: rgb(36, 150, 255);", + "onClick": { + "type": "JSExpression", + "value": "this.linkClick" + } + }, + "id": "3ed13633" + }, + { + "componentName": "Icon", + "props": { + "name": "IconEdit" + }, + "id": "16b75d9f" + } + ] + } + ] + }, + { + "componentName": "div", + "props": { + "className": "components-box", + "style": "width: 88%; margin: 0 auto; border-width: 1px; border-color: rgb(223, 225, 230); border-style: solid; padding-top: 40px; padding-bottom: 40px; height: 1200px;" + }, + "id": "c880007b", + "children": [ + { + "componentName": "div", + "props": { + "className": "components-box-left", + "style": "border-right-width: 2px; border-right-style: solid; border-color: rgb(223, 225, 230); position: relative;" + }, + "id": "3525fc52", + "children": [ + { + "componentName": "TinyTimeLine", + "props": { + "active": "1", + "data": [ + { + "name": "添加组件" + }, + { + "name": "添加区块" + } + ], + "horizontal": false, + "className": "components-box-left", + "vertical": true + }, + "id": "1e391ed7" + }, + { + "componentName": "div", + "props": {}, + "id": "81ccd767", + "children": [ + { + "componentName": "div", + "props": { + "style": "height: 300px; position: absolute; bottom: 20px; left: 20px;" + }, + "id": "bc11d593", + "children": [ + { + "componentName": "div", + "props": {}, + "id": "50ed6e39", + "children": [ + { + "componentName": "Text", + "props": { + "text": "组件示意图 " + }, + "id": "fa6b920c" + } + ] + }, + { + "componentName": "div", + "props": {}, + "id": "9ca346e6", + "children": [ + { + "componentName": "Text", + "props": { + "text": "组件是构建物料资产包的必要元素\n", + "style": "margin-top: 10px; color: rgb(173, 176, 184); margin-bottom: 20px;" + }, + "id": "d0ac5a34" + } + ] + }, + { + "componentName": "Img", + "props": { + "src": "http://localhost:9090/assets/images/f750dc319828b039af713c643aad02bd_222x134.png", + "style": "margin-top: 20px; width: 95%;" + }, + "id": "3eac458c" + } + ] + } + ] + } + ] + }, + { + "componentName": "div", + "props": { + "className": ".components-box-right", + "style": "padding-left: 50px; border-radius: 0px; height: 100%;" + }, + "id": "d0890144", + "children": [ + { + "componentName": "div", + "props": { + "className": "components-box-right-add" + }, + "id": "0c79b824", + "children": [ + { + "componentName": "div", + "props": { + "style": "height: 50px;" + }, + "id": "5dd75633", + "children": [ + { + "componentName": "Text", + "props": { + "text": "已添加", + "style": "font-size: 16px; font-weight: bold;" + }, + "id": "e534646e" + }, + { + "componentName": "div", + "props": { + "style": "display: inline-block;", + "onClick": { + "type": "JSExpression", + "value": "this.clearSelected(event)" + } + }, + "id": "1f3f03e5", + "children": [ + { + "componentName": "Icon", + "props": { + "name": "IconUndelete", + "style": "margin-left: 10px; font-size: 20px; color:rgb(94, 124, 224);" + }, + "id": "1ea6eea4" + }, + { + "componentName": "Text", + "props": { + "text": "清空默认", + "style": "color: rgb(94, 124, 224); border-radius: 0px;" + }, + "id": "4f143cd5" + } + ] + } + ] + }, + { + "componentName": "Collection", + "props": { + "style": "height: 140px; display: flex; border-radius: 0px;", + "dataSource": 151 + }, + "id": "9b4f4898", + "children": [ + { + "componentName": "div", + "props": { + "style": "width: 300px; height: 70px; margin-top: 20px; border-top-width: 1px; border-right-width: 1px; border-bottom-width: 1px; border-left-width: 1px; border-width: 1px; border-style: solid; border-color: #dfe1e6; display: flex; flex-direction: row; padding-right: 0px; padding-left: 0px; margin-right: 25px; margin-left: 0px; padding-top: 20px; margin-bottom: 20px; position: relative; background: rgb(242, 245, 252); border-radius: 2px;" + }, + "id": "b5f585f9", + "children": [ + { + "componentName": "Img", + "props": { + "style": "width: 50px; height: 50px; margin-left: 20px; margin-top: 0px;", + "src": "http://localhost:9090/assets/images/24b520f0-dd5d-11ec-9e28-e51c91ead705.png" + }, + "id": "ee90fa60" + }, + { + "componentName": "div", + "props": { + "style": "width: 200px; margin-left: 12px;" + }, + "id": "7735e4da", + "children": [ + { + "componentName": "Text", + "props": { + "text": { + "type": "JSExpression", + "value": "item.name" + }, + "style": "font-weight: bold;" + }, + "id": "068127b6" + }, + { + "componentName": "Text", + "props": { + "text": "默认", + "style": "position: absolute; right: 2px; top: 2px; font-family: \"Microsoft YaHei\"; color: rgb(255, 255, 255); background: rgb(80, 212, 171); border-radius: 4.5px 0px;" + }, + "id": "6d0281d2" + }, + { + "componentName": "TinyCheckbox", + "props": { + "text": "", + "style": "position: absolute; right: 10px; bottom: 10px; color: rgb(82, 110, 204);", + "checked": { + "type": "JSExpression", + "value": "item.isSelected" + }, + "modelValue": true + }, + "id": "622d9bdf" + }, + { + "componentName": "Text", + "props": { + "text": { + "type": "JSExpression", + "value": "item.description" + }, + "style": "display: block; margin-top: 10px; text-overflow: ellipsis; width: 90%; overflow: hidden; white-space: nowrap;" + }, + "id": "eb87da78" + } + ] + } + ], + "loop": { + "type": "JSExpression", + "value": "this.state.render7e97d9c7" + } + } + ] + } + ] + }, + { + "componentName": "div", + "props": { + "style": "width: 98%; display: flex; margin-bottom: 22px; justify-content: space-between; margin-right: 0px; padding-right: 0px;" + }, + "id": "c7f80c55", + "children": [ + { + "componentName": "Text", + "props": { + "text": "选择组件", + "style": "font-size: 16px; font-weight: bold;" + }, + "id": "2ebef929" + }, + { + "componentName": "div", + "props": { + "style": "display: flex;" + }, + "id": "00a6fb16", + "children": [ + { + "componentName": "TinySearch", + "props": { + "modelValue": "", + "placeholder": "输入关键词", + "style": "width: 295px; margin-right: 12px;", + "onChange": { + "type": "JSExpression", + "value": "this.query" + } + }, + "id": "d7364e4d" + }, + { + "componentName": "Collection", + "props": { + "dataSource": 129 + }, + "id": "03a2f95b", + "children": [ + { + "componentName": "TinySelect", + "props": { + "modelValue": "", + "placeholder": "请选择", + "options": { + "type": "JSExpression", + "value": "this.state.renderf5956ed2" + }, + "style": "border-radius: 0px; margin-right: 0px;" + }, + "id": "181b5ab7" + } + ] + } + ] + } + ] + }, + { + "componentName": "Collection", + "props": { + "dataSource": 150, + "style": "margin-left: 0px; margin-right: 314px; display: flex; justify-content: flex-start; flex-wrap: wrap; width: 98%; over-flow: hidden; border-radius: 0px;" + }, + "id": "2b24a6d3", + "children": [ + { + "componentName": "div", + "props": { + "style": "padding-top: 20px; padding-left: 12px; padding-right: 12px; width: 280px; height: 92px; background: rgb(255, 255, 255); border-width: 1px; border-color: rgb(223, 225, 230); border-style: solid; border-radius: 2px; padding-bottom: 20px; display: flex; margin-right: 0px; margin-bottom: 20px; margin-left: 20px;" + }, + "id": "8a6e5b83", + "children": [ + { + "componentName": "Img", + "props": { + "style": "width: 40px; height: 40px;", + "src": "http://localhost:9090/assets/images/0cfe4680-dd6c-11ec-a115-b53bbc5cfe9d.png" + }, + "id": "474ffcb2" + }, + { + "componentName": "div", + "props": { + "style": "margin-left: 12px; border-radius: 0px; width: 90%;" + }, + "id": "99944a57", + "children": [ + { + "componentName": "div", + "props": { + "style": "display: flex; justify-content: space-between;" + }, + "id": "b5c88120", + "children": [ + { + "componentName": "Text", + "props": { + "text": { + "type": "JSExpression", + "value": "item.name" + }, + "style": "font-weight: bold; border-radius: 0px;" + }, + "id": "a747169d" + }, + { + "componentName": "TinyCheckbox", + "props": { + "text": "", + "checked": false, + "modelValue": { + "type": "JSExpression", + "value": "item.isSelected", + "model": true + }, + "style": "border-radius: 0px;" + }, + "id": "72cee0e5" + } + ] + }, + { + "componentName": "Text", + "props": { + "style": "display: block; font-size: 12px; line-height: 17px; color: #333333; margin-top: 10px;", + "text": { + "type": "JSExpression", + "value": "item.description" + } + }, + "id": "1aed3258" + } + ] + } + ], + "loop": { + "type": "JSExpression", + "value": "this.state.renderb52aeac9" + }, + "condition": true, + "loopArgs": ["item", "idx"] + } + ] + }, + { + "componentName": "TinyPager", + "props": { + "layout": "sizes,total, prev, pager, next", + "total": { + "type": "JSExpression", + "value": "this.state.componentsTotal" + }, + "pageSize": 10, + "currentPage": 1, + "style": "margin-left: 314px; margin-right: 314px;" + }, + "id": "ff96cc4e" + } + ] + } + ] + }, + { + "componentName": "div", + "props": { + "style": "height: 100px; background: rgb(255, 255, 255); filter: drop-shadow(rgba(0, 0, 0, 0.1) 0px -1px 4px); text-align: center;" + }, + "id": "616d5f40", + "children": [ + { + "componentName": "TinyButton", + "props": { + "text": "创建物料资产包", + "style": "background: rgb(245, 245, 246); border-width: 1px; border-color: rgb(173, 176, 184); border-style: solid; border-radius: 2.5px; opacity: 0.6; margin: 0 auto; width: 200px; height: 32px; margin-top: 30px; max-width: none; margin-bottom: 10px;" + }, + "id": "e6abff72" + }, + { + "componentName": "Text", + "props": { + "style": "display: block; color: rgb(173, 176, 184); margin-top: 5px; width: 380px; margin: 0 auto;", + "text": "组件或区块未添加,请切换左侧步骤条去完成添加" + }, + "id": "f3a123ba", + "children": [ + { + "componentName": "Icon", + "props": {} + } + ] + } + ] + } + ], + "fileName": "componentsSetting" + }, + "tenant": 1, + "isBody": false, + "parentId": "0", + "group": "staticPages", + "depth": 0, + "isPage": true, + "isDefault": false, + "occupier": { + "id": 86, + "username": "开发者", + "email": "developer@lowcode.com", + "resetPasswordToken": "developer", + "confirmationToken": "dfb2c162-351f-4f44-ad5f-8998", + "is_admin": true + }, + "isHome": true, + "_id": "fh7U0xYetFGA5Ieu" + } + ], + "blockHistories": [ + { + "id": 1655, + "message": "build block 989", + "content": { + "state": { + "logoUrl": "", + "loginImgUrl": "" + }, + "componentName": "Block", + "css": ".home-content {\r\n display: flex;\r\n flex-direction: column;\r\n justify-content: center;\r\n align-items: center;\r\n text-align: center;\r\n height: calc(100vh - 262px);\r\n \r\n}\r\n.home-content .btn {\r\n margin-top: 24px;\r\n \r\n }\r\n .home-content .btn button {\r\n border: none;\r\n border-radius: 30px;\r\n background: #5e7ce0;\r\n \r\n font-size: 14px;\r\n color: #fff;\r\n \r\n cursor: pointer;\r\n }\r\n\r\n .home-content .text {\r\n font-size: 18px;\r\n }\r\n\r\n .home-content .account {\r\n margin-top: 16px;\r\n \r\n \r\n }\r\n\r\n .home-content .account .sub-text {\r\n color: #575d6c;\r\n }\r\n .home-content .account .login {\r\n color: #1890ff;\r\n cursor: pointer;\r\n }\r\n .home-content .logo img{\r\n border-radius: 50%;\r\n overflow: hidden;\r\n }", + "props": {}, + "children": [ + { + "componentName": "div", + "props": { + "className": "home", + "style": "height: 100vh; display: flex;" + }, + "id": "357534ab", + "children": [ + { + "componentName": "TinyRow", + "props": { + "align": "middle", + "flex": true, + "style": "" + }, + "children": [ + { + "componentName": "TinyCol", + "props": { + "span": 6, + "style": "text-align: center; display: flex; justify-content: center;" + }, + "id": "f01b66ea", + "children": [ + { + "componentName": "div", + "props": { + "style": "width: 90%; height: 50%;" + }, + "id": "8197d016", + "children": [ + { + "componentName": "Img", + "props": { + "style": "width: 100%; height: 100%;", + "src": { + "type": "JSExpression", + "value": "this.state.loginImgUrl" + } + }, + "id": "471e30f3" + } + ] + } + ] + }, + { + "componentName": "TinyCol", + "props": { + "span": "6", + "style": "text-align: center;" + }, + "id": "781d5b46", + "children": [ + { + "componentName": "div", + "props": { + "className": "home-content", + "style": "font-size: 14px;" + }, + "id": "08638b8a", + "children": [ + { + "componentName": "div", + "props": { + "className": "text" + }, + "id": "18712ee2", + "children": [ + { + "componentName": "div", + "props": { + "style": "font-size: 16px;" + }, + "id": "07e6794c", + "children": [ + { + "componentName": "div", + "props": { + "className": "logo" + }, + "id": "07cad264", + "children": [ + { + "componentName": "Img", + "props": { + "style": "width: 105px; height: 105px; border-radius: 100px;", + "src": { + "type": "JSExpression", + "value": "this.state.logoUrl" + } + }, + "id": "f4489e27" + } + ] + }, + { + "componentName": "Text", + "props": { + "text": "TinyLowCode 低代码平台", + "style": "display: block; font-size: 28px; margin-top: 12px; margin-bottom: 12px; font-weight: bold;", + "ref": "", + "className": "title" + }, + "id": "e82108ce" + }, + { + "componentName": "Text", + "props": { + "text": "致力于通过友好的用户交互提升业务的开发效率", + "style": "display: block; margin-bottom: 12px;" + }, + "id": "65a2f1ad" + }, + { + "componentName": "Text", + "props": { + "text": "欢迎一起来解锁~~", + "style": "margin-top: 12px;" + }, + "id": "bb879abb" + } + ] + }, + { + "componentName": "div", + "props": { + "className": "btn" + }, + "id": "44b2bcbd", + "children": [ + { + "componentName": "TinyButton", + "props": { + "text": "立即体验", + "round": true, + "type": "primary", + "style": "margin-top: 40px;" + }, + "id": "9580c5e7" + }, + { + "componentName": "div", + "props": { + "className": "account" + }, + "id": "6a8ffa3e", + "children": [ + { + "componentName": "div", + "props": { + "style": "font-size: 14px; margin-top: 4px;" + }, + "id": "bfc6eb6c", + "children": [ + { + "componentName": "Text", + "props": { + "text": "已有团队?", + "style": "color: #777777;" + }, + "id": "3d993264" + }, + { + "componentName": "Text", + "props": { + "text": "立即进入", + "style": "color: #5e7ce0;", + "onClick": { + "type": "JSExpression", + "value": "this.handleClick(event)" + } + }, + "id": "21390118" + } + ] + } + ] + } + ] + } + ] + } + ] + } + ] + } + ], + "id": "4545fea2" + } + ] + } + ], + "methods": { + "handleClick": { + "type": "JSFunction", + "value": "function (event) {this.emit('goto-home', event)\n}" + } + }, + "fileName": "PortalHome", + "meta": { + "id": 1722, + "parentId": "0", + "group": "staticPages", + "title": null, + "occupier": null, + "isHome": false, + "description": "", + "router": "/", + "rootElement": "div", + "creator": "开发者", + "gmt_create": "2022-06-08 03:25:51", + "gmt_modified": "2022-06-09 05:19:09" + }, + "id": 1722, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [] + } + ], + "events": { + "onGotoHome": { + "label": { + "zh_CN": "点击立即进入触发方法" + }, + "description": { + "zh_CN": "点击立即进入触发方法" + }, + "type": "event", + "functionInfo": { + "params": [], + "returns": {} + }, + "defaultValue": "", + "linked": { + "id": "21390118", + "componentName": "Text", + "event": "onClick" + } + } + }, + "slots": {} + }, + "dataSource": {}, + "i18n": {} + }, + "assets": { + "material": [], + "scripts": [ + "http://localhost:9090/assets/js/989web-components.es.js", + "http://localhost:9090/assets/js/989web-components.umd.js" + ], + "styles": [] + }, + "created_by": null, + "updated_by": null, + "created_at": "2023-01-13T08:12:49.000Z", + "updated_at": "2023-01-13T08:12:49.000Z", + "screenshot": "", + "path": "common/components/home", + "label": "PortalHome", + "description": null, + "mode": null, + "block_id": 989, + "version": "1.0.0", + "publishConfig": { + "access": "public" + }, + "i18n": null, + "created_app": null, + "content_blocks": null + }, + { + "id": 1005, + "label": "PortalBlock", + "framework": "Vue", + "content": { + "state": {}, + "methods": {}, + "componentName": "Block", + "fileName": "PortalBlock", + "css": "", + "props": {}, + "children": [ + { + "componentName": "div", + "props": { + "style": "font-size: 18px; height: 40px; border-bottom: 1px solid rgb(223, 225, 230); margin-top: 20px;" + }, + "id": "d38cea57", + "children": [ + { + "componentName": "Icon", + "props": { + "name": "IconChevronLeft" + }, + "id": "86c6e6b0" + }, + { + "componentName": "Text", + "props": { + "text": "编辑物料资产包 | ", + "style": "margin-left: 10px; font-weight: bold;" + }, + "id": "38d9fbc8" + }, + { + "componentName": "Text", + "props": { + "text": { + "type": "JSExpression", + "value": "this.props.blockName" + }, + "style": "margin-left: 10px; font-weight: bold;" + }, + "id": "6cd76396" + } + ] + } + ], + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "blockName", + "type": "String", + "defaultValue": "MT0526-React 1.0", + "label": { + "text": { + "zh_CN": "区块名称" + } + }, + "cols": 12, + "rules": [], + "handle": { + "getter": "", + "setter": "" + }, + "hidden": false, + "required": true, + "readOnly": false, + "disabled": false, + "widget": { + "component": "MetaInput", + "props": { + "modelValue": "MT0526-React 1.0" + } + } + } + ] + } + ], + "events": {}, + "slots": {} + }, + "dataSource": {} + }, + "created_at": "2022-06-28T08:59:54.000Z", + "updated_at": "2023-01-13T08:20:09.000Z", + "assets": { + "material": [], + "scripts": [ + "http://localhost:9090/assets/js/1005web-components.es.js", + "http://localhost:9090/assets/js/1005web-components.umd.js" + ], + "styles": [] + }, + "createdBy": { + "id": 86, + "username": "开发者", + "resetPasswordToken": "developer" + }, + "description": null, + "tags": null, + "current_history": 1665, + "screenshot": "", + "path": "portal", + "occupier": { + "id": 86, + "username": "开发者", + "resetPasswordToken": "developer" + }, + "isOfficial": null, + "public": 1, + "isDefault": null, + "tiny_reserved": false, + "author": null, + "name_cn": null, + "created_app": null, + "content_blocks": null, + "categories": [], + "public_scope_tenants": [], + "histories_length": 1 + } + ], + "materialHistory": { + "id": 639, + "name": "materialstwo", + "material_version": "", + "version": "1.0.8", + "framework": "Vue", + "material": 1505, + "content": { + "data": { + "framework": "Vue", + "materials": { + "blocks": [], + "snippets": [{}], + "components": [ + { + "name": { + "zh_CN": "走马灯子项" + }, + "component": "TinyCarouselItem", + "icon": "carouselitem", + "description": "常用于一组图片或卡片轮播,当内容空间不足时,可以用走马灯的形式进行收纳,进行轮播展现。", + "doc_url": "", + "screenshot": "screenshoot", + "tags": "tiny-carousel-item", + "keywords": "", + "dev_mode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "CarouselItem", + "version": "0.1.16", + "destructuring": true + }, + "group": "component", + "category": "容器组件", + "priority": 2, + "snippets": [], + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": [""] + }, + "contextMenu": { + "actions": ["copy", "remove", "insert", "updateAttr", "bindEevent", "createBlock"], + "disable": [] + }, + "slots": [], + "framework": "Vue" + }, + "createdBy": 169, + "created_at": "2022-06-23T12:05:38.000Z", + "updated_at": "2022-06-27T06:51:25.000Z", + "public": 1, + "framework": "Vue", + "isOfficial": true, + "isDefault": true, + "tiny_reserved": true, + "component_metadata": null, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "name", + "label": { + "text": { + "zh_CN": "幻灯片的名字,可用作 setActiveItem 的参数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "title", + "label": { + "text": { + "zh_CN": "幻灯片的标题" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + } + ] + } + ], + "events": {} + } + }, + { + "name": { + "zh_CN": "复选框按钮" + }, + "component": "TinyCheckboxButton", + "icon": "checkboxbutton", + "description": "用于配置不同场景的选项,提供用户可在一组选项中进行多选", + "doc_url": "", + "screenshot": "screenshot", + "tags": "", + "keywords": "", + "dev_mode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "CheckboxButton", + "version": "0.1.17", + "destructuring": true + }, + "group": "component", + "category": "表单组件", + "priority": 2, + "snippets": [], + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": [""] + }, + "contextMenu": { + "actions": ["remove", "copy", "insert", "updateAttr", "bindEevent", "createBlock"], + "disable": [] + }, + "slots": [], + "framework": "Vue" + }, + "createdBy": 169, + "created_at": "2022-06-17T06:42:16.000Z", + "updated_at": "2022-06-27T08:31:33.000Z", + "public": 1, + "framework": "Vue", + "isOfficial": true, + "isDefault": true, + "tiny_reserved": true, + "component_metadata": null, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "modelValue", + "label": { + "text": { + "zh_CN": "绑定值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "双向绑定的是否选中的状态值" + }, + "labelPosition": "left" + }, + { + "property": "disabled", + "label": { + "text": { + "zh_CN": "是否禁用" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "checked", + "label": { + "text": { + "zh_CN": "勾选" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "当前是否勾选" + }, + "labelPosition": "left" + }, + { + "property": "text", + "label": { + "text": { + "zh_CN": "文本" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "按钮文本" + }, + "labelPosition": "left" + } + ] + } + ], + "events": { + "onChange": { + "label": { + "zh_CN": "勾选值改变后将触发" + }, + "description": { + "zh_CN": "勾选值改变后将触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "boolean", + "defaultValue": "", + "description": { + "zh_CN": "选中项的值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onUpdate:modelValue": { + "label": { + "zh_CN": "双向绑定的值改变时触发" + }, + "description": { + "zh_CN": "是否选中的状态值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "boolean", + "defaultValue": "", + "description": { + "zh_CN": "双向绑定的是否选中的状态值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + } + } + } + }, + { + "name": { + "zh_CN": "树" + }, + "component": "TinyTree", + "icon": "tree", + "description": "可进行展示有父子层级的数据,支持选择,异步加载等功能。但不推荐用它来展示菜单,展示菜单推荐使用树菜单", + "doc_url": "", + "screenshot": "null", + "tags": "", + "keywords": "", + "dev_mode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Tree", + "version": "0.1.16", + "destructuring": true + }, + "group": "component", + "category": "数据组件", + "priority": 12, + "snippets": [ + { + "name": { + "zh_CN": "树" + }, + "icon": "tree", + "screenshot": "", + "snippetName": "TinyTree", + "schema": { + "componentName": "TinyTree", + "props": { + "data": [ + { + "label": "一级 1", + "children": [ + { + "label": "二级 1-1", + "children": [ + { + "label": "三级 1-1-1" + } + ] + } + ] + }, + { + "label": "一级 2", + "children": [ + { + "label": "二级 2-1", + "children": [ + { + "label": "三级 2-1-1" + } + ] + }, + { + "label": "二级 2-2", + "children": [ + { + "label": "三级 2-2-1" + } + ] + } + ] + } + ] + } + } + } + ], + "configure": { + "loop": false, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["show-checkbox"] + }, + "contextMenu": { + "actions": ["copy", "remove", "insert", "updateAttr", "bindEevent", "createBlock"], + "disable": [] + }, + "framework": "Vue" + }, + "createdBy": 169, + "created_at": "2022-05-19T02:31:12.000Z", + "updated_at": "2022-06-30T10:55:59.000Z", + "public": 1, + "framework": "Vue", + "isOfficial": true, + "isDefault": true, + "tiny_reserved": true, + "component_metadata": null, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "show-checkbox", + "label": { + "text": { + "zh_CN": "多选" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "设置接口是否可以多选" + }, + "labelPosition": "left" + }, + { + "property": "data", + "label": { + "text": { + "zh_CN": "数据源" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "defaultValue": [ + { + "label": "一级 1", + "children": [ + { + "label": "二级 1-1" + } + ] + } + ], + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "可配置静态数据源和动态数据源" + } + }, + { + "property": "node-key", + "label": { + "text": { + "zh_CN": "唯一标识" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "节点唯一标识属性名称" + }, + "labelPosition": "left" + }, + { + "property": "icon-trigger-click-node", + "label": { + "text": { + "zh_CN": "触发NodeClick 事件" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "点击图标展开节点时是否触发 node-click 事件" + }, + "labelPosition": "left" + }, + { + "property": "expand-icon", + "label": { + "text": { + "zh_CN": "展开图标" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "节点展开图标" + }, + "labelPosition": "left" + }, + { + "property": "shrink-icon", + "label": { + "text": { + "zh_CN": "收缩图标" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "节点收缩的图标" + }, + "labelPosition": "left" + } + ] + }, + { + "name": "1", + "label": { + "zh_CN": "其他" + }, + "content": [ + { + "property": "check-on-click-node", + "label": { + "text": { + "zh_CN": "点击节点选中" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否在点击节点的时候选中节点,默认值为 false,即只有在点击复选框时才会选中节点" + }, + "labelPosition": "left" + }, + { + "property": "filter-node-method", + "label": { + "text": { + "zh_CN": "筛选函数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "节点筛选函数" + }, + "labelPosition": "left" + } + ], + "description": { + "zh_CN": "" + } + } + ], + "events": { + "onCheck": { + "label": { + "zh_CN": "勾选节点后的事件" + }, + "description": { + "zh_CN": "勾选节点后的事件" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "data", + "type": "object", + "defaultValue": "", + "description": { + "zh_CN": "当前选中节点信息" + } + }, + { + "name": "currentNode", + "type": "object", + "defaultValue": "", + "description": { + "zh_CN": "树组件目前的选中状态信息,包含 checkedNodes、checkedKeys、halfCheckedNodes、halfCheckedKeys 四个属性" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onNodeClick": { + "label": { + "zh_CN": "点击节点后的事件" + }, + "description": { + "zh_CN": "点击节点后的事件" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "data", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "当前选中节点信息" + } + }, + { + "name": "node", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "树组件目前的选中状态信息,包含 checkedNodes、checkedKeys、halfCheckedNodes、halfCheckedKeys 四个属性" + } + }, + { + "name": "vm", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "树组件实例" + } + } + ], + "returns": {} + }, + "defaultValue": "" + } + } + } + }, + { + "name": { + "zh_CN": "提示框" + }, + "component": "TinyPopover", + "icon": "popover", + "description": "Popover可通过对一个触发源操作触发弹出框,支持自定义弹出内容,延迟触发和渐变动画", + "doc_url": "", + "screenshot": "null", + "tags": "", + "keywords": "", + "dev_mode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Popover", + "version": "0.1.16", + "destructuring": true + }, + "group": "component", + "category": "提示组件", + "priority": 7, + "snippets": [ + { + "name": { + "zh_CN": "提示框" + }, + "icon": "popover", + "screenshot": "", + "snippetName": "TinyPopover", + "schema": { + "componentName": "TinyPopover", + "props": { + "width": 200, + "title": "弹框标题", + "trigger": "manual", + "modelValue": true + }, + "children": [ + { + "componentName": "Template", + "props": { + "slot": "reference" + }, + "children": [ + { + "componentName": "div", + "props": { + "placeholder": "触发源" + } + } + ] + }, + { + "componentName": "Template", + "props": { + "slot": "default" + }, + "children": [ + { + "componentName": "div", + "props": { + "placeholder": "提示内容" + } + } + ] + } + ] + } + } + ], + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": true, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["placement", "trigger"] + }, + "contextMenu": { + "actions": ["createBlock", "copy"], + "disable": ["copy", "remove"] + }, + "slots": ["reference"], + "isPopper": true, + "framework": "Vue" + }, + "createdBy": 169, + "created_at": "2022-05-19T02:17:18.000Z", + "updated_at": "2022-07-04T06:23:19.000Z", + "public": 1, + "framework": "Vue", + "isOfficial": true, + "isDefault": true, + "tiny_reserved": true, + "component_metadata": null, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "modelValue", + "label": { + "text": { + "zh_CN": "绑定值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "双向绑定,手动控制是否可见的状态值" + }, + "labelPosition": "left" + }, + { + "property": "placement", + "label": { + "text": { + "zh_CN": "位置" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "top", + "value": "top" + }, + { + "label": "top-start", + "value": "top-start" + }, + { + "label": "top-end", + "value": "top-end" + }, + { + "label": "bottom", + "value": "bottom" + }, + { + "label": "bottom-start", + "value": "bottom-start" + }, + { + "label": "bottom-end", + "value": "bottom-end" + }, + { + "label": "left", + "value": "left" + }, + { + "label": "left-start", + "value": "left-start" + }, + { + "label": "left-end", + "value": "left-end" + }, + { + "label": "right", + "value": "right" + }, + { + "label": "right-start", + "value": "right-start" + }, + { + "label": "right-end", + "value": "right-end" + } + ] + } + }, + "description": { + "zh_CN": "" + }, + "labelPosition": "left" + }, + { + "property": "trigger", + "label": { + "text": { + "zh_CN": "触发方式" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "click", + "value": "click" + }, + { + "label": "focus", + "value": "focus" + }, + { + "label": "hover", + "value": "hover" + }, + { + "label": "manual", + "value": "manual" + } + ] + } + }, + "description": { + "zh_CN": "触发方式,该属性的可选值为 click / focus / hover / manual,该属性的默认值为 click" + } + }, + { + "property": "popper-class", + "label": { + "text": { + "zh_CN": "自定义类" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "为 popper 添加类名" + }, + "labelPosition": "left" + }, + { + "property": "visible-arrow", + "label": { + "text": { + "zh_CN": "显示箭头" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否显示 Tooltip 箭头" + } + }, + { + "property": "append-to-body", + "label": { + "text": { + "zh_CN": "添加到body上" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "Popover弹窗是否添加到body上" + } + }, + { + "property": "arrow-offset", + "label": { + "text": { + "zh_CN": "箭头的位置偏移" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": {} + }, + "description": { + "zh_CN": "箭头的位置偏移,该属性的默认值为 0" + } + }, + { + "property": "close-delay", + "label": { + "text": { + "zh_CN": "隐藏延迟" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": {} + }, + "description": { + "zh_CN": "触发方式为 hover 时的隐藏延迟,单位为毫秒" + } + }, + { + "property": "content", + "label": { + "text": { + "zh_CN": "显示的内容" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "显示的内容,也可以通过 slot 传入 DOM" + } + }, + { + "property": "disabled", + "label": { + "text": { + "zh_CN": "禁用" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "Popover 是否可用" + } + }, + { + "property": "offset", + "label": { + "text": { + "zh_CN": "位置偏移量" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": {} + }, + "description": { + "zh_CN": "出现位置的偏移量" + } + }, + { + "property": "open-delay", + "label": { + "text": { + "zh_CN": "显示延迟" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": {} + }, + "description": { + "zh_CN": "触发方式为 hover 时的显示延迟,单位为毫秒" + } + }, + { + "property": "popper-options", + "label": { + "text": { + "zh_CN": "popper.js的参数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "popper.js 的参数" + } + }, + { + "property": "title", + "label": { + "text": { + "zh_CN": "标题" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "标题" + } + }, + { + "property": "transform-origin", + "label": { + "text": { + "zh_CN": "旋转中心点" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "组件的旋转中心点,组件的旋转中心点" + } + }, + { + "property": "transition", + "label": { + "text": { + "zh_CN": "定义渐变动画" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "该属性的默认值为 fade-in-linear" + } + }, + { + "property": "width", + "label": { + "text": { + "zh_CN": "宽度" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": {} + }, + "description": { + "zh_CN": "宽度" + } + } + ] + } + ], + "events": { + "onUpdate:modelValue": { + "label": { + "zh_CN": "双向绑定的值改变时触发" + }, + "description": { + "zh_CN": "手动控制是否可见的状态值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "boolean", + "defaultValue": "", + "description": { + "zh_CN": "双向绑定的可见状态值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + } + } + } + }, + { + "name": { + "zh_CN": "文字提示框" + }, + "component": "TinyTooltip", + "icon": "tooltip", + "description": "动态显示提示信息,一般通过鼠标事件进行响应;提供 warning、error、info、success 四种类型显示不同类别的信", + "doc_url": "", + "screenshot": "null", + "tags": "", + "keywords": "", + "dev_mode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Tooltip", + "version": "0.1.16", + "destructuring": true + }, + "group": "component", + "category": "提示组件", + "priority": 11, + "snippets": [ + { + "name": { + "zh_CN": "文字提示框" + }, + "icon": "tooltip", + "screenshot": "", + "snippetName": "TinyTooltip", + "schema": { + "componentName": "TinyTooltip", + "props": { + "content": "Top Left 提示文字", + "placement": "top-start", + "manual": true, + "modelValue": true + }, + "children": [ + { + "componentName": "span", + "children": [ + { + "componentName": "div", + "props": { + "placeholder": "触发源" + } + } + ] + }, + { + "componentName": "Template", + "props": { + "slot": "content" + }, + "children": [ + { + "componentName": "span", + "children": [ + { + "componentName": "div", + "props": { + "placeholder": "触发源" + } + } + ] + } + ] + } + ] + } + } + ], + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["text", "", "size"] + }, + "contextMenu": { + "actions": ["createBlock", "copy", "remove", "insert", "updateAttr", "bindEevent"], + "disable": [] + }, + "slots": ["content"], + "isPopper": true, + "framework": "Vue" + }, + "createdBy": 169, + "created_at": "2022-05-19T02:22:59.000Z", + "updated_at": "2022-07-04T06:24:18.000Z", + "public": 1, + "framework": "Vue", + "isOfficial": true, + "isDefault": true, + "tiny_reserved": true, + "component_metadata": null, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 20, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "placement", + "label": { + "text": { + "zh_CN": "提示位置" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "top", + "value": "top" + }, + { + "label": "top-start", + "value": "top-start" + }, + { + "label": "top-end", + "value": "top-end" + }, + { + "label": "bottom", + "value": "bottom" + }, + { + "label": "bottom-start", + "value": "bottom-start" + }, + { + "label": "bottom-end", + "value": "bottom-end" + }, + { + "label": "left", + "value": "left" + }, + { + "label": "left-start", + "value": "left-start" + }, + { + "label": "left-end", + "value": "left-end" + }, + { + "label": "right", + "value": "right" + }, + { + "label": "right-start", + "value": "right-start" + }, + { + "label": "right-end", + "value": "right-end" + } + ] + } + }, + "description": { + "zh_CN": "Tooltip 的出现位置" + }, + "labelPosition": "left" + }, + { + "property": "content", + "label": { + "text": { + "zh_CN": "内容" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "defaultValue": "提示信息", + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "显示的内容,也可以通过 slot#content 传入 DOM" + } + }, + { + "property": "modelValue", + "label": { + "text": { + "zh_CN": "是否可见" + } + }, + "defaultValue": true, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "状态是否可见" + } + }, + { + "property": "manual", + "label": { + "text": { + "zh_CN": "手动控制" + } + }, + "defaultValue": true, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "手动控制模式,设置为 true 后,mouseenter 和 mouseleave 事件将不会生效" + } + } + ] + } + ], + "events": {}, + "slots": { + "content": { + "label": { + "zh_CN": "提示内容" + }, + "description": { + "zh_CN": "自定义提示内容" + } + } + } + } + }, + { + "name": { + "zh_CN": "布局列" + }, + "component": "TinyCol", + "icon": "col", + "description": "列配置信息", + "doc_url": "", + "screenshot": "colscreenshot", + "tags": "", + "keywords": "", + "dev_mode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Col", + "version": "0.1.16", + "destructuring": true + }, + "group": "component", + "category": "布局组件", + "priority": 20, + "snippets": [ + { + "name": { + "zh_CN": "Col" + }, + "icon": "col", + "screenshot": "", + "snippetName": "TinyCol", + "schema": { + "componentName": "TinyCol", + "props": { + "span": 12, + "style": { + "height": "30px", + "border": "1px solid #ccc" + } + } + } + } + ], + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": true, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "TinyRow", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["span"] + }, + "contextMenu": { + "actions": ["copy", "remove", "insert", "updateAttr", "bindEevent", "createBlock"], + "disable": [] + }, + "framework": "Vue" + }, + "createdBy": 169, + "created_at": "2022-05-19T02:40:08.000Z", + "updated_at": "2022-07-15T02:22:42.000Z", + "public": 1, + "framework": "Vue", + "isOfficial": true, + "isDefault": true, + "tiny_reserved": true, + "component_metadata": null, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "span", + "label": { + "text": { + "zh_CN": "栅格列格数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "整行", + "value": 12 + }, + { + "label": "6格", + "value": 6 + }, + { + "label": "4格", + "value": 4 + }, + { + "label": "3格", + "value": 3 + }, + { + "label": "1格", + "value": 1 + } + ] + } + }, + "description": { + "zh_CN": "当一行分为12格时,一列可占位多少格" + } + }, + { + "property": "move", + "label": { + "text": { + "zh_CN": "栅格左右移动格数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": { + "min": -12, + "max": 12 + } + }, + "description": { + "zh_CN": "栅格左右移动格数(正数向右,负数向左)" + } + }, + { + "property": "no", + "label": { + "text": { + "zh_CN": "排序编号" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": { + "max": 12 + } + }, + "description": { + "zh_CN": "排序编号(row中启用order生效)" + } + }, + { + "property": "offset", + "label": { + "text": { + "zh_CN": "间隔格数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": { + "min": 0, + "max": 12 + } + }, + "description": { + "zh_CN": "栅格左侧的间隔格数" + } + }, + { + "property": "xs", + "label": { + "text": { + "zh_CN": "超小屏格数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": { + "min": 1, + "max": 12 + } + }, + "description": { + "zh_CN": "<768px 响应式栅格数" + } + }, + { + "property": "sm", + "label": { + "text": { + "zh_CN": "小屏格数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": { + "min": 1, + "max": 12 + } + }, + "description": { + "zh_CN": "≥768px 响应式栅格数" + } + }, + { + "property": "md", + "label": { + "text": { + "zh_CN": "中屏格数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": { + "min": 1, + "max": 12 + } + }, + "description": { + "zh_CN": "≥992px 响应式栅格数" + } + }, + { + "property": "lg", + "label": { + "text": { + "zh_CN": "大屏格数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": { + "min": 1, + "max": 12 + } + }, + "description": { + "zh_CN": "≥1200px 响应式栅格数" + } + }, + { + "property": "xl", + "label": { + "text": { + "zh_CN": "超大屏格数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": { + "min": 1, + "max": 12 + } + }, + "description": { + "zh_CN": "≥1920px 响应式栅格数" + } + } + ] + } + ], + "events": {} + } + }, + { + "name": { + "zh_CN": "下拉菜单子项" + }, + "component": "TinyDropdownItem", + "icon": "dropdown", + "description": "下拉菜单子项", + "doc_url": "", + "screenshot": "http://localhost:9090/assets/images/logo.png", + "tags": "", + "keywords": "", + "dev_mode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "DropdownItem", + "version": "0.1.16", + "destructuring": true + }, + "group": "component", + "category": "导航组件", + "priority": 2, + "snippets": [{}], + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "isPopper": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "TinyDropdownMenu", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": [""] + }, + "contextMenu": { + "actions": ["copy", "remove", "insert", "updateAttr", "bindEevent", "createBlock"], + "disable": [] + }, + "invalidity": [""], + "clickCapture": true, + "framework": "Vue" + }, + "createdBy": 169, + "created_at": "2022-11-09T03:31:38.000Z", + "updated_at": "2022-11-10T03:47:10.000Z", + "public": 1, + "framework": "Vue", + "isOfficial": true, + "isDefault": true, + "tiny_reserved": true, + "component_metadata": { + "events": [], + "attrs": [ + { + "property": "divided", + "type": "boolean", + "defaultValue": null, + "enumerateValue": null, + "title": "显示分割线", + "_RID": "row_1" + }, + { + "property": "disabled", + "type": "boolean", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_3" + }, + { + "property": "icon", + "type": "string", + "defaultValue": null, + "enumerateValue": null, + "title": "菜单项", + "_RID": "row_2" + }, + { + "property": "label", + "type": "string", + "defaultValue": null, + "enumerateValue": null, + "title": "菜单项标签", + "_RID": "row_1" + } + ], + "slots": { + "default": { + "label": { + "zh_CN": "default" + }, + "description": { + "zh_CN": "下拉列表选项内容" + } + } + } + }, + "schema": { + "properties": [ + { + "name": "0", + "label": { + "zh_CN": "基础信息" + }, + "content": [ + { + "property": "disabled", + "label": { + "text": { + "zh_CN": "是否禁用" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "icon", + "label": { + "text": { + "zh_CN": "图标" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "divided", + "label": { + "text": { + "zh_CN": "显示分割线" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + } + ], + "description": { + "zh_CN": "" + } + } + ], + "events": [], + "slots": { + "default": { + "label": { + "zh_CN": "default" + }, + "description": { + "zh_CN": "下拉列表选项内容" + } + } + } + } + }, + { + "name": { + "zh_CN": "分页" + }, + "component": "TinyPager", + "icon": "pager", + "description": "当数据量过多时,使用分页分解数据,常用于 Grid 和 Repeater 组件", + "doc_url": "", + "screenshot": "null", + "tags": "", + "keywords": "", + "dev_mode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Pager", + "version": "0.1.16", + "destructuring": true + }, + "group": "component", + "category": "数据组件", + "priority": 1, + "snippets": [ + { + "name": { + "zh_CN": "分页" + }, + "icon": "pager", + "screenshot": "", + "snippetName": "TinyPager", + "schema": { + "componentName": "TinyPager", + "props": { + "layout": "total, sizes, prev, pager, next", + "total": 100, + "pageSize": 10, + "currentPage": 1 + } + } + } + ], + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["text", "", "size"] + }, + "contextMenu": { + "actions": [], + "disable": [] + }, + "slots": [], + "framework": "Vue" + }, + "createdBy": 169, + "created_at": "2022-05-19T02:36:23.000Z", + "updated_at": "2022-11-26T02:45:29.000Z", + "public": 1, + "framework": "Vue", + "isOfficial": true, + "isDefault": true, + "tiny_reserved": true, + "component_metadata": { + "events": [ + { + "eventName": "current-change", + "label": "切换页码触发事件", + "params": null, + "defaultValue": null, + "description": "\tcurrentPage 改变时会触发;arg1: 新的当前页的值", + "_RID": "row_1" + }, + { + "eventName": "size-change", + "label": "分页事件", + "params": null, + "defaultValue": null, + "description": "设置分页跳转后的事件;pageSize 改变时会触发;arg1: pageSize 新的当前值", + "_RID": "row_2" + } + ], + "attrs": [], + "slots": [] + }, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 10, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "currentPage", + "label": { + "text": { + "zh_CN": "当前页数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumeric", + "props": {} + }, + "description": { + "zh_CN": "当前页数,支持 .sync 修饰符" + }, + "labelPosition": "left" + }, + { + "property": "pageSize", + "label": { + "text": { + "zh_CN": "每页条数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumeric", + "props": {} + }, + "description": { + "zh_CN": "每页显示条目个数" + }, + "labelPosition": "left" + }, + { + "property": "pageSizes", + "label": { + "text": { + "zh_CN": "可选每页条数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "设置可选择的每页显示条数" + } + }, + { + "property": "total", + "label": { + "text": { + "zh_CN": "总条数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumeric", + "props": {} + }, + "description": { + "zh_CN": "数据总条数" + }, + "labelPosition": "left" + }, + { + "property": "layout", + "label": { + "text": { + "zh_CN": "布局" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": { + "value": "total,sizes,prev, pager, next" + } + }, + "description": { + "zh_CN": "组件布局,子组件名用逗号分隔" + }, + "labelPosition": "left" + } + ] + } + ], + "events": { + "onCurrent-change": { + "label": { + "zh_CN": "切换页码触发事件" + }, + "description": { + "zh_CN": "\tcurrentPage 改变时会触发;arg1: 新的当前页的值" + }, + "type": "event", + "functionInfo": { + "params": [null], + "returns": {} + } + }, + "onSize-change": { + "label": { + "zh_CN": "分页事件" + }, + "description": { + "zh_CN": "设置分页跳转后的事件;pageSize 改变时会触发;arg1: pageSize 新的当前值" + }, + "type": "event", + "functionInfo": { + "params": [null], + "returns": {} + } + } + }, + "slots": [] + } + }, + { + "name": { + "zh_CN": "访问受限页面" + }, + "component": "TinyPlusAccessdeclined", + "icon": "accessdeclined", + "description": "访问受限页面组件", + "doc_url": "", + "screenshot": "http://localhost:9090/assets/images/logo.png", + "tags": "", + "keywords": "受限", + "dev_mode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "AccessDeclined", + "version": "3.4.1", + "destructuring": true + }, + "group": "component", + "category": "业务组件", + "priority": 1, + "snippets": [ + { + "name": { + "zh_CN": "访问受限页面" + }, + "icon": "accessdeclined", + "screenshot": "http://localhost:9090/assets/images/logo.png", + "snippetName": "TinyPlusAccessdeclined", + "schema": { + "componentName": "TinyPlusAccessdeclined", + "props": { + "description": "非常抱歉,您尚未有该服务的访问权限,请联系管理员申请权限。", + "linkText": "返回华为云首页", + "linkHref": "" + } + } + } + ], + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "isPopper": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["text", "size"] + }, + "contextMenu": { + "actions": ["copy", "remove", "insert", "updateAttr", "bindEevent", "createBlock"], + "disable": [] + }, + "invalidity": [""], + "clickCapture": true, + "framework": "Vue" + }, + "createdBy": 169, + "created_at": "2022-11-21T07:08:03.000Z", + "updated_at": "2023-01-18T06:35:58.000Z", + "public": 1, + "framework": "Vue", + "isOfficial": true, + "isDefault": true, + "tiny_reserved": true, + "component_metadata": { + "events": [ + { + "eventName": "description", + "label": null, + "params": null, + "defaultValue": null, + "description": null, + "_RID": "row_1" + } + ], + "attrs": [ + { + "property": "image", + "type": "string", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_4" + }, + { + "property": "linkHref", + "type": "string", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_3" + }, + { + "property": "linkText", + "type": "string", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_2" + }, + { + "property": "description", + "type": "string", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_1" + } + ], + "slots": [] + }, + "schema": { + "properties": [ + { + "name": "0", + "label": { + "zh_CN": "基础信息" + }, + "content": [ + { + "property": "description", + "label": { + "text": { + "zh_CN": "description" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "linkText", + "label": { + "text": { + "zh_CN": "linkText" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "linkHref", + "label": { + "text": { + "zh_CN": "linkHref" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "image", + "label": { + "text": { + "zh_CN": "image" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + } + ], + "description": { + "zh_CN": "" + } + } + ], + "events": {} + } + }, + { + "name": { + "zh_CN": "冻结页面" + }, + "component": "TinyPlusFrozenPage", + "icon": "frozenpage", + "description": "冻结页面组件", + "doc_url": "", + "screenshot": "http://localhost:9090/assets/images/logo.png", + "tags": "", + "keywords": "冻结", + "dev_mode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "FrozenPage", + "version": "3.4.1", + "destructuring": true + }, + "group": "component", + "category": "业务组件", + "priority": 4, + "snippets": [ + { + "name": { + "zh_CN": "冻结页面" + }, + "icon": "frozenpage", + "screenshot": "http://localhost:9090/assets/images/logo.png", + "snippetName": "TinyPlusFrozenPage", + "schema": { + "componentName": "TinyPlusFrozenPage", + "props": { + "description": "非常抱歉,您尚未有该服务的访问权限,请联系管理员申请权限。", + "linkText": "返回华为云首页", + "linkHref": "" + } + } + } + ], + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "isPopper": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["text", "size"] + }, + "contextMenu": { + "actions": ["copy", "remove", "insert", "updateAttr", "bindEevent", "createBlock"], + "disable": [] + }, + "invalidity": [""], + "clickCapture": true, + "framework": "Vue" + }, + "createdBy": 169, + "created_at": "2022-11-22T08:56:31.000Z", + "updated_at": "2023-01-18T06:36:15.000Z", + "public": 1, + "framework": "Vue", + "isOfficial": true, + "isDefault": true, + "tiny_reserved": true, + "component_metadata": { + "events": [], + "attrs": [ + { + "property": "image", + "type": "string", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_25" + }, + { + "property": "linkHref", + "type": "string", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_24" + }, + { + "property": "linkText", + "type": "string", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_23" + }, + { + "property": "description", + "type": "string", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_22" + } + ], + "slots": [] + }, + "schema": { + "properties": [ + { + "name": "0", + "label": { + "zh_CN": "基础信息" + }, + "content": [ + { + "property": "description", + "label": { + "text": { + "zh_CN": "description" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "linkText", + "label": { + "text": { + "zh_CN": "linkText" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "linkHref", + "label": { + "text": { + "zh_CN": "linkHref" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "image", + "label": { + "text": { + "zh_CN": "image" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + } + ], + "description": { + "zh_CN": "" + } + } + ], + "events": [] + } + }, + { + "name": { + "zh_CN": "区域服务不支持页面" + }, + "component": "TinyPlusNonSupportRegion", + "icon": "nonsupportregion", + "description": "区域服务不支持页面组件", + "doc_url": "", + "screenshot": "http://localhost:9090/assets/images/logo.png", + "tags": "", + "keywords": "", + "dev_mode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "NonSupportRegion", + "version": "3.4.1", + "destructuring": true + }, + "group": "component", + "category": "业务组件", + "priority": 5, + "snippets": [ + { + "name": { + "zh_CN": "区域服务不支持页面" + }, + "icon": "nonsupportregion", + "screenshot": "http://localhost:9090/assets/images/logo.png", + "snippetName": "TinyPlusNonSupportRegion", + "schema": { + "componentName": "TinyPlusNonSupportRegion", + "props": { + "regionData": { + "region": { + "displayName": "奥丁" + }, + "supportRegions": [ + { + "displayName": "华北-北京一", + "href": "1" + }, + { + "displayName": "华东-上海二", + "href": "1" + }, + { + "displayName": "华南-广州", + "href": "1" + } + ] + } + } + } + } + ], + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "isPopper": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["text", "size"] + }, + "contextMenu": { + "actions": ["copy", "remove", "insert", "updateAttr", "bindEevent", "createBlock"], + "disable": [] + }, + "invalidity": [""], + "clickCapture": true, + "framework": "Vue" + }, + "createdBy": 169, + "created_at": "2022-11-22T11:18:52.000Z", + "updated_at": "2023-01-18T06:36:24.000Z", + "public": 1, + "framework": "Vue", + "isOfficial": true, + "isDefault": true, + "tiny_reserved": true, + "component_metadata": { + "events": [], + "attrs": [ + { + "property": "image", + "type": "string", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_21" + }, + { + "property": "regionData", + "type": "object", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_20" + }, + { + "property": "regionData", + "type": "object", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_20" + } + ], + "slots": [] + }, + "schema": { + "properties": [ + { + "name": "0", + "label": { + "zh_CN": "基础信息" + }, + "content": [ + { + "property": "regionData", + "label": { + "text": { + "zh_CN": "regionData" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "image", + "label": { + "text": { + "zh_CN": "image" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + } + ], + "description": { + "zh_CN": "" + } + } + ], + "events": [] + } + }, + { + "name": { + "zh_CN": "公测" + }, + "component": "TinyPlusBeta", + "icon": "beta", + "description": "公测组件", + "doc_url": "", + "screenshot": "http://localhost:9090/assets/images/logo.png", + "tags": "", + "keywords": "公测", + "dev_mode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Beta", + "version": "3.4.1", + "destructuring": true + }, + "group": "component", + "category": "业务组件", + "priority": 3, + "snippets": [ + { + "name": { + "zh_CN": "公测" + }, + "icon": "beta", + "screenshot": "http://localhost:9090/assets/images/logo.png", + "snippetName": "TinyPlusBeta", + "schema": {} + } + ], + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "isPopper": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["text", "size"] + }, + "contextMenu": { + "actions": ["copy", "remove", "insert", "updateAttr", "bindEevent", "createBlock"], + "disable": [] + }, + "invalidity": [""], + "clickCapture": true, + "framework": "Vue" + }, + "createdBy": 169, + "created_at": "2022-11-22T08:13:37.000Z", + "updated_at": "2023-01-18T06:36:53.000Z", + "public": 1, + "framework": "Vue", + "isOfficial": true, + "isDefault": true, + "tiny_reserved": true, + "component_metadata": { + "events": [], + "attrs": [ + { + "property": "message", + "type": "string", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_4" + }, + { + "property": "intro", + "type": "string", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_3" + }, + { + "property": "icon", + "type": "string", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_2" + }, + { + "property": "applyUrl", + "type": "string", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_1" + } + ], + "slots": [] + }, + "schema": { + "properties": [ + { + "name": "0", + "label": { + "zh_CN": "基础信息" + }, + "content": [ + { + "property": "applyUrl", + "label": { + "text": { + "zh_CN": "applyUrl" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "icon", + "label": { + "text": { + "zh_CN": "icon" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "intro", + "label": { + "text": { + "zh_CN": "intro" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "message", + "label": { + "text": { + "zh_CN": "message" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + } + ], + "description": { + "zh_CN": "" + } + } + ], + "events": [] + } + }, + { + "name": { + "zh_CN": "搜索框" + }, + "component": "TinySearch", + "icon": "search", + "description": "指定条件对象进行搜索数据", + "doc_url": "", + "screenshot": "searchscreenshot", + "tags": "", + "keywords": "", + "dev_mode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Search", + "version": "0.1.13", + "destructuring": true + }, + "group": "component", + "category": "表单组件", + "priority": 2, + "snippets": [ + { + "name": { + "zh_CN": "搜索框" + }, + "icon": "search", + "screenshot": "", + "snippetName": "TinySearch", + "schema": { + "componentName": "TinySearch", + "props": { + "modelValue": "", + "placeholder": "输入关键词" + } + } + } + ], + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["clearable", "", "mini"] + }, + "contextMenu": { + "actions": ["copy", "remove", "insert", "updateAttr", "createBlock", "bindEevent"], + "disable": [] + }, + "slots": [], + "framework": "Vue" + }, + "createdBy": 169, + "created_at": "2022-05-19T02:47:45.000Z", + "updated_at": "2023-02-16T03:13:14.000Z", + "public": 1, + "framework": "Vue", + "isOfficial": true, + "isDefault": true, + "tiny_reserved": true, + "component_metadata": { + "events": [ + { + "eventName": "search", + "label": "搜索的回调", + "params": null, + "defaultValue": null, + "description": "在展开状态点击搜索按钮时触发的回调函数;arg1:{Object 搜索类型},arg2:{String 当前input框中值}", + "_RID": "row_1" + }, + { + "eventName": "mouseout", + "label": "鼠标离开", + "params": null, + "defaultValue": null, + "description": "鼠标离开时候触发该时间", + "_RID": "row_2" + } + ], + "attrs": [ + { + "property": "isEnterSearch", + "type": "boolean", + "defaultValue": "false", + "enumerateValue": null, + "title": "是否在按下键盘Enter键的时候触发search事件", + "_RID": "row_1" + }, + { + "property": "tiny_mode", + "type": "string", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_1" + }, + { + "property": "button-text", + "type": "string", + "defaultValue": "搜索", + "enumerateValue": null, + "title": null, + "_RID": "row_2" + } + ], + "slots": [] + }, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "modelValue", + "label": { + "text": { + "zh_CN": "默认值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "双向绑定的搜索值" + }, + "labelPosition": "left" + }, + { + "property": "disabled", + "label": { + "text": { + "zh_CN": "禁用" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否被禁用" + }, + "labelPosition": "left" + }, + { + "property": "placeholder", + "label": { + "text": { + "zh_CN": "占位文本 " + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "输入框内的提示占位文本" + }, + "labelPosition": "left" + }, + { + "property": "clearable", + "label": { + "text": { + "zh_CN": "清空按钮" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "设置显示清空图标按钮" + }, + "labelPosition": "left" + } + ] + }, + { + "name": "1", + "label": { + "zh_CN": "其他配置" + }, + "content": [ + { + "property": "mini", + "label": { + "text": { + "zh_CN": "迷你尺寸" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "迷你模式,配置为true时,搜索默认显示为一个带图标的圆形按钮,点击后展开" + }, + "labelPosition": "left" + }, + { + "property": "transparent", + "label": { + "text": { + "zh_CN": "透明模式" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "配置为true时,边框变为透明且收缩后半透明显示,一般用在带有背景的场景,默认 false" + }, + "labelPosition": "left" + }, + { + "property": "isEnterSearch", + "label": { + "text": { + "zh_CN": "isEnterSearch" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + } + }, + { + "property": "tiny_mode", + "label": { + "text": { + "zh_CN": "tiny_mode" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "pc", + "value": "pc" + }, + { + "label": "mobile", + "value": "mobile" + } + ] + } + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "button-text", + "label": { + "text": { + "zh_CN": "button-text" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "自定义搜索框按钮的文本内容" + } + } + ], + "description": { + "zh_CN": "" + } + } + ], + "events": { + "onSearch": { + "label": { + "zh_CN": "搜索的回调" + }, + "description": { + "zh_CN": "在展开状态点击搜索按钮时触发的回调函数;arg1:{Object 搜索类型},arg2:{String 当前input框中值}" + }, + "type": "event", + "functionInfo": { + "params": [null], + "returns": {} + } + }, + "onMouseout": { + "label": { + "zh_CN": "鼠标离开" + }, + "description": { + "zh_CN": "鼠标离开时候触发该时间" + }, + "type": "event", + "functionInfo": { + "params": [null], + "returns": {} + } + } + } + } + }, + { + "name": { + "zh_CN": "布局行" + }, + "component": "TinyRow", + "icon": "row", + "description": "定义 Layout 的行配置信息", + "doc_url": "", + "screenshot": "rowscreenshot", + "tags": "", + "keywords": "", + "dev_mode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Row", + "version": "0.1.16", + "destructuring": true + }, + "group": "component", + "category": "布局组件", + "priority": 2, + "snippets": [ + { + "name": { + "zh_CN": "Row" + }, + "icon": "row", + "screenshot": "", + "snippetName": "TinyRow", + "schema": { + "componentName": "TinyRow", + "props": {}, + "children": [ + { + "componentName": "TinyCol", + "props": { + "span": 3, + "style": "height:100%;" + }, + "children": [ + { + "componentName": "div", + "props": { + "style": "height: 100%;" + } + } + ] + }, + { + "componentName": "TinyCol", + "props": { + "span": 3, + "style": "height:100%;" + }, + "children": [ + { + "componentName": "div", + "props": { + "style": "height: 100%;" + } + } + ] + }, + { + "componentName": "TinyCol", + "props": { + "span": 3, + "style": "height:100%;" + }, + "children": [ + { + "componentName": "div", + "props": { + "style": "height: 100%;" + } + } + ] + }, + { + "componentName": "TinyCol", + "props": { + "span": 3, + "style": "height:100%;" + }, + "children": [ + { + "componentName": "div", + "props": { + "style": "height: 100%;" + } + } + ] + } + ] + } + } + ], + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": true, + "isModal": false, + "nestingRule": { + "childWhitelist": "TinyCol", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["flex", "align"] + }, + "contextMenu": { + "actions": ["copy", "remove", "insert", "updateAttr", "bindEevent", "createBlock"], + "disable": [] + }, + "slots": [], + "framework": "Vue" + }, + "createdBy": 169, + "created_at": "2022-05-19T02:02:47.000Z", + "updated_at": "2023-02-16T03:53:28.000Z", + "public": 1, + "framework": "Vue", + "isOfficial": true, + "isDefault": true, + "tiny_reserved": true, + "component_metadata": { + "events": [], + "attrs": [ + { + "property": "tiny_mode", + "type": "string", + "defaultValue": null, + "enumerateValue": "pc,mobile", + "title": null, + "_RID": "row_44" + } + ], + "slots": [] + }, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "layout", + "label": { + "text": { + "zh_CN": "layout" + } + }, + "cols": 12, + "widget": { + "component": "MetaLayoutGrid", + "props": {} + }, + "description": { + "zh_CN": "layout" + }, + "labelPosition": "none" + }, + { + "property": "align", + "label": { + "text": { + "zh_CN": "align" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "top", + "value": "top" + }, + { + "label": "middle", + "value": "middle" + }, + { + "label": "bottom", + "value": "bottom" + } + ] + } + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "flex", + "label": { + "text": { + "zh_CN": "flex" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "gutter", + "label": { + "text": { + "zh_CN": "gutter" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumeric", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "tiny_mode", + "label": { + "text": { + "zh_CN": "tiny_mode" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "pc", + "value": "pc" + }, + { + "label": "mobile", + "value": "mobile" + } + ] + } + }, + "description": { + "zh_CN": "" + } + } + ] + } + ], + "events": [] + } + }, + { + "name": { + "zh_CN": "表单项" + }, + "component": "TinyFormItem", + "icon": "formitem", + "description": "Form 组件下的 FormItem 配置", + "doc_url": "", + "screenshot": "img/logo.png", + "tags": "", + "keywords": "", + "dev_mode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "FormItem", + "version": "0.1.16", + "destructuring": true + }, + "group": "component", + "category": "表单组件", + "priority": 3, + "snippets": [{}], + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": true, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "TinyForm", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": [""] + }, + "contextMenu": { + "actions": ["remove", "insert", "copy", "updateAttr", "bindEevent", "createBlock"], + "disable": [] + }, + "slots": ["label"], + "framework": "Vue" + }, + "createdBy": 169, + "created_at": "2022-05-09T03:09:44.000Z", + "updated_at": "2023-02-16T06:15:02.000Z", + "public": 1, + "framework": "Vue", + "isOfficial": true, + "isDefault": true, + "tiny_reserved": true, + "component_metadata": { + "events": [], + "attrs": [ + { + "property": "validateIcon", + "type": "object", + "defaultValue": null, + "enumerateValue": null, + "title": "校验提示图标", + "_RID": "row_1" + }, + { + "property": "tiny_mode", + "type": "string", + "defaultValue": null, + "enumerateValue": "pc,mobile", + "title": null, + "_RID": "row_8" + } + ], + "slots": [] + }, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "label", + "label": { + "text": { + "zh_CN": "标签文本" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "defaultValue": "标签", + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "标签文本" + }, + "labelPosition": "left" + }, + { + "property": "prop", + "label": { + "text": { + "zh_CN": "校验字段" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "表单域 model 字段,在使用 validate、resetFields 方法的情况下,该属性是必填的" + } + }, + { + "property": "required", + "label": { + "text": { + "zh_CN": "必填" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否必填" + }, + "labelPosition": "left" + }, + { + "property": "validateIcon", + "label": { + "text": { + "zh_CN": "validateIcon" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + } + } + ] + } + ], + "events": {} + } + }, + { + "name": { + "zh_CN": "警告" + }, + "component": "TinyAlert", + "icon": "alert", + "description": "警告", + "doc_url": "", + "screenshot": "http://localhost:9090/assets/images/logo.png", + "tags": "", + "keywords": "", + "dev_mode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Alert", + "version": "0.1.16", + "destructuring": true + }, + "group": "component", + "category": "提示组件", + "priority": 2, + "snippets": [ + { + "name": { + "zh_CN": "警告" + }, + "icon": "alert", + "screenshot": "http://localhost:9090/assets/images/logo.png", + "snippetName": "TinyAlert", + "schema": { + "componentName": "TinyAlert", + "props": { + "description": "提示内容" + } + } + } + ], + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "isPopper": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["type", "size"] + }, + "contextMenu": { + "actions": ["copy", "remove", "insert", "updateAttr", "bindEevent", "createBlock"], + "disable": [] + }, + "invalidity": [""], + "clickCapture": true, + "framework": "Vue" + }, + "createdBy": 169, + "created_at": "2022-10-25T07:27:44.000Z", + "updated_at": "2023-02-16T06:32:42.000Z", + "public": 1, + "framework": "Vue", + "isOfficial": true, + "isDefault": true, + "tiny_reserved": true, + "component_metadata": { + "events": [ + { + "eventName": "close", + "label": "关闭Alert时触发的事件", + "params": null, + "defaultValue": null, + "description": null, + "_RID": "row_1" + } + ], + "attrs": [ + { + "property": "title", + "type": "string", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_13" + }, + { + "property": "icon", + "type": "string", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_12" + }, + { + "property": "show-icon", + "type": "boolean", + "defaultValue": "true", + "enumerateValue": null, + "title": "是否显示图标", + "_RID": "row_7" + }, + { + "property": "close-text", + "type": "string", + "defaultValue": null, + "enumerateValue": null, + "title": "关闭按钮文本", + "_RID": "row_6" + }, + { + "property": "center", + "type": "boolean", + "defaultValue": "true", + "enumerateValue": null, + "title": "是否居中", + "_RID": "row_5" + }, + { + "property": "description", + "type": "string", + "defaultValue": null, + "enumerateValue": null, + "title": "提示内容", + "_RID": "row_4" + }, + { + "property": "type", + "type": "array", + "defaultValue": "info", + "enumerateValue": null, + "title": "类型", + "_RID": "row_3" + }, + { + "property": "tiny_mode", + "type": "string", + "defaultValue": null, + "enumerateValue": "pc,mobile", + "title": null, + "_RID": "row_1" + } + ], + "slots": { + "description": { + "label": { + "zh_CN": "description" + }, + "description": { + "zh_CN": "提示内容" + } + }, + "title": { + "label": { + "zh_CN": "title" + }, + "description": { + "zh_CN": "标题内容" + } + }, + "default": { + "label": { + "zh_CN": "default" + }, + "description": { + "zh_CN": "默认插槽" + } + } + } + }, + "schema": { + "properties": [ + { + "name": "0", + "label": { + "zh_CN": "基础信息" + }, + "content": [ + { + "property": "show-icon", + "label": { + "text": { + "zh_CN": "是否显示图标" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "close-text", + "label": { + "text": { + "zh_CN": "关闭按钮文本" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "center", + "label": { + "text": { + "zh_CN": "文字是否居中" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "description", + "label": { + "text": { + "zh_CN": "提示内容" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "type", + "label": { + "text": { + "zh_CN": "警告类型" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "success", + "value": "success" + }, + { + "label": "warning", + "value": "warning" + }, + { + "label": "info", + "value": "info" + }, + { + "label": "error", + "value": "error" + } + ] + } + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "closable", + "label": { + "text": { + "zh_CN": "是否可以关闭" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "size", + "label": { + "text": { + "zh_CN": "尺寸" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "normal", + "value": "normal" + }, + { + "label": "large", + "value": "large" + } + ] + } + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "icon", + "label": { + "text": { + "zh_CN": "图标" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "title", + "label": { + "text": { + "zh_CN": "标题,在 size 为 large 时有效" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "tiny_mode", + "label": { + "text": { + "zh_CN": "tiny_mode" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "pc", + "value": "pc" + }, + { + "label": "mobile", + "value": "mobile" + } + ] + } + }, + "description": { + "zh_CN": "" + } + } + ], + "description": { + "zh_CN": "" + } + } + ], + "events": { + "onClose": { + "label": { + "zh_CN": "关闭Alert时触发的事件" + }, + "description": { + "zh_CN": null + }, + "type": "event", + "functionInfo": { + "params": [null], + "returns": {} + } + } + } + } + }, + { + "name": { + "zh_CN": "输入框" + }, + "component": "TinyInput", + "icon": "input", + "description": "通过鼠标或键盘输入字符", + "doc_url": "", + "screenshot": "input-screeshot", + "tags": "", + "keywords": "", + "dev_mode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Input", + "version": "0.1.16", + "destructuring": true + }, + "group": "component", + "category": "表单组件", + "priority": 3, + "snippets": [ + { + "name": { + "zh_CN": "输入框" + }, + "icon": "input", + "screenshot": "", + "snippetName": "TinyInput", + "schema": { + "componentName": "TinyInput", + "props": { + "placeholder": "请输入", + "modelValue": "", + "tiny_mode": "" + } + } + } + ], + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["value", "disabled"] + }, + "contextMenu": { + "actions": ["copy", "remove", "insert", "updateAttr", "bindEevent", "createBlock"], + "disable": [] + }, + "slots": [], + "framework": "Vue" + }, + "createdBy": 169, + "created_at": "2022-05-11T07:22:02.000Z", + "updated_at": "2023-03-06T06:44:18.000Z", + "public": 1, + "framework": "Vue", + "isOfficial": true, + "isDefault": true, + "tiny_reserved": true, + "component_metadata": { + "events": [], + "attrs": [ + { + "property": "key", + "type": "string", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_1" + }, + { + "property": "tiny_mode", + "type": "string", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_2" + }, + { + "property": "modelValue", + "type": "string", + "defaultValue": null, + "enumerateValue": null, + "title": "", + "_RID": "row_1" + }, + { + "property": "type", + "type": "array", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_2" + }, + { + "property": "rows", + "type": "number", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_3" + }, + { + "property": "placeholder", + "type": "string", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_4" + }, + { + "property": "clearable", + "type": "boolean", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_5" + }, + { + "property": "disabled", + "type": "boolean", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_6" + }, + { + "property": "size", + "type": "array", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_7" + }, + { + "property": "maxlength", + "type": "number", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_8" + }, + { + "property": "autofocus", + "type": "boolean", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_9" + } + ], + "slots": [] + }, + "schema": { + "properties": [ + { + "name": "0", + "label": { + "zh_CN": "基础信息" + }, + "content": [ + { + "property": "key", + "label": { + "text": { + "zh_CN": "key" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + } + }, + { + "property": "tiny_mode", + "label": { + "text": { + "zh_CN": "tiny_mode" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "pc", + "value": "pc" + }, + { + "label": "mobile", + "value": "mobile" + } + ] + } + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "modelValue", + "label": { + "text": { + "zh_CN": "绑定值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaBindI18n", + "props": {} + }, + "description": { + "zh_CN": "双向绑定值" + } + }, + { + "property": "type", + "label": { + "text": { + "zh_CN": "类型" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "textarea", + "value": "textarea" + }, + { + "label": "text", + "value": "text" + }, + { + "label": "password", + "value": "password" + } + ] + } + }, + "description": { + "zh_CN": "设置input框的type属性" + } + }, + { + "property": "rows", + "label": { + "text": { + "zh_CN": "行数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": {} + }, + "description": { + "zh_CN": "输入框行数,只对 type='textarea' 有效" + } + }, + { + "property": "placeholder", + "label": { + "text": { + "zh_CN": "占位文本" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaBindI18n", + "props": {} + }, + "description": { + "zh_CN": "输入框占位文本" + } + }, + { + "property": "clearable", + "label": { + "text": { + "zh_CN": "清除按钮" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否显示清除按钮" + } + }, + { + "property": "disabled", + "label": { + "text": { + "zh_CN": "是否禁用" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否禁用" + } + }, + { + "property": "size", + "label": { + "text": { + "zh_CN": "尺寸" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "medium", + "value": "medium" + }, + { + "label": "small", + "value": "small" + }, + { + "label": "mini", + "value": "mini" + } + ] + } + }, + "description": { + "zh_CN": "输入框尺寸。该属性的可选值为 medium / small / mini" + } + }, + { + "property": "maxlength", + "label": { + "text": { + "zh_CN": "最大长度" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumeric", + "props": {} + }, + "description": { + "zh_CN": "最大长度" + } + }, + { + "property": "autofocus", + "label": { + "text": { + "zh_CN": "聚焦" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "自动获取焦点" + } + } + ], + "description": { + "zh_CN": "" + } + } + ], + "events": { + "onChange": { + "label": { + "zh_CN": "值改变时触发" + }, + "description": { + "zh_CN": "在 Input 值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "输入框改变后的值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onInput": { + "label": { + "zh_CN": "输入值改变时触发" + }, + "description": { + "zh_CN": "在 Input 输入值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "输入框输入的值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onUpdate:modelValue": { + "label": { + "zh_CN": "双向绑定的值改变时触发" + }, + "description": { + "zh_CN": "在 Input 输入值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "双向绑定的值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onBlur": { + "label": { + "zh_CN": "失去焦点时触发" + }, + "description": { + "zh_CN": "在 Input 失去焦点时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "event", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "原生 event" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onFocus": { + "label": { + "zh_CN": "获取焦点时触发" + }, + "description": { + "zh_CN": "在 Input 获取焦点时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "event", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "原生 event" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onClear": { + "label": { + "zh_CN": "点击清空按钮时触发" + }, + "description": { + "zh_CN": "点击清空按钮时触发" + }, + "type": "event", + "functionInfo": { + "params": [], + "returns": {} + }, + "defaultValue": "" + } + } + } + }, + { + "name": { + "zh_CN": "标签页" + }, + "component": "TinyTabs", + "icon": "tabs", + "description": "分隔内容上有关联但属于不同类别的数据集合", + "doc_url": "", + "screenshot": "tabsscreenshot", + "tags": "", + "keywords": "", + "dev_mode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Tabs", + "version": "0.1.16", + "destructuring": true + }, + "group": "component", + "category": "容器组件", + "priority": 5, + "snippets": [ + { + "name": { + "zh_CN": "标签页" + }, + "icon": "tabs", + "screenshot": "", + "group": true, + "snippetName": "TinyTabs", + "schema": { + "componentName": "TinyTabs", + "props": { + "modelValue": "first", + "tiny_mode": "" + }, + "children": [ + { + "componentName": "TinyTabItem", + "props": { + "title": "标签页1", + "name": "first" + }, + "children": [ + { + "componentName": "div" + } + ] + }, + { + "componentName": "TinyTabItem", + "props": { + "title": "标签页2", + "name": "second" + }, + "children": [ + { + "componentName": "div" + } + ] + } + ] + } + } + ], + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": "TinyTabItem", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["tab-style", "", "size"] + }, + "contextMenu": { + "actions": ["copy", "remove", "insert", "updateAttr", "bindEevent", "createBlock"], + "disable": [] + }, + "slots": [], + "clickCapture": false, + "framework": "Vue" + }, + "createdBy": 169, + "created_at": "2022-05-19T02:58:09.000Z", + "updated_at": "2023-03-06T06:45:54.000Z", + "public": 1, + "framework": "Vue", + "isOfficial": true, + "isDefault": true, + "tiny_reserved": true, + "component_metadata": { + "events": [], + "attrs": [ + { + "property": "swipeable", + "type": "boolean", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_1" + }, + { + "property": "active-color", + "type": "string", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_2" + }, + { + "property": "tiny_mode", + "type": "string", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_1" + } + ], + "slots": [] + }, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "showEditIcon", + "label": { + "text": { + "zh_CN": "显示编辑ICON " + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否显示标题后编辑 ICON" + }, + "labelPosition": "left" + }, + { + "property": "modelValue", + "label": { + "text": { + "zh_CN": "绑定值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "双向绑定,当前选中选项卡的 name" + }, + "labelPosition": "left" + }, + { + "property": "with-add", + "label": { + "text": { + "zh_CN": "可新增" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "标签是否可增加" + }, + "labelPosition": "left" + }, + { + "property": "with-close", + "label": { + "text": { + "zh_CN": "可关闭" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "标签是否可关闭" + }, + "labelPosition": "left" + }, + { + "property": "tab-style", + "label": { + "text": { + "zh_CN": "标签页样式" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "card", + "value": "card" + }, + { + "label": "border-card", + "value": "border-card" + } + ] + } + }, + "description": { + "zh_CN": "标签页样式" + }, + "labelPosition": "left" + }, + { + "property": "active-color", + "label": { + "text": { + "zh_CN": "active-color" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + } + }, + { + "property": "swipeable", + "label": { + "text": { + "zh_CN": "swipeable" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + } + }, + { + "property": "tiny_mode", + "label": { + "text": { + "zh_CN": "tiny_mode" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "pc", + "value": "pc" + }, + { + "label": "mobile", + "value": "mobile" + } + ] + } + }, + "description": { + "zh_CN": "" + } + } + ] + } + ], + "events": { + "onClick": { + "label": { + "zh_CN": "点击页签时触发事件" + }, + "description": { + "zh_CN": "在 Input 值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "component", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "当前点击的页签对象" + } + }, + { + "name": "event", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "原生 event" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onUpdate:modelValue": { + "label": { + "zh_CN": "双向绑定的值改变时触发" + }, + "description": { + "zh_CN": "当前选中的选项卡改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "双向绑定的当前选中选项卡的 name 值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onEdit": { + "label": { + "zh_CN": "点击新增按钮或关闭按钮或者编辑按钮后触发" + }, + "description": { + "zh_CN": "点击新增按钮或关闭按钮或者编辑按钮后触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "tab", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "当前操作的页签对象" + } + }, + { + "name": "type", + "type": "String", + "defaultValue": "", + "description": { + "zh_CN": "当前操作的类型(remove || add || edit)" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onClose": { + "label": { + "zh_CN": "关闭页签时触发" + }, + "description": { + "zh_CN": "关闭页签时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "name", + "type": "String", + "defaultValue": "", + "description": { + "zh_CN": "页签名称" + } + } + ], + "returns": {} + }, + "defaultValue": "" + } + } + } + }, + { + "name": { + "zh_CN": "下拉菜单menu" + }, + "component": "TinyDropdownMenu", + "icon": "dropdown", + "description": "下拉菜单menu", + "doc_url": "", + "screenshot": "http://localhost:9090/assets/images/logo.png", + "tags": "", + "keywords": "", + "dev_mode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "DropdownMenu", + "version": "0.1.16", + "destructuring": true + }, + "group": "component", + "category": "导航组件", + "priority": 2, + "snippets": [ + { + "name": { + "zh_CN": "下拉菜单menu" + }, + "icon": "dropdown", + "screenshot": "", + "snippetName": "TinyDropdownMenu", + "schema": { + "componentName": "TinyDropdownMenu", + "props": { + "modelValue": "", + "options": [ + { + "value": "1", + "text": "黄金糕" + }, + { + "value": "2", + "text": "双皮奶" + } + ], + "tiny_mode": "" + } + } + } + ], + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "isPopper": false, + "nestingRule": { + "childWhitelist": "DropdownItem", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": [""] + }, + "contextMenu": { + "actions": ["copy", "remove", "insert", "updateAttr", "bindEevent", "createBlock"], + "disable": [] + }, + "invalidity": [""], + "clickCapture": true, + "framework": "Vue" + }, + "createdBy": 169, + "created_at": "2022-11-09T03:28:12.000Z", + "updated_at": "2023-03-06T07:01:00.000Z", + "public": 1, + "framework": "Vue", + "isOfficial": true, + "isDefault": true, + "tiny_reserved": true, + "component_metadata": { + "events": [ + { + "eventName": "open", + "label": null, + "params": null, + "defaultValue": null, + "description": null, + "_RID": "row_27" + }, + { + "eventName": "close", + "label": null, + "params": null, + "defaultValue": null, + "description": "关闭菜单时触发", + "_RID": "row_26" + }, + { + "eventName": "change", + "label": null, + "params": null, + "defaultValue": null, + "description": "点击选项时触发,type为 selection 时启用", + "_RID": "row_25" + } + ], + "attrs": [ + { + "property": "icon", + "type": "string", + "defaultValue": null, + "enumerateValue": null, + "title": "菜单项", + "_RID": "row_2" + }, + { + "property": "label", + "type": "string", + "defaultValue": null, + "enumerateValue": null, + "title": "菜单项标签", + "_RID": "row_1" + }, + { + "property": "tiny_mode", + "type": "string", + "defaultValue": "mobile", + "enumerateValue": "mobile", + "title": null, + "_RID": "row_22" + }, + { + "property": "key", + "type": "string", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_1" + }, + { + "property": "active-color", + "type": "string", + "defaultValue": null, + "enumerateValue": null, + "title": "标题和选项的选中态颜色", + "_RID": "row_2" + }, + { + "property": "close-on-click-outside", + "type": "boolean", + "defaultValue": "true", + "enumerateValue": null, + "title": "设置点击外部元素后关闭菜单", + "_RID": "row_3" + }, + { + "property": "close-on-click-overlay", + "type": "boolean", + "defaultValue": null, + "enumerateValue": null, + "title": "设置点击遮罩层后关闭菜单", + "_RID": "row_4" + }, + { + "property": "direction", + "type": "string", + "defaultValue": "down", + "enumerateValue": null, + "title": "设置弹出框弹出框展开方向", + "_RID": "row_5" + }, + { + "property": "duration", + "type": "number", + "defaultValue": null, + "enumerateValue": null, + "title": "设置弹出框的动画时长", + "_RID": "row_6" + }, + { + "property": "overlay", + "type": "boolean", + "defaultValue": "true", + "enumerateValue": null, + "title": "设置是否显示遮罩层", + "_RID": "row_7" + } + ], + "slots": [ + { + "slotName": "title", + "description": "当type为selection时选项内容", + "_RID": "row_24" + }, + { + "slotName": "icon", + "description": "当type为selection时选项左侧内容", + "_RID": "row_23" + } + ] + }, + "schema": { + "properties": [ + { + "name": "0", + "label": { + "zh_CN": "分组1" + }, + "content": [ + { + "property": "icon", + "label": { + "text": { + "zh_CN": "icon" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + } + }, + { + "property": "label", + "label": { + "text": { + "zh_CN": "label" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + } + }, + { + "property": "tiny_mode", + "label": { + "text": { + "zh_CN": "tiny_mode" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "mobile", + "value": "mobile" + } + ] + } + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "key", + "label": { + "text": { + "zh_CN": "key" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + } + }, + { + "property": "active-color", + "label": { + "text": { + "zh_CN": "active-color" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + } + }, + { + "property": "close-on-click-outside", + "label": { + "text": { + "zh_CN": "close-on-click-outside" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + } + }, + { + "property": "close-on-click-overlay", + "label": { + "text": { + "zh_CN": "close-on-click-overlay" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + } + }, + { + "property": "direction", + "label": { + "text": { + "zh_CN": "direction" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + } + }, + { + "property": "duration", + "label": { + "text": { + "zh_CN": "duration" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumeric", + "props": {} + } + }, + { + "property": "overlay", + "label": { + "text": { + "zh_CN": "overlay" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + } + } + ], + "description": { + "zh_CN": "" + } + } + ], + "events": { + "onOpen": { + "label": { + "zh_CN": null + }, + "description": { + "zh_CN": null + }, + "type": "event", + "functionInfo": { + "params": [null], + "returns": {} + } + }, + "onClose": { + "label": { + "zh_CN": null + }, + "description": { + "zh_CN": "关闭菜单时触发" + }, + "type": "event", + "functionInfo": { + "params": [null], + "returns": {} + } + }, + "onChange": { + "label": { + "zh_CN": null + }, + "description": { + "zh_CN": "点击选项时触发,type为 selection 时启用" + }, + "type": "event", + "functionInfo": { + "params": [null], + "returns": {} + } + } + } + } + }, + { + "name": { + "zh_CN": "对话框" + }, + "component": "TinyDialogBox", + "icon": "dialogbox", + "description": "模态对话框,在浮层中显示,引导用户进行相关操作。", + "doc_url": "", + "screenshot": "dialogboxshot", + "tags": "", + "keywords": "", + "dev_mode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "DialogBox", + "version": "0.1.16", + "destructuring": true + }, + "group": "component", + "category": "容器组件", + "priority": 2, + "snippets": [ + { + "name": { + "zh_CN": "对话框" + }, + "screenshot": "", + "snippetName": "TinyDialogBox", + "icon": "dialogbox", + "schema": { + "componentName": "TinyDialogBox", + "props": { + "visible": true, + "title": "dialogBox title", + "tiny_mode": "" + }, + "children": [ + { + "componentName": "div" + } + ] + } + } + ], + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": ".tiny-dialog-box", + "shortcuts": { + "properties": ["visible", "", "width"] + }, + "contextMenu": { + "actions": ["remove", "insert", "copy", "updateAttr", "bindEevent", "createBlock"], + "disable": [] + }, + "slots": [], + "framework": "Vue" + }, + "createdBy": 169, + "created_at": "2022-05-19T02:55:58.000Z", + "updated_at": "2023-03-06T07:01:26.000Z", + "public": 1, + "framework": "Vue", + "isOfficial": true, + "isDefault": true, + "tiny_reserved": true, + "component_metadata": { + "events": [], + "attrs": [ + { + "property": "close-on-click-modal", + "type": "boolean", + "defaultValue": "true", + "enumerateValue": null, + "title": "是否可以通过点击遮罩层关闭弹窗,默认为 true ,可以在标签上设置:modal-closable=\"false\"不能通过点击遮罩层关闭弹窗。", + "_RID": "row_1" + }, + { + "property": "show-close", + "type": "boolean", + "defaultValue": "true", + "enumerateValue": null, + "title": "是否显示关闭按钮", + "_RID": "row_1" + }, + { + "property": "tiny_mode", + "type": "string", + "defaultValue": null, + "enumerateValue": "pc,mobile", + "title": null, + "_RID": "row_16" + } + ], + "slots": [ + { + "slotName": "footer", + "description": "\tDialog 按钮操作区的内容", + "_RID": "row_2" + } + ] + }, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "title", + "label": { + "text": { + "zh_CN": "标题" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "弹出框标题" + }, + "labelPosition": "left" + }, + { + "property": "visible", + "label": { + "text": { + "zh_CN": "显示与隐藏" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "控制弹出框显示与关闭" + }, + "labelPosition": "left" + }, + { + "property": "width", + "label": { + "text": { + "zh_CN": "宽度" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "弹出框的宽度" + }, + "labelPosition": "left" + }, + { + "property": "draggable", + "label": { + "text": { + "zh_CN": "可拖拽" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否开启弹窗的拖拽功能,默认值为 false 。" + } + }, + { + "property": "center", + "label": { + "text": { + "zh_CN": "居中" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "弹出框的头部与底部内容会自动居中" + }, + "labelPosition": "left" + }, + { + "property": "dialog-class", + "label": { + "text": { + "zh_CN": "自定义类" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "自定义配置弹窗类名" + }, + "labelPosition": "left" + }, + { + "property": "append-to-body", + "label": { + "text": { + "zh_CN": "插入到 Body " + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "DialogBox 本身是否插入到 body 上,嵌套的 Dialog 必须指定该属性并赋值为 true" + }, + "labelPosition": "left" + }, + { + "property": "show-close", + "label": { + "text": { + "zh_CN": "show-close" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": { + "modelValue": true + } + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "close-on-click-modal", + "label": { + "text": { + "zh_CN": "close-on-click-modal" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": { + "modelValue": true + } + }, + "description": { + "zh_CN": "是否可以通过点击遮罩层关闭弹窗,默认为 true ,可以在标签上设置:modal-closable=\"false\"不能通过点击遮罩层关闭弹窗。" + } + }, + { + "property": "tiny_mode", + "label": { + "text": { + "zh_CN": "tiny_mode" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "pc", + "value": "pc" + }, + { + "label": "mobile", + "value": "mobile" + } + ] + } + }, + "description": { + "zh_CN": "" + } + } + ] + } + ], + "events": { + "onClose": { + "label": { + "zh_CN": "关闭弹窗是触发" + }, + "description": { + "zh_CN": "Dialog 关闭的回调" + }, + "type": "event", + "functionInfo": { + "params": [], + "returns": {} + }, + "defaultValue": "" + }, + "onUpdate:modelValue": { + "label": { + "zh_CN": "双向绑定的值改变时触发" + }, + "description": { + "zh_CN": "显示或隐藏的状态值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "boolean", + "defaultValue": "", + "description": { + "zh_CN": "双向绑定的显示或隐藏的状态值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + } + } + } + }, + { + "name": { + "zh_CN": "开关" + }, + "component": "TinySwitch", + "icon": "switch", + "description": "开关开关开关开关开关", + "doc_url": "", + "screenshot": "img/logo.png", + "tags": "", + "keywords": "", + "dev_mode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Switch", + "version": "0.1.16", + "destructuring": true + }, + "group": "component", + "category": "表单组件", + "priority": 5, + "snippets": [ + { + "name": { + "zh_CN": "开关" + }, + "icon": "switch", + "screenshot": "", + "snippetName": "TinySwitch", + "schema": { + "componentName": "TinySwitch", + "props": { + "modelValue": "", + "tiny_mode": "" + } + } + } + ], + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["disabled", "mini"] + }, + "contextMenu": { + "actions": ["copy", "remove", "insert", "updateAttr", "bindEevent", "createBlock"], + "disable": [] + }, + "slots": [], + "framework": "Vue" + }, + "createdBy": 169, + "created_at": "2022-05-12T08:13:59.000Z", + "updated_at": "2023-03-06T07:02:29.000Z", + "public": 1, + "framework": "Vue", + "isOfficial": true, + "isDefault": true, + "tiny_reserved": true, + "component_metadata": { + "events": [], + "attrs": [ + { + "property": "tiny_mode", + "type": "string", + "defaultValue": null, + "enumerateValue": "pc,mobile", + "title": null, + "_RID": "row_3" + } + ], + "slots": [] + }, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "disabled", + "label": { + "text": { + "zh_CN": "禁用" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否被禁用" + }, + "labelPosition": "left" + }, + { + "property": "modelValue", + "label": { + "text": { + "zh_CN": "绑定值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "双向绑定的开关状态值" + } + }, + { + "property": "true-value", + "label": { + "text": { + "zh_CN": "打开时的值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "设置打开时的值(Boolean / String / Number)" + }, + "labelPosition": "left" + }, + { + "property": "false-value", + "label": { + "text": { + "zh_CN": "关闭时的值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "设置关闭时的值(Boolean / String / Number)" + }, + "labelPosition": "left" + }, + { + "property": "mini", + "label": { + "text": { + "zh_CN": "迷你尺寸" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否显示为 mini 模式" + }, + "labelPosition": "left" + }, + { + "property": "tiny_mode", + "label": { + "text": { + "zh_CN": "tiny_mode" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "pc", + "value": "pc" + }, + { + "label": "mobile", + "value": "mobile" + } + ] + } + }, + "description": { + "zh_CN": "" + } + } + ] + } + ], + "events": { + "onChange": { + "label": { + "zh_CN": "点击事件" + }, + "description": { + "zh_CN": "按钮被点击时触发的回调函数" + }, + "type": "event", + "functionInfo": { + "params": [], + "returns": {} + }, + "defaultValue": "" + }, + "onUpdate:modelValue": { + "label": { + "zh_CN": "双向绑定的值改变时触发" + }, + "description": { + "zh_CN": "开关的状态值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "双向绑定的开关状态值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + } + } + } + }, + { + "name": { + "zh_CN": "时间线" + }, + "component": "TinyTimeLine", + "icon": "timeline", + "description": "时间线", + "doc_url": "", + "screenshot": "null", + "tags": "", + "keywords": "", + "dev_mode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "TimeLine", + "version": "0.1.16", + "destructuring": true + }, + "group": "component", + "category": "数据组件", + "priority": 3, + "snippets": [ + { + "name": { + "zh_CN": "时间线" + }, + "icon": "timeline", + "screenshot": "", + "snippetName": "TinyTimeLine", + "schema": { + "componentName": "TinyTimeLine", + "props": { + "active": "2", + "data": [ + { + "name": "已下单" + }, + { + "name": "运输中" + }, + { + "name": "已签收" + } + ], + "tiny_mode": "" + } + } + } + ], + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["horizontal", "", "active"] + }, + "contextMenu": { + "actions": ["copy", "remove", "insert", "updateAttr", "bindEevent", "createBlock"], + "disable": [] + }, + "framework": "Vue" + }, + "createdBy": 169, + "created_at": "2022-05-19T02:26:32.000Z", + "updated_at": "2023-03-06T07:04:21.000Z", + "public": 1, + "framework": "Vue", + "isOfficial": true, + "isDefault": true, + "tiny_reserved": true, + "component_metadata": { + "events": [], + "attrs": [ + { + "property": "tiny_mode", + "type": "string", + "defaultValue": null, + "enumerateValue": "pc,mobile", + "title": null, + "_RID": "row_4" + } + ], + "slots": [] + }, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "vertical", + "type": "Boolean", + "defaultValue": { + "type": "i18n", + "zh_CN": "布局", + "en_US": "layout", + "key": "" + }, + "label": { + "text": { + "zh_CN": "竖向布局" + } + }, + "cols": 12, + "rules": [], + "hidden": false, + "required": true, + "readOnly": false, + "disabled": false, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "竖向时间线" + } + }, + { + "property": "reverse", + "type": "Boolean", + "defaultValue": { + "type": "i18n", + "zh_CN": "布局", + "en_US": "layout", + "key": "" + }, + "label": { + "text": { + "zh_CN": "竖向逆向" + } + }, + "cols": 12, + "rules": [], + "hidden": false, + "required": true, + "readOnly": false, + "disabled": false, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "竖向时数字的顺序,从上到下还是从下到上" + } + }, + { + "property": "horizontal", + "type": "Boolean", + "defaultValue": { + "type": "i18n", + "zh_CN": "布局", + "en_US": "layout", + "key": "" + }, + "label": { + "text": { + "zh_CN": "水平布局" + } + }, + "cols": 12, + "rules": [], + "hidden": false, + "required": true, + "readOnly": false, + "disabled": false, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "节点和文字横向布局" + } + }, + { + "property": "active", + "label": { + "text": { + "zh_CN": "选中值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumeric", + "props": {} + }, + "description": { + "zh_CN": "步骤条的选中步骤值" + }, + "labelPosition": "left" + }, + { + "property": "data", + "label": { + "text": { + "zh_CN": "数据" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "defaultValue": [ + { + "name": "配置基本信息", + "status": "ready" + }, + { + "name": "配置报价", + "status": "wait" + }, + { + "name": "完成报价", + "status": "wait" + } + ], + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "时间线步骤条数据" + }, + "labelPosition": "left" + }, + { + "property": "tiny_mode", + "label": { + "text": { + "zh_CN": "tiny_mode" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "pc", + "value": "pc" + }, + { + "label": "mobile", + "value": "mobile" + } + ] + } + }, + "description": { + "zh_CN": "" + } + } + ] + } + ], + "events": { + "onClick": { + "label": { + "zh_CN": "节点的点击时触发" + }, + "description": { + "zh_CN": "节点的点击时触发的回调函数" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "type", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "点击节点的下标" + } + }, + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "当前节点对象:{ name: 节点名称, time: 时间 }" + } + } + ], + "returns": {} + }, + "defaultValue": "" + } + } + } + }, + { + "name": { + "zh_CN": "标签页签项" + }, + "component": "TinyTabItem", + "icon": "tabitem", + "description": "tab页签", + "doc_url": "", + "screenshot": "tabshot", + "tags": "", + "keywords": "", + "dev_mode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "TabItem", + "version": "0.1.16", + "destructuring": true + }, + "group": "component", + "category": "容器组件", + "priority": 20, + "snippets": [ + { + "name": { + "zh_CN": "标签页签项" + }, + "icon": "tabitem", + "screenshot": "", + "snippetName": "TinyTabItem", + "schema": { + "componentName": "TinyTabItem", + "props": { + "tiny_mode": "" + } + } + } + ], + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "TinyTabs", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["name", "title"] + }, + "contextMenu": { + "actions": ["copy", "remove", "insert", "updateAttr", "bindEevent", "createBlock"], + "disable": [] + }, + "slots": [], + "framework": "Vue" + }, + "createdBy": 169, + "created_at": "2022-05-19T03:00:11.000Z", + "updated_at": "2023-03-06T07:04:47.000Z", + "public": 1, + "framework": "Vue", + "isOfficial": true, + "isDefault": true, + "tiny_reserved": true, + "component_metadata": { + "events": [], + "attrs": [ + { + "property": "tiny_mode", + "type": "string", + "defaultValue": null, + "enumerateValue": "pc,mobile", + "title": null, + "_RID": "row_1" + } + ], + "slots": [] + }, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "name", + "label": { + "text": { + "zh_CN": "唯一表示" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "唯一表示" + } + }, + { + "property": "title", + "label": { + "text": { + "zh_CN": "标题" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "标题" + } + }, + { + "property": "tiny_mode", + "label": { + "text": { + "zh_CN": "tiny_mode" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "pc", + "value": "pc" + }, + { + "label": "mobile", + "value": "mobile" + } + ] + } + }, + "description": { + "zh_CN": "" + } + } + ] + } + ], + "events": {} + } + }, + { + "name": { + "zh_CN": "单选" + }, + "component": "TinyRadio", + "icon": "radio", + "description": "用于配置不同场景的选项,在一组备选项中进行单选", + "doc_url": "", + "screenshot": "img/logo.png", + "tags": "", + "keywords": "", + "dev_mode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Radio", + "version": "0.1.16", + "destructuring": true + }, + "group": "component", + "category": "表单组件", + "priority": 5, + "snippets": [ + { + "name": { + "zh_CN": "单选" + }, + "icon": "radio", + "screenshot": "", + "snippetName": "TinyRadio", + "schema": { + "componentName": "TinyRadio", + "props": { + "label": "1", + "text": "单选文本", + "tiny_mode": "" + } + } + } + ], + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["text", "size"] + }, + "contextMenu": { + "actions": ["copy", "remove", "insert", "updateAttr", "bindEevent", "createBlock"], + "disable": [] + }, + "slots": [], + "framework": "Vue" + }, + "createdBy": 169, + "created_at": "2022-05-16T02:38:18.000Z", + "updated_at": "2023-03-06T07:05:11.000Z", + "public": 1, + "framework": "Vue", + "isOfficial": true, + "isDefault": true, + "tiny_reserved": true, + "component_metadata": { + "events": [], + "attrs": [ + { + "property": "tiny_mode", + "type": "string", + "defaultValue": null, + "enumerateValue": "pc,mobile", + "title": null, + "_RID": "row_13" + } + ], + "slots": [] + }, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "text", + "label": { + "text": { + "zh_CN": "文本" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "label", + "label": { + "text": { + "zh_CN": "单选框的值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "modelValue", + "label": { + "text": { + "zh_CN": "绑定值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "双向绑定的当前选中值" + } + }, + { + "property": "disabled", + "label": { + "text": { + "zh_CN": "禁用" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + } + ] + }, + { + "label": { + "zh_CN": "其他" + }, + "description": { + "zh_CN": "" + }, + "content": [ + { + "property": "border", + "label": { + "text": { + "zh_CN": "显示边框" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "size", + "label": { + "text": { + "zh_CN": "单选框的尺寸" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "name", + "label": { + "text": { + "zh_CN": "原生 name 属性" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "tiny_mode", + "label": { + "text": { + "zh_CN": "tiny_mode" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "pc", + "value": "pc" + }, + { + "label": "mobile", + "value": "mobile" + } + ] + } + }, + "description": { + "zh_CN": "" + } + } + ] + } + ], + "events": { + "onChange": { + "label": { + "zh_CN": "值变化事件" + }, + "description": { + "zh_CN": "绑定值变化时触发的事件" + } + }, + "onUpdate:modelValue": { + "label": { + "zh_CN": "双向绑定的值改变时触发" + }, + "description": { + "zh_CN": "当前选中的值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "双向绑定的当前选中值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + } + } + } + }, + { + "name": { + "zh_CN": "表单" + }, + "component": "TinyForm", + "icon": "form", + "description": "由按钮、输入框、选择器、单选框、多选框等控件组成,用以收集、校验、提交数据", + "doc_url": "", + "screenshot": "formscreenshot", + "tags": "", + "keywords": "", + "dev_mode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Form", + "version": "0.1.16", + "destructuring": true + }, + "group": "component", + "category": "表单组件", + "priority": 2, + "snippets": [ + { + "name": { + "zh_CN": "表单" + }, + "screenshot": "", + "snippetName": "tiny-form", + "icon": "form", + "schema": { + "componentName": "TinyForm", + "props": { + "labelWidth": "80px", + "labelPosition": "top", + "tiny_mode": "" + }, + "children": [ + { + "componentName": "TinyFormItem", + "props": { + "label": "人员" + }, + "children": [ + { + "componentName": "TinyInput", + "props": { + "placeholder": "请输入", + "modelValue": "" + } + } + ] + }, + { + "componentName": "TinyFormItem", + "props": { + "label": "密码" + }, + "children": [ + { + "componentName": "TinyInput", + "props": { + "placeholder": "请输入", + "modelValue": "", + "type": "password" + } + } + ] + }, + { + "componentName": "TinyFormItem", + "props": { + "label": "" + }, + "children": [ + { + "componentName": "TinyButton", + "props": { + "text": "提交", + "type": "primary", + "style": "margin-right: 10px" + } + }, + { + "componentName": "TinyButton", + "props": { + "text": "重置", + "type": "primary" + } + } + ] + } + ] + } + } + ], + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": "TinyFormItem", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["label-width", "", "disabled"] + }, + "contextMenu": { + "actions": ["copy", "remove", "insert", "updateAttr", "bindEevent", "createBlock"], + "disable": [] + }, + "slots": [], + "framework": "Vue" + }, + "createdBy": 169, + "created_at": "2022-05-09T02:50:45.000Z", + "updated_at": "2023-03-06T07:05:36.000Z", + "public": 1, + "framework": "Vue", + "isOfficial": true, + "isDefault": true, + "tiny_reserved": true, + "component_metadata": { + "events": [], + "attrs": [ + { + "property": "tiny_mode", + "type": "string", + "defaultValue": null, + "enumerateValue": "pc,mobile", + "title": null, + "_RID": "row_12" + } + ], + "slots": [] + }, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "disabled", + "label": { + "text": { + "zh_CN": "是否禁用" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "label-width", + "label": { + "text": { + "zh_CN": "标签宽度" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "表单中标签占位宽度,默认为 80px" + }, + "labelPosition": "left" + }, + { + "property": "inline", + "label": { + "text": { + "zh_CN": "行内布局" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "行内布局模式,默认为 false" + } + }, + { + "property": "label-align", + "label": { + "text": { + "zh_CN": "必填标识是否占位" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "必填标识 * 是否占位" + }, + "labelPosition": "left" + }, + { + "property": "label-suffix", + "label": { + "text": { + "zh_CN": "标签后缀" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "表单中标签后缀" + } + }, + { + "property": "label-position", + "label": { + "text": { + "zh_CN": "标签位置" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "right", + "value": "right" + }, + { + "label": "left ", + "value": "left " + }, + { + "label": "top", + "value": "top" + } + ] + } + }, + "description": { + "zh_CN": "表单中标签的布局位置" + } + }, + { + "property": "tiny_mode", + "label": { + "text": { + "zh_CN": "tiny_mode" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "pc", + "value": "pc" + }, + { + "label": "mobile", + "value": "mobile" + } + ] + } + }, + "description": { + "zh_CN": "" + } + } + ] + }, + { + "name": "1", + "label": { + "zh_CN": "校验属性" + }, + "content": [ + { + "property": "model", + "label": { + "text": { + "zh_CN": "表单校验对象" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "表单数据对象" + }, + "labelPosition": "left" + }, + { + "property": "rules", + "label": { + "text": { + "zh_CN": "校验规则" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "表单验证规则" + } + } + ], + "description": { + "zh_CN": "" + } + } + ], + "events": { + "onValidate": { + "label": { + "zh_CN": "表单项被校验后触发" + }, + "description": { + "zh_CN": "表单项被校验后触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "function", + "type": "Function", + "defaultValue": "(valid) => {}", + "description": { + "zh_CN": "校验回调函数" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onInput": { + "label": { + "zh_CN": "输入值改变时触发" + }, + "description": { + "zh_CN": "在 Input 输入值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "输入框输入的值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onBlur": { + "label": { + "zh_CN": "失去焦点时触发" + }, + "description": { + "zh_CN": "在 Input 失去焦点时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "event", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "原生 event" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onFocus": { + "label": { + "zh_CN": "获取焦点时触发" + }, + "description": { + "zh_CN": "在 Input 获取焦点时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "event", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "原生 event" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onClear": { + "label": { + "zh_CN": "点击清空按钮时触发" + }, + "description": { + "zh_CN": "点击清空按钮时触发" + }, + "type": "event", + "functionInfo": { + "params": [], + "returns": {} + }, + "defaultValue": "" + } + } + } + }, + { + "name": { + "zh_CN": "表格" + }, + "component": "TinyGrid", + "icon": "grid", + "description": "提供了非常强大数据表格功能,可以展示数据列表,可以对数据列表进行选择、编辑等", + "doc_url": null, + "screenshot": "null", + "tags": null, + "keywords": null, + "dev_mode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Grid", + "version": "0.1.16", + "destructuring": true + }, + "group": "component", + "category": "数据组件", + "priority": 2, + "snippets": [ + { + "name": { + "zh_CN": "表格" + }, + "icon": "grid", + "screenshot": "", + "snippetName": "tinyGrid", + "schema": { + "componentName": "TinyGrid", + "props": { + "editConfig": { + "trigger": "click", + "mode": "cell", + "showStatus": true + }, + "columns": [ + { + "type": "index", + "width": 60 + }, + { + "type": "selection", + "width": 60 + }, + { + "field": "employees", + "title": "员工数" + }, + { + "field": "created_date", + "title": "创建日期" + }, + { + "field": "city", + "title": "城市" + } + ], + "data": [ + { + "id": "1", + "name": "GFD科技有限公司", + "city": "福州", + "employees": 800, + "created_date": "2014-04-30 00:56:00", + "boole": false + }, + { + "id": "2", + "name": "WWW科技有限公司", + "city": "深圳", + "employees": 300, + "created_date": "2016-07-08 12:36:22", + "boole": true + } + ], + "tiny_mode": "" + } + } + } + ], + "configure": { + "loop": false, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["columns", "", "resizable"] + }, + "contextMenu": { + "actions": ["copy", "remove", "insert", "updateAttr", "bindEevent", "createBlock"], + "disable": [] + }, + "slots": [], + "framework": "Vue", + "invalidity": [""] + }, + "createdBy": 169, + "created_at": "2022-05-19T10:41:29.000Z", + "updated_at": "2023-03-06T07:06:54.000Z", + "public": 1, + "framework": "Vue", + "isOfficial": true, + "isDefault": true, + "tiny_reserved": true, + "component_metadata": { + "events": [ + { + "eventName": "select-change", + "label": "当手动勾选并且值发生改变时触发的事件", + "params": null, + "defaultValue": null, + "description": "只对 type=selection 有效,当手动勾选并且值发生改变时触发的事件;", + "_RID": "row_2" + }, + { + "eventName": "select-all", + "label": "全选时触发的事件", + "params": null, + "defaultValue": null, + "description": "只对 type=selection 有效,当手动勾选全选时触发的事件", + "_RID": "row_1" + }, + { + "eventName": "current-change", + "label": "行选中事件", + "params": "e", + "defaultValue": null, + "description": "行选中事件", + "_RID": "row_4" + } + ], + "attrs": [ + { + "property": "highlight-current-row", + "type": "boolean", + "defaultValue": "false", + "enumerateValue": null, + "title": "是否需要高亮当前行", + "_RID": "row_3" + } + ], + "slots": [] + }, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础属性" + }, + "description": { + "zh_CN": "基础属性" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "data", + "label": { + "text": { + "zh_CN": "表格数据" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": { + "language": "json" + } + }, + "onChange": "this.delProp('fetchData')", + "description": { + "zh_CN": "设置表格的数据" + } + }, + { + "property": "columns", + "label": { + "text": { + "zh_CN": "表格列" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "properties": [ + { + "label": { + "zh_CN": "默认分组" + }, + "content": [ + { + "property": "title", + "type": "string", + "defaultValue": "", + "label": { + "text": { + "zh_CN": "列标题" + } + }, + "widget": { + "component": "MetaBindI18n", + "props": {} + } + }, + { + "property": "field", + "type": "string", + "defaultValue": "", + "label": { + "text": { + "zh_CN": "列键值" + } + }, + "widget": { + "component": "MetaInput", + "props": {} + } + }, + { + "property": "sortable", + "type": "boolean", + "defaultValue": true, + "label": { + "text": { + "zh_CN": "是否排序" + } + }, + "widget": { + "component": "MetaSwitch", + "props": {} + } + }, + { + "property": "width", + "type": "string", + "defaultValue": "", + "label": { + "text": { + "zh_CN": "列宽" + } + }, + "widget": { + "component": "MetaNumber", + "props": {} + } + }, + { + "property": "formatText", + "type": "string", + "defaultValue": "", + "label": { + "text": { + "zh_CN": "内置渲染器" + } + }, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "整数", + "value": "integer" + }, + { + "label": "小数", + "value": "number" + }, + { + "label": "金额", + "value": "money" + }, + { + "label": "百分比", + "value": "rate" + }, + { + "label": "布尔", + "value": "boole" + }, + { + "label": "年月日", + "value": "date" + }, + { + "label": "年月日时分", + "value": "dateTime" + }, + { + "label": "时间", + "value": "time" + }, + { + "label": "省略", + "value": "ellipsis" + } + ] + } + } + }, + { + "property": "renderer", + "type": "object", + "defaultValue": "", + "label": { + "text": { + "zh_CN": "渲染函数" + } + }, + "widget": { + "component": "MetaCodeEditor", + "props": { + "dataType": "JSFunction" + } + } + }, + { + "property": "slots", + "type": "object", + "defaultValue": "", + "label": { + "text": { + "zh_CN": "插槽" + } + }, + "labelPosition": "none", + "widget": { + "component": "MetaJsSlot", + "props": { + "slots": ["header", "default"] + } + } + }, + { + "property": "type", + "label": { + "text": { + "zh_CN": "列类型" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "索引列", + "value": "index" + }, + { + "label": "单选列", + "value": "radio" + }, + { + "label": "多选列", + "value": "selection" + }, + { + "label": "展开列", + "value": "expand" + } + ], + "clearable": true + } + }, + "description": { + "zh_CN": "设置内置列的类型,该属性的可选值为 index(序号)/ selection(复选框)/ radio(单选框)/ expand(展开行)" + }, + "labelPosition": "left" + }, + { + "property": "editor", + "label": { + "text": { + "zh_CN": "编辑配置" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": { + "language": "json" + } + }, + "description": { + "zh_CN": "单元格编辑渲染配置项,也可以是函数 Function(h, params)" + }, + "labelPosition": "left" + }, + { + "property": "filter", + "label": { + "text": { + "zh_CN": "筛选配置" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "设置表格列的筛选配置信息。默认值为 false 不配置筛选信息" + } + }, + { + "property": "showOverflow", + "label": { + "text": { + "zh_CN": "内容超出部分省略号配置" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "只显示省略号", + "value": "ellipsis" + }, + { + "label": "显示为原生 title", + "value": "title" + }, + { + "label": "显示为 tooltip 提示", + "value": "tooltip" + } + ], + "clearable": true + } + }, + "description": { + "zh_CN": "设置内置列的内容超出部分显示省略号配置,该属性的可选值为 ellipsis(只显示省略号)/ title(显示为原生 title)/ tooltip(显示为 tooltip 提示)" + }, + "labelPosition": "left" + } + ] + } + ], + "widget": { + "component": "MetaArrayItem", + "props": { + "type": "object", + "textField": "title", + "language": "json", + "buttonText": "编辑列配置", + "title": "编辑列配置", + "expand": true + } + }, + "description": { + "zh_CN": "表格列的配置信息" + }, + "labelPosition": "left" + }, + { + "property": "fetchData", + "label": { + "text": { + "zh_CN": "服务端数据" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "onChange": "this.delProp('data')", + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": { + "name": "fetchData" + } + }, + "description": { + "zh_CN": "服务端数据查询方法" + } + }, + { + "property": "pager", + "label": { + "text": { + "zh_CN": "分页配置" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "defaultValue": { + "attrs": { + "currentPage": 1 + } + }, + "widget": { + "component": "MetaCodeEditor", + "props": { + "name": "pager" + } + }, + "description": { + "zh_CN": "分页配置" + } + }, + { + "property": "resizable", + "label": { + "text": { + "zh_CN": "调整列宽" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否允许调整列宽" + }, + "labelPosition": "left" + }, + { + "property": "row-id", + "label": { + "text": { + "zh_CN": "行数据唯一标识的字段名" + } + }, + "required": false, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": { + "placeholder": "比如:id" + } + }, + "description": { + "zh_CN": "行数据唯一标识的字段名" + }, + "labelPosition": "left" + }, + { + "property": "select-config", + "label": { + "text": { + "zh_CN": "复选框配置" + } + }, + "required": false, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": { + "dataType": "JSExpression" + } + }, + "description": { + "zh_CN": "表格行数据复选框配置项" + }, + "labelPosition": "left" + }, + { + "property": "edit-rules", + "label": { + "text": { + "zh_CN": "校验规则" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "表格校验规则配置项" + }, + "labelPosition": "left" + }, + { + "property": "edit-config", + "label": { + "text": { + "zh_CN": "编辑配置项" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "表格编辑配置项" + } + }, + { + "property": "expand-config", + "label": { + "text": { + "zh_CN": "复选框配置项" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "复选框配置项" + }, + "labelPosition": "left" + }, + { + "property": "sortable", + "label": { + "text": { + "zh_CN": "可排序" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否允许列数据排序。默认为 true 可排序" + }, + "labelPosition": "left" + }, + { + "property": "highlight-current-row", + "label": { + "text": { + "zh_CN": "highlight-current-row" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + } + } + ] + }, + { + "label": { + "zh_CN": "其他属性" + }, + "description": { + "zh_CN": "其他属性" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "auto-resize", + "label": { + "text": { + "zh_CN": "父元素响应式监听" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "父元素响应式监听(对于父元素可能存在动态变化的场景可能会用到)" + }, + "labelPosition": "left" + }, + { + "property": "border", + "label": { + "text": { + "zh_CN": "边框" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否带有纵向边框" + }, + "labelPosition": "left" + }, + { + "property": "seq-serial", + "label": { + "text": { + "zh_CN": "行号连续" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "设置行序号是否连续,开启分页时有效,该属性的默认值为 false" + }, + "labelPosition": "left" + }, + { + "property": "highlight-hover-row", + "label": { + "text": { + "zh_CN": "hover 高亮" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "鼠标移到行是否要高亮显示" + }, + "labelPosition": "left" + }, + { + "property": "row-class-name", + "label": { + "text": { + "zh_CN": "hover 高亮" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "给行附加 className,也可以是函数 Function({seq, row, rowIndex, $rowIndex})" + }, + "labelPosition": "left" + }, + { + "property": "max-height", + "label": { + "text": { + "zh_CN": "最大高度" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "设置表格内容区域(不含表格头部,底部)的最大高度。" + }, + "labelPosition": "left" + }, + { + "property": "row-span", + "label": { + "text": { + "zh_CN": "行合并" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "设置行合并,该属性仅适用于普通表格,不可与 tree-config 同时使用" + }, + "labelPosition": "left" + } + ] + } + ], + "events": { + "onSelect-change": { + "label": { + "zh_CN": "当手动勾选并且值发生改变时触发的事件" + }, + "description": { + "zh_CN": "只对 type=selection 有效,当手动勾选并且值发生改变时触发的事件;" + }, + "type": "event", + "functionInfo": { + "params": [null], + "returns": {} + } + }, + "onSelect-all": { + "label": { + "zh_CN": "全选时触发的事件" + }, + "description": { + "zh_CN": "只对 type=selection 有效,当手动勾选全选时触发的事件" + }, + "type": "event", + "functionInfo": { + "params": [null], + "returns": {} + } + }, + "onCurrent-change": { + "label": { + "zh_CN": "行选中事件" + }, + "description": { + "zh_CN": "行选中事件" + }, + "type": "event", + "functionInfo": { + "params": ["e"], + "returns": {} + } + } + } + } + }, + { + "name": { + "zh_CN": "计数器" + }, + "component": "TinyNumeric", + "icon": "numeric", + "description": "用于输入数字,可自定义数值范围,步进大小。支持鼠标键盘增减", + "doc_url": "", + "screenshot": "http://localhost:9090/assets/images/logo.png", + "tags": "", + "keywords": "", + "dev_mode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Numeric", + "version": "0.1.16", + "destructuring": true + }, + "group": "component", + "category": "表单组件", + "priority": 2, + "snippets": [ + { + "name": { + "zh_CN": "计数器" + }, + "icon": "numeric", + "screenshot": "http://localhost:9090/assets/images/logo.png", + "snippetName": "TinyNumeric", + "schema": { + "componentName": "TinyNumeric", + "props": { + "tiny_mode": "" + } + } + } + ], + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "isPopper": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["value", "size"] + }, + "contextMenu": { + "actions": ["copy", "remove", "insert", "updateAttr", "bindEevent", "createBlock"], + "disable": [] + }, + "invalidity": [""], + "clickCapture": true, + "framework": "Vue" + }, + "createdBy": 169, + "created_at": "2022-10-25T03:02:56.000Z", + "updated_at": "2023-03-06T07:07:18.000Z", + "public": 1, + "framework": "Vue", + "isOfficial": true, + "isDefault": true, + "tiny_reserved": true, + "component_metadata": { + "events": [ + { + "eventName": "update:modelValue", + "label": "双向绑定的值改变时触发", + "params": null, + "defaultValue": null, + "description": null, + "_RID": "row_2" + }, + { + "eventName": "blur", + "label": "失去焦点事件", + "params": null, + "defaultValue": null, + "description": null, + "_RID": "row_11" + }, + { + "eventName": "focus", + "label": "获得焦点事件", + "params": null, + "defaultValue": null, + "description": null, + "_RID": "row_10" + }, + { + "eventName": "change", + "label": "值变化事件", + "params": null, + "defaultValue": null, + "description": null, + "_RID": "row_11" + } + ], + "attrs": [ + { + "property": "allow-empty", + "type": "boolean", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_9" + }, + { + "property": "format", + "type": "object", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_8" + }, + { + "property": "precision", + "type": "number", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_7" + }, + { + "property": "placeholder", + "type": "string", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_6" + }, + { + "property": "label", + "type": "string", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_5" + }, + { + "property": "name", + "type": "string", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_4" + }, + { + "property": "controls-position", + "type": "string", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_3" + }, + { + "property": "controls", + "type": "boolean", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_2" + }, + { + "property": "step-strictly", + "type": "boolean", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_1" + }, + { + "property": "modelValue", + "type": "number", + "defaultValue": null, + "enumerateValue": null, + "title": "绑定值", + "_RID": "row_10" + }, + { + "property": "size", + "type": "array", + "defaultValue": "small", + "enumerateValue": "mini,small,medium", + "title": "尺寸", + "_RID": "row_9" + }, + { + "property": "disabled", + "type": "boolean", + "defaultValue": "false", + "enumerateValue": null, + "title": "禁用", + "_RID": "row_8" + }, + { + "property": "mouse-wheel", + "type": "boolean", + "defaultValue": "true", + "enumerateValue": null, + "title": "鼠标滚动", + "_RID": "row_6" + }, + { + "property": "circulate", + "type": "boolean", + "defaultValue": "false", + "enumerateValue": null, + "title": "数值循环", + "_RID": "row_5" + }, + { + "property": "tiny_mode", + "type": "string", + "defaultValue": null, + "enumerateValue": "pc,mobile", + "title": null, + "_RID": "row_2" + } + ], + "slots": [] + }, + "schema": { + "properties": [ + { + "name": "0", + "label": { + "zh_CN": "基础信息" + }, + "content": [ + { + "property": "modelValue", + "label": { + "text": { + "zh_CN": "绑定值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumeric", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "size", + "label": { + "text": { + "zh_CN": "尺寸" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "mini", + "value": "mini" + }, + { + "label": "small", + "value": "small" + }, + { + "label": "medium", + "value": "medium" + } + ] + } + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "disabled", + "label": { + "text": { + "zh_CN": "禁用" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "mouse-wheel", + "label": { + "text": { + "zh_CN": "鼠标滚动滑轮是否改变数值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "circulate", + "label": { + "text": { + "zh_CN": "向上到达最大值后从最小值开始,或反过来" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "step", + "label": { + "text": { + "zh_CN": "步长" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumeric", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "max", + "label": { + "text": { + "zh_CN": "最大数值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumeric", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "min", + "label": { + "text": { + "zh_CN": "最小数值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumeric", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "controls", + "label": { + "text": { + "zh_CN": "是否使用控制按钮" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "controls-position", + "label": { + "text": { + "zh_CN": "控制按钮位置;该属性的可选值为 right" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "step-strictly", + "label": { + "text": { + "zh_CN": "是否只能输入 step 的倍数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "name", + "label": { + "text": { + "zh_CN": "原生属性" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "label", + "label": { + "text": { + "zh_CN": "输入框关联的label文字" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "placeholder", + "label": { + "text": { + "zh_CN": "输入框内的提示占位文本" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "precision", + "label": { + "text": { + "zh_CN": "数值精度" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumeric", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "format", + "label": { + "text": { + "zh_CN": "数字格式化置项" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "allow-empty", + "label": { + "text": { + "zh_CN": "计数器内容可清空" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "tiny_mode", + "label": { + "text": { + "zh_CN": "tiny_mode" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "pc", + "value": "pc" + }, + { + "label": "mobile", + "value": "mobile" + } + ] + } + }, + "description": { + "zh_CN": "" + } + } + ], + "description": { + "zh_CN": "" + } + } + ], + "events": { + "onUpdate:modelValue": { + "label": { + "zh_CN": "双向绑定的值改变时触发" + }, + "description": { + "zh_CN": "计数器的值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "number", + "defaultValue": "", + "description": { + "zh_CN": "双向绑定的计数值" + } + } + ], + "returns": {} + } + }, + "onBlur": { + "label": { + "zh_CN": "失去焦点事件" + }, + "description": { + "zh_CN": null + }, + "type": "event", + "functionInfo": { + "params": [null], + "returns": {} + } + }, + "onFocus": { + "label": { + "zh_CN": "获得焦点事件" + }, + "description": { + "zh_CN": null + }, + "type": "event", + "functionInfo": { + "params": [null], + "returns": {} + } + }, + "onChange": { + "label": { + "zh_CN": "值变化事件" + }, + "description": { + "zh_CN": null + }, + "type": "event", + "functionInfo": { + "params": [null], + "returns": {} + } + } + } + } + }, + { + "name": { + "zh_CN": "复选框按钮组" + }, + "component": "TinyCheckboxGroup", + "icon": "checkboxgroup", + "description": "用于配置不同场景的选项,提供用户可在一组选项中进行多选", + "doc_url": "", + "screenshot": "screenshot", + "tags": "", + "keywords": "复选框按钮组", + "dev_mode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "CheckboxGroup", + "version": "0.1.17", + "destructuring": true + }, + "group": "component", + "category": "表单组件", + "priority": 2, + "snippets": [ + { + "name": { + "zh_CN": "复选框组" + }, + "icon": "checkboxs", + "screenshot": "", + "snippetName": "TinyCheckboxGroup", + "schema": { + "componentName": "TinyCheckboxGroup", + "props": { + "modelValue": ["name1", "name2"], + "type": "checkbox", + "options": [ + { + "text": "复选框1", + "label": "name1" + }, + { + "text": "复选框2", + "label": "name2" + }, + { + "text": "复选框3", + "label": "name3" + } + ], + "tiny_mode": "" + } + } + }, + { + "name": { + "zh_CN": "复选框拖拽按钮组" + }, + "icon": "checkboxgroup", + "screenshot": "", + "snippetName": "TinyCheckboxbuttonGroup", + "schema": { + "componentName": "TinyCheckboxGroup", + "props": { + "modelValue": [] + }, + "children": [ + { + "componentName": "TinyCheckboxButton", + "children": [ + { + "componentName": "div" + } + ] + } + ] + } + } + ], + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["text", "size"] + }, + "contextMenu": { + "actions": ["copy", "remove", "insert", "updateAttr", "bindEevent", "createBlock"], + "disable": [] + }, + "slots": [], + "framework": "Vue" + }, + "createdBy": 169, + "created_at": "2022-06-18T03:09:20.000Z", + "updated_at": "2023-03-06T07:08:09.000Z", + "public": 1, + "framework": "Vue", + "isOfficial": true, + "isDefault": true, + "tiny_reserved": true, + "component_metadata": { + "events": [], + "attrs": [ + { + "property": "tiny_mode", + "type": "string", + "defaultValue": null, + "enumerateValue": "pc,mobile", + "title": null, + "_RID": "row_45" + } + ], + "slots": [] + }, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "modelValue", + "label": { + "text": { + "zh_CN": "绑定值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": { + "dataType": "Array" + } + }, + "description": { + "zh_CN": "双向绑定选中的选项值" + }, + "labelPosition": "left" + }, + { + "property": "disabled", + "label": { + "text": { + "zh_CN": "是否禁用" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "options", + "label": { + "text": { + "zh_CN": "数据列表" + } + }, + "defaultValue": [ + { + "label": "标签2" + }, + { + "label": "标签2" + } + ], + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "checkbox组件列表" + } + }, + { + "property": "type", + "label": { + "text": { + "zh_CN": "类型" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "button", + "value": "button" + }, + { + "label": "checkbox", + "value": "checkbox" + } + ] + } + }, + "description": { + "zh_CN": "checkbox组件类型(button/checkbox),该属性的默认值为 checkbox,配合 options 属性一起使用" + }, + "labelPosition": "left" + }, + { + "property": "tiny_mode", + "label": { + "text": { + "zh_CN": "tiny_mode" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "pc", + "value": "pc" + }, + { + "label": "mobile", + "value": "mobile" + } + ] + } + }, + "description": { + "zh_CN": "" + } + } + ] + } + ], + "events": { + "onChange": { + "label": { + "zh_CN": "勾选值改变后将触发" + }, + "description": { + "zh_CN": "勾选值改变后将触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "array", + "defaultValue": "", + "description": { + "zh_CN": "选中项的值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onUpdate:modelValue": { + "label": { + "zh_CN": "双向绑定的值改变时触发" + }, + "description": { + "zh_CN": "双向绑定选中的选项值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "array", + "defaultValue": "", + "description": { + "zh_CN": "双向绑定的选中选项值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + } + } + } + }, + { + "name": { + "zh_CN": "下拉框" + }, + "component": "TinySelect", + "icon": "select", + "description": "Select 选择器是一种通过点击弹出下拉列表展示数据并进行选择的 UI 组件", + "doc_url": "", + "screenshot": "selectScreenshot", + "tags": "", + "keywords": "", + "dev_mode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Select", + "version": "0.1.16", + "destructuring": true + }, + "group": "component", + "category": "表单组件", + "priority": 2, + "snippets": [ + { + "name": { + "zh_CN": "下拉框" + }, + "icon": "select", + "screenshot": "", + "snippetName": "TinySelect", + "schema": { + "componentName": "TinySelect", + "props": { + "modelValue": "", + "placeholder": "请选择", + "options": [ + { + "value": "1", + "label": "黄金糕" + }, + { + "value": "2", + "label": "双皮奶" + } + ], + "tiny_mode": "" + } + } + } + ], + "configure": { + "loop": false, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["multiple", "", "options"] + }, + "contextMenu": { + "actions": ["copy", "remove", "insert", "updateAttr", "bindEevent", "createBlock"], + "disable": [] + }, + "slots": [], + "framework": "Vue" + }, + "createdBy": 169, + "created_at": "2022-05-19T02:44:05.000Z", + "updated_at": "2023-03-06T07:08:49.000Z", + "public": 1, + "framework": "Vue", + "isOfficial": true, + "isDefault": true, + "tiny_reserved": true, + "component_metadata": { + "events": [], + "attrs": [ + { + "property": "searchable", + "type": "boolean", + "defaultValue": "false", + "enumerateValue": null, + "title": "是否可搜索", + "_RID": "row_1" + }, + { + "property": "tiny_mode", + "type": "string", + "defaultValue": "", + "enumerateValue": null, + "title": null, + "_RID": "row_1" + } + ], + "slots": [] + }, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 10, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "modelValue", + "label": { + "text": { + "zh_CN": "绑定值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "双向绑定的当前选中值" + }, + "labelPosition": "left" + }, + { + "property": "placeholder", + "label": { + "text": { + "zh_CN": "占位文本" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "输入框占位文本" + }, + "labelPosition": "left" + }, + { + "property": "clearable", + "label": { + "text": { + "zh_CN": "清除按钮" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否显示清除按钮" + }, + "labelPosition": "left" + }, + { + "property": "searchable", + "label": { + "text": { + "zh_CN": "下拉面板可搜索" + } + }, + "required": false, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "下拉面板是否可搜索" + }, + "labelPosition": "left" + }, + { + "property": "disabled", + "label": { + "text": { + "zh_CN": "是否禁用" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "options", + "label": { + "text": { + "zh_CN": "下拉数据" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": { + "language": "json" + } + }, + "description": { + "zh_CN": "配置 Select 下拉数据项" + }, + "labelPosition": "left" + }, + { + "property": "multiple", + "label": { + "text": { + "zh_CN": "多选" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否允许输入框输入或选择多个项" + }, + "labelPosition": "left" + } + ] + }, + { + "name": "1", + "label": { + "zh_CN": "其他" + }, + "content": [ + { + "property": "multiple-limit", + "label": { + "text": { + "zh_CN": "最大可选值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumeric", + "props": {} + }, + "description": { + "zh_CN": "多选时用户最多可以选择的项目数,为 0 则不限制" + }, + "labelPosition": "left" + }, + { + "property": "popper-class", + "label": { + "text": { + "zh_CN": "下拉框的类名" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "设置下拉框自定义的类名" + }, + "labelPosition": "left" + }, + { + "property": "collapse-tags", + "label": { + "text": { + "zh_CN": "多选展示" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "多选时是否将选中值按文字的形式展示" + }, + "labelPosition": "left" + }, + { + "property": "tiny_mode", + "label": { + "text": { + "zh_CN": "tiny_mode" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "pc", + "value": "pc" + } + ] + } + }, + "description": { + "zh_CN": "" + } + } + ], + "description": { + "zh_CN": "" + } + } + ], + "events": { + "onChange": { + "label": { + "zh_CN": "值改变时触发" + }, + "description": { + "zh_CN": "在下拉框值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "下拉框选中项的值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onUpdate:modelValue": { + "label": { + "zh_CN": "双向绑定的值改变时触发" + }, + "description": { + "zh_CN": "当前选中的值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "双向绑定的当前选中值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onBlur": { + "label": { + "zh_CN": "失去焦点时触发" + }, + "description": { + "zh_CN": "在 Input 失去焦点时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "event", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "原生 event" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onFocus": { + "label": { + "zh_CN": "获取焦点时触发" + }, + "description": { + "zh_CN": "在 Input 获取焦点时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "event", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "原生 event" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onClear": { + "label": { + "zh_CN": "点击清空按钮时触发" + }, + "description": { + "zh_CN": "点击清空按钮时触发" + }, + "type": "event", + "functionInfo": { + "params": [], + "returns": {} + }, + "defaultValue": "" + }, + "onRemoveTag": { + "label": { + "zh_CN": "多选模式下移除tag时触发" + }, + "description": { + "zh_CN": "多选模式下移除tag时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "被移除Tag对应数据项的值字段" + } + } + ], + "returns": {} + }, + "defaultValue": "" + } + } + } + }, + { + "name": { + "zh_CN": "按钮组" + }, + "component": "TinyButtonGroup", + "icon": "buttons", + "description": "以按钮组的方式出现,常用于多项类似操作", + "doc_url": "", + "screenshot": "http://localhost:9090/assets/images/e4f27d446aef8318e4b4989f1f816b1e_220x220.png", + "tags": "", + "keywords": "", + "dev_mode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "ButtonGroup", + "version": "0.1.16", + "destructuring": true + }, + "group": "component", + "category": "表单组件", + "priority": 2, + "snippets": [ + { + "name": { + "zh_CN": "互斥按钮组" + }, + "icon": "buttons", + "snippetName": "TinyButtonGroup", + "screenshot": "", + "schema": { + "componentName": "TinyButtonGroup", + "props": { + "data": [ + { + "text": "Button1", + "value": "1" + }, + { + "text": "Button2", + "value": "2" + }, + { + "text": "Button3", + "value": "3" + } + ], + "modelValue": "1", + "tiny_mode": "" + } + } + } + ], + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["disabled", "size"] + }, + "contextMenu": { + "actions": ["copy", "remove", "insert", "updateAttr", "bindEevent", "createBlock"], + "disable": [] + }, + "framework": "Vue" + }, + "createdBy": 169, + "created_at": "2022-05-19T01:53:17.000Z", + "updated_at": "2023-03-06T07:10:09.000Z", + "public": 1, + "framework": "Vue", + "isOfficial": true, + "isDefault": true, + "tiny_reserved": true, + "component_metadata": { + "events": [ + { + "eventName": "update:modelValue", + "label": "绑定值改变触发的事件", + "params": null, + "defaultValue": null, + "description": null, + "_RID": "row_1" + } + ], + "attrs": [ + { + "property": "modelValue", + "type": "string", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_1" + } + ], + "slots": [] + }, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "data", + "label": { + "text": { + "zh_CN": "按钮组数据" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "size", + "label": { + "text": { + "zh_CN": "组件大小" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "mini", + "value": "mini" + }, + { + "label": "small", + "value": "small" + }, + { + "label": "medium", + "value": "medium" + } + ] + } + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "plain", + "label": { + "text": { + "zh_CN": "是否是朴素按钮" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "disabled", + "label": { + "text": { + "zh_CN": "禁用" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "modelValue", + "label": { + "text": { + "zh_CN": "modelValue" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + } + ] + } + ], + "events": { + "onUpdate:modelValue": { + "label": { + "zh_CN": "绑定值改变触发的事件" + }, + "description": { + "zh_CN": null + }, + "type": "event", + "functionInfo": { + "params": [null], + "returns": {} + } + } + }, + "slots": [] + } + }, + { + "name": { + "zh_CN": "走马灯" + }, + "component": "TinyCarousel", + "icon": "carousel", + "description": "常用于一组图片或卡片轮播,当内容空间不足时,可以用走马灯的形式进行收纳,进行轮播展现。", + "doc_url": "", + "screenshot": "screenshoot", + "tags": "tiny-carousel", + "keywords": "", + "dev_mode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Carousel", + "version": "0.1.16", + "destructuring": true + }, + "group": "component", + "category": "容器组件", + "priority": 2, + "snippets": [ + { + "name": { + "zh_CN": "走马灯" + }, + "screenshot": "", + "snippetName": "tiny-carousel", + "icon": "carousel", + "schema": { + "componentName": "TinyCarousel", + "props": { + "height": "180px", + "tiny_mode": "" + }, + "children": [ + { + "componentName": "TinyCarouselItem", + "children": [ + { + "componentName": "div", + "props": { + "style": "margin:10px 0 0 30px" + } + } + ] + }, + { + "componentName": "TinyCarouselItem", + "children": [ + { + "componentName": "div", + "props": { + "style": "margin:10px 0 0 30px" + } + } + ] + } + ] + } + } + ], + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": true, + "isModal": false, + "nestingRule": { + "childWhitelist": "TinyCarouselItem", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["arrow"] + }, + "contextMenu": { + "actions": ["copy", "remove", "insert", "updateAttr", "bindEevent", "createBlock"], + "disable": [] + }, + "slots": ["default"], + "framework": "Vue" + }, + "createdBy": 169, + "created_at": "2022-06-23T12:01:18.000Z", + "updated_at": "2023-03-06T07:10:37.000Z", + "public": 1, + "framework": "Vue", + "isOfficial": true, + "isDefault": true, + "tiny_reserved": true, + "component_metadata": { + "events": [], + "attrs": [], + "slots": [] + }, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 12, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "arrow", + "label": { + "text": { + "zh_CN": "切换箭头的显示时机" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "总是显示", + "value": "always" + }, + { + "label": "鼠标悬停时显示", + "value": "hover" + }, + { + "label": "从不显示", + "value": "never" + } + ] + } + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "autoplay", + "label": { + "text": { + "zh_CN": "是否自动切换" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "height", + "label": { + "text": { + "zh_CN": "走马灯的高度" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "indicator-position", + "label": { + "text": { + "zh_CN": "指示器的位置" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "outside", + "value": "outside" + }, + { + "label": "none", + "value": "none" + } + ] + } + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "initial-index", + "label": { + "text": { + "zh_CN": "初始状态激活的幻灯片的索引,从 0 开始 " + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumeric", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "interval", + "label": { + "text": { + "zh_CN": "自动切换的时间间隔,单位为毫秒" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumeric", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "loop", + "label": { + "text": { + "zh_CN": "是否循环显示" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "show-title", + "label": { + "text": { + "zh_CN": "是否显示标题" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "trigger", + "label": { + "text": { + "zh_CN": "指示器的触发方式,默认为 hover" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "点击", + "value": "click" + }, + { + "label": "悬停", + "value": "hover" + } + ] + } + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "type", + "label": { + "text": { + "zh_CN": "走马灯的类型" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "水平", + "value": "horizontal" + }, + { + "label": "垂直", + "value": "vertical" + }, + { + "label": "卡片", + "value": "card" + } + ] + } + }, + "description": { + "zh_CN": "" + } + } + ] + } + ], + "events": {} + } + }, + { + "name": { + "zh_CN": "弹出编辑" + }, + "component": "TinyPopeditor", + "icon": "popeditor", + "description": "该组件只能在弹出的面板中选择数据,不能手动输入数据;弹出面板中显示为 Tree 组件或者 Grid 组件", + "doc_url": "", + "screenshot": "null", + "tags": "", + "keywords": "", + "dev_mode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Popeditor", + "version": "0.1.16", + "destructuring": true + }, + "group": "component", + "category": "表单组件", + "priority": 2, + "snippets": [ + { + "name": { + "zh_CN": "弹出编辑" + }, + "icon": "popeditor", + "screenshot": "", + "snippetName": "TinyPopeditor", + "schema": { + "componentName": "TinyPopeditor", + "props": { + "modelValue": "", + "placeholder": "请选择", + "gridOp": { + "columns": [ + { + "field": "id", + "title": "ID", + "width": 40 + }, + { + "field": "name", + "title": "名称", + "showOverflow": "tooltip" + }, + { + "field": "province", + "title": "省份", + "width": 80 + }, + { + "field": "city", + "title": "城市", + "width": 80 + } + ], + "data": [ + { + "id": "1", + "name": "GFD科技有限公司GFD科技有限公司GFD科技有限公司GFD科技有限公司GFD科技有限公司GFD科技有限公司GFD科技有限公司", + "city": "福州", + "province": "福建" + }, + { + "id": "2", + "name": "WWW科技有限公司", + "city": "深圳", + "province": "广东" + }, + { + "id": "3", + "name": "RFV有限责任公司", + "city": "中山", + "province": "广东" + }, + { + "id": "4", + "name": "TGB科技有限公司", + "city": "龙岩", + "province": "福建" + }, + { + "id": "5", + "name": "YHN科技有限公司", + "city": "韶关", + "province": "广东" + }, + { + "id": "6", + "name": "WSX科技有限公司", + "city": "黄冈", + "province": "武汉" + } + ] + }, + "tiny_mode": "" + } + } + } + ], + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["placeholder", "show-clear-btn"] + }, + "contextMenu": { + "actions": ["copy", "remove", "insert", "updateAttr", "bindEevent", "createBlock"], + "disable": [] + }, + "slots": [], + "framework": "Vue" + }, + "createdBy": 169, + "created_at": "2022-05-19T02:34:37.000Z", + "updated_at": "2023-03-06T07:11:13.000Z", + "public": 1, + "framework": "Vue", + "isOfficial": true, + "isDefault": true, + "tiny_reserved": true, + "component_metadata": null, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "modelValue", + "label": { + "text": { + "zh_CN": "绑定值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "双向绑定值" + }, + "labelPosition": "left" + }, + { + "property": "placeholder", + "label": { + "text": { + "zh_CN": "占位文本" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "输入框占位文本" + }, + "labelPosition": "left" + }, + { + "property": "show-clear-btn", + "label": { + "text": { + "zh_CN": "清除按钮" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否显示清除按钮" + }, + "labelPosition": "left" + }, + { + "property": "disabled", + "label": { + "text": { + "zh_CN": "是否禁用" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + } + ] + }, + { + "name": "1", + "label": { + "zh_CN": "其他" + }, + "content": [ + { + "property": "width", + "label": { + "text": { + "zh_CN": "宽度" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumeric", + "props": {} + }, + "description": { + "zh_CN": "设置弹出面板的宽度(单位像素)" + }, + "labelPosition": "left" + }, + { + "property": "conditions", + "label": { + "text": { + "zh_CN": "过滤条件" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "当弹出面板配置的是表格时,设置弹出面板中的过滤条件" + }, + "labelPosition": "left" + }, + { + "property": "grid-op", + "label": { + "text": { + "zh_CN": "表格配置" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "设置弹出面板中表格组件的配置信息" + }, + "labelPosition": "left" + }, + { + "property": "pager-op", + "label": { + "text": { + "zh_CN": "分页配置" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "设置弹出编辑框中分页配置" + }, + "labelPosition": "left" + }, + { + "property": "multi", + "label": { + "text": { + "zh_CN": "多选" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "设置弹出面板中的数据是否可多选" + }, + "labelPosition": "left" + }, + { + "property": "show-pager", + "label": { + "text": { + "zh_CN": "启用分页" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "当 popseletor 为 grid 时才能生效,配置为 true 后还需配置 pagerOp 属性" + } + } + ], + "description": { + "zh_CN": "" + } + } + ], + "events": { + "onChange": { + "label": { + "zh_CN": "选中值改变时触发" + }, + "description": { + "zh_CN": "在 Input 值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "当前选中项的值" + } + }, + { + "name": "value", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "当前选中对象" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onUpdate:modelValue": { + "label": { + "zh_CN": "双向绑定的值改变时触发" + }, + "description": { + "zh_CN": "当前选中的值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "双向绑定的当前选中值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onClose": { + "label": { + "zh_CN": "弹框关闭时触发的事件" + }, + "description": { + "zh_CN": "弹框关闭时触发的事件" + }, + "type": "event", + "functionInfo": { + "params": [], + "returns": {} + }, + "defaultValue": "" + }, + "onPageChange": { + "label": { + "zh_CN": "分页切换事件" + }, + "description": { + "zh_CN": "表格模式下分页切换事件" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "String", + "defaultValue": "", + "description": { + "zh_CN": "当前页码数" + } + } + ], + "returns": {} + }, + "defaultValue": "" + } + } + } + }, + { + "name": { + "zh_CN": "日期选择器" + }, + "component": "TinyDatePicker", + "icon": "datepicker", + "description": "用于设置/选择日期,包括年月/年月日/年月日时分/年月日时分秒日期格式。", + "doc_url": "", + "screenshot": "screenshoot", + "tags": "", + "keywords": "", + "dev_mode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "DatePicker", + "version": "0.1.16", + "destructuring": true + }, + "group": "component", + "category": "表单组件", + "priority": 2, + "snippets": [ + { + "name": { + "zh_CN": "日期选择器" + }, + "screenshot": "", + "snippetName": "tiny-date-picker", + "icon": "datepick", + "schema": { + "componentName": "TinyDatePicker", + "props": { + "placeholder": "请选择日期", + "modelValue": "", + "tiny_mode": "" + } + } + } + ], + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": [""] + }, + "contextMenu": { + "actions": ["copy", "remove", "insert", "updateAttr", "bindEevent", "createBlock"], + "disable": [] + }, + "invalidity": [], + "clickCapture": true, + "framework": "Vue" + }, + "createdBy": 169, + "created_at": "2022-06-28T01:54:39.000Z", + "updated_at": "2023-03-06T07:11:42.000Z", + "public": 1, + "framework": "Vue", + "isOfficial": true, + "isDefault": true, + "tiny_reserved": true, + "component_metadata": null, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "align", + "label": { + "text": { + "zh_CN": "对齐方式" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "左对齐", + "value": "left" + }, + { + "label": "居中对齐", + "value": "center" + }, + { + "label": "右对齐", + "value": "right" + } + ] + } + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "clear-icon", + "label": { + "text": { + "zh_CN": "自定义清空图标的类名" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "clearable", + "label": { + "text": { + "zh_CN": "是否显示清除按钮" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "default-time", + "label": { + "text": { + "zh_CN": "范围选择时选中日期所使用的当日内具体时刻,可选值为 支持的日期格式" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "default-value", + "label": { + "text": { + "zh_CN": "可选,选择器打开时默认显示的时间,可选值为 可被new Date()解析" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "disabled", + "label": { + "text": { + "zh_CN": "禁用" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "editable", + "label": { + "text": { + "zh_CN": "文本框可输入" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "end-placeholder", + "label": { + "text": { + "zh_CN": "范围选择时结束日期的占位内容" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "format", + "label": { + "text": { + "zh_CN": "显示在输入框中的格式" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "isutc8", + "label": { + "text": { + "zh_CN": "默认值为 false ,设置为 true 时切换系统默认时区,时间依然显示为东八区时间。适用场景为海外地区显示东八区时间" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "name", + "label": { + "text": { + "zh_CN": "原生属性" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "picker-options", + "label": { + "text": { + "zh_CN": "当前时间日期选择器特有的选项参考下表" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "placeholder", + "label": { + "text": { + "zh_CN": "非范围选择时的占位内容" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "popper-append-to-body", + "label": { + "text": { + "zh_CN": "是否将弹出框插入至 body 元素。在弹出框的定位出现问题时,可将该属性设置为 false (可参考 select 组件)" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "popper-class", + "label": { + "text": { + "zh_CN": "为 popper 添加类名(可参考 popover 组件)" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "range-separator", + "label": { + "text": { + "zh_CN": "选择范围时的分隔符" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "readonly", + "label": { + "text": { + "zh_CN": "设置日历组件是否只读" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "size", + "label": { + "text": { + "zh_CN": "输入框尺寸" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "中等尺寸", + "value": "medium" + }, + { + "label": "较小尺寸", + "value": "small" + }, + { + "label": "迷你尺寸", + "value": "mini" + } + ] + } + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "start-placeholder", + "label": { + "text": { + "zh_CN": "范围选择时开始日期的占位内容" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "suffix-icon ", + "label": { + "text": { + "zh_CN": "自定义后置图标的类名,prefix-icon 自 AUI 3.8.0 版本将替换为 suffix-icon " + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "time-arrow-control", + "label": { + "text": { + "zh_CN": "通过箭头按钮控制时间选择,当 type 为 datetime、datetimerange 时使用,默认为 通过鼠标滚轮滚动选择时间" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "type", + "label": { + "text": { + "zh_CN": "显示类型" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "年", + "value": "year" + }, + { + "label": "月", + "value": "month" + }, + { + "label": "多个日期", + "value": "dates" + }, + { + "label": "周", + "value": "week" + }, + { + "label": "日期范围", + "value": "daterange" + }, + { + "label": "日期", + "value": "date" + }, + { + "label": "日期时间", + "value": "datetime" + }, + { + "label": "日期时间范围", + "value": "datetimerange" + }, + { + "label": "月范围", + "value": "monthrange" + } + ] + } + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "unlink-panels", + "label": { + "text": { + "zh_CN": "在范围选择器里取消两个日期面板之间的联动" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "validate-event", + "label": { + "text": { + "zh_CN": "设置日期选择器在输入时是否会触发表单校验" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "value", + "label": { + "text": { + "zh_CN": "绑定值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "value-format", + "label": { + "text": { + "zh_CN": "指定绑定值的格式。不指定则绑定值为 Date 对象" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + } + ] + } + ], + "events": {} + } + }, + { + "name": { + "zh_CN": "下拉菜单" + }, + "component": "TinyDropdown", + "icon": "dropdown", + "description": "Dropdown 下拉菜单", + "doc_url": "", + "screenshot": "http://localhost:9090/assets/images/logo.png", + "tags": "", + "keywords": "", + "dev_mode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Dropdown", + "version": "0.1.16", + "destructuring": true + }, + "group": "component", + "category": "导航组件", + "priority": 2, + "snippets": [ + { + "name": { + "zh_CN": "下拉菜单" + }, + "icon": "dropdown", + "screenshot": "http://localhost:9090/assets/images/logo.png", + "snippetName": "TinyDropdown", + "schema": { + "componentName": "TinyDropdown", + "props": { + "trigger": "hover", + "title": "下拉菜单", + "menuOptions": { + "options": [ + { + "label": "老友粉", + "disabled": true + }, + { + "label": "狮子头", + "divided": true + }, + { + "label": "黄金糕", + "divided": true + } + ] + }, + "tiny_mode": "" + } + } + } + ], + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "isPopper": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["size", "trigger"] + }, + "contextMenu": { + "actions": ["copy", "remove", "insert", "updateAttr", "bindEevent", "createBlock"], + "disable": [] + }, + "invalidity": [""], + "clickCapture": true, + "framework": "Vue" + }, + "createdBy": 169, + "created_at": "2022-11-09T03:20:31.000Z", + "updated_at": "2023-03-08T06:20:17.000Z", + "public": 1, + "framework": "Vue", + "isOfficial": true, + "isDefault": false, + "tiny_reserved": true, + "component_metadata": { + "events": [ + { + "eventName": "visible-change", + "label": "下拉框出现/隐藏时触发", + "params": null, + "defaultValue": null, + "description": "下拉框出现/隐藏时触发", + "_RID": "row_8" + }, + { + "eventName": "button-click", + "label": "点击左侧按钮的回调", + "params": null, + "defaultValue": null, + "description": "点击左侧按钮的回调", + "_RID": "row_7" + }, + { + "eventName": "item-click", + "label": "点击菜单项触发的事件回调", + "params": null, + "defaultValue": null, + "description": "点击菜单项触发的事件回调", + "_RID": "row_6" + } + ], + "attrs": [ + { + "property": "menuOptions", + "type": "object", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_2" + }, + { + "property": "title", + "type": "string", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_1" + }, + { + "property": "size", + "type": "string", + "defaultValue": null, + "enumerateValue": null, + "title": "菜单尺寸", + "_RID": "row_4" + }, + { + "property": "trigger", + "type": "string", + "defaultValue": null, + "enumerateValue": null, + "title": "触发下拉的行为", + "_RID": "row_3" + }, + { + "property": "trigger", + "type": "string", + "defaultValue": null, + "enumerateValue": null, + "title": "触发下拉的行为", + "_RID": "row_3" + }, + { + "property": "trigger", + "type": "string", + "defaultValue": null, + "enumerateValue": null, + "title": "触发下拉的行为", + "_RID": "row_3" + } + ], + "slots": { + "default": { + "label": { + "zh_CN": "default" + }, + "description": { + "zh_CN": null + } + } + } + }, + "schema": { + "properties": [ + { + "name": "0", + "label": { + "zh_CN": "基础信息" + }, + "content": [ + { + "property": "title", + "label": { + "text": { + "zh_CN": "触发源名称" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "menuOptions", + "label": { + "text": { + "zh_CN": "菜单子项" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "trigger", + "label": { + "text": { + "zh_CN": "触发下拉的行为" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 6, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "hover", + "value": "hover" + }, + { + "label": "click", + "value": "click" + } + ] + } + }, + "description": { + "zh_CN": "" + }, + "type": "string", + "properties": [ + { + "label": { + "zh_CN": "默认分组" + }, + "content": [ + { + "property": "title", + "type": "string", + "defaultValue": "", + "label": { + "text": { + "zh_CN": "customProperty" + } + }, + "widget": { + "component": "MetaInput", + "props": {} + } + }, + { + "property": "id", + "type": "string", + "defaultValue": "", + "label": { + "text": { + "zh_CN": "customProperty" + } + }, + "widget": { + "component": "MetaInput", + "props": {} + } + }, + { + "property": "field", + "type": "array", + "defaultValue": "", + "label": { + "text": { + "zh_CN": "customProperty" + } + }, + "widget": { + "component": "MetaSelect", + "props": {} + } + } + ] + } + ], + "labelPosition": "left" + }, + { + "property": "placement", + "label": { + "text": { + "zh_CN": "菜单弹出位置" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "top", + "value": "top" + }, + { + "label": "top-start", + "value": "top-start" + }, + { + "label": "top-end", + "value": "top-end" + }, + { + "label": "bottom", + "value": "bottom" + }, + { + "label": "bottom-start", + "value": "bottom-start" + }, + { + "label": "bottom-end", + "value": "bottom-end" + } + ] + } + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "hide-timeout", + "label": { + "text": { + "zh_CN": "收起下拉菜单的延时" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumeric", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "show-timeout", + "label": { + "text": { + "zh_CN": "展开下拉菜单的延时" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumeric", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "hide-on-click", + "label": { + "text": { + "zh_CN": "点击菜单项后隐藏菜单" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + } + ], + "description": { + "zh_CN": "" + } + } + ], + "events": { + "onVisible-change": { + "label": { + "zh_CN": "下拉框出现/隐藏时触发" + }, + "description": { + "zh_CN": "下拉框出现/隐藏时触发" + }, + "type": "event", + "functionInfo": { + "params": [null], + "returns": {} + } + }, + "onButton-click": { + "label": { + "zh_CN": "点击左侧按钮的回调" + }, + "description": { + "zh_CN": "点击左侧按钮的回调" + }, + "type": "event", + "functionInfo": { + "params": [null], + "returns": {} + } + }, + "onItem-click": { + "label": { + "zh_CN": "点击菜单项触发的事件回调" + }, + "description": { + "zh_CN": "点击菜单项触发的事件回调" + }, + "type": "event", + "functionInfo": { + "params": [null], + "returns": {} + } + } + } + } + }, + { + "name": { + "zh_CN": "柱状图" + }, + "component": "TinyChartHistogram", + "icon": "histogram ", + "description": "基于 eCharts 封装的柱状图", + "doc_url": "", + "screenshot": "http://localhost:9090/assets/images/logo.png", + "tags": "", + "keywords": "", + "dev_mode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "ChartHistogram", + "version": "0.1.16", + "destructuring": true + }, + "group": "component", + "category": "图表组件", + "priority": 2, + "snippets": [ + { + "name": { + "zh_CN": "柱状图" + }, + "icon": "histogram ", + "screenshot": "http://localhost:9090/assets/images/logo.png", + "snippetName": "TinyChartHistogram", + "schema": { + "componentName": "TinyChartHistogram", + "props": { + "data": { + "columns": ["日期", "访问用户", "下单用户", "下单率"], + "rows": [ + { + "日期": "1/1", + "访问用户": 1393, + "下单用户": 1093, + "下单率": 0.32 + }, + { + "日期": "1/2", + "访问用户": 3530, + "下单用户": 3230, + "下单率": 0.26 + }, + { + "日期": "1/3", + "访问用户": 2923, + "下单用户": 2623, + "下单率": 0.76 + }, + { + "日期": "1/4", + "访问用户": 1723, + "下单用户": 1423, + "下单率": 0.49 + }, + { + "日期": "1/5", + "访问用户": 3792, + "下单用户": 3492, + "下单率": 0.323 + }, + { + "日期": "1/6", + "访问用户": 4593, + "下单用户": 4293, + "下单率": 0.78 + } + ] + } + } + } + } + ], + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "isPopper": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": [""] + }, + "contextMenu": { + "actions": ["copy", "remove", "insert", "updateAttr", "bindEevent", "createBlock"], + "disable": [] + }, + "invalidity": [""], + "clickCapture": true, + "framework": "Vue" + }, + "createdBy": 169, + "created_at": "2022-11-11T03:25:54.000Z", + "updated_at": "2022-11-12T08:18:30.000Z", + "public": 1, + "framework": "Vue", + "isOfficial": true, + "isDefault": false, + "tiny_reserved": true, + "component_metadata": { + "events": [], + "attrs": [ + { + "property": "data-empty", + "type": "boolean", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_6" + }, + { + "property": "loading", + "type": "boolean", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_5" + }, + { + "property": "events", + "type": "object", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_4" + }, + { + "property": "extend", + "type": "object", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_3" + }, + { + "property": "height", + "type": "string", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_2" + }, + { + "property": "width", + "type": "string", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_1" + }, + { + "property": "settings", + "type": "object", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_2" + }, + { + "property": "data", + "type": "object", + "defaultValue": null, + "enumerateValue": null, + "title": null, + "_RID": "row_1" + } + ], + "slots": [] + }, + "schema": { + "properties": [ + { + "name": "0", + "label": { + "zh_CN": "基础信息" + }, + "content": [ + { + "property": "data", + "label": { + "text": { + "zh_CN": "图表数据" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "settings", + "label": { + "text": { + "zh_CN": "图表配置" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "extend", + "label": { + "text": { + "zh_CN": "图表扩展配置,参考eChart" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "height", + "label": { + "text": { + "zh_CN": "图表容器的高度" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "width", + "label": { + "text": { + "zh_CN": "图表容器的宽度" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "events", + "label": { + "text": { + "zh_CN": "事件绑定" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "loading", + "label": { + "text": { + "zh_CN": "显示loading" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "data-empty", + "label": { + "text": { + "zh_CN": "暂无数据" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + } + ], + "description": { + "zh_CN": "" + } + } + ], + "events": [] + } + } + ] + } + } + }, + "createdBy": null, + "updatedBy": null, + "assets_url": { + "material": ["http://localhost:9090/assets/json/bundle.json"], + "scripts": [ + "http://localhost:9090/assets/js/1505web-components.es.js", + "http://localhost:9090/assets/js/1505web-components.umd.js" + ], + "styles": [] + }, + "tenant": null, + "created_by": null, + "updated_by": null, + "created_at": "2023-03-09T11:58:08.000Z", + "updated_at": "2023-03-09T11:58:08.000Z", + "description": "2023.3.9", + "components": [ + { + "id": 1, + "version": "2.4.2", + "name": { + "zh_CN": "输入框" + }, + "component": "ElInput", + "icon": "input", + "description": "通过鼠标或键盘输入字符", + "doc_url": "", + "screenshot": "", + "tags": "", + "keywords": "", + "dev_mode": "proCode", + "npm": { + "package": "element-plus", + "version": "2.4.2", + "script": "https://unpkg.com/element-plus@2.4.2/dist/index.full.mjs", + "css": "https://unpkg.com/element-plus@2.4.2/dist/index.css", + "dependencies": null, + "exportName": "ElInput" + }, + "group": "表单组件", + "category": "element-plus", + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "isPopper": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["type", "size"] + }, + "contextMenu": { + "actions": ["copy", "remove", "insert", "updateAttr", "bindEevent", "createBlock"], + "disable": [] + }, + "invalidity": [""], + "clickCapture": true, + "framework": "Vue" + }, + "schema": { + "properties": [ + { + "name": "0", + "label": { + "zh_CN": "基础属性" + }, + "content": [ + { + "property": "modelValue", + "label": { + "text": { + "zh_CN": "modelValue" + } + }, + "description": { + "zh_CN": "绑定值" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "type": "string", + "widget": { + "component": "MetaInput", + "props": {} + } + }, + { + "property": "size", + "label": { + "text": { + "zh_CN": "size" + } + }, + "description": { + "zh_CN": "尺寸" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "type": "string", + "defaultValue": "default", + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "large", + "value": "large" + }, + { + "label": "default", + "value": "default" + }, + { + "label": "small", + "value": "small" + } + ] + } + } + }, + { + "property": "type", + "label": { + "text": { + "zh_CN": "type" + } + }, + "description": { + "zh_CN": "类型" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "type": "string", + "widget": { + "component": "MetaInput", + "props": {} + } + }, + { + "property": "placeholder", + "label": { + "text": { + "zh_CN": "placeholder" + } + }, + "description": { + "zh_CN": "输入框占位文本" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "type": "string", + "widget": { + "component": "MetaBindI18n", + "props": {} + }, + "device": [] + }, + { + "property": "maxlength", + "label": { + "text": { + "zh_CN": "maxlength" + } + }, + "description": { + "zh_CN": "最大输入长度" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "type": "number", + "widget": { + "component": "MetaNumberic", + "props": {} + }, + "device": [] + }, + { + "property": "disabled", + "label": { + "text": { + "zh_CN": "disabled" + } + }, + "description": { + "zh_CN": "是否禁用" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "defaultValue": false, + "type": "boolean", + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "device": [] + } + ], + "description": { + "zh_CN": "" + } + } + ], + "events": { + "onUpdate:modelValue": { + "label": { + "zh_CN": "双向绑定值改变时触发" + }, + "description": { + "zh_CN": "双向绑定值改变时触发" + } + }, + "onBlur": { + "label": { + "zh_CN": "输入框失去焦点时触发" + }, + "description": { + "zh_CN": "输入框失去焦点时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "event", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "原生 event" + } + } + ], + "returns": {} + }, + "defaultValue": "" + } + }, + "slots": { + "prefix": { + "label": { + "zh_CN": "头部内容" + }, + "description": { + "zh_CN": "输入框头部内容,只对非 type='textarea' 有效" + } + }, + "suffix": { + "label": { + "zh_CN": "尾部内容" + }, + "description": { + "zh_CN": "输入框尾部内容,只对非 type='textarea' 有效" + } + }, + "prepend": { + "label": { + "zh_CN": "前置内容" + }, + "description": { + "zh_CN": "输入框前置内容,只对非 type='textarea' 有效" + } + }, + "append": { + "label": { + "zh_CN": "后置内容" + }, + "description": { + "zh_CN": "输入框后置内容,只对非 type='textarea' 有效" + } + } + } + } + }, + { + "id": 1, + "version": "2.4.2", + "name": { + "zh_CN": "按钮" + }, + "component": "ElButton", + "icon": "button", + "description": "常用的操作按钮", + "doc_url": "", + "screenshot": "", + "tags": "", + "keywords": "", + "dev_mode": "proCode", + "npm": { + "package": "element-plus", + "version": "2.4.2", + "script": "https://unpkg.com/element-plus@2.4.2/dist/index.full.mjs", + "css": "https://unpkg.com/element-plus@2.4.2/dist/index.css", + "dependencies": null, + "exportName": "ElButton" + }, + "group": "基础组件", + "category": "element-plus", + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "isPopper": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["type", "size"] + }, + "contextMenu": { + "actions": ["copy", "remove", "insert", "updateAttr", "bindEevent", "createBlock"], + "disable": [] + }, + "invalidity": [""], + "clickCapture": true, + "framework": "Vue" + }, + "schema": { + "properties": [ + { + "name": "0", + "label": { + "zh_CN": "基础属性" + }, + "content": [ + { + "property": "size", + "label": { + "text": { + "zh_CN": "size" + } + }, + "description": { + "zh_CN": "尺寸" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "type": "string", + "defaultValue": "default", + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "large", + "value": "large" + }, + { + "label": "default", + "value": "default" + }, + { + "label": "small", + "value": "small" + } + ] + } + } + }, + { + "property": "type", + "label": { + "text": { + "zh_CN": "type" + } + }, + "description": { + "zh_CN": "类型" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "type": "string", + "widget": { + "component": "MetaInput", + "props": {} + } + }, + { + "property": "plain", + "label": { + "text": { + "zh_CN": "plain" + } + }, + "description": { + "zh_CN": "是否为朴素按钮" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "type": "string", + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "device": [] + }, + { + "property": "text", + "label": { + "text": { + "zh_CN": "text" + } + }, + "description": { + "zh_CN": "是否为文字按钮" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "type": "string", + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "device": [] + }, + { + "property": "bg", + "label": { + "text": { + "zh_CN": "bg" + } + }, + "description": { + "zh_CN": "是否显示文字按钮背景颜色" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "type": "string", + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "device": [] + }, + { + "property": "link", + "label": { + "text": { + "zh_CN": "link" + } + }, + "description": { + "zh_CN": "是否为链接按钮" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "type": "string", + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "device": [] + }, + { + "property": "round", + "label": { + "text": { + "zh_CN": "round" + } + }, + "description": { + "zh_CN": "是否为圆角按钮" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "type": "string", + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "device": [] + }, + { + "property": "circle", + "label": { + "text": { + "zh_CN": "circle" + } + }, + "description": { + "zh_CN": "是否为圆形按钮" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "type": "string", + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "device": [] + }, + { + "property": "loading", + "label": { + "text": { + "zh_CN": "loading" + } + }, + "description": { + "zh_CN": "是否为加载中状态" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "type": "string", + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "device": [] + }, + { + "property": "disabled", + "label": { + "text": { + "zh_CN": "disabled" + } + }, + "description": { + "zh_CN": "是否禁用" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "defaultValue": false, + "type": "boolean", + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "device": [] + } + ], + "description": { + "zh_CN": "" + } + } + ], + "events": {}, + "slots": { + "default": { + "label": { + "zh_CN": "default" + }, + "description": { + "zh_CN": "自定义默认内容" + } + }, + "loading": { + "label": { + "zh_CN": "loading" + }, + "description": { + "zh_CN": "自定义加载中组件" + } + } + } + } + }, + { + "id": 1, + "version": "2.4.2", + "name": { + "zh_CN": "表单" + }, + "component": "ElForm", + "icon": "form", + "description": "表单包含 输入框, 单选框, 下拉选择, 多选框 等用户输入的组件。 使用表单,您可以收集、验证和提交数据。", + "doc_url": "", + "screenshot": "", + "tags": "", + "keywords": "", + "dev_mode": "proCode", + "npm": { + "package": "element-plus", + "version": "2.4.2", + "script": "https://unpkg.com/element-plus@2.4.2/dist/index.full.mjs", + "css": "https://unpkg.com/element-plus@2.4.2/dist/index.css", + "dependencies": null, + "exportName": "ElForm" + }, + "group": "表单组件", + "category": "element-plus", + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "isPopper": false, + "nestingRule": { + "childWhitelist": ["ElFormItem"], + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["inline", "label-width"] + }, + "contextMenu": { + "actions": ["copy", "remove", "insert", "updateAttr", "bindEevent", "createBlock"], + "disable": [] + }, + "invalidity": [""], + "clickCapture": true, + "framework": "Vue" + }, + "schema": { + "properties": [ + { + "name": "0", + "label": { + "zh_CN": "基础属性" + }, + "content": [ + { + "property": "model", + "label": { + "text": { + "zh_CN": "model" + } + }, + "description": { + "zh_CN": "表单数据对象" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "type": "object", + "widget": { + "component": "MetaCodeEditor", + "props": { + "language": "json" + } + } + }, + { + "property": "rules", + "label": { + "text": { + "zh_CN": "rules" + } + }, + "description": { + "zh_CN": "表单验证规则" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "type": "object", + "widget": { + "component": "MetaCodeEditor", + "props": { + "language": "json" + } + } + }, + { + "property": "inline", + "label": { + "text": { + "zh_CN": "inline" + } + }, + "description": { + "zh_CN": "行内表单模式" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "type": "boolean", + "widget": { + "component": "MetaSwitch", + "props": {} + } + }, + { + "property": "label-position", + "label": { + "text": { + "zh_CN": "label-position" + } + }, + "description": { + "zh_CN": "表单域标签的位置, 当设置为 left 或 right 时,则也需要设置 label-width 属性" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "type": "string", + "defaultValue": "right", + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "left", + "value": "left" + }, + { + "label": "right", + "value": "right" + }, + { + "label": "top", + "value": "top" + } + ] + } + } + }, + { + "property": "label-width", + "label": { + "text": { + "zh_CN": "label-width" + } + }, + "description": { + "zh_CN": "标签的长度,例如 '50px'。 作为 Form 直接子元素的 form-item 会继承该值。 可以使用 auto。" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "type": "string", + "widget": { + "component": "MetaInput", + "props": {} + }, + "device": [] + }, + { + "property": "label-suffix", + "label": { + "text": { + "zh_CN": "label-suffix" + } + }, + "description": { + "zh_CN": "表单域标签的后缀" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "type": "string", + "widget": { + "component": "MetaInput", + "props": {} + }, + "device": [] + }, + { + "property": "hide-required-asterisk", + "label": { + "text": { + "zh_CN": "hide-required-asterisk" + } + }, + "description": { + "zh_CN": "是否隐藏必填字段标签旁边的红色星号" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "type": "boolean", + "widget": { + "component": "MetaSwitch", + "props": {} + } + }, + { + "property": "require-asterisk-position", + "label": { + "text": { + "zh_CN": "星号的位置" + } + }, + "description": { + "zh_CN": "星号的位置" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "type": "string", + "defaultValue": "left", + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "left", + "value": "left" + }, + { + "label": "right", + "value": "right" + } + ] + } + } + }, + { + "property": "show-message", + "label": { + "text": { + "zh_CN": "show-message" + } + }, + "description": { + "zh_CN": "是否显示校验错误信息" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "defaultValue": true, + "type": "boolean", + "widget": { + "component": "MetaSwitch", + "props": {} + } + }, + { + "property": "inline-message", + "label": { + "text": { + "zh_CN": "inline-message" + } + }, + "description": { + "zh_CN": "是否以行内形式展示校验信息" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "defaultValue": false, + "type": "boolean", + "widget": { + "component": "MetaSwitch", + "props": {} + } + }, + { + "property": "status-icon", + "label": { + "text": { + "zh_CN": "status-icon" + } + }, + "description": { + "zh_CN": "是否在输入框中显示校验结果反馈图标" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "defaultValue": false, + "type": "boolean", + "widget": { + "component": "MetaSwitch", + "props": {} + } + }, + { + "property": "validate-on-rule-change", + "label": { + "text": { + "zh_CN": "validate-on-rule-change" + } + }, + "description": { + "zh_CN": "是否在 rules 属性改变后立即触发一次验证" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "defaultValue": true, + "type": "boolean", + "widget": { + "component": "MetaSwitch", + "props": {} + } + }, + { + "property": "size", + "label": { + "text": { + "zh_CN": "size" + } + }, + "description": { + "zh_CN": "用于控制该表单内组件的尺寸" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "type": "string", + "defaultValue": "default", + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "large", + "value": "large" + }, + { + "label": "default", + "value": "default" + }, + { + "label": "small", + "value": "small" + } + ] + } + } + }, + { + "property": "disabled", + "label": { + "text": { + "zh_CN": "disabled" + } + }, + "description": { + "zh_CN": "是否禁用该表单内的所有组件。 如果设置为 true, 它将覆盖内部组件的 disabled 属性" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "defaultValue": false, + "type": "boolean", + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "device": [] + }, + { + "property": "scroll-to-error", + "label": { + "text": { + "zh_CN": "scroll-to-error" + } + }, + "description": { + "zh_CN": "当校验失败时,滚动到第一个错误表单项" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "defaultValue": false, + "type": "boolean", + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "device": [] + } + ], + "description": { + "zh_CN": "" + } + } + ], + "events": { + "onValidate": { + "label": { + "zh_CN": "任一表单项被校验后触发" + }, + "description": { + "zh_CN": "任一表单项被校验后触发" + }, + "type": "event", + "functionInfo": { + "params": [], + "returns": {} + }, + "defaultValue": "" + } + }, + "slots": {} + } + }, + { + "id": 1, + "version": "2.4.2", + "name": { + "zh_CN": "表单子项" + }, + "component": "ElFormItem", + "icon": "formItem", + "description": "表单包含 输入框, 单选框, 下拉选择, 多选框 等用户输入的组件。 使用表单,您可以收集、验证和提交数据。", + "doc_url": "", + "screenshot": "", + "tags": "", + "keywords": "", + "dev_mode": "proCode", + "npm": { + "package": "element-plus", + "version": "2.4.2", + "script": "https://unpkg.com/element-plus@2.4.2/dist/index.full.mjs", + "css": "https://unpkg.com/element-plus@2.4.2/dist/index.css", + "dependencies": null, + "exportName": "ElFormItem" + }, + "group": "表单组件", + "category": "element-plus", + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "isPopper": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["inline", "label-width"] + }, + "contextMenu": { + "actions": ["copy", "remove", "insert", "updateAttr", "bindEevent", "createBlock"], + "disable": [] + }, + "invalidity": [""], + "clickCapture": true, + "framework": "Vue" + }, + "schema": { + "properties": [ + { + "name": "0", + "label": { + "zh_CN": "基础属性" + }, + "content": [ + { + "property": "prop", + "label": { + "text": { + "zh_CN": "prop" + } + }, + "description": { + "zh_CN": "model 的键名。 它可以是一个属性的值(如 a.b.0 或 [a', 'b', '0'])。 在定义了 validate、resetFields 的方法时,该属性是必填的" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "type": "string", + "widget": { + "component": "MetaInput", + "props": {} + } + }, + { + "property": "label", + "label": { + "text": { + "zh_CN": "label" + } + }, + "description": { + "zh_CN": "标签文本" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "type": "string", + "widget": { + "component": "MetaInput", + "props": {} + } + }, + { + "property": "label-width", + "label": { + "text": { + "zh_CN": "label-width" + } + }, + "description": { + "zh_CN": "标签宽度,例如 '50px'。 可以使用 auto" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "type": "string", + "widget": { + "component": "MetaInput", + "props": {} + } + }, + { + "property": "required", + "label": { + "text": { + "zh_CN": "required" + } + }, + "description": { + "zh_CN": "是否为必填项,如不设置,则会根据校验规则确认" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "type": "boolean", + "widget": { + "component": "MetaSwitch", + "props": {} + } + }, + { + "property": "rules", + "label": { + "text": { + "zh_CN": "rules" + } + }, + "description": { + "zh_CN": "表单验证规则, 更多内容可以参考async-validator" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "type": "object", + "widget": { + "component": "MetaCodeEditor", + "props": { + "language": "json" + } + } + }, + { + "property": "error", + "label": { + "text": { + "zh_CN": "error" + } + }, + "description": { + "zh_CN": "表单域验证错误时的提示信息。设置该值会导致表单验证状态变为 error,并显示该错误信息" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "type": "string", + "widget": { + "component": "MetaInput", + "props": {} + } + }, + { + "property": "show-message", + "label": { + "text": { + "zh_CN": "show-message" + } + }, + "description": { + "zh_CN": "是否显示校验错误信息" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "type": "boolean", + "widget": { + "component": "MetaSwitch", + "props": {} + } + }, + { + "property": "inline-message", + "label": { + "text": { + "zh_CN": "inline-message" + } + }, + "description": { + "zh_CN": "是否在行内显示校验信息" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "type": "boolean", + "widget": { + "component": "MetaSwitch", + "props": {} + } + }, + { + "property": "size", + "label": { + "text": { + "zh_CN": "size" + } + }, + "description": { + "zh_CN": "用于控制该表单内组件的尺寸" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "type": "string", + "defaultValue": "default", + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "large", + "value": "large" + }, + { + "label": "default", + "value": "default" + }, + { + "label": "small", + "value": "small" + } + ] + } + } + }, + { + "property": "for", + "label": { + "text": { + "zh_CN": "for" + } + }, + "description": { + "zh_CN": "和原生标签相同能力" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "type": "string", + "widget": { + "component": "MetaInput", + "props": {} + } + }, + { + "property": "validate-status", + "label": { + "text": { + "zh_CN": "validate-status" + } + }, + "description": { + "zh_CN": "formItem 校验的状态" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "type": "string", + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "error", + "value": "error" + }, + { + "label": "validating", + "value": "validating" + }, + { + "label": "success", + "value": "success" + } + ] + } + } + } + ], + "description": { + "zh_CN": "" + } + } + ], + "events": {}, + "slots": { + "label": { + "label": { + "zh_CN": "label" + }, + "description": { + "zh_CN": "标签位置显示的内容" + } + }, + "error": { + "label": { + "zh_CN": "error" + }, + "description": { + "zh_CN": "验证错误信息的显示内容" + } + } + } + } + }, + { + "id": 1, + "version": "2.4.2", + "name": { + "zh_CN": "表单" + }, + "component": "ElTable", + "icon": "table", + "description": "用于展示多条结构类似的数据, 可对数据进行排序、筛选、对比或其他自定义操作", + "doc_url": "", + "screenshot": "", + "tags": "", + "keywords": "", + "dev_mode": "proCode", + "npm": { + "package": "element-plus", + "version": "2.4.2", + "script": "https://unpkg.com/element-plus@2.4.2/dist/index.full.mjs", + "css": "https://unpkg.com/element-plus@2.4.2/dist/index.css", + "dependencies": null, + "exportName": "ElTable" + }, + "group": "表单组件", + "category": "element-plus", + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "isPopper": false, + "nestingRule": { + "childWhitelist": ["ElTableColumn"], + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["inline", "label-width"] + }, + "contextMenu": { + "actions": ["copy", "remove", "insert", "updateAttr", "bindEevent", "createBlock"], + "disable": [] + }, + "invalidity": [""], + "clickCapture": true, + "framework": "Vue" + }, + "schema": { + "properties": [ + { + "name": "0", + "label": { + "zh_CN": "基础属性" + }, + "content": [ + { + "property": "data", + "label": { + "text": { + "zh_CN": "data" + } + }, + "description": { + "zh_CN": "显示的数据" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "type": "array", + "widget": { + "component": "MetaCodeEditor", + "props": { + "language": "json" + } + } + }, + { + "property": "columns", + "label": { + "text": { + "zh_CN": "表格列" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "properties": [ + { + "label": { + "zh_CN": "默认分组" + }, + "content": [ + { + "property": "type", + "type": "string", + "labelPosition": "top", + "label": { + "text": { + "zh_CN": "type" + } + }, + "description": { + "text": { + "zh_CN": "对应列的类型。 如果设置了selection则显示多选框; 如果设置了 index 则显示该行的索引(从 1 开始计算); 如果设置了 expand 则显示为一个可展开的按钮" + } + }, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "selection", + "value": "selection" + }, + { + "label": "index", + "value": "index" + }, + { + "label": "expand", + "value": "expand" + } + ] + } + } + }, + { + "property": "index", + "type": "string", + "labelPosition": "top", + "label": { + "text": { + "zh_CN": "index" + } + }, + "description": { + "text": { + "zh_CN": "如果设置了 type=index,可以通过传递 index 属性来自定义索引" + } + }, + "widget": { + "component": "MetaCodeEditor", + "props": {} + } + }, + { + "property": "label", + "type": "string", + "labelPosition": "top", + "label": { + "text": { + "zh_CN": "label" + } + }, + "description": { + "text": { + "zh_CN": "显示的标题" + } + }, + "widget": { + "component": "MetaInput", + "props": {} + } + }, + { + "property": "column-key", + "type": "string", + "labelPosition": "top", + "label": { + "text": { + "zh_CN": "column-key" + } + }, + "description": { + "text": { + "zh_CN": "column 的 key, column 的 key, 如果需要使用 filter-change 事件,则需要此属性标识是哪个 column 的筛选条件" + } + }, + "widget": { + "component": "MetaInput", + "props": {} + } + }, + { + "property": "prop", + "type": "string", + "labelPosition": "top", + "label": { + "text": { + "zh_CN": "prop" + } + }, + "description": { + "text": { + "zh_CN": "字段名称 对应列内容的字段名, 也可以使用 property属性" + } + }, + "widget": { + "component": "MetaInput", + "props": {} + } + }, + { + "property": "width", + "type": "number", + "labelPosition": "top", + "label": { + "text": { + "zh_CN": "width" + } + }, + "description": { + "text": { + "zh_CN": "对应列的宽度" + } + }, + "widget": { + "component": "MetaNumberic", + "props": {} + } + }, + { + "property": "min-width", + "type": "number", + "labelPosition": "top", + "label": { + "text": { + "zh_CN": "min-width" + } + }, + "description": { + "text": { + "zh_CN": "对应列的最小宽度, 对应列的最小宽度, 与 width 的区别是 width 是固定的,min-width 会把剩余宽度按比例分配给设置了 min-width 的列" + } + }, + "widget": { + "component": "MetaNumberic", + "props": {} + } + }, + { + "property": "fixed", + "type": "string", + "labelPosition": "top", + "label": { + "text": { + "zh_CN": "fixed" + } + }, + "description": { + "text": { + "zh_CN": "列是否固定在左侧或者右侧。 true 表示固定在左侧" + } + }, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "left", + "value": "left" + }, + { + "label": "right", + "value": "right" + } + ] + } + } + }, + { + "property": "sortable", + "type": "boolean", + "labelPosition": "top", + "label": { + "text": { + "zh_CN": "sortable" + } + }, + "description": { + "text": { + "zh_CN": "对应列是否可以排序" + } + }, + "widget": { + "component": "MetaSwitch", + "props": {} + } + }, + { + "property": "sort-method", + "type": "function", + "labelPosition": "top", + "label": { + "text": { + "zh_CN": "sort-method" + } + }, + "description": { + "text": { + "zh_CN": "指定数据按照哪个属性进行排序,仅当sortable设置为true的时候有效。 应该如同 Array.sort 那样返回一个 Number" + } + }, + "widget": { + "component": "MetaCodeEditor", + "props": {} + } + }, + { + "property": "sort-by", + "type": "array", + "labelPosition": "top", + "label": { + "text": { + "zh_CN": "sort-by" + } + }, + "description": { + "text": { + "zh_CN": "指定数据按照哪个属性进行排序,仅当 sortable 设置为 true 且没有设置 sort-method 的时候有效。 如果 sort-by 为数组,则先按照第 1 个属性排序,如果第 1 个相等,再按照第 2 个排序,以此类推" + } + }, + "widget": { + "component": "MetaCodeEditor", + "props": { + "language": "json" + } + } + }, + { + "property": "sort-orders", + "type": "array", + "labelPosition": "top", + "label": { + "text": { + "zh_CN": "sort-orders" + } + }, + "description": { + "text": { + "zh_CN": "数据在排序时所使用排序策略的轮转顺序,仅当 sortable 为 true 时有效。 需传入一个数组,随着用户点击表头,该列依次按照数组中元素的顺序进行排序" + } + }, + "widget": { + "component": "MetaCodeEditor", + "props": { + "language": "json" + } + } + }, + { + "property": "resizable", + "type": "boolean", + "labelPosition": "top", + "defaultValue": true, + "label": { + "text": { + "zh_CN": "resizable" + } + }, + "description": { + "text": { + "zh_CN": "对应列是否可以通过拖动改变宽度(需要在 el-table 上设置 border 属性为真)" + } + }, + "widget": { + "component": "MetaSwitch", + "props": {} + } + }, + { + "property": "formatter", + "type": "function", + "labelPosition": "top", + "defaultValue": true, + "label": { + "text": { + "zh_CN": "formatter" + } + }, + "description": { + "text": { + "zh_CN": "用来格式化内容" + } + }, + "widget": { + "component": "MetaCodeEditor", + "props": {} + } + }, + { + "property": "show-overflow-tooltip", + "type": "boolean", + "labelPosition": "top", + "defaultValue": true, + "label": { + "text": { + "zh_CN": "show-overflow-tooltip" + } + }, + "description": { + "text": { + "zh_CN": "当内容过长被隐藏时显示 tooltip" + } + }, + "widget": { + "component": "MetaSwitch", + "props": {} + } + }, + { + "property": "align", + "type": "string", + "labelPosition": "top", + "defaultValue": "left", + "label": { + "text": { + "zh_CN": "align" + } + }, + "description": { + "text": { + "zh_CN": "对齐方式" + } + }, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "left", + "value": "left" + }, + { + "label": "center", + "value": "center" + }, + { + "label": "right", + "value": "right" + } + ] + } + } + }, + { + "property": "header-align", + "type": "string", + "labelPosition": "top", + "defaultValue": "left", + "label": { + "text": { + "zh_CN": "header-align" + } + }, + "description": { + "text": { + "zh_CN": "表头对齐方式, 若不设置该项,则使用表格的对齐方式" + } + }, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "left", + "value": "left" + }, + { + "label": "center", + "value": "center" + }, + { + "label": "right", + "value": "right" + } + ] + } + } + }, + { + "property": "class-name", + "type": "string", + "labelPosition": "top", + "defaultValue": "left", + "label": { + "text": { + "zh_CN": "class-name" + } + }, + "description": { + "text": { + "zh_CN": "列的 className" + } + }, + "widget": { + "component": "MetaInput", + "props": {} + } + }, + { + "property": "label-class-name", + "type": "string", + "labelPosition": "top", + "defaultValue": "left", + "label": { + "text": { + "zh_CN": "label-class-name" + } + }, + "description": { + "text": { + "zh_CN": "当前列标题的自定义类名" + } + }, + "widget": { + "component": "MetaInput", + "props": {} + } + }, + { + "property": "selectable", + "type": "function", + "labelPosition": "top", + "defaultValue": true, + "label": { + "text": { + "zh_CN": "selectable" + } + }, + "description": { + "text": { + "zh_CN": "仅对 type=selection 的列有效,类型为 Function,Function 的返回值用来决定这一行的 CheckBox 是否可以勾选" + } + }, + "widget": { + "component": "MetaCodeEditor", + "props": {} + } + }, + { + "property": "reserve-selection", + "type": "boolean", + "labelPosition": "top", + "defaultValue": true, + "label": { + "text": { + "zh_CN": "reserve-selection" + } + }, + "description": { + "text": { + "zh_CN": "数据刷新后是否保留选项,仅对 type=selection 的列有效, 请注意, 需指定 row-key 来让这个功能生效。" + } + }, + "widget": { + "component": "MetaSwitch", + "props": {} + } + }, + { + "property": "filters", + "type": "array", + "labelPosition": "top", + "defaultValue": true, + "label": { + "text": { + "zh_CN": "filters" + } + }, + "description": { + "text": { + "zh_CN": "数据刷新后是否保留选项,仅对 type=selection 的列有效, 请注意, 需指定 row-key 来让这个功能生效。" + } + }, + "widget": { + "component": "MetaCodeEditor", + "props": { + "language": "json" + } + } + }, + { + "property": "filter-placement", + "type": "string", + "labelPosition": "top", + "label": { + "text": { + "zh_CN": "filter-placement" + } + }, + "description": { + "text": { + "zh_CN": "过滤弹出框的定位" + } + }, + "widget": { + "component": "MetaInput", + "props": {} + } + }, + { + "property": "filter-multiple", + "type": "string", + "labelPosition": "top", + "defaultValue": true, + "label": { + "text": { + "zh_CN": "filter-multiple" + } + }, + "description": { + "text": { + "zh_CN": "数据过滤的选项是否多选" + } + }, + "widget": { + "component": "MetaSwitch", + "props": {} + } + }, + { + "property": "filter-method", + "type": "function", + "labelPosition": "top", + "defaultValue": true, + "label": { + "text": { + "zh_CN": "filter-method" + } + }, + "description": { + "text": { + "zh_CN": "数据过滤使用的方法, 如果是多选的筛选项,对每一条数据会执行多次,任意一次返回 true 就会显示" + } + }, + "widget": { + "component": "MetaCodeEditor", + "props": {} + } + }, + { + "property": "filtered-value", + "type": "array", + "labelPosition": "top", + "defaultValue": true, + "label": { + "text": { + "zh_CN": "filtered-value" + } + }, + "description": { + "text": { + "zh_CN": "选中的数据过滤项,如果需要自定义表头过滤的渲染方式,可能会需要此属性" + } + }, + "widget": { + "component": "MetaCodeEditor", + "props": { + "language": "json" + } + } + } + ] + } + ], + "widget": { + "component": "MetaTableColumns", + "props": { + "type": "object", + "textField": "title", + "language": "json", + "buttonText": "编辑列配置", + "title": "编辑列配置", + "expand": true + } + }, + "description": { + "zh_CN": "表格列的配置信息" + }, + "labelPosition": "top" + }, + { + "property": "max-height", + "label": { + "text": { + "zh_CN": "max-height" + } + }, + "description": { + "zh_CN": "Table 的最大高度。" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "type": "number", + "widget": { + "component": "MetaNumberic", + "props": {} + }, + "device": [] + }, + { + "property": "height", + "label": { + "text": { + "zh_CN": "height" + } + }, + "description": { + "zh_CN": "Table 的高度, 默认为自动高度。 这个高度会设置为 Table 的 style.height 的值,Table 的高度会受控于外部样式。" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "type": "string", + "widget": { + "component": "MetaInput", + "props": {} + }, + "device": [] + }, + { + "property": "stripe", + "label": { + "text": { + "zh_CN": "stripe" + } + }, + "description": { + "zh_CN": "是否为斑马纹 table" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "defaultValue": false, + "type": "boolean", + "widget": { + "component": "MetaSwitch", + "props": {} + } + }, + { + "property": "border", + "label": { + "text": { + "zh_CN": "border" + } + }, + "description": { + "zh_CN": "是否带有纵向边框" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "defaultValue": false, + "type": "boolean", + "widget": { + "component": "MetaSwitch", + "props": {} + } + }, + { + "property": "size", + "label": { + "text": { + "zh_CN": "size" + } + }, + "description": { + "zh_CN": "Table 的尺寸" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "type": "string", + "defaultValue": "default", + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "large", + "value": "large" + }, + { + "label": "default", + "value": "default" + }, + { + "label": "small", + "value": "small" + } + ] + } + } + }, + { + "property": "fit", + "label": { + "text": { + "zh_CN": "fit" + } + }, + "description": { + "zh_CN": "列的宽度是否自撑开" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "defaultValue": true, + "type": "boolean", + "widget": { + "component": "MetaSwitch", + "props": {} + } + }, + { + "property": "show-header", + "label": { + "text": { + "zh_CN": "show-header" + } + }, + "description": { + "zh_CN": "是否显示表头" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "defaultValue": true, + "type": "boolean", + "widget": { + "component": "MetaSwitch", + "props": {} + } + }, + { + "property": "highlight-current-row", + "label": { + "text": { + "zh_CN": "highlight-current-row" + } + }, + "description": { + "zh_CN": "是否要高亮当前行" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "defaultValue": false, + "type": "boolean", + "widget": { + "component": "MetaSwitch", + "props": {} + } + }, + { + "property": "current-row-key", + "label": { + "text": { + "zh_CN": "current-row-key" + } + }, + "description": { + "zh_CN": "当前行的 key,只写属性" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "type": "string", + "widget": { + "component": "MetaInput", + "props": {} + }, + "device": [] + }, + { + "property": "row-class-name", + "label": { + "text": { + "zh_CN": "row-class-name" + } + }, + "description": { + "zh_CN": "行的 className" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "widget": { + "component": "MetaInput", + "props": {} + }, + "device": [] + }, + { + "property": "row-key", + "label": { + "text": { + "zh_CN": "row-key" + } + }, + "description": { + "zh_CN": "行数据的 Key,用来优化 Table 的渲染; 在使用reserve-selection功能与显示树形数据时,该属性是必填的。 类型为 String 时,支持多层访问:user.info.id,但不支持 user.info[0].id,此种情况请使用 Function" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "device": [] + }, + { + "property": "empty-text", + "label": { + "text": { + "zh_CN": "empty-text" + } + }, + "description": { + "zh_CN": "空数据时显示的文本内容" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "widget": { + "component": "MetaInput", + "props": {} + }, + "device": [] + }, + { + "property": "table-layout", + "label": { + "text": { + "zh_CN": "table-layout" + } + }, + "description": { + "zh_CN": "设置表格单元、行和列的布局方式" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "defaultValue": "fixed", + "widget": { + "component": "MetaInput", + "props": { + "options": [ + { + "label": "fixed", + "value": "fixed" + }, + { + "label": "auto", + "value": "auto" + } + ] + } + }, + "device": [] + }, + { + "property": "scrollbar-always-on", + "label": { + "text": { + "zh_CN": "scrollbar-always-on" + } + }, + "description": { + "zh_CN": "总是显示滚动条" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "defaultValue": false, + "type": "boolean", + "widget": { + "component": "MetaSwitch", + "props": {} + } + }, + { + "property": "flexible", + "label": { + "text": { + "zh_CN": "flexible" + } + }, + "description": { + "zh_CN": "确保主轴的最小尺寸,以便不超过内容" + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "labelPosition": "top", + "defaultValue": false, + "type": "boolean", + "widget": { + "component": "MetaSwitch", + "props": {} + } + } + ], + "description": { + "zh_CN": "" + } + } + ], + "events": { + "onSelect": { + "label": { + "zh_CN": "勾选数据行的 Checkbox 时触发" + }, + "description": { + "zh_CN": "当用户手动勾选数据行的 Checkbox 时触发的事件" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "selection", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "当前选中项" + } + }, + { + "name": "row", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "当前行" + } + } + ], + "returns": {} + } + }, + "onSelectAll": { + "label": { + "zh_CN": "勾选全选时触发" + }, + "description": { + "zh_CN": "当用户手动勾选全选 Checkbox 时触发的事件" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "selection", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "当前选中项" + } + } + ], + "returns": {} + } + }, + "onSelectionChange": { + "label": { + "zh_CN": "选择项发生变化时会触发" + }, + "description": { + "zh_CN": "当选择项发生变化时会触发该事件" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "selection", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "当前选中项" + } + } + ], + "returns": {} + } + }, + "onCellMouseEnter": { + "label": { + "zh_CN": "单元格 hover 时会触发" + }, + "description": { + "zh_CN": "当单元格 hover 进入时会触发该事件" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "row", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "当前行" + } + }, + { + "name": "column", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "当前列" + } + }, + { + "name": "cell", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "当前单元格" + } + }, + { + "name": "event", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "原生事件 event" + } + } + ], + "returns": {} + } + }, + "onCellMouseLeave": { + "label": { + "zh_CN": "单元格 hover 退出时会触发" + }, + "description": { + "zh_CN": "当单元格 hover 退出时会触发该事件" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "row", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "当前行" + } + }, + { + "name": "column", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "当前列" + } + }, + { + "name": "cell", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "当前单元格" + } + }, + { + "name": "event", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "原生事件 event" + } + } + ], + "returns": {} + } + } + }, + "slots": { + "empty": { + "label": { + "zh_CN": "empty" + }, + "description": { + "zh_CN": "当数据为空时自定义的内容" + } + }, + "append": { + "label": { + "zh_CN": "append" + }, + "description": { + "zh_CN": "插入至表格最后一行之后的内容, 如果需要对表格的内容进行无限滚动操作,可能需要用到这个 slot。 若表格有合计行,该 slot 会位于合计行之上。" + } + } + } + } + }, + { + "id": 1, + "version": "2.4.2", + "name": { + "zh_CN": "表单" + }, + "component": "ElTableColumn", + "icon": "table", + "description": "用于展示多条结构类似的数据, 可对数据进行排序、筛选、对比或其他自定义操作", + "doc_url": "", + "screenshot": "", + "tags": "", + "keywords": "", + "dev_mode": "proCode", + "npm": { + "package": "element-plus", + "version": "2.4.2", + "script": "https://unpkg.com/element-plus@2.4.2/dist/index.full.mjs", + "css": "https://unpkg.com/element-plus@2.4.2/dist/index.css", + "dependencies": null, + "exportName": "ElTableColumn" + }, + "group": "表单组件", + "category": "element-plus", + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "isPopper": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["inline", "label-width"] + }, + "contextMenu": { + "actions": ["copy", "remove", "insert", "updateAttr", "bindEevent", "createBlock"], + "disable": [] + }, + "invalidity": [""], + "clickCapture": true, + "framework": "Vue" + }, + "schema": { + "properties": [ + { + "name": "0", + "label": { + "zh_CN": "基础属性" + }, + "content": [], + "description": { + "zh_CN": "" + } + } + ], + "events": {}, + "slots": {} + } + }, + { + "name": { + "zh_CN": "走马灯子项" + }, + "component": "TinyCarouselItem", + "icon": "carouselitem", + "description": "常用于一组图片或卡片轮播,当内容空间不足时,可以用走马灯的形式进行收纳,进行轮播展现。", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "CarouselItem", + "version": "", + "destructuring": true + }, + "group": "component", + "category": "容器组件", + "priority": 2, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "name", + "label": { + "text": { + "zh_CN": "幻灯片的名字,可用作 setActiveItem 的参数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "title", + "label": { + "text": { + "zh_CN": "幻灯片的标题" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "indicator-position", + "label": { + "text": { + "zh_CN": "指示器的位置" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "outside", + "value": "outside" + }, + { + "label": "none", + "value": "none" + } + ] + } + }, + "description": { + "zh_CN": "" + } + } + ] + } + ], + "events": {} + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": true, + "isModal": false, + "nestingRule": { + "childWhitelist": [], + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["disabled", "size"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "name": { + "zh_CN": "走马灯" + }, + "component": "TinyCarousel", + "icon": "carousel", + "description": "常用于一组图片或卡片轮播,当内容空间不足时,可以用走马灯的形式进行收纳,进行轮播展现。", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Carousel", + "version": "", + "destructuring": true + }, + "group": "component", + "category": "容器组件", + "priority": 2, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "arrow", + "label": { + "text": { + "zh_CN": "切换箭头的显示时机" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": { + "options": [ + { + "label": "总是显示", + "value": "always" + }, + { + "label": "鼠标悬停时显示", + "value": "hover" + }, + { + "label": "从不显示", + "value": "never" + } + ] + } + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "autoplay", + "label": { + "text": { + "zh_CN": "是否自动切换" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "tabs", + "label": { + "text": { + "zh_CN": "选项卡" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "defaultValue": "", + "cols": 12, + "bindState": false, + "widget": { + "component": "MetaContainer", + "props": {} + }, + "description": { + "zh_CN": "tabs" + }, + "labelPosition": "none" + }, + { + "property": "height", + "label": { + "text": { + "zh_CN": "走马灯的高度" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "indicator-position", + "label": { + "text": { + "zh_CN": "指示器的位置" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": { + "options": [ + { + "label": "走马灯外部", + "value": "outside" + }, + { + "label": "不显示", + "value": "none" + } + ] + } + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "initial-index", + "label": { + "text": { + "zh_CN": "初始状态激活的幻灯片的索引,从 0 开始 " + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "interval", + "label": { + "text": { + "zh_CN": "自动切换的时间间隔,单位为毫秒" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "loop", + "label": { + "text": { + "zh_CN": "是否循环显示" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "show-title", + "label": { + "text": { + "zh_CN": "是否显示标题" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "trigger", + "label": { + "text": { + "zh_CN": "指示器的触发方式,默认为 hover" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": { + "options": [ + { + "label": "点击", + "value": "click" + }, + { + "label": "悬停", + "value": "hover" + } + ] + } + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "type", + "label": { + "text": { + "zh_CN": "走马灯的类型" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": { + "options": [ + { + "label": "水平", + "value": "horizontal" + }, + { + "label": "垂直", + "value": "vertical" + }, + { + "label": "卡片", + "value": "card" + } + ] + } + }, + "description": { + "zh_CN": "" + } + } + ] + } + ], + "events": {} + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": true, + "clickCapture": false, + "isModal": false, + "nestingRule": { + "childWhitelist": ["TinyCarouselItem"], + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["disabled", "size"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "icon": "link", + "name": { + "zh_CN": "提示框" + }, + "component": "a", + "description": "链接", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "group": "component", + "priority": 7, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "children", + "label": { + "text": { + "zh_CN": "类型" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaHtmlText", + "props": {} + }, + "description": { + "zh_CN": "" + }, + "labelPosition": "none" + }, + { + "property": "href", + "label": { + "text": { + "zh_CN": "跳转链接" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "链接" + } + }, + { + "property": "target", + "label": { + "text": { + "zh_CN": "页面目标" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "当前页面", + "value": "_self" + }, + { + "label": "打开新页面", + "value": "_blank" + } + ] + } + }, + "description": { + "zh_CN": "链接" + } + }, + { + "property": "attributes3", + "label": { + "text": { + "zh_CN": "原生属性" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaHtmlAttributes", + "props": {} + }, + "description": { + "zh_CN": "" + }, + "labelPosition": "none" + } + ] + } + ] + }, + "configure": { + "loop": true, + "condition": true, + "slots": [], + "styles": true, + "isContainer": true, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": [] + }, + "contextMenu": { + "actions": [], + "disable": [] + } + } + }, + { + "name": { + "zh_CN": "标题" + }, + "component": ["h1", "h2", "h3", "h4", "h5", "h6"], + "icon": "h16", + "description": "标题", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": {}, + "group": "component", + "category": "html", + "priority": 20, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "children", + "label": { + "text": { + "zh_CN": "类型" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaHtmlText", + "props": { + "showRadioButton": true + } + }, + "description": { + "zh_CN": "" + }, + "labelPosition": "none" + }, + { + "property": "attributes3", + "label": { + "text": { + "zh_CN": "原生属性" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaHtmlAttributes", + "props": {} + }, + "description": { + "zh_CN": "" + }, + "labelPosition": "none" + } + ] + } + ], + "events": {} + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": [], + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["disabled", "size"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "name": { + "zh_CN": "段落" + }, + "component": "p", + "icon": "paragraph", + "description": "段落", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": {}, + "group": "component", + "category": "html", + "priority": 30, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "children", + "label": { + "text": { + "zh_CN": "类型" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaHtmlText", + "props": {} + }, + "description": { + "zh_CN": "" + }, + "labelPosition": "none" + }, + { + "property": "attributes3", + "label": { + "text": { + "zh_CN": "原生属性" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaHtmlAttributes", + "props": {} + }, + "description": { + "zh_CN": "" + }, + "labelPosition": "none" + } + ] + } + ], + "events": {} + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": [], + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": [] + }, + "contextMenu": { + "actions": [], + "disable": [] + } + } + }, + { + "name": { + "zh_CN": "输入框" + }, + "component": "input", + "icon": "input", + "description": "输入框", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": {}, + "group": "component", + "category": "html", + "priority": 40, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "type", + "label": { + "text": { + "zh_CN": "类型" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "checkbox", + "value": "checkbox" + }, + { + "label": "color", + "value": "color" + }, + { + "label": "date", + "value": "date" + }, + { + "label": "button", + "value": "button" + }, + { + "label": "email", + "value": "email" + }, + { + "label": "file", + "value": "file" + }, + { + "label": "hidden", + "value": "hidden" + }, + { + "label": "image", + "value": "image" + }, + { + "label": "month", + "value": "month" + }, + { + "label": "number", + "value": "number" + }, + { + "label": "password", + "value": "password" + }, + { + "label": "radio", + "value": "radio" + }, + { + "label": "range", + "value": "range" + }, + { + "label": "reset", + "value": "reset" + }, + { + "label": "search", + "value": "search" + }, + { + "label": "submit", + "value": "submit" + }, + { + "label": "text", + "value": "text" + }, + { + "label": "time", + "value": "time" + }, + { + "label": "week", + "value": "week" + }, + { + "label": "url", + "value": "url" + } + ] + } + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "placeholder", + "label": { + "text": { + "zh_CN": "占位符" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "attributes3", + "label": { + "text": { + "zh_CN": "原生属性" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaHtmlAttributes", + "props": {} + }, + "description": { + "zh_CN": "" + }, + "labelPosition": "none" + } + ] + } + ], + "events": { + "onBlur": { + "label": { + "zh_CN": "失去焦点时触发" + }, + "description": { + "zh_CN": "在 Input 失去焦点时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "event", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "原生 event" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onFocus": { + "label": { + "zh_CN": "获取焦点时触发" + }, + "description": { + "zh_CN": "在 Input 获取焦点时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "event", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "原生 event" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onChange": { + "label": { + "zh_CN": "输入值改变时触发" + }, + "description": { + "zh_CN": "在 Input 输入值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "event", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "原生 event" + } + } + ], + "returns": {} + }, + "defaultValue": "" + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": [], + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["disabled", "size"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "name": { + "zh_CN": "视频" + }, + "component": "video", + "icon": "video", + "description": "视频", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": {}, + "group": "component", + "category": "html", + "priority": 50, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 10, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "src", + "label": { + "text": { + "zh_CN": "视频的 URL" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "width", + "label": { + "text": { + "zh_CN": "视频播放器的宽度" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "height", + "label": { + "text": { + "zh_CN": "视频播放器的高度" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "controls", + "label": { + "text": { + "zh_CN": "是否显示控件" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "autoplay", + "label": { + "text": { + "zh_CN": "是否马上播放" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "attributes3", + "label": { + "text": { + "zh_CN": "原生属性" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaHtmlAttributes", + "props": {} + }, + "description": { + "zh_CN": "" + }, + "labelPosition": "none" + } + ] + } + ], + "events": {} + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": [], + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": [] + }, + "contextMenu": { + "actions": [], + "disable": [] + } + } + }, + { + "icon": "Image", + "name": { + "zh_CN": "Img" + }, + "component": "Img", + "container": false, + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": {}, + "group": "component", + "category": "html", + "priority": 60, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "src", + "type": "string", + "defaultValue": "", + "bindState": true, + "label": { + "text": { + "zh_CN": "src路径" + } + }, + "cols": 12, + "rules": [], + "widget": { + "component": "MetaInput", + "props": {} + } + }, + { + "property": "attributes3", + "label": { + "text": { + "zh_CN": "原生属性" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaHtmlAttributes", + "props": {} + }, + "description": { + "zh_CN": "" + }, + "labelPosition": "none" + } + ] + } + ], + "events": {}, + "shortcuts": { + "properties": ["src"] + }, + "contentMenu": { + "actions": [] + } + } + }, + { + "icon": "button", + "name": { + "zh_CN": "Button" + }, + "component": "button", + "container": false, + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": {}, + "group": "component", + "category": "html", + "priority": 70, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "attributes3", + "label": { + "text": { + "zh_CN": "原生属性" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaHtmlAttributes", + "props": {} + }, + "description": { + "zh_CN": "" + }, + "labelPosition": "none" + } + ] + } + ], + "events": { + "onClick": { + "label": { + "zh_CN": "点击时触发" + }, + "description": { + "zh_CN": "点击时触发" + }, + "type": "event", + "functionInfo": { + "params": [], + "returns": {} + }, + "defaultValue": "" + } + }, + "shortcuts": { + "properties": [] + }, + "contentMenu": { + "actions": [] + } + } + }, + { + "icon": "table", + "name": { + "zh_CN": "表格" + }, + "component": "table", + "container": false, + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": {}, + "group": "component", + "category": "html", + "priority": 80, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "width", + "label": { + "text": { + "zh_CN": "表格的宽度" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "border", + "label": { + "text": { + "zh_CN": "表格边框的宽度" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "attributes3", + "label": { + "text": { + "zh_CN": "原生属性" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaHtmlAttributes", + "props": {} + }, + "description": { + "zh_CN": "" + }, + "labelPosition": "none" + } + ] + } + ], + "events": { + "onClick": { + "label": { + "zh_CN": "点击时触发" + }, + "description": { + "zh_CN": "点击时触发" + }, + "type": "event", + "functionInfo": { + "params": [], + "returns": {} + }, + "defaultValue": "" + } + }, + "shortcuts": { + "properties": [] + }, + "contentMenu": { + "actions": [] + } + } + }, + { + "icon": "td", + "name": { + "zh_CN": "表格单元格" + }, + "component": "td", + "container": false, + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": {}, + "group": "component", + "category": "html", + "priority": 90, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "colspan", + "label": { + "text": { + "zh_CN": "单元格可横跨的列数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "rowspan", + "label": { + "text": { + "zh_CN": "单元格可横跨的行数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "attributes3", + "label": { + "text": { + "zh_CN": "原生属性" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaHtmlAttributes", + "props": {} + }, + "description": { + "zh_CN": "" + }, + "labelPosition": "none" + } + ] + } + ], + "events": { + "onClick": { + "label": { + "zh_CN": "点击时触发" + }, + "description": { + "zh_CN": "点击时触发" + }, + "type": "event", + "functionInfo": { + "params": [], + "returns": {} + }, + "defaultValue": "" + } + }, + "shortcuts": { + "properties": [] + }, + "contentMenu": { + "actions": [] + } + } + }, + { + "icon": "form", + "name": { + "zh_CN": "表单" + }, + "component": "form", + "container": false, + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": {}, + "group": "component", + "category": "html", + "priority": 100, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "name", + "label": { + "text": { + "zh_CN": "表单的名称" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "action", + "label": { + "text": { + "zh_CN": "提交表单时向何处发送表单数据" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "method", + "label": { + "text": { + "zh_CN": "用于发送 form-data 的 HTTP 方法" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "get", + "value": "get" + }, + { + "label": "post", + "value": "post" + } + ] + } + }, + "description": { + "zh_CN": "" + } + } + ] + } + ], + "events": { + "onClick": { + "label": { + "zh_CN": "点击时触发" + }, + "description": { + "zh_CN": "点击时触发" + }, + "type": "event", + "functionInfo": { + "params": [], + "returns": {} + }, + "defaultValue": "" + } + }, + "shortcuts": { + "properties": [] + }, + "contentMenu": { + "actions": [] + } + } + }, + { + "icon": "label", + "name": { + "zh_CN": "表单标签" + }, + "component": "label", + "container": false, + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": {}, + "group": "component", + "category": "html", + "priority": 110, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "for", + "label": { + "text": { + "zh_CN": "label 绑定到哪个表单元素" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "form", + "label": { + "text": { + "zh_CN": "label 字段所属的一个或多个表单" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + } + ] + } + ], + "events": {}, + "shortcuts": { + "properties": [] + }, + "contentMenu": { + "actions": [] + } + } + }, + { + "name": { + "zh_CN": "按钮组" + }, + "component": "TinyButtonGroup", + "icon": "buttonGroup", + "description": "以按钮组的方式出现,常用于多项类似操作", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "ButtonGroup", + "version": "", + "destructuring": true + }, + "group": "component", + "category": "general", + "priority": 2, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "data", + "label": { + "text": { + "zh_CN": "按钮组数据" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": { + "language": "json" + } + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "size", + "label": { + "text": { + "zh_CN": "组件大小" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "mini", + "value": "mini" + }, + { + "label": "small", + "value": "small" + }, + { + "label": "medium", + "value": "medium" + } + ] + } + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "plain", + "label": { + "text": { + "zh_CN": "是否是朴素按钮" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "disabled", + "label": { + "text": { + "zh_CN": "禁用" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + } + ] + } + ], + "events": {} + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": [], + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["disabled", "size"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "icon": "row", + "name": { + "zh_CN": "row" + }, + "component": "TinyRow", + "description": "定义 Layout 的行配置信息", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Row", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 5, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "layout", + "label": { + "text": { + "zh_CN": "layout" + } + }, + "cols": 12, + "widget": { + "component": "MetaLayoutGrid", + "props": {} + }, + "description": { + "zh_CN": "layout" + }, + "labelPosition": "none" + }, + { + "property": "align", + "label": { + "text": { + "zh_CN": "align" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "top", + "value": "top" + }, + { + "label": "middle", + "value": "middle" + }, + { + "label": "bottom", + "value": "bottom" + } + ] + } + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "flex", + "label": { + "text": { + "zh_CN": "flex" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + } + }, + { + "property": "gutter", + "label": { + "text": { + "zh_CN": "gutter" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": {} + }, + "description": { + "zh_CN": "" + } + } + ] + } + ] + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": [], + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["label-width", "disabled"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "icon": "form", + "name": { + "zh_CN": "表单" + }, + "component": "TinyForm", + "description": "由按钮、输入框、选择器、单选框、多选框等控件组成,用以收集、校验、提交数据", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Form", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 5, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "disabled", + "label": { + "text": { + "zh_CN": "是否禁用" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "label-width", + "label": { + "text": { + "zh_CN": "标签宽度" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "表单中标签占位宽度,默认为 80px" + }, + "labelPosition": "left" + }, + { + "property": "inline", + "label": { + "text": { + "zh_CN": "行内布局" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "行内布局模式,默认为 false" + } + }, + { + "property": "label-align", + "label": { + "text": { + "zh_CN": "必填标识是否占位" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "必填标识 * 是否占位" + }, + "labelPosition": "left" + }, + { + "property": "label-suffix", + "label": { + "text": { + "zh_CN": "标签后缀" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "表单中标签后缀" + } + }, + { + "property": "label-position", + "label": { + "text": { + "zh_CN": "标签位置" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "right", + "value": "right" + }, + { + "label": "left ", + "value": "left " + }, + { + "label": "top", + "value": "top" + } + ] + } + }, + "description": { + "zh_CN": "表单中标签的布局位置" + } + } + ] + }, + { + "name": "1", + "label": { + "zh_CN": "校验属性" + }, + "content": [ + { + "property": "model", + "label": { + "text": { + "zh_CN": "表单校验对象" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "表单数据对象" + }, + "labelPosition": "left" + }, + { + "property": "rules", + "label": { + "text": { + "zh_CN": "校验规则" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "表单验证规则" + } + } + ], + "description": { + "zh_CN": "" + } + } + ], + "events": { + "onValidate": { + "label": { + "zh_CN": "表单项被校验后触发" + }, + "description": { + "zh_CN": "表单项被校验后触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "function", + "type": "Function", + "defaultValue": "(valid) => {}", + "description": { + "zh_CN": "校验回调函数" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onInput": { + "label": { + "zh_CN": "输入值改变时触发" + }, + "description": { + "zh_CN": "在 Input 输入值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "输入框输入的值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onBlur": { + "label": { + "zh_CN": "失去焦点时触发" + }, + "description": { + "zh_CN": "在 Input 失去焦点时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "event", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "原生 event" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onFocus": { + "label": { + "zh_CN": "获取焦点时触发" + }, + "description": { + "zh_CN": "在 Input 获取焦点时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "event", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "原生 event" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onClear": { + "label": { + "zh_CN": "点击清空按钮时触发" + }, + "description": { + "zh_CN": "点击清空按钮时触发" + }, + "type": "event", + "functionInfo": { + "params": [], + "returns": {} + }, + "defaultValue": "" + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": [], + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["label-width", "disabled"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "icon": "formitem", + "name": { + "zh_CN": "表单项" + }, + "component": "TinyFormItem", + "description": "由按钮、输入框、选择器、单选框、多选框等控件组成,用以收集、校验、提交数据", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "FormItem", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 12, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "label", + "label": { + "text": { + "zh_CN": "标签文本" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "defaultValue": "标签", + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "标签文本" + }, + "labelPosition": "left" + }, + { + "property": "prop", + "label": { + "text": { + "zh_CN": "校验字段" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "表单域 model 字段,在使用 validate、resetFields 方法的情况下,该属性是必填的" + } + }, + { + "property": "required", + "label": { + "text": { + "zh_CN": "必填" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否必填" + }, + "labelPosition": "left" + } + ] + } + ], + "events": {}, + "slots": { + "label": { + "label": { + "zh_CN": "字段名" + }, + "description": { + "zh_CN": "自定义显示字段名称" + } + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": true, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": ["TinyForm"], + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["label", "rules"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "icon": "col", + "name": { + "zh_CN": "col" + }, + "component": "TinyCol", + "description": "列配置信息", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Col", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 2, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "span", + "label": { + "text": { + "zh_CN": "栅格列格数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "整行", + "value": 12 + }, + { + "label": "6格", + "value": 6 + }, + { + "label": "4格", + "value": 4 + }, + { + "label": "3格", + "value": 3 + }, + { + "label": "1格", + "value": 1 + } + ] + } + }, + "description": { + "zh_CN": "当一行分为12格时,一列可占位多少格" + } + }, + { + "property": "move", + "label": { + "text": { + "zh_CN": "栅格左右移动格数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": { + "min": -12, + "max": 12 + } + }, + "description": { + "zh_CN": "栅格左右移动格数(正数向右,负数向左)" + } + }, + { + "property": "no", + "label": { + "text": { + "zh_CN": "排序编号" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": { + "max": 12 + } + }, + "description": { + "zh_CN": "排序编号(row中启用order生效)" + } + }, + { + "property": "offset", + "label": { + "text": { + "zh_CN": "间隔格数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": { + "min": 0, + "max": 12 + } + }, + "description": { + "zh_CN": "栅格左侧的间隔格数" + } + }, + { + "property": "xs", + "label": { + "text": { + "zh_CN": "超小屏格数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": { + "min": 1, + "max": 12 + } + }, + "description": { + "zh_CN": "<768px 响应式栅格数" + } + }, + { + "property": "sm", + "label": { + "text": { + "zh_CN": "小屏格数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": { + "min": 1, + "max": 12 + } + }, + "description": { + "zh_CN": "≥768px 响应式栅格数" + } + }, + { + "property": "md", + "label": { + "text": { + "zh_CN": "中屏格数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": { + "min": 1, + "max": 12 + } + }, + "description": { + "zh_CN": "≥992px 响应式栅格数" + } + }, + { + "property": "lg", + "label": { + "text": { + "zh_CN": "大屏格数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": { + "min": 1, + "max": 12 + } + }, + "description": { + "zh_CN": "≥1200px 响应式栅格数" + } + }, + { + "property": "xl", + "label": { + "text": { + "zh_CN": "超大屏格数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": { + "min": 1, + "max": 12 + } + }, + "description": { + "zh_CN": "≥1920px 响应式栅格数" + } + } + ] + } + ], + "events": {} + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": true, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["label", "rules"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "name": { + "zh_CN": "按钮" + }, + "component": "TinyButton", + "icon": "button", + "description": "常用的操作按钮,提供包括默认按钮、图标按钮、图片按钮、下拉按钮等类型", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Button", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 2, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "text", + "type": "string", + "defaultValue": "按钮文案", + "label": { + "text": { + "zh_CN": "按钮文字" + } + }, + "cols": 12, + "hidden": false, + "required": true, + "readOnly": false, + "disabled": false, + "widget": { + "component": "MetaBindI18n", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "size", + "type": "select", + "label": { + "text": { + "zh_CN": "大小" + } + }, + "cols": 12, + "rules": [], + "hidden": false, + "required": true, + "readOnly": false, + "disabled": false, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "large", + "value": "large" + }, + { + "label": "medium", + "value": "medium" + }, + { + "label": "small", + "value": "small" + }, + { + "label": "mini", + "value": "mini" + } + ] + } + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "disabled", + "label": { + "text": { + "zh_CN": "禁用" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否被禁用" + }, + "labelPosition": "left" + }, + { + "property": "type", + "label": { + "text": { + "zh_CN": "类型" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "primary", + "value": "primary" + }, + { + "label": "success", + "value": "success" + }, + { + "label": "info", + "value": "info" + }, + { + "label": "warning", + "value": "warning" + }, + { + "label": "danger", + "value": "danger" + }, + { + "label": "text", + "value": "text" + } + ] + } + }, + "description": { + "zh_CN": "设置不同的主题样式" + }, + "labelPosition": "left" + } + ] + }, + { + "name": "1", + "label": { + "zh_CN": "其他" + }, + "content": [ + { + "property": "round", + "label": { + "text": { + "zh_CN": "圆角" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否圆角按钮" + }, + "labelPosition": "left" + }, + { + "property": "plain", + "label": { + "text": { + "zh_CN": "朴素按钮" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否为朴素按钮" + }, + "labelPosition": "left" + }, + { + "property": "reset-time", + "label": { + "text": { + "zh_CN": "禁用时间" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": {} + }, + "description": { + "zh_CN": "设置禁用时间,防止重复提交,单位毫秒" + } + }, + { + "property": "circle", + "label": { + "text": { + "zh_CN": "圆角" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否圆形按钮" + }, + "labelPosition": "left" + }, + { + "property": "autofocus", + "label": { + "text": { + "zh_CN": "聚焦" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否默认聚焦" + }, + "labelPosition": "left" + }, + { + "property": "loading", + "label": { + "text": { + "zh_CN": "加载中" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否展示位加载中样式" + }, + "labelPosition": "left" + } + ], + "description": { + "zh_CN": "" + } + } + ], + "events": { + "onClick": { + "label": { + "zh_CN": "点击事件" + }, + "description": { + "zh_CN": "按钮被点击时触发的回调函数" + }, + "type": "event", + "functionInfo": { + "params": [], + "returns": {} + }, + "defaultValue": "" + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": true, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["text", "size"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "name": { + "zh_CN": "输入框" + }, + "component": "TinyInput", + "icon": "input", + "description": "通过鼠标或键盘输入字符", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Input", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 1, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "modelValue", + "label": { + "text": { + "zh_CN": "绑定值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaBindI18n", + "props": {} + }, + "description": { + "zh_CN": "双向绑定值" + }, + "labelPosition": "left" + }, + { + "property": "type", + "label": { + "text": { + "zh_CN": "类型" + } + }, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "textarea", + "value": "textarea" + }, + { + "label": "text", + "value": "text" + }, + { + "label": "password", + "value": "password" + } + ] + } + }, + "description": { + "zh_CN": "设置input框的type属性" + } + }, + { + "property": "rows", + "label": { + "text": { + "zh_CN": "行数" + } + }, + "widget": { + "component": "MetaNumber" + }, + "description": { + "zh_CN": "输入框行数,只对 type='textarea' 有效" + } + }, + { + "property": "placeholder", + "label": { + "text": { + "zh_CN": "占位文本" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaBindI18n", + "props": {} + }, + "description": { + "zh_CN": "输入框占位文本" + }, + "labelPosition": "left" + }, + { + "property": "clearable", + "label": { + "text": { + "zh_CN": "清除按钮" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否显示清除按钮" + }, + "labelPosition": "left" + }, + { + "property": "disabled", + "label": { + "text": { + "zh_CN": "是否禁用" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "size", + "label": { + "text": { + "zh_CN": "尺寸" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "medium", + "value": "medium" + }, + { + "label": "small", + "value": "small" + }, + { + "label": "mini", + "value": "mini" + } + ] + } + }, + "description": { + "zh_CN": "输入框尺寸。该属性的可选值为 medium / small / mini" + } + } + ] + }, + { + "name": "1", + "label": { + "zh_CN": "其他" + }, + "content": [ + { + "property": "maxlength", + "label": { + "text": { + "zh_CN": "最大长度" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": {} + }, + "description": { + "zh_CN": "设置 input 框的maxLength" + }, + "labelPosition": "left" + }, + { + "property": "autofocus", + "label": { + "text": { + "zh_CN": "聚焦" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "自动获取焦点" + }, + "labelPosition": "left" + } + ], + "description": { + "zh_CN": "" + } + } + ], + "events": { + "onChange": { + "label": { + "zh_CN": "值改变时触发" + }, + "description": { + "zh_CN": "在 Input 值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "输入框改变后的值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onInput": { + "label": { + "zh_CN": "输入值改变时触发" + }, + "description": { + "zh_CN": "在 Input 输入值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "输入框输入的值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onUpdate:modelValue": { + "label": { + "zh_CN": "双向绑定的值改变时触发" + }, + "description": { + "zh_CN": "在 Input 输入值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "双向绑定的值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onBlur": { + "label": { + "zh_CN": "失去焦点时触发" + }, + "description": { + "zh_CN": "在 Input 失去焦点时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "event", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "原生 event" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onFocus": { + "label": { + "zh_CN": "获取焦点时触发" + }, + "description": { + "zh_CN": "在 Input 获取焦点时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "event", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "原生 event" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onClear": { + "label": { + "zh_CN": "点击清空按钮时触发" + }, + "description": { + "zh_CN": "点击清空按钮时触发" + }, + "type": "event", + "functionInfo": { + "params": [], + "returns": {} + }, + "defaultValue": "" + } + }, + "slots": { + "prefix": { + "label": { + "zh_CN": "前置内容" + } + }, + "suffix": { + "label": { + "zh_CN": "后置内容" + } + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": true, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["value", "disabled"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "icon": "radio", + "name": { + "zh_CN": "单选" + }, + "component": "TinyRadio", + "description": "用于配置不同场景的选项,在一组备选项中进行单选", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Radio", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 3, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "text", + "label": { + "text": { + "zh_CN": "文本" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "label", + "label": { + "text": { + "zh_CN": "单选框的值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "modelValue", + "label": { + "text": { + "zh_CN": "绑定值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "双向绑定的当前选中值" + } + }, + { + "property": "disabled", + "label": { + "text": { + "zh_CN": "禁用" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + } + ] + }, + { + "label": { + "zh_CN": "其他" + }, + "description": { + "zh_CN": "" + }, + "content": [ + { + "property": "border", + "label": { + "text": { + "zh_CN": "显示边框" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "size", + "label": { + "text": { + "zh_CN": "单选框的尺寸" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "name", + "label": { + "text": { + "zh_CN": "原生 name 属性" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "" + } + } + ] + } + ], + "events": { + "onChange": { + "label": { + "zh_CN": "值变化事件" + }, + "description": { + "zh_CN": "绑定值变化时触发的事件" + } + }, + "onUpdate:modelValue": { + "label": { + "zh_CN": "双向绑定的值改变时触发" + }, + "description": { + "zh_CN": "当前选中的值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "双向绑定的当前选中值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["visible", "width"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "icon": "select", + "name": { + "zh_CN": "下拉框" + }, + "component": "TinySelect", + "description": "Select 选择器是一种通过点击弹出下拉列表展示数据并进行选择的 UI 组件", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Select", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 8, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 10, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "modelValue", + "label": { + "text": { + "zh_CN": "绑定值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "双向绑定的当前选中值" + }, + "labelPosition": "left" + }, + { + "property": "placeholder", + "label": { + "text": { + "zh_CN": "占位文本" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "输入框占位文本" + }, + "labelPosition": "left" + }, + { + "property": "clearable", + "label": { + "text": { + "zh_CN": "清除按钮" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否显示清除按钮" + }, + "labelPosition": "left" + }, + { + "property": "searchable", + "label": { + "text": { + "zh_CN": "下拉面板可搜索" + } + }, + "required": false, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "下拉面板是否可搜索" + }, + "labelPosition": "left" + }, + { + "property": "disabled", + "label": { + "text": { + "zh_CN": "是否禁用" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "options", + "label": { + "text": { + "zh_CN": "下拉数据" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": { + "language": "json" + } + }, + "description": { + "zh_CN": "配置 Select 下拉数据项" + }, + "labelPosition": "left" + }, + { + "property": "multiple", + "label": { + "text": { + "zh_CN": "多选" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否允许输入框输入或选择多个项" + }, + "labelPosition": "left" + } + ] + }, + { + "name": "1", + "label": { + "zh_CN": "其他" + }, + "content": [ + { + "property": "multiple-limit", + "label": { + "text": { + "zh_CN": "最大可选值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": {} + }, + "description": { + "zh_CN": "多选时用户最多可以选择的项目数,为 0 则不限制" + }, + "labelPosition": "left" + }, + { + "property": "popper-class", + "label": { + "text": { + "zh_CN": "下拉框的类名" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "设置下拉框自定义的类名" + }, + "labelPosition": "left" + }, + { + "property": "collapse-tags", + "label": { + "text": { + "zh_CN": "多选展示" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "多选时是否将选中值按文字的形式展示" + }, + "labelPosition": "left" + } + ], + "description": { + "zh_CN": "" + } + } + ], + "events": { + "onChange": { + "label": { + "zh_CN": "值改变时触发" + }, + "description": { + "zh_CN": "在下拉框值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "下拉框选中项的值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onUpdate:modelValue": { + "label": { + "zh_CN": "双向绑定的值改变时触发" + }, + "description": { + "zh_CN": "当前选中的值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "双向绑定的当前选中值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onBlur": { + "label": { + "zh_CN": "失去焦点时触发" + }, + "description": { + "zh_CN": "在 Input 失去焦点时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "event", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "原生 event" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onFocus": { + "label": { + "zh_CN": "获取焦点时触发" + }, + "description": { + "zh_CN": "在 Input 获取焦点时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "event", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "原生 event" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onClear": { + "label": { + "zh_CN": "点击清空按钮时触发" + }, + "description": { + "zh_CN": "点击清空按钮时触发" + }, + "type": "event", + "functionInfo": { + "params": [], + "returns": {} + }, + "defaultValue": "" + }, + "onRemoveTag": { + "label": { + "zh_CN": "多选模式下移除tag时触发" + }, + "description": { + "zh_CN": "多选模式下移除tag时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "被移除Tag对应数据项的值字段" + } + } + ], + "returns": {} + }, + "defaultValue": "" + } + }, + "onBeforeMount": "console.log('table on load'); this.options = source.data" + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["multiple", "options"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "icon": "switch", + "name": { + "zh_CN": "开关" + }, + "component": "TinySwitch", + "description": "Switch 在两种状态间切换选择", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Switch", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 9, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "disabled", + "label": { + "text": { + "zh_CN": "禁用" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否被禁用" + }, + "labelPosition": "left" + }, + { + "property": "modelValue", + "label": { + "text": { + "zh_CN": "绑定值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "绑定默认值" + } + }, + { + "property": "true-value", + "label": { + "text": { + "zh_CN": "打开时的值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "设置打开时的值(Boolean / String / Number)" + }, + "labelPosition": "left" + }, + { + "property": "false-value", + "label": { + "text": { + "zh_CN": "关闭时的值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "设置关闭时的值(Boolean / String / Number)" + }, + "labelPosition": "left" + }, + { + "property": "mini", + "label": { + "text": { + "zh_CN": "迷你尺寸" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否显示为 mini 模式" + }, + "labelPosition": "left" + } + ] + } + ], + "events": { + "onChange": { + "label": { + "zh_CN": "点击事件" + }, + "description": { + "zh_CN": "按钮被点击时触发的回调函数" + }, + "type": "event", + "functionInfo": { + "params": [], + "returns": {} + }, + "defaultValue": "" + }, + "onUpdate:modelValue": { + "label": { + "zh_CN": "双向绑定的值改变时触发" + }, + "description": { + "zh_CN": "开关的状态值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "双向绑定的开关状态值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["disabled", "mini"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "icon": "search", + "name": { + "zh_CN": "搜索框" + }, + "component": "TinySearch", + "description": "指定条件对象进行搜索数据", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Search", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 2, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "modelValue", + "label": { + "text": { + "zh_CN": "默认值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "输入框内的默认搜索值" + }, + "labelPosition": "left" + }, + { + "property": "disabled", + "label": { + "text": { + "zh_CN": "禁用" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否被禁用" + }, + "labelPosition": "left" + }, + { + "property": "placeholder", + "label": { + "text": { + "zh_CN": "占位文本 " + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "输入框内的提示占位文本" + }, + "labelPosition": "left" + }, + { + "property": "clearable", + "label": { + "text": { + "zh_CN": "清空按钮" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "设置显示清空图标按钮" + }, + "labelPosition": "left" + }, + { + "property": "isEnterSearch", + "label": { + "text": { + "zh_CN": "是否Enter键触发search事件" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否在按下键盘Enter键的时候触发search事件" + }, + "labelPosition": "left" + } + ] + }, + { + "name": "1", + "label": { + "zh_CN": "其他配置" + }, + "content": [ + { + "property": "mini", + "label": { + "text": { + "zh_CN": "迷你尺寸" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "迷你模式,配置为true时,搜索默认显示为一个带图标的圆形按钮,点击后展开" + }, + "labelPosition": "left" + }, + { + "property": "transparent", + "label": { + "text": { + "zh_CN": "透明模式" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "配置为true时,边框变为透明且收缩后半透明显示,一般用在带有背景的场景,默认 false" + }, + "labelPosition": "left" + } + ], + "description": { + "zh_CN": "" + } + } + ], + "events": { + "onChange": { + "label": { + "zh_CN": "输入完成时触发" + }, + "description": { + "zh_CN": "在 input 框中输入完成时触发的回调函数" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "type", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "搜索类型,默认值为 {} " + } + }, + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "当前input框中值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onSearch": { + "label": { + "zh_CN": "点击搜索按钮时触发" + }, + "description": { + "zh_CN": "展开状态点击搜索按钮时触发的回调函数" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "type", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "搜索类型,默认值为 {} " + } + }, + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "当前input框中值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["clearable", "mini"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "icon": "checkbox", + "name": { + "zh_CN": "复选框" + }, + "component": "TinyCheckbox", + "description": "用于配置不同场景的选项,提供用户可在一组选项中进行多选", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Checkbox", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 4, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "modelValue", + "label": { + "text": { + "zh_CN": "绑定值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "双向绑定值" + }, + "labelPosition": "left" + }, + { + "property": "disabled", + "label": { + "text": { + "zh_CN": "是否禁用" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "checked", + "label": { + "text": { + "zh_CN": "勾选" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "当前是否勾选" + }, + "labelPosition": "left" + }, + { + "property": "text", + "label": { + "text": { + "zh_CN": "文本" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "复选框的文本" + }, + "labelPosition": "left" + } + ] + }, + { + "name": "1", + "label": { + "zh_CN": "其他" + }, + "content": [ + { + "property": "border", + "label": { + "text": { + "zh_CN": "边框" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否显示边框" + } + }, + { + "property": "false-label", + "label": { + "text": { + "zh_CN": "未选中的值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "没有选中时的值" + } + }, + { + "property": "true-label", + "label": { + "text": { + "zh_CN": "选择时的值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "选中时的值" + } + } + ], + "description": { + "zh_CN": "" + } + } + ], + "events": { + "onChange": { + "label": { + "zh_CN": "勾选值改变后将触发" + }, + "description": { + "zh_CN": "勾选值改变后将触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "选中项的值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onUpdate:modelValue": { + "label": { + "zh_CN": "双向绑定的值改变时触发" + }, + "description": { + "zh_CN": "当前选中的值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "双向绑定的当前选中值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["border", "disabled"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "icon": "checkboxbutton", + "name": { + "zh_CN": "复选按钮" + }, + "component": "TinyCheckboxButton", + "description": "用于配置不同场景的选项,提供用户可在一组选项中进行多选", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "CheckboxButton", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 1, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "modelValue", + "label": { + "text": { + "zh_CN": "绑定值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "双向绑定的当前选中值" + }, + "labelPosition": "left" + }, + { + "property": "disabled", + "label": { + "text": { + "zh_CN": "是否禁用" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "checked", + "label": { + "text": { + "zh_CN": "勾选" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "当前是否勾选" + }, + "labelPosition": "left" + }, + { + "property": "text", + "label": { + "text": { + "zh_CN": "文本" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "按钮文本" + }, + "labelPosition": "left" + } + ] + } + ], + "events": { + "onChange": { + "label": { + "zh_CN": "勾选值改变后将触发" + }, + "description": { + "zh_CN": "勾选值改变后将触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "选中项的值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onUpdate:modelValue": { + "label": { + "zh_CN": "双向绑定的值改变时触发" + }, + "description": { + "zh_CN": "当前选中的值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "array", + "defaultValue": "", + "description": { + "zh_CN": "双向绑定的当前选中值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": true, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["text", "size"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "icon": "checkboxgroup", + "name": { + "zh_CN": "复选按钮组" + }, + "component": "TinyCheckboxGroup", + "description": "用于配置不同场景的选项,提供用户可在一组选项中进行多选", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "CheckboxGroup", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 2, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "modelValue", + "label": { + "text": { + "zh_CN": "绑定值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": { + "dataType": "Array" + } + }, + "description": { + "zh_CN": "双向绑定的当前选中值" + }, + "labelPosition": "left" + }, + { + "property": "disabled", + "label": { + "text": { + "zh_CN": "是否禁用" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "options", + "label": { + "text": { + "zh_CN": "数据列表" + } + }, + "defaultValue": [ + { + "label": "标签2" + }, + { + "label": "标签2" + } + ], + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "checkbox组件列表" + } + }, + { + "property": "type", + "label": { + "text": { + "zh_CN": "类型" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "button", + "value": "button" + }, + { + "label": "checkbox", + "value": "checkbox" + } + ] + } + }, + "description": { + "zh_CN": "checkbox组件类型(button/checkbox),该属性的默认值为 checkbox,配合 options 属性一起使用" + }, + "labelPosition": "left" + } + ] + } + ], + "events": { + "onChange": { + "label": { + "zh_CN": "勾选值改变后将触发" + }, + "description": { + "zh_CN": "勾选值改变后将触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "选中项的值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onUpdate:modelValue": { + "label": { + "zh_CN": "双向绑定的值改变时触发" + }, + "description": { + "zh_CN": "当前选中的值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "array", + "defaultValue": "", + "description": { + "zh_CN": "双向绑定的当前选中值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": true, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["disabled", "type"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "icon": "dialogbox", + "name": { + "zh_CN": "对话框" + }, + "component": "TinyDialogBox", + "description": "模态对话框,在浮层中显示,引导用户进行相关操作。", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "DialogBox", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 4, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "title", + "label": { + "text": { + "zh_CN": "标题" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "弹出框标题" + }, + "labelPosition": "left" + }, + { + "property": "visible", + "label": { + "text": { + "zh_CN": "显示与隐藏" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "控制弹出框显示与关闭" + }, + "labelPosition": "left" + }, + { + "property": "width", + "label": { + "text": { + "zh_CN": "宽度" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "弹出框的宽度" + }, + "labelPosition": "left" + }, + { + "property": "draggable", + "label": { + "text": { + "zh_CN": "可拖拽" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否开启弹窗的拖拽功能,默认值为 false 。" + } + }, + { + "property": "center", + "label": { + "text": { + "zh_CN": "居中" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "弹出框的头部与底部内容会自动居中" + }, + "labelPosition": "left" + }, + { + "property": "dialog-class", + "label": { + "text": { + "zh_CN": "自定义类" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "自定义配置弹窗类名" + }, + "labelPosition": "left" + }, + { + "property": "append-to-body", + "label": { + "text": { + "zh_CN": "插入到 Body " + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "DialogBox 本身是否插入到 body 上,嵌套的 Dialog 必须指定该属性并赋值为 true" + }, + "labelPosition": "left" + }, + { + "property": "show-close", + "label": { + "text": { + "zh_CN": "关闭按钮" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否显示关闭按钮,默认值为 true 。" + } + } + ] + } + ], + "selector": ".TinyDialogBox", + "events": { + "onClose": { + "label": { + "zh_CN": "关闭弹窗时触发" + }, + "description": { + "zh_CN": "Dialog 关闭的回调" + }, + "type": "event", + "functionInfo": { + "params": [], + "returns": {} + }, + "defaultValue": "" + }, + "onUpdate:visible": { + "label": { + "zh_CN": "双向绑定的状态改变时触发" + }, + "description": { + "zh_CN": "显示或隐藏的状态值,发生改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "boolean", + "defaultValue": "", + "description": { + "zh_CN": "双向绑定的显示或隐藏的状态值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + } + }, + "slots": { + "title": { + "label": { + "zh_CN": "标题区" + }, + "description": { + "zh_CN": "Dialog 标题区的内容" + } + }, + "footer": { + "label": { + "zh_CN": "按钮操作区" + }, + "description": { + "zh_CN": "Dialog 按钮操作区的内容" + } + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": true, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": ".tiny-dialog-box", + "shortcuts": { + "properties": ["visible", "width"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "icon": "tabs", + "name": { + "zh_CN": "标签页" + }, + "component": "TinyTabs", + "description": "分隔内容上有关联但属于不同类别的数据集合", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Tabs", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 10, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "showEditIcon", + "label": { + "text": { + "zh_CN": "显示编辑ICON " + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否显示标题后编辑 ICON" + }, + "labelPosition": "left" + }, + { + "property": "tabs", + "label": { + "text": { + "zh_CN": "选项卡" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "defaultValue": "", + "cols": 12, + "bindState": false, + "widget": { + "component": "MetaContainer", + "props": {} + }, + "description": { + "zh_CN": "tabs" + }, + "labelPosition": "none" + }, + { + "property": "modelValue", + "label": { + "text": { + "zh_CN": "绑定值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "绑定值,选中选项卡的 name" + }, + "labelPosition": "left" + }, + { + "property": "with-add", + "label": { + "text": { + "zh_CN": "可新增" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "标签是否可增加" + }, + "labelPosition": "left" + }, + { + "property": "with-close", + "label": { + "text": { + "zh_CN": "可关闭" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "标签是否可关闭" + }, + "labelPosition": "left" + }, + { + "property": "tab-style", + "label": { + "text": { + "zh_CN": "标签页样式" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "card", + "value": "card" + }, + { + "label": "border-card", + "value": "border-card" + } + ] + } + }, + "description": { + "zh_CN": "标签页样式" + }, + "labelPosition": "left" + } + ] + } + ], + "events": { + "onClick": { + "label": { + "zh_CN": "点击页签时触发事件" + }, + "description": { + "zh_CN": "在 Input 值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "component", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "当前点击的页签对象" + } + }, + { + "name": "event", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "原生 event" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onEdit": { + "label": { + "zh_CN": "点击新增按钮或关闭按钮或者编辑按钮后触发" + }, + "description": { + "zh_CN": "点击新增按钮或关闭按钮或者编辑按钮后触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "tab", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "当前操作的页签对象" + } + }, + { + "name": "type", + "type": "String", + "defaultValue": "", + "description": { + "zh_CN": "当前操作的类型(remove || add || edit)" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onClose": { + "label": { + "zh_CN": "关闭页签时触发" + }, + "description": { + "zh_CN": "关闭页签时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "name", + "type": "String", + "defaultValue": "", + "description": { + "zh_CN": "页签名称" + } + } + ], + "returns": {} + }, + "defaultValue": "" + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": true, + "clickCapture": false, + "isModal": false, + "nestingRule": { + "childWhitelist": ["TinyTabItem"], + "parentWhitelist": [], + "descendantBlacklist": [], + "ancestorWhitelist": [] + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["size", "tab-style"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "icon": "tabitem", + "name": { + "zh_CN": "tab页签" + }, + "component": "TinyTabItem", + "description": "tab 标签页", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "TabItem", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 2, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "name", + "label": { + "text": { + "zh_CN": "唯一表示" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "唯一表示" + } + }, + { + "property": "title", + "label": { + "text": { + "zh_CN": "标题" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "标题" + } + } + ] + } + ], + "events": {}, + "slots": { + "title": { + "label": { + "zh_CN": "标题" + }, + "description": { + "zh_CN": "自定义标题" + } + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": true, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": ["TinyTab"], + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["name", "title"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "icon": "breadcrumb", + "name": { + "zh_CN": "面包屑" + }, + "component": "TinyBreadcrumb", + "description": "告诉访问者他们目前在网站中的位置以及如何返回", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Select", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 1, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "separator", + "label": { + "text": { + "zh_CN": "分隔符" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "自定义分隔符" + }, + "labelPosition": "left" + }, + { + "property": "options", + "label": { + "text": { + "zh_CN": "options" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "textField", + "label": { + "text": { + "zh_CN": "textField" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + } + } + ] + } + ], + "events": { + "onSelect": { + "label": { + "zh_CN": "选择 breadcrumb 时触发" + }, + "description": { + "zh_CN": "选择 breadcrumb 时触发" + }, + "type": "event", + "functionInfo": { + "params": [], + "returns": {} + }, + "defaultValue": "" + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": true, + "clickCapture": false, + "isModal": false, + "nestingRule": { + "childWhitelist": ["TinyBreadcrumbItem"], + "parentWhitelist": [], + "descendantBlacklist": [], + "ancestorWhitelist": [] + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["separator"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "icon": "breadcrumb", + "name": { + "zh_CN": "面包屑项" + }, + "component": "TinyBreadcrumbItem", + "description": "", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "BreadcrumbItem", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 1, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "to", + "label": { + "text": { + "zh_CN": "路由路径" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "面包屑项" + } + } + ] + } + ], + "slots": { + "default": { + "label": { + "zh_CN": "面包屑项标签" + }, + "description": { + "zh_CN": "面包屑项" + } + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": true, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": ["TinyBreadcrumb"], + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["to"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "icon": "collapse", + "name": { + "zh_CN": "折叠面板" + }, + "component": "TinyCollapse", + "description": "内容区可指定动态页面或自定义 html 等,支持展开收起操作", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Collapse", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 3, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "modelValue", + "label": { + "text": { + "zh_CN": "当前激活的面板" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "双向绑定当前激活的面板" + }, + "labelPosition": "left" + } + ] + } + ], + "events": { + "onChange": { + "label": { + "zh_CN": "激活面板改变时触发" + }, + "description": { + "zh_CN": "当前激活面板改变时触发(如果是手风琴模式,参数 activeNames 类型为string,否则为array)" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "data", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "当前激活面板的值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onUpdate:modelValue": { + "label": { + "zh_CN": "双向绑定的值改变时触发" + }, + "description": { + "zh_CN": "当前激活面板的值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "双向绑定的值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["label-width", "disabled"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "icon": "collapseitem", + "name": { + "zh_CN": "折叠面板项" + }, + "component": "TinyCollapseItem", + "description": "内容区可指定动态页面或自定义 html 等,支持展开收起操作", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "CollapseItem", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 2, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "name", + "label": { + "text": { + "zh_CN": "唯一标志符" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "唯一标志符;String | Number" + }, + "labelPosition": "left" + }, + { + "property": "title", + "label": { + "text": { + "zh_CN": "面板标题" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "面板标题" + }, + "labelPosition": "left" + } + ] + } + ], + "events": {}, + "slots": { + "title": { + "label": { + "zh_CN": "标题" + }, + "description": { + "zh_CN": "自定义标题" + } + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": true, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["label-width", "disabled"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "icon": "grid", + "name": { + "zh_CN": "表格" + }, + "component": "TinyGrid", + "description": "提供了非常强大数据表格功能,可以展示数据列表,可以对数据列表进行选择、编辑等", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Grid", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 2, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础属性" + }, + "description": { + "zh_CN": "基础属性" + }, + "collapse": { + "number": 15, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "data", + "label": { + "text": { + "zh_CN": "表格数据" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": { + "language": "json" + } + }, + "onChange": "this.delProp('fetchData')", + "description": { + "zh_CN": "设置表格的数据" + } + }, + { + "property": "columns", + "label": { + "text": { + "zh_CN": "表格列" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "properties": [ + { + "label": { + "zh_CN": "默认分组" + }, + "content": [ + { + "property": "title", + "type": "string", + "defaultValue": "", + "label": { + "text": { + "zh_CN": "列标题" + } + }, + "widget": { + "component": "MetaBindI18n", + "props": {} + } + }, + { + "property": "field", + "type": "string", + "defaultValue": "", + "label": { + "text": { + "zh_CN": "列键值" + } + }, + "widget": { + "component": "MetaInput", + "props": {} + } + }, + { + "property": "sortable", + "type": "boolean", + "defaultValue": true, + "label": { + "text": { + "zh_CN": "是否排序" + } + }, + "widget": { + "component": "MetaSwitch", + "props": {} + } + }, + { + "property": "width", + "type": "string", + "defaultValue": "", + "label": { + "text": { + "zh_CN": "列宽" + } + }, + "widget": { + "component": "MetaNumber", + "props": {} + } + }, + { + "property": "formatText", + "type": "string", + "defaultValue": "", + "label": { + "text": { + "zh_CN": "内置渲染器" + } + }, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "整数", + "value": "integer" + }, + { + "label": "小数", + "value": "number" + }, + { + "label": "金额", + "value": "money" + }, + { + "label": "百分比", + "value": "rate" + }, + { + "label": "布尔", + "value": "boole" + }, + { + "label": "年月日", + "value": "date" + }, + { + "label": "年月日时分", + "value": "dateTime" + }, + { + "label": "时间", + "value": "time" + }, + { + "label": "省略", + "value": "ellipsis" + } + ] + } + } + }, + { + "property": "renderer", + "type": "object", + "defaultValue": "", + "label": { + "text": { + "zh_CN": "渲染函数" + } + }, + "widget": { + "component": "MetaCodeEditor", + "props": { + "dataType": "JSFunction" + } + } + }, + { + "property": "slots", + "type": "object", + "defaultValue": "", + "label": { + "text": { + "zh_CN": "插槽" + } + }, + "labelPosition": "none", + "widget": { + "component": "MetaJsSlot", + "props": { + "slots": ["header", "default"] + } + } + }, + { + "property": "type", + "label": { + "text": { + "zh_CN": "列类型" + } + }, + "required": false, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "索引列", + "value": "index" + }, + { + "label": "单选列", + "value": "radio" + }, + { + "label": "多选列", + "value": "selection" + }, + { + "label": "展开列", + "value": "expand" + } + ], + "clearable": true + } + }, + "description": { + "zh_CN": "设置内置列的类型,该属性的可选值为 index(序号)/ selection(复选框)/ radio(单选框)/ expand(展开行)" + }, + "labelPosition": "left" + }, + { + "property": "editor", + "label": { + "text": { + "zh_CN": "编辑配置" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": { + "language": "json" + } + }, + "description": { + "zh_CN": "单元格编辑渲染配置项,也可以是函数 Function(h, params)" + }, + "labelPosition": "left" + }, + { + "property": "filter", + "label": { + "text": { + "zh_CN": "筛选配置" + } + }, + "required": false, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": { + "language": "json" + } + }, + "description": { + "zh_CN": "设置表格列的筛选配置信息。默认值为 false 不配置筛选信息" + } + }, + { + "property": "showOverflow", + "label": { + "text": { + "zh_CN": "内容超出部分省略号配置" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "只显示省略号", + "value": "ellipsis" + }, + { + "label": "显示为原生 title", + "value": "title" + }, + { + "label": "显示为 tooltip 提示", + "value": "tooltip" + } + ], + "clearable": true + } + }, + "description": { + "zh_CN": "设置内置列的内容超出部分显示省略号配置,该属性的可选值为 ellipsis(只显示省略号)/ title(显示为原生 title)/ tooltip(显示为 tooltip 提示)" + }, + "labelPosition": "left" + } + ] + } + ], + "widget": { + "component": "MetaArrayItem", + "props": { + "type": "object", + "textField": "title", + "language": "json", + "buttonText": "编辑列配置", + "title": "编辑列配置", + "expand": true + } + }, + "description": { + "zh_CN": "表格列的配置信息" + }, + "labelPosition": "left" + }, + { + "property": "fetchData", + "label": { + "text": { + "zh_CN": "服务端数据" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "onChange": "this.delProp('data')", + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": { + "name": "fetchData", + "dataType": "JSExpression" + } + }, + "description": { + "zh_CN": "服务端数据查询方法" + } + }, + { + "property": "pager", + "label": { + "text": { + "zh_CN": "分页配置" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "defaultValue": { + "attrs": { + "currentPage": 1 + } + }, + "widget": { + "component": "MetaCodeEditor", + "props": { + "name": "pager", + "dataType": "JSExpression" + } + }, + "description": { + "zh_CN": "分页配置" + } + }, + { + "property": "resizable", + "label": { + "text": { + "zh_CN": "调整列宽" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否允许调整列宽" + }, + "labelPosition": "left" + }, + { + "property": "row-id", + "label": { + "text": { + "zh_CN": "行数据唯一标识的字段名" + } + }, + "required": false, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": { + "placeholder": "比如:id" + } + }, + "description": { + "zh_CN": "行数据唯一标识的字段名" + }, + "labelPosition": "left" + }, + { + "property": "select-config", + "label": { + "text": { + "zh_CN": "复选框配置" + } + }, + "required": false, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": { + "dataType": "JSExpression" + } + }, + "description": { + "zh_CN": "表格行数据复选框配置项" + }, + "labelPosition": "left" + }, + { + "property": "edit-rules", + "label": { + "text": { + "zh_CN": "校验规则" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "表格校验规则配置项" + }, + "labelPosition": "left" + }, + { + "property": "edit-config", + "label": { + "text": { + "zh_CN": "编辑配置项" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "表格编辑配置项" + } + }, + { + "property": "expand-config", + "label": { + "text": { + "zh_CN": "复选框配置项" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "复选框配置项" + }, + "labelPosition": "left" + }, + { + "property": "sortable", + "label": { + "text": { + "zh_CN": "可排序" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否允许列数据排序。默认为 true 可排序" + }, + "labelPosition": "left" + } + ] + }, + { + "label": { + "zh_CN": "其他属性" + }, + "description": { + "zh_CN": "其他属性" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "auto-resize", + "label": { + "text": { + "zh_CN": "可排序" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否允许列数据排序。默认为 true 可排序" + }, + "labelPosition": "left" + }, + { + "property": "border", + "label": { + "text": { + "zh_CN": "边框" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否带有纵向边框" + }, + "labelPosition": "left" + }, + { + "property": "seq-serial", + "label": { + "text": { + "zh_CN": "行号连续" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "设置行序号是否连续,开启分页时有效,该属性的默认值为 false" + }, + "labelPosition": "left" + }, + { + "property": "highlight-current-row", + "label": { + "text": { + "zh_CN": "高亮当前行" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "高亮当前行" + }, + "labelPosition": "left" + }, + { + "property": "highlight-hover-row", + "label": { + "text": { + "zh_CN": "hover 时候高亮" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "鼠标移到行是否要高亮显示" + }, + "labelPosition": "left" + }, + { + "property": "row-class-name", + "label": { + "text": { + "zh_CN": "hover 高亮" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "给行附加 className,也可以是函数 Function({seq, row, rowIndex, $rowIndex})" + }, + "labelPosition": "left" + }, + { + "property": "max-height", + "label": { + "text": { + "zh_CN": "最大高度" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "设置表格内容区域(不含表格头部,底部)的最大高度。" + }, + "labelPosition": "left" + }, + { + "property": "row-span", + "label": { + "text": { + "zh_CN": "行合并" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "设置行合并,该属性仅适用于普通表格,不可与 tree-config 同时使用" + }, + "labelPosition": "left" + } + ] + } + ], + "events": { + "onFilterChange": { + "label": { + "zh_CN": "筛选条件改变时触发改事件" + }, + "description": { + "zh_CN": "配置 remote-filter 开启服务端过滤,服务端过滤会调用表格 fetch-data 进行查询,filter-change 服务端过滤后触发的事件" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "table", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "{$table,filters} 包含 table 实例对象和过滤条件的对象" + } + } + ], + "returns": {} + }, + "defaultValue": "function onClick(e) {}" + }, + "onSortChange": { + "label": { + "zh_CN": "点击列头,执行数据排序前触发的事件" + }, + "description": { + "zh_CN": "配置 remote-filter 开启服务端过滤,服务端过滤会调用表格 fetch-data 进行查询,filter-change 服务端过滤后触发的事件" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "table", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "{$table,filters} 包含 table 实例对象和过滤条件的对象" + } + } + ], + "returns": {} + }, + "defaultValue": "function onClick(e) {}" + }, + "onSelectAll": { + "label": { + "zh_CN": "当手动勾选全选时触发的事件" + }, + "description": { + "zh_CN": "只对 type=selection 有效,当手动勾选全选时触发的事件" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "table", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": " 包含 table 实例对象" + } + }, + { + "name": "checked", + "type": "boolean", + "defaultValue": "", + "description": { + "zh_CN": "勾选状态" + } + }, + { + "name": "selction", + "type": "Array", + "defaultValue": "", + "description": { + "zh_CN": "选中的表格数据数组" + } + } + ], + "returns": {} + }, + "defaultValue": "function onClick(e) {}" + }, + "onSelectChange": { + "label": { + "zh_CN": "手动勾选并且值发生改变时触发的事件" + }, + "description": { + "zh_CN": "只对 type=selection 有效,当手动勾选并且值发生改变时触发的事件" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "table", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": " table 实例对象" + } + }, + { + "name": "event", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": " 原生 Event" + } + } + ], + "returns": {} + }, + "defaultValue": "function onClick(e) {}" + }, + "onToggleExpandChange": { + "label": { + "zh_CN": "当行展开或收起时会触发该事件" + }, + "description": { + "zh_CN": "当行展开或收起时会触发该事件" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "table", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "{$table,row,rowIndex} 包含 table 实例对象和当前行数据的对象" + } + }, + { + "name": "event", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": " 原生 Event" + } + } + ], + "returns": {} + }, + "defaultValue": "function onClick(e) {}" + }, + "onCurrentChange": { + "label": { + "zh_CN": "行点击时触发" + }, + "description": { + "zh_CN": "行点击时触发" + }, + "type": "event", + "functionInfo": { + "params": [], + "returns": {} + }, + "defaultValue": "" + } + }, + "shortcuts": { + "properties": ["sortable", "columns"] + }, + "contentMenu": { + "actions": ["create symbol"] + }, + "onBeforeMount": "console.log('table on load'); this.pager = source.pager; this.fetchData = source.fetchData; this.data = source.data ;this.columns = source.columns" + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["sortable", "columns"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "name": { + "zh_CN": "分页" + }, + "component": "TinyPager", + "icon": "pager", + "description": "当数据量过多时,使用分页分解数据,常用于 Grid 和 Repeater 组件", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Pager", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 1, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 10, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "currentPage", + "label": { + "text": { + "zh_CN": "当前页数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": {} + }, + "description": { + "zh_CN": "当前页数,支持 .sync 修饰符" + }, + "labelPosition": "left" + }, + { + "property": "pageSize", + "label": { + "text": { + "zh_CN": "每页条数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": {} + }, + "description": { + "zh_CN": "每页显示条目个数" + }, + "labelPosition": "left" + }, + { + "property": "pageSizes", + "label": { + "text": { + "zh_CN": "可选每页条数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "设置可选择的每页显示条数" + } + }, + { + "property": "total", + "label": { + "text": { + "zh_CN": "总条数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": {} + }, + "description": { + "zh_CN": "数据总条数" + }, + "labelPosition": "left" + }, + { + "property": "layout", + "label": { + "text": { + "zh_CN": "布局" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "defaultValue": "total,sizes,prev, pager, next", + "widget": { + "component": "MetaInput", + "props": { + "type": "textarea" + } + }, + "description": { + "zh_CN": "组件布局,子组件名用逗号分隔" + }, + "labelPosition": "left" + } + ] + } + ], + "events": { + "onCurrentChange ": { + "label": { + "zh_CN": "切换页码时触发" + }, + "description": { + "zh_CN": "切换页码时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "当前页的值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onPrevClick ": { + "label": { + "zh_CN": "点击上一页按钮时触发" + }, + "description": { + "zh_CN": "点击上一页按钮时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "page", + "type": "String", + "defaultValue": "", + "description": { + "zh_CN": "当前页的页码值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onNextClick": { + "label": { + "zh_CN": "点击下一页按钮时触发" + }, + "description": { + "zh_CN": "点击上一页按钮时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "page", + "type": "String", + "defaultValue": "", + "description": { + "zh_CN": "当前页的页码值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["currentPage", "total"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "name": { + "zh_CN": "弹出编辑" + }, + "component": "TinyPopeditor", + "icon": "popEditor", + "description": "该组件只能在弹出的面板中选择数据,不能手动输入数据;弹出面板中显示为 Tree 组件或者 Grid 组件", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "PopEditor", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 6, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "modelValue", + "label": { + "text": { + "zh_CN": "绑定值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "双向绑定值" + }, + "labelPosition": "left" + }, + { + "property": "placeholder", + "label": { + "text": { + "zh_CN": "占位文本" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "输入框占位文本" + }, + "labelPosition": "left" + }, + { + "property": "show-clear-btn", + "label": { + "text": { + "zh_CN": "清除按钮" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否显示清除按钮" + }, + "labelPosition": "left" + }, + { + "property": "disabled", + "label": { + "text": { + "zh_CN": "是否禁用" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + } + ] + }, + { + "name": "1", + "label": { + "zh_CN": "其他" + }, + "content": [ + { + "property": "width", + "label": { + "text": { + "zh_CN": "宽度" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": {} + }, + "description": { + "zh_CN": "设置弹出面板的宽度(单位像素)" + }, + "labelPosition": "left" + }, + { + "property": "conditions", + "label": { + "text": { + "zh_CN": "过滤条件" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "当弹出面板配置的是表格时,设置弹出面板中的过滤条件" + }, + "labelPosition": "left" + }, + { + "property": "grid-op", + "label": { + "text": { + "zh_CN": "表格配置" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "设置弹出面板中表格组件的配置信息" + }, + "labelPosition": "left" + }, + { + "property": "pager-op", + "label": { + "text": { + "zh_CN": "分页配置" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "设置弹出编辑框中分页配置" + }, + "labelPosition": "left" + }, + { + "property": "multi", + "label": { + "text": { + "zh_CN": "多选" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "设置弹出面板中的数据是否可多选" + }, + "labelPosition": "left" + }, + { + "property": "show-pager", + "label": { + "text": { + "zh_CN": "启用分页" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "当 popseletor 为 grid 时才能生效,配置为 true 后还需配置 pagerOp 属性" + } + } + ], + "description": { + "zh_CN": "" + } + } + ], + "events": { + "onChange": { + "label": { + "zh_CN": "选中值改变时触发" + }, + "description": { + "zh_CN": "在 Input 值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "当前选中项的值" + } + }, + { + "name": "value", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "当前选中对象" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onUpdate:modelValue": { + "label": { + "zh_CN": "双向绑定的值改变时触发" + }, + "description": { + "zh_CN": "当前选中的值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "双向绑定的当前选中值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onClose": { + "label": { + "zh_CN": "弹框关闭时触发的事件" + }, + "description": { + "zh_CN": "弹框关闭时触发的事件" + }, + "type": "event", + "functionInfo": { + "params": [], + "returns": {} + }, + "defaultValue": "" + }, + "onPageChange": { + "label": { + "zh_CN": "分页切换事件" + }, + "description": { + "zh_CN": "表格模式下分页切换事件" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "String", + "defaultValue": "", + "description": { + "zh_CN": "当前页码数" + } + } + ], + "returns": {} + }, + "defaultValue": "" + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["modelValue", "disabled"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "icon": "tree", + "name": { + "zh_CN": "树" + }, + "component": "TinyTree", + "description": "可进行展示有父子层级的数据,支持选择,异步加载等功能。但不推荐用它来展示菜单,展示菜单推荐使用树菜单", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Tree", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 12, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "show-checkbox", + "label": { + "text": { + "zh_CN": "多选" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "设置接口是否可以多选" + }, + "labelPosition": "left" + }, + { + "property": "data", + "label": { + "text": { + "zh_CN": "数据源" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "defaultValue": [ + { + "label": "一级 1", + "children": [ + { + "label": "二级 1-1" + } + ] + } + ], + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "可配置静态数据源和动态数据源" + } + }, + { + "property": "node-key", + "label": { + "text": { + "zh_CN": "唯一标识" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "节点唯一标识属性名称" + }, + "labelPosition": "left" + }, + { + "property": "icon-trigger-click-node", + "label": { + "text": { + "zh_CN": "触发NodeClick 事件" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "点击图标展开节点时是否触发 node-click 事件" + }, + "labelPosition": "left" + }, + { + "property": "expand-icon", + "label": { + "text": { + "zh_CN": "展开图标" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "节点展开图标" + }, + "labelPosition": "left" + }, + { + "property": "shrink-icon", + "label": { + "text": { + "zh_CN": "收缩图标" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "节点收缩的图标" + }, + "labelPosition": "left" + } + ] + }, + { + "name": "1", + "label": { + "zh_CN": "其他" + }, + "content": [ + { + "property": "check-on-click-node", + "label": { + "text": { + "zh_CN": "点击节点选中" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否在点击节点的时候选中节点,默认值为 false,即只有在点击复选框时才会选中节点" + }, + "labelPosition": "left" + }, + { + "property": "filter-node-method", + "label": { + "text": { + "zh_CN": "筛选函数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "节点筛选函数" + }, + "labelPosition": "left" + } + ], + "description": { + "zh_CN": "" + } + } + ], + "events": { + "onCheck": { + "label": { + "zh_CN": "勾选节点后的事件" + }, + "description": { + "zh_CN": "勾选节点后的事件" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "data", + "type": "object", + "defaultValue": "", + "description": { + "zh_CN": "当前选中节点信息" + } + }, + { + "name": "currentNode", + "type": "object", + "defaultValue": "", + "description": { + "zh_CN": "树组件目前的选中状态信息,包含 checkedNodes、checkedKeys、halfCheckedNodes、halfCheckedKeys 四个属性" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onNodeClick": { + "label": { + "zh_CN": "点击节点后的事件" + }, + "description": { + "zh_CN": "点击节点后的事件" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "data", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "当前选中节点信息" + } + }, + { + "name": "node", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "树组件目前的选中状态信息,包含 checkedNodes、checkedKeys、halfCheckedNodes、halfCheckedKeys 四个属性" + } + }, + { + "name": "vm", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "树组件实例" + } + } + ], + "returns": {} + }, + "defaultValue": "" + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["data", "show-checkbox"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "icon": "timeline", + "name": { + "zh_CN": "时间线" + }, + "component": "TinyTimeLine", + "description": "TimeLine 时间线", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "TimeLine", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 3, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "horizontal", + "type": "Boolean", + "defaultValue": { + "type": "i18n", + "zh_CN": "布局", + "en_US": "layout", + "key": "" + }, + "label": { + "text": { + "zh_CN": "水平布局" + } + }, + "cols": 12, + "rules": [], + "hidden": false, + "required": true, + "readOnly": false, + "disabled": false, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "节点和文字横向布局" + } + }, + { + "property": "vertical", + "type": "Boolean", + "defaultValue": { + "type": "i18n", + "zh_CN": "垂直布局", + "en_US": "layout", + "key": "" + }, + "label": { + "text": { + "zh_CN": "垂直布局" + } + }, + "cols": 12, + "rules": [], + "hidden": false, + "required": true, + "readOnly": false, + "disabled": false, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "节点和文字垂直布局" + } + }, + { + "property": "active", + "label": { + "text": { + "zh_CN": "选中值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": {} + }, + "description": { + "zh_CN": "步骤条的选中步骤值" + }, + "labelPosition": "left" + }, + { + "property": "data", + "label": { + "text": { + "zh_CN": "数据" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "defaultValue": [ + { + "name": "配置基本信息", + "status": "ready" + }, + { + "name": "配置报价", + "status": "wait" + }, + { + "name": "完成报价", + "status": "wait" + } + ], + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": { + "language": "json" + } + }, + "description": { + "zh_CN": "时间线步骤条数据" + }, + "labelPosition": "left" + } + ] + } + ], + "events": { + "onClick": { + "label": { + "zh_CN": "节点的点击时触发" + }, + "description": { + "zh_CN": "节点的点击时触发的回调函数" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "type", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "点击节点的下标" + } + }, + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "当前节点对象:{ name: 节点名称, time: 时间 }" + } + } + ], + "returns": {} + }, + "defaultValue": "" + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": false, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["active", "data"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "icon": "tooltip", + "name": { + "zh_CN": "文字提示框" + }, + "component": "TinyTooltip", + "description": "动态显示提示信息,一般通过鼠标事件进行响应;提供 warning、error、info、success 四种类型显示不同类别的信", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Tooltip", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 11, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 20, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "placement", + "label": { + "text": { + "zh_CN": "提示位置" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "top", + "value": "top" + }, + { + "label": "top-start", + "value": "top-start" + }, + { + "label": "top-end", + "value": "top-end" + }, + { + "label": "bottom", + "value": "bottom" + }, + { + "label": "bottom-start", + "value": "bottom-start" + }, + { + "label": "bottom-end", + "value": "bottom-end" + }, + { + "label": "left", + "value": "left" + }, + { + "label": "left-start", + "value": "left-start" + }, + { + "label": "left-end", + "value": "left-end" + }, + { + "label": "right", + "value": "right" + }, + { + "label": "right-start", + "value": "right-start" + }, + { + "label": "right-end", + "value": "right-end" + } + ] + } + }, + "description": { + "zh_CN": "Tooltip 的出现位置" + }, + "labelPosition": "left" + }, + { + "property": "content", + "label": { + "text": { + "zh_CN": "内容" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "defaultValue": "提示信息", + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "显示的内容,也可以通过 slot#content 传入 DOM" + } + }, + { + "property": "modelValue", + "label": { + "text": { + "zh_CN": "是否可见" + } + }, + "defaultValue": true, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "状态是否可见" + } + }, + { + "property": "manual", + "label": { + "text": { + "zh_CN": "手动控制" + } + }, + "defaultValue": true, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "手动控制模式,设置为 true 后,mouseenter 和 mouseleave 事件将不会生效" + } + } + ] + } + ], + "events": {}, + "slots": { + "content": { + "label": { + "zh_CN": "提示内容" + }, + "description": { + "zh_CN": "自定义提示内容" + } + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": true, + "isModal": false, + "isPopper": true, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["disabled", "content"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "icon": "popover", + "name": { + "zh_CN": "提示框" + }, + "component": "TinyPopover", + "description": "Popover可通过对一个触发源操作触发弹出框,支持自定义弹出内容,延迟触发和渐变动画", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Popover", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 7, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "modelValue", + "label": { + "text": { + "zh_CN": "绑定值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "双向绑定,手动控制是否可见的状态值" + }, + "labelPosition": "left" + }, + { + "property": "placement", + "label": { + "text": { + "zh_CN": "位置" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "top", + "value": "top" + }, + { + "label": "top-start", + "value": "top-start" + }, + { + "label": "top-end", + "value": "top-end" + }, + { + "label": "bottom", + "value": "bottom" + }, + { + "label": "bottom-start", + "value": "bottom-start" + }, + { + "label": "bottom-end", + "value": "bottom-end" + }, + { + "label": "left", + "value": "left" + }, + { + "label": "left-start", + "value": "left-start" + }, + { + "label": "left-end", + "value": "left-end" + }, + { + "label": "right", + "value": "right" + }, + { + "label": "right-start", + "value": "right-start" + }, + { + "label": "right-end", + "value": "right-end" + } + ] + } + }, + "description": { + "zh_CN": "" + }, + "labelPosition": "left" + }, + { + "property": "trigger", + "label": { + "text": { + "zh_CN": "触发方式" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "click", + "value": "click" + }, + { + "label": "focus", + "value": "focus" + }, + { + "label": "hover", + "value": "hover" + }, + { + "label": "manual", + "value": "manual" + } + ] + } + }, + "description": { + "zh_CN": "触发方式,该属性的可选值为 click / focus / hover / manual,该属性的默认值为 click" + } + }, + { + "property": "popper-class", + "label": { + "text": { + "zh_CN": "自定义类" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "为 popper 添加类名" + }, + "labelPosition": "left" + }, + { + "property": "visible-arrow", + "label": { + "text": { + "zh_CN": "显示箭头" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否显示 Tooltip 箭头" + } + }, + { + "property": "append-to-body", + "label": { + "text": { + "zh_CN": "添加到body上" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "Popover弹窗是否添加到body上" + } + }, + { + "property": "arrow-offset", + "label": { + "text": { + "zh_CN": "箭头的位置偏移" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": {} + }, + "description": { + "zh_CN": "箭头的位置偏移,该属性的默认值为 0" + } + }, + { + "property": "close-delay", + "label": { + "text": { + "zh_CN": "隐藏延迟" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": {} + }, + "description": { + "zh_CN": "触发方式为 hover 时的隐藏延迟,单位为毫秒" + } + }, + { + "property": "content", + "label": { + "text": { + "zh_CN": "显示的内容" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "显示的内容,也可以通过 slot 传入 DOM" + } + }, + { + "property": "disabled", + "label": { + "text": { + "zh_CN": "禁用" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "Popover 是否可用" + } + }, + { + "property": "offset", + "label": { + "text": { + "zh_CN": "位置偏移量" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": {} + }, + "description": { + "zh_CN": "出现位置的偏移量" + } + }, + { + "property": "open-delay", + "label": { + "text": { + "zh_CN": "显示延迟" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": {} + }, + "description": { + "zh_CN": "触发方式为 hover 时的显示延迟,单位为毫秒" + } + }, + { + "property": "popper-options", + "label": { + "text": { + "zh_CN": "popper.js的参数" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaCodeEditor", + "props": {} + }, + "description": { + "zh_CN": "popper.js 的参数" + } + }, + { + "property": "title", + "label": { + "text": { + "zh_CN": "标题" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "标题" + } + }, + { + "property": "transform-origin", + "label": { + "text": { + "zh_CN": "旋转中心点" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "组件的旋转中心点,组件的旋转中心点" + } + }, + { + "property": "transition", + "label": { + "text": { + "zh_CN": "定义渐变动画" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaInput", + "props": {} + }, + "description": { + "zh_CN": "该属性的默认值为 fade-in-linear" + } + }, + { + "property": "width", + "label": { + "text": { + "zh_CN": "宽度" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": {} + }, + "description": { + "zh_CN": "宽度" + } + } + ] + } + ], + "events": { + "onUpdate:modelValue": { + "label": { + "zh_CN": "双向绑定的值改变时触发" + }, + "description": { + "zh_CN": "手动控制是否可见的状态值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "boolean", + "defaultValue": "", + "description": { + "zh_CN": "双向绑定的可见状态值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": true, + "isModal": false, + "isPopper": true, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["visible", "width"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "name": { + "zh_CN": "日期选择" + }, + "component": "TinyDatePicker", + "icon": "datepick", + "description": "用于输入或选择日期", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "DatePicker", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 1, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "modelValue", + "label": { + "text": { + "zh_CN": "绑定值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaBindI18n", + "props": {} + }, + "description": { + "zh_CN": "双向绑定值" + }, + "labelPosition": "left" + }, + { + "property": "type", + "label": { + "text": { + "zh_CN": "类型" + } + }, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "日期", + "value": "date" + }, + { + "label": "日期时间", + "value": "datetime" + }, + { + "label": "周", + "value": "week" + }, + { + "label": "月份", + "value": "month" + }, + { + "label": "年份", + "value": "year" + } + ] + } + }, + "description": { + "zh_CN": "设置日期框的type属性" + } + }, + { + "property": "placeholder", + "label": { + "text": { + "zh_CN": "占位文本" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaBindI18n", + "props": {} + }, + "description": { + "zh_CN": "输入框占位文本" + }, + "labelPosition": "left" + }, + { + "property": "clearable", + "label": { + "text": { + "zh_CN": "清除按钮" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否显示清除按钮" + }, + "labelPosition": "left" + }, + { + "property": "disabled", + "label": { + "text": { + "zh_CN": "禁用" + } + }, + "required": false, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "禁用" + } + }, + { + "property": "readonly", + "label": { + "text": { + "zh_CN": "是否只读" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "size", + "label": { + "text": { + "zh_CN": "尺寸" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "medium", + "value": "medium" + }, + { + "label": "small", + "value": "small" + }, + { + "label": "mini", + "value": "mini" + } + ] + } + }, + "description": { + "zh_CN": "日期框尺寸。该属性的可选值为 medium / small / mini" + } + } + ] + }, + { + "name": "1", + "label": { + "zh_CN": "其他" + }, + "content": [ + { + "property": "maxlength", + "label": { + "text": { + "zh_CN": "最大长度" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": {} + }, + "description": { + "zh_CN": "设置 input 框的maxLength" + }, + "labelPosition": "left" + }, + { + "property": "autofocus", + "label": { + "text": { + "zh_CN": "聚焦" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "自动获取焦点" + }, + "labelPosition": "left" + } + ], + "description": { + "zh_CN": "" + } + } + ], + "events": { + "onChange": { + "label": { + "zh_CN": "值改变时触发" + }, + "description": { + "zh_CN": "在 Input 值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "输入框改变后的值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onInput": { + "label": { + "zh_CN": "输入值改变时触发" + }, + "description": { + "zh_CN": "在 Input 输入值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "输入框输入的值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onUpdate:modelValue": { + "label": { + "zh_CN": "双向绑定的值改变时触发" + }, + "description": { + "zh_CN": "在 Input 输入值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "双向绑定的值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onBlur": { + "label": { + "zh_CN": "失去焦点时触发" + }, + "description": { + "zh_CN": "在 Input 失去焦点时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "event", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "原生 event" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onFocus": { + "label": { + "zh_CN": "获取焦点时触发" + }, + "description": { + "zh_CN": "在 Input 获取焦点时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "event", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "原生 event" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onClear": { + "label": { + "zh_CN": "点击清空按钮时触发" + }, + "description": { + "zh_CN": "点击清空按钮时触发" + }, + "type": "event", + "functionInfo": { + "params": [], + "returns": {} + }, + "defaultValue": "" + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": true, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["value", "disabled"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + }, + { + "name": { + "zh_CN": "数字输入框" + }, + "component": "TinyNumeric", + "icon": "numeric", + "description": "通过鼠标或键盘输入字符", + "docUrl": "", + "screenshot": "", + "tags": "", + "keywords": "", + "devMode": "proCode", + "npm": { + "package": "@opentiny/vue", + "exportName": "Numeric", + "version": "", + "destructuring": true + }, + "group": "component", + "priority": 1, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "modelValue", + "label": { + "text": { + "zh_CN": "绑定值" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "widget": { + "component": "MetaBindI18n", + "props": {} + }, + "description": { + "zh_CN": "双向绑定值" + }, + "labelPosition": "left" + }, + { + "property": "placeholder", + "label": { + "text": { + "zh_CN": "占位文本" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaBindI18n", + "props": {} + }, + "description": { + "zh_CN": "输入框占位文本" + }, + "labelPosition": "left" + }, + { + "property": "allow-empty", + "label": { + "text": { + "zh_CN": "内容可清空" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "是否内容可清空" + }, + "labelPosition": "left" + }, + { + "property": "disabled", + "label": { + "text": { + "zh_CN": "禁用" + } + }, + "required": false, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "禁用" + } + }, + { + "property": "size", + "label": { + "text": { + "zh_CN": "尺寸" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "medium", + "value": "medium" + }, + { + "label": "small", + "value": "small" + }, + { + "label": "mini", + "value": "mini" + } + ] + } + }, + "description": { + "zh_CN": "输入框尺寸。该属性的可选值为 medium / small / mini" + } + }, + { + "property": "controls", + "label": { + "text": { + "zh_CN": "是否使用加减按钮" + } + }, + "required": false, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSwitch", + "props": {} + }, + "description": { + "zh_CN": "" + } + }, + { + "property": "controls-position", + "label": { + "text": { + "zh_CN": "加减按钮位置" + } + }, + "required": true, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaSelect", + "props": { + "options": [ + { + "label": "左右两侧", + "value": "" + }, + { + "label": "只在右侧", + "value": "right" + } + ] + } + }, + "description": { + "zh_CN": "加减按钮位置" + }, + "labelPosition": "left" + }, + { + "property": "precision", + "label": { + "text": { + "zh_CN": "数值精度" + } + }, + "required": false, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": { + "allowEmpty": true + } + }, + "description": { + "zh_CN": "数值精度" + }, + "labelPosition": "left" + }, + { + "property": "step", + "label": { + "text": { + "zh_CN": "步长" + } + }, + "required": false, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": { + "allowEmpty": true + } + }, + "description": { + "zh_CN": "步长" + }, + "labelPosition": "left" + }, + { + "property": "max", + "label": { + "text": { + "zh_CN": "可输入的最大数值" + } + }, + "required": false, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": { + "allowEmpty": true + } + }, + "description": { + "zh_CN": "可输入的最大数值" + }, + "labelPosition": "left" + }, + { + "property": "min", + "label": { + "text": { + "zh_CN": "可输入的最小数值" + } + }, + "required": false, + "readOnly": false, + "disabled": false, + "cols": 12, + "widget": { + "component": "MetaNumber", + "props": { + "allowEmpty": true + } + }, + "description": { + "zh_CN": "可输入的最大数值" + }, + "labelPosition": "left" + } + ] + } + ], + "events": { + "onChange": { + "label": { + "zh_CN": "值改变时触发" + }, + "description": { + "zh_CN": "在 Input 值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "输入框改变后的值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onInput": { + "label": { + "zh_CN": "输入值改变时触发" + }, + "description": { + "zh_CN": "在 Input 输入值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "输入框输入的值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onUpdate:modelValue": { + "label": { + "zh_CN": "双向绑定的值改变时触发" + }, + "description": { + "zh_CN": "在 Input 输入值改变时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "value", + "type": "string", + "defaultValue": "", + "description": { + "zh_CN": "双向绑定的值" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onBlur": { + "label": { + "zh_CN": "失去焦点时触发" + }, + "description": { + "zh_CN": "在 Input 失去焦点时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "event", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "原生 event" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onFocus": { + "label": { + "zh_CN": "获取焦点时触发" + }, + "description": { + "zh_CN": "在 Input 获取焦点时触发" + }, + "type": "event", + "functionInfo": { + "params": [ + { + "name": "event", + "type": "Object", + "defaultValue": "", + "description": { + "zh_CN": "原生 event" + } + } + ], + "returns": {} + }, + "defaultValue": "" + }, + "onClear": { + "label": { + "zh_CN": "点击清空按钮时触发" + }, + "description": { + "zh_CN": "点击清空按钮时触发" + }, + "type": "event", + "functionInfo": { + "params": [], + "returns": {} + }, + "defaultValue": "" + } + } + }, + "configure": { + "loop": true, + "condition": true, + "styles": true, + "isContainer": true, + "isModal": false, + "nestingRule": { + "childWhitelist": "", + "parentWhitelist": "", + "descendantBlacklist": "", + "ancestorWhitelist": "" + }, + "isNullNode": false, + "isLayout": false, + "rootSelector": "", + "shortcuts": { + "properties": ["value", "disabled"] + }, + "contextMenu": { + "actions": ["create symbol"], + "disable": ["copy", "remove"] + } + } + } + ] + }, + "app": { + "id": 918, + "name": "portal-app", + "app_website": null, + "platform": { + "id": 897, + "name": "portal-platform" + }, + "obs_url": "", + "created_by": null, + "updated_by": null, + "created_at": "2022-06-08T07:19:01.000Z", + "updated_at": "2023-09-04T08:55:40.000Z", + "state": null, + "published": false, + "createdBy": 86, + "updatedBy": 564, + "tenant": 1, + "home_page": "NTJ4MjvqoVj8OVsc", + "css": null, + "config": {}, + "git_group": "", + "project_name": "", + "constants": null, + "data_handler": { + "type": "JSFunction", + "value": "function dataHanlder(res){\n return res;\n}" + }, + "description": "demo应用", + "latest": 22, + "platform_history": null, + "editor_url": "", + "branch": "develop", + "visit_url": null, + "is_demo": null, + "image_url": "", + "is_default": true, + "template_type": null, + "set_template_time": null, + "set_template_by": null, + "set_default_by": 169, + "framework": "Vue", + "global_state": [], + "default_lang": null, + "extend_config": { + "business": { + "serviceName": "", + "endpointName": "cce", + "endpointId": "ee", + "serviceId": "ee", + "router": "ee" + }, + "env": { + "alpha": { + "regions": [ + { + "name": "", + "baseUrl": "", + "isDefault": false + } + ], + "isDefault": true + } + }, + "type": "console" + }, + "assets_url": "", + "data_hash": "ae128e37f6bc378f1b9c21d75bd05551", + "can_associate": true, + "data_source_global": { + "dataHandler": { + "type": "JSFunction", + "value": "function dataHanlder(res){\n return res;\n}" + } + } + } +} diff --git a/mockServer/src/services/block.js b/mockServer/src/services/block.js new file mode 100644 index 000000000..c8071fe10 --- /dev/null +++ b/mockServer/src/services/block.js @@ -0,0 +1,93 @@ +/** + * Copyright (c) 2023 - present TinyEngine Authors. + * Copyright (c) 2023 - present Huawei Cloud Computing Technologies Co., Ltd. + * + * Use of this source code is governed by an MIT-style license. + * + * THE OPEN SOURCE SOFTWARE IN THIS PRODUCT IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, + * BUT WITHOUT ANY WARRANTY, WITHOUT EVEN THE IMPLIED WARRANTY OF MERCHANTABILITY OR FITNESS FOR + * A PARTICULAR PURPOSE. SEE THE APPLICABLE LICENSES FOR MORE DETAILS. + * + */ +import path from 'path' +import DateStore from '@seald-io/nedb' +import { getResponseData } from '../tool/Common' +export default class BlockService { + constructor() { + this.db = new DateStore({ + filename: path.resolve(__dirname, '../database/blocks.db'), + autoload: true + }) + + this.db.ensureIndex({ + fieldName: 'label', + unique: true + }) + + this.userInfo = { + id: 86, + username: '开发者', + email: 'developer@lowcode.com', + resetPasswordToken: 'developer', + confirmationToken: 'dfb2c162-351f-4f44-ad5f-8998', + is_admin: true + } + + this.blockModel = { + id: '', + label: '', + name_cn: '', + framework: [], + content: {}, + description: '', + path: '', + screenshot: '', + created_app: '', + tags: '', + categories: [], + occupier: { + id: 86, + username: '开发者', + resetPasswordToken: 'developer' + }, + isDefault: null, + isOfficial: null + } + } + + async create(params) { + const blockData = { ...this.blockModel, ...params } + const result = await this.db.insertAsync(blockData) + const { _id } = result + await this.db.updateAsync({ _id }, { $set: { id: _id } }) + result.id = result._id + return result + } + + async update(id, params) { + await this.db.updateAsync({ _id: id }, { $set: params }) + const result = await this.db.findOneAsync({ _id: id }) + return getResponseData(result) + } + + async detail(blockId) { + const result = await this.db.findOneAsync({ _id: blockId }) + return result + } + + async delete(blockId) { + const result = await this.db.findOneAsync({ _id: blockId }) + await this.db.removeAsync({ _id: blockId }) + return getResponseData(result) + } + + async list(appId) { + const result = await this.db.findAsync() + return getResponseData(result) + } + + async find(params) { + const result = await this.db.findAsync(params) + return result + } +} diff --git a/mockServer/src/services/blockCategory.js b/mockServer/src/services/blockCategory.js new file mode 100644 index 000000000..401b963dd --- /dev/null +++ b/mockServer/src/services/blockCategory.js @@ -0,0 +1,76 @@ +/** + * Copyright (c) 2023 - present TinyEngine Authors. + * Copyright (c) 2023 - present Huawei Cloud Computing Technologies Co., Ltd. + * + * Use of this source code is governed by an MIT-style license. + * + * THE OPEN SOURCE SOFTWARE IN THIS PRODUCT IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, + * BUT WITHOUT ANY WARRANTY, WITHOUT EVEN THE IMPLIED WARRANTY OF MERCHANTABILITY OR FITNESS FOR + * A PARTICULAR PURPOSE. SEE THE APPLICABLE LICENSES FOR MORE DETAILS. + * + */ +import path from 'path' +import DateStore from '@seald-io/nedb' +import { getResponseData } from '../tool/Common' +import appinfo from './appinfo.json' +export default class BlockCategoryService { + constructor() { + this.db = new DateStore({ + filename: path.resolve(__dirname, '../database/blockCategories.db'), + autoload: true + }) + + this.db.ensureIndex({ + fieldName: 'name', + unique: true + }) + + this.blockCategoriesModel = { + id: '', + app: '', + name: '', + desc: '', + blocks: [] + } + } + + async create(params) { + const blockCategoriesData = { ...this.blockCategoriesModel, ...params } + blockCategoriesData.app = appinfo.app + const result = await this.db.insertAsync(blockCategoriesData) + const { _id } = result + await this.db.updateAsync({ _id }, { $set: { id: _id } }) + result.id = result._id + return getResponseData(result) + } + + async update(id, params) { + if (params?._id) { + const categories = await this.db.findOneAsync({ _id: id }) + categories.blocks.push(params._id) + await this.db.updateAsync({ _id: id }, { $set: categories }) + return getResponseData(categories) + } + params.app = appinfo.app + await this.db.updateAsync({ _id: id }, { $set: params }) + + const result = await this.db.findOneAsync({ _id: id }) + return getResponseData(result) + } + + async find(params) { + const result = await this.db.findAsync() + return getResponseData(result) + } + + async delete(id) { + const result = await this.db.findOneAsync({ _id: id }) + await this.db.removeAsync({ _id: id }) + return getResponseData(result) + } + + async list(appId) { + const result = await this.db.findAsync() + return getResponseData(result) + } +} diff --git a/mockServer/src/services/blockGroup.js b/mockServer/src/services/blockGroup.js new file mode 100644 index 000000000..01cd868f6 --- /dev/null +++ b/mockServer/src/services/blockGroup.js @@ -0,0 +1,75 @@ +/** + * Copyright (c) 2023 - present TinyEngine Authors. + * Copyright (c) 2023 - present Huawei Cloud Computing Technologies Co., Ltd. + * + * Use of this source code is governed by an MIT-style license. + * + * THE OPEN SOURCE SOFTWARE IN THIS PRODUCT IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, + * BUT WITHOUT ANY WARRANTY, WITHOUT EVEN THE IMPLIED WARRANTY OF MERCHANTABILITY OR FITNESS FOR + * A PARTICULAR PURPOSE. SEE THE APPLICABLE LICENSES FOR MORE DETAILS. + * + */ +import path from 'path' +import DateStore from '@seald-io/nedb' +import { getResponseData } from '../tool/Common' +import appinfo from './appinfo.json' +export default class BlockGroupService { + constructor() { + this.db = new DateStore({ + filename: path.resolve(__dirname, '../database/blockGroups.db'), + autoload: true + }) + + this.db.ensureIndex({ + fieldName: 'name', + unique: true + }) + + this.blockGroupModel = { + id: '', + app: '', + name: '', + desc: '', + blocks: [] + } + } + + async create(params) { + const blockGroupData = { ...this.blockGroupModel, ...params } + blockGroupData.app = appinfo.app + const result = await this.db.insertAsync(blockGroupData) + const { _id } = result + await this.db.updateAsync({ _id }, { $set: { id: _id } }) + result.id = result._id + return getResponseData(result) + } + + async update(id, params) { + params.app = appinfo.app + await this.db.updateAsync({ _id: id }, { $set: params }) + + const result = await this.db.findOneAsync({ _id: id }) + return getResponseData(result) + } + + async find(params) { + if (params?.app || !params?.id) { + const result = await this.db.findAsync() + return getResponseData(result) + } + const { id } = params + const blockGroup = await this.db.findOneAsync({ _id: id }) + return getResponseData([blockGroup]) + } + + async delete(blockGroupId) { + const result = await this.db.findOneAsync({ _id: blockGroupId }) + await this.db.removeAsync({ _id: blockGroupId }) + return getResponseData(result) + } + + async list(appId) { + const result = await this.db.findAsync() + return getResponseData(result) + } +} diff --git a/mockServer/src/services/blocks.json b/mockServer/src/services/blocks.json new file mode 100644 index 000000000..df91f08fc --- /dev/null +++ b/mockServer/src/services/blocks.json @@ -0,0 +1,436 @@ +{ + "PortalHome": { + "id": 989, + "label": "PortalHome", + "framework": "Vue", + "content": { + "state": { + "logoUrl": "", + "loginImgUrl": "" + }, + "componentName": "Block", + "css": ".home-content {\r\n display: flex;\r\n flex-direction: column;\r\n justify-content: center;\r\n align-items: center;\r\n text-align: center;\r\n height: calc(100vh - 262px);\r\n \r\n}\r\n.home-content .btn {\r\n margin-top: 24px;\r\n \r\n }\r\n .home-content .btn button {\r\n border: none;\r\n border-radius: 30px;\r\n background: #5e7ce0;\r\n \r\n font-size: 14px;\r\n color: #fff;\r\n \r\n cursor: pointer;\r\n }\r\n\r\n .home-content .text {\r\n font-size: 18px;\r\n }\r\n\r\n .home-content .account {\r\n margin-top: 16px;\r\n \r\n \r\n }\r\n\r\n .home-content .account .sub-text {\r\n color: #575d6c;\r\n }\r\n .home-content .account .login {\r\n color: #1890ff;\r\n cursor: pointer;\r\n }\r\n .home-content .logo img{\r\n border-radius: 50%;\r\n overflow: hidden;\r\n }", + "props": {}, + "children": [ + { + "componentName": "div", + "props": { + "className": "home", + "style": "height: 100vh; display: flex;" + }, + "id": "357534ab", + "children": [ + { + "componentName": "TinyRow", + "props": { + "align": "middle", + "flex": true, + "style": "" + }, + "children": [ + { + "componentName": "TinyCol", + "props": { + "span": 6, + "style": "text-align: center; display: flex; justify-content: center;" + }, + "id": "f01b66ea", + "children": [ + { + "componentName": "div", + "props": { + "style": "width: 90%; height: 50%;" + }, + "id": "8197d016", + "children": [ + { + "componentName": "Img", + "props": { + "style": "width: 100%; height: 100%;", + "src": { + "type": "JSExpression", + "value": "this.state.loginImgUrl" + } + }, + "id": "471e30f3" + } + ] + } + ] + }, + { + "componentName": "TinyCol", + "props": { + "span": "6", + "style": "text-align: center;" + }, + "id": "781d5b46", + "children": [ + { + "componentName": "div", + "props": { + "className": "home-content", + "style": "font-size: 14px;" + }, + "id": "08638b8a", + "children": [ + { + "componentName": "div", + "props": { + "className": "text" + }, + "id": "18712ee2", + "children": [ + { + "componentName": "div", + "props": { + "style": "font-size: 16px;" + }, + "id": "07e6794c", + "children": [ + { + "componentName": "div", + "props": { + "className": "logo" + }, + "id": "07cad264", + "children": [ + { + "componentName": "Img", + "props": { + "style": "width: 105px; height: 105px; border-radius: 100px;", + "src": { + "type": "JSExpression", + "value": "this.state.logoUrl" + } + }, + "id": "f4489e27" + } + ] + }, + { + "componentName": "Text", + "props": { + "text": "TinyLowCode 低代码平台", + "style": "display: block; font-size: 28px; margin-top: 12px; margin-bottom: 12px; font-weight: bold;", + "ref": "", + "className": "title" + }, + "id": "e82108ce" + }, + { + "componentName": "Text", + "props": { + "text": "致力于通过友好的用户交互提升业务的开发效率", + "style": "display: block; margin-bottom: 12px;" + }, + "id": "65a2f1ad" + }, + { + "componentName": "Text", + "props": { + "text": "欢迎一起来解锁~~", + "style": "margin-top: 12px;" + }, + "id": "bb879abb" + } + ] + }, + { + "componentName": "div", + "props": { + "className": "btn" + }, + "id": "44b2bcbd", + "children": [ + { + "componentName": "TinyButton", + "props": { + "text": "立即体验", + "round": true, + "type": "primary", + "style": "margin-top: 40px;" + }, + "id": "9580c5e7" + }, + { + "componentName": "div", + "props": { + "className": "account" + }, + "id": "6a8ffa3e", + "children": [ + { + "componentName": "div", + "props": { + "style": "font-size: 14px; margin-top: 4px;" + }, + "id": "bfc6eb6c", + "children": [ + { + "componentName": "Text", + "props": { + "text": "已有团队?", + "style": "color: #777777;" + }, + "id": "3d993264" + }, + { + "componentName": "Text", + "props": { + "text": "立即进入", + "style": "color: #5e7ce0;", + "onClick": { + "type": "JSExpression", + "value": "this.handleClick(event)" + } + }, + "id": "21390118" + } + ] + } + ] + } + ] + } + ] + } + ] + } + ] + } + ], + "id": "4545fea2" + } + ] + } + ], + "methods": { + "handleClick": { + "type": "JSFunction", + "value": "function (event) {this.emit('goto-home', event)\n}" + } + }, + "fileName": "PortalHome", + "meta": { + "id": 1722, + "parentId": "0", + "group": "staticPages", + "title": null, + "occupier": null, + "isHome": false, + "description": "", + "router": "/", + "rootElement": "div", + "creator": "开发者", + "gmt_create": "2022-06-08 03:25:51", + "gmt_modified": "2022-06-09 05:19:09" + }, + "id": 1722, + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [] + } + ], + "events": { + "onGotoHome": { + "label": { + "zh_CN": "点击立即进入触发方法" + }, + "description": { + "zh_CN": "点击立即进入触发方法" + }, + "type": "event", + "functionInfo": { + "params": [], + "returns": {} + }, + "defaultValue": "", + "linked": { + "id": "21390118", + "componentName": "Text", + "event": "onClick" + } + } + }, + "slots": {} + }, + "dataSource": {}, + "i18n": {} + }, + "created_at": "2022-06-13T07:56:51.000Z", + "updated_at": "2023-01-13T08:12:51.000Z", + "assets": { + "material": [], + "scripts": [ + "http://localhost:9090/assets/js/989web-components.es.js", + "http://localhost:9090/assets/js/989web-components.umd.js" + ], + "styles": [] + }, + "createdBy": 86, + "description": null, + "tags": "", + "current_history": 1655, + "screenshot": "", + "path": "common/components/home", + "occupier": null, + "isOfficial": true, + "public": 1, + "isDefault": null, + "tiny_reserved": false, + "author": null, + "name_cn": null, + "created_app": null, + "content_blocks": null, + "current_version": "x" + }, + "portalBlock": { + "id": 1005, + "label": "PortalBlock", + "framework": "Vue", + "content": { + "state": {}, + "methods": {}, + "componentName": "Block", + "fileName": "PortalBlock", + "css": "", + "props": {}, + "children": [ + { + "componentName": "div", + "props": { + "style": "font-size: 18px; height: 40px; border-bottom: 1px solid rgb(223, 225, 230); margin-top: 20px;" + }, + "id": "d38cea57", + "children": [ + { + "componentName": "Icon", + "props": { + "name": "IconChevronLeft" + }, + "id": "86c6e6b0" + }, + { + "componentName": "Text", + "props": { + "text": "编辑物料资产包 | ", + "style": "margin-left: 10px; font-weight: bold;" + }, + "id": "38d9fbc8" + }, + { + "componentName": "Text", + "props": { + "text": { + "type": "JSExpression", + "value": "this.props.blockName" + }, + "style": "margin-left: 10px; font-weight: bold;" + }, + "id": "6cd76396" + } + ] + } + ], + "schema": { + "properties": [ + { + "label": { + "zh_CN": "基础信息" + }, + "description": { + "zh_CN": "基础信息" + }, + "collapse": { + "number": 6, + "text": { + "zh_CN": "显示更多" + } + }, + "content": [ + { + "property": "blockName", + "type": "String", + "defaultValue": "MT0526-React 1.0", + "label": { + "text": { + "zh_CN": "区块名称" + } + }, + "cols": 12, + "rules": [], + "handle": { + "getter": "", + "setter": "" + }, + "hidden": false, + "required": true, + "readOnly": false, + "disabled": false, + "widget": { + "component": "MetaInput", + "props": { + "modelValue": "MT0526-React 1.0" + } + } + } + ] + } + ], + "events": {}, + "slots": {} + }, + "dataSource": {} + }, + "created_at": "2022-06-28T08:59:54.000Z", + "updated_at": "2023-01-13T08:20:09.000Z", + "assets": { + "material": [], + "scripts": [ + "http://localhost:9090/assets/js/1005web-components.es.js", + "http://localhost:9090/assets/js/1005web-components.umd.js" + ], + "styles": [] + }, + "createdBy": { + "id": 86, + "username": "开发者", + "resetPasswordToken": "developer" + }, + "description": null, + "tags": null, + "current_history": 1665, + "screenshot": "", + "path": "portal", + "occupier": { + "id": 86, + "username": "开发者", + "resetPasswordToken": "developer" + }, + "isOfficial": null, + "public": 1, + "isDefault": null, + "tiny_reserved": false, + "author": null, + "name_cn": null, + "created_app": null, + "content_blocks": null, + "categories": [], + "public_scope_tenants": [], + "histories_length": 1 + } +} \ No newline at end of file diff --git a/mockServer/src/services/mockService.js b/mockServer/src/services/mockService.js new file mode 100644 index 000000000..5f05fd389 --- /dev/null +++ b/mockServer/src/services/mockService.js @@ -0,0 +1,37 @@ +/** + * Copyright (c) 2023 - present TinyEngine Authors. + * Copyright (c) 2023 - present Huawei Cloud Computing Technologies Co., Ltd. + * + * Use of this source code is governed by an MIT-style license. + * + * THE OPEN SOURCE SOFTWARE IN THIS PRODUCT IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, + * BUT WITHOUT ANY WARRANTY, WITHOUT EVEN THE IMPLIED WARRANTY OF MERCHANTABILITY OR FITNESS FOR + * A PARTICULAR PURPOSE. SEE THE APPLICABLE LICENSES FOR MORE DETAILS. + * + */ +import PageService from './pages' +import AppService from './app' +import BlockService from './block' +import SourceService from './source' +import BlockGroupService from './blockGroup' +import BlockCategoryService from './blockCategory' +import Schema2CodeServcice from './schema2code' +export default class MockService { + schema2codeService + pageService + appService + blockService + sourceService + blockGroupService + blockCategoryService + + constructor() { + this.schema2codeService = new Schema2CodeServcice() + this.pageService = new PageService() + this.appService = new AppService() + this.blockService = new BlockService() + this.sourceService = new SourceService() + this.blockGroupService = new BlockGroupService() + this.blockCategoryService = new BlockCategoryService() + } +} diff --git a/mockServer/src/services/pageSchema.js b/mockServer/src/services/pageSchema.js new file mode 100644 index 000000000..2b78b9be7 --- /dev/null +++ b/mockServer/src/services/pageSchema.js @@ -0,0 +1,178 @@ +/** +* Copyright (c) 2023 - present TinyEngine Authors. +* Copyright (c) 2023 - present Huawei Cloud Computing Technologies Co., Ltd. +* +* Use of this source code is governed by an MIT-style license. +* +* THE OPEN SOURCE SOFTWARE IN THIS PRODUCT IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, +* BUT WITHOUT ANY WARRANTY, WITHOUT EVEN THE IMPLIED WARRANTY OF MERCHANTABILITY OR FITNESS FOR +* A PARTICULAR PURPOSE. SEE THE APPLICABLE LICENSES FOR MORE DETAILS. +* +*/ + +import { E_SchemaFormatFunc } from './utils' +import { getResponseData } from '../tool/Common' + +const config = { + pageMeta: { + convert: { + page_desc: 'description', + route: 'router', + isBody: 'rootElement', + createdBy: 'creator', + created_at: 'gmt_create', + updated_at: 'gmt_modified' + }, + include: [ + 'id', + 'title', + 'page_desc', + 'createdBy', + 'parentId', + 'created_at', + 'updated_at', + 'isHome', + 'isBody', + 'group', + 'route', + 'occupier' + ], + format: { + created_at: E_SchemaFormatFunc.ToLocalTimestamp, + updated_at: E_SchemaFormatFunc.ToLocalTimestamp, + isBody: E_SchemaFormatFunc.ToRootElement, + group: E_SchemaFormatFunc.ToGroupName, + createdBy: E_SchemaFormatFunc.ToCreatorName + } + }, + pageContent: { + include: ['fileName', 'componentName', 'props', 'css', 'children', 'methods', 'state', 'lifeCycles'] + }, + folder: { + convert: { + name: 'folderName', + route: 'router', + created_at: 'gmt_create', + updated_at: 'gmt_modified' + }, + include: ['name', 'route', 'created_at', 'updated_at', 'id', 'parentId', 'depth'], + format: { + created_at: E_SchemaFormatFunc.ToLocalTimestamp, + updated_at: E_SchemaFormatFunc.ToLocalTimestamp + } + } +} + +export default class PageSchemaService { + constructor() { + this.config = config + } + + + assembleFields(originalData, type) { + let dataCopy = JSON.parse(JSON.stringify(originalData.data)) + const conf = this.config[type] + if (conf.include || conf.exclude) { + dataCopy = this.filterFields(dataCopy, conf) + } + if (conf.format) { + dataCopy = this.formatFields(dataCopy, conf) + } + if (conf.convert) { + dataCopy = this.convertFields(dataCopy, conf) + } + return getResponseData(dataCopy) + } + + // 转换数据表字段为schema中的字段命名 + convertFields(data, conf) { + const convertConf = conf.convert || {} + Object.keys(convertConf).forEach((key) => { + data[convertConf[key]] = data[key] + delete data[key] + }) + return data + } + + // 筛选数据 + filterFields(data, conf) { + const excludeConf = conf.exclude || [] + const includeConf = conf.include || [] + let res = {} + // include 优先级高于 exclude + if (includeConf.length) { + for (const key in data) { + if (includeConf.includes(key)) { + res[key] = data[key] + } + } + } else if (excludeConf.length) { + for (const key in data) { + if (!excludeConf.includes(key)) { + res[key] = data[key] + } + } + } else { + res = data + } + + return res + } + + // 格式化数据 + formatFields(data, conf) { + const { format = {} } = conf + Object.keys(format).forEach((key) => { + const funcName = format[key] + const func = this[funcName] + if (func) { + data[key] = func(data[key]) + } + }) + return data + } + + // 获取页面元数据 + getSchemaMeta(pageData) { + return this.assembleFields(pageData, 'pageMeta') + } + + // 提取page_schema + getSchemaBase(pageData) { + const pageMate = JSON.parse(JSON.stringify(pageData.data)) + const pageContent = pageMate.page_content || {} + pageContent.fileName = pageMate.name + return this.assembleFields( + { + data: pageContent + }, + 'pageContent' + ) + } + + // 获取folder schema数据 todo + getFolderSchema(param) { + const schema = this.assembleFields( + { + data: param + }, + 'folder' + ) + schema.data.componentName = 'Folder' + return schema + } + + // 获取页面的schema + getSchema(pageInfo) { + const pageInfoData = { + data: pageInfo + } + if (!pageInfo.isPage) { + return this.getFolderSchema(pageInfo) + } + const schema = this.getSchemaBase(pageInfoData).data + // 从page_schema中获取基本字段 + schema.meta = this.getSchemaMeta(pageInfoData).data + return getResponseData(schema) + } +} diff --git a/mockServer/src/services/pages.js b/mockServer/src/services/pages.js new file mode 100644 index 000000000..07b743e2e --- /dev/null +++ b/mockServer/src/services/pages.js @@ -0,0 +1,102 @@ +/** +* Copyright (c) 2023 - present TinyEngine Authors. +* Copyright (c) 2023 - present Huawei Cloud Computing Technologies Co., Ltd. +* +* Use of this source code is governed by an MIT-style license. +* +* THE OPEN SOURCE SOFTWARE IN THIS PRODUCT IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, +* BUT WITHOUT ANY WARRANTY, WITHOUT EVEN THE IMPLIED WARRANTY OF MERCHANTABILITY OR FITNESS FOR +* A PARTICULAR PURPOSE. SEE THE APPLICABLE LICENSES FOR MORE DETAILS. +* +*/ + +import path from 'path' +import DateStore from '@seald-io/nedb' +import { getResponseData } from '../tool/Common' + +export default class PageService { + constructor() { + this.db = new DateStore({ + filename: path.resolve(__dirname, '../database/pages.db'), + autoload: true + }) + + this.db.ensureIndex({ + fieldName: 'route', + unique: true + }) + + this.userInfo = { + id: 86, + username: '开发者', + email: 'developer@lowcode.com', + resetPasswordToken: 'developer', + confirmationToken: 'dfb2c162-351f-4f44-ad5f-8998', + is_admin: true + } + + this.pageModel = { + name: '', + id: '', + app: '918', + route: '', + page_content: {}, + tenant: 1, + isBody: true, + parentId: '', + depth: 0, + isPage: true, + isDefault: false, + group: 'staticPages', + occupier: { + id: 86, + username: '开发者', + email: 'developer@lowcode.com', + resetPasswordToken: 'developer', + confirmationToken: 'dfb2c162-351f-4f44-ad5f-8998', + is_admin: true + } + } + + this.folderModel = { + parentId: '0', + route: 'test', + name: 'test', + app: '918', + isPage: false, + group: 'staticPages' + } + } + + async create(params) { + const model = params.isPage ? this.pageModel : this.folderModel + const pageData = { ...model, ...params } + const result = await this.db.insertAsync(pageData) + const { _id } = result + await this.db.updateAsync({ _id }, { $set: { id: _id } }) + result.id = result._id + return getResponseData(result) + } + + async update(id, params) { + await this.db.updateAsync({ _id: id }, { $set: params }) + const result = await this.db.findOneAsync({ _id: id }) + return getResponseData(result) + } + + async list(appId) { + const result = await this.db.findAsync({ app: appId.toString() }) + return getResponseData(result) + } + + async detail(pageId) { + const result = await this.db.findOneAsync({ _id: pageId }) + return getResponseData(result) + } + + async delete(pageId) { + const result = await this.db.findOneAsync({ _id: pageId }) + await this.db.removeAsync({ _id: pageId }) + return getResponseData(result) + } +} diff --git a/mockServer/src/services/schema2code.js b/mockServer/src/services/schema2code.js new file mode 100644 index 000000000..9b2700065 --- /dev/null +++ b/mockServer/src/services/schema2code.js @@ -0,0 +1,113 @@ +/** + * Copyright (c) 2023 - present TinyEngine Authors. + * Copyright (c) 2023 - present Huawei Cloud Computing Technologies Co., Ltd. + * + * Use of this source code is governed by an MIT-style license. + * + * THE OPEN SOURCE SOFTWARE IN THIS PRODUCT IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, + * BUT WITHOUT ANY WARRANTY, WITHOUT EVEN THE IMPLIED WARRANTY OF MERCHANTABILITY OR FITNESS FOR + * A PARTICULAR PURPOSE. SEE THE APPLICABLE LICENSES FOR MORE DETAILS. + * + */ + +import { pageService } from '../routes/main-routes' +import appInfo from './appinfo.json' + +export default class Schema2CodeServcice { + constructor() { + this.blockHistories = appInfo.blockHistories + this.components = appInfo.materialHistory.components + } + + schema2code(pageInfo, type = 'page') { + const { schema, name } = pageInfo + return this.translateSchema({ + schema, + name, + type + }) + } + + /** + * 通过dsl 将页面/区块schema数据生成对应代码 + * @param { I_TranslateSchemaParam } params + * @return {Promise