large-model-component 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (87) hide show
  1. package/.editorconfig +13 -0
  2. package/.env +2 -0
  3. package/.env.development +2 -0
  4. package/.env.production +2 -0
  5. package/.eslintignore +9 -0
  6. package/.eslintrc.js +7 -0
  7. package/.markdownlint.json +3 -0
  8. package/.markdownlintignore +7 -0
  9. package/.prettierrc.js +8 -0
  10. package/.stylelintignore +10 -0
  11. package/.stylelintrc.js +3 -0
  12. package/CHANGELOG.md +4 -0
  13. package/README.md +57 -0
  14. package/babel.config.js +3 -0
  15. package/commitlint.config.js +3 -0
  16. package/dist/css/248.e455a0b7.css +1 -0
  17. package/dist/css/712.3716bdaf.css +1 -0
  18. package/dist/css/792.3716bdaf.css +1 -0
  19. package/dist/demo.html +1 -0
  20. package/dist/img/ai-chart.167a7713.png +0 -0
  21. package/dist/img/scrol-bg.f446933a.png +0 -0
  22. package/dist/img/zhijing-model.6a81c5a7.png +0 -0
  23. package/dist/large-model-component.common.712.js +73 -0
  24. package/dist/large-model-component.common.712.js.map +1 -0
  25. package/dist/large-model-component.common.js +143384 -0
  26. package/dist/large-model-component.common.js.map +1 -0
  27. package/dist/large-model-component.css +1 -0
  28. package/dist/large-model-component.umd.792.js +73 -0
  29. package/dist/large-model-component.umd.792.js.map +1 -0
  30. package/dist/large-model-component.umd.js +143395 -0
  31. package/dist/large-model-component.umd.js.map +1 -0
  32. package/dist/large-model-component.umd.min.248.js +2 -0
  33. package/dist/large-model-component.umd.min.248.js.map +1 -0
  34. package/dist/large-model-component.umd.min.js +32 -0
  35. package/dist/large-model-component.umd.min.js.map +1 -0
  36. package/docs/.vuepress/config.js +30 -0
  37. package/docs/.vuepress/enhanceApp.js +7 -0
  38. package/docs/.vuepress/styles/palette.styl +3 -0
  39. package/docs/README.md +12 -0
  40. package/docs/comps/README.md +18 -0
  41. package/docs/comps/header.md +100 -0
  42. package/docs/config.md +0 -0
  43. package/docs/logs/README.md +42 -0
  44. package/f2elint.config.js +5 -0
  45. package/jsconfig.json +19 -0
  46. package/package.json +80 -0
  47. package/packages/index.js +27 -0
  48. package/packages/largeModel/contentFold.vue +221 -0
  49. package/packages/largeModel/index.js +2 -0
  50. package/packages/largeModel/index.vue +1703 -0
  51. package/packages/largeModel/pubsub.js +30 -0
  52. package/packages/largeModel/wsconnecter.js +60 -0
  53. package/public/index.html +17 -0
  54. package/src/App.vue +33 -0
  55. package/src/api/user.js +68 -0
  56. package/src/assets/css/app.css +3255 -0
  57. package/src/assets/css/base.css +3 -0
  58. package/src/assets/css/chunk-vendors.css +2071 -0
  59. package/src/assets/css/github-markdown.css +985 -0
  60. package/src/assets/img/ai-chart.png +0 -0
  61. package/src/assets/img/close.png +0 -0
  62. package/src/assets/img/delete.png +0 -0
  63. package/src/assets/img/fontawesome-webfont.912ec66d.svg +2671 -0
  64. package/src/assets/img/home-bg.png +0 -0
  65. package/src/assets/img/link.png +0 -0
  66. package/src/assets/img/message.png +0 -0
  67. package/src/assets/img/qas.png +0 -0
  68. package/src/assets/img/quick_finder_icon1.png +0 -0
  69. package/src/assets/img/quick_finder_icon2.png +0 -0
  70. package/src/assets/img/quick_finder_icon3.png +0 -0
  71. package/src/assets/img/quick_finder_icon4.png +0 -0
  72. package/src/assets/img/quizzer.png +0 -0
  73. package/src/assets/img/scrol-bg.png +0 -0
  74. package/src/assets/img/send.png +0 -0
  75. package/src/assets/img/serviceIcon.png +0 -0
  76. package/src/assets/img/zhijing-model.png +0 -0
  77. package/src/main.js +15 -0
  78. package/src/router/index.js +20 -0
  79. package/src/store/index.js +26 -0
  80. package/src/utils/auth.js +48 -0
  81. package/src/utils/index.js +111 -0
  82. package/src/utils/request.js +103 -0
  83. package/src/utils/spceialistConfig.js +44 -0
  84. package/src/utils/tool.js +4 -0
  85. package/src/utils/utils.js +56 -0
  86. package/src/utils/validate.js +20 -0
  87. package/vue.config.js +42 -0
