Compare commits

..

212 Commits

Author SHA1 Message Date
wangxiaoshuang 7fcbd7f983 生产环境配置修改
continuous-integration/drone/push Build encountered an error Details
2025-03-24 13:59:21 +08:00
wangxiaoshuang 779badb041 项目文档系统数据中英文转换
continuous-integration/drone/push Build is passing Details
2025-03-24 09:31:49 +08:00
caiyiling ef5e5527fd 标注更改及检查名称更改
continuous-integration/drone/push Build is passing Details
2025-03-21 16:29:47 +08:00
caiyiling 52ac12d6b6 阅片页面显示检查名称
continuous-integration/drone/push Build is passing Details
2025-03-21 15:36:23 +08:00
caiyiling 272c28a988 自定义阅片更改及非dicom阅片添加个性化配置
continuous-integration/drone/push Build is passing Details
2025-03-21 15:03:21 +08:00
caiyiling 6b10d07e2a 自定义阅片预览paf更改
continuous-integration/drone/push Build is passing Details
2025-03-21 14:03:53 +08:00
caiyiling 032e710890 阅片工具及报告页查看pdf更改
continuous-integration/drone/push Build is passing Details
2025-03-21 13:09:36 +08:00
caiyiling 032150904e 非dicom阅片更改
continuous-integration/drone/push Build is passing Details
2025-03-20 19:23:20 +08:00
wangxiaoshuang d91161a139 网速监控改为三位小数
continuous-integration/drone/push Build is passing Details
2025-03-19 15:53:41 +08:00
wangxiaoshuang bba2237337 文件大小改为保留3位小数
continuous-integration/drone/push Build is passing Details
2025-03-19 15:36:53 +08:00
wangxiaoshuang 707ca5602c Merge branch 'main' of https://gitea.frp.extimaging.com/XCKJ/irc_web
continuous-integration/drone/push Build is passing Details
2025-03-18 17:59:20 +08:00
wangxiaoshuang 3b03d6ba76 项目文档搜索栏样式问题 2025-03-18 17:59:10 +08:00
caiyiling 9277d48c85 1
continuous-integration/drone/push Build is passing Details
2025-03-18 17:55:22 +08:00
caiyiling d753fbc2ab 非dicom阅片测量工具更改
continuous-integration/drone/push Build is passing Details
2025-03-18 16:53:03 +08:00
caiyiling 5678e3302b 国际化补充
continuous-integration/drone/push Build is passing Details
2025-03-18 15:34:12 +08:00
caiyiling c25cb097ab 1
continuous-integration/drone/push Build is passing Details
2025-03-18 15:28:13 +08:00
caiyiling 070db5158d Merge branch 'main' of https://gitea.frp.extimaging.com/XCKJ/irc_web into main
continuous-integration/drone/push Build is running Details
2025-03-18 15:27:16 +08:00
caiyiling 121bf497bb 非dicom阅片更改 2025-03-18 15:26:51 +08:00
wangxiaoshuang e2ffd76504 阅片人筛选机构城市国家中英文显示
continuous-integration/drone/push Build is passing Details
2025-03-18 15:18:26 +08:00
wangxiaoshuang cfbe3b4839 项目文档培训记录培训人数校验修改
continuous-integration/drone/push Build is running Details
2025-03-18 15:16:31 +08:00
wangxiaoshuang 81bef8abe0 项目文档培训记录培训人数添加校验
continuous-integration/drone/push Build is passing Details
2025-03-18 14:15:31 +08:00
wangxiaoshuang 84b1263340 浏览器页签标题修改
continuous-integration/drone/push Build is passing Details
2025-03-18 13:57:07 +08:00
wangxiaoshuang 4016e71c37 项目文档阅片人问题修复
continuous-integration/drone/push Build is passing Details
2025-03-18 13:51:25 +08:00
wangxiaoshuang 3b0afd3913 1
continuous-integration/drone/push Build is passing Details
2025-03-18 13:45:13 +08:00
wangxiaoshuang 3672892451 项目文档阅片人问题修复
continuous-integration/drone/push Build is passing Details
2025-03-18 09:54:33 +08:00
wangxiaoshuang c46ca18a42 项目文档菜单与列表是否适用字段联动
continuous-integration/drone/push Build is passing Details
2025-03-17 16:38:14 +08:00
wangxiaoshuang 0e0b5c2c4c 项目文档同意入项记录上传方式修改
continuous-integration/drone/push Build is passing Details
2025-03-17 14:34:24 +08:00
wangxiaoshuang 5339e2df63 Merge branch 'main' of https://gitea.frp.extimaging.com/XCKJ/irc_web
continuous-integration/drone/push Build is passing Details
2025-03-17 13:23:25 +08:00
wangxiaoshuang 66d5591d50 项目文档同意入项记录上传更改为弹框 2025-03-17 13:23:21 +08:00
caiyiling bfe2f1dbfb Merge branch 'main' of https://gitea.frp.extimaging.com/XCKJ/irc_web into main
continuous-integration/drone/push Build is passing Details
2025-03-17 11:37:30 +08:00
caiyiling 24806f57ed 自定义阅片bug修复 2025-03-17 11:37:09 +08:00
wangxiaoshuang b0ff8e7163 项目文档培训记录效果改为可输入所有字符
continuous-integration/drone/push Build is passing Details
2025-03-17 11:34:03 +08:00
caiyiling c9ef6cd19f Merge branch 'main' of https://gitea.frp.extimaging.com/XCKJ/irc_web into main
continuous-integration/drone/push Build is passing Details
2025-03-17 11:24:01 +08:00
caiyiling 00cc5d5d27 非dicom阅片ecrf更改 2025-03-17 11:23:24 +08:00
wangxiaoshuang 25ddd422a3 1
continuous-integration/drone/push Build is passing Details
2025-03-17 09:29:56 +08:00
wangxiaoshuang a060c1745d 项目文档资质材料
continuous-integration/drone/push Build is passing Details
2025-03-14 17:09:38 +08:00
wangxiaoshuang 1a4bfe64f9 项目文档上传文件路径更改
continuous-integration/drone/push Build is passing Details
2025-03-14 13:15:44 +08:00
caiyiling 2fd6e1893b Merge branch 'main' of https://gitea.frp.extimaging.com/XCKJ/irc_web into main
continuous-integration/drone/push Build is passing Details
2025-03-14 10:35:46 +08:00
caiyiling dc0229810d 国际化补充 2025-03-14 10:35:20 +08:00
wangxiaoshuang 08c911d4a0 项目文档申报方同意入项记录审核人角色字段更改
continuous-integration/drone/push Build is passing Details
2025-03-14 10:25:35 +08:00
wangxiaoshuang 08cdcffd82 项目文档申报方同意入项记录
continuous-integration/drone/push Build is passing Details
2025-03-13 17:10:42 +08:00
wangxiaoshuang a5f16c866d 检查名称配置更改
continuous-integration/drone/push Build is passing Details
2025-03-13 16:37:08 +08:00
caiyiling 3167c2bea7 Merge branch 'main' of https://gitea.frp.extimaging.com/XCKJ/irc_web into main
continuous-integration/drone/push Build is passing Details
2025-03-13 15:01:16 +08:00
caiyiling 26cca57f75 系统标准国际化补充 2025-03-13 15:00:50 +08:00
wangxiaoshuang ff88cbd6e2 1
continuous-integration/drone/push Build is passing Details
2025-03-13 13:23:56 +08:00
wangxiaoshuang c4a498d953 检查被IQC标记删除:在crc查看时,该行记录增加删除线
continuous-integration/drone/push Build is passing Details
2025-03-13 11:14:34 +08:00
wangxiaoshuang f58e2ff82f 影像重传,确认完成时,签名中XXX未替换 2025-03-13 11:14:00 +08:00
wangxiaoshuang 1696fb6294 Merge branch 'main' of https://gitea.frp.extimaging.com/XCKJ/irc_web
continuous-integration/drone/push Build is passing Details
2025-03-12 17:33:10 +08:00
wangxiaoshuang 3c81a8a678 1 2025-03-12 17:32:58 +08:00
caiyiling afcd1b82c0 Merge branch 'main' of https://gitea.frp.extimaging.com/XCKJ/irc_web into main 2025-03-12 17:22:44 +08:00
caiyiling 96864b808c 配置文件更改 2025-03-12 17:22:18 +08:00
wangxiaoshuang 5ba2abb8f5 Merge branch 'main' of https://gitea.frp.extimaging.com/XCKJ/irc_web
continuous-integration/drone/push Build is failing Details
2025-03-12 17:11:15 +08:00
wangxiaoshuang dc0329032e 项目文档菜单添加滚动条 2025-03-12 17:11:05 +08:00
caiyiling 4097389447 图片渲染窗口滚动条优化
continuous-integration/drone/push Build is passing Details
2025-03-12 16:11:16 +08:00
caiyiling cf39a84370 全局和裁判阅片签名更改
continuous-integration/drone/push Build is passing Details
2025-03-12 15:42:56 +08:00
caiyiling aae2d6a1c5 非dicom全局和裁判阅片更改
continuous-integration/drone/push Build is passing Details
2025-03-12 15:18:23 +08:00
caiyiling 10f4bf7480 pdf文件替换
continuous-integration/drone/push Build is passing Details
2025-03-12 14:56:17 +08:00
caiyiling 57f0938efc 非dicom文件交互更改
continuous-integration/drone/push Build is passing Details
2025-03-12 14:50:55 +08:00
caiyiling 615580331b 后台管理页面调整
continuous-integration/drone/push Build is passing Details
2025-03-12 14:42:05 +08:00
caiyiling 4b4058b0da 文件渲染视口样式更改
continuous-integration/drone/push Build is passing Details
2025-03-12 13:16:47 +08:00
caiyiling f77820df79 临床数据查看更改
continuous-integration/drone/push Build is running Details
2025-03-12 13:14:31 +08:00
caiyiling 398bc21666 Merge branch 'main' of https://gitea.frp.extimaging.com/XCKJ/irc_web into main
continuous-integration/drone/push Build is passing Details
2025-03-12 13:10:53 +08:00
caiyiling 7db8e231b6 切换pdf时取消取消全屏 2025-03-12 13:10:26 +08:00
wangxiaoshuang 581e2c3879 培训记录备注可输入值变更
continuous-integration/drone/push Build is passing Details
2025-03-12 11:47:27 +08:00
caiyiling ce030d23cd Merge branch 'main' of https://gitea.frp.extimaging.com/XCKJ/irc_web into main
continuous-integration/drone/push Build is passing Details
2025-03-12 11:35:06 +08:00
caiyiling f3c073286b 非dicom表单更改及渲染视口双击事件优化 2025-03-12 11:34:18 +08:00
wangxiaoshuang d5b342ddc6 Merge branch 'main' of https://gitea.frp.extimaging.com/XCKJ/irc_web
continuous-integration/drone/push Build is passing Details
2025-03-12 11:22:32 +08:00
wangxiaoshuang d616512a72 项目文档按钮权限更改 2025-03-12 11:22:20 +08:00
caiyiling bf57b75bed 肿瘤学阅片配置更改
continuous-integration/drone/push Build is passing Details
2025-03-12 10:46:38 +08:00
caiyiling 0d9a77f4a5 文件管理模块列宽调整
continuous-integration/drone/push Build is passing Details
2025-03-12 10:24:25 +08:00
caiyiling 7f3da436c4 后台管理页面样式调整
continuous-integration/drone/push Build is passing Details
2025-03-12 10:21:40 +08:00
caiyiling 9e1cd5a099 配置文件更改
continuous-integration/drone/push Build is passing Details
2025-03-12 09:34:50 +08:00
caiyiling 639351c469 Merge branch 'main' of https://gitea.frp.extimaging.com/XCKJ/irc_web into main
continuous-integration/drone/push Build is passing Details
2025-03-12 09:31:16 +08:00
caiyiling fa173a32fb 非dicom文件更改 2025-03-12 09:30:51 +08:00
wangxiaoshuang b93ab130fb 追溯显示信息右对齐
continuous-integration/drone/push Build is passing Details
2025-03-12 09:20:56 +08:00
caiyiling c6a6029f38 Merge branch 'main' of https://gitea.frp.extimaging.com/XCKJ/irc_web into main
continuous-integration/drone/push Build is passing Details
2025-03-11 17:41:03 +08:00
caiyiling ca907a5196 非dicom阅片更改 2025-03-11 17:40:44 +08:00
wangxiaoshuang b4fe2a1c06 ir重阅,pm驳回,签名后无响应
continuous-integration/drone/push Build is passing Details
2025-03-11 17:00:01 +08:00
wangxiaoshuang 40061db7f7 Merge branch 'main' of https://gitea.frp.extimaging.com/XCKJ/irc_web 2025-03-11 16:59:49 +08:00
wangxiaoshuang 513e9b018a spm审批签署-重阅审批,中心编号筛选查询无效 2025-03-11 16:37:59 +08:00
wangxiaoshuang 0c7b4fbfdd 影像重传,确认完成时,签名中XXX未替换 2025-03-11 16:35:10 +08:00
caiyiling 74893a51c7 Merge branch 'main' of https://gitea.frp.extimaging.com/XCKJ/irc_web into main
continuous-integration/drone/push Build is passing Details
2025-03-11 16:04:55 +08:00
caiyiling 305b6ab294 非dicom缩略图更改 2025-03-11 16:00:10 +08:00
wangxiaoshuang 920c95f611 非dicom预览pdf和zip缩略图
continuous-integration/drone/push Build is passing Details
2025-03-11 15:05:31 +08:00
wangxiaoshuang f73eabed03 培训记录删除文件后授权状态改为否、禁用下载按钮
continuous-integration/drone/push Build is passing Details
2025-03-11 14:41:34 +08:00
wangxiaoshuang e99c77fb0d 培训记录上传单个文件问题修复
continuous-integration/drone/push Build is running Details
2025-03-11 14:39:36 +08:00
wangxiaoshuang ec37ca2d3e 一般文件记录删除文件后授权状态改为否、禁用下载按钮
continuous-integration/drone/push Build is passing Details
2025-03-11 14:32:49 +08:00
wangxiaoshuang 6a6a26feb7 Merge branch 'main' of https://gitea.frp.extimaging.com/XCKJ/irc_web
continuous-integration/drone/push Build is passing Details
2025-03-11 14:18:07 +08:00
wangxiaoshuang 5676bb6e57 1 2025-03-11 14:17:57 +08:00
caiyiling 200aa7c0f8 Merge branch 'main' of https://gitea.frp.extimaging.com/XCKJ/irc_web into main
continuous-integration/drone/push Build is running Details
2025-03-11 14:16:16 +08:00
caiyiling bf4f0c7245 本地预览影像更改 2025-03-11 14:15:52 +08:00
wangxiaoshuang 21dab27e0b 国际化排序
continuous-integration/drone/push Build is passing Details
2025-03-11 14:11:18 +08:00
wangxiaoshuang 7b90715953 Merge branch 'main' of https://gitea.frp.extimaging.com/XCKJ/irc_web
continuous-integration/drone/push Build is passing Details
2025-03-11 13:53:55 +08:00
wangxiaoshuang cb8bc506a7 项目文档上传弹框文件数量没有限制时2才显示上传文件夹按钮 2025-03-11 13:53:38 +08:00
caiyiling 7a69227888 邮件列表列宽调整
continuous-integration/drone/push Build is passing Details
2025-03-11 13:11:59 +08:00
caiyiling 0785219954 Merge branch 'main' of https://gitea.frp.extimaging.com/XCKJ/irc_web into main
continuous-integration/drone/push Build is passing Details
2025-03-11 11:52:52 +08:00
caiyiling b5f2cfeaff 国际化补充 2025-03-11 11:52:38 +08:00
wangxiaoshuang 4164b24bd9 Merge branch 'main' of https://gitea.frp.extimaging.com/XCKJ/irc_web
continuous-integration/drone/push Build is passing Details
2025-03-11 11:41:49 +08:00
wangxiaoshuang 49b723ab01 上传同名文件时进度条出错 2025-03-11 11:41:30 +08:00
caiyiling 0de49faed1 国际化补充
continuous-integration/drone/push Build is passing Details
2025-03-11 10:59:22 +08:00
caiyiling 7f85302c1b 国际化补充
continuous-integration/drone/push Build is passing Details
2025-03-11 10:42:34 +08:00
caiyiling 4305f2536c institutions模块国际化更改
continuous-integration/drone/push Build is passing Details
2025-03-11 10:30:07 +08:00
caiyiling 55783de27f Merge branch 'main' of https://gitea.frp.extimaging.com/XCKJ/irc_web into main
continuous-integration/drone/push Build is passing Details
2025-03-10 17:59:25 +08:00
caiyiling 465ea59906 国际化更改 2025-03-10 17:59:10 +08:00
wangxiaoshuang 81fab97ee4 项目文档部分字段去除排序
continuous-integration/drone/push Build is passing Details
2025-03-10 17:33:38 +08:00
wangxiaoshuang 2c93ba2882 国际化修改
continuous-integration/drone/push Build is running Details
2025-03-10 17:31:42 +08:00
wangxiaoshuang f3a237b0bf 1
continuous-integration/drone/push Build is passing Details
2025-03-10 17:08:43 +08:00
caiyiling c0588661ce Merge branch 'main' of https://gitea.frp.extimaging.com/XCKJ/irc_web into main
continuous-integration/drone/push Build is passing Details
2025-03-10 16:11:22 +08:00
caiyiling 381acf8d76 ecrf表单中分类问题bug修复 2025-03-10 16:10:41 +08:00
wangxiaoshuang e6715a429b 项目文档阅片人简历、阅片人培训记录、阅片人阅片记录、阅片人医学审核记录
continuous-integration/drone/push Build is passing Details
2025-03-10 15:24:11 +08:00
caiyiling 33ac08f4e4 非dicom阅片更改
continuous-integration/drone/push Build is passing Details
2025-03-10 15:20:02 +08:00
caiyiling d117bac7f6 Merge branch 'main' of https://gitea.frp.extimaging.com/XCKJ/irc_web into main
continuous-integration/drone/push Build is passing Details
2025-03-10 15:09:37 +08:00
caiyiling 7051312855 国际化更改 2025-03-10 15:09:18 +08:00
wangxiaoshuang ff5a868377 项目文档部分问题修复
continuous-integration/drone/push Build is passing Details
2025-03-10 11:03:19 +08:00
wangxiaoshuang ea44f97985 非dicom列表改变状态时列表不重置
continuous-integration/drone/push Build is passing Details
2025-03-07 16:04:34 +08:00
wangxiaoshuang 156411fea3 非dicom列表改变状态时列表不重置
continuous-integration/drone/push Build is passing Details
2025-03-07 15:51:59 +08:00
wangxiaoshuang 822c2dc955 预览按钮位置交换
continuous-integration/drone/push Build is passing Details
2025-03-07 15:26:49 +08:00
wangxiaoshuang d729c4d34e 阅片期操作按钮样式问题
continuous-integration/drone/push Build is passing Details
2025-03-07 15:00:46 +08:00
caiyiling a887e686a8 Merge branch 'main' of https://gitea.frp.extimaging.com/XCKJ/irc_web into main
continuous-integration/drone/push Build is passing Details
2025-03-07 14:25:09 +08:00
caiyiling 21cb32f1a9 自定义阅片数值问题渲染bug修复 2025-03-07 14:24:32 +08:00
wangxiaoshuang c74b482f0d 非dicom预览样式调整
continuous-integration/drone/push Build is passing Details
2025-03-07 14:13:57 +08:00
wangxiaoshuang 1af302961b 非dicom预览样式调整
continuous-integration/drone/push Build is running Details
2025-03-07 14:11:53 +08:00
wangxiaoshuang e83ac6714d 非dicom列表获取参数iReading默认为false
continuous-integration/drone/push Build is passing Details
2025-03-07 13:37:22 +08:00
wangxiaoshuang fc98aa0312 1
continuous-integration/drone/push Build is running Details
2025-03-07 13:34:36 +08:00
wangxiaoshuang 278c051f51 质控非dicom添加预览阅片影像功能
continuous-integration/drone/push Build is passing Details
2025-03-07 12:23:40 +08:00
wangxiaoshuang 5b8716f9ae 质控删除后数据不显示
continuous-integration/drone/push Build is passing Details
2025-03-07 11:02:30 +08:00
wangxiaoshuang cfef89c703 根据角色权限表核对开放页面以及功能
continuous-integration/drone/push Build is passing Details
2025-03-06 15:37:13 +08:00
caiyiling bf33f9d589 中心调研表更改
continuous-integration/drone/push Build is passing Details
2025-03-06 15:15:09 +08:00
caiyiling d74da23d41 Merge branch 'main' of https://gitea.frp.extimaging.com/XCKJ/irc_web into main
continuous-integration/drone/push Build is passing Details
2025-03-06 15:10:50 +08:00
caiyiling cd630a70fb 阅片布局调整及中心调研更改 2025-03-06 15:10:11 +08:00
wangxiaoshuang 0b688bc33f PM在阅片期上传临床数据页面调整
continuous-integration/drone/push Build is passing Details
2025-03-06 14:56:28 +08:00
wangxiaoshuang a602be255b 项目文档部分问题修复
continuous-integration/drone/push Build is passing Details
2025-03-06 14:39:51 +08:00
wangxiaoshuang fb7891a2af 项目文档部分问题解决
continuous-integration/drone/push Build is passing Details
2025-03-06 13:20:47 +08:00
wangxiaoshuang 620f0d92ca 追溯角色可查看详情 2025-03-06 13:13:43 +08:00
wangxiaoshuang 8f43c697c0 Merge branch 'main' of https://gitea.frp.extimaging.com/XCKJ/irc_web
continuous-integration/drone/push Build is passing Details
2025-03-06 13:05:40 +08:00
wangxiaoshuang 55769e906d 项目文档菜单增加排序字段 2025-03-06 11:41:17 +08:00
caiyiling 4ad67e5501 Merge branch 'main' of https://gitea.frp.extimaging.com/XCKJ/irc_web into main
continuous-integration/drone/push Build is passing Details
2025-03-06 11:02:41 +08:00
caiyiling 1265cef6f9 系统标准阅片bug修复及非dicom阅片更改 2025-03-06 11:01:46 +08:00
wangxiaoshuang 86f5e2c782 非DICOM影像质控时,可以设置影像为删除、不阅片
continuous-integration/drone/push Build is passing Details
2025-03-05 16:14:29 +08:00
wangxiaoshuang 5450188a6e DICOM影像上传时缩略图的生成与存储
continuous-integration/drone/push Build is passing Details
2025-03-05 14:52:27 +08:00
wangxiaoshuang c8601f6f8f 文件模板
continuous-integration/drone/push Build is passing Details
2025-03-05 14:34:07 +08:00
wangxiaoshuang 299481a124 Merge branch 'uat'
continuous-integration/drone/push Build is passing Details
2025-03-05 13:32:23 +08:00
wangxiaoshuang 5ca123e90b 培训记录
continuous-integration/drone/push Build is running Details
2025-03-05 13:32:00 +08:00
wangxiaoshuang bc34ed5c25 Merge branch 'uat'
continuous-integration/drone/push Build is passing Details
2025-03-05 10:58:20 +08:00
wangxiaoshuang ecebeb2271 Merge branch 'uat'
continuous-integration/drone/push Build is passing Details
# Conflicts:
#	src/views/trials/trials-panel/visit/crc-upload/components/studyInfo.vue
#	src/views/trials/trials-panel/visit/crc-upload/components/uploadDicomFiles2.vue
2025-03-05 10:12:21 +08:00
wangxiaoshuang a0594cab96 培训记录
continuous-integration/drone/push Build is passing Details
2025-03-05 09:26:40 +08:00
wangxiaoshuang bcde358584 影像检查排序、字符集问题
continuous-integration/drone/push Build is passing Details
2025-03-04 16:16:04 +08:00
caiyiling 067162e1d7 自定义标准更改
continuous-integration/drone/push Build is passing Details
2025-03-04 11:48:00 +08:00
caiyiling b5b5830b1f Merge branch 'main' of https://gitea.frp.extimaging.com/XCKJ/irc_web into main
continuous-integration/drone/push Build is passing Details
2025-03-04 10:57:19 +08:00
caiyiling fb1d87e84b 非dicom阅片更改 2025-03-04 10:56:55 +08:00
wangxiaoshuang 6b42b4e88c 一般文件记录
continuous-integration/drone/push Build is passing Details
2025-03-03 17:54:07 +08:00
caiyiling 2516be481d Merge branch 'main' of https://gitea.frp.extimaging.com/XCKJ/irc_web into main
continuous-integration/drone/push Build is passing Details
2025-03-03 13:47:21 +08:00
caiyiling 3aa66af253 非dicom阅片更改 2025-03-03 13:46:57 +08:00
wangxiaoshuang fa339dcdb0 项目文档报告/文档功能实现
continuous-integration/drone/push Build is passing Details
2025-02-28 17:55:10 +08:00
wangxiaoshuang 541e309d1d 用户追溯添加跳转至项目详情
continuous-integration/drone/push Build is passing Details
2025-02-28 11:18:19 +08:00
wangxiaoshuang 949ec6d2d6 Merge branch 'uat'
continuous-integration/drone/push Build is passing Details
2025-02-28 11:02:37 +08:00
wangxiaoshuang 6b331ab6f6 项目文档
continuous-integration/drone/push Build is passing Details
2025-02-27 10:34:06 +08:00
wangxiaoshuang 00a7e8e609 部分问题修复 2025-02-27 10:33:57 +08:00
wangxiaoshuang c686850292 锁定弹窗支持邮箱校验
continuous-integration/drone/push Build is passing Details
2025-02-26 11:43:12 +08:00
wangxiaoshuang 887bb2534b Merge branch 'main' of https://gitea.frp.extimaging.com/XCKJ/irc_web
continuous-integration/drone/push Build is passing Details
2025-02-26 09:24:49 +08:00
wangxiaoshuang 3192ec7516 用户编辑保存按钮国际化 2025-02-26 09:24:42 +08:00
caiyiling 5f960348ed 1
continuous-integration/drone/push Build is passing Details
2025-02-25 17:55:17 +08:00
caiyiling d2757c6f9b Merge branch 'main' of https://gitea.frp.extimaging.com/XCKJ/irc_web into main
continuous-integration/drone/push Build is passing Details
2025-02-25 17:35:41 +08:00
caiyiling 734d6dc1a5 非dicom图像阅片更改 2025-02-25 17:35:02 +08:00
wangxiaoshuang be95951f40 用户来源问题修复
continuous-integration/drone/push Build is passing Details
2025-02-25 16:58:26 +08:00
wangxiaoshuang f4af0fc157 管理端用户列表角色过滤
continuous-integration/drone/push Build is passing Details
2025-02-25 11:31:56 +08:00
wangxiaoshuang 2090866521 管理端添加账号追溯页面 2025-02-25 11:31:32 +08:00
wangxiaoshuang d61131ed61 文件记录删除添加权限
continuous-integration/drone/push Build is passing Details
2025-02-25 09:52:36 +08:00
wangxiaoshuang 20aee53a3f 管理端添加文件记录列表
continuous-integration/drone/push Build is passing Details
2025-02-24 15:36:58 +08:00
wangxiaoshuang 05c75c32cf 角色与用户问题修复 2025-02-24 15:35:33 +08:00
wangxiaoshuang 2575e27d22 角色添加启用、停用功能
continuous-integration/drone/push Build is passing Details
2025-02-24 14:20:31 +08:00
wangxiaoshuang e7dcdb33c4 上传影像缩略图去除中心目录
continuous-integration/drone/push Build is passing Details
2025-02-24 09:04:59 +08:00
caiyiling d4c1b75423 1
continuous-integration/drone/push Build is passing Details
2025-02-21 17:05:36 +08:00
caiyiling d1159a09b4 图像窗口添加切换访视功能
continuous-integration/drone/push Build is running Details
2025-02-21 17:04:18 +08:00
caiyiling d69d8802cd Merge branch 'main' of https://gitea.frp.extimaging.com/XCKJ/irc_web into main
continuous-integration/drone/push Build is failing Details
2025-02-21 16:13:45 +08:00
caiyiling 6223eac81a 阅片页面图像预览更改 2025-02-21 16:13:17 +08:00
wangxiaoshuang b453eede31 打包配置修改,pdf预览文件
continuous-integration/drone/push Build is passing Details
2025-02-20 11:49:06 +08:00
wangxiaoshuang e5330765af 重阅审批页面查询条件中心初始化修改
continuous-integration/drone/push Build is passing Details
2025-02-20 10:07:29 +08:00
wangxiaoshuang 493b155678 国际化查询框换行问题
continuous-integration/drone/push Build is passing Details
2025-02-20 09:40:58 +08:00
wangxiaoshuang a2b2fd65af 国际化修改
continuous-integration/drone/push Build is passing Details
2025-02-19 11:25:57 +08:00
caiyiling 551cdf0ed3 工作台跳转中心调研异常bug修复
continuous-integration/drone/push Build is passing Details
2025-02-18 17:22:21 +08:00
caiyiling cadb3e8f7a 配置及样式更改
continuous-integration/drone/push Build is running Details
2025-02-18 17:15:09 +08:00
caiyiling 4da35daa3c cornerstone3D库升级及其他文件调整
continuous-integration/drone/push Build is failing Details
2025-02-18 15:09:25 +08:00
caiyiling 0f50ff6ded Merge branch 'main' of https://gitea.frp.extimaging.com/XCKJ/irc_web into main
continuous-integration/drone/push Build is passing Details
2025-02-17 17:18:04 +08:00
caiyiling 2f371f0435 1 2025-02-17 17:17:40 +08:00
wangxiaoshuang 245d4edca7 影像上传列表数据采集显示临床数据
continuous-integration/drone/push Build is passing Details
2025-02-17 14:56:11 +08:00
wangxiaoshuang 42d1c713bd 阅片人简历邮箱更改,admin禁用
continuous-integration/drone/push Build is passing Details
2025-02-17 13:35:47 +08:00
caiyiling 65b81fc633 Merge branch 'main' of https://gitea.frp.extimaging.com/XCKJ/irc_web into main
continuous-integration/drone/push Build is passing Details
2025-02-17 10:15:49 +08:00
caiyiling 3a1d4ee15d 阅片任务中反馈状态修复 2025-02-17 10:15:19 +08:00
wangxiaoshuang c0eab7e896 Merge branch 'uat'
continuous-integration/drone/push Build is passing Details
2025-02-17 09:46:49 +08:00
caiyiling bfe9817544 Merge branch 'uat' into main
continuous-integration/drone/push Build is passing Details
2025-02-14 17:42:54 +08:00
caiyiling 596ea8f658 Merge branch 'uat' into main
continuous-integration/drone/push Build is passing Details
2025-02-14 17:26:58 +08:00
caiyiling 4a479258f2 Merge branch 'uat' into main
continuous-integration/drone/push Build is passing Details
2025-02-14 17:06:14 +08:00
caiyiling 6de9cd26a4 影像阅片页面反馈按钮优化
continuous-integration/drone/push Build is passing Details
2025-02-14 16:07:40 +08:00
caiyiling caf3f41465 Merge branch 'uat' into main
continuous-integration/drone/push Build is passing Details
2025-02-14 14:52:03 +08:00
caiyiling 8896737a9e Merge branch 'main' of https://gitea.frp.extimaging.com/XCKJ/irc_web into main
continuous-integration/drone/push Build is passing Details
2025-02-14 14:32:57 +08:00
caiyiling 1be46686a3 国际化更改 2025-02-14 14:32:39 +08:00
wangxiaoshuang d74c0028f6 版本记录页面国际化
continuous-integration/drone/push Build is passing Details
2025-02-13 15:37:08 +08:00
wangxiaoshuang 129548031c 影像上传页面,临床数据统计
continuous-integration/drone/push Build is passing Details
2025-02-13 10:17:42 +08:00
caiyiling 689782bf36 后台管理页面部分国际化更改
continuous-integration/drone/push Build is passing Details
2025-02-13 09:25:32 +08:00
wangxiaoshuang 89fe4e4c00 阅片人简历邮箱更改
continuous-integration/drone/push Build is passing Details
2025-02-12 17:20:23 +08:00
wangxiaoshuang a582daf686 il8n页面国际化 2025-02-12 17:20:10 +08:00
wangxiaoshuang 3e680d0033 临床数据上传依赖,排序改为枚举值
continuous-integration/drone/push Build is passing Details
2025-02-11 14:39:01 +08:00
wangxiaoshuang af343d43d8 邮件模板预览样式调整
continuous-integration/drone/push Build is passing Details
2025-02-11 14:17:41 +08:00
wangxiaoshuang 4b9216229c 国际化编辑新增迭代版本、状态
continuous-integration/drone/push Build is passing Details
2025-02-11 13:13:39 +08:00
wangxiaoshuang 2952762ce7 切换角色、项目返回时清除项目路由缓存
continuous-integration/drone/push Build is passing Details
2025-02-10 10:42:10 +08:00
caiyiling 361aed4a0c dicom文件上传批量验证提示更改
continuous-integration/drone/push Build is passing Details
2025-02-10 09:22:44 +08:00
caiyiling 19b419c29e 一致性核查更改
continuous-integration/drone/push Build is passing Details
2025-02-08 15:06:11 +08:00
caiyiling 7e9a9b62f6 样式调整
continuous-integration/drone/push Build is passing Details
2025-02-08 14:10:00 +08:00
caiyiling 3921f369c3 阅片单元样式调整
continuous-integration/drone/push Build is passing Details
2025-02-08 13:07:46 +08:00
caiyiling 0ffe7ff1a7 Merge branch 'main' of https://gitea.frp.extimaging.com/XCKJ/irc_web into main
continuous-integration/drone/push Build is passing Details
2025-02-08 11:31:23 +08:00
caiyiling 5ec969c2f9 临床数据补充英文模板及界面样式调整 2025-02-08 11:30:07 +08:00
323 changed files with 43380 additions and 23350 deletions

View File

@ -2,6 +2,9 @@
ENV = 'prop' ENV = 'prop'
NODE_ENV = 'prop' NODE_ENV = 'prop'
# base public path
VUE_APP_BASE_PATH = '/'
# 是否开启登陆限制 true:是 false:否 # 是否开启登陆限制 true:是 false:否
VUE_APP_LOGIN_FOR_PERMISSION = true VUE_APP_LOGIN_FOR_PERMISSION = true

View File

@ -1,48 +1,58 @@
module.exports = { module.exports = {
root: true, root: true,
parserOptions: { parserOptions: {
parser: 'babel-eslint', parser: '@babel/eslint-parser',
sourceType: 'module' sourceType: 'module'
}, },
globals: { globals: {
"zzSessionStorage": true 'zzSessionStorage': true
}, },
env: { env: {
browser: true, browser: true,
node: true, node: true,
es6: true es6: true
}, },
extends: ["plugin:vue/recommended"], extends: ['plugin:vue/recommended'],
// add your custom rules here // add your custom rules here
//it is base on https://github.com/vuejs/eslint-config-vue // it is base on https://github.com/vuejs/eslint-config-vue
rules: { rules: {
"vue/max-attributes-per-line": [ // "rule-name": "off"
2, // "vue/max-attributes-per-line": [
// 2,
// {
// singleline: 10,
// multiline: {
// max: 1,
// allowFirstLine: false
// }
// }
// ],
'vue/max-attributes-per-line': [
'error',
{ {
singleline: 10, singleline: 10,
multiline: { multiline: {
max: 1, max: 1
allowFirstLine: false
} }
} }
], ],
"vue/singleline-html-element-content-newline": "off", 'vue/singleline-html-element-content-newline': 'off',
"vue/multiline-html-element-content-newline": "off", 'vue/multiline-html-element-content-newline': 'off',
"vue/name-property-casing": ["error", "PascalCase"], 'vue/name-property-casing': ['error', 'PascalCase'],
"vue/no-v-html": "off", 'vue/no-v-html': 'off',
"accessor-pairs": 2, 'accessor-pairs': 2,
"arrow-spacing": [ 'arrow-spacing': [
2, 2,
{ {
before: true, before: true,
after: true after: true
} }
], ],
"block-spacing": [2, "always"], 'block-spacing': [2, 'always'],
"brace-style": [ 'brace-style': [
2, 2,
"1tbs", '1tbs',
{ {
allowSingleLine: true allowSingleLine: true
} }
@ -50,31 +60,31 @@ module.exports = {
camelcase: [ camelcase: [
0, 0,
{ {
properties: "always" properties: 'always'
} }
], ],
"comma-dangle": [2, "never"], 'comma-dangle': [2, 'never'],
"comma-spacing": [ 'comma-spacing': [
2, 2,
{ {
before: false, before: false,
after: true after: true
} }
], ],
"comma-style": [2, "last"], 'comma-style': [2, 'last'],
"constructor-super": 2, 'constructor-super': 2,
curly: [2, "multi-line"], curly: [2, 'multi-line'],
"dot-location": [2, "property"], 'dot-location': [2, 'property'],
"eol-last": 2, 'eol-last': 2,
eqeqeq: ["error", "always", { null: "ignore" }], eqeqeq: ['error', 'always', { null: 'ignore' }],
"generator-star-spacing": [ 'generator-star-spacing': [
2, 2,
{ {
before: true, before: true,
after: true after: true
} }
], ],
"handle-callback-err": [2, "^(err|error)$"], 'handle-callback-err': [2, '^(err|error)$'],
indent: [ indent: [
2, 2,
2, 2,
@ -82,197 +92,197 @@ module.exports = {
SwitchCase: 1 SwitchCase: 1
} }
], ],
"jsx-quotes": [2, "prefer-single"], 'jsx-quotes': [2, 'prefer-single'],
"key-spacing": [ 'key-spacing': [
2, 2,
{ {
beforeColon: false, beforeColon: false,
afterColon: true afterColon: true
} }
], ],
"keyword-spacing": [ 'keyword-spacing': [
2, 2,
{ {
before: true, before: true,
after: true after: true
} }
], ],
"new-cap": [ 'new-cap': [
2, 2,
{ {
newIsCap: true, newIsCap: true,
capIsNew: false capIsNew: false
} }
], ],
"new-parens": 2, 'new-parens': 2,
"no-array-constructor": 2, 'no-array-constructor': 2,
"no-caller": 2, 'no-caller': 2,
"no-console": "off", 'no-console': 'off',
"no-class-assign": 2, 'no-class-assign': 2,
"no-cond-assign": 2, 'no-cond-assign': 2,
"no-const-assign": 2, 'no-const-assign': 2,
"no-control-regex": 0, 'no-control-regex': 0,
"no-delete-var": 2, 'no-delete-var': 2,
"no-dupe-args": 2, 'no-dupe-args': 2,
"no-dupe-class-members": 2, 'no-dupe-class-members': 2,
"no-dupe-keys": 2, 'no-dupe-keys': 2,
"no-duplicate-case": 2, 'no-duplicate-case': 2,
"no-empty-character-class": 2, 'no-empty-character-class': 2,
"no-empty-pattern": 2, 'no-empty-pattern': 2,
"no-eval": 2, 'no-eval': 2,
"no-ex-assign": 2, 'no-ex-assign': 2,
"no-extend-native": 2, 'no-extend-native': 2,
"no-extra-bind": 2, 'no-extra-bind': 2,
"no-extra-boolean-cast": 2, 'no-extra-boolean-cast': 2,
"no-extra-parens": [2, "functions"], 'no-extra-parens': [2, 'functions'],
"no-fallthrough": 2, 'no-fallthrough': 2,
"no-floating-decimal": 2, 'no-floating-decimal': 2,
"no-func-assign": 2, 'no-func-assign': 2,
"no-implied-eval": 2, 'no-implied-eval': 2,
"no-inner-declarations": [2, "functions"], 'no-inner-declarations': [2, 'functions'],
"no-invalid-regexp": 2, 'no-invalid-regexp': 2,
"no-irregular-whitespace": 2, 'no-irregular-whitespace': 2,
"no-iterator": 2, 'no-iterator': 2,
"no-label-var": 2, 'no-label-var': 2,
"no-labels": [ 'no-labels': [
2, 2,
{ {
allowLoop: false, allowLoop: false,
allowSwitch: false allowSwitch: false
} }
], ],
"no-lone-blocks": 2, 'no-lone-blocks': 2,
"no-mixed-spaces-and-tabs": 2, 'no-mixed-spaces-and-tabs': 2,
"no-multi-spaces": 2, 'no-multi-spaces': 2,
"no-multi-str": 2, 'no-multi-str': 2,
"no-multiple-empty-lines": [ 'no-multiple-empty-lines': [
2, 2,
{ {
max: 1 max: 1
} }
], ],
"no-native-reassign": 2, 'no-native-reassign': 2,
"no-negated-in-lhs": 2, 'no-negated-in-lhs': 2,
"no-new-object": 2, 'no-new-object': 2,
"no-new-require": 2, 'no-new-require': 2,
"no-new-symbol": 2, 'no-new-symbol': 2,
"no-new-wrappers": 2, 'no-new-wrappers': 2,
"no-obj-calls": 2, 'no-obj-calls': 2,
"no-octal": 2, 'no-octal': 2,
"no-octal-escape": 2, 'no-octal-escape': 2,
"no-path-concat": 2, 'no-path-concat': 2,
"no-proto": 2, 'no-proto': 2,
"no-redeclare": 2, 'no-redeclare': 2,
"no-regex-spaces": 2, 'no-regex-spaces': 2,
"no-return-assign": [2, "except-parens"], 'no-return-assign': [2, 'except-parens'],
"no-self-assign": 2, 'no-self-assign': 2,
"no-self-compare": 2, 'no-self-compare': 2,
"no-sequences": 2, 'no-sequences': 2,
"no-shadow-restricted-names": 2, 'no-shadow-restricted-names': 2,
"no-spaced-func": 2, 'no-spaced-func': 2,
"no-sparse-arrays": 2, 'no-sparse-arrays': 2,
"no-this-before-super": 2, 'no-this-before-super': 2,
"no-throw-literal": 2, 'no-throw-literal': 2,
"no-trailing-spaces": 2, 'no-trailing-spaces': 2,
"no-undef": 2, 'no-undef': 2,
"no-undef-init": 2, 'no-undef-init': 2,
"no-unexpected-multiline": 2, 'no-unexpected-multiline': 2,
"no-unmodified-loop-condition": 2, 'no-unmodified-loop-condition': 2,
"no-unneeded-ternary": [ 'no-unneeded-ternary': [
2, 2,
{ {
defaultAssignment: false defaultAssignment: false
} }
], ],
"no-unreachable": 2, 'no-unreachable': 2,
"no-unsafe-finally": 2, 'no-unsafe-finally': 2,
"no-unused-vars": [ 'no-unused-vars': [
2, 2,
{ {
vars: "all", vars: 'all',
args: "none" args: 'none'
} }
], ],
"no-useless-call": 2, 'no-useless-call': 2,
"no-useless-computed-key": 2, 'no-useless-computed-key': 2,
"no-useless-constructor": 2, 'no-useless-constructor': 2,
"no-useless-escape": 0, 'no-useless-escape': 0,
"no-whitespace-before-property": 2, 'no-whitespace-before-property': 2,
"no-with": 2, 'no-with': 2,
"one-var": [ 'one-var': [
2, 2,
{ {
initialized: "never" initialized: 'never'
} }
], ],
"operator-linebreak": [ 'operator-linebreak': [
2, 2,
"after", 'after',
{ {
overrides: { overrides: {
"?": "before", '?': 'before',
":": "before" ':': 'before'
} }
} }
], ],
"padded-blocks": [2, "never"], 'padded-blocks': [2, 'never'],
quotes: [ quotes: [
2, 2,
"single", 'single',
{ {
avoidEscape: true, avoidEscape: true,
allowTemplateLiterals: true allowTemplateLiterals: true
} }
], ],
semi: [2, "never"], semi: [2, 'never'],
"semi-spacing": [ 'semi-spacing': [
2, 2,
{ {
before: false, before: false,
after: true after: true
} }
], ],
"space-before-blocks": [2, "always"], 'space-before-blocks': [2, 'always'],
"space-before-function-paren": [2, "never"], 'space-before-function-paren': [2, 'never'],
"space-in-parens": [2, "never"], 'space-in-parens': [2, 'never'],
"space-infix-ops": 2, 'space-infix-ops': 2,
"space-unary-ops": [ 'space-unary-ops': [
2, 2,
{ {
words: true, words: true,
nonwords: false nonwords: false
} }
], ],
"spaced-comment": [ 'spaced-comment': [
2, 2,
"always", 'always',
{ {
markers: [ markers: [
"global", 'global',
"globals", 'globals',
"eslint", 'eslint',
"eslint-disable", 'eslint-disable',
"*package", '*package',
"!", '!',
"," ','
] ]
} }
], ],
"template-curly-spacing": [2, "never"], 'template-curly-spacing': [2, 'never'],
"use-isnan": 2, 'use-isnan': 2,
"valid-typeof": 2, 'valid-typeof': 2,
"wrap-iife": [2, "any"], 'wrap-iife': [2, 'any'],
"yield-star-spacing": [2, "both"], 'yield-star-spacing': [2, 'both'],
yoda: [2, "never"], yoda: [2, 'never'],
"prefer-const": 2, 'prefer-const': 2,
//"no-debugger": process.env.NODE_ENV === "production" ? 2 : 0, // "no-debugger": process.env.NODE_ENV === "production" ? 2 : 0,
"object-curly-spacing": [ 'object-curly-spacing': [
2, 2,
"always", 'always',
{ {
objectsInObjects: false objectsInObjects: false
} }
], ],
"array-bracket-spacing": [2, "never"] 'array-bracket-spacing': [2, 'never']
} }
}; }

View File

@ -1,10 +1,12 @@
module.exports = { module.exports = {
presets: [ presets: [
'@vue/cli-plugin-babel/preset', // '@vue/cli-plugin-babel/preset',
// ["@babel/preset-env", { "modules": false }]
'@babel/preset-env' '@babel/preset-env'
], ],
plugins: [ plugins: [
'@babel/plugin-proposal-optional-chaining', '@vue/babel-plugin-transform-vue-jsx'
'@babel/plugin-proposal-nullish-coalescing-operator' // '@babel/plugin-proposal-optional-chaining',
// '@babel/plugin-proposal-nullish-coalescing-operator'
] ]
} }

36966
package-lock.json generated

File diff suppressed because it is too large Load Diff

View File

@ -14,23 +14,20 @@
"i18n:en": "node i18nGenerate.js lang=en keyCol=5 valCol=7" "i18n:en": "node i18nGenerate.js lang=en keyCol=5 valCol=7"
}, },
"dependencies": { "dependencies": {
"@aws-sdk/client-s3": "^3.370.0", "@aws-sdk/client-s3": "^3.701.0",
"@cornerstonejs/adapters": "^2.19.7",
"@cornerstonejs/calculate-suv": "^1.1.0", "@cornerstonejs/calculate-suv": "^1.1.0",
"@cornerstonejs/core": "^1.27.4", "@cornerstonejs/core": "^2.19.7",
"@cornerstonejs/dicom-image-loader": "^1.27.4", "@cornerstonejs/dicom-image-loader": "^2.19.7",
"@cornerstonejs/streaming-image-volume-loader": "1.23.2", "@cornerstonejs/tools": "^2.19.7",
"@cornerstonejs/tools": "^1.27.4", "@icr/polyseg-wasm": "^0.4.0",
"@ffmpeg/core": "^0.10.0", "@microsoft/signalr": "^8.0.7",
"@ffmpeg/ffmpeg": "^0.10.1", "@riophae/vue-treeselect": "^0.4.0",
"@microsoft/signalr": "^6.0.8",
"@riophae/vue-treeselect": "0.4.0",
"@vue-office/docx": "^1.6.2", "@vue-office/docx": "^1.6.2",
"@vue-office/excel": "^1.7.11", "@vue-office/excel": "^1.7.11",
"@vue/composition-api": "^1.7.2", "@vue/composition-api": "^1.7.2",
"ali-oss": "^6.17.1", "ali-oss": "^6.17.1",
"axios": "0.18.1", "axios": "^0.18.1",
"babel-eslint": "7.2.3",
"copy-webpack-plugin": "^4.5.2",
"core-js": "^3.8.3", "core-js": "^3.8.3",
"cornerstone-core": "^2.6.1", "cornerstone-core": "^2.6.1",
"cornerstone-math": "^0.1.10", "cornerstone-math": "^0.1.10",
@ -41,67 +38,68 @@
"dicom-parser": "^1.8.9", "dicom-parser": "^1.8.9",
"dicomedit": "^0.1.0", "dicomedit": "^0.1.0",
"echarts": "^4.8.0", "echarts": "^4.8.0",
"element-ui": "^2.15.8", "element-ui": "^2.15.14",
"exceljs": "^4.1.0", "exceljs": "^4.4.0",
"file-saver": "^2.0.5", "file-saver": "^2.0.5",
"hammerjs": "^2.0.8", "hammerjs": "^2.0.8",
"html2canvas": "^1.4.1", "html2canvas": "^1.4.1",
"js-md5": "^0.7.3", "js-md5": "^0.8.3",
"jsencrypt": "^3.3.2", "jsencrypt": "^3.3.2",
"jszip": "^3.7.1", "jszip": "^3.10.1",
"moment": "^2.27.0", "minio": "^7.1.3",
"node-polyfill-webpack-plugin": "^2.0.1", "moment": "^2.30.1",
"node-sass": "^4.14.1", "moment-timezone": "^0.5.46",
"normalize.css": "7.0.0", "node-xlsx": "^0.24.0",
"nprogress": "0.2.0", "normalize.css": "^8.0.1",
"path-to-regexp": "2.4.0", "nprogress": "^0.2.0",
"pdfobject": "^2.2.8", "path-to-regexp": "^0.1.10",
"popper.js": "^1.16.1", "pdfobject": "^2.3.0",
"qrcodejs2": "0.0.2", "qrcodejs2": "^0.0.2",
"sass-loader": "^8.0.0", "screenfull": "^6.0.2",
"screenfull": "^4.2.0", "sortablejs": "^1.15.5",
"sortablejs": "^1.15.0",
"streamsaver": "^2.0.6", "streamsaver": "^2.0.6",
"v-viewer": "^1.6.4", "svg-sprite-loader": "^4.1.3",
"svgo": "^1.2.2",
"v-viewer": "^1.7.4",
"vcrontab": "^0.3.5", "vcrontab": "^0.3.5",
"vue": "^2.6.11", "vue": "^2.6.14",
"vue-clipboard2": "^0.3.1", "vue-clipboard2": "^0.3.3",
"vue-contextmenujs": "^1.3.13", "vue-contextmenujs": "^1.4.11",
"vue-count-to": "^1.0.13", "vue-count-to": "^1.0.13",
"vue-demi": "^0.14.6", "vue-demi": "^0.14.10",
"vue-i18n": "^8.7.0", "vue-i18n": "^8.28.2",
"vue-pdf": "^4.3.0",
"vue-puzzle-vcode": "^1.1.10", "vue-puzzle-vcode": "^1.1.10",
"vue-router": "3.0.6", "vue-router": "^3.0.6",
"vue-seamless-scroll": "^1.1.21", "vue-seamless-scroll": "^1.1.23",
"vuedraggable": "^2.24.3", "vuedraggable": "^2.24.3",
"vuex": "3.1.0", "vuex": "^3.1.0",
"webpack-aliyun-oss": "^0.4.9" "webpack-aliyun-oss": "^0.3.13"
}, },
"devDependencies": { "devDependencies": {
"@babel/plugin-proposal-nullish-coalescing-operator": "^7.18.6", "@babel/core": "^7.12.16",
"@babel/plugin-proposal-optional-chaining": "^7.21.0", "@babel/eslint-parser": "^7.12.16",
"@vue/cli-plugin-babel": "~4.5.4", "@babel/plugin-transform-class-static-block": "^7.26.0",
"@vue/cli-plugin-eslint": "~4.5.4", "@vue/babel-plugin-transform-vue-jsx": "^1.4.0",
"@vue/cli-service": "~4.5.4", "@vue/cli-plugin-babel": "~5.0.0",
"autoprefixer": "^9.5.1", "@vue/cli-plugin-eslint": "~5.0.0",
"aws-sdk": "^2.1532.0", "@vue/cli-service": "~5.0.0",
"babel-eslint": "^10.1.0", "autoprefixer": "^10.4.20",
"chalk": "2.4.2", "clean-webpack-plugin": "^4.0.0",
"connect": "3.6.6", "copy-webpack-plugin": "^12.0.2",
"eslint": "^6.7.2", "css-minimizer-webpack-plugin": "^7.0.0",
"eslint-plugin-vue": "^6.2.2", "eslint": "^7.32.0",
"html-webpack-plugin": "3.2.0", "eslint-plugin-vue": "^8.0.3",
"minio": "^7.1.3", "html-webpack-plugin": "^5.6.3",
"moment-timezone": "^0.5.45", "mini-css-extract-plugin": "^2.9.2",
"node-xlsx": "^0.21.0", "node-polyfill-webpack-plugin": "^4.0.0",
"runjs": "^4.3.2", "path-browserify": "^1.0.1",
"script-ext-html-webpack-plugin": "2.1.3", "process": "^0.11.10",
"script-loader": "0.7.2", "sass": "^1.63.2",
"serve-static": "^1.13.2", "sass-loader": "^10.4.1",
"svg-sprite-loader": "4.1.3", "terser-webpack-plugin": "^5.3.10",
"svgo": "1.2.2", "vue-template-compiler": "^2.6.14",
"vue-template-compiler": "^2.6.11" "webpack": "^5.96.1",
"webpack-bundle-analyzer": "^4.10.2"
}, },
"eslintConfig": { "eslintConfig": {
"root": true, "root": true,
@ -109,19 +107,19 @@
"node": true "node": true
}, },
"extends": [ "extends": [
"plugin:vue/essential" "plugin:vue/essential",
"eslint:recommended"
], ],
"parserOptions": { "parserOptions": {
"parser": "babel-eslint" "parser": "@babel/eslint-parser",
"requireConfigFile": false
}, },
"rules": {} "rules": {}
}, },
"engines": {
"node": ">=8.9",
"npm": ">= 3.0.0"
},
"browserslist": [ "browserslist": [
"> 1%", "> 1%",
"last 2 versions" "last 2 versions",
"not dead",
"not op_mini all"
] ]
} }

197
public/cease.html Normal file

File diff suppressed because one or more lines are too long

View File

@ -29,7 +29,7 @@
direction="rtl" direction="rtl"
size="80%" size="80%"
> >
<div style="width: 620px"> <div style="width: 800px">
<el-form <el-form
label-width="100px" label-width="100px"
@submit.native.prevent @submit.native.prevent
@ -40,7 +40,7 @@
<el-form-item :label="$t('il8n:search:keyword')"> <el-form-item :label="$t('il8n:search:keyword')">
<el-input v-model="key" @input="keyChange" /> <el-input v-model="key" @input="keyChange" />
</el-form-item> </el-form-item>
<el-form-item :label="$t('il8n:search:state')" v-if="il8nExternal"> <el-form-item :label="$t('il8n:search:state')">
<el-select <el-select
v-model="State" v-model="State"
clearable clearable
@ -62,12 +62,14 @@
v-adaptive="{ bottomOffset: 50 }" v-adaptive="{ bottomOffset: 50 }"
height="100" height="100"
style="width: 100%" style="width: 100%"
@sort-change="handleSortByColumn"
> >
<el-table-column <el-table-column
prop="Code" prop="Code"
:label="$t('il8n:table:label')" :label="$t('il8n:table:label')"
width="300" width="300"
show-overflow-tooltip show-overflow-tooltip
sortable="custom"
> >
</el-table-column> </el-table-column>
<!-- <el-table-column--> <!-- <el-table-column-->
@ -79,7 +81,11 @@
<!-- {{scope.row.Description}}--> <!-- {{scope.row.Description}}-->
<!-- </template>--> <!-- </template>-->
<!-- </el-table-column>--> <!-- </el-table-column>-->
<el-table-column prop="Value" :label="$t('il8n:table:en')"> <el-table-column
prop="Value"
:label="$t('il8n:table:en')"
sortable="custom"
>
<template slot-scope="scope"> <template slot-scope="scope">
<el-input <el-input
v-model="scope.row.Value" v-model="scope.row.Value"
@ -92,7 +98,11 @@
></el-input> ></el-input>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column prop="ValueCN" :label="$t('il8n:table:cn')"> <el-table-column
prop="ValueCN"
:label="$t('il8n:table:cn')"
sortable="custom"
>
<template slot-scope="scope"> <template slot-scope="scope">
<el-input <el-input
v-model="scope.row.ValueCN" v-model="scope.row.ValueCN"
@ -108,7 +118,7 @@
<el-table-column <el-table-column
prop="ValueCN" prop="ValueCN"
:label="$t('il8n:table:state')" :label="$t('il8n:table:state')"
v-if="il8nExternal" sortable="custom"
> >
<template slot-scope="scope"> <template slot-scope="scope">
<el-select <el-select
@ -126,12 +136,20 @@
</el-select> </el-select>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column
prop="Version"
:label="$t('il8n:table:Version')"
sortable="custom"
>
</el-table-column>
</el-table> </el-table>
<div style="text-align: right; padding-top: 10px; padding-right: 10px"> <div style="text-align: right; padding-top: 10px; padding-right: 10px">
<el-button size="mini" @click="drawer = false">取消 </el-button> <el-button size="mini" @click="drawer = false"
<el-button size="mini" type="primary" @click="handleSave" >{{ $t('common:button:cancel') }}
>保存</el-button </el-button>
> <el-button size="mini" type="primary" @click="handleSave">{{
$t('common:button:save')
}}</el-button>
</div> </div>
</el-drawer> </el-drawer>
<feedBack v-if="$route.matched.length > 0" /> <feedBack v-if="$route.matched.length > 0" />
@ -195,6 +213,18 @@ export default {
// }, // },
// }, // },
methods: { methods: {
//
handleSortByColumn(column) {
if (column.order === 'ascending') {
this.tableData.sort((a, b) =>
a[column.prop].localeCompare(b[column.prop])
)
} else {
this.tableData.sort((a, b) =>
b[column.prop].localeCompare(a[column.prop])
)
}
},
handleStateChange() { handleStateChange() {
this.tableData.forEach((item) => { this.tableData.forEach((item) => {
item.State = this.State item.State = this.State
@ -209,9 +239,12 @@ export default {
[], [],
this.arr.filter( this.arr.filter(
(v) => (v) =>
~v.Code.toLowerCase().indexOf(this.key.toLowerCase()) || (v.Code &&
~v.Value.toLowerCase().indexOf(this.key.toLowerCase()) || ~v.Code.toLowerCase().indexOf(this.key.toLowerCase())) ||
~v.ValueCN.toLowerCase().indexOf(this.key.toLowerCase()) (v.Value &&
~v.Value.toLowerCase().indexOf(this.key.toLowerCase())) ||
(v.ValueCN &&
~v.ValueCN.toLowerCase().indexOf(this.key.toLowerCase()))
) )
) )
} else { } else {
@ -219,33 +252,39 @@ export default {
} }
}, },
handleSave() { handleSave() {
this.$confirm('确定修改当前页面国际化内容?').then(() => { this.$confirm('确定修改当前页面国际化内容?')
batchAddOrUpdateFrontInternationalization(this.tableData).then( .then(() => {
async (res) => { batchAddOrUpdateFrontInternationalization(this.tableData).then(
var zhMessages = {}, async (res) => {
enMessages = {} var zhMessages = {},
var Internationalization = await getFrontInternationalizationList() enMessages = {}
Vue.prototype.$tl = Internationalization.Result var Internationalization =
this.tableData.forEach((v) => { await getFrontInternationalizationList()
// zhMessages[v.Description + '_' + v.Code] = v.ValueCN Vue.prototype.$tl = Internationalization.Result
// enMessages[v.Description + '_' + v.Code] = v.Value this.tableData.forEach((v) => {
zhMessages[v.Code] = v.ValueCN // zhMessages[v.Description + '_' + v.Code] = v.ValueCN
enMessages[v.Code] = v.Value // enMessages[v.Description + '_' + v.Code] = v.Value
}) zhMessages[v.Code] = v.ValueCN
i18n.mergeLocaleMessage('zh', zhMessages) enMessages[v.Code] = v.Value
i18n.mergeLocaleMessage('en', enMessages) })
this.drawer = false i18n.mergeLocaleMessage('zh', zhMessages)
this.$message.success('国际化修改成功') i18n.mergeLocaleMessage('en', enMessages)
if (this.il8nExternal) { this.drawer = false
this.$EventBus.$emit('il8nUpdate') this.$message.success('国际化修改成功')
if (this.il8nExternal) {
this.$EventBus.$emit('il8nUpdate')
}
} }
} )
) })
}) .catch((err) => {
console.log(err)
})
}, },
openI18n(ARRAY) { openI18n(ARRAY) {
this.tableData = [] this.tableData = []
this.il8nExternal = false this.il8nExternal = false
this.State = null
this.key = null this.key = null
this.drawer = true this.drawer = true
let arr = [] let arr = []
@ -266,6 +305,8 @@ export default {
Value: item.Value, Value: item.Value,
ValueCN: item.ValueCN, ValueCN: item.ValueCN,
State: item.State, State: item.State,
Version: item.Version,
InternationalizationType: item.InternationalizationType,
} }
}) })
this.tableData = Object.assign([], tableData) this.tableData = Object.assign([], tableData)
@ -296,6 +337,9 @@ export default {
Description: null, Description: null,
Value: null, Value: null,
ValueCN: null, ValueCN: null,
State: 0,
Version: this.$version.Version,
InternationalizationType: 0,
}) })
} }
}) })

View File

@ -342,3 +342,11 @@ export function addNewUserSendEmail(data) {
data data
}) })
} }
// 用户追溯
export function getUserJoinedTrialList(data) {
return request({
url: `/TrialMaintenance/getUserJoinedTrialList`,
method: 'post',
data
})
}

View File

@ -1069,4 +1069,255 @@ export function batchAddEnrollOrPdEmailConfig(params) {
method: 'post', method: 'post',
params params
}) })
} }
// 文件记录-系统文件列表
export function getSysFileTypeList(data) {
return request({
url: `/SysFileType/getSysFileTypeList`,
method: 'post',
data
})
}
// 文件记录-新增/编辑系统文件
export function addOrUpdateSysFileType(data) {
return request({
url: `/SysFileType/addOrUpdateSysFileType`,
method: 'post',
data
})
}
// 文件记录-删除系统文件
export function deleteSysFileType(id) {
return request({
url: `/SysFileType/deleteSysFileType/${id}`,
method: 'delete'
})
}
// 项目文档-获取项目菜单
export function getTrialFileTypeData(data) {
return request({
url: `/TrialFileType/getTrialFileTypeData`,
method: 'post',
data
})
}
// 项目文档-修改项目菜单启用
export function setAuthorizedView(data) {
return request({
url: `/TrialFileType/setAuthorizedView`,
method: 'post',
data
})
}
// 项目文档-新增/修改项目菜单
export function addOrUpdateTrialFileType(data) {
return request({
url: `/TrialFileType/addOrUpdateTrialFileType`,
method: 'post',
data
})
}
// 项目文档-删除项目菜单
export function deleteTrialFileType(id) {
return request({
url: `/TrialFileType/deleteTrialFileType/${id}`,
method: 'delete',
})
}
// 项目文档-报告/文档列表
export function getTrialFinalRecordList(data) {
return request({
url: `/TrialFinalRecord/getTrialFinalRecordList`,
method: 'post',
data
})
}
// 项目文档-报告/文档授权
export function authorizedTrialFinalRecord(data) {
return request({
url: `/TrialFinalRecord/authorizedTrialFinalRecord`,
method: 'post',
data
})
}
// 项目文档-报告/文档新增/修改
export function addOrUpdateTrialFinalRecord(data) {
return request({
url: `/TrialFinalRecord/addOrUpdateTrialFinalRecord`,
method: 'post',
data
})
}
// 项目文档-删除报告/文档
export function deleteTrialFinalRecord(id) {
return request({
url: `/TrialFinalRecord/deleteTrialFinalRecord/${id}`,
method: 'delete',
})
}
// 项目文档-一般文件记录列表
export function getTrialNormalRecordList(data) {
return request({
url: `/TrialNormalRecord/getTrialNormalRecordList`,
method: 'post',
data
})
}
// 项目文档-一般文件记录授权
export function authorizedTTrialNormalRecord(data) {
return request({
url: `/TrialNormalRecord/authorizedTTrialNormalRecord`,
method: 'post',
data
})
}
// 项目文档-一般文件记录批量新增
export function batchAddTrialNormalRecord(data) {
return request({
url: `/TrialNormalRecord/batchAddTrialNormalRecord`,
method: 'post',
data
})
}
// 项目文档-一般文件记录新增/修改
export function addOrUpdateTrialNormalRecord(data) {
return request({
url: `/TrialNormalRecord/addOrUpdateTrialNormalRecord`,
method: 'post',
data
})
}
// 项目文档-删除一般文件记录
export function deleteTrialNormalRecord(id) {
return request({
url: `/TrialNormalRecord/deleteTrialNormalRecord/${id}`,
method: 'delete',
})
}
// 项目文档-批量删除一般文件记录
export function deleteTrialNormalRecordList(data) {
return request({
url: `/TrialNormalRecord/deleteTrialNormalRecordList`,
method: 'post',
data
})
}
// 项目文档-培训记录列表
export function getTrialTrianingRecordList(data) {
return request({
url: `/TrialTrianingRecord/getTrialTrianingRecordList`,
method: 'post',
data
})
}
// 项目文档-培训记录新增/修改
export function addOrUpdateTrialTrianingRecord(data) {
return request({
url: `/TrialTrianingRecord/addOrUpdateTrialTrianingRecord`,
method: 'post',
data
})
}
// 项目文档-培训记录批量新增/修改
export function batchAddTrialTrianingRecord(data) {
return request({
url: `/TrialTrianingRecord/batchAddTrialTrianingRecord`,
method: 'post',
data
})
}
// 项目文档-删除培训记录
export function deleteTrialTrianingRecord(id) {
return request({
url: `/TrialTrianingRecord/deleteTrialTrianingRecord/${id}`,
method: 'delete',
})
}
// 项目文档-培训记录授权
export function authorizedTrialTrianingRecord(data) {
return request({
url: `/TrialTrianingRecord/authorizedTrialTrianingRecord`,
method: 'post',
data
})
}
// 项目文档-阅片人简历
export function getTrialDoctorList(data) {
return request({
url: `/DoctorList/getTrialDoctorList`,
method: 'post',
data
})
}
// 项目文档-上传同意入项记录
export function uploadTrialFileTypeFile(data) {
return request({
url: `/TrialFileType/uploadTrialFileTypeFile`,
method: 'post',
data
})
}
// 项目文档-获取上传同意入项记录
export function getTrialFileTypeFile(data) {
return request({
url: `/TrialFileType/getTrialFileTypeFile`,
method: 'post',
data
})
}
// 项目文档-删除上传同意入项记录
export function deleteTrialTypeFile(params) {
return request({
url: `/TrialFileType/deleteTrialTypeFile`,
method: 'post',
params
})
}
// 项目文档-获取资质材料列表
export function getTrialAttachments(data) {
return request({
url: `/Attachment/getTrialAttachments`,
method: 'post',
data
})
}
// 项目文档-修改资质材料稽查状态
export function setAuthorizedViewC(data) {
return request({
url: `/Attachment/setAuthorizedView`,
method: 'post',
data
})
}
// 项目文档-上传资质材料
export function saveTrialAttachments(data) {
return request({
url: `/Attachment/saveTrialAttachments`,
method: 'post',
data
})
}
// 项目文档-资质材料(获取医生列表)
export function getTrialDoctorListC(data) {
return request({
url: `/Attachment/getTrialDoctorList`,
method: 'post',
data
})
}
// 项目文档-修改资质材料
export function updateTrialAttachments(data) {
return request({
url: `/Attachment/updateTrialAttachments`,
method: 'post',
data
})
}
// 项目文档-删除资质材料
export function deleteAttachment(data) {
return request({
url: `/Attachment/deleteAttachment`,
method: 'post',
data
})
}

View File

@ -1080,7 +1080,13 @@ export function setSeriesStatus(trialId, subjectVisitId, studyId, seriesId, stat
method: 'put' method: 'put'
}) })
} }
export function setNodicomStudyState(params) {
return request({
url: `/QCOperation/setNodicomStudyState`,
method: 'put',
params
})
}
export function setInstanceStatus(trialId, subjectVisitId, seriesId, instanceId, state) { export function setInstanceStatus(trialId, subjectVisitId, seriesId, instanceId, state) {
return request({ return request({
url: `/QCOperation/setInstanceState/${trialId}/${subjectVisitId}/${seriesId}/${instanceId}/${state}`, url: `/QCOperation/setInstanceState/${trialId}/${subjectVisitId}/${seriesId}/${instanceId}/${state}`,
@ -1372,9 +1378,9 @@ export function getForwardList(param) {
}) })
} }
export function getNoneDicomStudyList(subjectVisitId, sudyId = '', isFilterZip = false, visitTaskId = '') { export function getNoneDicomStudyList(subjectVisitId, sudyId = '', isFilterZip = false, visitTaskId = '', IsReading = false) {
return request({ return request({
url: `/NoneDicomStudy/getNoneDicomStudyList?subjectVisitId=${subjectVisitId}&nonedicomStudyId=${sudyId}&isFilterZip=${isFilterZip}&visitTaskId=${visitTaskId}`, url: `/NoneDicomStudy/getNoneDicomStudyList?subjectVisitId=${subjectVisitId}&nonedicomStudyId=${sudyId}&isFilterZip=${isFilterZip}&visitTaskId=${visitTaskId}&IsReading=${IsReading}`,
method: 'get' method: 'get'
}) })
} }
@ -3940,8 +3946,6 @@ export function updateTrialUserRole(data) {
}) })
} }
// 获取报表配置 // 获取报表配置
export function getTrialQuestionExportResult(data) { export function getTrialQuestionExportResult(data) {
return request({ return request({
@ -3965,4 +3969,29 @@ export function trialUserSendJoinEmail(data) {
method: 'post', method: 'post',
data data
}) })
} }
// 获取非Dicom标记
export function getNoneDicomMarkListOutDto(data) {
return request({
url: `/ReadingImageTask/getNoneDicomMarkListOutDto`,
method: 'post',
data
})
}
// 添加非Dicom标记
export function addNoneDicomMark(data) {
return request({
url: `/ReadingImageTask/addNoneDicomMark`,
method: 'post',
data
})
}
// 删除非Dicom标记
export function deleteTrialFileType(id) {
return request({
url: `/ReadingImageTask/deleteTrialFileType/${id}`,
method: 'post'
})
}

View File

@ -110,4 +110,12 @@ export function addOrUpdateTrialBodyPart(data) {
data data
}) })
} }
// 修改检查名称列表
export function updateTrialStudyNameList(data) {
return request({
url: `/TrialConfig/updateTrialStudyNameList`,
method: 'post',
data
})
}

BIN
src/assets/pdf.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 8.7 KiB

BIN
src/assets/zip.jpg Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 16 KiB

View File

@ -4,6 +4,7 @@
<el-col :span="24"> <el-col :span="24">
<div class="box"> <div class="box">
<div class="box-body"> <div class="box-body">
<slot name="title-container" />
<div class="search"> <div class="search">
<slot name="search-container" /> <slot name="search-container" />
</div> </div>
@ -24,42 +25,42 @@ export default {
props: { props: {
noTitle: { noTitle: {
type: Boolean, type: Boolean,
default: false default: false,
} },
}, },
computed: { computed: {
contentClass() { contentClass() {
return this.noTitle ? 'content-notitle' : 'content' return this.noTitle ? 'content-notitle' : 'content'
} },
} },
} }
</script> </script>
<style lang="scss"> <style lang="scss">
.box-body{ .box-body {
padding: 0px; padding: 0px;
background-color: #fff; background-color: #fff;
.el-card__body { .el-card__body {
padding: 0px; padding: 0px;
} }
.search{ .search {
display: flex; display: flex;
padding: 5px; padding: 5px;
.mr5{ .mr5 {
margin-right:5px; margin-right: 5px;
}
.el-form-item{
margin-bottom: 10px;
}
} }
.page{ .el-form-item {
text-align: right; margin-bottom: 10px;
padding-top: 3px;
}
.el-button.is-circle {
padding: 9px;
font-weight: bold;
font-size: 14px;
} }
} }
.page {
text-align: right;
padding-top: 3px;
}
.el-button.is-circle {
padding: 9px;
font-weight: bold;
font-size: 14px;
}
}
</style> </style>

View File

@ -1,7 +1,7 @@
<!-- 搜索表单 --> <!-- 搜索表单 -->
<template> <template>
<div class="base-search-form"> <div class="base-search-form">
<el-form :size="size" :inline="true" :label-width="labelWidth"> <el-form :inline="true" :label-width="labelWidth">
<el-form-item <el-form-item
v-for="item in searchForm" v-for="item in searchForm"
:key="item.prop" :key="item.prop"
@ -146,17 +146,18 @@
<!-- 具名slot --> <!-- 具名slot -->
<slot v-if="item.type === 'Custom'" :name="item.slot" /> <slot v-if="item.type === 'Custom'" :name="item.slot" />
</el-form-item> </el-form-item>
<el-form-item v-for="item in searchHandle" :key="item.label"> <div style="display: inline-block;width: fit-content;">
<slot v-if="item.slot" :name="item.slot" /> <el-form-item v-for="item in searchHandle" :key="item.label">
<el-button <slot v-if="item.slot" :name="item.slot" />
v-else <el-button
:type="item.type" v-else
:size="item.size || size" :type="item.type"
:icon="item.icon || ''" :icon="item.icon || ''"
@click="handleClick(item.emitKey)" @click="handleClick(item.emitKey)"
>{{ item.label }}</el-button >{{ item.label }}</el-button
> >
</el-form-item> </el-form-item>
</div>
</el-form> </el-form>
</div> </div>
</template> </template>
@ -174,11 +175,11 @@ export default {
}, },
labelWidth: { labelWidth: {
type: String, type: String,
default: "", default: '',
}, },
size: { size: {
type: String, type: String,
default: "mini", default: 'mini',
}, },
searchForm: { searchForm: {
type: Array, type: Array,
@ -196,10 +197,10 @@ export default {
methods: { methods: {
handleClick(emitKey) { handleClick(emitKey) {
// emit // emit
this.$emit(`${emitKey}`); this.$emit(`${emitKey}`)
}, },
}, },
}; }
</script> </script>
<style lang="scss"> <style lang="scss">
.base-search-form { .base-search-form {

View File

@ -62,7 +62,6 @@
</a> --> </a> -->
<span v-for="(operate, i) in column.operates" :key="i"> <span v-for="(operate, i) in column.operates" :key="i">
<el-button <el-button
:size="operate.size || 'mini'"
:type="operate.type || 'primary'" :type="operate.type || 'primary'"
v-if=" v-if="
(operate.show && scope.row[operate.show]) || (operate.show && scope.row[operate.show]) ||

View File

@ -90,7 +90,7 @@
custom-class="base-dialog-wrapper" custom-class="base-dialog-wrapper"
append-to-body append-to-body
> >
<DicomTags :image-id="stack.imageIds[stack.currentImageIdIndex]" @close="dcmTag.visible = false" /> <dicom-tags :image-id="stack.imageIds[stack.currentImageIdIndex]" @close="dcmTag.visible = false" />
</el-dialog> </el-dialog>
</div> </div>
</template> </template>
@ -217,10 +217,10 @@ export default {
this.stack.description = dicomSeries.description this.stack.description = dicomSeries.description
this.toolState.viewportInvert = false this.toolState.viewportInvert = false
this.toolState.dicomInfoVisible = false this.toolState.dicomInfoVisible = false
var imageId = this.stack.imageIds[this.stack.currentImageIdIndex] // var imageId = this.stack.imageIds[this.stack.currentImageIdIndex]
var instanceId = imageId.split('/')[imageId.split('/').length - 1] // var instanceId = imageId.split('/')[imageId.split('/').length - 1]
instanceId = instanceId.split('.')[0] // instanceId = instanceId.split('.')[0]
this.stack.instanceId = instanceId // this.stack.instanceId = instanceId
this.toolState.clipPlaying = false this.toolState.clipPlaying = false
const element = this.$refs.canvas const element = this.$refs.canvas
cornerstone.enable(element) cornerstone.enable(element)
@ -346,9 +346,9 @@ export default {
// return // return
// } // }
// this.stack.instanceId = image.imageId.split('/')[image.imageId.split('/').length - 1] // this.stack.instanceId = image.imageId.split('/')[image.imageId.split('/').length - 1]
var instanceId = image.imageId.split('/')[image.imageId.split('/').length - 1] // var instanceId = image.imageId.split('/')[image.imageId.split('/').length - 1]
instanceId = instanceId.split('.')[0] // instanceId = instanceId.split('.')[0]
this.stack.instanceId = instanceId // this.stack.instanceId = instanceId
this.height = (this.stack.currentImageIdIndex) * 100 / (this.stack.imageIds.length - 1) this.height = (this.stack.currentImageIdIndex) * 100 / (this.stack.imageIds.length - 1)
this.resetWwwc() this.resetWwwc()
}, },
@ -415,15 +415,16 @@ export default {
}, },
onImageRendered(e) { onImageRendered(e) {
var imageId = e.detail.image.imageId // var imageId = e.detail.image.imageId
var instanceId = imageId.split('/')[imageId.split('/').length - 1] // var instanceId = imageId.split('/')[imageId.split('/').length - 1]
instanceId = instanceId.split('.')[0] // instanceId = instanceId.split('.')[0]
if (this.imageId !== instanceId) { // if (this.imageId !== instanceId) {
this.getOrientationMarker(e.detail.element) // this.getOrientationMarker(e.detail.element)
this.imageId = instanceId // this.imageId = instanceId
} // }
this.stack.instanceId = instanceId this.getOrientationMarker(e.detail.element)
// this.stack.instanceId = instanceId
var viewport = e.detail.viewport var viewport = e.detail.viewport
this.dicomInfo.wwwc = `${Math.round( this.dicomInfo.wwwc = `${Math.round(
viewport.voi.windowWidth viewport.voi.windowWidth

View File

@ -149,6 +149,7 @@ export default {
return isShow return isShow
}, },
goBack() { goBack() {
zzSessionStorage.removeItem('lastWorkbench')
this.$router.push({ path: '/trials/trials-list' }) this.$router.push({ path: '/trials/trials-list' })
}, },
selectTrials(v) { selectTrials(v) {

View File

@ -193,7 +193,7 @@
</el-col> </el-col>
<!-- eslint-disable vue/no-use-v-if-with-v-for --> <!-- eslint-disable vue/no-use-v-if-with-v-for -->
<!-- eslint-disable vue/valid-v-for --> <!-- eslint-disable vue/valid-v-for -->
<el-col v-for="(item) in question.Childrens" v-if="question.Childrens && question.Childrens.length>0 && question.ClinicalQuestionType !== 'table'" :span="['group', 'summary', 'table'].includes(item.ClinicalQuestionType) || item.Childrens.length > 0 ? 24 : 12"> <el-col v-for="(item) in question.Childrens" :key="item.Id" v-if="question.Childrens && question.Childrens.length>0 && question.ClinicalQuestionType !== 'table'" :span="['group', 'summary', 'table'].includes(item.ClinicalQuestionType) || item.Childrens.length > 0 ? 24 : 12">
<QuestionFormItem <QuestionFormItem
:key="item.Id" :key="item.Id"
:question="item" :question="item"
@ -593,7 +593,7 @@ export default {
<style lang="scss" scoped> <style lang="scss" scoped>
.my_dialog{ .my_dialog{
.criterion-form-item{ .criterion-form-item{
>>>.el-form-item__content{ ::v-deep .el-form-item__content{
width: auto; width: auto;
} }
} }
@ -614,7 +614,7 @@ export default {
margin-bottom: 0px; margin-bottom: 0px;
} }
.disabled{ .disabled{
>>>.el-upload--picture-card { ::v-deep .el-upload--picture-card {
display: none; display: none;
} }
} }

View File

@ -222,7 +222,7 @@ export default {
<style lang="scss" scoped> <style lang="scss" scoped>
.my_dialog{ .my_dialog{
.criterion-form-item{ .criterion-form-item{
>>>.el-form-item__content{ ::v-deep .el-form-item__content{
width: auto; width: auto;
} }
} }
@ -233,7 +233,7 @@ export default {
flex-direction: row; flex-direction: row;
align-items: flex-start; align-items: flex-start;
} }
>>>.el-form-item__content{ ::v-deep .el-form-item__content{
width: 500px; width: 500px;
} }
.el-input{ .el-input{
@ -243,7 +243,7 @@ export default {
margin-bottom: 0px; margin-bottom: 0px;
} }
.disabled{ .disabled{
>>>.el-upload--picture-card { ::v-deep .el-upload--picture-card {
display: none; display: none;
} }
} }

View File

@ -92,6 +92,7 @@ export default {
try { try {
if (!this.form.userRoleId) if (!this.form.userRoleId)
return this.$message.warning(this.$t('toggleRole:ruleMessage:select')) return this.$message.warning(this.$t('toggleRole:ruleMessage:select'))
zzSessionStorage.removeItem('lastWorkbench')
this.$emit('save', this.form.userRoleId) this.$emit('save', this.form.userRoleId)
} catch (err) { } catch (err) {
console.log(err) console.log(err)
@ -111,11 +112,11 @@ export default {
margin: auto; margin: auto;
} }
/deep/ .el-radio__original { ::v-deep .el-radio__original {
display: none !important; /* 隐藏原生 radio 输入,但仍然允许交互 */ display: none !important; /* 隐藏原生 radio 输入,但仍然允许交互 */
} }
/deep/.el-radio:focus:not(.is-focus):not(:active):not(.is-disabled) ::v-deep.el-radio:focus:not(.is-focus):not(:active):not(.is-disabled)
.el-radio__inner { .el-radio__inner {
box-shadow: none !important; box-shadow: none !important;
} }

View File

@ -316,9 +316,9 @@
scope.row.dicomInfo.fileCount scope.row.dicomInfo.fileCount
}} }}
({{ ({{
(scope.row.dicomInfo.uploadFileSize / 1024 / 1024).toFixed(2) (scope.row.dicomInfo.uploadFileSize / 1024 / 1024).toFixed(3)
}}MB/{{ }}MB/{{
(scope.row.dicomInfo.fileSize / 1024 / 1024).toFixed(2) (scope.row.dicomInfo.fileSize / 1024 / 1024).toFixed(3)
}}MB) }}MB)
</span> </span>
</template> </template>
@ -1308,7 +1308,7 @@ export default {
o.imageColumns, o.imageColumns,
o.imageRows o.imageRows
) )
let thumbnailPath = `/${params.trialId}/Image/${params.subjectId}/${params.subjectVisitId}/${dicomInfo.visitTaskId}/${dicomInfo.studyUid}/${v.seriesUid}.png` let thumbnailPath = `/${params.trialId}/Image/${params.subjectId}/${params.subjectVisitId}/${dicomInfo.visitTaskId}/${dicomInfo.studyUid}/${v.seriesUid}.jpg`
let OSSclient = scope.OSSclient let OSSclient = scope.OSSclient
let seriesRes = await OSSclient.put( let seriesRes = await OSSclient.put(
thumbnailPath, thumbnailPath,
@ -1421,7 +1421,7 @@ export default {
v.instanceList[0].imageColumns, v.instanceList[0].imageColumns,
v.instanceList[0].imageRows v.instanceList[0].imageRows
) )
let thumbnailPath = `/${params.trialId}/Image/${params.trialSiteId}/${params.subjectId}/${params.subjectVisitId}/${dicomInfo.studyUid}/${v.seriesUid}.png` let thumbnailPath = `/${params.trialId}/Image/${params.subjectId}/${params.subjectVisitId}/${dicomInfo.studyUid}/${v.seriesUid}.jpg`
let OSSclient = scope.OSSclient let OSSclient = scope.OSSclient
try { try {
let seriesRes = await OSSclient.put(thumbnailPath, blob) let seriesRes = await OSSclient.put(thumbnailPath, blob)
@ -1499,8 +1499,8 @@ export default {
return new Promise((resolve) => { return new Promise((resolve) => {
cornerstone.loadImage(imageId).then(async (image) => { cornerstone.loadImage(imageId).then(async (image) => {
let canvas = document.createElement('canvas') let canvas = document.createElement('canvas')
canvas.width = width canvas.width = (width * 60) / height
canvas.height = height canvas.height = 60
if (image) { if (image) {
cornerstone.renderToCanvas(canvas, image) cornerstone.renderToCanvas(canvas, image)
// Canvas PNG // Canvas PNG

View File

@ -66,7 +66,7 @@
<template slot-scope="scope"> <template slot-scope="scope">
<span>{{ <span>{{
scope.row.FileSize && scope.row.FileSize > 0 scope.row.FileSize && scope.row.FileSize > 0
? `${(scope.row.FileSize / 1024 / 1024).toFixed(2)}MB` ? `${(scope.row.FileSize / 1024 / 1024).toFixed(3)}MB`
: '' : ''
}}</span> }}</span>
</template> </template>
@ -138,7 +138,7 @@
<template slot-scope="scope"> <template slot-scope="scope">
<span>{{ <span>{{
scope.row.FileSize && scope.row.FileSize > 0 scope.row.FileSize && scope.row.FileSize > 0
? `${(scope.row.FileSize / 1024 / 1024).toFixed(2)}MB` ? `${(scope.row.FileSize / 1024 / 1024).toFixed(3)}MB`
: '' : ''
}}</span> }}</span>
</template> </template>
@ -320,7 +320,7 @@
<template slot-scope="scope"> <template slot-scope="scope">
<span>{{ <span>{{
scope.row.size && scope.row.size > 0 scope.row.size && scope.row.size > 0
? `${(scope.row.size / 1024 / 1024).toFixed(2)}MB` ? `${(scope.row.size / 1024 / 1024).toFixed(3)}MB`
: '' : ''
}}</span> }}</span>
</template> </template>

View File

@ -567,7 +567,7 @@ export default {
for (let i = 0; i < arr.length; i++) { for (let i = 0; i < arr.length; i++) {
let dicom = arr[i]; let dicom = arr[i];
if (dicom.StudyInstanceUid !== StudyInstanceUid) continue; if (dicom.StudyInstanceUid !== StudyInstanceUid) continue;
let thumbnailPath = `/${dicom.params.TrialId}/TaskImage/${dicom.params.SubjectId}/${dicom.params.VisitTaskId}/${dicom.StudyInstanceUid}/${dicom.SeriesInstanceUid}.png`; let thumbnailPath = `/${dicom.params.TrialId}/TaskImage/${dicom.params.SubjectId}/${dicom.params.VisitTaskId}/${dicom.StudyInstanceUid}/${dicom.SeriesInstanceUid}.jpg`;
if (!studyObj[dicom.StudyId]) { if (!studyObj[dicom.StudyId]) {
studyObj[dicom.StudyId] = { studyObj[dicom.StudyId] = {
StudyId: dicom.StudyId, StudyId: dicom.StudyId,

View File

@ -22,7 +22,7 @@
import { mapGetters } from 'vuex' import { mapGetters } from 'vuex'
import Logo from './Logo' import Logo from './Logo'
import SidebarItem from './SidebarItem' import SidebarItem from './SidebarItem'
import variables from '@/styles/variables.scss' import variables from '@/styles/variables.module.scss'
export default { export default {
components: { SidebarItem, Logo }, components: { SidebarItem, Logo },

View File

@ -73,7 +73,7 @@ export default {
position: relative; position: relative;
overflow: hidden; overflow: hidden;
width: 100%; width: 100%;
/deep/ { ::v-deep {
.el-scrollbar__bar { .el-scrollbar__bar {
bottom: 0px; bottom: 0px;
} }

View File

@ -57,7 +57,7 @@ export default {
<style lang="scss" scoped> <style lang="scss" scoped>
@import "~@/styles/mixin.scss"; @import "~@/styles/mixin.scss";
@import "~@/styles/variables.scss"; @import "~@/styles/variables.module.scss";
.app-wrapper { .app-wrapper {
@include clearfix; @include clearfix;

View File

@ -461,8 +461,8 @@ async function VueInit() {
var my_username = zzSessionStorage.getItem('my_username') var my_username = zzSessionStorage.getItem('my_username')
var my_password = zzSessionStorage.getItem('my_password') var my_password = zzSessionStorage.getItem('my_password')
let my_userid = zzSessionStorage.getItem('userId') let my_userid = zzSessionStorage.getItem('userId')
let my_EMail = zzSessionStorage.getItem('my_EMail') let my_EMail = zzSessionStorage.getItem('my_EMail') || ''
if (md5(_vm.unlock.my_password) === my_password && my_username === _vm.unlock.my_username) { if (md5(_vm.unlock.my_password) === my_password && (my_username === _vm.unlock.my_username || my_EMail.toUpperCase() === vm.unlock.my_username.toUpperCase())) {
resetReadingRestTime().then(() => { resetReadingRestTime().then(() => {
}) })
const closeLock = (_vm) => { const closeLock = (_vm) => {

View File

@ -7,15 +7,15 @@ import 'nprogress/nprogress.css'
import { getToken, removeToken } from '@/utils/auth' import { getToken, removeToken } from '@/utils/auth'
import Vue from 'vue' import Vue from 'vue'
import { OSSclient } from './utils/oss' import { OSSclient } from './utils/oss'
import WHITELIST from "./utils/whiteList" import WHITELIST from './utils/whiteList'
import { getTrialExtralConfig } from '@/api/trials' import { getTrialExtralConfig } from '@/api/trials'
// import getPageTitle from '@/utils/get-page-title' // import getPageTitle from '@/utils/get-page-title'
NProgress.configure({ showSpinner: false }) NProgress.configure({ showSpinner: false })
const whiteList = WHITELIST const whiteList = WHITELIST
store.state.trials.whiteList = whiteList; store.state.trials.whiteList = whiteList
router.beforeEach(async (to, from, next) => { router.beforeEach(async(to, from, next) => {
NProgress.start() NProgress.start()
// 设置页面标题 // 设置页面标题
// document.title = getPageTitle(to.meta.title) store.state.trials.whiteList.indexOf(to.path) === -1 // document.title = getPageTitle(to.meta.title) store.state.trials.whiteList.indexOf(to.path) === -1
@ -27,13 +27,13 @@ router.beforeEach(async (to, from, next) => {
to.query.trialId !== to.query.trialId !==
store.state.trials.config.trialId store.state.trials.config.trialId
) { ) {
let res = await getTrialExtralConfig({ const res = await getTrialExtralConfig({
TrialId: to.query.trialId, TrialId: to.query.trialId
}) })
if (res.IsSuccess) { if (res.IsSuccess) {
store.dispatch('trials/setConfig', { store.dispatch('trials/setConfig', {
trialId: to.query.trialId, trialId: to.query.trialId,
...res.Result, ...res.Result
}) })
} }
} }
@ -45,13 +45,13 @@ router.beforeEach(async (to, from, next) => {
to.query.trialId !== to.query.trialId !==
store.state.trials.config.trialId store.state.trials.config.trialId
) { ) {
let res = await getTrialExtralConfig({ const res = await getTrialExtralConfig({
TrialId: to.query.trialId, TrialId: to.query.trialId
}) })
if (res.IsSuccess) { if (res.IsSuccess) {
store.dispatch('trials/setConfig', { store.dispatch('trials/setConfig', {
trialId: to.query.trialId, trialId: to.query.trialId,
...res.Result, ...res.Result
}) })
} }
} }
@ -72,12 +72,12 @@ router.beforeEach(async (to, from, next) => {
NProgress.done() NProgress.done()
} else if (from.path === '/researchForm') { } else if (from.path === '/researchForm') {
removeToken() removeToken()
let lang = to.query.lang || zzSessionStorage.getItem('lang') const lang = to.query.lang || zzSessionStorage.getItem('lang')
next(`/researchLogin?trialId=${to.query.trialId}&lang=${lang}`) next(`/researchLogin?trialId=${to.query.trialId}&lang=${lang}`)
NProgress.done() NProgress.done()
} else if (from.path === '/researchDetail_m') { } else if (from.path === '/researchDetail_m') {
removeToken() removeToken()
let lang = to.query.lang || zzSessionStorage.getItem('lang') const lang = to.query.lang || zzSessionStorage.getItem('lang')
next(`/researchLogin_m?trialId=${to.query.trialId}&lang=${lang}`) next(`/researchLogin_m?trialId=${to.query.trialId}&lang=${lang}`)
NProgress.done() NProgress.done()
} else { } else {
@ -107,7 +107,7 @@ router.beforeEach(async (to, from, next) => {
/* has no token*/ /* has no token*/
if (whiteList.indexOf(to.path) !== -1) { if (whiteList.indexOf(to.path) !== -1) {
if (to.path === '/researchLogin') { if (to.path === '/researchLogin') {
let lang = to.query.lang || zzSessionStorage.getItem('lang') const lang = to.query.lang || zzSessionStorage.getItem('lang')
const flag = navigator.userAgent.match(/(phone|pad|pod|iPhone|iPod|ios|iPad|Android|Mobile|BlackBerry|IEMobile|MQQBrowser|JUC|Fennec|wOSBrowser|BrowserNG|WebOS|Symbian|Windows Phone)/i) const flag = navigator.userAgent.match(/(phone|pad|pod|iPhone|iPod|ios|iPad|Android|Mobile|BlackBerry|IEMobile|MQQBrowser|JUC|Fennec|wOSBrowser|BrowserNG|WebOS|Symbian|Windows Phone)/i)
if (flag) { if (flag) {
next(`/researchLogin_m?trialId=${to.query.trialId}&lang=${lang}`) next(`/researchLogin_m?trialId=${to.query.trialId}&lang=${lang}`)
@ -123,11 +123,11 @@ router.beforeEach(async (to, from, next) => {
} }
} else { } else {
if (to.path === '/researchForm') { if (to.path === '/researchForm') {
let lang = to.query.lang || zzSessionStorage.getItem('lang') const lang = to.query.lang || zzSessionStorage.getItem('lang')
next(`/researchLogin?trialId=${to.query.trialId}&lang=${lang}`) next(`/researchLogin?trialId=${to.query.trialId}&lang=${lang}`)
NProgress.done() NProgress.done()
} else if (to.path === '/researchDetail_m') { } else if (to.path === '/researchDetail_m') {
let lang = to.query.lang || zzSessionStorage.getItem('lang') const lang = to.query.lang || zzSessionStorage.getItem('lang')
next(`/researchLogin_m?trialId=${to.query.trialId}&lang=${lang}`) next(`/researchLogin_m?trialId=${to.query.trialId}&lang=${lang}`)
NProgress.done() NProgress.done()
} else if (to.path === '/ReviewersResearchForm') { } else if (to.path === '/ReviewersResearchForm') {

View File

@ -50,6 +50,11 @@ export const constantRoutes = [
component: () => import('@/views/login/index'), component: () => import('@/views/login/index'),
hidden: true hidden: true
}, },
// {
// path: '/test',
// component: () => import('@/views/test/index'),
// hidden: true
// },
{ {
path: '/resetpassword', path: '/resetpassword',
component: () => import('@/views/forgetpassword/index'), component: () => import('@/views/forgetpassword/index'),

View File

@ -1,7 +1,7 @@
// eslint-disable-next-line no-undef // eslint-disable-next-line no-undef
module.exports = { module.exports = {
title: 'IRCIS', title: 'IRC Imaging System',
/** /**
* @type {boolean} true | false * @type {boolean} true | false

View File

@ -48,6 +48,8 @@ const getters = {
TotalNeedSignSystemDocCount: state => state.user.TotalNeedSignSystemDocCount, TotalNeedSignSystemDocCount: state => state.user.TotalNeedSignSystemDocCount,
TotalNeedSignTrialDocCount: state => state.user.TotalNeedSignTrialDocCount, TotalNeedSignTrialDocCount: state => state.user.TotalNeedSignTrialDocCount,
IsFirstSysDocNeedSign: state => state.user.IsFirstSysDocNeedSign, IsFirstSysDocNeedSign: state => state.user.IsFirstSysDocNeedSign,
TrialStatusStr: state => state.user.TrialStatusStr TrialStatusStr: state => state.user.TrialStatusStr,
lastViewportTaskId: state => state.noneDicomReview.lastViewportTaskId,
currentTaskState: state => state.noneDicomReview.currentTaskState
} }
export default getters export default getters

View File

@ -12,7 +12,7 @@ import trials from './modules/trials'
import financials from './modules/financials' import financials from './modules/financials'
import reading from './modules/reading' import reading from './modules/reading'
import lang from './modules/lang' import lang from './modules/lang'
import noneDicomReview from './modules/noneDicomReview'
Vue.use(Vuex) Vue.use(Vuex)
const store = new Vuex.Store({ const store = new Vuex.Store({
@ -27,7 +27,8 @@ const store = new Vuex.Store({
trials, trials,
financials, financials,
reading, reading,
lang lang,
noneDicomReview
}, },
getters getters
}) })

View File

@ -0,0 +1,28 @@
const getDefaultState = () => {
return {
lastViewportTaskId: null,
currentTaskState: 0
}
}
const state = getDefaultState
const mutations = {
}
const actions = {
setLastViewportTaskId({ state }, id) {
state.lastViewportTaskId = id
},
setCurrentTaskState({ state }, taskState) {
state.currentTaskState = taskState
}
}
export default {
namespaced: true,
state,
mutations,
actions
}

View File

@ -862,6 +862,7 @@ const actions = {
const data = {} const data = {}
data.StudyId = study.StudyId data.StudyId = study.StudyId
data.StudyCode = study.StudyCode data.StudyCode = study.StudyCode
data.StudyName = study.StudyName
data.Modalities = study.Modalities data.Modalities = study.Modalities
data.SeriesCount = study.SeriesCount data.SeriesCount = study.SeriesCount
data.InstanceCount = study.InstanceCount data.InstanceCount = study.InstanceCount

View File

@ -1,4 +1,4 @@
@import "./variables.scss"; @import "./variables.module.scss";
@import "./mixin.scss"; @import "./mixin.scss";
@import "./transition.scss"; @import "./transition.scss";
@import "./element-ui.scss"; @import "./element-ui.scss";

View File

@ -71,29 +71,49 @@ $sideBarWidth: 200px;
border: none; border: none;
height: 100%; height: 100%;
width: 100% !important; width: 100% !important;
background-color: $menuBg;
} }
// menu hover // menu hover
.submenu-title-noDropdown, .submenu-title-noDropdown,
.el-submenu__title { .el-submenu__title {
color: $menuText !important;
&:hover { &:hover {
background-color: $menuHover !important; background-color: $menuHover !important;
color: $menuActiveText !important;
} }
} }
.is-active>.el-submenu__title { .is-active>.el-submenu__title {
color: $subMenuActiveText !important; color: $subMenuActiveText !important;
} }
.el-menu-item {
& .nest-menu .el-submenu>.el-submenu__title, color: $menuText !important;
& .el-submenu .el-menu-item { }
.el-menu-item:focus,
.el-menu-item:hover {
background-color: $subMenuBg !important;
color: $menuActiveText !important;
}
.el-submenu .el-menu-item {
min-width: $sideBarWidth !important; min-width: $sideBarWidth !important;
background-color: $subMenuBg !important; background-color: $subMenuBg !important;
&:hover { &:hover {
background-color: $subMenuHover !important; background-color: $subMenuHover !important;
} }
} }
// &.nest-menu .el-submenu>.el-submenu__title,
// &.el-submenu .el-menu-item {
// min-width: $sideBarWidth !important;
// background-color: $subMenuBg !important;
// &:hover {
// background-color: $subMenuHover !important;
// }
// }
} }
.hideSidebar { .hideSidebar {

View File

@ -1,6 +1,6 @@
import defaultSettings from '@/settings' import defaultSettings from '@/settings'
const title = defaultSettings.title || 'IRCIS' const title = defaultSettings.title || 'IRC Imaging System'
export default function getPageTitle(pageTitle) { export default function getPageTitle(pageTitle) {
if (pageTitle) { if (pageTitle) {

View File

@ -34,7 +34,7 @@ export function parseTime(time, cFormat) {
const time_str = format.replace(/{([ymdhisa])+}/g, (result, key) => { const time_str = format.replace(/{([ymdhisa])+}/g, (result, key) => {
const value = formatObj[key] const value = formatObj[key]
// Note: getDay() returns 0 on Sunday // Note: getDay() returns 0 on Sunday
if (key === 'a') { return ['日', '一', '二', '三', '四', '五', '六'][value ] } if (key === 'a') { return ['日', '一', '二', '三', '四', '五', '六'][value] }
return value.toString().padStart(2, '0') return value.toString().padStart(2, '0')
}) })
return time_str return time_str
@ -51,12 +51,44 @@ export function param2Obj(url) {
} }
return JSON.parse( return JSON.parse(
'{"' + '{"' +
decodeURIComponent(search) decodeURIComponent(search)
.replace(/"/g, '\\"') .replace(/"/g, '\\"')
.replace(/&/g, '","') .replace(/&/g, '","')
.replace(/=/g, '":"') .replace(/=/g, '":"')
.replace(/\+/g, ' ') + .replace(/\+/g, ' ') +
'"}' '"}'
) )
} }
export function deepClone(source, map = new WeakMap()) {
// 处理基本类型和函数(直接返回)
if (typeof source !== 'object' || source === null) {
return source;
}
// 处理循环引用
if (map.has(source)) {
return map.get(source);
}
// 创建新容器
const target = Array.isArray(source) ? [] : {};
map.set(source, target); // 记录克隆关系
// 克隆普通键值
for (const key in source) {
if (Object.prototype.hasOwnProperty.call(source, key)) {
target[key] = deepClone(source[key], map);
}
}
// 克隆Symbol键值ES6+
const symbolKeys = Object.getOwnPropertySymbols(source);
for (const symKey of symbolKeys) {
if (source.propertyIsEnumerable(symKey)) {
target[symKey] = deepClone(source[symKey], map);
}
}
return target;
}

View File

@ -445,7 +445,7 @@ function setTimer() {
totalBytes = totalBytes / 1024; totalBytes = totalBytes / 1024;
unit = "MB/s"; unit = "MB/s";
} }
store.state.trials.uploadTip = totalBytes.toFixed(2) + unit; store.state.trials.uploadTip = totalBytes.toFixed(3) + unit;
} }
if (timeList.length >= 5) { if (timeList.length >= 5) {
delete bytesReceivedPerSecond[timeList[0]] delete bytesReceivedPerSecond[timeList[0]]

View File

@ -150,7 +150,7 @@ function setTimer() {
totalBytes = totalBytes / 1024; totalBytes = totalBytes / 1024;
unit = "MB/s"; unit = "MB/s";
} }
store.state.trials.uploadTip = totalBytes.toFixed(2) + unit; store.state.trials.uploadTip = totalBytes.toFixed(3) + unit;
} }
if (timeList.length >= 5) { if (timeList.length >= 5) {
delete bytesReceivedPerSecond[timeList[0]] delete bytesReceivedPerSecond[timeList[0]]

View File

@ -41,7 +41,13 @@ async function ossGenerateSTS() {
let _vm = router.default.app let _vm = router.default.app
if (_vm._route.path !== '/trials/trials-panel/visit/crc-upload') { if (_vm._route.path !== '/trials/trials-panel/visit/crc-upload') {
var objectItem = objectName.split('/') var objectItem = objectName.split('/')
objectItem[objectItem.length - 1] = new Date().getTime() + '_' + objectItem[objectItem.length - 1] // objectItem[objectItem.length - 1] = new Date().getTime() + '_' + objectItem[objectItem.length - 1]
objectItem[objectItem.length - 1] = `${objectItem[objectItem.length - 1].substring(
0,
objectItem[objectItem.length - 1].lastIndexOf('.')
)}__${new Date().getTime()}${objectItem[objectItem.length - 1].substring(
objectItem[objectItem.length - 1].lastIndexOf('.')
).toLocaleLowerCase()}`
objectName = objectItem.join('/') objectName = objectItem.join('/')
} }
let res = await OSSclient.put(objectName, object) let res = await OSSclient.put(objectName, object)
@ -78,7 +84,13 @@ async function ossGenerateSTS() {
let _vm = router.default.app let _vm = router.default.app
if (_vm._route.path !== '/trials/trials-panel/visit/crc-upload') { if (_vm._route.path !== '/trials/trials-panel/visit/crc-upload') {
var objectItem = data.path.split('/') var objectItem = data.path.split('/')
objectItem[objectItem.length - 1] = new Date().getTime() + '_' + objectItem[objectItem.length - 1] // objectItem[objectItem.length - 1] = new Date().getTime() + '_' + objectItem[objectItem.length - 1]
objectItem[objectItem.length - 1] = `${objectItem[objectItem.length - 1].substring(
0,
objectItem[objectItem.length - 1].lastIndexOf('.')
)}__${new Date().getTime()}${objectItem[objectItem.length - 1].substring(
objectItem[objectItem.length - 1].lastIndexOf('.')
).toLocaleLowerCase()}`
data.path = objectItem.join('/') data.path = objectItem.join('/')
} }
let res = await customerHttp(OSSclient, data, progress); let res = await customerHttp(OSSclient, data, progress);
@ -185,7 +197,13 @@ function uploadAWS(aws, data, progress) {
let _vm = router.default.app let _vm = router.default.app
if (_vm._route.path !== '/trials/trials-panel/visit/crc-upload') { if (_vm._route.path !== '/trials/trials-panel/visit/crc-upload') {
var objectItem = data.path.split('/') var objectItem = data.path.split('/')
objectItem[objectItem.length - 1] = new Date().getTime() + '_' + objectItem[objectItem.length - 1] // objectItem[objectItem.length - 1] = new Date().getTime() + '_' + objectItem[objectItem.length - 1]
objectItem[objectItem.length - 1] = `${objectItem[objectItem.length - 1].substring(
0,
objectItem[objectItem.length - 1].lastIndexOf('.')
)}__${new Date().getTime()}${objectItem[objectItem.length - 1].substring(
objectItem[objectItem.length - 1].lastIndexOf('.')
).toLocaleLowerCase()}`
data.path = objectItem.join('/') data.path = objectItem.join('/')
} }
let bucketName = data.path.split("/")[1] || Vue.prototype.OSSclientConfig.bucket let bucketName = data.path.split("/")[1] || Vue.prototype.OSSclientConfig.bucket

View File

@ -189,8 +189,8 @@ const dicomToPng = (imageId, width, height) => {
return new Promise((resolve) => { return new Promise((resolve) => {
cornerstone.loadImage(imageId).then(async (image) => { cornerstone.loadImage(imageId).then(async (image) => {
let canvas = document.createElement("canvas"); let canvas = document.createElement("canvas");
canvas.width = width; canvas.width = (width * 60) / height
canvas.height = height; canvas.height = 60
if (image) { if (image) {
cornerstone.renderToCanvas(canvas, image); cornerstone.renderToCanvas(canvas, image);
// 将 Canvas 图像对象转换为 PNG 格式 // 将 Canvas 图像对象转换为 PNG 格式

View File

@ -9,6 +9,7 @@ const ROUTER = require('@/router');
axios.defaults.withCredentials = false axios.defaults.withCredentials = false
const service = axios.create({ const service = axios.create({
baseURL: '/api', baseURL: '/api',
// baseURL: process.env.NODE_ENV === 'prod' ? "https://api.irc.extimaging.com" : '/api',
timeout: 2 * 360000, // request timeout timeout: 2 * 360000, // request timeout
withCredentials: false withCredentials: false
}) })

View File

@ -20,7 +20,7 @@ function zipFiles(zipName, files) {
ctrl.close(); ctrl.close();
} else { } else {
let { name, url } = fileInfo.value; let { name, url } = fileInfo.value;
url = decodeUtf8(url); // url = decodeUtf8(url); // 待定,可能做过特殊处理
return fetch(url).then(res => { return fetch(url).then(res => {
ctrl.enqueue({ ctrl.enqueue({
name, name,
@ -58,7 +58,7 @@ async function updateFile(file, name) {
try { try {
store.dispatch('trials/setUnLock', true) store.dispatch('trials/setUnLock', true)
const fileOutputStream = streamSaver.createWriteStream(name); const fileOutputStream = streamSaver.createWriteStream(name);
file = decodeUtf8(file); // file = decodeUtf8(file);
let res = await fetch(file); let res = await fetch(file);
res.body.pipeTo(fileOutputStream).then(() => { res.body.pipeTo(fileOutputStream).then(() => {
store.dispatch('trials/setUnLock', true) store.dispatch('trials/setUnLock', true)

View File

@ -17,7 +17,7 @@
</el-form-item> </el-form-item>
<el-form-item label="是否内部角色: " prop="IsInternal"> <el-form-item label="是否内部角色: " prop="IsInternal">
<el-radio-group v-model="form.IsInternal"> <el-radio-group v-model="form.IsInternal">
<el-radio v-for="item of $d.YesOrNo" :label="item.value">{{ item.label }}</el-radio> <el-radio v-for="item of $d.YesOrNo" :key="`IsInternal${item.value}`" :label="item.value">{{ item.label }}</el-radio>
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>

View File

@ -27,7 +27,7 @@ export default {
} }
</script> </script>
<style lang="scss" scoped> <style lang="scss" scoped>
/deep/ .el-collapse-item__header{ ::v-deep .el-collapse-item__header{
background-color: #e9eef1; background-color: #e9eef1;
padding: 0 10px; padding: 0 10px;
} }

View File

@ -195,7 +195,7 @@ export default {
} }
</script> </script>
<style lang="scss" scoped> <style lang="scss" scoped>
/deep/ .el-collapse-item__header{ ::v-deep .el-collapse-item__header{
background-color: #e9eef1; background-color: #e9eef1;
padding: 0 10px; padding: 0 10px;
} }

View File

@ -1,5 +1,5 @@
<template> <template>
<div ref="preview-wrapper"> <div ref="preview-wrapper" class="preview-wrapper">
<div class="viewerContainer"> <div class="viewerContainer">
<div class="viewerContentWrapper" style="padding-top:25px;"> <div class="viewerContentWrapper" style="padding-top:25px;">
<div class="viewerLeftSidePanel"> <div class="viewerLeftSidePanel">
@ -38,7 +38,39 @@
</span> </span>
</span>--> </span>-->
<div class="viewernavitextwrapper"> <div class="viewernavitextwrapper">
<div style="padding: 1px;">#{{ item.seriesNumber }}</div> <div style="padding: 1px 5px 1px 1px;display: flex;justify-content: space-between;">
<div style="padding: 1px;">#{{ item.seriesNumber }}</div>
<div v-if="item.isExistMutiFrames && item.instanceCount > 1">
<el-popover
v-model="item.isShowPopper"
placement="right-start"
trigger="manual"
popper-class="instance_frame_wrapper"
>
<div style="text-align: right;">
<i class="el-icon-circle-close" style="font-size: 20px;cursor: pointer;color:#ddd;" @click="item.isShowPopper = false" />
</div>
<div class="frame_list">
<div
v-for="(instance, idx) in item.instanceInfoList"
:key="instance.InstanceUid"
class="frame_content"
:style="{'margin-bottom':idx<item.instanceInfoList.length-1? '5px':'0px'}"
@click="showMultiFrames(item, index, instance)"
>
<div>
<div>{{ instance.InstanceNumber }}</div>
<div>
{{ `${instance.NumberOfFrames > 0 ? instance.NumberOfFrames : 1} frame` }}
</div>
</div>
</div>
</div>
<i slot="reference" class="el-icon-connection" style="font-size: 15px;cursor: pointer;" @click="popperClick(seriesList, item)" />
</el-popover>
</div>
</div>
<div style="padding: 1px;">{{ item.description }}</div> <div style="padding: 1px;">{{ item.description }}</div>
<div <div
v-show="item.instanceCount" v-show="item.instanceCount"
@ -147,7 +179,11 @@ export default {
}) })
var imageIds = [] var imageIds = []
let isExistMutiFrames = false
let instanceInfoList = []
series.instanceList.forEach(function(instance) { series.instanceList.forEach(function(instance) {
console.log(instance)
let instanceInfo = {}
var fileId = cornerstoneWADOImageLoader.wadouri.fileManager.add( var fileId = cornerstoneWADOImageLoader.wadouri.fileManager.add(
instance.file instance.file
) )
@ -155,7 +191,19 @@ export default {
for (var i = 0; i < instance.frameCount; ++i) { for (var i = 0; i < instance.frameCount; ++i) {
imageIds.push(`${fileId}?frame=${i}`) imageIds.push(`${fileId}?frame=${i}`)
} }
} else imageIds.push(fileId) isExistMutiFrames = true
instanceInfo.NumberOfFrames = instance.frameCount
instanceInfo.InstanceNumber = instance.instanceNumber
instanceInfo.InstanceUid = instance.instanceUid
instanceInfo.FileId = fileId
} else {
imageIds.push(fileId)
instanceInfo.NumberOfFrames = 0
instanceInfo.InstanceNumber = instance.instanceNumber
instanceInfo.InstanceUid = instance.instanceUid
instanceInfo.FileId = fileId
}
instanceInfoList.push(instanceInfo)
}) })
scope.seriesList.push({ scope.seriesList.push({
@ -164,13 +212,43 @@ export default {
modality: series.modality, modality: series.modality,
instanceCount: series.instanceList.length, instanceCount: series.instanceList.length,
imageIds: imageIds, imageIds: imageIds,
previewImageId: imageIds[0] previewImageId: imageIds[0],
isExistMutiFrames: isExistMutiFrames,
instanceInfoList: instanceInfoList,
isShowPopper: false
}) })
}) })
this.showSeriesImage(0) this.showSeriesImage(0)
}, },
popperClick(seriesList, series) {
for (let i = 0; i < seriesList.length; i++) {
if (seriesList[i].isShowPopper) {
seriesList[i].isShowPopper = false
}
}
series.isShowPopper = !series.isShowPopper
},
showMultiFrames(series, seriesIndex, instanceInfo) {
this.currentSeriesIndex = seriesIndex
const imageIds = []
if (instanceInfo.NumberOfFrames && instanceInfo.NumberOfFrames > 1) {
for (let j = 0; j < instanceInfo.NumberOfFrames; j++) {
imageIds.push(`${instanceInfo.FileId}?frame=${j}`)
}
} else {
imageIds.push(instanceInfo.FileId)
}
const seriesInfo = {
seriesNumber: series.seriesNumber,
description: series.description,
modality: series.modality,
instanceCount: series.instanceCount,
imageIds: imageIds,
previewImageId: imageIds[0],
}
this.$refs.dicomViewer.loadImageStack(seriesInfo)
},
showSeriesImage(seriesIndex) { showSeriesImage(seriesIndex) {
// if (seriesIndex === this.currentSeriesIndex) return; // if (seriesIndex === this.currentSeriesIndex) return;
this.currentSeriesIndex = seriesIndex this.currentSeriesIndex = seriesIndex
@ -183,136 +261,172 @@ export default {
} }
</script> </script>
<style scoped> <style lang="scss">
::-webkit-scrollbar { ::-webkit-scrollbar {
width: 7px; width: 7px;
height: 7px; height: 7px;
} }
::-webkit-scrollbar-thumb { ::-webkit-scrollbar-thumb {
border-radius: 10px; border-radius: 10px;
background: #d0d0d0; background: #d0d0d0;
} }
.viewerContainer { .viewerContainer {
display: block; width: 100%;
height: 100%; display: block;
margin-top: 20px; height: 100%;
margin-left: auto; margin-top: 20px;
margin-right: auto; margin-left: auto;
background-color: #444; margin-right: auto;
overflow: hidden; background-color: #444;
} overflow: hidden;
}
.viewerBanner { .viewerBanner {
background: linear-gradient(0, #444, #222); background: linear-gradient(0, #444, #222);
min-height: 28px; min-height: 28px;
font-size: 16px; font-size: 16px;
margin: 0; margin: 0;
height: 30px; height: 30px;
padding-top: 0; padding-top: 0;
padding-left: 5px; padding-left: 5px;
padding-right: 5px; padding-right: 5px;
font-weight: bold; font-weight: bold;
} }
.viewerContentWrapper { .viewerContentWrapper {
display: flex; display: flex;
flex-direction: row; flex-direction: row;
width: 100%; width: 100%;
padding: 5px; padding: 5px;
height: 99%; height: 99%;
/* height: 95%; */ /* height: 95%; */
overflow: hidden; overflow: hidden;
text-overflow: clip; text-overflow: clip;
white-space: nowrap; white-space: nowrap;
} }
.viewerContentWrapper > div { .viewerContentWrapper > div {
display: inline-block; display: inline-block;
white-space: normal; white-space: normal;
} }
.viewerLeftSidePanel { .viewerLeftSidePanel {
width: 200px; width: 200px;
background-color: #323232; background-color: #323232;
box-sizing: border-box; box-sizing: border-box;
margin: 0; margin: 0;
padding: 0; padding: 0;
margin-right: 2px; margin-right: 2px;
color: #d0d0d0; color: #d0d0d0;
overflow-y: auto; overflow-y: auto;
} }
.viewerContentWrapper > div > .sidePanelBody { .viewerContentWrapper > div > .sidePanelBody {
background: rgba(50, 50, 50, 1); background: rgba(50, 50, 50, 1);
word-break: break-all; word-break: break-all;
display: table; display: table;
width: 100%; width: 100%;
border: 1px solid #3e3f3a; border: 1px solid #3e3f3a;
} }
.viewerContentWrapper > div > div.sidePanelBody > div { .viewerContentWrapper > div > div.sidePanelBody > div {
width: 100%; width: 100%;
height: 100%; height: 100%;
} }
.studyDesc { .studyDesc {
font-weight: bold; font-weight: bold;
font-size: 13px; font-size: 13px;
text-align: center; text-align: center;
background: rgb(88 84 83); background: rgb(88 84 83);
color: #d0d0d0; color: #d0d0d0;
padding: 5px; padding: 5px;
} }
.ps { .ps {
overflow: hidden !important; overflow: hidden !important;
overflow-anchor: none; overflow-anchor: none;
-ms-overflow-style: none; -ms-overflow-style: none;
touch-action: auto; touch-action: auto;
-ms-touch-action: auto; -ms-touch-action: auto;
} }
.viewerLeftSidePanel .viewernavigatorwrapper { .viewerLeftSidePanel .viewernavigatorwrapper {
display: flex; display: flex;
width: 196px; width: 196px;
height: 84px; height: 84px;
padding: 1px 2px 1px 8px; padding: 1px 2px 1px 8px;
margin: 6px 0 6px 1px; margin: 6px 0 6px 1px;
border-radius: 2px; border-radius: 2px;
border: 1px solid #404040; border: 1px solid #404040;
} }
.ui-draggable-handle { .ui-draggable-handle {
-ms-touch-action: none; -ms-touch-action: none;
touch-action: none; touch-action: none;
} }
.viewerLeftSidePanel .image-preview { .viewerLeftSidePanel .image-preview {
border: 2px solid #252525; border: 2px solid #252525;
cursor: pointer; cursor: pointer;
} }
.viewerLeftSidePanel .viewernavitextwrapper { .viewerLeftSidePanel .viewernavitextwrapper {
flex: 1; flex: 1;
padding: 3px 1px 3px 4px; padding: 3px 1px 3px 4px;
vertical-align: top; vertical-align: top;
font-size: 12px; font-size: 12px;
} }
.viewerSideActive { .viewerSideActive {
background: #16477b; background: #16477b;
background: #16477b80; background: #16477b80;
border: 1px solid #23527b; border: 1px solid #23527b;
} }
.viewerContent { .viewerContent {
flex: 1; flex: 1;
height: 100%; height: 100%;
display: block; display: block;
background-color: black; background-color: black;
color: #d0d0d0; color: #d0d0d0;
font-size: 13px; font-size: 13px;
} }
.instance_frame_wrapper{
min-width: 120px;
background-color: #2c2c2c;
border: 1px solid #2c2c2c;
padding: 5px;
}
.frame_list{
max-height: 500px;
overflow-y: auto;
}
.instance_frame_wrapper ::-webkit-scrollbar {
width: 7px;
height: 7px;
}
.instance_frame_wrapper ::-webkit-scrollbar-thumb {
border-radius: 10px;
background: #d0d0d0;
}
.frame_content{
/* height: 50px; */
padding: 10px;
display: flex;
justify-content: flex-start;
color: #ddd;
font-size: 12px;
border: 1px solid #404040;
}
.frame_content:hover {
/* font-weight: bold; */
/* box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.1); */
cursor: pointer;
/* color: #428bca; */
border-color: #213a54 !important;
background-color: #213a54;
}
</style> </style>

View File

@ -9,10 +9,10 @@
class="upload-temporary-file" class="upload-temporary-file"
> >
<div class="base-dialog-body"> <div class="base-dialog-body">
<el-form-item label="Code" prop="Code"> <el-form-item :label="$t('dictionary:attachment:label:code')" prop="Code">
<el-input v-model="form.Code" /> <el-input v-model="form.Code" />
</el-form-item> </el-form-item>
<el-form-item label="业务场景: " prop="BusinessScenarioEnum"> <el-form-item :label="$t('dictionary:attachment:label:businessScenario')" prop="BusinessScenarioEnum">
<el-select <el-select
v-model="form.BusinessScenarioEnum" v-model="form.BusinessScenarioEnum"
style="width:100%;" style="width:100%;"
@ -28,7 +28,7 @@
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item label="文件: "> <el-form-item :label="$t('dictionary:attachment:export:form:file')">
<div class="upload-container"> <div class="upload-container">
<el-upload <el-upload
class="upload-demo" class="upload-demo"
@ -60,7 +60,7 @@
</el-form-item> </el-form-item>
<el-form-item v-if="form.Id !== ''" label="是否废除: "> <el-form-item v-if="form.Id !== ''" label="是否废除: ">
<el-radio-group v-model="form.IsDeleted"> <el-radio-group v-model="form.IsDeleted">
<el-radio v-for="item of $d.YesOrNo" :label="item.value">{{ item.label }}</el-radio> <el-radio v-for="item of $d.YesOrNo" :key="`IsDeleted${item.value}`" :label="item.value">{{ item.label }}</el-radio>
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
<el-form-item label="描述"> <el-form-item label="描述">

View File

@ -2,7 +2,8 @@
<BaseContainer> <BaseContainer>
<template slot="search-container"> <template slot="search-container">
<el-form :inline="true" size="small"> <el-form :inline="true" size="small">
<el-form-item label="业务场景"> <!-- 业务场景 -->
<el-form-item :label="$t('dictionary:attachment:label:businessScenario')">
<el-select <el-select
v-model="searchData.BusinessScenarioEnum" v-model="searchData.BusinessScenarioEnum"
style="width:150px;" style="width:150px;"
@ -16,7 +17,8 @@
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item label="文件名称"> <!-- 文件名称 -->
<el-form-item :label="$t('dictionary:attachment:label:name')">
<el-input <el-input
v-model="searchData.Name" v-model="searchData.Name"
style="width:130px;" style="width:130px;"
@ -37,7 +39,6 @@
</el-form> </el-form>
<el-button <el-button
type="primary" type="primary"
icon="el-icon-plus"
style="margin-left:auto;" style="margin-left:auto;"
size="small" size="small"
@click="handleAdd" @click="handleAdd"
@ -57,14 +58,14 @@
<el-table-column type="index" width="40" /> <el-table-column type="index" width="40" />
<el-table-column <el-table-column
prop="Code" prop="Code"
label="Code" :label="$t('dictionary:attachment:label:code')"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<el-table-column <el-table-column
prop="BusinessScenarioEnum" prop="BusinessScenarioEnum"
label="业务场景" :label="$t('dictionary:attachment:label:businessScenario')"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
> >
@ -76,18 +77,18 @@
<el-table-column <el-table-column
prop="Name" prop="Name"
label="文件名称" :label="$t('dictionary:attachment:label:name')"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<el-table-column <el-table-column
prop="Description" prop="Description"
label="描述" :label="$t('dictionary:attachment:label:description')"
show-overflow-tooltip show-overflow-tooltip
/> />
<el-table-column <el-table-column
prop="IsDeleted" prop="IsDeleted"
label="是否废除" :label="$t('dictionary:attachment:label:isDeleted')"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
> >
@ -98,30 +99,30 @@
</el-table-column> </el-table-column>
<el-table-column <el-table-column
prop="UpdateTime" prop="UpdateTime"
label="上传时间" :label="$t('dictionary:attachment:label:updateTime')"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<el-table-column label="Action"> <el-table-column label="Action" width="300">
<template slot-scope="scope"> <template slot-scope="scope">
<el-button <el-button
type="text" type="text"
@click="handleDownload(scope.row)" @click="handleDownload(scope.row)"
> >
下载 {{ $t('common:button:download') }}
</el-button> </el-button>
<el-button <el-button
type="text" type="text"
@click="handleEdit(scope.row)" @click="handleEdit(scope.row)"
> >
编辑 {{ $t('common:action:edit') }}
</el-button> </el-button>
<el-button <el-button
type="text" type="text"
@click="handleDelete(scope.row)" @click="handleDelete(scope.row)"
> >
删除 {{ $t('common:button:delete') }}
</el-button> </el-button>
</template> </template>
</el-table-column> </el-table-column>
@ -176,9 +177,9 @@ export default {
}, },
methods: { methods: {
handleDelete(row) { handleDelete(row) {
this.$confirm('确定删除该文件?').then(() => { this.$confirm(this.$t('dictionary:attachment:export:confirm:delete')).then(() => {
deleteCommonDocument(row.Id).then(() => { deleteCommonDocument(row.Id).then(() => {
this.$message.success('删除成功') this.$message.success(this.$t('common:message:deletedSuccessfully'))
this.getList() this.getList()
}) })
}) })
@ -195,7 +196,7 @@ export default {
}, },
// //
handleAdd() { handleAdd() {
this.editDialog.title = 'Add' this.editDialog.title = this.$t('common:button:new')
this.currentRow = { FileTypeEnum: FileTypeEnum } this.currentRow = { FileTypeEnum: FileTypeEnum }
this.editDialog.visible = true this.editDialog.visible = true
}, },
@ -208,7 +209,7 @@ export default {
}, },
// //
handleEdit(row) { handleEdit(row) {
this.editDialog.title = 'Edit' this.editDialog.title = this.$t('common:action:edit')
this.currentRow = { ...row } this.currentRow = { ...row }
this.editDialog.visible = true this.editDialog.visible = true
}, },

View File

@ -78,7 +78,7 @@
<el-form-item v-if="form.Id !== ''" label="是否废除: "> <el-form-item v-if="form.Id !== ''" label="是否废除: ">
<el-radio-group v-model="form.IsDeleted"> <el-radio-group v-model="form.IsDeleted">
<el-radio v-for="item of $d.YesOrNo" :label="item.value">{{ item.label }}</el-radio> <el-radio v-for="item of $d.YesOrNo" :key="`IsDeleted${item.value}`" :label="item.value">{{ item.label }}</el-radio>
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
<el-form-item label="描述"> <el-form-item label="描述">

View File

@ -2,7 +2,8 @@
<BaseContainer> <BaseContainer>
<template slot="search-container"> <template slot="search-container">
<el-form :inline="true" size="small"> <el-form :inline="true" size="small">
<el-form-item label="业务场景"> <!-- 业务场景 -->
<el-form-item :label="$t('dictionary:attachment:label:businessScenario')">
<el-select <el-select
v-model="searchData.BusinessScenarioEnum" v-model="searchData.BusinessScenarioEnum"
style="width:150px;" style="width:150px;"
@ -16,7 +17,8 @@
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item label="文件名称"> <!-- 文件名称 -->
<el-form-item :label="$t('dictionary:attachment:label:name')">
<el-input <el-input
v-model="searchData.Name" v-model="searchData.Name"
style="width:130px;" style="width:130px;"
@ -57,14 +59,14 @@
<el-table-column type="index" width="40" /> <el-table-column type="index" width="40" />
<el-table-column <el-table-column
prop="Code" prop="Code"
label="Code" :label="$t('dictionary:attachment:label:code')"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<el-table-column <el-table-column
prop="BusinessScenarioEnum" prop="BusinessScenarioEnum"
label="业务场景" :label="$t('dictionary:attachment:label:businessScenario')"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
> >
@ -76,7 +78,7 @@
<el-table-column <el-table-column
prop="Name" prop="Name"
label="文件名称" :label="$t('dictionary:attachment:label:name')"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
@ -92,12 +94,12 @@
</el-table-column> </el-table-column>
<el-table-column <el-table-column
prop="Description" prop="Description"
label="描述" :label="$t('dictionary:attachment:label:description')"
show-overflow-tooltip show-overflow-tooltip
/> />
<el-table-column <el-table-column
prop="IsDeleted" prop="IsDeleted"
label="是否废除" :label="$t('dictionary:attachment:label:isDeleted')"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
> >
@ -108,18 +110,18 @@
</el-table-column> </el-table-column>
<el-table-column <el-table-column
prop="UpdateTime" prop="UpdateTime"
label="上传时间" :label="$t('dictionary:attachment:label:updateTime')"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<el-table-column label="Action"> <el-table-column :label="$t('common:action:action')">
<template slot-scope="scope"> <template slot-scope="scope">
<el-button <el-button
type="text" type="text"
@click="handleDownload(scope.row)" @click="handleDownload(scope.row)"
> >
下载 {{ $t('common:button:download') }}
</el-button> </el-button>
<!-- <el-button <!-- <el-button
type="text" type="text"

View File

@ -9,7 +9,7 @@
class="upload-temporary-file" class="upload-temporary-file"
> >
<div class="base-dialog-body"> <div class="base-dialog-body">
<el-form-item label="Code" prop="Code"> <el-form-item :label="$t('dictionary:attachment:export:search:code')" prop="Code">
<el-input v-model="form.Code" /> <el-input v-model="form.Code" />
</el-form-item> </el-form-item>
<el-form-item <el-form-item
@ -76,8 +76,9 @@
:label="$t('dictionary:attachment:export:form:isDeleted')" :label="$t('dictionary:attachment:export:form:isDeleted')"
> >
<el-radio-group v-model="form.IsDeleted"> <el-radio-group v-model="form.IsDeleted">
<el-radio :label="true"></el-radio> <el-radio v-for="item of $d.YesOrNo" :key="`IsDeleted${item.value}`" :label="item.value">
<el-radio :label="false"></el-radio> {{ item.label }}
</el-radio>
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
<el-form-item <el-form-item

View File

@ -39,7 +39,6 @@
</el-form-item> </el-form-item>
<el-button <el-button
type="primary" type="primary"
icon="el-icon-plus"
style="float: right" style="float: right"
size="small" size="small"
@click="handleAdd" @click="handleAdd"
@ -60,7 +59,7 @@
<el-table-column type="index" width="40" /> <el-table-column type="index" width="40" />
<el-table-column <el-table-column
prop="Code" prop="Code"
label="Code" :label="$t('dictionary:attachment:export:search:code')"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
@ -120,7 +119,7 @@
sortable="custom" sortable="custom"
/> />
<el-table-column :label="$t('common:action:action')"> <el-table-column :label="$t('common:action:action')" width="300">
<template slot-scope="scope"> <template slot-scope="scope">
<el-button type="text" @click="PreviewFile(scope.row)"> <el-button type="text" @click="PreviewFile(scope.row)">
{{ $t('common:button:preview') }} {{ $t('common:button:preview') }}
@ -235,7 +234,7 @@ export default {
}, },
// //
handleAdd() { handleAdd() {
this.editDialog.title = 'Add' this.editDialog.title = this.$t('common:button:new')
this.currentRow = { FileTypeEnum: FileTypeEnum } this.currentRow = { FileTypeEnum: FileTypeEnum }
this.editDialog.visible = true this.editDialog.visible = true
}, },
@ -252,7 +251,7 @@ export default {
}, },
// //
handleEdit(row) { handleEdit(row) {
this.editDialog.title = 'Edit' this.editDialog.title = this.$t('common:action:edit')
this.currentRow = { ...row } this.currentRow = { ...row }
this.editDialog.visible = true this.editDialog.visible = true
}, },

View File

@ -33,7 +33,6 @@
</el-form> </el-form>
<el-button <el-button
type="primary" type="primary"
icon="el-icon-plus"
style="margin-left: auto; margin-bottom: 10px" style="margin-left: auto; margin-bottom: 10px"
size="small" size="small"
@click="handleAdd" @click="handleAdd"
@ -117,7 +116,7 @@
sortable="custom" sortable="custom"
/> />
<el-table-column :label="$t('common:action:action')" min-width="100"> <el-table-column :label="$t('common:action:action')" min-width="120">
<template slot-scope="scope"> <template slot-scope="scope">
<el-button type="text" @click="handlePreview(scope.row)"> <el-button type="text" @click="handlePreview(scope.row)">
{{ $t('common:button:preview') }} {{ $t('common:button:preview') }}
@ -247,7 +246,7 @@ export default {
}, },
// //
handleAdd() { handleAdd() {
this.title = 'Add' this.title = this.$t('common:button:new')
this.currentRow = {} this.currentRow = {}
this.editVisible = true this.editVisible = true
}, },
@ -262,7 +261,7 @@ export default {
}, },
// //
handleEdit(row) { handleEdit(row) {
this.title = 'Edit' this.title = this.$t('common:action:edit')
this.currentRow = { ...row } this.currentRow = { ...row }
this.editVisible = true this.editVisible = true
}, },

View File

@ -9,10 +9,10 @@
class="upload-temporary-file" class="upload-temporary-file"
> >
<div class="base-dialog-body"> <div class="base-dialog-body">
<el-form-item label="Code" prop="Code"> <el-form-item :label="$t('dictionary:attachment:label:code')" prop="Code">
<el-input v-model="form.Code" /> <el-input v-model="form.Code" />
</el-form-item> </el-form-item>
<el-form-item label="业务场景: " prop="BusinessScenarioEnum"> <el-form-item :label="$t('dictionary:attachment:label:businessScenario')" prop="BusinessScenarioEnum">
<el-select <el-select
v-model="form.BusinessScenarioEnum" v-model="form.BusinessScenarioEnum"
style="width: 100%" style="width: 100%"
@ -28,7 +28,7 @@
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item label="文件: "> <el-form-item :label="$t('dictionary:attachment:label:file')">
<div class="upload-container"> <div class="upload-container">
<el-upload <el-upload
class="upload-demo" class="upload-demo"
@ -57,7 +57,7 @@
</el-upload> </el-upload>
</div> </div>
</el-form-item> </el-form-item>
<el-form-item label="文件名" prop="Name"> <el-form-item :label="$t('dictionary:attachment:label:name')" prop="Name">
<el-input v-model="form.Name" /> <el-input v-model="form.Name" />
</el-form-item> </el-form-item>
<el-form-item <el-form-item
@ -66,7 +66,7 @@
> >
<el-input v-model="form.NameCN" /> <el-input v-model="form.NameCN" />
</el-form-item> </el-form-item>
<el-form-item v-if="form.Id !== ''" label="是否废除: "> <el-form-item v-if="form.Id !== ''" :label="$t('dictionary:attachment:label:isDeleted')">
<el-radio-group v-model="form.IsDeleted"> <el-radio-group v-model="form.IsDeleted">
<el-radio <el-radio
v-for="item of $d.YesOrNo" v-for="item of $d.YesOrNo"
@ -76,12 +76,11 @@
> >
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
<el-form-item label="描述"> <el-form-item :label="$t('dictionary:attachment:label:description')">
<el-input <el-input
v-model="form.Description" v-model="form.Description"
type="textarea" type="textarea"
:autosize="{ minRows: 2, maxRows: 4 }" :autosize="{ minRows: 2, maxRows: 4 }"
placeholder="请输入内容"
/> />
</el-form-item> </el-form-item>
</div> </div>
@ -93,7 +92,7 @@
:disabled="!form.FileTypeEnum || !form.BusinessScenarioEnum" :disabled="!form.FileTypeEnum || !form.BusinessScenarioEnum"
:loading="saveBtnLoading" :loading="saveBtnLoading"
@click="handleSave" @click="handleSave"
>Save</el-button >{{ $t('common:button:save') }}</el-button
> >
</el-form-item> </el-form-item>
</div> </div>
@ -132,16 +131,16 @@ export default {
}, },
rules: { rules: {
Code: [ Code: [
{ required: true, message: 'Please specify', trigger: ['blur'] }, { required: true, message: this.$t('common:ruleMessage:specify'), trigger: ['blur'] },
], ],
Name: [ Name: [
{ required: true, message: 'Please specify', trigger: ['blur'] }, { required: true, message: this.$t('common:ruleMessage:specify'), trigger: ['blur'] },
], ],
NameCN: [ NameCN: [
{ required: true, message: 'Please specify', trigger: ['blur'] }, { required: true, message: this.$t('common:ruleMessage:specify'), trigger: ['blur'] },
], ],
BusinessScenarioEnum: [ BusinessScenarioEnum: [
{ required: true, message: 'Please select', trigger: ['blur'] }, { required: true, message: this.$t('common:ruleMessage:specify'), trigger: ['blur'] },
], ],
}, },
fileList: [], fileList: [],
@ -193,7 +192,7 @@ export default {
this.fileList = [] this.fileList = []
return true return true
} else { } else {
this.$alert('必须是word/excel格式') this.$alert(this.$t('dictionary:attachment:export:alert:formatFile'))
return false return false
} }
@ -220,7 +219,7 @@ export default {
this.$refs.sysTemplateFrom.validate((valid) => { this.$refs.sysTemplateFrom.validate((valid) => {
if (!valid) return if (!valid) return
if (!this.form.Name) { if (!this.form.Name) {
this.$alert('Please select file.') this.$alert(this.$t('dictionary:attachment:message:msg1'))
return return
} }
this.saveBtnLoading = true this.saveBtnLoading = true
@ -229,7 +228,7 @@ export default {
this.saveBtnLoading = false this.saveBtnLoading = false
this.$emit('closeDialog') this.$emit('closeDialog')
this.$emit('getList') this.$emit('getList')
this.$message.success('Uploaded successfully') this.$message.success(this.$t('common:message:savedSuccessfully'))
}) })
.catch(() => { .catch(() => {
this.saveBtnLoading = false this.saveBtnLoading = false
@ -248,7 +247,7 @@ export default {
} }
}, },
handleExceed(files, fileList) { handleExceed(files, fileList) {
this.$message.warning(`Upload is currently limited to 1 file`) this.$message.warning(this.$t('upload:rule:maxFile1'))
}, },
checkFileSuffix(fileName) { checkFileSuffix(fileName) {
var typeArr = ['xls', 'xlsx', 'doc', 'docx'] var typeArr = ['xls', 'xlsx', 'doc', 'docx']

View File

@ -2,7 +2,8 @@
<BaseContainer> <BaseContainer>
<template slot="search-container"> <template slot="search-container">
<el-form :inline="true" size="small"> <el-form :inline="true" size="small">
<el-form-item label="业务场景"> <!-- 业务场景 -->
<el-form-item :label="$t('dictionary:attachment:label:businessScenario')">
<el-select <el-select
v-model="searchData.BusinessScenarioEnum" v-model="searchData.BusinessScenarioEnum"
style="width: 150px" style="width: 150px"
@ -15,7 +16,8 @@
/> />
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item label="文件名称"> <!-- 文件名称 -->
<el-form-item :label="$t('dictionary:attachment:label:name')">
<el-input v-model="searchData.Name" style="width: 130px" clearable /> <el-input v-model="searchData.Name" style="width: 130px" clearable />
</el-form-item> </el-form-item>
@ -35,7 +37,6 @@
</el-form-item> </el-form-item>
<el-button <el-button
type="primary" type="primary"
icon="el-icon-plus"
style="float: right" style="float: right"
size="small" size="small"
@click="handleAdd" @click="handleAdd"
@ -56,14 +57,14 @@
<el-table-column type="index" width="40" /> <el-table-column type="index" width="40" />
<el-table-column <el-table-column
prop="Code" prop="Code"
label="Code" :label="$t('dictionary:attachment:label:code')"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<!-- 业务场景 -->
<el-table-column <el-table-column
prop="BusinessScenarioEnum" prop="BusinessScenarioEnum"
label="业务场景" :label="$t('dictionary:attachment:label:businessScenario')"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
> >
@ -76,10 +77,10 @@
}} }}
</template> </template>
</el-table-column> </el-table-column>
<!-- 文件名称 -->
<el-table-column <el-table-column
prop="Name" prop="Name"
label="文件名称" :label="$t('dictionary:attachment:label:name')"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
@ -89,14 +90,16 @@
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<!-- 描述 -->
<el-table-column <el-table-column
prop="Description" prop="Description"
label="描述" :label="$t('dictionary:attachment:label:description')"
show-overflow-tooltip show-overflow-tooltip
/> />
<!-- 是否废除 -->
<el-table-column <el-table-column
prop="IsDeleted" prop="IsDeleted"
label="是否废除" :label="$t('dictionary:attachment:label:isDeleted')"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
> >
@ -109,26 +112,27 @@
}}</el-tag> }}</el-tag>
</template> </template>
</el-table-column> </el-table-column>
<!-- 上传时间 -->
<el-table-column <el-table-column
prop="UpdateTime" prop="UpdateTime"
label="上传时间" :label="$t('dictionary:attachment:label:updateTime')"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<el-table-column label="Action"> <el-table-column :label="$t('common:action:action')" width="300">
<template slot-scope="scope"> <template slot-scope="scope">
<el-button type="text" @click="PreviewFile(scope.row)"> <el-button type="text" @click="PreviewFile(scope.row)">
{{ $t('common:button:preview') }} {{ $t('common:button:preview') }}
</el-button> </el-button>
<el-button type="text" @click="handleDownload(scope.row)"> <el-button type="text" @click="handleDownload(scope.row)">
下载 {{ $t('common:button:download') }}
</el-button> </el-button>
<el-button type="text" @click="handleEdit(scope.row)"> <el-button type="text" @click="handleEdit(scope.row)">
编辑 {{ $t('common:button:edit') }}
</el-button> </el-button>
<el-button type="text" @click="handleDelete(scope.row)"> <el-button type="text" @click="handleDelete(scope.row)">
删除 {{ $t('common:button:delete') }}
</el-button> </el-button>
</template> </template>
</el-table-column> </el-table-column>
@ -197,12 +201,13 @@ export default {
}, },
methods: { methods: {
handleDelete(row) { handleDelete(row) {
this.$confirm('确定删除该模版?').then(() => { //
this.$confirm(this.$t('dictionary:attachment:message:msg1')).then(() => {
deleteCommonDocument(row.Id).then(() => { deleteCommonDocument(row.Id).then(() => {
this.$message.success('删除成功') this.$message.success(this.$t('common:message:deletedSuccessfully'))
this.getList() this.getList()
}) })
}) }).catch(()=>{})
}, },
PreviewFile(row) { PreviewFile(row) {
let basePath = window.location.origin let basePath = window.location.origin
@ -229,7 +234,7 @@ export default {
}, },
// //
handleAdd() { handleAdd() {
this.editDialog.title = 'Add' this.editDialog.title = this.$t('common:button:new')
this.currentRow = { FileTypeEnum: FileTypeEnum } this.currentRow = { FileTypeEnum: FileTypeEnum }
this.editDialog.visible = true this.editDialog.visible = true
}, },
@ -246,7 +251,7 @@ export default {
}, },
// //
handleEdit(row) { handleEdit(row) {
this.editDialog.title = 'Edit' this.editDialog.title = this.$t('common:button:edit')
this.currentRow = { ...row } this.currentRow = { ...row }
this.editDialog.visible = true this.editDialog.visible = true
}, },

View File

@ -2,13 +2,13 @@
<div class="app-container my_menu" > <div class="app-container my_menu" >
<el-form :inline="true"> <el-form :inline="true">
<el-form-item label="模块"> <el-form-item label="模块">
<el-select v-model="queryParams.ModuleTypeId" placeholder="模块" clearable size="small"> <el-select v-model="queryParams.ModuleTypeId" placeholder="模块" clearable >
<el-option v-for="item of dict.type.ModuleType" :value="item.value" :label="item.raw.ValueCN" /> <el-option v-for="item of dict.type.ModuleType" :key="`ModuleTypeId${item.value}`" :value="item.value" :label="item.raw.ValueCN" />
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item> <el-form-item>
<el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery"></el-button> <el-button type="primary" icon="el-icon-search" @click="handleQuery"></el-button>
<el-button type="primary" icon="el-icon-plus" size="mini" @click="handleAdd"></el-button> <el-button type="primary" icon="el-icon-plus" @click="handleAdd"></el-button>
</el-form-item> </el-form-item>
</el-form> </el-form>
<div> <div>
@ -66,42 +66,30 @@
<template slot-scope="scope"> <template slot-scope="scope">
<el-button <el-button
v-if="scope.row.ModuleTypeValueCN && scope.row.ObjectTypeValueCN && scope.row.OptTypeValueCN && scope.row.ChildrenTypeValueCN " v-if="scope.row.ModuleTypeValueCN && scope.row.ObjectTypeValueCN && scope.row.OptTypeValueCN && scope.row.ChildrenTypeValueCN "
size="mini"
type="text" type="text"
icon="el-icon-top"
@click="handleUpMove(scope.row)" @click="handleUpMove(scope.row)"
>上移</el-button> >上移</el-button>
<el-button <el-button
size="mini"
type="text" type="text"
icon="el-icon-edit"
@click="handleUpdate(scope.row)" @click="handleUpdate(scope.row)"
>修改</el-button> >修改</el-button>
<el-button <el-button
v-if="!(scope.row.ModuleTypeValueCN && scope.row.ObjectTypeValueCN && scope.row.OptTypeValueCN && scope.row.ChildrenTypeValueCN)" v-if="!(scope.row.ModuleTypeValueCN && scope.row.ObjectTypeValueCN && scope.row.OptTypeValueCN && scope.row.ChildrenTypeValueCN)"
size="mini"
type="text" type="text"
icon="el-icon-plus"
@click="handleAdd(scope.row)" @click="handleAdd(scope.row)"
>新增</el-button> >新增</el-button>
<el-button <el-button
v-if="scope.row.ModuleTypeValueCN && scope.row.ObjectTypeValueCN && scope.row.OptTypeValueCN && scope.row.ChildrenTypeValueCN " v-if="scope.row.ModuleTypeValueCN && scope.row.ObjectTypeValueCN && scope.row.OptTypeValueCN && scope.row.ChildrenTypeValueCN "
size="mini"
type="text" type="text"
icon="el-icon-plus"
@click="handleChildren(scope.row)" @click="handleChildren(scope.row)"
>Children</el-button> >Children</el-button>
<el-button <el-button
v-if="scope.row.ModuleTypeValueCN && scope.row.ObjectTypeValueCN && scope.row.OptTypeValueCN && scope.row.ChildrenTypeValueCN " v-if="scope.row.ModuleTypeValueCN && scope.row.ObjectTypeValueCN && scope.row.OptTypeValueCN && scope.row.ChildrenTypeValueCN "
size="mini"
type="text" type="text"
icon="el-icon-plus"
@click="handleCopy(scope.row)" @click="handleCopy(scope.row)"
>复制到</el-button> >复制到</el-button>
<el-button <el-button
size="mini"
type="text" type="text"
icon="el-icon-delete"
@click="handleDelete(scope.row)" @click="handleDelete(scope.row)"
>删除</el-button> >删除</el-button>
</template> </template>
@ -169,28 +157,28 @@
<el-col v-show="form.ConfigType === 'M' && title !== '复制'" :span="12"> <el-col v-show="form.ConfigType === 'M' && title !== '复制'" :span="12">
<el-form-item label="功能模块" prop="menuType"> <el-form-item label="功能模块" prop="menuType">
<el-select v-model="form.ModuleTypeId" placeholder="模块" clearable size="small" @change="changeModule"> <el-select v-model="form.ModuleTypeId" placeholder="模块" clearable size="small" @change="changeModule">
<el-option v-for="item of dict.type.ModuleType" :value="item.value" :label="item.raw.ValueCN" /> <el-option v-for="item of dict.type.ModuleType" :key="`ModuleType${item.value}`" :value="item.value" :label="item.raw.ValueCN" />
</el-select> </el-select>
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col v-show="form.ConfigType === 'M' && title !== '复制'" :span="12"> <el-col v-show="form.ConfigType === 'M' && title !== '复制'" :span="12">
<el-form-item label="操作类型" prop="menuType"> <el-form-item label="操作类型" prop="menuType">
<el-select v-model="form.OptTypeId" placeholder="操作类型" clearable size="small" @change="changeDescription"> <el-select v-model="form.OptTypeId" placeholder="操作类型" clearable size="small" @change="changeDescription">
<el-option v-for="item of dict.type.OptType" :value="item.value" :label="item.raw.ValueCN" /> <el-option v-for="item of dict.type.OptType" :key="`OptTypeId${item.value}`" :value="item.value" :label="item.raw.ValueCN" />
</el-select> </el-select>
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col v-show="form.ConfigType === 'M' && title !== '复制'" :span="12"> <el-col v-show="form.ConfigType === 'M' && title !== '复制'" :span="12">
<el-form-item label="对象类型" prop="menuType"> <el-form-item label="对象类型" prop="menuType">
<el-select v-model="form.ObjectTypeId" placeholder="对象类型" clearable size="small" @change="changeDescription"> <el-select v-model="form.ObjectTypeId" placeholder="对象类型" clearable size="small" @change="changeDescription">
<el-option v-for="item of dict.type.ObjectType" v-if="ChildGroup === item.raw.ChildGroup" :value="item.value" :label="item.raw.ValueCN" /> <el-option v-for="item of dict.type.ObjectType" :key="`ObjectType${item.value}`" v-if="ChildGroup === item.raw.ChildGroup" :value="item.value" :label="item.raw.ValueCN" />
</el-select> </el-select>
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col v-show="form.ConfigType === 'M' && title !== '复制'" :span="12"> <el-col v-show="form.ConfigType === 'M' && title !== '复制'" :span="12">
<el-form-item label="数据类型" prop="menuType"> <el-form-item label="数据类型" prop="menuType">
<el-select v-model="form.ChildrenTypeId" placeholder="操作子类" clearable size="small" @change="changeDescription"> <el-select v-model="form.ChildrenTypeId" placeholder="操作子类" clearable size="small" @change="changeDescription">
<el-option v-for="item of dict.type.ChildrenType" :value="item.value" :label="item.raw.ValueCN" /> <el-option v-for="item of dict.type.ChildrenType" :key="`ChildrenType${item.value}`" :value="item.value" :label="item.raw.ValueCN" />
</el-select> </el-select>
</el-form-item> </el-form-item>
</el-col> </el-col>
@ -295,7 +283,7 @@
</el-button> </el-button>
</el-col> </el-col>
</el-row> </el-row>
<el-row v-show="form.DataType === 'Router'" v-if="form.UrlConfig && form.UrlConfig.IsHaveParameters" v-for="(item,index) of form.UrlConfig ? form.UrlConfig.ParameterList : []"> <el-row v-show="form.DataType === 'Router'" v-if="form.UrlConfig && form.UrlConfig.IsHaveParameters" v-for="(item,index) of form.UrlConfig ? form.UrlConfig.ParameterList : []" :key="`Router${index}`">
<el-col :span="10"> <el-col :span="10">
<el-form-item> <el-form-item>
<span slot="label"> <span slot="label">
@ -671,11 +659,11 @@
<div style="padding: 0 40px;display: flex;flex-direction: column"> <div style="padding: 0 40px;display: flex;flex-direction: column">
<div style="text-align: right;height: 50px;"> <div style="text-align: right;height: 50px;">
<el-select v-model="copeParams.FromItemId" collapse-tags filterable placeholder="完全拷贝对象" clearable size="small"> <el-select v-model="copeParams.FromItemId" collapse-tags filterable placeholder="完全拷贝对象" clearable size="small">
<el-option v-for="item of list" v-if="drawer_cfg.drawerChild && item.ConfigType === 'M' && item.ObjectTypeId === selectRow.ObjectTypeId && item.OptTypeId && item.ChildrenTypeId " :value="item.Id" :label="item.DescriptionCN" /> <el-option v-for="item of list" :key="item.Id" v-if="drawer_cfg.drawerChild && item.ConfigType === 'M' && item.ObjectTypeId === selectRow.ObjectTypeId && item.OptTypeId && item.ChildrenTypeId " :value="item.Id" :label="item.DescriptionCN" />
</el-select> </el-select>
<el-button type="primary" size="mini" style="margin-right: 10px" @click="handleOverCope(selectRow)"></el-button> <el-button type="primary" size="mini" style="margin-right: 10px" @click="handleOverCope(selectRow)"></el-button>
<el-select v-model="copeParams.DataSourceGuids" multiple collapse-tags filterable placeholder="拷贝对象" clearable size="small"> <el-select v-model="copeParams.DataSourceGuids" multiple collapse-tags filterable placeholder="拷贝对象" clearable size="small">
<el-option v-for="item of list" v-if="drawer_cfg.drawerChild && item.ConfigType === 'M' && item.ObjectTypeId === selectRow.ObjectTypeId && item.OptTypeId && item.ChildrenTypeId " :value="item.Id" :label="item.DescriptionCN" /> <el-option v-for="item of list" :key="item.Id" v-if="drawer_cfg.drawerChild && item.ConfigType === 'M' && item.ObjectTypeId === selectRow.ObjectTypeId && item.OptTypeId && item.ChildrenTypeId " :value="item.Id" :label="item.DescriptionCN" />
</el-select> </el-select>
<el-button type="primary" size="mini" @click="handleCope(selectRow)"></el-button> <el-button type="primary" size="mini" @click="handleCope(selectRow)"></el-button>
<el-button type="primary" size="mini" @click="handleAdd(selectRow)"></el-button> <el-button type="primary" size="mini" @click="handleAdd(selectRow)"></el-button>

View File

@ -1,411 +0,0 @@
<template>
<div class="app-container my_menu">
<el-form :inline="true">
<el-form-item label="操作名">
<el-input
v-model="queryParams.menuName"
placeholder="请输入操作名"
clearable
size="small"
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item label="模块">
<el-select v-model="queryParams.visible" placeholder="模块" clearable size="small" />
</el-form-item>
<el-form-item>
<el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery"></el-button>
<el-button type="primary" icon="el-icon-plus" size="mini" @click="handleAdd"></el-button>
</el-form-item>
</el-form>
<div>
<el-button
type="info"
plain
icon="el-icon-sort"
size="mini"
@click="toggleExpandAll"
>展开/折叠</el-button>
</div>
<el-table
v-if="refreshTable"
v-loading="loading"
:data="menuList"
:default-expand-all="isExpandAll"
row-key="Id"
:tree-props="{children: 'Children', hasChildren: 'hasChildren'}"
>
<el-table-column prop="ModuleTypeValueCN" label="模块" align="left" min-width="230px" />
<el-table-column prop="OptTypeValueCN" label="操作类型" min-width="120px" />
<el-table-column prop="ChildrenTypeValueCN" label="操作子类" min-width="120px" show-overflow-tooltip />
<el-table-column prop="Description" label="操作名称" :show-overflow-tooltip="true" min-width="200px" />
<el-table-column prop="Code" label="字段名" min-width="120px" :show-overflow-tooltip="true" />
<el-table-column prop="Value" label="字段英文" min-width="120px" :show-overflow-tooltip="true" />
<el-table-column prop="ValueCN" label="字段中文" min-width="120px" :show-overflow-tooltip="true" />
<el-table-column label="启用" align="center" prop="CreateTime" min-width="80">
<template slot-scope="scope">
<el-tag v-if="scope.row.IsEnable" size="success"></el-tag>
<el-tag v-else size="danger">禁用</el-tag>
</template>
</el-table-column>
<el-table-column label="是否使用父数据" align="center" prop="CreateTime" min-width="130">
<template slot-scope="scope">
<el-tag v-if="scope.row.IsShowParent" size="success"></el-tag>
<el-tag v-else size="danger">子数据</el-tag>
</template>
</el-table-column>
<el-table-column label="操作" align="center" min-width="180" class-name="small-padding fixed-width">
<template slot-scope="scope">
<el-button
size="mini"
type="text"
icon="el-icon-edit"
@click="handleUpdate(scope.row)"
>修改</el-button>
<el-button
size="mini"
type="text"
v-if="scope.row.ConfigType === 'M'"
icon="el-icon-plus"
@click="handleAdd(scope.row)"
>新增</el-button>
<el-button
size="mini"
type="text"
icon="el-icon-delete"
@click="handleDelete(scope.row)"
>删除</el-button>
</template>
</el-table-column>
</el-table>
<!-- 添加或修改菜单对话框 -->
<el-dialog :title="title" :close-on-click-modal="false" :visible.sync="open" width="680px" append-to-body>
<el-form ref="form" :model="form" label-width="100px">
<el-row>
<el-col :span="24">
<el-form-item label="选择操作">
<treeselect
v-model="form.ParentId"
:options="menuOptions"
:normalizer="normalizer"
:show-count="true"
placeholder="选择上级操作"
/>
</el-form-item>
</el-col>
<el-col :span="12" v-show="form.ConfigType === 'M'">
<el-form-item label="模块" prop="menuType">
<el-select v-model="form.ModuleTypeId" placeholder="模块" clearable size="small" @change="changeDescription">
<el-option v-for="item of dict.type.ModuleType" :value="item.value" :label="item.raw.ValueCN"></el-option>
</el-select>
</el-form-item>
</el-col>
<el-col :span="12" v-show="form.ConfigType === 'M'">
<el-form-item label="操作类型" prop="menuType">
<el-select v-model="form.OptTypeId" placeholder="操作类型" clearable size="small" @change="changeDescription">
<el-option v-for="item of dict.type.OptType" :value="item.value" :label="item.raw.ValueCN"></el-option>
</el-select>
</el-form-item>
</el-col>
<el-col :span="12" v-show="form.ConfigType === 'M'">
<el-form-item label="操作子类" prop="menuType">
<el-select v-model="form.ChildrenTypeId" placeholder="操作子类" clearable size="small" @change="changeDescription">
<el-option v-for="item of dict.type.ChildrenType" :value="item.value" :label="item.raw.ValueCN"></el-option>
</el-select>
</el-form-item>
</el-col>
<el-col :span="12" v-show="form.ConfigType == 'M'">
<el-form-item label="名称" prop="Description">
<el-input v-model="form.Description" placeholder="请输入名称" />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="显示排序" prop="ShowOrder">
<el-input-number v-model="form.Sort" controls-position="right" :min="0" />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item>
<span slot="label">
是否启用
</span>
<el-switch
v-model="form.IsEnable"
:active-value="true"
:inactive-value="false"
/>
</el-form-item>
</el-col>
<el-col :span="12" v-show="form.ConfigType === 'C'">
<el-form-item>
<span slot="label">
继承父数据
</span>
<el-switch
v-model="form.IsShowParent"
:active-value="true"
:inactive-value="false"
/>
</el-form-item>
</el-col>
<el-col :span="24" v-show="form.ConfigType === 'C'">
<el-form-item label="字段key">
<el-input v-model="form.Code" placeholder="请输入字段key" />
</el-form-item>
</el-col>
<el-col :span="12" v-show="form.ConfigType === 'C'">
<el-form-item label="字段英文">
<el-input v-model="form.Value" placeholder="请输入字段英文" />
</el-form-item>
</el-col>
<el-col :span="12" v-show="form.ConfigType === 'C'">
<el-form-item label="字段中文">
<el-input v-model="form.ValueCN" placeholder="请输入字段中文" />
</el-form-item>
</el-col>
<el-col :span="24" v-show="form.ConfigType === 'C'">
<el-form-item label="枚举类型">
<el-radio-group v-model="form.EnumType">
<el-radio :label="null"></el-radio>
<el-radio label="E">枚举</el-radio>
<el-radio label="D">字典</el-radio>
</el-radio-group>
</el-form-item>
</el-col>
<el-col :span="24" v-show="form.ConfigType === 'C' && form.EnumType === 'E'">
<el-form-item label="枚举">
<el-input v-model="form.EnumList" placeholder="请输入枚举" />
</el-form-item>
</el-col>
<el-col :span="24" v-show="form.ConfigType === 'C' && form.EnumType === 'D'">
<el-form-item label="字典code">
<el-input v-model="form.dictionaryKey" placeholder="请输入字典code" />
</el-form-item>
</el-col>
</el-row>
</el-form>
<div slot="footer" class="dialog-footer">
<el-button type="primary" @click="submitForm"> </el-button>
<el-button @click="cancel"> </el-button>
</div>
</el-dialog>
</div>
</template>
<script>
import { getFrontAuditConfigList, addOrUpdateFrontAuditConfig, deleteFrontAuditConfig } from '@/api/dictionary/checkConfig'
import Treeselect from '@riophae/vue-treeselect'
import '@riophae/vue-treeselect/dist/vue-treeselect.css'
import IconSelect from '@/components/IconSelect'
export default {
name: 'checkConfig',
dicts: [ 'OptType', 'ModuleType', 'ChildrenType' ],
components: { Treeselect, IconSelect },
data() {
return {
//
loading: true,
//
menuList: [],
//
menuOptions: [],
//
title: '',
//
open: false,
//
visibleOptions: [],
//
queryParams: {
menuName: undefined,
visible: undefined,
},
//
isExpandAll: false,
//
refreshTable: true,
//
form: {},
//
rules: {
MenuName: [
{ required: true, message: '菜单名称不能为空', trigger: 'blur' }
],
ShowOrder: [
{ required: true, message: '菜单顺序不能为空', trigger: 'blur' }
]
}
}
},
created() {
this.getList()
// this.getDicts("sys_show_hide").then(response => {
// this.visibleOptions = response.data;
// });
},
methods: {
toggleExpandAll() {
this.refreshTable = false
this.isExpandAll = !this.isExpandAll
this.$nextTick(() => {
this.refreshTable = true
})
},
normalizer(node) {
if (node.Children && !node.Children.length) {
delete node.Children
}
return {
id: node.Id,
label: node.Description,
children: node.Children
}
},
toTree(arr, ParentId) {
function loop(ParentId) {
const res = []
for (let i = 0; i < arr.length; i++) {
const item = arr[i]
item.hasChildren = false
if (item.ParentId !== ParentId) {
continue
}
item.Children = loop(item.Id)
res.push(item)
}
return res
}
return loop(ParentId)
},
//
selected(name) {
this.form.MenuIcon = name
},
/** 查询菜单列表 */
getList() {
this.loading = true
getFrontAuditConfigList(this.queryParams).then(res => {
this.menuList = this.toTree(res.Result, '00000000-0000-0000-0000-000000000000')
const menu = { Id: '00000000-0000-0000-0000-000000000000', Description: '操作', Children: [] }
menu.Children = this.menuList
this.menuOptions = Object.assign([], [menu])
this.loading = false
}).catch(function() {})
},
/** 查询菜单下拉树结构 */
getTreeselect() {
this.loading = true
getFrontAuditConfigList({}).then(res => {
const menu = { Id: '00000000-0000-0000-0000-000000000000', Description: '操作', Children: [] }
menu.Children = this.toTree(res.Result, '00000000-0000-0000-0000-000000000000')
this.menuOptions = Object.assign([], [menu])
this.loading = false
}).catch(function() {})
},
//
visibleFormat(row, column) {
if (row.MenuType === 'F') {
return ''
}
return this.selectDictLabel(this.visibleOptions, row.visible)
},
//
cancel() {
this.open = false
this.reset()
},
//
reset() {
this.form = {
Id: null,
ParentId: null,
ConfigType: 'M',
Description: null,
IsEnable: true,
ModuleTypeId: null,
OptTypeId: null,
ChildrenTypeId: null,
IsShowParent: false,
Sort: 0,
Code: null,
Value: null,
ValueCN: null,
EnumType: null
}
this.resetForm('form')
},
findName (id, dict, type) {
if (id) {
return this.dict.type[dict].find(v => {
return v.value === id
}).raw[type]
}
return ''
},
changeDescription () {
this.form.Description = this.findName(this.form.OptTypeId, 'OptType', 'ValueCN') + this.findName(this.form.ModuleTypeId, 'ModuleType', 'ValueCN') + this.findName(this.form.ChildrenTypeId, 'ChildrenType', 'ValueCN')
},
/** 搜索按钮操作 */
handleQuery() {
this.getList()
},
/** 新增按钮操作 */
handleAdd(row) {
this.reset()
this.getTreeselect()
if (row != null) {
this.form.ParentId = row.Id
this.form.ModuleTypeId = row.ModuleTypeId
this.form.OptTypeId = row.OptTypeId
this.form.ChildrenTypeId = row.ChildrenTypeId
if (row.ModuleTypeId && row.OptTypeId && row.ChildrenTypeId) {
this.form.ConfigType = 'C'
}
this.form.Description = row.OptTypeValueCN + row.ModuleTypeValueCN + row.ChildrenTypeValueCN
}
this.open = true
this.title = '添加'
},
/** 修改按钮操作 */
handleUpdate(row) {
this.reset()
this.getTreeselect()
this.form = Object.assign({}, row)
this.open = true
this.title = '修改'
},
/** 提交按钮 */
submitForm: function() {
this.$refs['form'].validate(valid => {
if (valid) {
addOrUpdateFrontAuditConfig(this.form).then(response => {
this.$message.success(this.$t('common:message:savedSuccessfully'))
this.open = false
this.getList()
})
}
})
},
/** 删除按钮操作 */
handleDelete(row) {
this.$confirm('是否确认删除名称为"' + row.Description + '"的数据项?', '警告', {
confirmButtonText: '确定',
cancelButtonText: '取消',
type: 'warning'
}).then(function() {
return deleteFrontAuditConfig(row.Id)
}).then(() => {
this.getList()
this.$message.success('删除成功')
}).catch(function() {})
}
}
}
</script>
<style lang="scss">
.vue-treeselect div{
line-height: 40px;
}
</style>

View File

@ -1,30 +1,29 @@
<template> <template>
<box-content> <box-content>
<div class="search"> <div class="search">
<el-form :inline="true" size="small" class="base-search-form"> <el-form :inline="true" class="base-search-form">
<el-form-item label="CRO Name:"> <!-- CRO Name -->
<el-form-item :label="$t('institutions:cros:label:croName')">
<el-input v-model="searchData.CROName" style="width: 100px" /> <el-input v-model="searchData.CROName" style="width: 100px" />
</el-form-item> </el-form-item>
<el-form-item> <el-form-item>
<el-button type="primary" icon="el-icon-search" @click="handleSearch" <el-button type="primary" icon="el-icon-search" @click="handleSearch">
>Search</el-button {{ $t('common:button:search') }}
> </el-button>
<el-button <el-button
type="primary" type="primary"
icon="el-icon-refresh-left" icon="el-icon-refresh-left"
@click="handleReset" @click="handleReset"
>Reset</el-button
> >
{{ $t('common:button:reset') }}
</el-button>
</el-form-item> </el-form-item>
</el-form> </el-form>
<span style="margin-left: auto"> <span style="margin-left: auto">
<el-button <el-button
size="small"
type="primary" type="primary"
style="margin-left: auto"
icon="el-icon-plus"
@click="handleAddCro" @click="handleAddCro"
>New</el-button >{{ $t('common:button:new') }}</el-button
> >
</span> </span>
</div> </div>
@ -37,30 +36,34 @@
@sort-change="handleSortByColumn" @sort-change="handleSortByColumn"
> >
<el-table-column type="index" width="40" /> <el-table-column type="index" width="40" />
<!-- CRO Code -->
<el-table-column <el-table-column
prop="CROCode" prop="CROCode"
label="CRO Code" :label="$t('institutions:cros:label:croCode')"
min-width="150" min-width="150"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<!-- CRO Name -->
<el-table-column <el-table-column
prop="CROName" prop="CROName"
label="CRO Name" :label="$t('institutions:cros:label:croName')"
min-width="150" min-width="150"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<!-- CRO NameCN -->
<el-table-column <el-table-column
prop="CRONameCN" prop="CRONameCN"
label="CRO NameCN" :label="$t('institutions:cros:label:croNameCN')"
min-width="150" min-width="150"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<!-- Level -->
<el-table-column <el-table-column
prop="IsTrialLevel" prop="IsTrialLevel"
label="Level" :label="$t('institutions:cros:label:level')"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
> >
@ -68,20 +71,20 @@
<span>{{ $fd("IsTrialLevel", String(scope.row.IsTrialLevel)) }}</span> <span>{{ $fd("IsTrialLevel", String(scope.row.IsTrialLevel)) }}</span>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column label="Action" min-width="200"> <el-table-column :label="$t('common:action:action')" min-width="200">
<template slot-scope="scope"> <template slot-scope="scope">
<el-button <el-button
circle type="text"
icon="el-icon-edit-outline"
title="编辑"
@click="handleEdit(scope.row)" @click="handleEdit(scope.row)"
/> >
{{ $t('common:button:edit') }}
</el-button>
<el-button <el-button
circle type="text"
icon="el-icon-delete"
title="删除"
@click="handleDelete(scope.row)" @click="handleDelete(scope.row)"
/> >
{{ $t('common:button:delete') }}
</el-button>
</template> </template>
</el-table-column> </el-table-column>
</el-table> </el-table>
@ -160,13 +163,13 @@ export default {
// CRO // CRO
handleAddCro() { handleAddCro() {
this.rowData = {}; this.rowData = {};
this.title = "Add"; this.title =this.$t('common:button:new');
this.editVisible = true; this.editVisible = true;
}, },
// CRO // CRO
handleEdit(row) { handleEdit(row) {
this.rowData = row; this.rowData = row;
this.title = "Edit"; this.title = this.$t('common:action:edit');
this.editVisible = true; this.editVisible = true;
}, },
// CRO // CRO

View File

@ -5,19 +5,23 @@
:rules="rules" :rules="rules"
class="demo-ruleForm" class="demo-ruleForm"
size="small" size="small"
label-width="120px" label-width="140px"
> >
<div class="base-dialog-body"> <div class="base-dialog-body">
<el-form-item label="CRO Name: " prop="CROName"> <!-- CRO Name -->
<el-form-item :label="$t('institutions:cros:label:croName')" prop="CROName">
<el-input v-model="form.CROName" /> <el-input v-model="form.CROName" />
</el-form-item> </el-form-item>
<el-form-item label="CRO NameCN: " prop="CRONameCN"> <!-- CRO NameCN -->
<el-form-item :label="$t('institutions:cros:label:croNameCN')" prop="CRONameCN">
<el-input v-model="form.CRONameCN" /> <el-input v-model="form.CRONameCN" />
</el-form-item> </el-form-item>
<el-form-item label="CRO Code: " prop="CROCode"> <!-- CRO Code -->
<el-form-item :label="$t('institutions:cros:label:croCode')" prop="CROCode">
<el-input v-model="form.CROCode" /> <el-input v-model="form.CROCode" />
</el-form-item> </el-form-item>
<el-form-item label="Level: "> <!-- Level -->
<el-form-item :label="$t('institutions:cros:label:level')">
<el-switch <el-switch
:disabled="!IsTrialLevel" :disabled="!IsTrialLevel"
v-model="form.IsTrialLevel" v-model="form.IsTrialLevel"
@ -30,10 +34,10 @@
<div class="base-dialog-footer" style="text-align: right; margin-top: 10px"> <div class="base-dialog-footer" style="text-align: right; margin-top: 10px">
<el-form-item> <el-form-item>
<el-button :disabled="btnLoading" type="primary" @click="handleCancel" <el-button :disabled="btnLoading" type="primary" @click="handleCancel"
>Cancel</el-button >{{ $t('common:button:cancel') }}</el-button
> >
<el-button type="primary" :loading="btnLoading" @click="handleSave" <el-button type="primary" :loading="btnLoading" @click="handleSave"
>Save</el-button >{{ $t('common:button:save') }}</el-button
> >
</el-form-item> </el-form-item>
</div> </div>
@ -67,16 +71,16 @@ export default {
}, },
rules: { rules: {
CROName: [ CROName: [
{ required: true, message: "Please specify", trigger: "blur" }, { required: true, message: this.$t('common:ruleMessage:specify'), trigger: "blur" },
{ max: 500, message: "The maximum length is 500" }, { max: 500, message: this.$t('common:ruleMessage:maxLength') + ' 500' },
], ],
CRONameCN: [ CRONameCN: [
{ required: true, message: "Please specify", trigger: "blur" }, { required: true, message: this.$t('common:ruleMessage:specify'), trigger: "blur" },
{ max: 500, message: "The maximum length is 500" }, { max: 500, message: this.$t('common:ruleMessage:maxLength') + ' 500' },
], ],
CROCode: [ CROCode: [
{ required: true, message: "Please specify", trigger: "blur" }, { required: true, message: this.$t('common:ruleMessage:specify'), trigger: "blur" },
{ max: 50, message: "The maximum length is 50" }, { max: 50, message: this.$t('common:ruleMessage:maxLength') + ' 50' },
], ],
}, },
}; };
@ -95,7 +99,7 @@ export default {
.then((res) => { .then((res) => {
this.btnLoading = false; this.btnLoading = false;
if (res.IsSuccess) { if (res.IsSuccess) {
this.$message.success("Saved successfully"); this.$message.success(this.$t('common:message:savedSuccessfully'));
this.$refs["CROForm"].resetFields(); this.$refs["CROForm"].resetFields();
this.$emit("getList"); this.$emit("getList");
this.$emit("close"); this.$emit("close");

View File

@ -8,7 +8,8 @@
label-width="170px" label-width="170px"
> >
<div class="base-dialog-body"> <div class="base-dialog-body">
<el-form-item label="Site: "> <!-- Site -->
<el-form-item :label="$t('institutions:hospitals:label:site')">
<el-select <el-select
v-model="form.SiteId" v-model="form.SiteId"
style="width: 100%" style="width: 100%"
@ -25,40 +26,50 @@
</el-option> </el-option>
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item label="Hospital CN: " prop="HospitalNameCN"> <!-- Hospital CN -->
<el-form-item :label="$t('institutions:hospitals:label:hospitalCN')" prop="HospitalNameCN">
<el-input v-model="form.HospitalNameCN" /> <el-input v-model="form.HospitalNameCN" />
</el-form-item> </el-form-item>
<el-form-item label="Hospital EN: " prop="HospitalName"> <!-- Hospital EN -->
<el-form-item :label="$t('institutions:hospitals:label:hospital')" prop="HospitalName">
<el-input v-model="form.HospitalName" /> <el-input v-model="form.HospitalName" />
</el-form-item> </el-form-item>
<!-- Affiliated University CN -->
<el-form-item <el-form-item
label="Affiliated University CN: " :label="$t('institutions:hospitals:label:universityAffiliatedCN')"
prop="UniversityAffiliatedCN" prop="UniversityAffiliatedCN"
> >
<el-input v-model="form.UniversityAffiliatedCN" /> <el-input v-model="form.UniversityAffiliatedCN" />
</el-form-item> </el-form-item>
<!-- Affiliated University EN -->
<el-form-item <el-form-item
label="Affiliated University EN: " :label="$t('institutions:hospitals:label:universityAffiliated')"
prop="UniversityAffiliated" prop="UniversityAffiliated"
> >
<el-input v-model="form.UniversityAffiliated" /> <el-input v-model="form.UniversityAffiliated" />
</el-form-item> </el-form-item>
<el-form-item label="Country CN: " prop="CountryCN"> <!-- Country CN -->
<el-form-item :label="$t('institutions:hospitals:label:countryCN')" prop="CountryCN">
<el-input v-model="form.CountryCN" /> <el-input v-model="form.CountryCN" />
</el-form-item> </el-form-item>
<el-form-item label="Country EN: " prop="Country"> <!-- Country EN -->
<el-form-item :label="$t('institutions:hospitals:label:country')" prop="Country">
<el-input v-model="form.Country" /> <el-input v-model="form.Country" />
</el-form-item> </el-form-item>
<el-form-item label="Province CN: " prop="ProvinceCN"> <!-- Province CN -->
<el-form-item :label="$t('institutions:hospitals:label:provinceCN')" prop="ProvinceCN">
<el-input v-model="form.ProvinceCN" /> <el-input v-model="form.ProvinceCN" />
</el-form-item> </el-form-item>
<el-form-item label="Province EN: " prop="Province"> <!-- Province EN -->
<el-form-item :label="$t('institutions:hospitals:label:province')" prop="Province">
<el-input v-model="form.Province" /> <el-input v-model="form.Province" />
</el-form-item> </el-form-item>
<el-form-item label="City CN: " prop="CityCN"> <!-- City CN -->
<el-form-item :label="$t('institutions:hospitals:label:cityCN')" prop="CityCN">
<el-input v-model="form.CityCN" /> <el-input v-model="form.CityCN" />
</el-form-item> </el-form-item>
<el-form-item label="City EN: " prop="City"> <!-- City EN -->
<el-form-item :label="$t('institutions:hospitals:label:city')" prop="City">
<el-input v-model="form.City" /> <el-input v-model="form.City" />
</el-form-item> </el-form-item>
</div> </div>
@ -69,14 +80,14 @@
size="small" size="small"
type="primary" type="primary"
@click="handleCancel" @click="handleCancel"
>Cancel</el-button >{{ $t('common:button:cancel') }}</el-button
> >
<el-button <el-button
size="small" size="small"
type="primary" type="primary"
:loading="btnLoading" :loading="btnLoading"
@click="handleSave" @click="handleSave"
>Save</el-button >{{ $t('common:button:save') }}</el-button
> >
</el-form-item> </el-form-item>
</div> </div>
@ -121,29 +132,29 @@ export default {
siteList: [], siteList: [],
rules: { rules: {
HospitalNameCN: [ HospitalNameCN: [
{ required: true, message: 'Please specify', trigger: 'blur' }, { required: true, message: this.$t('common:ruleMessage:specify'), trigger: 'blur' },
{ max: 50, message: 'The maximum length is 50' }, { max: 50, message: this.$t('common:ruleMessage:maxLength') + ' 50' },
], ],
UniversityAffiliated: [ UniversityAffiliated: [
{ max: 100, message: 'The maximum length is 100' }, { max: 100, message: this.$t('common:ruleMessage:maxLength') + ' 100' },
], ],
UniversityAffiliatedCN: [ UniversityAffiliatedCN: [
{ max: 100, message: 'The maximum length is 100' }, { max: 100, message: this.$t('common:ruleMessage:maxLength') + ' 100' },
], ],
Country: [{ max: 50, message: 'The maximum length is 50' }], Country: [{ max: 50, message: this.$t('common:ruleMessage:maxLength') + ' 50' }],
CountryCN: [ CountryCN: [
{ required: true, message: 'Please specify', trigger: 'blur' }, { required: true, message: this.$t('common:ruleMessage:specify'), trigger: 'blur' },
{ max: 50, message: 'The maximum length is 50' }, { max: 50, message: this.$t('common:ruleMessage:maxLength') + ' 50' },
], ],
Province: [{ max: 50, message: 'The maximum length is 50' }], Province: [{ max: 50, message: this.$t('common:ruleMessage:maxLength') + ' 50' }],
ProvinceCN: [ ProvinceCN: [
{ required: true, message: 'Please specify', trigger: 'blur' }, { required: true, message: this.$t('common:ruleMessage:specify'), trigger: 'blur' },
{ max: 50, message: 'The maximum length is 50' }, { max: 50, message: this.$t('common:ruleMessage:maxLength') + ' 50' },
], ],
City: [{ max: 50, message: 'The maximum length is 50' }], City: [{ max: 50, message: this.$t('common:ruleMessage:maxLength') + ' 50' }],
CityCN: [ CityCN: [
{ required: true, message: 'Please specify', trigger: 'blur' }, { required: true, message: 'Please specify', trigger: 'blur' },
{ max: 50, message: 'The maximum length is 50' }, { max: 50, message: this.$t('common:ruleMessage:maxLength') + ' 50' },
], ],
}, },
} }
@ -184,7 +195,7 @@ export default {
.then((res) => { .then((res) => {
this.btnLoading = false this.btnLoading = false
if (res.IsSuccess) { if (res.IsSuccess) {
this.$message.success('Saved successfully') this.$message.success(this.$t('common:message:savedSuccessfully'))
this.$refs['hospitalForm'].resetFields() this.$refs['hospitalForm'].resetFields()
this.$emit('getList') this.$emit('getList')
this.$emit('close') this.$emit('close')

View File

@ -1,29 +1,37 @@
<template> <template>
<box-content> <box-content>
<div class="search"> <div class="search">
<el-form :inline="true" size="small" class="base-search-form"> <el-form :inline="true" class="base-search-form">
<el-form-item label="Hospital:"> <!-- Hospital -->
<el-form-item :label="$t('institutions:hospitals:label:hospital')">
<el-input v-model="searchData.HospitalName" style="width:100px;" /> <el-input v-model="searchData.HospitalName" style="width:100px;" />
</el-form-item> </el-form-item>
<el-form-item label="Province:"> <!-- Province -->
<el-form-item :label="$t('institutions:hospitals:label:province')">
<el-input v-model="searchData.Province" style="width:100px;" /> <el-input v-model="searchData.Province" style="width:100px;" />
</el-form-item> </el-form-item>
<el-form-item label="City:"> <!-- City -->
<el-form-item :label="$t('institutions:hospitals:label:city')">
<el-input v-model="searchData.City" style="width:100px;" /> <el-input v-model="searchData.City" style="width:100px;" />
</el-form-item> </el-form-item>
<el-form-item> <el-form-item>
<el-button type="primary" icon="el-icon-search" @click="handleSearch">Search</el-button> <el-button type="primary" icon="el-icon-search" @click="handleSearch">
<el-button type="primary" icon="el-icon-refresh-left" @click="handleReset">Reset</el-button> {{ $t('common:button:search') }}
</el-button>
<el-button
type="primary"
icon="el-icon-refresh-left"
@click="handleReset"
>
{{ $t('common:button:reset') }}
</el-button>
</el-form-item> </el-form-item>
</el-form> </el-form>
<span style="margin-left:auto;"> <span style="margin-left:auto;">
<el-button <el-button
size="small"
type="primary" type="primary"
style="margin-left:auto;"
icon="el-icon-plus"
@click="handleAddHospital" @click="handleAddHospital"
>New</el-button> >{{ $t('common:button:new') }}</el-button>
</span> </span>
</div> </div>
<!-- hospital列表 --> <!-- hospital列表 -->
@ -36,92 +44,102 @@
@sort-change="handleSortByColumn" @sort-change="handleSortByColumn"
> >
<el-table-column type="index" width="40" /> <el-table-column type="index" width="40" />
<!-- Hospital -->
<el-table-column <el-table-column
prop="HospitalName" prop="HospitalName"
label="Hospital" :label="$t('institutions:hospitals:label:hospital')"
min-width="120" min-width="120"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<!-- Hospital CN -->
<el-table-column <el-table-column
prop="HospitalNameCN" prop="HospitalNameCN"
label="Hospital CN" label="Hospital CN"
:label="$t('institutions:hospitals:label:hospitalCN')"
min-width="120" min-width="120"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<!-- University Affiliated -->
<el-table-column <el-table-column
prop="UniversityAffiliated" prop="UniversityAffiliated"
label="University Affiliated" :label="$t('institutions:hospitals:label:universityAffiliated')"
min-width="170" min-width="170"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<!-- University Affiliated CN -->
<el-table-column <el-table-column
prop="UniversityAffiliatedCN" prop="UniversityAffiliatedCN"
label="University Affiliated CN" :label="$t('institutions:hospitals:label:universityAffiliatedCN')"
min-width="170" min-width="170"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<!-- Country -->
<el-table-column <el-table-column
prop="Country" prop="Country"
label="Country" :label="$t('institutions:hospitals:label:country')"
width="120" width="120"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<!-- Country CN -->
<el-table-column <el-table-column
prop="CountryCN" prop="CountryCN"
label="Country CN" :label="$t('institutions:hospitals:label:countryCN')"
width="140" width="140"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<!-- Province -->
<el-table-column <el-table-column
prop="Province" prop="Province"
label="Province" :label="$t('institutions:hospitals:label:province')"
width="120" width="120"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<!-- Province CN -->
<el-table-column <el-table-column
prop="ProvinceCN" prop="ProvinceCN"
label="Province CN" :label="$t('institutions:hospitals:label:provinceCN')"
width="140" width="140"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<!-- City -->
<el-table-column <el-table-column
prop="City" prop="City"
label="City" :label="$t('institutions:hospitals:label:city')"
width="120" width="120"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<!-- City CN -->
<el-table-column <el-table-column
prop="CityCN" prop="CityCN"
label="City CN" :label="$t('institutions:hospitals:label:cityCN')"
width="120" width="130"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<el-table-column label="Action" width="150"> <el-table-column :label="$t('common:action:action')" width="150">
<template slot-scope="scope"> <template slot-scope="scope">
<el-button <el-button
circle type="text"
icon="el-icon-edit-outline"
title="编辑"
@click="handleEdit(scope.row)" @click="handleEdit(scope.row)"
/> >
{{ $t('common:button:edit') }}
</el-button>
<el-button <el-button
circle type="text"
icon="el-icon-delete"
title="删除"
@click="handleDelete(scope.row)" @click="handleDelete(scope.row)"
/> >
{{ $t('common:button:delete') }}
</el-button>
</template> </template>
</el-table-column> </el-table-column>
</el-table> </el-table>
@ -190,13 +208,13 @@ export default {
// //
handleAddHospital() { handleAddHospital() {
this.rowData = {} this.rowData = {}
this.editDialog.title = 'Add' this.editDialog.title = this.$t('common:button:new')
this.editDialog.visible = true this.editDialog.visible = true
}, },
// //
handleEdit(row) { handleEdit(row) {
this.rowData = row this.rowData = row
this.editDialog.title = 'Edit' this.editDialog.title = this.$t('common:action:edit')
this.editDialog.visible = true this.editDialog.visible = true
}, },
// //

View File

@ -9,49 +9,50 @@
label-width="150px" label-width="150px"
> >
<div class="base-dialog-body"> <div class="base-dialog-body">
<el-form-item label="Site Code: " v-if="form.Id" prop="SiteCode"> <!-- Site Code -->
<el-form-item :label="$t('institutions:sites:label:siteCode')" v-if="form.Id" prop="SiteCode">
<el-input v-model="form.SiteCode" disabled /> <el-input v-model="form.SiteCode" disabled />
</el-form-item> </el-form-item>
<!-- 中心名称 --> <!-- 中心名称 -->
<el-form-item <el-form-item
:label="$t('trials:customSite:form:siteName')" :label="$t('institutions:sites:label:siteName')"
prop="SiteName" prop="SiteName"
> >
<el-input v-model="form.SiteName" /> <el-input v-model="form.SiteName" />
</el-form-item> </el-form-item>
<!-- 中心名称CN --> <!-- 中心名称CN -->
<el-form-item <el-form-item
:label="$t('trials:customSite:form:siteName') + 'CN'" :label="$t('institutions:sites:label:siteNameCN')"
prop="SiteNameCN" prop="SiteNameCN"
> >
<el-input v-model="form.SiteNameCN" /> <el-input v-model="form.SiteNameCN" />
</el-form-item> </el-form-item>
<!-- Alias Name -->
<el-form-item label="Alias Name: "> <el-form-item :label="$t('institutions:sites:label:aliasName')">
<el-input v-model="form.AliasName" /> <el-input v-model="form.AliasName" />
</el-form-item> </el-form-item>
<el-form-item label="组织机构代码: "> <!-- <el-form-item label="组织机构代码: ">
<el-input v-model="form.UniqueCode" /> <el-input v-model="form.UniqueCode" />
</el-form-item> </el-form-item> -->
<!-- Country -->
<el-form-item label="Country: " prop="Country"> <el-form-item :label="$t('institutions:sites:label:country')" prop="Country">
<el-input v-model="form.Country" /> <el-input v-model="form.Country" />
</el-form-item> </el-form-item>
<!-- City -->
<el-form-item label="City: " prop="City"> <el-form-item :label="$t('institutions:sites:label:city')" prop="City">
<el-input v-model="form.City" /> <el-input v-model="form.City" />
</el-form-item> </el-form-item>
<el-form-item label="Address: " prop="Address"> <!-- Address -->
<el-form-item :label="$t('institutions:sites:label:address')" prop="Address">
<el-input v-model="form.Address" /> <el-input v-model="form.Address" />
</el-form-item> </el-form-item>
<!-- Affiliated Hospital -->
<el-form-item label="Affiliated Hospital: "> <el-form-item :label="$t('institutions:sites:label:affiliatedHospital')">
<el-select <el-select
v-model="form.HospitalId" v-model="form.HospitalId"
clearable clearable
placeholder="Please select"
style="width: 100%" style="width: 100%"
> >
<el-option <el-option
@ -62,20 +63,20 @@
/> />
</el-select> </el-select>
</el-form-item> </el-form-item>
<!-- Director Name -->
<el-form-item label="Director Name: " prop="DirectorName"> <el-form-item :label="$t('institutions:sites:label:directorName')" prop="DirectorName">
<el-input v-model="form.DirectorName" /> <el-input v-model="form.DirectorName" />
</el-form-item> </el-form-item>
<!-- Director Phone -->
<el-form-item label="Director Phone: " prop="DirectorPhone"> <el-form-item :label="$t('institutions:sites:label:directorPhone')" prop="DirectorPhone">
<el-input v-model="form.DirectorPhone" /> <el-input v-model="form.DirectorPhone" />
</el-form-item> </el-form-item>
<!-- Contact Name -->
<el-form-item label="Contact Name: " prop="ContactName"> <el-form-item :label="$t('institutions:sites:label:contactName')" prop="ContactName">
<el-input v-model="form.ContactName" /> <el-input v-model="form.ContactName" />
</el-form-item> </el-form-item>
<!-- Contact Phone -->
<el-form-item label="Contact Phone: " prop="ContactPhone"> <el-form-item :label="$t('institutions:sites:label:contactPhone')" prop="ContactPhone">
<el-input v-model="form.ContactPhone" /> <el-input v-model="form.ContactPhone" />
</el-form-item> </el-form-item>
</div> </div>
@ -86,14 +87,14 @@
size="small" size="small"
type="primary" type="primary"
@click="handleCancel" @click="handleCancel"
>Cancel</el-button >{{ $t('common:button:cancel') }}</el-button
> >
<el-button <el-button
size="small" size="small"
type="primary" type="primary"
:loading="btnLoading" :loading="btnLoading"
@click="handleSave" @click="handleSave"
>Save</el-button >{{ $t('common:button:save') }}</el-button
> >
</el-form-item> </el-form-item>
</div> </div>
@ -133,35 +134,35 @@ export default {
}, },
rules: { rules: {
SiteName: [ SiteName: [
{ required: true, message: 'Please specify', trigger: 'blur' }, { required: true, message: this.$t('common:ruleMessage:specify'), trigger: 'blur' },
// { max: 50, message: 'The maximum length is 50' } // { max: 50, message: 'The maximum length is 50' }
], ],
SiteNameCN: [ SiteNameCN: [
{ required: true, message: 'Please specify', trigger: 'blur' }, { required: true, message: this.$t('common:ruleMessage:specify'), trigger: 'blur' },
// { max: 50, message: 'The maximum length is 50' } // { max: 50, message: 'The maximum length is 50' }
], ],
SiteCode: [ SiteCode: [
{ required: true, message: 'Please specify', trigger: 'blur' }, { required: true, message: this.$t('common:ruleMessage:specify'), trigger: 'blur' },
{ max: 50, message: 'The maximum length is 50' }, { max: 50, message: this.$t('common:ruleMessage:maxLength') + ' 50' },
], ],
Country: [ Country: [
{ required: true, message: 'Please specify', trigger: 'blur' }, { required: true, message: this.$t('common:ruleMessage:specify'), trigger: 'blur' },
{ max: 50, message: 'The maximum length is 50' }, { max: 50, message: this.$t('common:ruleMessage:maxLength') + ' 50' },
], ],
City: [ City: [
{ required: true, message: 'Please specify', trigger: 'blur' }, { required: true, message: this.$t('common:ruleMessage:specify'), trigger: 'blur' },
{ max: 50, message: 'The maximum length is 50' }, { max: 50, message: this.$t('common:ruleMessage:maxLength') + ' 50' },
], ],
// HospitalId: [ // HospitalId: [
// { required: true, message: 'Please specify', trigger: 'blur' } // { required: true, message: 'Please specify', trigger: 'blur' }
// ], // ],
Address: [ Address: [
{ required: true, message: 'Please specify', trigger: 'blur' }, { required: true, message: this.$t('common:ruleMessage:specify'), trigger: 'blur' },
], ],
DirectorName: [{ max: 50, message: 'The maximum length is 50' }], DirectorName: [{ max: 50, message: this.$t('common:ruleMessage:maxLength') + ' 50' }],
DirectorPhone: [{ max: 50, message: 'The maximum length is 50' }], DirectorPhone: [{ max: 50, message: this.$t('common:ruleMessage:maxLength') + ' 50' }],
ContactName: [{ max: 50, message: 'The maximum length is 50' }], ContactName: [{ max: 50, message: this.$t('common:ruleMessage:maxLength') + ' 50' }],
ContactPhone: [{ max: 50, message: 'The maximum length is 50' }], ContactPhone: [{ max: 50, message: this.$t('common:ruleMessage:maxLength') + ' 50' }],
}, },
loading: false, loading: false,
show: false, show: false,
@ -180,7 +181,7 @@ export default {
.then((res) => { .then((res) => {
this.btnLoading = false this.btnLoading = false
if (res.IsSuccess) { if (res.IsSuccess) {
this.$message.success('Saved successfully') this.$message.success(this.$t('common:message:savedSuccessfully'))
this.$refs['siteForm'].resetFields() this.$refs['siteForm'].resetFields()
this.$emit('getList') this.$emit('getList')
this.$emit('close') this.$emit('close')

View File

@ -1,46 +1,49 @@
<template> <template>
<box-content> <box-content>
<div class="search"> <div class="search">
<el-form :inline="true" size="small" class="base-search-form"> <el-form :inline="true" class="base-search-form">
<el-form-item label="Site Name:"> <!-- Site Name -->
<el-form-item :label="$t('institutions:sites:label:siteName')">
<el-input v-model="searchData.SiteName" style="width: 120px" /> <el-input v-model="searchData.SiteName" style="width: 120px" />
</el-form-item> </el-form-item>
<el-form-item label="Alias Name:"> <!-- Alias Name -->
<el-form-item :label="$t('institutions:sites:label:aliasName')">
<el-input v-model="searchData.AliasName" style="width: 120px" /> <el-input v-model="searchData.AliasName" style="width: 120px" />
</el-form-item> </el-form-item>
<el-form-item label="Country:"> <!-- Country -->
<el-form-item :label="$t('institutions:sites:label:country')">
<el-input v-model="searchData.Country" style="width: 120px" /> <el-input v-model="searchData.Country" style="width: 120px" />
</el-form-item> </el-form-item>
<el-form-item label="City:"> <!-- City -->
<el-form-item :label="$t('institutions:sites:label:city')">
<el-input v-model="searchData.City" style="width: 120px" /> <el-input v-model="searchData.City" style="width: 120px" />
</el-form-item> </el-form-item>
<el-form-item> <el-form-item>
<el-button type="primary" icon="el-icon-search" @click="handleSearch" <el-button type="primary" icon="el-icon-search" @click="handleSearch">
>Search</el-button {{ $t('common:button:search') }}
> </el-button>
<el-button <el-button
type="primary" type="primary"
icon="el-icon-refresh-left" icon="el-icon-refresh-left"
@click="handleReset" @click="handleReset"
>Reset</el-button
> >
{{ $t('common:button:reset') }}
</el-button>
</el-form-item> </el-form-item>
</el-form> </el-form>
<div style="margin-left: auto"> <div style="margin-left: auto">
<el-button <el-button
type="primary" type="primary"
size="small"
icon="el-icon-plus" icon="el-icon-plus"
@click="handleAddSystemSite" @click="handleAddSystemSite"
>{{ $t("trial:dictionary:institutions:site:addSystemSite") }} >{{ $t("trial:dictionary:institutions:site:addSystemSite") }}
</el-button> </el-button>
<el-button <el-button
type="primary" type="primary"
size="small"
style="margin-left: 10px" style="margin-left: 10px"
icon="el-icon-plus"
@click="handleAddSite" @click="handleAddSite"
>New >
{{ $t('common:button:new') }}
</el-button> </el-button>
</div> </div>
</div> </div>
@ -53,111 +56,131 @@
@sort-change="handleSortByColumn" @sort-change="handleSortByColumn"
> >
<el-table-column type="index" width="40" /> <el-table-column type="index" width="40" />
<!-- Site Code -->
<el-table-column <el-table-column
prop="SiteCode" prop="SiteCode"
label="Site Code" :label="$t('institutions:sites:label:siteCode')"
min-width="120" min-width="120"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<!-- Site Name -->
<el-table-column <el-table-column
prop="SiteName" prop="SiteName"
label="Site Name" :label="$t('institutions:sites:label:siteName')"
min-width="150" min-width="150"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<el-table-column
prop="SiteNameCN"
:label="$t('institutions:sites:label:siteNameCN')"
min-width="150"
show-overflow-tooltip
sortable="custom"
/>
<!-- Alias Name -->
<el-table-column <el-table-column
prop="AliasName" prop="AliasName"
label="Alias Name" :label="$t('institutions:sites:label:aliasName')"
min-width="150" min-width="150"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<el-table-column <!-- <el-table-column
prop="UniqueCode" prop="UniqueCode"
label="组织机构代码" label="组织机构代码"
min-width="130" min-width="130"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> /> -->
<!-- Country -->
<el-table-column <el-table-column
prop="Country" prop="Country"
label="Country" :label="$t('institutions:sites:label:country')"
min-width="120" min-width="120"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<!-- City -->
<el-table-column <el-table-column
prop="City" prop="City"
label="City" :label="$t('institutions:sites:label:city')"
min-width="120" min-width="120"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<!-- Address -->
<el-table-column <el-table-column
prop="Address" prop="Address"
label="Address" :label="$t('institutions:sites:label:address')"
min-width="120" min-width="120"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<!-- Affiliated Hospital -->
<el-table-column <el-table-column
prop="HospitalName" prop="HospitalName"
label="Affiliated Hospital" :label="$t('institutions:sites:label:affiliatedHospital')"
min-width="180" min-width="180"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<!-- Director Name -->
<el-table-column <el-table-column
prop="DirectorName" prop="DirectorName"
label="Director Name" :label="$t('institutions:sites:label:directorName')"
min-width="160" min-width="160"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<!-- Director Phone -->
<el-table-column <el-table-column
prop="DirectorPhone" prop="DirectorPhone"
label="Director Phone" :label="$t('institutions:sites:label:directorPhone')"
min-width="150" min-width="150"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<!-- Contact Name -->
<el-table-column <el-table-column
prop="ContactName" prop="ContactName"
label="Contact Name" :label="$t('institutions:sites:label:contactName')"
min-width="150" min-width="150"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<!-- Contact Phone -->
<el-table-column <el-table-column
prop="ContactPhone" prop="ContactPhone"
label="Contact Phone" :label="$t('institutions:sites:label:contactPhone')"
min-width="160" min-width="160"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<!-- CreateTime -->
<el-table-column <el-table-column
prop="CreateTime" prop="CreateTime"
label="CreateTime" :label="$t('institutions:sites:label:createTime')"
min-width="160" min-width="160"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<el-table-column label="Action" fixed="right" width="150"> <el-table-column :label="$t('common:action:action')" fixed="right" width="150">
<template slot-scope="scope"> <template slot-scope="scope">
<el-button <el-button
circle type="text"
icon="el-icon-edit-outline"
title="编辑"
@click="handleEdit(scope.row)" @click="handleEdit(scope.row)"
/> >
{{ $t('common:button:edit') }}
</el-button>
<el-button <el-button
circle type="text"
icon="el-icon-delete"
title="删除"
@click="handleDelete(scope.row)" @click="handleDelete(scope.row)"
/> >
{{ $t('common:button:delete') }}
</el-button>
</template> </template>
</el-table-column> </el-table-column>
</el-table> </el-table>
@ -357,7 +380,7 @@ export default {
data() { data() {
return { return {
editVisible: false, editVisible: false,
title: "Add", title: this.$t('common:button:new'),
searchData: searchDataDefault(), searchData: searchDataDefault(),
list: [], list: [],
total: 0, total: 0,
@ -439,13 +462,13 @@ export default {
// Site // Site
handleAddSite() { handleAddSite() {
this.rowData = {}; this.rowData = {};
this.title = "Add"; this.title = this.$t('common:button:new');
this.editVisible = true; this.editVisible = true;
}, },
// Site // Site
handleEdit(row) { handleEdit(row) {
this.rowData = row; this.rowData = row;
this.title = "Edit"; this.title = this.$t('common:action:edit');
this.editVisible = true; this.editVisible = true;
}, },
// Site // Site

View File

@ -8,16 +8,20 @@
label-width="150px" label-width="150px"
> >
<div class="base-dialog-body"> <div class="base-dialog-body">
<el-form-item label="Sponsor Name: " prop="SponsorName"> <!-- Sponsor Name -->
<el-form-item :label="$t('institutions:sponsors:label:sponsorName')" prop="SponsorName">
<el-input v-model="form.SponsorName" /> <el-input v-model="form.SponsorName" />
</el-form-item> </el-form-item>
<el-form-item label="Sponsor NameCN: " prop="SponsorName"> <!-- Sponsor NameCN -->
<el-form-item :label="$t('institutions:sponsors:label:sponsorNameCN')" prop="SponsorName">
<el-input v-model="form.SponsorNameCN" /> <el-input v-model="form.SponsorNameCN" />
</el-form-item> </el-form-item>
<el-form-item label="Sponsor Code: " prop="SponsorCode"> <!-- Sponsor Code -->
<el-form-item :label="$t('institutions:sponsors:label:sponsorCode')" prop="SponsorCode">
<el-input v-model="form.SponsorCode" /> <el-input v-model="form.SponsorCode" />
</el-form-item> </el-form-item>
<el-form-item label="Level: "> <!-- Level -->
<el-form-item :label="$t('institutions:sponsors:label:level')">
<el-switch <el-switch
:disabled="!IsTrialLevel" :disabled="!IsTrialLevel"
v-model="form.IsTrialLevel" v-model="form.IsTrialLevel"
@ -34,15 +38,17 @@
size="small" size="small"
type="primary" type="primary"
@click="handleCancel" @click="handleCancel"
>Cancel</el-button
> >
{{ $t('common:button:cancel') }}
</el-button>
<el-button <el-button
size="small" size="small"
type="primary" type="primary"
:loading="btnLoading" :loading="btnLoading"
@click="handleSave" @click="handleSave"
>Save</el-button
> >
{{ $t('common:button:save') }}
</el-button>
</el-form-item> </el-form-item>
</div> </div>
</el-form> </el-form>
@ -75,16 +81,16 @@ export default {
}, },
rules: { rules: {
SponsorName: [ SponsorName: [
{ required: true, message: "Please specify", trigger: "blur" }, { required: true, message: this.$t('common:ruleMessage:specify'), trigger: "blur" },
{ max: 500, message: "The maximum length is 500" }, { max: 500, message: this.$t('common:ruleMessage:maxLength') + ' 500' },
], ],
SponsorNameCN: [ SponsorNameCN: [
{ required: true, message: "Please specify", trigger: "blur" }, { required: true, message: this.$t('common:ruleMessage:specify'), trigger: "blur" },
{ max: 500, message: "The maximum length is 500" }, { max: 500, message: this.$t('common:ruleMessage:maxLength') + ' 500' },
], ],
SponsorCode: [ SponsorCode: [
{ required: true, message: "Please specify", trigger: "blur" }, { required: true, message: this.$t('common:ruleMessage:specify'), trigger: "blur" },
{ max: 50, message: "The maximum length is 50" }, { max: 50, message: this.$t('common:ruleMessage:maxLength') + ' 50' },
], ],
}, },
}; };
@ -103,7 +109,7 @@ export default {
.then((res) => { .then((res) => {
this.btnLoading = false; this.btnLoading = false;
if (res.IsSuccess) { if (res.IsSuccess) {
this.$message.success("Saved successfully"); this.$message.success(this.$t('common:message:savedSuccessfully'));
this.$refs["sponsorForm"].resetFields(); this.$refs["sponsorForm"].resetFields();
this.$emit("getList"); this.$emit("getList");
this.$emit("close"); this.$emit("close");

View File

@ -1,30 +1,30 @@
<template> <template>
<box-content> <box-content>
<div class="search"> <div class="search">
<el-form :inline="true" size="small" class="base-search-form"> <el-form :inline="true" class="base-search-form">
<el-form-item label="Sponsor Name:"> <!-- Sponsor Name -->
<el-form-item :label="$t('institutions:sponsors:label:sponsorName')">
<el-input v-model="searchData.SponsorName" style="width: 100px" /> <el-input v-model="searchData.SponsorName" style="width: 100px" />
</el-form-item> </el-form-item>
<el-form-item> <el-form-item>
<el-button type="primary" icon="el-icon-search" @click="handleSearch" <el-button type="primary" icon="el-icon-search" @click="handleSearch">
>Search</el-button {{ $t('common:button:search') }}
> </el-button>
<el-button <el-button
type="primary" type="primary"
icon="el-icon-refresh-left" icon="el-icon-refresh-left"
@click="handleReset" @click="handleReset"
>Reset</el-button
> >
{{ $t('common:button:reset') }}
</el-button>
</el-form-item> </el-form-item>
</el-form> </el-form>
<span style="margin-left: auto"> <span style="margin-left: auto">
<el-button <el-button
size="small"
type="primary" type="primary"
style="margin-left: auto" style="margin-left: auto"
icon="el-icon-plus"
@click="handleAddSponsor" @click="handleAddSponsor"
>New</el-button >{{ $t('common:button:new') }}</el-button
> >
</span> </span>
</div> </div>
@ -37,30 +37,34 @@
@sort-change="handleSortByColumn" @sort-change="handleSortByColumn"
> >
<el-table-column type="index" width="40" /> <el-table-column type="index" width="40" />
<!-- Sponsor Code -->
<el-table-column <el-table-column
prop="SponsorCode" prop="SponsorCode"
label="Sponsor Code" :label="$t('institutions:sponsors:label:sponsorCode')"
min-width="100" min-width="100"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<!-- Sponsor Name -->
<el-table-column <el-table-column
prop="SponsorName" prop="SponsorName"
label="Sponsor Name" :label="$t('institutions:sponsors:label:sponsorName')"
min-width="100" min-width="100"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<!-- Sponsor NameCN -->
<el-table-column <el-table-column
prop="SponsorNameCN" prop="SponsorNameCN"
label="Sponsor NameCN" :label="$t('institutions:sponsors:label:sponsorNameCN')"
min-width="100" min-width="100"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<!-- Level -->
<el-table-column <el-table-column
prop="IsTrialLevel" prop="IsTrialLevel"
label="Level" :label="$t('institutions:sponsors:label:level')"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
> >
@ -68,20 +72,20 @@
<span>{{ $fd("IsTrialLevel", String(scope.row.IsTrialLevel)) }}</span> <span>{{ $fd("IsTrialLevel", String(scope.row.IsTrialLevel)) }}</span>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column label="Action" min-width="150"> <el-table-column :label="$t('common:action:action')" min-width="150">
<template slot-scope="scope"> <template slot-scope="scope">
<el-button <el-button
circle type="text"
icon="el-icon-edit-outline"
title="编辑"
@click="handleEdit(scope.row)" @click="handleEdit(scope.row)"
/> >
{{ $t('common:button:edit') }}
</el-button>
<el-button <el-button
circle type="text"
icon="el-icon-delete"
title="删除"
@click="handleDelete(scope.row)" @click="handleDelete(scope.row)"
/> >
{{ $t('common:button:delete') }}
</el-button>
</template> </template>
</el-table-column> </el-table-column>
</el-table> </el-table>
@ -160,13 +164,13 @@ export default {
// Sponsor // Sponsor
handleAddSponsor() { handleAddSponsor() {
this.rowData = {}; this.rowData = {};
this.title = "Add"; this.title = this.$t('common:button:new');
this.editVisible = true; this.editVisible = true;
}, },
// Sponsor // Sponsor
handleEdit(row) { handleEdit(row) {
this.rowData = row; this.rowData = row;
this.title = "Edit"; this.title = this.$t('common:action:edit');
this.editVisible = true; this.editVisible = true;
}, },
// Sponsor // Sponsor

View File

@ -1,16 +1,20 @@
<template> <template>
<div class="institution-wrapper"> <div class="institution-wrapper">
<el-tabs v-model="activeTab" @tab-click="clickTab"> <el-tabs v-model="activeTab" @tab-click="clickTab">
<el-tab-pane label="Hospitals" name="Hospitals"> <!-- Hospitals -->
<el-tab-pane :label="$t('institutions:tab:hospitals')" name="Hospitals">
<Hospitals v-if="activeTab === 'Hospitals'" /> <Hospitals v-if="activeTab === 'Hospitals'" />
</el-tab-pane> </el-tab-pane>
<el-tab-pane label="Sites" name="Sites"> <!-- Sites -->
<el-tab-pane :label="$t('institutions:tab:sites')" name="Sites">
<Sites v-if="activeTab === 'Sites'" /> <Sites v-if="activeTab === 'Sites'" />
</el-tab-pane> </el-tab-pane>
<el-tab-pane label="CROs" name="CROs"> <!-- CROs -->
<el-tab-pane :label="$t('institutions:tab:CROs')" name="CROs">
<CROs v-if="activeTab === 'CROs'" /> <CROs v-if="activeTab === 'CROs'" />
</el-tab-pane> </el-tab-pane>
<el-tab-pane label="Sponsors" name="Sponsors"> <!-- Sponsors -->
<el-tab-pane :label="$t('institutions:tab:sponsors')" name="Sponsors">
<Sponsors v-if="activeTab === 'Sponsors'" /> <Sponsors v-if="activeTab === 'Sponsors'" />
</el-tab-pane> </el-tab-pane>
</el-tabs> </el-tabs>

View File

@ -2,7 +2,7 @@
<box-content> <box-content>
<!-- 搜索框 --> <!-- 搜索框 -->
<div class="search"> <div class="search">
<el-form :inline="true" size="mini" class="base-search-form"> <el-form :inline="true" class="base-search-form">
<el-form-item label="字典表名称:"> <el-form-item label="字典表名称:">
<el-input v-model="searchData.Code" clearable style="width:120px;" /> <el-input v-model="searchData.Code" clearable style="width:120px;" />
</el-form-item> </el-form-item>
@ -12,12 +12,24 @@
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item> <el-form-item>
<el-button type="primary" @click="handleReset">Reset</el-button> <el-button
<el-button type="primary" @click="handleSearch">Search</el-button> type="primary"
icon="el-icon-search"
@click="handleSearch"
>
{{ $t('common:button:search') }}
</el-button>
<el-button
type="primary"
icon="el-icon-refresh-left"
@click="handleReset"
>
{{ $t('common:button:reset') }}
</el-button>
</el-form-item> </el-form-item>
</el-form> </el-form>
<span style="margin-left:auto"> <span style="margin-left:auto">
<el-button type="primary" size="mini" @click="handleAdd"></el-button> <el-button type="primary" @click="handleAdd"></el-button>
</span> </span>
</div> </div>
<el-table <el-table
@ -68,25 +80,22 @@
/> />
</template> </template>
</el-table-column> </el-table-column>
<el-table-column label="操作" width="300" fixed="right"> <el-table-column label="操作" width="200" fixed="right">
<template slot-scope="scope"> <template slot-scope="scope">
<el-button <el-button
type="primary" type="text"
size="mini"
@click="handleEdit(scope.row)" @click="handleEdit(scope.row)"
> >
编辑 编辑
</el-button> </el-button>
<el-button <el-button
type="success" type="text"
size="mini"
@click="handleChild(scope.row)" @click="handleChild(scope.row)"
> >
子项 子项
</el-button> </el-button>
<el-button <el-button
type="danger" type="text"
size="mini"
@click="handleDelete(scope.row)" @click="handleDelete(scope.row)"
> >
删除 删除

View File

@ -63,18 +63,16 @@
/> />
</template> </template>
</el-table-column> </el-table-column>
<el-table-column label="操作" width="300" fixed="right"> <el-table-column label="操作" width="150" fixed="right">
<template slot-scope="scope"> <template slot-scope="scope">
<el-button <el-button
type="primary" type="text"
size="mini"
@click="handleEdit(scope.row)" @click="handleEdit(scope.row)"
> >
编辑 编辑
</el-button> </el-button>
<el-button <el-button
type="danger" type="text"
size="mini"
@click="handleDelete(scope.row)" @click="handleDelete(scope.row)"
> >
删除 删除

View File

@ -2,7 +2,7 @@
<box-content> <box-content>
<!-- 搜索框 --> <!-- 搜索框 -->
<div class="search"> <div class="search">
<el-form :inline="true" size="mini" class="base-search-form"> <el-form :inline="true" class="base-search-form">
<el-form-item label="字典表名称:"> <el-form-item label="字典表名称:">
<el-input v-model="searchData.Code" clearable style="width:120px;" /> <el-input v-model="searchData.Code" clearable style="width:120px;" />
</el-form-item> </el-form-item>
@ -12,12 +12,24 @@
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item> <el-form-item>
<el-button type="primary" @click="handleReset">Reset</el-button> <el-button
<el-button type="primary" @click="handleSearch">Search</el-button> type="primary"
icon="el-icon-search"
@click="handleSearch"
>
{{ $t('common:button:search') }}
</el-button>
<el-button
type="primary"
icon="el-icon-refresh-left"
@click="handleReset"
>
{{ $t('common:button:reset') }}
</el-button>
</el-form-item> </el-form-item>
</el-form> </el-form>
<span style="margin-left:auto"> <span style="margin-left:auto">
<el-button type="primary" size="mini" @click="handleAdd"></el-button> <el-button type="primary" @click="handleAdd"></el-button>
</span> </span>
</div> </div>
<el-table <el-table
@ -68,25 +80,22 @@
/> />
</template> </template>
</el-table-column> </el-table-column>
<el-table-column label="操作" width="300" fixed="right"> <el-table-column label="操作" width="200" fixed="right">
<template slot-scope="scope"> <template slot-scope="scope">
<el-button <el-button
type="primary" type="text"
size="mini"
@click="handleEdit(scope.row)" @click="handleEdit(scope.row)"
> >
编辑 编辑
</el-button> </el-button>
<el-button <el-button
type="success" type="text"
size="mini"
@click="handleChild(scope.row)" @click="handleChild(scope.row)"
> >
子项 子项
</el-button> </el-button>
<el-button <el-button
type="danger" type="text"
size="mini"
@click="handleDelete(scope.row)" @click="handleDelete(scope.row)"
> >
删除 删除

View File

@ -183,16 +183,13 @@
<el-button <el-button
size="small" size="small"
type="primary" type="primary"
icon="el-icon-plus"
@click="handleAdd" @click="handleAdd"
>{{ $t('common:button:new') }}</el-button> >{{ $t('common:button:new') }}</el-button>
</template> </template>
<template slot-scope="scope"> <template slot-scope="scope">
<!-- 删除 --> <!-- 删除 -->
<el-button <el-button
size="mini"
type="text" type="text"
icon="el-icon-delete"
@click="handleDelete(scope.$index)" @click="handleDelete(scope.$index)"
>{{ $t('common:button:delete') }}</el-button> >{{ $t('common:button:delete') }}</el-button>
</template> </template>

View File

@ -65,15 +65,13 @@
<el-table-column label="操作" width="300" fixed="right"> <el-table-column label="操作" width="300" fixed="right">
<template slot-scope="scope"> <template slot-scope="scope">
<el-button <el-button
type="primary" type="text"
size="mini"
@click="handleEdit(scope.row)" @click="handleEdit(scope.row)"
> >
编辑 编辑
</el-button> </el-button>
<el-button <el-button
type="danger" type="text"
size="mini"
@click="handleDelete(scope.row)" @click="handleDelete(scope.row)"
> >
删除 删除

View File

@ -2,7 +2,7 @@
<box-content> <box-content>
<!-- 搜索框 --> <!-- 搜索框 -->
<div class="search"> <div class="search">
<el-form :inline="true" size="mini" class="base-search-form"> <el-form :inline="true" class="base-search-form">
<el-form-item label="字典表名称:"> <el-form-item label="字典表名称:">
<el-input v-model="searchData.Code" clearable style="width:120px;" /> <el-input v-model="searchData.Code" clearable style="width:120px;" />
</el-form-item> </el-form-item>
@ -15,13 +15,25 @@
<el-input v-model="searchData.KeyInfo" clearable style="width:120px;" /> <el-input v-model="searchData.KeyInfo" clearable style="width:120px;" />
</el-form-item> </el-form-item>
<el-form-item> <el-form-item>
<el-button type="primary" @click="handleReset">Reset</el-button> <el-button
<el-button type="primary" @click="handleSearch">Search</el-button> type="primary"
icon="el-icon-search"
@click="handleSearch"
>
{{ $t('common:button:search') }}
</el-button>
<el-button
type="primary"
icon="el-icon-refresh-left"
@click="handleReset"
>
{{ $t('common:button:reset') }}
</el-button>
</el-form-item> </el-form-item>
</el-form> </el-form>
<span style="margin-left:auto"> <span style="margin-left:auto">
<el-button type="primary" size="mini" @click="handleAdd"></el-button> <el-button type="primary" @click="handleAdd"></el-button>
<el-button type="primary" size="mini" @click="handleBatchAdd"></el-button> <el-button type="primary" @click="handleBatchAdd"></el-button>
</span> </span>
</div> </div>
<el-table <el-table
@ -86,22 +98,19 @@
<el-table-column label="操作" width="300" fixed="right"> <el-table-column label="操作" width="300" fixed="right">
<template slot-scope="scope"> <template slot-scope="scope">
<el-button <el-button
type="primary" type="text"
size="mini"
@click="handleEdit(scope.row)" @click="handleEdit(scope.row)"
> >
编辑 编辑
</el-button> </el-button>
<el-button <el-button
type="success" type="text"
size="mini"
@click="handleChild(scope.row)" @click="handleChild(scope.row)"
> >
子项 子项
</el-button> </el-button>
<el-button <el-button
type="danger" type="text"
size="mini"
@click="handleDelete(scope.row)" @click="handleDelete(scope.row)"
> >
删除 删除

View File

@ -2,7 +2,7 @@
<box-content> <box-content>
<!-- 搜索框 --> <!-- 搜索框 -->
<div class="search"> <div class="search">
<el-form :inline="true" size="mini" class="base-search-form"> <el-form :inline="true" class="base-search-form">
<el-form-item label="字典表名称:"> <el-form-item label="字典表名称:">
<el-input v-model="searchData.Code" clearable style="width:120px;" /> <el-input v-model="searchData.Code" clearable style="width:120px;" />
</el-form-item> </el-form-item>
@ -12,13 +12,25 @@
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item> <el-form-item>
<el-button type="primary" @click="handleReset">Reset</el-button> <el-button
<el-button type="primary" @click="handleSearch">Search</el-button> type="primary"
icon="el-icon-search"
@click="handleSearch"
>
{{ $t('common:button:search') }}
</el-button>
<el-button
type="primary"
icon="el-icon-refresh-left"
@click="handleReset"
>
{{ $t('common:button:reset') }}
</el-button>
</el-form-item> </el-form-item>
</el-form> </el-form>
<span style="margin-left:auto"> <span style="margin-left:auto">
<el-button type="primary" size="mini" @click="handleSetting"></el-button> <el-button type="primary" @click="handleSetting"></el-button>
<el-button type="primary" size="mini" @click="handleAdd"></el-button> <el-button type="primary" @click="handleAdd"></el-button>
</span> </span>
</div> </div>
<el-table <el-table
@ -72,22 +84,19 @@
<el-table-column label="操作" width="300" fixed="right"> <el-table-column label="操作" width="300" fixed="right">
<template slot-scope="scope"> <template slot-scope="scope">
<el-button <el-button
type="primary" type="text"
size="mini"
@click="handleEdit(scope.row)" @click="handleEdit(scope.row)"
> >
编辑 编辑
</el-button> </el-button>
<el-button <el-button
type="success" type="text"
size="mini"
@click="handleChild(scope.row)" @click="handleChild(scope.row)"
> >
子项 子项
</el-button> </el-button>
<el-button <el-button
type="danger" type="text"
size="mini"
@click="handleDelete(scope.row)" @click="handleDelete(scope.row)"
> >
删除 删除

View File

@ -2,7 +2,7 @@
<box-content> <box-content>
<!-- 搜索框 --> <!-- 搜索框 -->
<div class="search"> <div class="search">
<el-form :inline="true" size="mini" class="base-search-form"> <el-form :inline="true" class="base-search-form">
<el-form-item label="Code:"> <el-form-item label="Code:">
<el-input v-model="searchData.Code" clearable style="width:120px;" /> <el-input v-model="searchData.Code" clearable style="width:120px;" />
</el-form-item> </el-form-item>
@ -10,12 +10,24 @@
<el-input v-model="searchData.KeyName" clearable style="width:120px;" /> <el-input v-model="searchData.KeyName" clearable style="width:120px;" />
</el-form-item> </el-form-item>
<el-form-item> <el-form-item>
<el-button type="primary" @click="handleReset">Reset</el-button> <el-button
<el-button type="primary" @click="handleSearch">Search</el-button> type="primary"
icon="el-icon-search"
@click="handleSearch"
>
{{ $t('common:button:search') }}
</el-button>
<el-button
type="primary"
icon="el-icon-refresh-left"
@click="handleReset"
>
{{ $t('common:button:reset') }}
</el-button>
</el-form-item> </el-form-item>
</el-form> </el-form>
<span style="margin-left:auto"> <span style="margin-left:auto">
<el-button type="primary" size="mini" @click="handleAdd">New</el-button> <el-button type="primary" @click="handleAdd">New</el-button>
</span> </span>
</div> </div>
<el-table <el-table
@ -50,18 +62,16 @@
<el-table-column label="Action" width="200" fixed="right"> <el-table-column label="Action" width="200" fixed="right">
<template slot-scope="scope"> <template slot-scope="scope">
<el-button <el-button
type="primary" type="text"
size="mini"
@click="handleEdit(scope.row)" @click="handleEdit(scope.row)"
> >
Edit 编辑
</el-button> </el-button>
<el-button <el-button
type="danger" type="text"
size="mini"
@click="handleDelete(scope.row)" @click="handleDelete(scope.row)"
> >
Delete 删除
</el-button> </el-button>
</template> </template>
</el-table-column> </el-table-column>

View File

@ -3,15 +3,25 @@
<!-- 搜索框 --> <!-- 搜索框 -->
<div class="search"> <div class="search">
<el-form :inline="true" size="mini" class="base-search-form"> <el-form :inline="true" size="mini" class="base-search-form">
<el-form-item label="编号:"> <!-- 编号 -->
<el-form-item :label="$t('dictionary:sign:label:code')">
<el-input v-model="searchData.Code" style="width:100px;" /> <el-input v-model="searchData.Code" style="width:100px;" />
</el-form-item> </el-form-item>
<el-form-item label="模板:"> <!-- 模板 -->
<el-form-item :label="$t('dictionary:sign:label:name')">
<el-input v-model="searchData.Name" style="width:100px;" /> <el-input v-model="searchData.Name" style="width:100px;" />
</el-form-item> </el-form-item>
<el-form-item> <el-form-item>
<el-button type="primary" @click="handleReset">Reset</el-button> <el-button type="primary" icon="el-icon-search" @click="handleSearch">
<el-button type="primary" @click="handleSearch">Search</el-button> {{ $t('common:button:search') }}
</el-button>
<el-button
type="primary"
icon="el-icon-refresh-left"
@click="handleReset"
>
{{ $t('common:button:reset') }}
</el-button>
</el-form-item> </el-form-item>
</el-form> </el-form>
<span style="margin-left:auto;"> <span style="margin-left:auto;">
@ -20,7 +30,7 @@
size="mini" size="mini"
@click="handleAdd" @click="handleAdd"
> >
New {{ $t('common:button:new') }}
</el-button> </el-button>
</span> </span>
@ -37,58 +47,65 @@
@sort-change="handleSortByColumn" @sort-change="handleSortByColumn"
> >
<el-table-column type="index" width="40" /> <el-table-column type="index" width="40" />
<!-- 编号 -->
<el-table-column <el-table-column
prop="Code" prop="Code"
label="Code" :label="$t('dictionary:sign:label:code')"
sortable="custom" sortable="custom"
show-overflow-tooltip show-overflow-tooltip
/> />
<!-- 模板 -->
<el-table-column <el-table-column
prop="Name" prop="Name"
label="模板" :label="$t('dictionary:sign:label:name')"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<!-- 签名内容(EN) -->
<el-table-column <el-table-column
prop="Value" prop="Value"
label="签名内容(EN)" :label="$t('dictionary:sign:label:value')"
show-overflow-tooltip show-overflow-tooltip
/> />
<!-- 签名内容(CN) -->
<el-table-column <el-table-column
prop="ValueCN" prop="ValueCN"
label="签名内容(CN)" :label="$t('dictionary:sign:label:valueCN')"
show-overflow-tooltip show-overflow-tooltip
/> />
<!-- 更新时间 -->
<el-table-column <el-table-column
prop="UpdateTime" prop="UpdateTime"
label="更新时间" :label="$t('dictionary:sign:label:updateTime')"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<!-- 创建时间 -->
<el-table-column <el-table-column
prop="CreateTime" prop="CreateTime"
label="创建时间" :label="$t('dictionary:sign:label:createTime')"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<el-table-column label="Action" width="200" fixed="right"> <el-table-column :label="$t('common:action:action')" width="200" fixed="right">
<template slot-scope="scope"> <template slot-scope="scope">
<el-button <el-button
type="text" type="text"
@click="handleEdit(scope.row)" @click="handleEdit(scope.row)"
> >
Edit {{ $t('common:button:edit') }}
</el-button> </el-button>
<!-- 场景配置 -->
<el-button <el-button
type="text" type="text"
@click="handleConfig(scope.row)" @click="handleConfig(scope.row)"
> >
场景配置 {{ $t('dictionary:sign:button:config') }}
</el-button> </el-button>
<el-button type="text" @click="handleDelete(scope.row)">Delete</el-button> <el-button type="text" @click="handleDelete(scope.row)">
{{ $t('common:button:delete') }}
</el-button>
</template> </template>
</el-table-column> </el-table-column>
@ -113,7 +130,7 @@
<el-dialog <el-dialog
v-if="configVisible" v-if="configVisible"
:visible.sync="configVisible" :visible.sync="configVisible"
title="场景配置" :title="$t('dictionary:sign:button:config')"
:fullscreen="true" :fullscreen="true"
append-to-body append-to-body
custom-class="base-dialog-wrapper" custom-class="base-dialog-wrapper"
@ -167,13 +184,13 @@ export default {
// //
handleAdd() { handleAdd() {
this.rowData = {} this.rowData = {}
this.title = 'Add' this.title = this.$t('common:button:new')
this.editVisible = true this.editVisible = true
}, },
// //
handleEdit(row) { handleEdit(row) {
this.rowData = { ...row } this.rowData = { ...row }
this.title = 'Edit' this.title = this.$t('common:button:edit')
this.editVisible = true this.editVisible = true
}, },
// //

View File

@ -2,7 +2,7 @@
<box-content> <box-content>
<!-- 搜索框 --> <!-- 搜索框 -->
<div class="search"> <div class="search">
<el-form :inline="true" size="mini" class="base-search-form"> <el-form :inline="true" class="base-search-form">
<el-form-item :label="$t('dictionary:browser:search:title')"> <el-form-item :label="$t('dictionary:browser:search:title')">
<el-input v-model="searchData.Title" style="width: 100px" /> <el-input v-model="searchData.Title" style="width: 100px" />
</el-form-item> </el-form-item>
@ -23,7 +23,7 @@
</el-form-item> </el-form-item>
</el-form> </el-form>
<span style="margin-left: auto"> <span style="margin-left: auto">
<el-button type="primary" size="mini" @click="handleAdd"> <el-button type="primary" @click="handleAdd">
{{ $t("dictionary:browser:button:add") }} {{ $t("dictionary:browser:button:add") }}
</el-button> </el-button>
</span> </span>

View File

@ -33,7 +33,7 @@ export default {
let browserType = this.getExplore(); let browserType = this.getExplore();
let type = browserType.split(": ")[0]; let type = browserType.split(": ")[0];
let No = browserType.split(": ")[1].split(".")[0]; let No = browserType.split(": ")[1].split(".")[0];
console.log(type, No); // console.log(type, No);
if (type !== "Chrome" && type !== "Edge") { if (type !== "Chrome" && type !== "Edge") {
this.tip = this.$t("browser:tip:changeBorwser"); this.tip = this.$t("browser:tip:changeBorwser");
return (this.visible = true); return (this.visible = true);

View File

@ -3,18 +3,19 @@
ref="organForm" ref="organForm"
v-loading="loading" v-loading="loading"
:model="form" :model="form"
label-width="130px" label-width="170px"
size="small" size="small"
:rules="rules" :rules="rules"
> >
<div class="base-dialog-body"> <div class="base-dialog-body">
<el-form-item label="标准名称" prop="CriterionName"> <!-- 标准名称 -->
<el-form-item :label="$t('trials:auditRecord:table:criterion')" prop="CriterionName">
<el-input <el-input
v-model="form.CriterionName" v-model="form.CriterionName"
/> />
</el-form-item> </el-form-item>
<!-- 标准类型 -->
<el-form-item label="标准类型" prop="CriterionType"> <el-form-item :label="$t('dictionary:template:criterionConfig:table:criterionType')" prop="CriterionType">
<el-select v-model="form.CriterionType"> <el-select v-model="form.CriterionType">
<el-option <el-option
v-for="item of $d.CriterionType" v-for="item of $d.CriterionType"
@ -24,7 +25,8 @@
/> />
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item label="标准分组" prop="CriterionGroup"> <!-- 标准分组 -->
<el-form-item :label="$t('dictionary:template:criterionConfig:table:criterionGroup')" prop="CriterionGroup">
<el-select v-model="form.CriterionGroup"> <el-select v-model="form.CriterionGroup">
<el-option <el-option
v-for="item of $d.CriterionGroup" v-for="item of $d.CriterionGroup"
@ -34,23 +36,26 @@
/> />
</el-select> </el-select>
</el-form-item> </el-form-item>
<!-- 是否配置完成 -->
<el-form-item v-if="form.Id !== ''" label="是否配置完成"> <el-form-item v-if="form.Id !== ''" :label="$t('dictionary:template:criterionConfig:table:isCompleteConfig')">
<el-switch v-model="form.IsCompleteConfig" /> <el-switch v-model="form.IsCompleteConfig" />
</el-form-item> </el-form-item>
<el-form-item label="描述"> <!-- 描述 -->
<el-form-item :label="$t('dictionary:template:criterionConfig:table:description')">
<el-input <el-input
v-model="form.Description" v-model="form.Description"
/> />
</el-form-item> </el-form-item>
<!-- 显示序号 -->
<el-form-item label="显示序号: " prop="ShowOrder"> <el-form-item :label="$t('dictionary:template:criterionConfig:table:showOrder')" prop="ShowOrder">
<el-input-number v-model="form.ShowOrder" :min="0" style="width:100%;" /> <el-input-number v-model="form.ShowOrder" :min="0" style="width:100%;" />
</el-form-item> </el-form-item>
<el-form-item v-if="form.Id !== ''" label="是否启用"> <!-- 是否启用 -->
<el-form-item v-if="form.Id !== ''" :label="$t('dictionary:template:criterionConfig:table:isEnable')">
<el-switch v-model="form.IsEnable" /> <el-switch v-model="form.IsEnable" />
</el-form-item> </el-form-item>
<el-form-item v-if="form.Id !== ''" label="eICRF仅展示阅片Tab"> <!-- eICRF仅展示阅片Tab -->
<el-form-item v-if="form.Id !== ''" :label="$t('dictionary:template:criterionConfig:table:isECRFShowInDicomReading')">
<el-switch v-model="form.IseCRFShowInDicomReading" /> <el-switch v-model="form.IseCRFShowInDicomReading" />
</el-form-item> </el-form-item>
</div> </div>

View File

@ -8,32 +8,36 @@
label-width="160px" label-width="160px"
size="small" size="small"
> >
<el-form-item label="Group: " prop="Group"> <el-form-item :label="$t('template:anonymization:label:group')" prop="Group">
<el-input v-model="form.Group" /> <el-input v-model="form.Group" />
</el-form-item> </el-form-item>
<el-form-item label="Element: " prop="Group"> <el-form-item :label="$t('template:anonymization:label:element')" prop="Group">
<el-input v-model="form.Element" /> <el-input v-model="form.Element" />
</el-form-item> </el-form-item>
<el-form-item label="tag Description: " prop="Group"> <!-- tag Description -->
<el-form-item :label="$t('template:anonymization:label:tagDescription')" prop="Group">
<el-input v-model="form.TagDescription" /> <el-input v-model="form.TagDescription" />
</el-form-item> </el-form-item>
<el-form-item label="Tag DescriptionCN: " prop="Group"> <!-- Tag DescriptionCN -->
<el-form-item :label="$t('template:anonymization:label:tagDescriptionCN')" prop="Group">
<el-input v-model="form.TagDescriptionCN" /> <el-input v-model="form.TagDescriptionCN" />
</el-form-item> </el-form-item>
<el-form-item label="Value Representation: " prop="Group"> <!-- Value Representation -->
<el-form-item :label="$t('template:anonymization:label:valueRepresentation')" prop="Group">
<el-input v-model="form.ValueRepresentation" /> <el-input v-model="form.ValueRepresentation" />
</el-form-item> </el-form-item>
<el-form-item label="Is Fixed: "> <!-- Is Fixed -->
<el-form-item :label="$t('template:anonymization:label:isFixed')">
<el-switch <el-switch
v-model="form.IsFixed" v-model="form.IsFixed"
:active-value="true" :active-value="true"
:inactive-value="false" :inactive-value="false"
/> />
</el-form-item> </el-form-item>
<el-form-item label="Replace Value: "> <el-form-item :label="$t('template:anonymization:label:valueReplace')">
<el-input v-model="form.ReplaceValue" /> <el-input v-model="form.ReplaceValue" />
</el-form-item> </el-form-item>
<el-form-item label="Is Enable: "> <el-form-item :label="$t('template:anonymization:label:isEnable')">
<el-switch <el-switch
v-model="form.IsEnable" v-model="form.IsEnable"
:active-value="true" :active-value="true"
@ -43,8 +47,8 @@
</el-form> </el-form>
</template> </template>
<template slot="dialog-footer"> <template slot="dialog-footer">
<el-button :disabled="btnLoading" size="small" type="primary" @click="handleCancle">Cancel</el-button> <el-button :disabled="btnLoading" size="small" type="primary" @click="handleCancle">{{ $t('common:button:cancel') }}</el-button>
<el-button size="small" type="primary" :loading="btnLoading" @click="handleSave">Save</el-button> <el-button size="small" type="primary" :loading="btnLoading" @click="handleSave">{{ $t('common:button:save') }}</el-button>
</template> </template>
</base-model> </base-model>
</template> </template>
@ -82,7 +86,7 @@ export default {
IsAdd: false IsAdd: false
}, },
rules: { rules: {
Group: [{ required: true, message: 'Please specify', trigger: 'blur' }] Group: [{ required: true, message: this.$t('common:ruleMessage:specify'), trigger: 'blur' }]
}, },
model_cfg: { visible: false, showClose: true, width: '600px', title: '' } model_cfg: { visible: false, showClose: true, width: '600px', title: '' }
} }
@ -108,7 +112,7 @@ export default {
this.btnLoading = true this.btnLoading = true
addOrUpdateSystemAnonymization(this.form).then(res => { addOrUpdateSystemAnonymization(this.form).then(res => {
this.btnLoading = false this.btnLoading = false
this.$message.success('Saved successfully!') this.$message.success(this.$t('common:message:savedSuccessfully'))
this.model_cfg.visible = false this.model_cfg.visible = false
this.$emit('getList') this.$emit('getList')
}).catch(() => { }).catch(() => {

View File

@ -2,17 +2,21 @@
<box-content> <box-content>
<!-- 搜索框 --> <!-- 搜索框 -->
<div class="search"> <div class="search">
<el-form :inline="true" size="mini" class="base-search-form"> <el-form :inline="true" class="base-search-form">
<el-form-item label="Group:"> <!-- Group -->
<el-form-item :label="$t('template:anonymization:label:group')">
<el-input v-model="searchData.Group" clearable style="width:120px;" /> <el-input v-model="searchData.Group" clearable style="width:120px;" />
</el-form-item> </el-form-item>
<el-form-item label="Element:"> <!-- Element -->
<el-form-item :label="$t('template:anonymization:label:element')">
<el-input v-model="searchData.Element" clearable style="width:120px;" /> <el-input v-model="searchData.Element" clearable style="width:120px;" />
</el-form-item> </el-form-item>
<el-form-item label="Tag Description:"> <!-- Tag Description -->
<el-form-item :label="$t('template:anonymization:label:tagDescription')">
<el-input v-model="searchData.TagDescription" clearable style="width:120px;" /> <el-input v-model="searchData.TagDescription" clearable style="width:120px;" />
</el-form-item> </el-form-item>
<el-form-item label="Tag DescriptionCN:"> <!-- Tag DescriptionCN -->
<el-form-item :label="$t('template:anonymization:label:tagDescriptionCN')">
<el-input v-model="searchData.TagDescriptionCN" clearable style="width:120px;" /> <el-input v-model="searchData.TagDescriptionCN" clearable style="width:120px;" />
</el-form-item> </el-form-item>
<el-form-item> <el-form-item>
@ -29,7 +33,7 @@
</el-form-item> </el-form-item>
</el-form> </el-form>
<span style="margin-left:auto"> <span style="margin-left:auto">
<el-button type="primary" size="mini" @click="handleAdd">New</el-button> <el-button type="primary" @click="handleAdd">{{ $t('common:button:new') }}</el-button>
</span> </span>
</div> </div>
@ -38,37 +42,42 @@
v-adaptive="{bottomOffset:45}" v-adaptive="{bottomOffset:45}"
:data="list" :data="list"
stripe stripe
size="small"
height="100" height="100"
> >
<el-table-column type="index" width="60" /> <el-table-column type="index" width="60" />
<!-- Group -->
<el-table-column <el-table-column
prop="Group" prop="Group"
label="Group" :label="$t('template:anonymization:label:group')"
show-overflow-tooltip show-overflow-tooltip
/> />
<!-- Element -->
<el-table-column <el-table-column
prop="Element" prop="Element"
label="Element" :label="$t('template:anonymization:label:element')"
show-overflow-tooltip show-overflow-tooltip
min-width="110" min-width="110"
/> />
<!-- Tag Description -->
<el-table-column <el-table-column
prop="TagDescription" prop="TagDescription"
label="Tag Description" :label="$t('template:anonymization:label:tagDescription')"
min-width="110" min-width="110"
/> />
<!-- Tag DescriptionCN -->
<el-table-column <el-table-column
prop="TagDescriptionCN" prop="TagDescriptionCN"
label="Tag DescriptionCN" :label="$t('template:anonymization:label:tagDescriptionCN')"
min-width="110" min-width="110"
/> />
<!-- Value Representation -->
<el-table-column <el-table-column
prop="ValueRepresentation" prop="ValueRepresentation"
label="Value Representation" :label="$t('template:anonymization:label:valueRepresentation')"
min-width="110" min-width="110"
/> />
<el-table-column label="Is Fixed" width="100"> <!-- Is Fixed -->
<el-table-column :label="$t('template:anonymization:label:isFixed')" width="100">
<template slot-scope="scope"> <template slot-scope="scope">
<el-switch <el-switch
v-model="scope.row.IsFixed" v-model="scope.row.IsFixed"
@ -78,12 +87,14 @@
/> />
</template> </template>
</el-table-column> </el-table-column>
<!-- Value Replace -->
<el-table-column <el-table-column
prop="ReplaceValue" prop="ReplaceValue"
label="Value Replace" :label="$t('template:anonymization:label:valueReplace')"
min-width="110" min-width="110"
/> />
<el-table-column label="Is Enable" width="100" fixed="right"> <!-- Is Enable -->
<el-table-column :label="$t('template:anonymization:label:isEnable')" width="100" fixed="right">
<template slot-scope="scope"> <template slot-scope="scope">
<el-switch <el-switch
v-model="scope.row.IsEnable" v-model="scope.row.IsEnable"
@ -93,21 +104,19 @@
/> />
</template> </template>
</el-table-column> </el-table-column>
<el-table-column label="Action" width="200" fixed="right"> <el-table-column :label="$t('common:action:action')" width="200" fixed="right">
<template slot-scope="scope"> <template slot-scope="scope">
<el-button <el-button
type="primary" type="text"
size="mini"
@click="handleEdit(scope.row)" @click="handleEdit(scope.row)"
> >
Edit {{ $t('common:button:edit') }}
</el-button> </el-button>
<el-button <el-button
type="danger" type="text"
size="mini"
@click="handleDelete(scope.row)" @click="handleDelete(scope.row)"
> >
Delete {{ $t('common:button:delete') }}
</el-button> </el-button>
</template> </template>
</el-table-column> </el-table-column>
@ -153,7 +162,7 @@ export default {
switchChange(event, item) { switchChange(event, item) {
this.loading = true this.loading = true
addOrUpdateSystemAnonymization(item).then(res => { addOrUpdateSystemAnonymization(item).then(res => {
this.$message.success('Saved successfully!') this.$message.success(this.$t('common:message:savedSuccessfully'))
this.loading = false this.loading = false
}).catch(() => { }).catch(() => {
this.loading = false this.loading = false
@ -161,12 +170,12 @@ export default {
}, },
handleAdd() { handleAdd() {
this.$nextTick(() => { this.$nextTick(() => {
this.$refs['AddDICOMConfig'].openDialog('New Anonymization', {}) this.$refs['AddDICOMConfig'].openDialog(this.$t('common:button:new'), {})
}) })
}, },
handleEdit(row) { handleEdit(row) {
this.$nextTick(() => { this.$nextTick(() => {
this.$refs['AddDICOMConfig'].openDialog('Edit Anonymization', row) this.$refs['AddDICOMConfig'].openDialog(this.$t('common:action:edit'), row)
}) })
}, },
handleDelete(row) { handleDelete(row) {

View File

@ -2,11 +2,13 @@
<box-content> <box-content>
<!-- 搜索框 --> <!-- 搜索框 -->
<div class="search"> <div class="search">
<el-form :inline="true" size="mini" class="base-search-form"> <el-form :inline="true" class="base-search-form">
<el-form-item label="临床数据名称"> <!-- 临床数据名称 -->
<el-form-item :label="$t('trials:processCfg:title:clinicalDataCfg')">
<el-input v-model="searchData.ClinicalDataSetName" /> <el-input v-model="searchData.ClinicalDataSetName" />
</el-form-item> </el-form-item>
<el-form-item label="数据级别"> <!-- 数据级别 -->
<el-form-item :label="$t('trials:processCfg:title:dataLevel')">
<el-select v-model="searchData.ClinicalDataLevel" clearable style="width:120px;"> <el-select v-model="searchData.ClinicalDataLevel" clearable style="width:120px;">
<el-option <el-option
v-for="(item,index) of $d.ClinicalLevel" v-for="(item,index) of $d.ClinicalLevel"
@ -16,7 +18,8 @@
/> />
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item label="传输方式"> <!-- 传输方式 -->
<el-form-item :label="$t('trials:processCfg:title:transferType')">
<el-select v-model="searchData.ClinicalUploadType" clearable style="width:120px;"> <el-select v-model="searchData.ClinicalUploadType" clearable style="width:120px;">
<el-option <el-option
v-for="(item,index) of $d.ClinicalUploadType" v-for="(item,index) of $d.ClinicalUploadType"
@ -40,7 +43,8 @@
</el-form-item> </el-form-item>
</el-form> </el-form>
<span style="margin-left:auto"> <span style="margin-left:auto">
<el-button type="primary" size="mini" @click="handleAdd"></el-button> <!-- 新增 -->
<el-button type="primary" @click="handleAdd">{{ $t('common:button:new') }}</el-button>
</span> </span>
</div> </div>
@ -49,113 +53,152 @@
v-adaptive="{bottomOffset:45}" v-adaptive="{bottomOffset:45}"
:data="list" :data="list"
stripe stripe
size="small"
height="100" height="100"
> >
<el-table-column type="index" width="60" /> <el-table-column type="index" width="40" />
<!-- 临床数据名称 -->
<el-table-column <el-table-column
prop="ClinicalDataSetName" prop="ClinicalDataSetName"
label="临床数据名称" :label="$t('trials:processCfg:title:clinicalDataName')"
show-overflow-tooltip show-overflow-tooltip
min-width="160"
/> />
<!-- 临床数据名称EN -->
<el-table-column <el-table-column
prop="ClinicalDataSetEnName" prop="ClinicalDataSetEnName"
label="临床数据名称EN" :label="$t('dictionary:clinicalData:label:clinicalDataNameEn')"
show-overflow-tooltip show-overflow-tooltip
min-width="190"
/> />
<!-- 上传人 -->
<el-table-column <el-table-column
prop="UploadRole" prop="UploadRole"
:label="$t('trials:uploadMonitor:table:uploader')" :label="$t('trials:processCfg:title:uploader')"
show-overflow-tooltip show-overflow-tooltip
min-width="120"
> >
<template slot-scope="scope"> <template slot-scope="scope">
{{ $fd('ClinicalDataUploadRole',scope.row.UploadRole) }} {{ $fd('ClinicalDataUploadRole',scope.row.UploadRole) }}
</template> </template>
</el-table-column> </el-table-column>
<!-- 数据级别 -->
<el-table-column <el-table-column
prop="ClinicalDataLevel" prop="ClinicalDataLevel"
label="数据级别" :label="$t('trials:processCfg:title:dataLevel')"
show-overflow-tooltip show-overflow-tooltip
min-width="120"
> >
<template slot-scope="scope"> <template slot-scope="scope">
{{ $fd('ClinicalLevel',scope.row.ClinicalDataLevel) }} {{ $fd('ClinicalLevel',scope.row.ClinicalDataLevel) }}
</template> </template>
</el-table-column> </el-table-column>
<!-- 传输方式 -->
<el-table-column <el-table-column
prop="ClinicalUploadType" prop="ClinicalUploadType"
label="传输方式" :label="$t('trials:processCfg:title:transferType')"
show-overflow-tooltip show-overflow-tooltip
min-width="120"
> >
<template slot-scope="scope"> <template slot-scope="scope">
{{ $fd('ClinicalUploadType',scope.row.ClinicalUploadType) }} {{ $fd('ClinicalUploadType',scope.row.ClinicalUploadType) }}
</template> </template>
</el-table-column> </el-table-column>
<!-- 匹配的阅片标准 -->
<el-table-column <el-table-column
prop="CriterionEnumList" prop="CriterionEnumList"
:label="$t('trials:auditRecord:table:criterion')" :label="$t('trials:processCfg:label:criterion')"
show-overflow-tooltip show-overflow-tooltip
min-width="200"
> >
<template slot-scope="scope"> <template slot-scope="scope">
{{ scope.row.CriterionEnumList.map(v => $fd('CriterionType', v)).toString() }} {{ scope.row.CriterionEnumList.map(v => $fd('CriterionType', v)).toString() }}
</template> </template>
</el-table-column> </el-table-column>
<!-- 模板名称 -->
<el-table-column <el-table-column
prop="FileName" prop="FileName"
label="模板名称" :label="$t('trials:processCfg:title:module')"
show-overflow-tooltip show-overflow-tooltip
min-width="120"
> >
<template slot-scope="scope"> <template slot-scope="scope">
{{ scope.row.FileName }} {{ scope.row.FileName }}
</template> </template>
</el-table-column> </el-table-column>
<!-- 模板英文名称 -->
<el-table-column <el-table-column
prop="IsEnable" prop="EnFileName"
label="状态" :label="$t('trials:processCfg:title:enModule')"
show-overflow-tooltip show-overflow-tooltip
min-width="140"
> >
<template slot-scope="scope"> <template slot-scope="scope">
<el-tag v-if="scope.row.IsEnable"></el-tag> {{ scope.row.EnFileName }}
<el-tag v-else type="danger">禁用</el-tag>
</template> </template>
</el-table-column> </el-table-column>
<!-- 状态 -->
<el-table-column
prop="IsEnable"
:label="$t('dictionary:clinicalData:label:status')"
show-overflow-tooltip
min-width="120"
>
<template slot-scope="scope">
<!-- <el-tag v-if="scope.row.IsEnable"></el-tag>
<el-tag v-else type="danger">禁用</el-tag> -->
<el-tag v-if="!scope.row.IsEnable" type="danger">{{ $fd('IsEnable', scope.row.IsEnable) }}</el-tag>
<el-tag v-else>{{ $fd('IsEnable', scope.row.IsEnable) }}</el-tag>
</template>
</el-table-column>
<!-- 创建时间 -->
<el-table-column <el-table-column
prop="CreateTime" prop="CreateTime"
label="创建时间" :label="$t('dictionary:clinicalData:label:CreateTime')"
show-overflow-tooltip show-overflow-tooltip
min-width="140"
/> />
<el-table-column label="操作" width="340" fixed="right"> <el-table-column :label="$t('common:action:action')" min-width="250" fixed="right">
<template slot-scope="scope"> <template slot-scope="scope">
<!-- 问题配置 -->
<el-button <el-button
type="primary" type="text"
size="mini"
:disabled="scope.row.ClinicalUploadType !== 2" :disabled="scope.row.ClinicalUploadType !== 2"
@click="handleConfigQuestion(scope.row)" @click="handleConfigQuestion(scope.row)"
> >
问题配置 {{ $t('dictionary:clinicalData:button:qsConfig') }}
</el-button> </el-button>
<!-- 下载 -->
<el-button <el-button
type="primary" v-if="$i18n.locale === 'zh'"
size="mini" type="text"
:disabled="!scope.row.FileName" :disabled="!scope.row.FileName"
@click="handleDownloadTpl(scope.row)" @click="handleDownloadTpl(scope.row.Path)"
> >
下载 {{ $t('common:button:download') }}
</el-button> </el-button>
<!-- 下载 -->
<el-button
v-else
type="text"
:disabled="!scope.row.EnFileName"
@click="handleDownloadTpl(scope.row.EnPath)"
>
{{ $t('common:button:download') }}
</el-button>
<!-- 编辑 -->
<el-button <el-button
type="primary" type="text"
size="mini"
@click="handleEdit(scope.row)" @click="handleEdit(scope.row)"
> >
编辑 {{ $t('common:action:edit') }}
</el-button> </el-button>
<!-- 删除 -->
<el-button <el-button
type="danger" type="text"
size="mini"
@click="handleDelete(scope.row)" @click="handleDelete(scope.row)"
> >
删除 {{ $t('common:button:delete') }}
</el-button> </el-button>
</template> </template>
</el-table-column> </el-table-column>
@ -165,11 +208,11 @@
:visible.sync="addOrEditCD.visible" :visible.sync="addOrEditCD.visible"
:close-on-click-modal="false" :close-on-click-modal="false"
:title="addOrEditCD.title" :title="addOrEditCD.title"
width="500px" width="600px"
append-to-body append-to-body
custom-class="base-dialog-wrapper" custom-class="base-dialog-wrapper"
> >
<ClinicalDataForm ref="addOrEditCD" :data="currentRow" @close="addOrEditCD.visible = false" @getList="getList" /> <clinical-data-form ref="addOrEditCD" :data="currentRow" @close="addOrEditCD.visible = false" @getList="getList" />
</el-dialog> </el-dialog>
<el-dialog <el-dialog
v-if="QuestionConfigVisible.visible" v-if="QuestionConfigVisible.visible"
@ -180,7 +223,7 @@
append-to-body append-to-body
custom-class="base-dialog-wrapper" custom-class="base-dialog-wrapper"
> >
<ClinicalQuestionConfig ref="QuestionConfigVisible" :data="currentRow" @close="QuestionConfigVisible.visible = false" @getList="getList" /> <clinical-question-config ref="QuestionConfigVisible" :data="currentRow" @close="QuestionConfigVisible.visible = false" @getList="getList" />
</el-dialog> </el-dialog>
</box-content> </box-content>
</template> </template>
@ -218,7 +261,8 @@ export default {
handleConfigQuestion(row) { handleConfigQuestion(row) {
this.currentRow = { ...row } this.currentRow = { ...row }
this.QuestionConfigVisible.visible = true this.QuestionConfigVisible.visible = true
this.QuestionConfigVisible.title = '问题配置' //
this.QuestionConfigVisible.title = this.$t('dictionary:clinicalData:button:qsConfig')
}, },
// //
getList() { getList() {
@ -231,13 +275,13 @@ export default {
// //
handleAdd() { handleAdd() {
this.currentRow = {} this.currentRow = {}
this.addOrEditCD.title = '新增' this.addOrEditCD.title = this.$t('common:button:new')
this.addOrEditCD.visible = true this.addOrEditCD.visible = true
}, },
// //
handleEdit(row) { handleEdit(row) {
this.currentRow = { ...row } this.currentRow = { ...row }
this.addOrEditCD.title = '编辑' this.addOrEditCD.title = this.$t('common:action:edit')
this.addOrEditCD.visible = true this.addOrEditCD.visible = true
}, },
// //
@ -253,13 +297,13 @@ export default {
this.loading = false this.loading = false
if (res.IsSuccess) { if (res.IsSuccess) {
this.getList() this.getList()
this.$message.success('删除成功!') this.$message.success(this.$t('common:message:deletedSuccessfully'))
} }
}).catch(() => { this.loading = false }) }).catch(() => { this.loading = false })
}) })
}, },
handleDownloadTpl(row) { handleDownloadTpl(path) {
window.open(this.OSSclientConfig.basePath + row.Path, '_blank') window.open(this.OSSclientConfig.basePath + path, '_blank')
}, },
// //
handleSortByColumn(column) { handleSortByColumn(column) {

View File

@ -5,12 +5,13 @@
:model="form" :model="form"
size="small" size="small"
:rules="rules" :rules="rules"
label-width="110px" label-width="200px"
> >
<div class="base-dialog-body"> <div class="base-dialog-body">
<el-form-item label="临床数据名称" prop="ClinicalDataSetEnum"> <!-- 临床数据名称 -->
<el-form-item :label="$t('trials:processCfg:title:clinicalDataName')" prop="ClinicalDataSetEnum">
<!-- <el-input v-model="form.ClinicalDataSetName" /> --> <!-- <el-input v-model="form.ClinicalDataSetName" /> -->
<el-select v-model="form.ClinicalDataSetEnum" placeholder="请选择" style="width:100%;"> <el-select v-model="form.ClinicalDataSetEnum" style="width:100%;">
<el-option <el-option
v-for="(item,index) of $d.ClinicalDataType" v-for="(item,index) of $d.ClinicalDataType"
:key="index" :key="index"
@ -19,11 +20,10 @@
/> />
</el-select> </el-select>
</el-form-item> </el-form-item>
<!-- 上传人 -->
<el-form-item :label="$t('trials:studyList:table:uploader')" prop="UploadRole"> <el-form-item :label="$t('trials:processCfg:title:uploader')" prop="UploadRole">
<el-select <el-select
v-model="form.UploadRole" v-model="form.UploadRole"
placeholder="请选择"
style="width:100%;" style="width:100%;"
@change="handleUploadRoleChange" @change="handleUploadRoleChange"
> >
@ -35,11 +35,10 @@
/> />
</el-select> </el-select>
</el-form-item> </el-form-item>
<!-- 数据级别 -->
<el-form-item label="数据级别" prop="ClinicalDataLevel"> <el-form-item :label="$t('trials:processCfg:title:dataLevel')" prop="ClinicalDataLevel">
<el-select <el-select
v-model="form.ClinicalDataLevel" v-model="form.ClinicalDataLevel"
placeholder="请选择"
style="width:100%;" style="width:100%;"
> >
<el-option <el-option
@ -51,11 +50,10 @@
/> />
</el-select> </el-select>
</el-form-item> </el-form-item>
<!-- 传输方式 -->
<el-form-item label="传输方式" prop="ClinicalUploadType"> <el-form-item :label="$t('trials:processCfg:title:transferType')" prop="ClinicalUploadType">
<el-select <el-select
v-model="form.ClinicalUploadType" v-model="form.ClinicalUploadType"
placeholder="请选择"
style="width:100%;" style="width:100%;"
> >
<el-option <el-option
@ -67,13 +65,13 @@
/> />
</el-select> </el-select>
</el-form-item> </el-form-item>
<!-- 阅片标准 -->
<el-form-item <el-form-item
:label="$t('trials:auditRecord:table:criterion')" :label="$t('trials:processCfg:label:criterion')"
prop="CriterionEnumList" prop="CriterionEnumList"
> >
<el-select <el-select
v-model="form.CriterionEnumList" v-model="form.CriterionEnumList"
placeholder="请选择"
multiple multiple
style="width:100%;" style="width:100%;"
> >
@ -85,7 +83,8 @@
/> />
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item v-if="form.ClinicalUploadType === 1" label="模板: "> <!-- 模板 -->
<el-form-item v-if="form.ClinicalUploadType === 1" :label="$t('trials:processCfg:title:module')">
<div class="upload-container"> <div class="upload-container">
<el-upload <el-upload
class="upload-demo" class="upload-demo"
@ -101,19 +100,51 @@
:on-exceed="handleExceed" :on-exceed="handleExceed"
:disabled="form.Type === ''" :disabled="form.Type === ''"
> >
<el-button size="small" type="primary">选择</el-button> <el-button size="small" type="primary">
{{ $t('trials:processCfg:button:select') }}
</el-button>
<span <span
slot="tip" slot="tip"
style="margin-left:10px;" style="margin-left:10px;"
class="el-upload__tip" class="el-upload__tip"
> >
(必须是doc/docx格式) {{ $t('system:tip:file:docx') }}
</span> </span>
</el-upload> </el-upload>
</div> </div>
</el-form-item> </el-form-item>
<!-- 英文模板 -->
<el-form-item v-if="form.Id !== ''" label="是否启用"> <el-form-item v-if="form.ClinicalUploadType === 1" :label="$t('trials:processCfg:title:enModule')">
<div class="upload-container">
<el-upload
class="upload-demo"
action
accept=".doc,.docx"
:before-upload="beforeUploadEnFile"
:http-request="handleUploadEnFile"
:on-preview="handlePreview"
:on-remove="handleRemoveEnFile"
:show-file-list="true"
:file-list="enFileList"
:limit="1"
:on-exceed="handleExceed"
:disabled="form.Type === ''"
>
<el-button size="small" type="primary">
{{ $t('trials:processCfg:button:select') }}
</el-button>
<span
slot="tip"
style="margin-left:10px;"
class="el-upload__tip"
>
{{ $t('system:tip:file:docx') }}
</span>
</el-upload>
</div>
</el-form-item>
<!-- 是否启用 -->
<el-form-item v-if="form.Id !== ''" :label="$t('dictionary:clinicalData:label:IsEnable')">
<el-switch v-model="form.IsEnable" /> <el-switch v-model="form.IsEnable" />
</el-form-item> </el-form-item>
</div> </div>
@ -160,6 +191,8 @@ export default {
UploadRole: null, UploadRole: null,
FileName: '', FileName: '',
Path: '', Path: '',
EnFileName: '',
EnPath: '',
IsEnable: true, IsEnable: true,
CriterionEnumList: [] CriterionEnumList: []
}, },
@ -173,6 +206,7 @@ export default {
loading: false, loading: false,
btnLoading: false, btnLoading: false,
fileList: [], fileList: [],
enFileList: [],
systemCriterionSelectList: [] systemCriterionSelectList: []
} }
}, },
@ -195,6 +229,14 @@ export default {
} }
] ]
} }
if (this.data.EnPath) {
this.enFileList = [
{
name: this.data.EnFileName,
path: this.data.EnPath
}
]
}
} }
}, },
save() { save() {
@ -231,7 +273,7 @@ export default {
this.fileList = [] this.fileList = []
return true return true
} else { } else {
this.$alert('(必须是doc/docx格式)') this.$alert(this.$t('system:tip:file:docx'))
return false return false
} }
@ -247,7 +289,33 @@ export default {
} }
}, },
handleExceed(files, fileList) { handleExceed(files, fileList) {
this.$message.warning(`只允许上传一个文件`) this.$message.warning(this.$t('trials:processCfg:title:onlyOneFile'))
},
beforeUploadEnFile(file) {
//
if (this.checkFileSuffix(file.name)) {
this.enFileList = []
return true
} else {
this.$alert(this.$t('system:tip:file:docx'))
return false
}
},
async handleUploadEnFile(param) {
this.loading = true
var fileBlob = await this.fileToBlob(param.file)
const res = await this.OSSclient.put(`/System/ClinicalDataTemplate/${param.file.name}`, fileBlob)
this.form.EnFileName = res.name
this.form.EnPath = this.$getObjectName(res.url)
let file = { name: res.name, path: this.$getObjectName(res.url), url:this.$getObjectName(res.url) }
this.enFileList.push(file)
this.loading = false
},
handleRemoveEnFile() {
this.enFileList = []
this.form.EnPath = ''
this.form.EnFileName = ''
}, },
checkFileSuffix(fileName) { checkFileSuffix(fileName) {
var typeArr = ['doc', 'docx'] var typeArr = ['doc', 'docx']
@ -275,7 +343,7 @@ export default {
</script> </script>
<style lang="scss" scoped> <style lang="scss" scoped>
.upload-container{ .upload-container{
/deep/ .el-upload { ::v-deep .el-upload {
width: 100%; width: 100%;
text-align: left; text-align: left;
} }

View File

@ -2,39 +2,49 @@
<div class="criterion-config"> <div class="criterion-config">
<div class="search-form" style="display:flex;justify-content: space-between;"> <div class="search-form" style="display:flex;justify-content: space-between;">
<el-form :inline="true" size="mini" class="base-search-form"> <el-form :inline="true" size="mini" class="base-search-form">
<el-form-item label="名称"> <!-- 名称 -->
<el-form-item :label="$t('trials:readingUnit:qsList:title:qName')">
<el-input v-model="searchData.QuestionName" clearable style="width:120px;" /> <el-input v-model="searchData.QuestionName" clearable style="width:120px;" />
</el-form-item> </el-form-item>
<el-form-item> <el-form-item>
<el-button type="primary" @click="handleReset"></el-button> <el-button type="primary" icon="el-icon-search" @click="handleSearch">
<el-button type="primary" @click="handleSearch"></el-button> {{ $t('common:button:search') }}
</el-button>
<el-button
type="primary"
icon="el-icon-refresh-left"
@click="handleReset"
>
{{ $t('common:button:reset') }}
</el-button>
</el-form-item> </el-form-item>
</el-form> </el-form>
<div> <div>
<!-- 预览 -->
<el-button <el-button
:disabled="list.length === 0" :disabled="list.length === 0"
size="mini" size="mini"
type="primary" type="primary"
@click="preview.visible = true" @click="preview.visible = true"
> >
预览 {{ $t('common:button:preview') }}
</el-button> </el-button>
<!-- 添加 -->
<el-button <el-button
v-if="Object.keys(data).length > 0 && !data.IsBeUsed" v-if="Object.keys(data).length > 0 && !data.IsBeUsed"
size="mini" size="mini"
type="primary" type="primary"
@click="handleAdd" @click="handleAdd"
> >
添加 {{ $t('common:button:add') }}
</el-button> </el-button>
<!-- 应用 -->
<el-button <el-button
size="mini" size="mini"
type="primary" type="primary"
@click="handleApply" @click="handleApply"
> >
应用 {{ $t('dictionary:clinicalDataQs:button:apply') }}
</el-button> </el-button>
</div> </div>
</div> </div>
@ -52,81 +62,92 @@
label="" label=""
width="50" width="50"
/> />
<!-- 名称 -->
<el-table-column <el-table-column
prop="QuestionName" prop="QuestionName"
label="名称" :label="$t('trials:readingUnit:qsList:title:qName')"
show-overflow-tooltip show-overflow-tooltip
/> />
<!-- 名称(EN) -->
<el-table-column <el-table-column
prop="QuestionEnName" prop="QuestionEnName"
label="名称(EN)" :label="$t('trials:readingUnit:qsList:title:qNameEn')"
show-overflow-tooltip show-overflow-tooltip
/> />
<!-- 题型 -->
<el-table-column <el-table-column
prop="Type" prop="Type"
label="题型" :label="$t('trials:readingUnit:qsList:title:type')"
show-overflow-tooltip show-overflow-tooltip
> >
<template slot-scope="scope"> <template slot-scope="scope">
{{ $fd('ClinicalQuestionType',scope.row.ClinicalQuestionType) }} {{ $fd('ClinicalQuestionType',scope.row.ClinicalQuestionType) }}
</template> </template>
</el-table-column> </el-table-column>
<!-- 选项 -->
<el-table-column <el-table-column
prop="TypeValue" prop="TypeValue"
label="选项" :label="$t('trials:readingUnit:qsList:title:type')"
show-overflow-tooltip show-overflow-tooltip
> >
</el-table-column> </el-table-column>
<!-- 是否显示 -->
<el-table-column <el-table-column
prop="ClinicalQuestionShowEnum" prop="ClinicalQuestionShowEnum"
label="是否显示" :label="$t('trials:readingUnit:qsList:title:isShow')"
show-overflow-tooltip show-overflow-tooltip
> >
<template slot-scope="scope"> <template slot-scope="scope">
{{ $fd('ShowQuestion',scope.row.ClinicalQuestionShowEnum) }} {{ $fd('ShowQuestion',scope.row.ClinicalQuestionShowEnum) }}
</template> </template>
</el-table-column> </el-table-column>
<!-- 是否必填 -->
<el-table-column <el-table-column
prop="IsRequired" prop="IsRequired"
label="是否必填" :label="$t('trials:qcCfg:table:isRequired')"
show-overflow-tooltip show-overflow-tooltip
> >
<template slot-scope="scope"> <template slot-scope="scope">
{{ $fd('YesOrNo',scope.row.IsRequired) }} {{ $fd('YesOrNo',scope.row.IsRequired) }}
</template> </template>
</el-table-column> </el-table-column>
<!-- 操作 -->
<el-table-column <el-table-column
prop="" prop=""
label="操作" :label="$t('common:action:action')"
width="250" width="250"
show-overflow-tooltip show-overflow-tooltip
fixed="right" fixed="right"
> >
<template slot-scope="scope"> <template slot-scope="scope">
<!-- 编辑 -->
<el-button <el-button
v-if="Object.keys(data).length > 0 && !(data.IsCompleteConfig || data.IsBeUsed)" v-if="Object.keys(data).length > 0 && !(data.IsCompleteConfig || data.IsBeUsed)"
type="primary" type="primary"
size="mini" size="mini"
@click="handleEdit(scope.row)" @click="handleEdit(scope.row)"
> >
编辑 {{ $t('trials:readingUnit:qsList:title:edit') }}
</el-button> </el-button>
<!-- 查看 -->
<el-button <el-button
v-else v-else
type="primary" type="primary"
size="mini" size="mini"
@click="handleLook(scope.row)" @click="handleLook(scope.row)"
> >
查看 {{ $t('trials:enrolledReviews:button:view') }}
</el-button> </el-button>
<!-- 表格问题 -->
<el-button <el-button
type="primary" type="primary"
size="mini" size="mini"
:disabled="scope.row.ClinicalQuestionType !== 'table'" :disabled="scope.row.ClinicalQuestionType !== 'table'"
@click="handleConfig(scope.row)" @click="handleConfig(scope.row)"
> >
表格问题 {{ $t('trials:readingUnit:qsList:title:tableQs') }}
</el-button> </el-button>
<!-- 删除 -->
<el-button <el-button
v-if="Object.keys(data).length > 0 && !(data.IsCompleteConfig || data.IsBeUsed)" v-if="Object.keys(data).length > 0 && !(data.IsCompleteConfig || data.IsBeUsed)"
type="danger" type="danger"
@ -134,7 +155,7 @@
:disabled="scope.row.IsEnable" :disabled="scope.row.IsEnable"
@click="handleDelete(scope.row)" @click="handleDelete(scope.row)"
> >
删除 {{ $t('common:button:delete') }}
</el-button> </el-button>
</template> </template>
</el-table-column> </el-table-column>
@ -149,7 +170,7 @@
append-to-body append-to-body
custom-class="base-dialog-wrapper" custom-class="base-dialog-wrapper"
> >
<ClinicalQuestionForm <clinical-question-form
ref="addOrEdit" ref="addOrEdit"
:list="this.list" :list="this.list"
:clinical-id="clinicalId" :clinical-id="clinicalId"
@ -254,7 +275,8 @@ export default {
applySystemClinical({ applySystemClinical({
SystemClinicalId: this.clinicalId SystemClinicalId: this.clinicalId
}).then(res => { }).then(res => {
this.$message.success('应用成功') //
this.$message.success(this.$t('dictionary:clinicalDataQs:message:msg1'))
this.$emit('close') this.$emit('close')
}) })
}, },
@ -271,19 +293,19 @@ export default {
handleAdd() { handleAdd() {
this.rowData = { SystemClinicalId: this.data.Id, Id: '' } this.rowData = { SystemClinicalId: this.data.Id, Id: '' }
this.type = 'add' this.type = 'add'
this.addOrEdit.title = '添加' this.addOrEdit.title = this.$t('common:button:add')
this.addOrEdit.visible = true this.addOrEdit.visible = true
}, },
handleLook(row) { handleLook(row) {
this.rowData = { ...row } this.rowData = { ...row }
this.type = 'look' this.type = 'look'
this.addOrEdit.title = '查看' this.addOrEdit.title = this.$t('trials:enrolledReviews:button:view')
this.addOrEdit.visible = true this.addOrEdit.visible = true
}, },
handleEdit(row) { handleEdit(row) {
this.rowData = { ...row } this.rowData = { ...row }
this.type = 'edit' this.type = 'edit'
this.addOrEdit.title = '编辑' this.addOrEdit.title = this.$t('trials:readingUnit:qsList:title:edit')
this.addOrEdit.visible = true this.addOrEdit.visible = true
}, },
handleDelete(row) { handleDelete(row) {
@ -298,14 +320,14 @@ export default {
this.loading = false this.loading = false
if (res.IsSuccess) { if (res.IsSuccess) {
this.getList() this.getList()
this.$message.success('删除成功!') this.$message.success(this.$t('common:message:deletedSuccessfully'))
} }
}).catch(() => { this.loading = false }) }).catch(() => { this.loading = false })
}) })
}, },
handleConfig(row) { handleConfig(row) {
this.rowData = { ...row } this.rowData = { ...row }
this.config.title = `表格问题` this.config.title = this.$t('trials:readingUnit:qsList:title:tableQs')
this.config.visible = true this.config.visible = true
}, },
// //

View File

@ -6,10 +6,11 @@
size="small" size="small"
:rules="rules" :rules="rules"
:disabled="type === 'look'" :disabled="type === 'look'"
label-width="130px" label-width="180px"
> >
<div class="base-dialog-body"> <div class="base-dialog-body">
<el-form-item label="类型" prop="ClinicalQuestionType"> <!-- 类型 -->
<el-form-item :label="$t('trials:readingUnit:qsList:title:type')" prop="ClinicalQuestionType">
<el-select v-model="form.ClinicalQuestionType" clearable @change="((val)=>{typeChange(val, form)})"> <el-select v-model="form.ClinicalQuestionType" clearable @change="((val)=>{typeChange(val, form)})">
<el-option <el-option
v-for="item of $d.ClinicalQuestionType" v-for="item of $d.ClinicalQuestionType"
@ -19,31 +20,35 @@
/> />
</el-select> </el-select>
</el-form-item> </el-form-item>
<!-- 问题名称 -->
<el-form-item <el-form-item
label="问题名称" :label="$t('trials:readingUnit:qsList:title:qName')"
prop="QuestionName" prop="QuestionName"
> >
<el-input v-model="form.QuestionName" /> <el-input v-model="form.QuestionName" />
</el-form-item> </el-form-item>
<!-- 问题名称EN -->
<el-form-item <el-form-item
label="问题名称EN" :label="$t('dictionary:template:criterionConfig:title:qsNameEn')"
prop="QuestionEnName" prop="QuestionEnName"
> >
<el-input v-model="form.QuestionEnName" /> <el-input v-model="form.QuestionEnName" />
</el-form-item> </el-form-item>
<!-- 选项 -->
<el-form-item <el-form-item
v-if="form.ClinicalQuestionType === 'select' || form.ClinicalQuestionType === 'radio' || form.ClinicalQuestionType === 'checkbox'" v-if="form.ClinicalQuestionType === 'select' || form.ClinicalQuestionType === 'radio' || form.ClinicalQuestionType === 'checkbox'"
label="选项" :label="$t('trials:qcCfg:table:typeValue')"
prop="TypeValue" prop="TypeValue"
> >
<el-input <el-input
v-model="form.TypeValue" v-model="form.TypeValue"
placeholder="选项请用‘|’分割多个选项" :placeholder="$t('trials:qcCfg:message:typeValue')"
/> />
</el-form-item> </el-form-item>
<!-- 小数位数 -->
<el-form-item <el-form-item
v-if="form.ClinicalQuestionType === 'number'" v-if="form.ClinicalQuestionType === 'number'"
label="小数位数" :label="$t('trials:processCfg:form:digitPlaces')"
prop="DigitPlaces" prop="DigitPlaces"
> >
<el-radio-group <el-radio-group
@ -59,16 +64,17 @@
</el-radio> </el-radio>
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
<!-- 单位 -->
<el-form-item <el-form-item
v-if="form.ClinicalQuestionType === 'number'" v-if="form.ClinicalQuestionType === 'number'"
label="单位" :label="$t('trials:readingUnit:qsList:title:unit')"
prop="Unit" prop="Unit"
> >
<el-input <el-input
v-model="form.Unit" v-model="form.Unit"
/> />
</el-form-item> </el-form-item>
<el-form-item v-if="form.ClinicalQuestionType !== 'group'" label="是否显示" prop="ClinicalQuestionShowEnum"> <el-form-item v-if="form.ClinicalQuestionType !== 'group'" :label="$t('trials:readingUnit:qsList:title:isShow')" prop="ClinicalQuestionShowEnum">
<el-radio-group <el-radio-group
v-model="form.ClinicalQuestionShowEnum" v-model="form.ClinicalQuestionShowEnum"
@change="((val)=>{isShowQuestionChange(val, form)})" @change="((val)=>{isShowQuestionChange(val, form)})"
@ -82,9 +88,10 @@
</el-radio> </el-radio>
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
<!-- 显示依赖父问题 -->
<el-form-item <el-form-item
v-if="form.ClinicalQuestionType !== 'group' && form.ClinicalQuestionShowEnum===1" v-if="form.ClinicalQuestionType !== 'group' && form.ClinicalQuestionShowEnum===1"
label="显示依赖父问题" :label="$t('trials:readingUnit:qsList:title:parentId')"
prop="ParentId" prop="ParentId"
> >
<el-select <el-select
@ -101,7 +108,7 @@
</el-select> </el-select>
</el-form-item> </el-form-item>
<!-- 显示时依赖父问题触发值 --> <!-- 显示时依赖父问题触发值 -->
<el-form-item v-if="form.ParentId && form.ClinicalQuestionShowEnum===1" label="显示触发值" prop="ParentTriggerValue"> <el-form-item v-if="form.ParentId && form.ClinicalQuestionShowEnum===1" :label="$t('trials:qcCfg:table:parentTriggerValue')" prop="ParentTriggerValue">
<el-select v-model="form.ParentTriggerValue" clearable> <el-select v-model="form.ParentTriggerValue" clearable>
<el-option <el-option
v-for="item of parentTriggerValOptions" v-for="item of parentTriggerValOptions"
@ -111,7 +118,8 @@
/> />
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item v-if="form.ClinicalQuestionType !== 'group' && form.ClinicalQuestionType !== 'table'" label="是否必填" prop="IsRequired"> <!-- 是否必填 -->
<el-form-item v-if="form.ClinicalQuestionType !== 'group' && form.ClinicalQuestionType !== 'table'" :label="$t('trials:readingUnit:qsList:title:isRequired')" prop="IsRequired">
<el-radio-group <el-radio-group
v-model="form.IsRequired" v-model="form.IsRequired"
> >
@ -124,7 +132,8 @@
</el-radio> </el-radio>
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
<el-form-item v-if="form.ClinicalQuestionType !== 'group'" label="问题分组"> <!-- 问题分组 -->
<el-form-item v-if="form.ClinicalQuestionType !== 'group'" :label="$t('dictionary:template:criterionConfig:title:groupNameEn')">
<el-select v-model="form.GroupId" clearable :disabled="isParentExistGroup"> <el-select v-model="form.GroupId" clearable :disabled="isParentExistGroup">
<el-option <el-option
v-for="group of groupOptions" v-for="group of groupOptions"
@ -147,7 +156,8 @@
</el-radio> </el-radio>
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
<el-form-item v-if="form.ClinicalQuestionType !== 'table' && form.ClinicalQuestionType !== 'group' && form.ClinicalQuestionType !== 'number' && form.ClinicalQuestionType !== 'select'" label="最大长度"> <!-- 最大长度 -->
<el-form-item v-if="form.ClinicalQuestionType !== 'table' && form.ClinicalQuestionType !== 'group' && form.ClinicalQuestionType !== 'number' && form.ClinicalQuestionType !== 'select'" :label="$t('trials:readingUnit:qsList:title:MaxAnswerLength')">
<el-input-number <el-input-number
v-model="form.MaxAnswerLength" v-model="form.MaxAnswerLength"
controls-position="right" controls-position="right"
@ -155,7 +165,8 @@
:max="2000" :max="2000"
/> />
</el-form-item> </el-form-item>
<el-form-item v-if="form.ClinicalQuestionType === 'table'" label="最大行数"> <!-- 最大行数 -->
<el-form-item v-if="form.ClinicalQuestionType === 'table'" :label="$t('trials:readingUnit:qsList:title:maxQuestionCount')">
<el-input-number <el-input-number
v-model="form.MaxQuestionCount" v-model="form.MaxQuestionCount"
controls-position="right" controls-position="right"
@ -163,10 +174,12 @@
:max="10" :max="10"
/> />
</el-form-item> </el-form-item>
<el-form-item v-if="form.ClinicalQuestionType === 'upload'" label="最大上传个数"> <!-- 最大上传个数 -->
<el-form-item v-if="form.ClinicalQuestionType === 'upload'" :label="$t('trials:readingUnit:qsList:title:imageCount')">
<el-input-number v-model="form.ImageCount" controls-position="right" :min="1" :max="10" /> <el-input-number v-model="form.ImageCount" controls-position="right" :min="1" :max="10" />
</el-form-item> </el-form-item>
<el-form-item label="序号" prop="ShowOrder"> <!-- 序号 -->
<el-form-item :label="$t('trials:readingUnit:qsList:title:order')" prop="ShowOrder">
<el-input-number <el-input-number
v-model="form.ShowOrder" v-model="form.ShowOrder"
controls-position="right" controls-position="right"
@ -227,7 +240,7 @@ export default {
} else { } else {
var arr = value.split('|') var arr = value.split('|')
if (new Set(arr).size !== arr.length) { if (new Set(arr).size !== arr.length) {
callback(new Error('选项不允许存在相同值')) callback(new Error(this.$t('trials:qcCfg:message:msg1')))
} else { } else {
callback() callback()
} }
@ -264,29 +277,29 @@ export default {
}, },
rules: { rules: {
Type: [ Type: [
{ required: true, message: '请选择', trigger: 'blur' } { required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }
], ],
LesionType: [ LesionType: [
{ required: true, message: '请选择', trigger: 'blur' } { required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }
], ],
QuestionName: [{ required: true, message: '请注明', trigger: 'blur' }, QuestionName: [{ required: true, message: this.$t('common:ruleMessage:specify'), trigger: 'blur' },
{ max: 300, message: '最大长度为 300' }], { max: 300, message: this.$t('common:ruleMessage:maxLength') + ' 300' }],
QuestionGenre: [{ required: true, message: '请选择', trigger: 'blur' }], QuestionGenre: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }],
TypeValue: [{ required: true, message: '请注明', trigger: 'blur' }, TypeValue: [{ required: true, message: this.$t('common:ruleMessage:specify'), trigger: 'blur' },
{ validator: validateTypeVal, trigger: 'blur' }, { validator: validateTypeVal, trigger: 'blur' },
{ max: 500, message: '最大长度为 500' }], { max: 500, message: this.$t('common:ruleMessage:maxLength') + ' 500' }],
DictionaryCode: [{ required: true, message: '请选择', trigger: 'blur' }], DictionaryCode: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }],
IsCheckDate: [{ required: true, message: '请选择', trigger: 'blur' }], IsCheckDate: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }],
ClinicalQuestionShowEnum: [{ required: true, message: '请选择', trigger: 'blur' }], ClinicalQuestionShowEnum: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }],
IsRequired: [{ required: true, message: '请选择', trigger: 'blur' }], IsRequired: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }],
ParentId: [{ required: true, message: '请选择', trigger: 'blur' }], ParentId: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }],
ParentTriggerValue: [ ParentTriggerValue: [
{ required: true, message: '请选择', trigger: 'blur' } { required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }
], ],
RelevanceId: [{ required: true, message: '请选择', trigger: 'blur' }], RelevanceId: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }],
RelevanceValue: [{ required: true, message: '请选择', trigger: 'blur' }], RelevanceValue: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }],
GroupName: [{ required: true, message: '请注明', trigger: 'blur' }, GroupName: [{ required: true, message: this.$t('common:ruleMessage:specify'), trigger: 'blur' },
{ max: 50, message: '最大长度为 50' }] { max: 50, message: this.$t('common:ruleMessage:maxLength') + ' 50' }]
}, },
loading: false, loading: false,
btnLoading: false, btnLoading: false,

View File

@ -9,7 +9,8 @@
label-width="120px" label-width="120px"
> >
<div class="base-dialog-body"> <div class="base-dialog-body">
<el-form-item label="类型" prop="ClinicalTableQuestionType"> <!-- 类型 -->
<el-form-item :label="$t('trials:readingUnit:qsList:title:type')" prop="ClinicalTableQuestionType">
<el-select <el-select
v-model="form.ClinicalTableQuestionType" v-model="form.ClinicalTableQuestionType"
@change="((val)=>{qsTypeChange(val, form)})" @change="((val)=>{qsTypeChange(val, form)})"
@ -23,28 +24,31 @@
/> />
</el-select> </el-select>
</el-form-item> </el-form-item>
<!-- 问题名称 -->
<el-form-item <el-form-item
v-if="form.ClinicalTableQuestionType !== 'group'" v-if="form.ClinicalTableQuestionType !== 'group'"
label="问题名称" :label="$t('trials:readingUnit:qsList:title:qName')"
prop="QuestionName" prop="QuestionName"
> >
<el-input <el-input
v-model="form.QuestionName" v-model="form.QuestionName"
/> />
</el-form-item> </el-form-item>
<!-- 选项 -->
<el-form-item <el-form-item
label="选项" :label="$t('trials:readingUnit:qsList:title:typeValue')"
v-if="form.ClinicalTableQuestionType === 'select' || form.ClinicalTableQuestionType === 'radio'" v-if="form.ClinicalTableQuestionType === 'select' || form.ClinicalTableQuestionType === 'radio'"
prop="TypeValue" prop="TypeValue"
> >
<el-input <el-input
v-model="form.TypeValue" v-model="form.TypeValue"
placeholder="选项请用‘|’分割多个选项" :placeholder="$t('trials:readingUnit:qsList:message:msg3')"
/> />
</el-form-item> </el-form-item>
<!-- 小数位数 -->
<el-form-item <el-form-item
v-if="form.ClinicalTableQuestionType === 'number'" v-if="form.ClinicalTableQuestionType === 'number'"
label="小数位数" :label="$t('trials:readingUnit:qsList:title:digitPlaces')"
> >
<el-radio-group <el-radio-group
v-model="form.DigitPlaces" v-model="form.DigitPlaces"
@ -58,19 +62,18 @@
</el-radio> </el-radio>
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
<!-- 数值单位 --> <!-- 单位 -->
<el-form-item <el-form-item
v-if="form.ClinicalTableQuestionType === 'number'" v-if="form.ClinicalTableQuestionType === 'number'"
label="单位" :label="$t('trials:readingUnit:qsList:title:unit')"
> >
<el-input <el-input
v-model="form.Unit" v-model="form.Unit"
placeholder="请输入单位"
/> />
</el-form-item> </el-form-item>
<!-- 数值单位 --> <!-- 问题标记 -->
<el-form-item <el-form-item
label="问题标记" :label="$t('dictionary:clinicalDataQs:title:qsMark')"
> >
<el-select <el-select
v-model="form.clinicalTableQuestionMarkEnum" v-model="form.clinicalTableQuestionMarkEnum"
@ -84,16 +87,17 @@
/> />
</el-select> </el-select>
</el-form-item> </el-form-item>
<!-- 数值单位 --> <!-- 是否必填 -->
<el-form-item <el-form-item
label="是否必填" :label="$t('trials:readingUnit:qsList:title:isRequired')"
prop="IsRequired" prop="IsRequired"
> >
<el-radio-group v-model="form.IsRequired"> <el-radio-group v-model="form.IsRequired">
<el-radio v-for="item of $d.QuestionRequired" :label="item.value">{{ item.label }}</el-radio> <el-radio v-for="item of $d.QuestionRequired" :key="`IsRequired${item.value}`" :label="item.value">{{ item.label }}</el-radio>
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
<el-form-item label="序号" prop="ShowOrder"> <!-- 序号 -->
<el-form-item :label="$t('trials:qcCfg:table:order')" prop="ShowOrder">
<el-input-number <el-input-number
v-model="form.ShowOrder" v-model="form.ShowOrder"
controls-position="right" controls-position="right"
@ -156,7 +160,7 @@ export default {
} else { } else {
var arr = value.split('|') var arr = value.split('|')
if (new Set(arr).size !== arr.length) { if (new Set(arr).size !== arr.length) {
callback(new Error('选项不允许存在相同值')) callback(new Error(this.$t('trials:qcCfg:message:msg1')))
} else { } else {
callback() callback()
} }
@ -193,26 +197,26 @@ export default {
}, },
rules: { rules: {
Type: [ Type: [
{ required: true, message: '请选择', trigger: 'blur' } { required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }
], ],
QuestionName: [{ required: true, message: '请注明', trigger: 'blur' }, QuestionName: [{ required: true, message: this.$t('common:ruleMessage:specify'), trigger: 'blur' },
{ max: 300, message: '最大长度为 300' }], { max: 300, message: this.$t('common:ruleMessage:maxLength') + ' 300' }],
TypeValue: [{ required: true, message: '请注明', trigger: 'blur' }, TypeValue: [{ required: true, message: this.$t('common:ruleMessage:specify'), trigger: 'blur' },
{ validator: validateTypeVal, trigger: 'blur' }, { validator: validateTypeVal, trigger: 'blur' },
{ max: 200, message: '最大长度为 200' }], { max: 200, message: this.$t('common:ruleMessage:maxLength') + ' 200' }],
ShowQuestion: [{ required: true, message: '请选择', trigger: 'blur' }], ShowQuestion: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }],
IsRequired: [{ required: true, message: '请选择', trigger: 'blur' }], IsRequired: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }],
ParentId: [{ required: true, message: '请选择', trigger: 'blur' }], ParentId: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }],
ParentTriggerValue: [ ParentTriggerValue: [
{ required: true, message: '请选择', trigger: 'blur' } { required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }
], ],
RelevanceId: [{ required: true, message: '请选择', trigger: 'blur' }], RelevanceId: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }],
RelevanceValue: [{ required: true, message: '请选择', trigger: 'blur' }], RelevanceValue: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }],
DataTableName: [{ required: true, message: '请选择', trigger: 'blur' }], DataTableName: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }],
DataTableColumn: [{ required: true, message: '请选择', trigger: 'blur' }], DataTableColumn: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }],
// DictionaryCode: [{ required: true, message: '', trigger: 'blur' }], // DictionaryCode: [{ required: true, message: '', trigger: 'blur' }],
DependParentId: [{ required: true, message: '请选择', trigger: 'blur' }] DependParentId: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }]
}, },
loading: false, loading: false,
parentOptions: [], parentOptions: [],

View File

@ -10,7 +10,7 @@
type="primary" type="primary"
@click="handleAdd" @click="handleAdd"
> >
新增 {{ $t('common:button:new') }}
</el-button> </el-button>
</div> </div>
@ -20,39 +20,45 @@
size="small" size="small"
height="500" height="500"
> >
<!-- 序号 -->
<el-table-column <el-table-column
prop="ShowOrder" prop="ShowOrder"
label="序号" :label="$t('trials:qcCfg:table:order')"
min-width="70" min-width="70"
/> />
<!-- 名称 -->
<el-table-column <el-table-column
prop="QuestionName" prop="QuestionName"
label="名称" :label="$t('trials:readingUnit:qsList:title:qName')"
show-overflow-tooltip show-overflow-tooltip
/> />
<!-- 名称(EN) -->
<el-table-column <el-table-column
prop="QuestionEnName" prop="QuestionEnName"
label="名称(EN)" :label="$t('trials:readingUnit:qsList:title:qNameEn')"
show-overflow-tooltip show-overflow-tooltip
/> />
<!-- 类型 -->
<el-table-column <el-table-column
prop="Type" prop="Type"
label="类型" :label="$t('trials:readingUnit:qsList:title:type')"
show-overflow-tooltip show-overflow-tooltip
> >
<template slot-scope="scope"> <template slot-scope="scope">
{{ $fd('ClinicalTableQuestionType',scope.row.ClinicalTableQuestionType) }} {{ $fd('ClinicalTableQuestionType',scope.row.ClinicalTableQuestionType) }}
</template> </template>
</el-table-column> </el-table-column>
<!-- 选项 -->
<el-table-column <el-table-column
prop="TypeValue" prop="TypeValue"
label="选项" :label="$t('trials:readingUnit:qsList:title:typeValue')"
show-overflow-tooltip show-overflow-tooltip
min-width="110" min-width="110"
/> />
<!-- 是否必填 -->
<el-table-column <el-table-column
prop="IsRequired" prop="IsRequired"
label="是否必填" :label="$t('trials:qcCfg:table:isRequired')"
min-width="90" min-width="90"
show-overflow-tooltip show-overflow-tooltip
> >
@ -60,36 +66,40 @@
{{ $fd('YesOrNo',scope.row.IsRequired) }} {{ $fd('YesOrNo',scope.row.IsRequired) }}
</template> </template>
</el-table-column> </el-table-column>
<!-- 操作 -->
<el-table-column <el-table-column
prop="" prop=""
label="操作" :label="$t('common:action:action')"
width="150" width="150"
show-overflow-tooltip show-overflow-tooltip
> >
<template slot-scope="scope"> <template slot-scope="scope">
<!-- 查看 -->
<el-button <el-button
v-if="isCompleteConfig" v-if="isCompleteConfig"
type="primary" type="primary"
size="mini" size="mini"
@click="handleLook(scope.row)" @click="handleLook(scope.row)"
> >
查看 {{ $t('trials:readingUnit:qsList:title:view') }}
</el-button> </el-button>
<!-- 编辑 -->
<el-button <el-button
v-if="!isCompleteConfig" v-if="!isCompleteConfig"
type="primary" type="primary"
size="mini" size="mini"
@click="handleEdit(scope.row)" @click="handleEdit(scope.row)"
> >
编辑 {{ $t('common:button:edit') }}
</el-button> </el-button>
<!-- 删除 -->
<el-button <el-button
v-if="!isCompleteConfig" v-if="!isCompleteConfig"
type="danger" type="danger"
size="mini" size="mini"
@click="handleDelete(scope.row)" @click="handleDelete(scope.row)"
> >
删除 {{ $t('common:button:delete') }}
</el-button> </el-button>
</template> </template>
</el-table-column> </el-table-column>
@ -104,7 +114,7 @@
append-to-body append-to-body
custom-class="base-dialog-wrapper" custom-class="base-dialog-wrapper"
> >
<ClinicalQuestionTableForm <clinical-question-table-form
:clinical-id="clinicalId" :clinical-id="clinicalId"
:clinical-info="clinicalInfo" :clinical-info="clinicalInfo"
ref="addOrEdit" ref="addOrEdit"
@ -165,7 +175,7 @@ export default {
handleLook(row) { handleLook(row) {
this.type = 'look' this.type = 'look'
this.rowData = { ...row } this.rowData = { ...row }
this.addOrEdit.title = '编辑' this.addOrEdit.title = this.$t('common:button:edit')
this.addOrEdit.visible = true this.addOrEdit.visible = true
}, },
getList() { getList() {
@ -178,13 +188,13 @@ export default {
handleAdd() { handleAdd() {
this.type = 'add' this.type = 'add'
this.rowData = {} this.rowData = {}
this.addOrEdit.title = '添加' this.addOrEdit.title = this.$t('common:button:add')
this.addOrEdit.visible = true this.addOrEdit.visible = true
}, },
handleEdit(row) { handleEdit(row) {
this.type = 'edit' this.type = 'edit'
this.rowData = { ...row } this.rowData = { ...row }
this.addOrEdit.title = '编辑' this.addOrEdit.title = this.$t('common:button:edit')
this.addOrEdit.visible = true this.addOrEdit.visible = true
}, },
handleDelete(row) { handleDelete(row) {
@ -199,7 +209,7 @@ export default {
this.loading = false this.loading = false
if (res.IsSuccess) { if (res.IsSuccess) {
this.getList() this.getList()
this.$message.success('删除成功!') this.$message.success(this.$t('common:message:deletedSuccessfully'))
} }
}).catch(() => { this.loading = false }) }).catch(() => { this.loading = false })
}) })

View File

@ -4,6 +4,7 @@
<div> <div>
</div> </div>
<div> <div>
<!-- 配置 -->
<el-button <el-button
size="mini" size="mini"
type="primary" type="primary"
@ -11,7 +12,7 @@
@click="handleAdd" @click="handleAdd"
style="margin-right: 10px;" style="margin-right: 10px;"
> >
配置 {{ $t('dictionary:template:criterionDictionary:button:config') }}
</el-button> </el-button>
</div> </div>
</div> </div>
@ -21,55 +22,62 @@
:data="list" :data="list"
stripe stripe
> >
<!-- 序号 -->
<el-table-column <el-table-column
prop="" prop=""
label="序号" label=""
width="50" width="50"
> >
<template slot-scope="scope"> <template slot-scope="scope">
{{scope.$index + 1}} {{scope.$index + 1}}
</template> </template>
</el-table-column> </el-table-column>
<!-- 字典表名 -->
<el-table-column <el-table-column
prop="Code" prop="Code"
label="字典表名" :label="$t('dictionary:template:criterionDictionary:table:code')"
show-overflow-tooltip show-overflow-tooltip
> >
</el-table-column> </el-table-column>
<!-- 描述 -->
<el-table-column <el-table-column
prop="Description" prop="Description"
label="描述" :label="$t('dictionary:template:criterionDictionary:table:description')"
show-overflow-tooltip show-overflow-tooltip
> >
</el-table-column> </el-table-column>
<!-- 子项数量 -->
<el-table-column <el-table-column
prop="Count" prop="Count"
label="子项数量" :label="$t('dictionary:template:criterionDictionary:table:count')"
show-overflow-tooltip show-overflow-tooltip
> >
</el-table-column> </el-table-column>
<!-- 排序 -->
<el-table-column <el-table-column
prop="ShowOrder" prop="ShowOrder"
label="排序" :label="$t('dictionary:template:criterionDictionary:table:showOrder')"
show-overflow-tooltip show-overflow-tooltip
> >
</el-table-column> </el-table-column>
<!-- 操作 -->
<el-table-column <el-table-column
prop="Description" prop="Description"
label="操作" :label="$t('common:action:action')"
show-overflow-tooltip show-overflow-tooltip
> >
<template slot-scope="scope"> <template slot-scope="scope">
<el-button size="small" :disabled="isCompleteConfig" type="primary" @click="openChildren(scope.row)"> <!-- 配置 -->
配置 <el-button :disabled="isCompleteConfig" type="text" @click="openChildren(scope.row)">
{{ $t('dictionary:template:criterionDictionary:button:config') }}
</el-button> </el-button>
<!-- 删除 -->
<el-button <el-button
type="danger" type="text"
size="small"
:disabled="isCompleteConfig" :disabled="isCompleteConfig"
@click="handleDelete(scope.row)" @click="handleDelete(scope.row)"
> >
删除 {{ $t('common:button:delete') }}
</el-button> </el-button>
</template> </template>
</el-table-column> </el-table-column>
@ -99,7 +107,7 @@
@click="handleSave" @click="handleSave"
v-loading="loading" v-loading="loading"
> >
保存 {{ $t('common:button:save')}}
</el-button> </el-button>
</div> </div>
<el-table <el-table
@ -122,21 +130,24 @@
{{ scope.$index + 1}} {{ scope.$index + 1}}
</template> </template>
</el-table-column> </el-table-column>
<!-- 字典表名 -->
<el-table-column <el-table-column
prop="Code" prop="Code"
label="字典表名" :label="$t('dictionary:template:criterionDictionary:table:code')"
show-overflow-tooltip show-overflow-tooltip
> >
</el-table-column> </el-table-column>
<!-- 描述 -->
<el-table-column <el-table-column
prop="Description" prop="Description"
label="描述" :label="$t('dictionary:template:criterionDictionary:table:description')"
show-overflow-tooltip show-overflow-tooltip
> >
</el-table-column> </el-table-column>
<!-- 排序 -->
<el-table-column <el-table-column
prop="ShowOrder" prop="ShowOrder"
label="排序" :label="$t('dictionary:template:criterionDictionary:table:showOrder')"
show-overflow-tooltip show-overflow-tooltip
> >
</el-table-column> </el-table-column>
@ -170,7 +181,6 @@ export default {
rowData: {}, rowData: {},
activeName: '0', activeName: '0',
addOrEdit: { visible: false, title: '' }, addOrEdit: { visible: false, title: '' },
preview: { visible: false, title: 'eCRF预览' },
config: { visible: false, title: '全局配置' }, config: { visible: false, title: '全局配置' },
drawer_cfg: { drawerChild: false, parentId: '', title: '' }, drawer_cfg: { drawerChild: false, parentId: '', title: '' },
drawer_cfg2: { drawerChild: false, parentId: '', title: '' }, drawer_cfg2: { drawerChild: false, parentId: '', title: '' },
@ -216,7 +226,8 @@ export default {
}) })
}, },
handleAdd() { handleAdd() {
this.drawer_cfg2 = { drawerChild: true, title: '选择标准字典' } //
this.drawer_cfg2 = { drawerChild: true, title: this.$t('template:criterionDictionary:title:selectDictionary') }
this.config.visible = true this.config.visible = true
this.$nextTick(() => { this.$nextTick(() => {
var a = this.dicList.filter(v => { var a = this.dicList.filter(v => {
@ -251,9 +262,10 @@ export default {
}, },
handleDelete(row) { handleDelete(row) {
this.loading = true this.loading = true
this.$confirm('确定要删除该系统标准字典吗?').then(() => { //
this.$confirm(this.$t('template:criterionDictionary:message:msg1')).then(() => {
deleteSystemCriterionDictionary({Id: row.Id}).then(res => { deleteSystemCriterionDictionary({Id: row.Id}).then(res => {
this.$message.success('删除成功') this.$message.success(this.$t('common:message:deletedSuccessfully'))
this.loading = false this.loading = false
this.getList() this.getList()
}).catch(() => { this.loading = false }) }).catch(() => { this.loading = false })
@ -265,7 +277,7 @@ export default {
</script> </script>
<style lang="scss" scoped> <style lang="scss" scoped>
/deep/ .el-form-item__content{ ::v-deep .el-form-item__content{
width: calc(100% - 110px); width: calc(100% - 110px);
} }
</style> </style>

View File

@ -10,7 +10,7 @@
@click="handleAdd" @click="handleAdd"
style="margin-right: 10px;" style="margin-right: 10px;"
> >
配置 {{ $t('dictionary:template:criterionDictionary:button:config') }}
</el-button> </el-button>
</div> </div>
</div> </div>
@ -24,39 +24,44 @@
> >
<el-table-column <el-table-column
prop="" prop=""
label="序号" label=""
width="50" width="50"
> >
<template slot-scope="scope"> <template slot-scope="scope">
{{scope.$index + 1}} {{scope.$index + 1}}
</template> </template>
</el-table-column> </el-table-column>
<!-- 键值 -->
<el-table-column <el-table-column
prop="Code" prop="Code"
label="键值" :label="$t('dictionary:template:criterionDictionary:table:code')"
show-overflow-tooltip show-overflow-tooltip
/> />
<!-- 中文值 -->
<el-table-column <el-table-column
prop="ValueCN" prop="ValueCN"
label="中文值" :label="$t('dictionary:template:criterionDictionary:table:valueCN')"
show-overflow-tooltip show-overflow-tooltip
> >
</el-table-column> </el-table-column>
<!-- 英文值 -->
<el-table-column <el-table-column
prop="Value" prop="Value"
label="英文值" :label="$t('dictionary:template:criterionDictionary:table:value')"
show-overflow-tooltip show-overflow-tooltip
> >
</el-table-column> </el-table-column>
<!-- 描述 -->
<el-table-column <el-table-column
prop="Description" prop="Description"
label="描述" :label="$t('dictionary:template:criterionDictionary:table:description')"
show-overflow-tooltip show-overflow-tooltip
> >
</el-table-column> </el-table-column>
<!-- 分组 -->
<el-table-column <el-table-column
prop="Description" prop="Description"
label="分组" :label="$t('dictionary:template:criterionDictionary:table:group')"
show-overflow-tooltip show-overflow-tooltip
> >
<template slot-scope="scope"> <template slot-scope="scope">
@ -84,7 +89,7 @@
@click="handleSave" @click="handleSave"
v-loading="loading" v-loading="loading"
> >
保存 {{ $t('common:button:save')}}
</el-button> </el-button>
</div> </div>
<el-table <el-table
@ -100,27 +105,31 @@
type="selection" type="selection"
width="55"> width="55">
</el-table-column> </el-table-column>
<!-- 键值 -->
<el-table-column <el-table-column
prop="raw.Code" prop="raw.Code"
label="键值" :label="$t('dictionary:template:criterionDictionary:table:code')"
show-overflow-tooltip show-overflow-tooltip
> >
</el-table-column> </el-table-column>
<!-- 中文值 -->
<el-table-column <el-table-column
prop="raw.ValueCN" prop="raw.ValueCN"
label="中文值" :label="$t('dictionary:template:criterionDictionary:table:valueCN')"
show-overflow-tooltip show-overflow-tooltip
> >
</el-table-column> </el-table-column>
<!-- 英文值 -->
<el-table-column <el-table-column
prop="raw.Value" prop="raw.Value"
label="英文值" :label="$t('dictionary:template:criterionDictionary:table:value')"
show-overflow-tooltip show-overflow-tooltip
> >
</el-table-column> </el-table-column>
<!-- 描述 -->
<el-table-column <el-table-column
prop="raw.Description" prop="raw.Description"
label="描述" :label="$t('dictionary:template:criterionDictionary:table:description')"
show-overflow-tooltip show-overflow-tooltip
> >
</el-table-column> </el-table-column>
@ -152,7 +161,7 @@ export default {
activeName: '0', activeName: '0',
addOrEdit: { visible: false, title: '' }, addOrEdit: { visible: false, title: '' },
preview: { visible: false, title: 'eCRF预览' }, preview: { visible: false, title: 'eCRF预览' },
config: { visible: false, title: '标准字典值' }, config: { visible: false, title: this.$t('template:criterionDictionary:message:msg2') }, //
selectedList: [] selectedList: []
} }
}, },
@ -167,7 +176,7 @@ export default {
CrterionDictionaryGroup: v CrterionDictionaryGroup: v
}).then(res => { }).then(res => {
this.loading = false this.loading = false
this.$message.success('设置成功') this.$message.success(this.$t('common:message:savedSuccessfully'))
this.getList() this.getList()
}).catch(() => {this.loading = false}) }).catch(() => {this.loading = false})
}, },
@ -231,7 +240,7 @@ export default {
</script> </script>
<style lang="scss" scoped> <style lang="scss" scoped>
/deep/ .el-form-item__content{ ::v-deep .el-form-item__content{
width: calc(100% - 110px); width: calc(100% - 110px);
} }
</style> </style>

View File

@ -25,7 +25,7 @@
:prop="question.Id" :prop="question.Id"
:rules="[ :rules="[
{ required: (question.IsRequired === 0 || (question.IsRequired ===1 && question.RelevanceId && question.RelevanceValueList.includes(questionForm[question.RelevanceId]))) && question.Type!=='group' && question.Type!=='summary', { required: (question.IsRequired === 0 || (question.IsRequired ===1 && question.RelevanceId && question.RelevanceValueList.includes(questionForm[question.RelevanceId]))) && question.Type!=='group' && question.Type!=='summary',
message: '请注明', trigger: ['blur', 'change']}, message: this.$t('common:ruleMessage:specify'), trigger: ['blur', 'change']},
]" ]"
:class="[question.Type==='group'?'mb':question.Type==='upload'?'uploadWrapper':'']" :class="[question.Type==='group'?'mb':question.Type==='upload'?'uploadWrapper':'']"
> >
@ -396,7 +396,7 @@ export default {
flex-direction: row; flex-direction: row;
align-items: flex-start; align-items: flex-start;
} }
/deep/ .el-form-item__content{ ::v-deep .el-form-item__content{
width: 500px; width: 500px;
} }
.el-input{ .el-input{
@ -406,7 +406,7 @@ export default {
margin-bottom: 0px; margin-bottom: 0px;
} }
.disabled{ .disabled{
/deep/ .el-upload--picture-card { ::v-deep .el-upload--picture-card {
display: none; display: none;
} }
} }

View File

@ -6,12 +6,12 @@
size="small" size="small"
:rules="rules" :rules="rules"
:disabled="type === 'look'" :disabled="type === 'look'"
label-width="140px" label-width="220px"
> >
<div class="base-dialog-body" style="height: 550px; display:flex;flex-direction: column;"> <div class="base-dialog-body" style="height: 550px; display:flex;flex-direction: column;">
<div style="height: 150px;"> <div style="height: 150px;">
<!-- 类型 --> <!-- 类型 -->
<el-form-item label="类型" prop="Type"> <el-form-item :label="$t('trials:readingUnit:qsList:title:type')" prop="Type">
<el-select <el-select
v-model="form.Type" v-model="form.Type"
clearable clearable
@ -33,22 +33,23 @@
<!-- 分组名称 --> <!-- 分组名称 -->
<el-form-item <el-form-item
v-if="form.Type === 'group'" v-if="form.Type === 'group'"
label="分组名称" :label="$t('trials:readingUnit:qsList:title:groupName')"
prop="GroupName" prop="GroupName"
> >
<el-input v-model="form.GroupName" /> <el-input v-model="form.GroupName" />
</el-form-item> </el-form-item>
<!-- 分组名称EN -->
<el-form-item <el-form-item
v-if="form.Type === 'group'" v-if="form.Type === 'group'"
label="分组名称EN" :label="$t('dictionary:template:criterionConfig:title:groupNameEn')"
prop="GroupEnName" prop="GroupEnName"
> >
<el-input v-model="form.GroupEnName" /> <el-input v-model="form.GroupEnName" />
</el-form-item> </el-form-item>
<!-- 问题名称 -->
<el-form-item <el-form-item
v-if="form.Type !== 'group'" v-if="form.Type !== 'group'"
label="问题名称" :label="$t('trials:readingUnit:qsList:title:qsName')"
prop="QuestionName" prop="QuestionName"
:rules="[ :rules="[
{ required: true, message: this.$t('common:ruleMessage:specify'), trigger: 'blur' }, { required: true, message: this.$t('common:ruleMessage:specify'), trigger: 'blur' },
@ -57,10 +58,10 @@
> >
<el-input v-model="form.QuestionName" /> <el-input v-model="form.QuestionName" />
</el-form-item> </el-form-item>
<!-- 问题名称EN -->
<el-form-item <el-form-item
v-if="form.Type !== 'group'" v-if="form.Type !== 'group'"
label="问题名称EN" :label="$t('dictionary:template:criterionConfig:title:qsNameEn')"
prop="QuestionEnName" prop="QuestionEnName"
:rules="[ :rules="[
{ max: form.Type === 'summary' ? 300 : 100, message: `${this.$t('common:ruleMessage:maxLength')} ${form.Type === 'summary' ? 300 : 100}` } { max: form.Type === 'summary' ? 300 : 100, message: `${this.$t('common:ruleMessage:maxLength')} ${form.Type === 'summary' ? 300 : 100}` }
@ -70,10 +71,12 @@
</el-form-item> </el-form-item>
</div> </div>
<div style="flex: 1;overflow-y:auto;"> <div style="flex: 1;overflow-y:auto;">
<el-divider content-position="left">公有属性</el-divider> <!-- 公有属性 -->
<el-divider content-position="left">{{$t('trials:readingUnit:title:publicProperties')}}</el-divider>
<!-- 问题分组 -->
<el-form-item <el-form-item
v-if="form.Type !== 'group'" v-if="form.Type !== 'group'"
label="问题分组" :label="$t('trials:readingUnit:qsList:title:qsGroupName')"
:rules="[ :rules="[
{ required: form.ShowQuestion === 1 ? false : true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' } { required: form.ShowQuestion === 1 ? false : true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }
]" ]"
@ -91,9 +94,10 @@
/> />
</el-select> </el-select>
</el-form-item> </el-form-item>
<!-- 是否显示 -->
<el-form-item <el-form-item
v-if="form.Type !== 'group'" v-if="form.Type !== 'group'"
label="是否显示" :label="$t('trials:readingUnit:qsList:title:isShow')"
prop="ShowQuestion" prop="ShowQuestion"
> >
<el-radio-group <el-radio-group
@ -117,7 +121,7 @@
<!-- 显示时依赖父问题 --> <!-- 显示时依赖父问题 -->
<el-form-item <el-form-item
v-if="form.Type !== 'group' && form.ShowQuestion === 1" v-if="form.Type !== 'group' && form.ShowQuestion === 1"
label="显示依赖父问题" :label="$t('trials:readingUnit:qsList:title:parentId')"
prop="ParentId" prop="ParentId"
> >
<el-select <el-select
@ -140,7 +144,7 @@
<!-- 显示时依赖父问题触发值 --> <!-- 显示时依赖父问题触发值 -->
<el-form-item <el-form-item
v-if="form.ParentId && form.ShowQuestion === 1" v-if="form.ParentId && form.ShowQuestion === 1"
label="显示触发值" :label="$t('trials:readingUnit:qsList:title:parentTriggerValueList')"
prop="ParentTriggerValueList" prop="ParentTriggerValueList"
> >
<el-select v-model="form.ParentTriggerValueList" clearable multiple> <el-select v-model="form.ParentTriggerValueList" clearable multiple>
@ -152,10 +156,10 @@
/> />
</el-select> </el-select>
</el-form-item> </el-form-item>
<!-- 是否必填 -->
<el-form-item <el-form-item
v-if="form.Type !== 'group' && form.Type !== 'table' && form.Type !== 'basicTable' && form.Type !== 'summary'" v-if="form.Type !== 'group' && form.Type !== 'table' && form.Type !== 'basicTable' && form.Type !== 'summary'"
label="是否必填" :label="$t('trials:readingUnit:qsList:title:isRequired')" prop="IsRequired"
prop="IsRequired"
> >
<el-radio-group <el-radio-group
v-model="form.IsRequired" v-model="form.IsRequired"
@ -176,10 +180,10 @@
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
<!-- 父问题 --> <!-- 必填依赖父问题 -->
<el-form-item <el-form-item
v-if="form.Type !== 'group' && form.IsRequired === 1" v-if="form.Type !== 'group' && form.IsRequired === 1"
label="必填依赖父问题" :label="$t('trials:readingUnit:qsList:title:relevanceId')"
prop="RelevanceId" prop="RelevanceId"
> >
<el-select <el-select
@ -199,10 +203,10 @@
/> />
</el-select> </el-select>
</el-form-item> </el-form-item>
<!-- 必填依赖的父问题触发值 --> <!-- 必填触发值 -->
<el-form-item <el-form-item
v-if="form.RelevanceId && form.IsRequired === 1" v-if="form.RelevanceId && form.IsRequired === 1"
label="必填触发值" :label="$t('trials:readingUnit:qsList:title:relevanceValueList')"
prop="RelevanceValueList" prop="RelevanceValueList"
> >
<el-select v-model="form.RelevanceValueList" clearable multiple> <el-select v-model="form.RelevanceValueList" clearable multiple>
@ -214,6 +218,7 @@
/> />
</el-select> </el-select>
</el-form-item> </el-form-item>
<!-- 是否裁判问题 -->
<el-form-item <el-form-item
v-if=" v-if="
form.Type === 'select' || form.Type === 'select' ||
@ -221,7 +226,7 @@
form.Type === 'calculation' || form.Type === 'calculation' ||
form.Type === 'number' form.Type === 'number'
" "
label="是否裁判问题" :label="$t('trials:readingUnit:qsList:title:isJudgeQuestion')"
prop="IsJudgeQuestion" prop="IsJudgeQuestion"
:rules="[ :rules="[
{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' } { required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }
@ -263,8 +268,9 @@
</el-radio> </el-radio>
</el-radio-group> </el-radio-group>
</el-form-item> --> </el-form-item> -->
<!-- 导出结果 -->
<el-form-item <el-form-item
label="导出结果" :label="$t('trials:readingUnit:qsList:title:ExportResult')"
v-if="form.Type === 'radio' || form.Type === 'select' || form.Type === 'input' || form.Type === 'textarea' || form.Type === 'number' || form.Type === 'class' || form.Type === 'calculation'" v-if="form.Type === 'radio' || form.Type === 'select' || form.Type === 'input' || form.Type === 'textarea' || form.Type === 'number' || form.Type === 'class' || form.Type === 'calculation'"
> >
<el-select v-model="form.ExportResult" multiple> <el-select v-model="form.ExportResult" multiple>
@ -277,9 +283,9 @@
</el-option> </el-option>
</el-select> </el-select>
</el-form-item> </el-form-item>
<!-- 限制编辑 -->
<el-form-item <el-form-item
label="限制编辑" :label="$t('trials:readingUnit:qsList:title:limitEdit')"
v-if="form.Type === 'radio' || form.Type === 'select' || form.Type === 'input' || form.Type === 'textarea' || form.Type === 'upload' || form.Type === 'number' || form.Type === 'screenshot'" v-if="form.Type === 'radio' || form.Type === 'select' || form.Type === 'input' || form.Type === 'textarea' || form.Type === 'upload' || form.Type === 'number' || form.Type === 'screenshot'"
prop="LimitEdit" prop="LimitEdit"
:rules="[ :rules="[
@ -295,8 +301,9 @@
> >
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
<!-- 全局阅片是否显示 -->
<el-form-item <el-form-item
label="全局阅片是否显示" :label="$t('trials:readingUnit:qsList:title:globalReadingShowType')"
prop="GlobalReadingShowType" prop="GlobalReadingShowType"
:rules="[ :rules="[
{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' } { required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }
@ -311,8 +318,9 @@
> >
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
<!-- 问题标识 -->
<el-form-item <el-form-item
label="问题标识" :label="$t('dictionary:template:criterionConfig:table:questionType')"
v-if="form.Type !== 'group' && form.Type !== 'summary'" v-if="form.Type !== 'group' && form.Type !== 'summary'"
prop="QuestionType" prop="QuestionType"
> >
@ -325,8 +333,9 @@
/> />
</el-select> </el-select>
</el-form-item> </el-form-item>
<!-- 是否在阅片页面显示 -->
<el-form-item <el-form-item
label="是否在阅片页面显示" :label="$t('trials:readingUnit:qsList:title:isShowInDicom')"
prop="IsShowInDicom" prop="IsShowInDicom"
:rules="[ :rules="[
{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' } { required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }
@ -341,14 +350,16 @@
> >
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
<!-- 注释 -->
<el-form-item <el-form-item
label="注释" :label="$t('trials:readingUnit:qsList:title:Remark')"
prop="Remark" prop="Remark"
> >
<el-input v-model="form.Remark" /> <el-input v-model="form.Remark" />
</el-form-item> </el-form-item>
<!-- 序号 -->
<el-form-item <el-form-item
label="序号" :label="$t('trials:readingUnit:qsList:title:order')"
prop="ShowOrder" prop="ShowOrder"
:rules="[ :rules="[
{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' } { required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }
@ -361,7 +372,8 @@
/> />
</el-form-item> </el-form-item>
<!-- 适用于Lugano 2014标准 --> <!-- 适用于Lugano 2014标准 -->
<el-form-item label="问题分类" v-if="form.Type !== 'group' && criterionType === 2"> <!-- 问题分类 -->
<el-form-item :label="$t('dictionary:template:criterionConfig:table:questionClassify')" v-if="form.Type !== 'group' && criterionType === 2">
<el-select v-model="form.QuestionClassify" clearable> <el-select v-model="form.QuestionClassify" clearable>
<el-option <el-option
v-for="item of $d.QuestionClassify" v-for="item of $d.QuestionClassify"
@ -372,7 +384,8 @@
</el-select> </el-select>
</el-form-item> </el-form-item>
<!-- 适用于iRECST标准 --> <!-- 适用于iRECST标准 -->
<el-form-item label="转化显示类型" prop="ConvertShowType" v-if="criterionType === 3"> <!-- 转化显示类型 -->
<el-form-item :label="$t('dictionary:template:criterionConfig:table:convertType')" prop="ConvertShowType" v-if="criterionType === 3">
<el-radio-group v-model="form.ConvertShowType"> <el-radio-group v-model="form.ConvertShowType">
<el-radio <el-radio
v-for="item of $d.ConvertShowType" v-for="item of $d.ConvertShowType"
@ -383,16 +396,18 @@
</el-radio> </el-radio>
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
<el-divider content-position="left">私有属性</el-divider> <!-- 私有属性 -->
<el-divider content-position="left">{{$t('trials:readingUnit:title:privateProperties')}}</el-divider>
<!-- 选项类型 -->
<el-form-item <el-form-item
v-if=" v-if="
form.Type === 'select' || form.Type === 'select' ||
form.Type === 'radio' || form.Type === 'radio' ||
form.Type === 'calculation' form.Type === 'calculation'
" "
label="选项类型" :label="$t('trials:readingUnit:label:QuestionGenre')"
prop="QuestionGenre" prop="QuestionGenre"
:rules="[{ required: form.Type !== 'calculation', message: '请选择' }]" :rules="[{ required: form.Type !== 'calculation', message: this.$t('common:ruleMessage:select') }]"
> >
<el-radio-group <el-radio-group
v-model="form.QuestionGenre" v-model="form.QuestionGenre"
@ -402,7 +417,7 @@
} }
" "
> >
<el-radio :label="-1"> </el-radio> <el-radio :label="-1"> {{ this.$t('common:title:none') }} </el-radio>
<el-radio <el-radio
v-for="item of $d.TableQuestionType" v-for="item of $d.TableQuestionType"
v-show="item.value === 0 || item.value === 3" v-show="item.value === 0 || item.value === 3"
@ -413,23 +428,23 @@
</el-radio> </el-radio>
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
<!-- 选项 -->
<el-form-item <el-form-item
v-if="form.QuestionGenre === 0 || form.Type === 'class'" v-if="form.QuestionGenre === 0 || form.Type === 'class'"
label="选项" :label="$t('trials:qcCfg:table:typeValue')"
prop="TypeValue" prop="TypeValue"
> >
<el-input <el-input
v-model="form.TypeValue" v-model="form.TypeValue"
placeholder="选项请用‘|’分割多个选项" :placeholder="$t('trials:qcCfg:message:typeValue')"
@change="typeValueChange" @change="typeValueChange"
/> />
</el-form-item> </el-form-item>
<!-- 关联字典 -->
<el-form-item <el-form-item
v-if="form.QuestionGenre === 3" v-if="form.QuestionGenre === 3"
label="关联字典" :label="$t('trials:readingUnit:label:DictionaryCode')"
prop="DictionaryCode" prop="DictionaryCode"
> >
<el-select <el-select
@ -449,8 +464,8 @@
/> />
</el-select> </el-select>
</el-form-item> </el-form-item>
<!-- 默认值 -->
<el-form-item v-if="form.QuestionGenre === 3" label="默认值"> <el-form-item v-if="form.QuestionGenre === 3" :label="$t('trials:readingUnit:qsList:title:defaultValue')">
<el-select v-model="form.DefaultValue" clearable> <el-select v-model="form.DefaultValue" clearable>
<el-option <el-option
v-for="item of highlightAnswers" v-for="item of highlightAnswers"
@ -460,7 +475,8 @@
/> />
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item v-if="form.QuestionGenre === 0" label="默认值"> <!-- 默认值 -->
<el-form-item v-if="form.QuestionGenre === 0" :label="$t('trials:readingUnit:qsList:title:defaultValue')">
<el-select v-model="form.DefaultValue" clearable> <el-select v-model="form.DefaultValue" clearable>
<el-option <el-option
v-for="item of form.TypeValue ? form.TypeValue.split('|') : []" v-for="item of form.TypeValue ? form.TypeValue.split('|') : []"
@ -470,9 +486,10 @@
/> />
</el-select> </el-select>
</el-form-item> </el-form-item>
<!-- 高亮标记值 -->
<el-form-item <el-form-item
v-if="form.Type === 'select' || form.Type === 'radio'" v-if="form.Type === 'select' || form.Type === 'radio'"
label="高亮标记值" :label="$t('trials:readingUnit:qsList:title:highlightAnswers')"
prop="HighlightAnswerList" prop="HighlightAnswerList"
> >
<el-select v-model="form.HighlightAnswerList" clearable multiple> <el-select v-model="form.HighlightAnswerList" clearable multiple>
@ -494,8 +511,9 @@
</template> </template>
</el-select> </el-select>
</el-form-item> </el-form-item>
<!-- 分组标识 -->
<el-form-item <el-form-item
label="分组标识" :label="$t('dictionary:template:criterionConfig:table:groupClassify')"
v-if="form.Type === 'group'" v-if="form.Type === 'group'"
prop="GroupClassify" prop="GroupClassify"
> >
@ -508,9 +526,10 @@
/> />
</el-select> </el-select>
</el-form-item> </el-form-item>
<!-- 最大长度 -->
<el-form-item <el-form-item
v-if="form.Type === 'input' || form.Type === 'textarea'" v-if="form.Type === 'input' || form.Type === 'textarea'"
label="最大长度" :label="$t('trials:readingUnit:qsList:title:MaxAnswerLength')"
prop="MaxAnswerLength" prop="MaxAnswerLength"
:rules="[ :rules="[
{ required: true, message: this.$t('common:ruleMessage:specify'), trigger: 'blur' } { required: true, message: this.$t('common:ruleMessage:specify'), trigger: 'blur' }
@ -518,9 +537,10 @@
> >
<el-input-number v-model="form.MaxAnswerLength" :min="0"></el-input-number> <el-input-number v-model="form.MaxAnswerLength" :min="0"></el-input-number>
</el-form-item> </el-form-item>
<!-- 最大行数 -->
<el-form-item <el-form-item
v-if="form.Type === 'table' || form.Type === 'basicTable'" v-if="form.Type === 'table' || form.Type === 'basicTable'"
label="最大行数" :label="$t('trials:readingUnit:qsList:title:maxQuestionCount')"
prop="MaxQuestionCount" prop="MaxQuestionCount"
:rules="[ :rules="[
{ required: true, message: this.$t('common:ruleMessage:specify'), trigger: 'blur' } { required: true, message: this.$t('common:ruleMessage:specify'), trigger: 'blur' }
@ -533,16 +553,16 @@
:max="10" :max="10"
/> />
</el-form-item> </el-form-item>
<el-form-item v-if="form.Type === 'table' || form.Type === 'basicTable'" label="自增序号前缀"> <el-form-item v-if="form.Type === 'table' || form.Type === 'basicTable'" :label="$t('trials:readingUnit:qsList:title:orderMark')">
<el-input v-model="form.OrderMark" /> <el-input v-model="form.OrderMark" />
</el-form-item> </el-form-item>
<!-- 数值类型 --> <!-- 数值类型 -->
<el-form-item <el-form-item
v-if="form.Type === 'number' || form.Type === 'calculation'" v-if="form.Type === 'number' || form.Type === 'calculation'"
label="数值类型" :label="$t('trials:readingUnit:qsList:title:valueType')"
prop="ValueType" prop="ValueType"
:rules="[{ required: true, message: '请选择' }]" :rules="[{ required: true, message: this.$t('common:ruleMessage:select') }]"
> >
<el-radio-group v-model="form.ValueType"> <el-radio-group v-model="form.ValueType">
<el-radio <el-radio
@ -555,10 +575,10 @@
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
<!-- 数值单位 --> <!-- 单位 -->
<el-form-item <el-form-item
v-if="form.Type === 'number' || form.Type === 'calculation'" v-if="form.Type === 'number' || form.Type === 'calculation'"
label="单位" :label="$t('trials:readingUnit:qsList:title:unit')"
prop="Unit" prop="Unit"
:rules="[ :rules="[
{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' } { required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }
@ -574,9 +594,10 @@
</el-radio> </el-radio>
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
<!-- 表格类型标识 -->
<el-form-item <el-form-item
v-if="form.Type === 'table'" v-if="form.Type === 'table'"
label="表格类型标识" :label="$t('dictionary:template:criterionConfig:table:tableType')"
prop="LesionType" prop="LesionType"
> >
<el-select v-model="form.LesionType" clearable> <el-select v-model="form.LesionType" clearable>
@ -588,9 +609,10 @@
/> />
</el-select> </el-select>
</el-form-item> </el-form-item>
<!-- 表格类型标识 -->
<el-form-item <el-form-item
v-if="form.Type === 'basicTable'" v-if="form.Type === 'basicTable'"
label="表格类型标识" :label="$t('dictionary:template:criterionConfig:table:tableType')"
prop="LesionType" prop="LesionType"
> >
<el-select v-model="form.LesionType" clearable> <el-select v-model="form.LesionType" clearable>
@ -602,9 +624,10 @@
/> />
</el-select> </el-select>
</el-form-item> </el-form-item>
<!-- 关联字典 -->
<el-form-item <el-form-item
v-if="form.Type === 'table' || form.Type === 'basicTable'" v-if="form.Type === 'table' || form.Type === 'basicTable'"
label="关联字典" :label="$t('dictionary:template:criterionConfig:table:relatedDictionaryCode')"
> >
<el-select <el-select
v-model="form.DictionaryCode" v-model="form.DictionaryCode"
@ -623,9 +646,10 @@
/> />
</el-select> </el-select>
</el-form-item> </el-form-item>
<!-- 最大上传个数 -->
<el-form-item <el-form-item
v-if="form.Type === 'upload'" v-if="form.Type === 'upload'"
label="最大上传个数" :label="$t('trials:readingUnit:qsList:title:imageCount')"
> >
<el-input-number <el-input-number
v-model="form.ImageCount" v-model="form.ImageCount"
@ -637,7 +661,7 @@
<!-- 文件类型 --> <!-- 文件类型 -->
<el-form-item <el-form-item
v-if="form.Type === 'upload'" v-if="form.Type === 'upload'"
label="文件类型" :label="$t('trials:readingUnit:qsList:title:FileType')"
prop="FileType" prop="FileType"
:rules="[{ type: 'array', required: true, message: this.$t('common:ruleMessage:specify'), trigger: [ 'change'] }]" :rules="[{ type: 'array', required: true, message: this.$t('common:ruleMessage:specify'), trigger: [ 'change'] }]"
> >
@ -660,10 +684,10 @@
</el-checkbox> </el-checkbox>
</el-checkbox-group> </el-checkbox-group>
</el-form-item> </el-form-item>
<!-- 分类 --> <!-- 分类数据来源 -->
<el-form-item <el-form-item
v-if="form.Type === 'class'" v-if="form.Type === 'class'"
label="分类数据来源" :label="$t('dictionary:template:criterionConfig:table:classifyQuestion')"
prop="ClassifyQuestionId" prop="ClassifyQuestionId"
> >
<el-select v-model="form.ClassifyQuestionId" clearable> <el-select v-model="form.ClassifyQuestionId" clearable>
@ -671,9 +695,10 @@
:value="item.Id"/> :value="item.Id"/>
</el-select> </el-select>
</el-form-item> </el-form-item>
<!-- 分类算法 -->
<el-form-item <el-form-item
v-if="form.Type === 'class'" v-if="form.Type === 'class'"
label="分类算法" :label="$t('dictionary:template:criterionConfig:table:classifyAlgorithms')"
prop="ClassifyAlgorithms" prop="ClassifyAlgorithms"
> >
<div> <div>
@ -785,7 +810,7 @@ export default {
} else { } else {
var arr = value.split('|') var arr = value.split('|')
if (new Set(arr).size !== arr.length) { if (new Set(arr).size !== arr.length) {
callback(new Error('选项不允许存在相同值')) callback(new Error(this.$t('trials:readingUnit:qsList:message:msg0')))
} else { } else {
callback() callback()
} }
@ -840,34 +865,34 @@ export default {
ClassifyAlgorithms: null, ClassifyAlgorithms: null,
}, },
rules: { rules: {
Type: [{ required: true, message: '请选择', trigger: 'blur' }], Type: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }],
LesionType: [{ required: true, message: '请选择', trigger: 'blur' }], LesionType: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }],
// QuestionName: [ // QuestionName: [
// { required: true, message: '', trigger: 'blur' }, // { required: true, message: '', trigger: 'blur' },
// { max: 300, message: ' 300' }, // { max: 300, message: ' 300' },
// ], // ],
QuestionGenre: [{ required: true, message: '请选择', trigger: 'blur' }], QuestionGenre: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }],
TypeValue: [ TypeValue: [
{ required: true, message: '请注明', trigger: 'blur' }, { required: true, message: this.$t('common:ruleMessage:specify'), trigger: 'blur' },
{ validator: validateTypeVal, trigger: 'blur' }, { validator: validateTypeVal, trigger: 'blur' },
{ max: 500, message: '最大长度为 500' }, { max: 500, message: `${this.$t('common:ruleMessage:maxLength')} 500` },
], ],
DictionaryCode: [ DictionaryCode: [
{ required: true, message: '请选择', trigger: 'blur' }, { required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' },
], ],
ShowQuestion: [{ required: true, message: '请选择', trigger: 'blur' }], ShowQuestion: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }],
IsRequired: [{ required: true, message: '请选择', trigger: 'blur' }], IsRequired: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }],
ParentId: [{ required: true, message: '请选择', trigger: 'blur' }], ParentId: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }],
ParentTriggerValueList: [ ParentTriggerValueList: [
{ required: true, message: '请选择', trigger: 'blur' }, { required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' },
], ],
RelevanceId: [{ required: true, message: '请选择', trigger: 'blur' }], RelevanceId: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }],
RelevanceValueList: [ RelevanceValueList: [
{ required: true, message: '请选择', trigger: 'blur' }, { required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' },
], ],
GroupName: [ GroupName: [
{ required: true, message: '请注明', trigger: 'blur' }, { required: true, message: this.$t('common:ruleMessage:specify'), trigger: 'blur' },
{ max: 50, message: '最大长度为 50' }, { max: 50, message: `${this.$t('common:ruleMessage:maxLength')} 50` },
], ],
// ExportIdentification: [ // ExportIdentification: [
// { required: true, message: '', trigger: 'blur' }, // { required: true, message: '', trigger: 'blur' },

View File

@ -1,13 +1,15 @@
<template> <template>
<el-tabs v-model="activeName" @tab-click="handleClick"> <el-tabs v-model="activeName" @tab-click="handleClick">
<el-tab-pane label="器官" name="organs"> <!-- 器官 -->
<el-tab-pane :label="$t('dictionary:template:basicData:organs')" name="organs">
<OrgansTbl <OrgansTbl
:criterion-id="criterionId" :criterion-id="criterionId"
:is-complete-config="isCompleteConfig" :is-complete-config="isCompleteConfig"
/> />
</el-tab-pane> </el-tab-pane>
<el-tab-pane label="疗效评估" name="efficacyAssessment"> <!-- 疗效评估 -->
<el-tab-pane :label="$t('dictionary:template:basicData:efficacyAssessment')" name="efficacyAssessment">
<EfficacyAssessment <EfficacyAssessment
v-if="tabs.includes('efficacyAssessment')" v-if="tabs.includes('efficacyAssessment')"
:criterion-id="criterionId" :criterion-id="criterionId"
@ -15,7 +17,8 @@
:is-complete-config="isCompleteConfig" :is-complete-config="isCompleteConfig"
/> />
</el-tab-pane> </el-tab-pane>
<el-tab-pane label="标准字典" name="criterionDictionary"> <!-- 标准字典 -->
<el-tab-pane :label="$t('dictionary:template:basicData:criterionDictionary')" name="criterionDictionary">
<CriterionDictionary <CriterionDictionary
v-if="tabs.includes('criterionDictionary')" v-if="tabs.includes('criterionDictionary')"
:criterion-id="criterionId" :criterion-id="criterionId"

View File

@ -1,10 +1,12 @@
<template> <template>
<div class="criterion-config"> <div class="criterion-config">
<el-tabs v-model="activeName"> <el-tabs v-model="activeName">
<el-tab-pane :label="'访视阅片'" name="0"> <!-- 访视阅片 -->
<el-tab-pane :label="$t('dictionary:template:criterionConfig:tab:visitReview')" name="0">
<div class="search-form" style="display:flex;justify-content: space-between;"> <div class="search-form" style="display:flex;justify-content: space-between;">
<el-form :inline="true" size="mini" class="base-search-form"> <el-form :inline="true" size="mini" class="base-search-form">
<el-form-item label="名称"> <!-- 问题名称 -->
<el-form-item :label="$t('trials:readingUnit:qsList:title:qsName')">
<el-input v-model="searchData.QuestionName" clearable style="width:120px;" /> <el-input v-model="searchData.QuestionName" clearable style="width:120px;" />
</el-form-item> </el-form-item>
<el-form-item> <el-form-item>
@ -27,7 +29,7 @@
type="primary" type="primary"
@click="handlePreview" @click="handlePreview"
> >
预览 {{ $t('common:button:preview') }}
</el-button> </el-button>
<el-button <el-button
v-if="Object.keys(data).length > 0 && !(data.IsCompleteConfig || data.IsBeUsed)" v-if="Object.keys(data).length > 0 && !(data.IsCompleteConfig || data.IsBeUsed)"
@ -35,7 +37,7 @@
type="primary" type="primary"
@click="handleAdd" @click="handleAdd"
> >
添加 {{ $t('common:button:add') }}
</el-button> </el-button>
</div> </div>
@ -49,72 +51,89 @@
stripe stripe
@sort-change="handleSortByColumn" @sort-change="handleSortByColumn"
> >
<!-- 显示序号 -->
<el-table-column <el-table-column
prop="ShowOrder" prop="ShowOrder"
label="" label=""
width="50" width="50"
/> />
<!-- 分组 -->
<el-table-column <el-table-column
prop="GroupName" prop="GroupName"
label="分组" :label="$t('trials:readingUnit:qsList:title:groupName')"
show-overflow-tooltip show-overflow-tooltip
min-width="120"
/> />
<!-- 分组(EN) -->
<el-table-column <el-table-column
prop="GroupEnName" prop="GroupEnName"
label="分组(EN)" :label="$t('dictionary:template:criterionConfig:title:groupNameEn')"
show-overflow-tooltip show-overflow-tooltip
min-width="140"
/> />
<!-- 名称 -->
<el-table-column <el-table-column
prop="QuestionName" prop="QuestionName"
label="名称" :label="$t('trials:readingUnit:qsList:title:qsName')"
show-overflow-tooltip show-overflow-tooltip
min-width="140"
/> />
<!-- 名称(EN) -->
<el-table-column <el-table-column
prop="QuestionEnName" prop="QuestionEnName"
label="名称(EN)" :label="$t('dictionary:template:criterionConfig:title:qsNameEn')"
show-overflow-tooltip show-overflow-tooltip
min-width="160"
/> />
<!-- 题型 -->
<el-table-column <el-table-column
prop="Type" prop="Type"
label="题型" :label="$t('trials:readingUnit:qsList:title:type')"
show-overflow-tooltip show-overflow-tooltip
min-width="180"
> >
<template slot-scope="scope"> <template slot-scope="scope">
{{ $fd('Criterion_Question_Type',scope.row.Type) }} {{ $fd('Criterion_Question_Type',scope.row.Type) }}
</template> </template>
</el-table-column> </el-table-column>
<el-table-column <!-- 是否显示 -->
prop="IsRequired"
label="是否必填"
show-overflow-tooltip
>
<template slot-scope="scope">
{{ $fd('QuestionRequired',scope.row.IsRequired) }}
</template>
</el-table-column>
<el-table-column <el-table-column
prop="ShowQuestion" prop="ShowQuestion"
label="是否显示" :label="$t('trials:readingUnit:qsList:title:isShow')"
show-overflow-tooltip show-overflow-tooltip
min-width="100"
> >
<template slot-scope="scope"> <template slot-scope="scope">
{{ $fd('ShowQuestion',scope.row.ShowQuestion) }} {{ $fd('ShowQuestion',scope.row.ShowQuestion) }}
</template> </template>
</el-table-column> </el-table-column>
<!-- 是否必填 -->
<el-table-column
prop="IsRequired"
:label="$t('trials:readingUnit:qsList:title:isRequired')"
show-overflow-tooltip
min-width="100"
>
<template slot-scope="scope">
{{ $fd('QuestionRequired',scope.row.IsRequired) }}
</template>
</el-table-column>
<!-- 是否裁判问题 -->
<el-table-column <el-table-column
prop="IsJudgeQuestion" prop="IsJudgeQuestion"
label="是否裁判问题" :label="$t('trials:readingUnit:qsList:title:isJudgeQuestion')"
width="120" min-width="200"
show-overflow-tooltip show-overflow-tooltip
> >
<template slot-scope="scope"> <template slot-scope="scope">
{{ $fd('YesOrNo', scope.row.IsJudgeQuestion) }} {{ $fd('YesOrNo', scope.row.IsJudgeQuestion) }}
</template> </template>
</el-table-column> </el-table-column>
<!-- 是否在阅片页面显示 -->
<el-table-column <el-table-column
prop="IsShowInDicom" prop="IsShowInDicom"
label="是否在阅片页面显示" :label="$t('trials:readingUnit:qsList:title:isShowInDicom')"
width="150" min-width="200"
show-overflow-tooltip show-overflow-tooltip
> >
<template slot-scope="scope"> <template slot-scope="scope">
@ -129,10 +148,11 @@
show-overflow-tooltip show-overflow-tooltip
> >
</el-table-column> --> </el-table-column> -->
<!-- 是否在全局阅片显示 -->
<el-table-column <el-table-column
prop="GlobalReadingShowType" prop="GlobalReadingShowType"
label="是否在全局阅片显示" :label="$t('trials:readingUnit:qsList:title:globalReadingShowType')"
width="160" min-width="240"
show-overflow-tooltip show-overflow-tooltip
> >
<template slot-scope="scope"> <template slot-scope="scope">
@ -153,8 +173,8 @@
<!-- 问题标识 --> <!-- 问题标识 -->
<el-table-column <el-table-column
prop="QuestionType" prop="QuestionType"
label="问题标识" :label="$t('dictionary:template:criterionConfig:table:questionType')"
width="140" min-width="160"
show-overflow-tooltip show-overflow-tooltip
> >
<template slot-scope="scope"> <template slot-scope="scope">
@ -185,54 +205,52 @@
</el-table-column> </el-table-column>
<el-table-column <el-table-column
prop="" prop=""
label="操作" :label="$t('common:action:action')"
width="250" width="200"
show-overflow-tooltip show-overflow-tooltip
fixed="right" fixed="right"
> >
<template slot-scope="scope"> <template slot-scope="scope">
<el-button <el-button
v-if="Object.keys(data).length > 0 && !(data.IsCompleteConfig || data.IsBeUsed)" v-if="Object.keys(data).length > 0 && !(data.IsCompleteConfig || data.IsBeUsed)"
type="primary" type="text"
size="mini"
@click="handleEdit(scope.row)" @click="handleEdit(scope.row)"
> >
编辑 {{ $t('trials:readingUnit:qsList:title:edit') }}
</el-button> </el-button>
<el-button <el-button
v-else v-else
type="primary" type="text"
size="mini"
@click="handleLook(scope.row)" @click="handleLook(scope.row)"
> >
查看 {{ $t('trials:readingUnit:qsList:title:view') }}
</el-button> </el-button>
<el-button <el-button
type="primary" type="text"
size="mini"
:disabled="!(scope.row.Type === 'table' || scope.row.Type === 'basicTable')" :disabled="!(scope.row.Type === 'table' || scope.row.Type === 'basicTable')"
@click="handleConfig(scope.row)" @click="handleConfig(scope.row)"
> >
表格问题 {{ $t('trials:readingUnit:qsList:title:tableQs') }}
</el-button> </el-button>
<el-button <el-button
v-if="Object.keys(data).length > 0 && !(data.IsCompleteConfig || data.IsBeUsed)" v-if="Object.keys(data).length > 0 && !(data.IsCompleteConfig || data.IsBeUsed)"
type="danger" type="text"
size="mini"
:disabled="scope.row.IsEnable" :disabled="scope.row.IsEnable"
@click="handleDelete(scope.row)" @click="handleDelete(scope.row)"
> >
删除 {{ $t('trials:readingUnit:qsList:title:delete') }}
</el-button> </el-button>
</template> </template>
</el-table-column> </el-table-column>
</el-table> </el-table>
<pagination style="text-align: right;margin-top: 10px;" class="page" :total="total" :page.sync="searchData.PageIndex" :limit.sync="searchData.PageSize" @pagination="getList" /> <pagination style="text-align: right;margin-top: 10px;" class="page" :total="total" :page.sync="searchData.PageIndex" :limit.sync="searchData.PageSize" @pagination="getList" />
</el-tab-pane> </el-tab-pane>
<el-tab-pane label="全局阅片" name="Global"> <!-- 全局阅片 -->
<el-tab-pane :label="$t('dictionary:template:criterionConfig:tab:globalReview')" name="Global">
<EvaluationOfGlobalConfig v-if="activeName === 'Global'" :data="data" :criterion-id="criterionId" /> <EvaluationOfGlobalConfig v-if="activeName === 'Global'" :data="data" :criterion-id="criterionId" />
</el-tab-pane> </el-tab-pane>
<el-tab-pane label="肿瘤学阅片" name="Oncology"> <!-- 肿瘤学阅片 -->
<el-tab-pane :label="$t('dictionary:template:criterionConfig:tab:oncologyReview')" name="Oncology">
<EvaluationOfOncologyConfig v-if="activeName === 'Oncology'" :data="data" :criterion-id="criterionId" /> <EvaluationOfOncologyConfig v-if="activeName === 'Oncology'" :data="data" :criterion-id="criterionId" />
</el-tab-pane> </el-tab-pane>
</el-tabs> </el-tabs>
@ -241,11 +259,11 @@
:visible.sync="addOrEdit.visible" :visible.sync="addOrEdit.visible"
:close-on-click-modal="false" :close-on-click-modal="false"
:title="`${addOrEdit.title}`" :title="`${addOrEdit.title}`"
width="650px" width="800px"
append-to-body append-to-body
custom-class="base-dialog-wrapper" custom-class="base-dialog-wrapper"
> >
<CriterionQuestionForm <criterion-question-form
ref="addOrEdit" ref="addOrEdit"
:data="rowData" :data="rowData"
:type="type" :type="type"
@ -361,19 +379,19 @@ export default {
handleAdd() { handleAdd() {
this.rowData = { ReadingQuestionCriterionSystemId: this.criterionId, Id: ''} this.rowData = { ReadingQuestionCriterionSystemId: this.criterionId, Id: ''}
this.type = 'add' this.type = 'add'
this.addOrEdit.title = '添加' this.addOrEdit.title = this.$t('common:button:new')
this.addOrEdit.visible = true this.addOrEdit.visible = true
}, },
handleLook(row) { handleLook(row) {
this.rowData = { ...row } this.rowData = { ...row }
this.type = 'look' this.type = 'look'
this.addOrEdit.title = '查看' this.addOrEdit.title = this.$t('common:button:view')
this.addOrEdit.visible = true this.addOrEdit.visible = true
}, },
handleEdit(row) { handleEdit(row) {
this.rowData = { ...row } this.rowData = { ...row }
this.type = 'edit' this.type = 'edit'
this.addOrEdit.title = '编辑' this.addOrEdit.title = this.$t('common:button:edit')
this.addOrEdit.visible = true this.addOrEdit.visible = true
}, },
handleDelete(row) { handleDelete(row) {
@ -388,7 +406,7 @@ export default {
this.loading = false this.loading = false
if (res.IsSuccess) { if (res.IsSuccess) {
this.getList() this.getList()
this.$message.success('删除成功!') this.$message.success(this.$t('common:message:deletedSuccessfully'))
} }
}).catch(() => { this.loading = false }) }).catch(() => { this.loading = false })
}) })

View File

@ -2,14 +2,15 @@
<box-content> <box-content>
<!-- 搜索框 --> <!-- 搜索框 -->
<div class="search"> <div class="search">
<el-form :inline="true" size="mini" class="base-search-form"> <el-form :inline="true" class="base-search-form">
<el-form-item <el-form-item
:label="$t('trials:auditRecord:table:criterion')" :label="$t('trials:auditRecord:table:criterion')"
> >
<el-input v-model="searchData.CriterionName" clearable style="width:120px;" /> <el-input v-model="searchData.CriterionName" clearable style="width:120px;" />
</el-form-item> </el-form-item>
<!-- 标准类型 -->
<el-form-item <el-form-item
label="标准类型" :label="$t('dictionary:template:criterionConfig:table:criterionType')"
> >
<el-select v-model="searchData.CriterionType" clearable style="width:120px;"> <el-select v-model="searchData.CriterionType" clearable style="width:120px;">
<el-option <el-option
@ -20,8 +21,9 @@
/> />
</el-select> </el-select>
</el-form-item> </el-form-item>
<!-- 标准分组 -->
<el-form-item <el-form-item
label="标准分组" :label="$t('dictionary:template:criterionConfig:table:criterionGroup')"
> >
<el-select v-model="searchData.CriterionGroup" clearable style="width:120px;"> <el-select v-model="searchData.CriterionGroup" clearable style="width:120px;">
<el-option <el-option
@ -32,8 +34,9 @@
/> />
</el-select> </el-select>
</el-form-item> </el-form-item>
<!-- 是否配置完成 -->
<el-form-item <el-form-item
label="是否配置完成" :label="$t('dictionary:template:criterionConfig:table:isCompleteConfig')"
> >
<el-select v-model="searchData.IsCompleteConfig" clearable style="width:120px;"> <el-select v-model="searchData.IsCompleteConfig" clearable style="width:120px;">
<el-option <el-option
@ -44,8 +47,9 @@
/> />
</el-select> </el-select>
</el-form-item> </el-form-item>
<!-- 是否启用 -->
<el-form-item <el-form-item
label="是否启用" :label="$t('dictionary:template:criterionConfig:table:isEnable')"
> >
<el-select v-model="searchData.IsEnable" clearable style="width:120px;"> <el-select v-model="searchData.IsEnable" clearable style="width:120px;">
<el-option <el-option
@ -70,7 +74,8 @@
</el-form-item> </el-form-item>
</el-form> </el-form>
<span style="margin-left:auto"> <span style="margin-left:auto">
<el-button type="primary" size="mini" @click="handleAdd"></el-button> <!-- 添加 -->
<el-button type="primary" @click="handleAdd">{{$t('common:button:new')}}</el-button>
</span> </span>
</div> </div>
@ -79,44 +84,49 @@
v-adaptive="{bottomOffset:45}" v-adaptive="{bottomOffset:45}"
:data="list" :data="list"
stripe stripe
size="small"
height="100" height="100"
@sort-change="handleSortByColumn" @sort-change="handleSortByColumn"
ref="criterionsTbl" ref="criterionsTbl"
> >
<el-table-column type="index" width="60" /> <el-table-column type="index" width="60" />
<!-- 标准名称 -->
<el-table-column <el-table-column
prop="CriterionName" prop="CriterionName"
label="标准名称" :label="$t('trials:auditRecord:table:criterion')"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
width="180"
/> />
<!-- 标准类型 -->
<el-table-column <el-table-column
prop="CriterionType" prop="CriterionType"
label="标准类型" :label="$t('dictionary:template:criterionConfig:table:criterionType')"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
width="180"
> >
<template slot-scope="scope"> <template slot-scope="scope">
{{ $fd('CriterionType',scope.row.CriterionType) }} {{ $fd('CriterionType',scope.row.CriterionType) }}
</template> </template>
</el-table-column> </el-table-column>
<!-- 标准分组 -->
<el-table-column <el-table-column
prop="CriterionGroup" prop="CriterionGroup"
label="标准分组" :label="$t('dictionary:template:criterionConfig:table:criterionGroup')"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
width="160"
> >
<template slot-scope="scope"> <template slot-scope="scope">
{{ $fd('CriterionGroup',scope.row.CriterionGroup) }} {{ $fd('CriterionGroup',scope.row.CriterionGroup) }}
</template> </template>
</el-table-column> </el-table-column>
<!-- 是否配置完成 -->
<el-table-column <el-table-column
prop="IsCompleteConfig" prop="IsCompleteConfig"
label="是否配置完成" :label="$t('dictionary:template:criterionConfig:table:isCompleteConfig')"
sortable="custom" sortable="custom"
width="220"
> >
<template slot-scope="scope"> <template slot-scope="scope">
@ -128,29 +138,33 @@
{{ $fd('YesOrNo', scope.row.IsCompleteConfig) }} {{ $fd('YesOrNo', scope.row.IsCompleteConfig) }}
</template> </template>
</el-table-column> </el-table-column>
<!-- 描述 -->
<el-table-column <el-table-column
prop="Description" prop="Description"
label="描述" :label="$t('dictionary:template:criterionConfig:table:description')"
show-overflow-tooltip show-overflow-tooltip
/> />
<!-- 是否启用 -->
<el-table-column <el-table-column
prop="IsEnable" prop="IsEnable"
label="是否启用" :label="$t('dictionary:template:criterionConfig:table:isEnable')"
sortable="custom" sortable="custom"
> >
<template slot-scope="scope"> <template slot-scope="scope">
{{ $fd('YesOrNo', scope.row.IsEnable) }} {{ $fd('YesOrNo', scope.row.IsEnable) }}
</template> </template>
</el-table-column> </el-table-column>
<!-- 显示序号 -->
<el-table-column <el-table-column
prop="ShowOrder" prop="ShowOrder"
label="显示序号" :label="$t('dictionary:template:criterionConfig:table:showOrder')"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<!-- eICRF仅展示阅片Tab -->
<el-table-column <el-table-column
prop="IseCRFShowInDicomReading" prop="IseCRFShowInDicomReading"
label="eICRF仅展示阅片Tab" :label="$t('dictionary:template:criterionConfig:table:isECRFShowInDicomReading')"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
width="210" width="210"
@ -159,36 +173,36 @@
{{ $fd('YesOrNo', scope.row.IseCRFShowInDicomReading) }} {{ $fd('YesOrNo', scope.row.IseCRFShowInDicomReading) }}
</template> </template>
</el-table-column> </el-table-column>
<el-table-column label="Action" min-width="200px"> <el-table-column :label="$t('common:action:action')" min-width="220px">
<template slot-scope="scope"> <template slot-scope="scope">
<!-- 编辑 -->
<el-button <el-button
type="primary" type="text"
size="mini"
@click="handleEdit(scope.row)" @click="handleEdit(scope.row)"
> >
编辑 {{ $t('common:button:edit') }}
</el-button> </el-button>
<!-- eCRF -->
<el-button <el-button
type="primary" type="text"
size="mini"
@click="handleConfig(scope.row)" @click="handleConfig(scope.row)"
> >
eCRF {{ $t('dictionary:template:criterionConfig:button:eCRF') }}
</el-button> </el-button>
<!-- 基础数据 -->
<el-button <el-button
type="primary" type="text"
size="mini"
@click="handleBaseDataConfig(scope.row)" @click="handleBaseDataConfig(scope.row)"
> >
基础数据 {{ $t('dictionary:template:criterionConfig:button:basicData') }}
</el-button> </el-button>
<!-- 删除 -->
<el-button <el-button
type="danger" type="text"
size="mini"
:disabled="scope.row.IsCompleteConfig" :disabled="scope.row.IsCompleteConfig"
@click="handleDelete(scope.row)" @click="handleDelete(scope.row)"
> >
删除 {{ $t('common:button:delete') }}
</el-button> </el-button>
</template> </template>
@ -204,9 +218,9 @@
:close-on-click-modal="false" :close-on-click-modal="false"
append-to-body append-to-body
custom-class="base-dialog-wrapper" custom-class="base-dialog-wrapper"
width="500px" width="600px"
> >
<AddCriterion <add-criterion
:data="rowData" :data="rowData"
@close="addDialog.visible = false" @close="addDialog.visible = false"
@getList="getList" @getList="getList"
@ -227,7 +241,7 @@
<el-dialog <el-dialog
v-if="configBaseDataVisible" v-if="configBaseDataVisible"
:title="'基础数据配置' + `(${rowData.CriterionName})`" :title="`${this.$t('trials:readingUnit:readingCriterion:title:baseDataCfg')} (${rowData.CriterionName})`"
:visible.sync="configBaseDataVisible" :visible.sync="configBaseDataVisible"
:close-on-click-modal="false" :close-on-click-modal="false"
:fullscreen="true" :fullscreen="true"
@ -292,17 +306,17 @@ export default {
}).catch(() => { this.loading = false }) }).catch(() => { this.loading = false })
}, },
handleAdd() { handleAdd() {
this.addDialog.title = '添加' this.addDialog.title = this.$t('common:button:new')
this.addDialog.visible = true this.addDialog.visible = true
this.rowData = {} this.rowData = {}
}, },
handleEdit(row) { handleEdit(row) {
this.addDialog.title = '编辑' this.addDialog.title = this.$t('common:button:edit')
this.addDialog.visible = true this.addDialog.visible = true
this.rowData = { ...row } this.rowData = { ...row }
}, },
handleDelete(row) { handleDelete(row) {
this.$confirm('是否确认删除', { this.$confirm(this.$t('trials:readingUnit:baseDataCfg:message:deleteConfirm'), {
distinguishCancelAndClose: true, distinguishCancelAndClose: true,
type: 'warning' type: 'warning'
}).then(() => { }).then(() => {
@ -310,7 +324,7 @@ export default {
deleteReadingQuestionCriterionSystem(row.Id).then(res => { deleteReadingQuestionCriterionSystem(row.Id).then(res => {
this.loading = false this.loading = false
if (res.IsSuccess) { if (res.IsSuccess) {
this.$message.success(this.$t('common:message:savedSuccessfully')) this.$message.success(this.$t('common:message:deletedSuccessfully'))
this.getList() this.getList()
} }
}).catch(() => { this.loading = false }) }).catch(() => { this.loading = false })
@ -319,10 +333,10 @@ export default {
changeStatus(callback, row) { changeStatus(callback, row) {
var message = '' var message = ''
if (callback) { if (callback) {
message = '是否确认更改?' message = this.$t('trials:readingUnit:baseDataCfg:message:updateConfirm')
row.IsCompleteConfig = false row.IsCompleteConfig = false
} else { } else {
message = '是否确认更改?' message = this.$t('trials:readingUnit:baseDataCfg:message:updateConfirm')
row.IsCompleteConfig = true row.IsCompleteConfig = true
} }
this.$confirm(message, { this.$confirm(message, {

View File

@ -54,7 +54,7 @@
</el-button> </el-button>
</el-form-item> </el-form-item>
</el-form> </el-form>
<span style="margin-left:auto"> <!-- <span style="margin-left:auto">
<el-button <el-button
v-if="!isCompleteConfig" v-if="!isCompleteConfig"
type="primary" type="primary"
@ -63,7 +63,7 @@
> >
{{ $t('common:button:new') }} {{ $t('common:button:new') }}
</el-button> </el-button>
</span> </span> -->
</template> </template>
@ -84,6 +84,7 @@
<el-table-column <el-table-column
:prop="item.ColumnKey" :prop="item.ColumnKey"
v-for="item of headList" v-for="item of headList"
:key="item.ColumnName"
:label="item.ColumnName" :label="item.ColumnName"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"

View File

@ -1,10 +1,13 @@
<template> <template>
<div style="position: relative"> <div style="position: relative">
<el-form size="small" :inline="true" label-width="130px" style="position: relative;"> <el-form size="small" :inline="true" style="position: relative;">
<el-divider content-position="left">阅片规则</el-divider> <!-- 阅片规则 -->
<el-form-item label="是否必须全局阅片"> <el-divider content-position="left">{{ $t('dictionary:template:globalConfig:readingRules') }}</el-divider>
<!-- 是否必须全局阅片 -->
<el-form-item :label="$t('dictionary:template:globalConfig:isMustGlobalReading')">
{{ $fd('YesOrNo', IsMustGlobalReading) }} {{ $fd('YesOrNo', IsMustGlobalReading) }}
</el-form-item> </el-form-item>
<!-- 配置 -->
<el-button <el-button
size="mini" size="mini"
type="primary" type="primary"
@ -12,11 +15,13 @@
v-if="Object.keys(data).length > 0 && !(data.IsCompleteConfig || data.IsBeUsed)" v-if="Object.keys(data).length > 0 && !(data.IsCompleteConfig || data.IsBeUsed)"
@click="handleAdd(1)" @click="handleAdd(1)"
> >
配置 {{ $t('dictionary:template:globalConfig:config') }}
</el-button> </el-button>
</el-form> </el-form>
<el-form size="small" :inline="true" label-width="110px" style="position: relative"> <el-form size="small" :inline="true" style="position: relative">
<el-divider content-position="left">名称</el-divider> <!-- 名称 -->
<el-divider content-position="left">{{ $t('dictionary:template:globalConfig:name') }}</el-divider>
<!-- 配置 -->
<el-button <el-button
size="mini" size="mini"
type="primary" type="primary"
@ -24,9 +29,10 @@
v-if="Object.keys(data).length > 0 && !(data.IsCompleteConfig || data.IsBeUsed)" v-if="Object.keys(data).length > 0 && !(data.IsCompleteConfig || data.IsBeUsed)"
@click="handleAdd(2)" @click="handleAdd(2)"
> >
配置 {{ $t('dictionary:template:globalConfig:config') }}
</el-button> </el-button>
<el-form-item label="评估更新类型" style="width: 100%"> <!-- 评估更新类型 -->
<el-form-item :label="$t('dictionary:template:globalConfig:updateType')" style="width: 100%">
</el-form-item> </el-form-item>
<el-table <el-table
v-loading="loading" v-loading="loading"
@ -34,30 +40,34 @@
:data="list" :data="list"
stripe stripe
> >
<!-- 序号 -->
<el-table-column <el-table-column
prop="" prop=""
label="序号" :label="$t('dictionary:template:globalConfig:order')"
width="50" width="80"
> >
<template slot-scope="scope"> <template slot-scope="scope">
{{scope.$index + 1}} {{scope.$index + 1}}
</template> </template>
</el-table-column> </el-table-column>
<!-- 中文值 -->
<el-table-column <el-table-column
prop="ValueCN" prop="ValueCN"
label="中文值" :label="$t('dictionary:template:globalConfig:valueCN')"
show-overflow-tooltip show-overflow-tooltip
> >
</el-table-column> </el-table-column>
<!-- 英文值 -->
<el-table-column <el-table-column
prop="Value" prop="Value"
label="英文值" :label="$t('dictionary:template:globalConfig:value')"
show-overflow-tooltip show-overflow-tooltip
> >
</el-table-column> </el-table-column>
<!-- 是否基线评估 -->
<el-table-column <el-table-column
prop="IsBaseLineUse" prop="IsBaseLineUse"
label="是否基线评估" :label="$t('dictionary:template:globalConfig:isBaseLineUse')"
show-overflow-tooltip show-overflow-tooltip
> >
<template slot-scope="scope"> <template slot-scope="scope">
@ -70,9 +80,10 @@
<el-tag v-else type="danger">{{ $fd('YesOrNo', scope.row.IsBaseLineUse) }}</el-tag> <el-tag v-else type="danger">{{ $fd('YesOrNo', scope.row.IsBaseLineUse) }}</el-tag>
</template> </template>
</el-table-column> </el-table-column>
<!-- 是否随访评估 -->
<el-table-column <el-table-column
prop="IsFollowVisitUse" prop="IsFollowVisitUse"
label="是否随访评估" :label="$t('dictionary:template:globalConfig:isFollowVisitUse')"
show-overflow-tooltip show-overflow-tooltip
> >
<template slot-scope="scope"> <template slot-scope="scope">
@ -93,12 +104,14 @@
> >
<template slot="dialog-body"> <template slot="dialog-body">
<el-form size="small" :inline="true" label-width="130px"> <el-form size="small" :inline="true" label-width="130px">
<el-form-item label="是否必须全局阅片" v-if="config.configType === 1"> <!-- 是否必须全局阅片 -->
<el-form-item :label="$t('dictionary:template:globalConfig:isMustGlobalReading')" v-if="config.configType === 1">
<el-radio-group v-model="form.IsMustGlobalReading"> <el-radio-group v-model="form.IsMustGlobalReading">
<el-radio v-for="item of $d.YesOrNo" :key="'form.IsMustGlobalReading' + item.value" :label="item.value">{{ item.label }}</el-radio> <el-radio v-for="item of $d.YesOrNo" :key="'form.IsMustGlobalReading' + item.value" :label="item.value">{{ item.label }}</el-radio>
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
<el-form-item v-if="config.configType === 2" label="评估更新类型" style="width: 100%"> <!-- 评估更新类型 -->
<el-form-item v-if="config.configType === 2" :label="$t('dictionary:template:globalConfig:updateType')" style="width: 100%">
</el-form-item> </el-form-item>
<el-table <el-table
v-if="config.configType === 2" v-if="config.configType === 2"
@ -112,21 +125,24 @@
type="selection" type="selection"
width="55"> width="55">
</el-table-column> </el-table-column>
<!-- 中文值 -->
<el-table-column <el-table-column
prop="ValueCN" prop="ValueCN"
label="中文值" :label="$t('dictionary:template:globalConfig:valueCN')"
show-overflow-tooltip show-overflow-tooltip
> >
</el-table-column> </el-table-column>
<!-- 英文值 -->
<el-table-column <el-table-column
prop="Value" prop="Value"
label="英文值" :label="$t('dictionary:template:globalConfig:value')"
show-overflow-tooltip show-overflow-tooltip
> >
</el-table-column> </el-table-column>
<!-- 是否基线评估 -->
<el-table-column <el-table-column
prop="IsBaseLineUse" prop="IsBaseLineUse"
label="是否基线评估" :label="$t('dictionary:template:globalConfig:isBaseLineUse')"
show-overflow-tooltip show-overflow-tooltip
> >
<template slot-scope="scope"> <template slot-scope="scope">
@ -138,9 +154,10 @@
<span>{{$fd('YesOrNo', scope.row.IsBaseLineUse)}}</span> <span>{{$fd('YesOrNo', scope.row.IsBaseLineUse)}}</span>
</template> </template>
</el-table-column> </el-table-column>
<!-- 是否随访评估 -->
<el-table-column <el-table-column
prop="IsFollowVisitUse" prop="IsFollowVisitUse"
label="是否随访评估" :label="$t('dictionary:template:globalConfig:isFollowVisitUse')"
show-overflow-tooltip show-overflow-tooltip
> >
<template slot-scope="scope"> <template slot-scope="scope">
@ -156,8 +173,12 @@
</el-form> </el-form>
</template> </template>
<template slot="dialog-footer"> <template slot="dialog-footer">
<el-button :disabled="loading" size="small" type="primary" @click="config.visible = false">取消</el-button> <el-button :disabled="loading" size="small" type="primary" @click="config.visible = false">
<el-button size="small" type="primary" :loading="loading" @click="handleSave"></el-button> {{ $t('common:button:cancel') }}
</el-button>
<el-button size="small" type="primary" :loading="loading" @click="handleSave">
{{ $t('common:button:save') }}
</el-button>
</template> </template>
</base-model> </base-model>
</div> </div>
@ -186,8 +207,8 @@ export default {
rowData: {}, rowData: {},
activeName: '0', activeName: '0',
addOrEdit: { visible: false, title: '' }, addOrEdit: { visible: false, title: '' },
preview: { visible: false, title: 'eCRF预览' }, // preview: { visible: false, title: 'eCRF' },
config: { visible: false, title: '评估更新类型', appendToBody: true, width: '600px', configType: 0 }, config: { visible: false, title: this.$t('dictionary:template:globalConfig:updateType'), appendToBody: true, width: '600px', configType: 0 },
selectedList: [], selectedList: [],
IsMustGlobalReading: false, IsMustGlobalReading: false,
form: { form: {
@ -269,10 +290,10 @@ export default {
this.config.configType = n this.config.configType = n
this.form.IsMustGlobalReading = this.IsMustGlobalReading this.form.IsMustGlobalReading = this.IsMustGlobalReading
if (n === 1) { if (n === 1) {
this.config.title = '是否必须全局阅片' this.config.title = this.$t('dictionary:template:globalConfig:isMustGlobalReading')
this.config.visible = true this.config.visible = true
} else { } else {
this.config.title = '评估更新类型' this.config.title = this.$t('dictionary:template:globalConfig:updateType')
this.config.visible = true this.config.visible = true
this.$nextTick(() => { this.$nextTick(() => {
var a = this.$d.GlobalAssessType.filter(v => { var a = this.$d.GlobalAssessType.filter(v => {
@ -322,8 +343,4 @@ export default {
} }
</script> </script>
<style scoped>
/deep/ .el-form-item__content{
width: calc(100% - 130px);
}
</style>

View File

@ -1,10 +1,13 @@
<template> <template>
<div> <div>
<el-form size="small" :inline="true" label-width="110px" style="position: relative;"> <el-form size="small" :inline="true" style="position: relative;">
<el-divider content-position="left">阅片规则</el-divider> <!-- 阅片规则 -->
<el-form-item label="是否肿瘤学阅片" style="width: 100%"> <el-divider content-position="left">{{ $t('dictionary:template:globalConfig:readingRules') }}</el-divider>
<!-- 是否肿瘤学阅片 -->
<el-form-item :label="$t('dictionary:template:oncologyConfig:isOncologyReading')" style="width: 100%">
{{ $fd('YesOrNo', IsOncologyReading)}} {{ $fd('YesOrNo', IsOncologyReading)}}
</el-form-item> </el-form-item>
<!-- 配置 -->
<el-button <el-button
size="mini" size="mini"
type="primary" type="primary"
@ -12,11 +15,13 @@
v-if="Object.keys(data).length > 0 && !(data.IsCompleteConfig || data.IsBeUsed)" v-if="Object.keys(data).length > 0 && !(data.IsCompleteConfig || data.IsBeUsed)"
@click="handleAdd(1)" @click="handleAdd(1)"
> >
配置 {{ $t('dictionary:template:globalConfig:config') }}
</el-button> </el-button>
</el-form> </el-form>
<el-form size="small" :inline="true" label-width="110px" style="position: relative"> <el-form size="small" :inline="true" style="position: relative">
<el-divider content-position="left">阅片问题</el-divider> <!-- 阅片问题 -->
<el-divider content-position="left">{{ $t('dictionary:template:oncologyConfig:reviewQs') }}</el-divider>
<!-- 配置 -->
<el-button <el-button
size="mini" size="mini"
type="primary" type="primary"
@ -24,9 +29,10 @@
v-if="Object.keys(data).length > 0 && !(data.IsCompleteConfig || data.IsBeUsed)" v-if="Object.keys(data).length > 0 && !(data.IsCompleteConfig || data.IsBeUsed)"
@click="handleAdd(2)" @click="handleAdd(2)"
> >
配置 {{ $t('dictionary:template:globalConfig:config') }}
</el-button> </el-button>
<el-form-item label="肿瘤学阅片结果" style="width: 100%"> <!-- 肿瘤学阅片结果 -->
<el-form-item :label="$t('dictionary:template:oncologyConfig:reviewResult')" style="width: 100%">
</el-form-item> </el-form-item>
</el-form> </el-form>
<el-table <el-table
@ -35,24 +41,27 @@
:data="list" :data="list"
stripe stripe
> >
<!-- 序号 -->
<el-table-column <el-table-column
prop="" prop=""
label="序号" :label="$t('dictionary:template:globalConfig:order')"
width="50" width="80"
> >
<template slot-scope="scope"> <template slot-scope="scope">
{{scope.$index + 1}} {{scope.$index + 1}}
</template> </template>
</el-table-column> </el-table-column>
<!-- 中文值 -->
<el-table-column <el-table-column
prop="ValueCN" prop="ValueCN"
label="中文值" :label="$t('dictionary:template:globalConfig:valueCN')"
show-overflow-tooltip show-overflow-tooltip
> >
</el-table-column> </el-table-column>
<!-- 英文值 -->
<el-table-column <el-table-column
prop="Value" prop="Value"
label="英文值" :label="$t('dictionary:template:globalConfig:value')"
show-overflow-tooltip show-overflow-tooltip
> >
</el-table-column> </el-table-column>
@ -60,12 +69,14 @@
<base-model :config="config"> <base-model :config="config">
<template slot="dialog-body"> <template slot="dialog-body">
<el-form size="small" :inline="true" label-width="110px"> <el-form size="small" :inline="true" label-width="110px">
<el-form-item label="是否肿瘤学阅片" v-if="config.configType === 1"> <!-- 是否肿瘤学阅片 -->
<el-form-item :label="$t('dictionary:template:oncologyConfig:isOncologyReading')" v-if="config.configType === 1">
<el-radio-group v-model="form.IsOncologyReading"> <el-radio-group v-model="form.IsOncologyReading">
<el-radio v-for="item of $d.YesOrNo" :key="'form.IsOncologyReading' + item.value" :label="item.value">{{ item.label }}</el-radio> <el-radio v-for="item of $d.YesOrNo" :key="'form.IsOncologyReading' + item.value" :label="item.value">{{ item.label }}</el-radio>
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
<el-form-item label="肿瘤学阅片结果" style="width: 100%" v-if="config.configType === 2"> <!-- 肿瘤学阅片结果 -->
<el-form-item :label="$t('dictionary:template:oncologyConfig:reviewResult')" style="width: 100%" v-if="config.configType === 2">
</el-form-item> </el-form-item>
<el-table <el-table
v-if="config.configType === 2" v-if="config.configType === 2"
@ -80,15 +91,17 @@
type="selection" type="selection"
width="55"> width="55">
</el-table-column> </el-table-column>
<!-- 中文值 -->
<el-table-column <el-table-column
prop="ValueCN" prop="ValueCN"
label="中文值" :label="$t('dictionary:template:globalConfig:valueCN')"
show-overflow-tooltip show-overflow-tooltip
> >
</el-table-column> </el-table-column>
<!-- 英文值 -->
<el-table-column <el-table-column
prop="Value" prop="Value"
label="英文值" :label="$t('dictionary:template:globalConfig:value')"
show-overflow-tooltip show-overflow-tooltip
> >
</el-table-column> </el-table-column>
@ -96,8 +109,12 @@
</el-form> </el-form>
</template> </template>
<template slot="dialog-footer"> <template slot="dialog-footer">
<el-button :disabled="loading" size="small" type="primary" @click="config.visible = false">取消</el-button> <el-button :disabled="loading" size="small" type="primary" @click="config.visible = false">
<el-button size="small" type="primary" :loading="loading" @click="handleSave"></el-button> {{ $t('common:button:cancel') }}
</el-button>
<el-button size="small" type="primary" :loading="loading" @click="handleSave">
{{ $t('common:button:save') }}
</el-button>
</template> </template>
</base-model> </base-model>
</div> </div>
@ -109,7 +126,7 @@ import { getSystemOncologyInfo, setSystemOncologyInfo, getCriterionDictionary }
export default { export default {
props: { props: {
data: { data: {
type: String, type: Object,
default() { return {} } default() { return {} }
}, },
criterionId: { criterionId: {
@ -129,8 +146,7 @@ export default {
rowData: {}, rowData: {},
activeName: '0', activeName: '0',
addOrEdit: { visible: false, title: '' }, addOrEdit: { visible: false, title: '' },
preview: { visible: false, title: 'eCRF预览' }, config: { visible: false, title: this.$t('dictionary:template:oncologyConfig:reviewResult'), appendToBody: true, width: '600px', configType: 0 },
config: { visible: false, title: '肿瘤学阅片结果', appendToBody: true, width: '600px', configType: 0 },
selectedList: [], selectedList: [],
OncologyAssessType: [], OncologyAssessType: [],
IsOncologyReading: true IsOncologyReading: true
@ -177,10 +193,10 @@ export default {
handleAdd(n) { handleAdd(n) {
this.config.configType = n this.config.configType = n
if (n === 1) { if (n === 1) {
this.config.title = '是否肿瘤学阅片' this.config.title = this.$t('dictionary:template:oncologyConfig:isOncologyReading')
this.config.visible = true this.config.visible = true
} else { } else {
this.config.title = '肿瘤学阅片结果' this.config.title = this.$t('dictionary:template:oncologyConfig:reviewResult')
this.config.visible = true this.config.visible = true
this.$nextTick(() => { this.$nextTick(() => {
var a = this.OncologyAssessType.filter(v => { var a = this.OncologyAssessType.filter(v => {
@ -221,9 +237,3 @@ export default {
} }
} }
</script> </script>
<style scoped>
/deep/ .el-form-item__content{
width: calc(100% - 110px);
}
</style>

Some files were not shown because too many files have changed in this diff Show More