@@ -0,0 +1,30 @@
1
+ module.exports = {
2
+ theme: '',
3
+ title: '公共组件库',
4
+ description: 'industrial-web-component',
5
+ base: '/docs-web/',
6
+ port: '8080',
7
+ themeConfig: {
8
+ nav: [
9
+ {
10
+ text: '首页',
11
+ link: '/',
12
+ },
13
+ {
14
+ text: '组件',
15
+ link: '/comps/',
16
+ },
17
+ {
18
+ text: '更新记录',
19
+ link: '/logs/',
20
+ },
21
+ ],
22
+ sidebar: {
23
+ // 配置侧边栏部分
24
+ '/comps/': ['/comps/', '/comps/header.md'],
25
+ },
26
+ },
27
+ head: [],
28
+ plugins: ['demo-container'], // 组件示例配置插件
29
+ markdown: {},
30
+ };
@@ -0,0 +1,7 @@
1
+ import iipComponents from '../../packages/index';
2
+
3
+ export default async ({ Vue }) => {
4
+ if (typeof process === 'undefined') {
5
+ Vue.use(iipComponents);
6
+ }
7
+ };
@@ -0,0 +1,3 @@
1
+ .theme-default-content:not(.custom){
2
+ max-width:none
3
+ }
package/docs/README.md ADDED
@@ -0,0 +1,12 @@
1
+ ---
2
+ home: true
3
+ heroImage: https://uoc.oss.cn-north-3.inspurcloudoss.com/uoc/1648607149757808.ico
4
+ heroText: industrial-web-component
5
+ features:
6
+ - title: 一致性 Consistency
7
+ details: 与现实生活一致:与现实生活的流程、逻辑保持一致,遵循用户习惯的语言和概念
8
+ - title: 反馈 Feedback
9
+ details: 通过界面样式和交互动效让用户可以清晰的感知自己的操作
10
+ - title: 效率 Efficiency
11
+ details: 界面简单直白,让用户快速识别而非回忆,减少用户记忆负担。
12
+ ---
@@ -0,0 +1,18 @@
1
+ # 安装
2
+
3
+ ## npm 安装
4
+
5
+ 安装命令:
6
+
7
+ ```shell
8
+ npm i industrial-web-component -S
9
+
10
+ ```
11
+
12
+ ## 仓库源地址
13
+
14
+ ```shell
15
+
16
+ https://nexus.qualink.com/repository/npm-hosted/
17
+
18
+ ```
@@ -0,0 +1,100 @@
1
+ # 基本信息组件
2
+
3
+ 通用顶部导航栏
4
+
5
+ ## 顶部导航栏
6
+
7
+ ::: demo 使用 demo 如下
8
+
9
+ ```html
10
+ <template>
11
+ <div>
12
+ <iipHeader
13
+ class="column"
14
+ :logoUrl="logo"
15
+ :loginUrl="loginUrl"
16
+ :showWorkBench="useWorkBench"
17
+ :columns="columnList"
18
+ :userName="userName"
19
+ @log-out="logout"
20
+ @go-work-bench="goWorkBench"
21
+ >
22
+ </iipHeader>
23
+ </div>
24
+ </template>
25
+ <script>
26
+ export default {
27
+ data() {
28
+ return {
29
+ // 配置信息
30
+ logo: 'http://10.221.19.220:8083/gateway/file/MjAyMy8xMC8xMi9hMWY5ZmRmMGQ1MTc0M2JkYThhYjNjM2E0ZTIxNzhlMg==',
31
+ loginUrl:
32
+ 'http://10.221.19.220:8083/sign/authz/oauth/v20/authorize?client_id=894283562298114048&response_type=code&redirect_uri=http://10.221.19.220:8083',
33
+ useWorkBench: true, //
34
+ columnList: [], // 栏目列表
35
+ userName: '珈百璃',
36
+ };
37
+ },
38
+ methods: {
39
+ logout() {
40
+ // 登出逻辑
41
+ },
42
+ goWorkBench() {
43
+ //工作台跳转逻辑
44
+ },
45
+ },
46
+ };
47
+ </script>
48
+ <style>
49
+ .column {
50
+ position: relative;
51
+ z-index: 3;
52
+ }
53
+ </style>
54
+ ```
55
+
56
+ :::
57
+
58
+ ### iipHeader Attributes
59
+
60
+ | 参数 | 说明 | 类型 | 可选值 | 默认值 |
61
+ | :------------ | :------------------------------------- | :------ | :--------- | :--------------------------------------------------------------------- |
62
+ | showWorkBench | 是否使用工作台 | Boolean | false/true | false |
63
+ | logoUrl | Logo 链接 | String | —— | —— |
64
+ | loginUrl | 登录链接 | String | —— | —— |
65
+ | useSlot | 是否使用插槽 | Boolean | false/true | false |
66
+ | columns | 默认栏目,仅当 useSolt 为 false 时生效 | Array | —— | —— |
67
+ | userName | 用户栏显示用户名 | String | —— | —— |
68
+ | userLinks | 用户栏下拉额外添加项 | Array | —— | 账号中心相关 |
69
+ | userLogo | 用户栏图标 | String | —— | https://uoc.oss.cn-north-3.inspurcloudoss.com/uoc/1694143414545484.svg |
70
+
71
+ ### columns Attributes
72
+
73
+ 栏目列表对象格式如下:
74
+
75
+ | 参数 | 说明 | 类型 | 可选值 | 默认值 |
76
+ | :--------- | :--------------------- | :----- | :----------------------- | :----- |
77
+ | columnName | 栏目名称 | String | —— | —— |
78
+ | columnLink | 跳转链接 | String | —— | —— |
79
+ | runType | 跳转方式 | String | 0,内部跳转;1,外部跳转 | 1 |
80
+ | child | 子栏目,格式与栏目相同 | Array | —— | —— |
81
+
82
+ ## 底部信息栏
83
+
84
+ 如果在 nuxt 中使用,需要使用 clientOnly 组件
85
+
86
+ ```html
87
+ <template>
88
+ <iipFooter :apiHost="`http://10.221.19.220:8083`" :apiPath="`/gateway/site/1/links`"></iipFooter>
89
+ </template>
90
+ ```
91
+
92
+ :::
93
+
94
+ ### iipFooter Attributes
95
+
96
+ | 参数 | 说明 | 类型 | 可选值 | 默认值 |
97
+ | :--------- | :-------------------------------- | :----- | :----- | :-------------- |
98
+ | apiHost | 调用域名 | String | ——— | window.location |
99
+ | apiPath | 调用方法,优先级高于 footerData | String | —— | —— |
100
+ | footerData | 数据传值,当不设置 apiPath 时生效 | String | —— | —— |
package/docs/config.md ADDED
File without changes
@@ -0,0 +1,42 @@
1
+ ## 2.0.0 (2024-02-21)
2
+
3
+ - 功能增删
4
+
5
+ ## 1.3.4 (2023-12-15)
6
+
7
+ - 修改一些 bug
8
+
9
+ ## 1.3.0 (2023-11-23)
10
+
11
+ - 与评估诊断版本分开
12
+
13
+ ## 1.2.7 (2023-11-13)
14
+
15
+ - 替换 user 图标
16
+ - 修改栏目与 logo 间距
17
+
18
+ ## 1.2.4 (2023-11-13)
19
+
20
+ - 修改顶部导航栏,栏目的高度
21
+
22
+ ## 1.2.3 (2023-11-6)
23
+
24
+ - 修改一些 bug
25
+
26
+ ## 1.2.0 (2023-11-4)
27
+
28
+ - 去掉 userLogo 入参,改为本地使用
29
+ - footer 修改数据使用逻辑,增加自身调用接口请求数据
30
+
31
+ ## 1.1.7 (2023-10-20)
32
+
33
+ - 将右上角图标改为本地引用
34
+
35
+ ## 1.1.6 (2023-10-20)
36
+
37
+ - 修改 userlink 样式
38
+ - 增加 CHANGELOG.md 文档
39
+
40
+ # 1.0.0 (2023-10-12)
41
+
42
+ - 从 0.21.0 迁移代码
@@ -0,0 +1,5 @@
1
+ module.exports = {
2
+ enableStylelint: true,
3
+ enableMarkdownlint: true,
4
+ enablePrettier: true,
5
+ };
package/jsconfig.json ADDED
@@ -0,0 +1,19 @@
1
+ {
2
+ "compilerOptions": {
3
+ "target": "es5",
4
+ "module": "esnext",
5
+ "baseUrl": "./",
6
+ "moduleResolution": "node",
7
+ "paths": {
8
+ "@/*": [
9
+ "src/*"
10
+ ]
11
+ },
12
+ "lib": [
13
+ "esnext",
14
+ "dom",
15
+ "dom.iterable",
16
+ "scripthost"
17
+ ]
18
+ }
19
+ }
package/package.json ADDED
@@ -0,0 +1,80 @@
1
+ {
2
+ "name": "large-model-component",
3
+ "version": "1.0.0",
4
+ "private": false,
5
+ "scripts": {
6
+ "dev": "vue-cli-service serve",
7
+ "build": "vue-cli-service build",
8
+ "test:unit": "vue-cli-service test:unit",
9
+ "lint": "vue-cli-service lint",
10
+ "lib": "vue-cli-service build --target lib packages/index.js",
11
+ "f2elint-scan": "f2elint scan",
12
+ "f2elint-fix": "f2elint fix",
13
+ "docs:dev": "vuepress dev docs",
14
+ "docs:build": "vuepress build docs"
15
+ },
16
+ "peerDependencies": {
17
+ "element-ui": "^2.15.14"
18
+ },
19
+ "main": "dist/large-model-component.umd.min.js",
20
+ "publishConfig": {
21
+ "access": "public",
22
+ "registry": "https://registry.npmjs.org/"
23
+ },
24
+ "dependencies": {
25
+ "axios": "0.18.1",
26
+ "core-js": "^3.8.3",
27
+ "element-ui": "2.13.2",
28
+ "event-source-polyfill": "^1.0.31",
29
+ "highlight.js": "^11.7.0",
30
+ "python": "^0.0.4",
31
+ "sass": "^1.32.0",
32
+ "spark-md5": "^3.0.2",
33
+ "vue": "^2.6.14",
34
+ "vuex": "^3.6.2",
35
+ "vue-router": "3.0.6",
36
+ "markdown-it": "12.3.2",
37
+ "markdown-it-abbr": "^2.0.0",
38
+ "markdown-it-container": "^4.0.0",
39
+ "markdown-it-emoji": "^3.0.0",
40
+ "markdown-it-footnote": "^4.0.0",
41
+ "markdown-it-github-toc": "^3.2.4",
42
+ "markdown-it-ins": "^4.0.0",
43
+ "markdown-it-latex": "^0.2.0",
44
+ "markdown-it-mark": "^4.0.0",
45
+ "markdown-it-sub": "^2.0.0",
46
+ "markdown-it-sup": "^2.0.0",
47
+ "markdown-it-task-lists": "^2.1.1",
48
+ "webpack": "5.94.0"
49
+ },
50
+ "devDependencies": {
51
+ "@babel/core": "^7.12.16",
52
+ "@vue/cli-plugin-babel": "~5.0.0",
53
+ "@vue/cli-plugin-eslint": "~5.0.0",
54
+ "@vue/cli-plugin-unit-jest": "~5.0.0",
55
+ "@vue/cli-service": "~5.0.0",
56
+ "@vue/test-utils": "^1.1.3",
57
+ "@vue/vue2-jest": "^27.0.0-alpha.2",
58
+ "babel-jest": "^27.0.6",
59
+ "jest": "^27.0.5",
60
+ "sass": "^1.32.0",
61
+ "sass-loader": "^10.2.0",
62
+ "vue-template-compiler": "^2.6.14",
63
+ "vuepress": "^1.9.10",
64
+ "vuepress-plugin-demo-container": "^0.2.0"
65
+ },
66
+ "browserslist": [
67
+ "> 1%",
68
+ "last 2 versions",
69
+ "not dead"
70
+ ],
71
+ "jest": {
72
+ "preset": "@vue/cli-plugin-unit-jest"
73
+ },
74
+ "husky": {
75
+ "hooks": {
76
+ "pre-commit": "f2elint commit-file-scan",
77
+ "commit-msg": "f2elint commit-msg-scan"
78
+ }
79
+ }
80
+ }
@@ -0,0 +1,27 @@
1
+ // 整个包的入口
2
+ // 定义 install 方法,接收 Vue 作为参数。如果使用 use 注册插件,则所有的组件都将被注册
3
+ // 统一导出
4
+ // 导入颜色选择器组件
5
+ import largeModel from './largeModel';
6
+
7
+ // 存储组件列表
8
+ const components = [largeModel];
9
+ const install = function (Vue, options = {}) {
10
+ // 全局注册所有的组件
11
+ components.forEach((item) => {
12
+ Vue.component(item.name, item);
13
+ });
14
+ };
15
+
16
+ // Vue.prototype.$message = Message;
17
+ // Vue.prototype.$notice = Notice;
18
+
19
+ // 判断是否是直接引入文件,如果是,就不用调用 Vue.use()
20
+ if (typeof window !== 'undefined' && window.Vue) {
21
+ install(window.Vue);
22
+ }
23
+
24
+ export default {
25
+ install,
26
+ largeModel,
27
+ };
@@ -0,0 +1,221 @@
1
+ <template>
2
+ <div class="show-information">
3
+ <div class="info-content">
4
+ <!-- 思考过程 -->
5
+ <div v-if="thinkProcess" class="info-main markdown-body think-process" v-html="thinkProcess"></div>
6
+ <!-- 主要内容 -->
7
+ <div class="info-main markdown-body" ref="observedElement" v-html="renderedContent"></div>
8
+ </div>
9
+ </div>
10
+ </template>
11
+
12
+ <script>
13
+ import MarkdownIt from 'markdown-it';
14
+ import sub from 'markdown-it-sub';
15
+ import sup from 'markdown-it-sup';
16
+ import footnote from 'markdown-it-footnote';
17
+ import taskLists from 'markdown-it-task-lists';
18
+ import container from 'markdown-it-container';
19
+ import abbr from 'markdown-it-abbr';
20
+ import ins from 'markdown-it-ins';
21
+ import mark from 'markdown-it-mark';
22
+ import hljs from 'highlight.js';
23
+
24
+ export default {
25
+ props: {
26
+ content: { type: String, default: '' },
27
+ height: { type: Number, default: 150 } // 增加默认高度以防误判
28
+ },
29
+ data() {
30
+ return {
31
+ fold: true,
32
+ isShow: false,
33
+ thinkProcess: '',
34
+ renderedContent: ''
35
+ };
36
+ },
37
+ watch: {
38
+ content: {
39
+ immediate: true,
40
+ handler(newVal) {
41
+ this.processMarkdown(newVal);
42
+ }
43
+ }
44
+ },
45
+ mounted() {
46
+ this.$nextTick(() => {
47
+ if (this.$refs.observedElement) {
48
+ const resizeObserver = new ResizeObserver(entries => {
49
+ for (const entry of entries) {
50
+ const { height } = entry.contentRect;
51
+ // 只有当内容高度超过设定值才显示折叠
52
+ if (height > this.height) {
53
+ this.isShow = true;
54
+ } else {
55
+ this.isShow = false;
56
+ this.fold = false; // 如果内容不多,默认展开且不显示折叠按钮
57
+ }
58
+ }
59
+ });
60
+ resizeObserver.observe(this.$refs.observedElement);
61
+ }
62
+ });
63
+ },
64
+ methods: {
65
+ processMarkdown(text) {
66
+ if (!text) {
67
+ this.renderedContent = '';
68
+ this.thinkProcess = '';
69
+ return;
70
+ }
71
+
72
+ const md = new MarkdownIt({
73
+ html: true,
74
+ linkify: true,
75
+ typographer: true,
76
+ breaks: true,
77
+ highlight: (str, lang) => {
78
+ if (lang && hljs.getLanguage(lang)) {
79
+ try {
80
+ return '<pre class="hljs"><code>' + hljs.highlight(str, { language: lang, ignoreIllegals: true }).value + '</code></pre>';
81
+ } catch (__) {}
82
+ }
83
+ return '<pre class="hljs"><code>' + md.utils.escapeHtml(str) + '</code></pre>';
84
+ }
85
+ })
86
+ .use(sub).use(sup).use(footnote).use(taskLists)
87
+ .use(container, 'warning').use(abbr).use(ins).use(mark);
88
+
89
+ try {
90
+ const parts = text.split('</think>');
91
+ if (parts.length > 1) {
92
+ this.thinkProcess = md.render(parts[0]);
93
+ } else {
94
+ this.thinkProcess = '';
95
+ }
96
+ this.renderedContent = md.render(parts[parts.length - 1]);
97
+ } catch (err) {
98
+ console.error('Markdown parsing failed:', err);
99
+ this.renderedContent = text; // 降级处理
100
+ }
101
+ },
102
+ options(type) {
103
+ this.fold = type;
104
+ }
105
+ }
106
+ };
107
+ </script>
108
+
109
+ <style scoped lang="scss">
110
+ .show-information {
111
+ width: 100%;
112
+ background: #ffffff; /* 保持背景色 */
113
+ box-sizing: border-box;
114
+ border-radius: 0 6px 6px 6px;
115
+
116
+ .info-content {
117
+ width: 100%;
118
+ padding: 8px 0;
119
+
120
+ /* 关键:深度选择器穿透 scoped,应用 markdown 样式 */
121
+ ::v-deep .markdown-body {
122
+ font-family: "PingFang SC", "Microsoft YaHei", sans-serif;
123
+ font-size: 16px;
124
+ line-height: 1.8;
125
+ color: #343f64;
126
+ word-wrap: break-word;
127
+
128
+ h1, h2, h3, h4, h5, h6 {
129
+ margin-top: 24px;
130
+ margin-bottom: 16px;
131
+ font-weight: 600;
132
+ line-height: 1.25;
133
+ color: #24292e;
134
+ }
135
+ h3 { font-size: 1.25em; }
136
+
137
+ p { margin-top: 0; margin-bottom: 16px; }
138
+
139
+ ul, ol {
140
+ padding-left: 2em;
141
+ margin-top: 0;
142
+ margin-bottom: 16px;
143
+ }
144
+
145
+ li { margin-bottom: 4px; }
146
+
147
+ strong { font-weight: 600; color: #24292e; }
148
+
149
+ code {
150
+ padding: 0.2em 0.4em;
151
+ margin: 0;
152
+ font-size: 85%;
153
+ background-color: rgba(27,31,35,0.05);
154
+ border-radius: 3px;
155
+ font-family: Consolas, Monaco, "Andale Mono", monospace;
156
+ color: #24292e;
157
+ }
158
+
159
+ pre {
160
+ background-color: #f6f8fa;
161
+ padding: 16px;
162
+ overflow: auto;
163
+ border-radius: 6px;
164
+ margin-bottom: 16px;
165
+ code {
166
+ background-color: transparent;
167
+ padding: 0;
168
+ font-size: 100%;
169
+ color: #24292e;
170
+ }
171
+ }
172
+
173
+ blockquote {
174
+ padding: 0 1em;
175
+ color: #6a737d;
176
+ border-left: 0.25em solid #dfe2e5;
177
+ margin: 0 0 16px 0;
178
+ }
179
+
180
+ table {
181
+ border-spacing: 0;
182
+ border-collapse: collapse;
183
+ display: block;
184
+ width: max-content;
185
+ max-width: 100%;
186
+ overflow: auto;
187
+ margin-bottom: 16px;
188
+ th, td {
189
+ padding: 6px 13px;
190
+ border: 1px solid #dfe2e5;
191
+ }
192
+ tr {
193
+ background-color: #fff;
194
+ border-top: 1px solid #c6cbd1;
195
+ &:nth-child(2n) { background-color: #f6f8fa; }
196
+ }
197
+ }
198
+
199
+ /* 针对折叠区域的特殊样式 */
200
+ &.think-process {
201
+ background: #fff;
202
+ border-left: 3px solid #409EFF;
203
+ padding: 8px 12px;
204
+ margin-bottom: 16px;
205
+ color: #606266;
206
+ font-size: 14px;
207
+ border-radius: 0 4px 4px 0;
208
+ }
209
+ }
210
+ }
211
+
212
+ /* 折叠控制逻辑相关的样式 (如果需要保留折叠功能) */
213
+ .content-fold-wrapper {
214
+ position: relative;
215
+ overflow: hidden;
216
+ transition: height 0.3s;
217
+ }
218
+
219
+ // 这里可以添加折叠蒙层和按钮的样式,参考您原有的 .flog
220
+ }
221
+ </style>
@@ -0,0 +1,2 @@
1
+ import largeModel from "./index.vue";
2
+ export default largeModel;