Compare commits

..

No commits in common. "7fcbd7f983728e9f321d0de9150b512501f305f1" and "af452bb04ee1ddbec9c939b116591c3b11b929b9" have entirely different histories.

323 changed files with 22984 additions and 43014 deletions

View File

@ -2,9 +2,6 @@
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,58 +1,48 @@
module.exports = { module.exports = {
root: true, root: true,
parserOptions: { parserOptions: {
parser: '@babel/eslint-parser', parser: 'babel-eslint',
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: {
// "rule-name": "off" "vue/max-attributes-per-line": [
// "vue/max-attributes-per-line": [ 2,
// 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
} }
@ -60,31 +50,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,
@ -92,197 +82,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,12 +1,10 @@
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: [
'@vue/babel-plugin-transform-vue-jsx' '@babel/plugin-proposal-optional-chaining',
// '@babel/plugin-proposal-optional-chaining', '@babel/plugin-proposal-nullish-coalescing-operator'
// '@babel/plugin-proposal-nullish-coalescing-operator'
] ]
} }

36176
package-lock.json generated

File diff suppressed because it is too large Load Diff

View File

@ -14,20 +14,23 @@
"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.701.0", "@aws-sdk/client-s3": "^3.370.0",
"@cornerstonejs/adapters": "^2.19.7",
"@cornerstonejs/calculate-suv": "^1.1.0", "@cornerstonejs/calculate-suv": "^1.1.0",
"@cornerstonejs/core": "^2.19.7", "@cornerstonejs/core": "^1.27.4",
"@cornerstonejs/dicom-image-loader": "^2.19.7", "@cornerstonejs/dicom-image-loader": "^1.27.4",
"@cornerstonejs/tools": "^2.19.7", "@cornerstonejs/streaming-image-volume-loader": "1.23.2",
"@icr/polyseg-wasm": "^0.4.0", "@cornerstonejs/tools": "^1.27.4",
"@microsoft/signalr": "^8.0.7", "@ffmpeg/core": "^0.10.0",
"@riophae/vue-treeselect": "^0.4.0", "@ffmpeg/ffmpeg": "^0.10.1",
"@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",
@ -38,68 +41,67 @@
"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.14", "element-ui": "^2.15.8",
"exceljs": "^4.4.0", "exceljs": "^4.1.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.8.3", "js-md5": "^0.7.3",
"jsencrypt": "^3.3.2", "jsencrypt": "^3.3.2",
"jszip": "^3.10.1", "jszip": "^3.7.1",
"minio": "^7.1.3", "moment": "^2.27.0",
"moment": "^2.30.1", "node-polyfill-webpack-plugin": "^2.0.1",
"moment-timezone": "^0.5.46", "node-sass": "^4.14.1",
"node-xlsx": "^0.24.0", "normalize.css": "7.0.0",
"normalize.css": "^8.0.1", "nprogress": "0.2.0",
"nprogress": "^0.2.0", "path-to-regexp": "2.4.0",
"path-to-regexp": "^0.1.10", "pdfobject": "^2.2.8",
"pdfobject": "^2.3.0", "popper.js": "^1.16.1",
"qrcodejs2": "^0.0.2", "qrcodejs2": "0.0.2",
"screenfull": "^6.0.2", "sass-loader": "^8.0.0",
"sortablejs": "^1.15.5", "screenfull": "^4.2.0",
"sortablejs": "^1.15.0",
"streamsaver": "^2.0.6", "streamsaver": "^2.0.6",
"svg-sprite-loader": "^4.1.3", "v-viewer": "^1.6.4",
"svgo": "^1.2.2",
"v-viewer": "^1.7.4",
"vcrontab": "^0.3.5", "vcrontab": "^0.3.5",
"vue": "^2.6.14", "vue": "^2.6.11",
"vue-clipboard2": "^0.3.3", "vue-clipboard2": "^0.3.1",
"vue-contextmenujs": "^1.4.11", "vue-contextmenujs": "^1.3.13",
"vue-count-to": "^1.0.13", "vue-count-to": "^1.0.13",
"vue-demi": "^0.14.10", "vue-demi": "^0.14.6",
"vue-i18n": "^8.28.2", "vue-i18n": "^8.7.0",
"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.23", "vue-seamless-scroll": "^1.1.21",
"vuedraggable": "^2.24.3", "vuedraggable": "^2.24.3",
"vuex": "^3.1.0", "vuex": "3.1.0",
"webpack-aliyun-oss": "^0.3.13" "webpack-aliyun-oss": "^0.4.9"
}, },
"devDependencies": { "devDependencies": {
"@babel/core": "^7.12.16", "@babel/plugin-proposal-nullish-coalescing-operator": "^7.18.6",
"@babel/eslint-parser": "^7.12.16", "@babel/plugin-proposal-optional-chaining": "^7.21.0",
"@babel/plugin-transform-class-static-block": "^7.26.0", "@vue/cli-plugin-babel": "~4.5.4",
"@vue/babel-plugin-transform-vue-jsx": "^1.4.0", "@vue/cli-plugin-eslint": "~4.5.4",
"@vue/cli-plugin-babel": "~5.0.0", "@vue/cli-service": "~4.5.4",
"@vue/cli-plugin-eslint": "~5.0.0", "autoprefixer": "^9.5.1",
"@vue/cli-service": "~5.0.0", "aws-sdk": "^2.1532.0",
"autoprefixer": "^10.4.20", "babel-eslint": "^10.1.0",
"clean-webpack-plugin": "^4.0.0", "chalk": "2.4.2",
"copy-webpack-plugin": "^12.0.2", "connect": "3.6.6",
"css-minimizer-webpack-plugin": "^7.0.0", "eslint": "^6.7.2",
"eslint": "^7.32.0", "eslint-plugin-vue": "^6.2.2",
"eslint-plugin-vue": "^8.0.3", "html-webpack-plugin": "3.2.0",
"html-webpack-plugin": "^5.6.3", "minio": "^7.1.3",
"mini-css-extract-plugin": "^2.9.2", "moment-timezone": "^0.5.45",
"node-polyfill-webpack-plugin": "^4.0.0", "node-xlsx": "^0.21.0",
"path-browserify": "^1.0.1", "runjs": "^4.3.2",
"process": "^0.11.10", "script-ext-html-webpack-plugin": "2.1.3",
"sass": "^1.63.2", "script-loader": "0.7.2",
"sass-loader": "^10.4.1", "serve-static": "^1.13.2",
"terser-webpack-plugin": "^5.3.10", "svg-sprite-loader": "4.1.3",
"vue-template-compiler": "^2.6.14", "svgo": "1.2.2",
"webpack": "^5.96.1", "vue-template-compiler": "^2.6.11"
"webpack-bundle-analyzer": "^4.10.2"
}, },
"eslintConfig": { "eslintConfig": {
"root": true, "root": true,
@ -107,19 +109,19 @@
"node": true "node": true
}, },
"extends": [ "extends": [
"plugin:vue/essential", "plugin:vue/essential"
"eslint:recommended"
], ],
"parserOptions": { "parserOptions": {
"parser": "@babel/eslint-parser", "parser": "babel-eslint"
"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"
] ]
} }

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: 800px"> <div style="width: 620px">
<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')"> <el-form-item :label="$t('il8n:search:state')" v-if="il8nExternal">
<el-select <el-select
v-model="State" v-model="State"
clearable clearable
@ -62,14 +62,12 @@
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-->
@ -81,11 +79,7 @@
<!-- {{scope.row.Description}}--> <!-- {{scope.row.Description}}-->
<!-- </template>--> <!-- </template>-->
<!-- </el-table-column>--> <!-- </el-table-column>-->
<el-table-column <el-table-column prop="Value" :label="$t('il8n:table:en')">
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"
@ -98,11 +92,7 @@
></el-input> ></el-input>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column <el-table-column prop="ValueCN" :label="$t('il8n:table:cn')">
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"
@ -118,7 +108,7 @@
<el-table-column <el-table-column
prop="ValueCN" prop="ValueCN"
:label="$t('il8n:table:state')" :label="$t('il8n:table:state')"
sortable="custom" v-if="il8nExternal"
> >
<template slot-scope="scope"> <template slot-scope="scope">
<el-select <el-select
@ -136,20 +126,12 @@
</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 size="mini" @click="drawer = false">取消 </el-button>
>{{ $t('common:button:cancel') }} <el-button size="mini" type="primary" @click="handleSave"
</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" />
@ -213,18 +195,6 @@ 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
@ -239,12 +209,9 @@ export default {
[], [],
this.arr.filter( this.arr.filter(
(v) => (v) =>
(v.Code && ~v.Code.toLowerCase().indexOf(this.key.toLowerCase()) ||
~v.Code.toLowerCase().indexOf(this.key.toLowerCase())) || ~v.Value.toLowerCase().indexOf(this.key.toLowerCase()) ||
(v.Value && ~v.ValueCN.toLowerCase().indexOf(this.key.toLowerCase())
~v.Value.toLowerCase().indexOf(this.key.toLowerCase())) ||
(v.ValueCN &&
~v.ValueCN.toLowerCase().indexOf(this.key.toLowerCase()))
) )
) )
} else { } else {
@ -252,39 +219,33 @@ export default {
} }
}, },
handleSave() { handleSave() {
this.$confirm('确定修改当前页面国际化内容?') this.$confirm('确定修改当前页面国际化内容?').then(() => {
.then(() => { batchAddOrUpdateFrontInternationalization(this.tableData).then(
batchAddOrUpdateFrontInternationalization(this.tableData).then( async (res) => {
async (res) => { var zhMessages = {},
var zhMessages = {}, enMessages = {}
enMessages = {} var Internationalization = await getFrontInternationalizationList()
var Internationalization = Vue.prototype.$tl = Internationalization.Result
await getFrontInternationalizationList() this.tableData.forEach((v) => {
Vue.prototype.$tl = Internationalization.Result // zhMessages[v.Description + '_' + v.Code] = v.ValueCN
this.tableData.forEach((v) => { // enMessages[v.Description + '_' + v.Code] = v.Value
// zhMessages[v.Description + '_' + v.Code] = v.ValueCN zhMessages[v.Code] = v.ValueCN
// enMessages[v.Description + '_' + v.Code] = v.Value enMessages[v.Code] = v.Value
zhMessages[v.Code] = v.ValueCN })
enMessages[v.Code] = v.Value i18n.mergeLocaleMessage('zh', zhMessages)
}) i18n.mergeLocaleMessage('en', enMessages)
i18n.mergeLocaleMessage('zh', zhMessages) this.drawer = false
i18n.mergeLocaleMessage('en', enMessages) this.$message.success('国际化修改成功')
this.drawer = false if (this.il8nExternal) {
this.$message.success('国际化修改成功') this.$EventBus.$emit('il8nUpdate')
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 = []
@ -305,8 +266,6 @@ 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)
@ -337,9 +296,6 @@ 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,11 +342,3 @@ export function addNewUserSendEmail(data) {
data data
}) })
} }
// 用户追溯
export function getUserJoinedTrialList(data) {
return request({
url: `/TrialMaintenance/getUserJoinedTrialList`,
method: 'post',
data
})
}

View File

@ -1070,254 +1070,3 @@ export function batchAddEnrollOrPdEmailConfig(params) {
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,13 +1080,7 @@ 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}`,
@ -1378,9 +1372,9 @@ export function getForwardList(param) {
}) })
} }
export function getNoneDicomStudyList(subjectVisitId, sudyId = '', isFilterZip = false, visitTaskId = '', IsReading = false) { export function getNoneDicomStudyList(subjectVisitId, sudyId = '', isFilterZip = false, visitTaskId = '') {
return request({ return request({
url: `/NoneDicomStudy/getNoneDicomStudyList?subjectVisitId=${subjectVisitId}&nonedicomStudyId=${sudyId}&isFilterZip=${isFilterZip}&visitTaskId=${visitTaskId}&IsReading=${IsReading}`, url: `/NoneDicomStudy/getNoneDicomStudyList?subjectVisitId=${subjectVisitId}&nonedicomStudyId=${sudyId}&isFilterZip=${isFilterZip}&visitTaskId=${visitTaskId}`,
method: 'get' method: 'get'
}) })
} }
@ -3946,6 +3940,8 @@ export function updateTrialUserRole(data) {
}) })
} }
// 获取报表配置 // 获取报表配置
export function getTrialQuestionExportResult(data) { export function getTrialQuestionExportResult(data) {
return request({ return request({
@ -3970,28 +3966,3 @@ export function trialUserSendJoinEmail(data) {
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,12 +110,4 @@ export function addOrUpdateTrialBodyPart(data) {
data data
}) })
} }
// 修改检查名称列表
export function updateTrialStudyNameList(data) {
return request({
url: `/TrialConfig/updateTrialStudyNameList`,
method: 'post',
data
})
}

Binary file not shown.

Before

Width:  |  Height:  |  Size: 8.7 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 16 KiB

View File

@ -4,7 +4,6 @@
<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>
@ -25,42 +24,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;
}
} }
.el-form-item { .page{
margin-bottom: 10px; text-align: right;
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 :inline="true" :label-width="labelWidth"> <el-form :size="size" :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,18 +146,17 @@
<!-- 具名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>
<div style="display: inline-block;width: fit-content;"> <el-form-item v-for="item in searchHandle" :key="item.label">
<el-form-item v-for="item in searchHandle" :key="item.label"> <slot v-if="item.slot" :name="item.slot" />
<slot v-if="item.slot" :name="item.slot" /> <el-button
<el-button v-else
v-else :type="item.type"
:type="item.type" :size="item.size || size"
: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>
@ -175,11 +174,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,
@ -197,10 +196,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,6 +62,7 @@
</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
> >
<dicom-tags :image-id="stack.imageIds[stack.currentImageIdIndex]" @close="dcmTag.visible = false" /> <DicomTags :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,16 +415,15 @@ 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.getOrientationMarker(e.detail.element) this.stack.instanceId = instanceId
// 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,7 +149,6 @@ 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" :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"> <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">
<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{
::v-deep .el-form-item__content{ >>>.el-form-item__content{
width: auto; width: auto;
} }
} }
@ -614,7 +614,7 @@ export default {
margin-bottom: 0px; margin-bottom: 0px;
} }
.disabled{ .disabled{
::v-deep .el-upload--picture-card { >>>.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{
::v-deep .el-form-item__content{ >>>.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;
} }
::v-deep .el-form-item__content{ >>>.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{
::v-deep .el-upload--picture-card { >>>.el-upload--picture-card {
display: none; display: none;
} }
} }

View File

@ -92,7 +92,6 @@ 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)
@ -112,11 +111,11 @@ export default {
margin: auto; margin: auto;
} }
::v-deep .el-radio__original { /deep/ .el-radio__original {
display: none !important; /* 隐藏原生 radio 输入,但仍然允许交互 */ display: none !important; /* 隐藏原生 radio 输入,但仍然允许交互 */
} }
::v-deep.el-radio:focus:not(.is-focus):not(:active):not(.is-disabled) /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(3) (scope.row.dicomInfo.uploadFileSize / 1024 / 1024).toFixed(2)
}}MB/{{ }}MB/{{
(scope.row.dicomInfo.fileSize / 1024 / 1024).toFixed(3) (scope.row.dicomInfo.fileSize / 1024 / 1024).toFixed(2)
}}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}.jpg` let thumbnailPath = `/${params.trialId}/Image/${params.subjectId}/${params.subjectVisitId}/${dicomInfo.visitTaskId}/${dicomInfo.studyUid}/${v.seriesUid}.png`
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.subjectId}/${params.subjectVisitId}/${dicomInfo.studyUid}/${v.seriesUid}.jpg` let thumbnailPath = `/${params.trialId}/Image/${params.trialSiteId}/${params.subjectId}/${params.subjectVisitId}/${dicomInfo.studyUid}/${v.seriesUid}.png`
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 * 60) / height canvas.width = width
canvas.height = 60 canvas.height = height
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(3)}MB` ? `${(scope.row.FileSize / 1024 / 1024).toFixed(2)}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(3)}MB` ? `${(scope.row.FileSize / 1024 / 1024).toFixed(2)}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(3)}MB` ? `${(scope.row.size / 1024 / 1024).toFixed(2)}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}.jpg`; let thumbnailPath = `/${dicom.params.TrialId}/TaskImage/${dicom.params.SubjectId}/${dicom.params.VisitTaskId}/${dicom.StudyInstanceUid}/${dicom.SeriesInstanceUid}.png`;
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.module.scss' import variables from '@/styles/variables.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%;
::v-deep { /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.module.scss"; @import "~@/styles/variables.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 || my_EMail.toUpperCase() === vm.unlock.my_username.toUpperCase())) { if (md5(_vm.unlock.my_password) === my_password && my_username === _vm.unlock.my_username) {
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
) { ) {
const res = await getTrialExtralConfig({ let 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
) { ) {
const res = await getTrialExtralConfig({ let 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()
const lang = to.query.lang || zzSessionStorage.getItem('lang') let 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()
const lang = to.query.lang || zzSessionStorage.getItem('lang') let 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') {
const lang = to.query.lang || zzSessionStorage.getItem('lang') let 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') {
const lang = to.query.lang || zzSessionStorage.getItem('lang') let 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') {
const lang = to.query.lang || zzSessionStorage.getItem('lang') let 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,11 +50,6 @@ 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: 'IRC Imaging System', title: 'IRCIS',
/** /**
* @type {boolean} true | false * @type {boolean} true | false

View File

@ -48,8 +48,6 @@ 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,8 +27,7 @@ const store = new Vuex.Store({
trials, trials,
financials, financials,
reading, reading,
lang, lang
noneDicomReview
}, },
getters getters
}) })

View File

@ -1,28 +0,0 @@
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,7 +862,6 @@ 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.module.scss"; @import "./variables.scss";
@import "./mixin.scss"; @import "./mixin.scss";
@import "./transition.scss"; @import "./transition.scss";
@import "./element-ui.scss"; @import "./element-ui.scss";

View File

@ -71,49 +71,29 @@ $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 {
color: $menuText !important; & .nest-menu .el-submenu>.el-submenu__title,
} & .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 || 'IRC Imaging System' const title = defaultSettings.title || 'IRCIS'
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,44 +51,12 @@ 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(3) + unit; store.state.trials.uploadTip = totalBytes.toFixed(2) + 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(3) + unit; store.state.trials.uploadTip = totalBytes.toFixed(2) + unit;
} }
if (timeList.length >= 5) { if (timeList.length >= 5) {
delete bytesReceivedPerSecond[timeList[0]] delete bytesReceivedPerSecond[timeList[0]]

View File

@ -41,13 +41,7 @@ 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)
@ -84,13 +78,7 @@ 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);
@ -197,13 +185,7 @@ 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 * 60) / height canvas.width = width;
canvas.height = 60 canvas.height = height;
if (image) { if (image) {
cornerstone.renderToCanvas(canvas, image); cornerstone.renderToCanvas(canvas, image);
// 将 Canvas 图像对象转换为 PNG 格式 // 将 Canvas 图像对象转换为 PNG 格式

View File

@ -9,7 +9,6 @@ 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" :key="`IsInternal${item.value}`" :label="item.value">{{ item.label }}</el-radio> <el-radio v-for="item of $d.YesOrNo" :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>
::v-deep .el-collapse-item__header{ /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>
::v-deep .el-collapse-item__header{ /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" class="preview-wrapper"> <div ref="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,39 +38,7 @@
</span> </span>
</span>--> </span>-->
<div class="viewernavitextwrapper"> <div class="viewernavitextwrapper">
<div style="padding: 1px 5px 1px 1px;display: flex;justify-content: space-between;"> <div style="padding: 1px;">#{{ item.seriesNumber }}</div>
<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"
@ -179,11 +147,7 @@ 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
) )
@ -191,19 +155,7 @@ 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}`)
} }
isExistMutiFrames = true } else imageIds.push(fileId)
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({
@ -212,43 +164,13 @@ 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
@ -261,172 +183,136 @@ export default {
} }
</script> </script>
<style lang="scss"> <style scoped>
::-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 {
width: 100%; display: block;
display: block; height: 100%;
height: 100%; margin-top: 20px;
margin-top: 20px; margin-left: auto;
margin-left: auto; margin-right: auto;
margin-right: auto; background-color: #444;
background-color: #444; overflow: hidden;
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="$t('dictionary:attachment:label:code')" prop="Code"> <el-form-item 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="$t('dictionary:attachment:label:businessScenario')" prop="BusinessScenarioEnum"> <el-form-item label="业务场景: " 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="$t('dictionary:attachment:export:form:file')"> <el-form-item label="文件: ">
<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" :key="`IsDeleted${item.value}`" :label="item.value">{{ item.label }}</el-radio> <el-radio v-for="item of $d.YesOrNo" :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,8 +2,7 @@
<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;"
@ -17,8 +16,7 @@
</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;"
@ -39,6 +37,7 @@
</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"
@ -58,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="$t('dictionary:attachment:label:code')" label="Code"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<el-table-column <el-table-column
prop="BusinessScenarioEnum" prop="BusinessScenarioEnum"
:label="$t('dictionary:attachment:label:businessScenario')" label="业务场景"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
> >
@ -77,18 +76,18 @@
<el-table-column <el-table-column
prop="Name" prop="Name"
:label="$t('dictionary:attachment:label:name')" label="文件名称"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<el-table-column <el-table-column
prop="Description" prop="Description"
:label="$t('dictionary:attachment:label:description')" label="描述"
show-overflow-tooltip show-overflow-tooltip
/> />
<el-table-column <el-table-column
prop="IsDeleted" prop="IsDeleted"
:label="$t('dictionary:attachment:label:isDeleted')" label="是否废除"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
> >
@ -99,30 +98,30 @@
</el-table-column> </el-table-column>
<el-table-column <el-table-column
prop="UpdateTime" prop="UpdateTime"
:label="$t('dictionary:attachment:label:updateTime')" label="上传时间"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<el-table-column label="Action" width="300"> <el-table-column label="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"
@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>
@ -177,9 +176,9 @@ export default {
}, },
methods: { methods: {
handleDelete(row) { handleDelete(row) {
this.$confirm(this.$t('dictionary:attachment:export:confirm:delete')).then(() => { this.$confirm('确定删除该文件?').then(() => {
deleteCommonDocument(row.Id).then(() => { deleteCommonDocument(row.Id).then(() => {
this.$message.success(this.$t('common:message:deletedSuccessfully')) this.$message.success('删除成功')
this.getList() this.getList()
}) })
}) })
@ -196,7 +195,7 @@ export default {
}, },
// //
handleAdd() { handleAdd() {
this.editDialog.title = this.$t('common:button:new') this.editDialog.title = 'Add'
this.currentRow = { FileTypeEnum: FileTypeEnum } this.currentRow = { FileTypeEnum: FileTypeEnum }
this.editDialog.visible = true this.editDialog.visible = true
}, },
@ -209,7 +208,7 @@ export default {
}, },
// //
handleEdit(row) { handleEdit(row) {
this.editDialog.title = this.$t('common:action:edit') this.editDialog.title = '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" :key="`IsDeleted${item.value}`" :label="item.value">{{ item.label }}</el-radio> <el-radio v-for="item of $d.YesOrNo" :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,8 +2,7 @@
<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;"
@ -17,8 +16,7 @@
</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;"
@ -59,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="$t('dictionary:attachment:label:code')" label="Code"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<el-table-column <el-table-column
prop="BusinessScenarioEnum" prop="BusinessScenarioEnum"
:label="$t('dictionary:attachment:label:businessScenario')" label="业务场景"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
> >
@ -78,7 +76,7 @@
<el-table-column <el-table-column
prop="Name" prop="Name"
:label="$t('dictionary:attachment:label:name')" label="文件名称"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
@ -94,12 +92,12 @@
</el-table-column> </el-table-column>
<el-table-column <el-table-column
prop="Description" prop="Description"
:label="$t('dictionary:attachment:label:description')" label="描述"
show-overflow-tooltip show-overflow-tooltip
/> />
<el-table-column <el-table-column
prop="IsDeleted" prop="IsDeleted"
:label="$t('dictionary:attachment:label:isDeleted')" label="是否废除"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
> >
@ -110,18 +108,18 @@
</el-table-column> </el-table-column>
<el-table-column <el-table-column
prop="UpdateTime" prop="UpdateTime"
:label="$t('dictionary:attachment:label:updateTime')" label="上传时间"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<el-table-column :label="$t('common:action:action')"> <el-table-column label="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="$t('dictionary:attachment:export:search:code')" prop="Code"> <el-form-item 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 <el-form-item
@ -76,9 +76,8 @@
: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 v-for="item of $d.YesOrNo" :key="`IsDeleted${item.value}`" :label="item.value"> <el-radio :label="true"></el-radio>
{{ item.label }} <el-radio :label="false"></el-radio>
</el-radio>
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
<el-form-item <el-form-item

View File

@ -39,6 +39,7 @@
</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"
@ -59,7 +60,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="$t('dictionary:attachment:export:search:code')" label="Code"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
@ -119,7 +120,7 @@
sortable="custom" sortable="custom"
/> />
<el-table-column :label="$t('common:action:action')" width="300"> <el-table-column :label="$t('common:action:action')">
<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') }}
@ -234,7 +235,7 @@ export default {
}, },
// //
handleAdd() { handleAdd() {
this.editDialog.title = this.$t('common:button:new') this.editDialog.title = 'Add'
this.currentRow = { FileTypeEnum: FileTypeEnum } this.currentRow = { FileTypeEnum: FileTypeEnum }
this.editDialog.visible = true this.editDialog.visible = true
}, },
@ -251,7 +252,7 @@ export default {
}, },
// //
handleEdit(row) { handleEdit(row) {
this.editDialog.title = this.$t('common:action:edit') this.editDialog.title = 'Edit'
this.currentRow = { ...row } this.currentRow = { ...row }
this.editDialog.visible = true this.editDialog.visible = true
}, },

View File

@ -33,6 +33,7 @@
</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"
@ -116,7 +117,7 @@
sortable="custom" sortable="custom"
/> />
<el-table-column :label="$t('common:action:action')" min-width="120"> <el-table-column :label="$t('common:action:action')" min-width="100">
<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') }}
@ -246,7 +247,7 @@ export default {
}, },
// //
handleAdd() { handleAdd() {
this.title = this.$t('common:button:new') this.title = 'Add'
this.currentRow = {} this.currentRow = {}
this.editVisible = true this.editVisible = true
}, },
@ -261,7 +262,7 @@ export default {
}, },
// //
handleEdit(row) { handleEdit(row) {
this.title = this.$t('common:action:edit') this.title = '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="$t('dictionary:attachment:label:code')" prop="Code"> <el-form-item 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="$t('dictionary:attachment:label:businessScenario')" prop="BusinessScenarioEnum"> <el-form-item label="业务场景: " 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="$t('dictionary:attachment:label:file')"> <el-form-item label="文件: ">
<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="$t('dictionary:attachment:label:name')" prop="Name"> <el-form-item label="文件名" 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="$t('dictionary:attachment:label:isDeleted')"> <el-form-item v-if="form.Id !== ''" label="是否废除: ">
<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,11 +76,12 @@
> >
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
<el-form-item :label="$t('dictionary:attachment:label:description')"> <el-form-item label="描述">
<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>
@ -92,7 +93,7 @@
:disabled="!form.FileTypeEnum || !form.BusinessScenarioEnum" :disabled="!form.FileTypeEnum || !form.BusinessScenarioEnum"
:loading="saveBtnLoading" :loading="saveBtnLoading"
@click="handleSave" @click="handleSave"
>{{ $t('common:button:save') }}</el-button >Save</el-button
> >
</el-form-item> </el-form-item>
</div> </div>
@ -131,16 +132,16 @@ export default {
}, },
rules: { rules: {
Code: [ Code: [
{ required: true, message: this.$t('common:ruleMessage:specify'), trigger: ['blur'] }, { required: true, message: 'Please specify', trigger: ['blur'] },
], ],
Name: [ Name: [
{ required: true, message: this.$t('common:ruleMessage:specify'), trigger: ['blur'] }, { required: true, message: 'Please specify', trigger: ['blur'] },
], ],
NameCN: [ NameCN: [
{ required: true, message: this.$t('common:ruleMessage:specify'), trigger: ['blur'] }, { required: true, message: 'Please specify', trigger: ['blur'] },
], ],
BusinessScenarioEnum: [ BusinessScenarioEnum: [
{ required: true, message: this.$t('common:ruleMessage:specify'), trigger: ['blur'] }, { required: true, message: 'Please select', trigger: ['blur'] },
], ],
}, },
fileList: [], fileList: [],
@ -192,7 +193,7 @@ export default {
this.fileList = [] this.fileList = []
return true return true
} else { } else {
this.$alert(this.$t('dictionary:attachment:export:alert:formatFile')) this.$alert('必须是word/excel格式')
return false return false
} }
@ -219,7 +220,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(this.$t('dictionary:attachment:message:msg1')) this.$alert('Please select file.')
return return
} }
this.saveBtnLoading = true this.saveBtnLoading = true
@ -228,7 +229,7 @@ export default {
this.saveBtnLoading = false this.saveBtnLoading = false
this.$emit('closeDialog') this.$emit('closeDialog')
this.$emit('getList') this.$emit('getList')
this.$message.success(this.$t('common:message:savedSuccessfully')) this.$message.success('Uploaded successfully')
}) })
.catch(() => { .catch(() => {
this.saveBtnLoading = false this.saveBtnLoading = false
@ -247,7 +248,7 @@ export default {
} }
}, },
handleExceed(files, fileList) { handleExceed(files, fileList) {
this.$message.warning(this.$t('upload:rule:maxFile1')) this.$message.warning(`Upload is currently limited to 1 file`)
}, },
checkFileSuffix(fileName) { checkFileSuffix(fileName) {
var typeArr = ['xls', 'xlsx', 'doc', 'docx'] var typeArr = ['xls', 'xlsx', 'doc', 'docx']

View File

@ -2,8 +2,7 @@
<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,8 +15,7 @@
/> />
</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>
@ -37,6 +35,7 @@
</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"
@ -57,14 +56,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="$t('dictionary:attachment:label:code')" label="Code"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<!-- 业务场景 -->
<el-table-column <el-table-column
prop="BusinessScenarioEnum" prop="BusinessScenarioEnum"
:label="$t('dictionary:attachment:label:businessScenario')" label="业务场景"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
> >
@ -77,10 +76,10 @@
}} }}
</template> </template>
</el-table-column> </el-table-column>
<!-- 文件名称 -->
<el-table-column <el-table-column
prop="Name" prop="Name"
:label="$t('dictionary:attachment:label:name')" label="文件名称"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
@ -90,16 +89,14 @@
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<!-- 描述 -->
<el-table-column <el-table-column
prop="Description" prop="Description"
:label="$t('dictionary:attachment:label:description')" label="描述"
show-overflow-tooltip show-overflow-tooltip
/> />
<!-- 是否废除 -->
<el-table-column <el-table-column
prop="IsDeleted" prop="IsDeleted"
:label="$t('dictionary:attachment:label:isDeleted')" label="是否废除"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
> >
@ -112,27 +109,26 @@
}}</el-tag> }}</el-tag>
</template> </template>
</el-table-column> </el-table-column>
<!-- 上传时间 -->
<el-table-column <el-table-column
prop="UpdateTime" prop="UpdateTime"
:label="$t('dictionary:attachment:label:updateTime')" label="上传时间"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<el-table-column :label="$t('common:action:action')" width="300"> <el-table-column label="Action">
<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>
@ -201,13 +197,12 @@ 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.$t('common:message:deletedSuccessfully')) this.$message.success('删除成功')
this.getList() this.getList()
}) })
}).catch(()=>{}) })
}, },
PreviewFile(row) { PreviewFile(row) {
let basePath = window.location.origin let basePath = window.location.origin
@ -234,7 +229,7 @@ export default {
}, },
// //
handleAdd() { handleAdd() {
this.editDialog.title = this.$t('common:button:new') this.editDialog.title = 'Add'
this.currentRow = { FileTypeEnum: FileTypeEnum } this.currentRow = { FileTypeEnum: FileTypeEnum }
this.editDialog.visible = true this.editDialog.visible = true
}, },
@ -251,7 +246,7 @@ export default {
}, },
// //
handleEdit(row) { handleEdit(row) {
this.editDialog.title = this.$t('common:button:edit') this.editDialog.title = '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 > <el-select v-model="queryParams.ModuleTypeId" placeholder="模块" clearable size="small">
<el-option v-for="item of dict.type.ModuleType" :key="`ModuleTypeId${item.value}`" :value="item.value" :label="item.raw.ValueCN" /> <el-option v-for="item of dict.type.ModuleType" :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" @click="handleQuery"></el-button> <el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery"></el-button>
<el-button type="primary" icon="el-icon-plus" @click="handleAdd"></el-button> <el-button type="primary" icon="el-icon-plus" size="mini" @click="handleAdd"></el-button>
</el-form-item> </el-form-item>
</el-form> </el-form>
<div> <div>
@ -66,30 +66,42 @@
<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>
@ -157,28 +169,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" :key="`ModuleType${item.value}`" :value="item.value" :label="item.raw.ValueCN" /> <el-option v-for="item of dict.type.ModuleType" :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" :key="`OptTypeId${item.value}`" :value="item.value" :label="item.raw.ValueCN" /> <el-option v-for="item of dict.type.OptType" :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" :key="`ObjectType${item.value}`" v-if="ChildGroup === item.raw.ChildGroup" :value="item.value" :label="item.raw.ValueCN" /> <el-option v-for="item of dict.type.ObjectType" 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" :key="`ChildrenType${item.value}`" :value="item.value" :label="item.raw.ValueCN" /> <el-option v-for="item of dict.type.ChildrenType" :value="item.value" :label="item.raw.ValueCN" />
</el-select> </el-select>
</el-form-item> </el-form-item>
</el-col> </el-col>
@ -283,7 +295,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 : []" :key="`Router${index}`"> <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-col :span="10"> <el-col :span="10">
<el-form-item> <el-form-item>
<span slot="label"> <span slot="label">
@ -659,11 +671,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" :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-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-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" :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-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-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

@ -0,0 +1,411 @@
<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,29 +1,30 @@
<template> <template>
<box-content> <box-content>
<div class="search"> <div class="search">
<el-form :inline="true" class="base-search-form"> <el-form :inline="true" size="small" class="base-search-form">
<!-- CRO Name --> <el-form-item label="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"
{{ $t('common:button:search') }} >Search</el-button
</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"
>{{ $t('common:button:new') }}</el-button >New</el-button
> >
</span> </span>
</div> </div>
@ -36,34 +37,30 @@
@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="$t('institutions:cros:label:croCode')" label="CRO Code"
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="$t('institutions:cros:label:croName')" label="CRO Name"
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="$t('institutions:cros:label:croNameCN')" label="CRO NameCN"
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="$t('institutions:cros:label:level')" label="Level"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
> >
@ -71,20 +68,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="$t('common:action:action')" min-width="200"> <el-table-column label="Action" min-width="200">
<template slot-scope="scope"> <template slot-scope="scope">
<el-button <el-button
type="text" circle
icon="el-icon-edit-outline"
title="编辑"
@click="handleEdit(scope.row)" @click="handleEdit(scope.row)"
> />
{{ $t('common:button:edit') }}
</el-button>
<el-button <el-button
type="text" circle
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>
@ -163,13 +160,13 @@ export default {
// CRO // CRO
handleAddCro() { handleAddCro() {
this.rowData = {}; this.rowData = {};
this.title =this.$t('common:button:new'); this.title = "Add";
this.editVisible = true; this.editVisible = true;
}, },
// CRO // CRO
handleEdit(row) { handleEdit(row) {
this.rowData = row; this.rowData = row;
this.title = this.$t('common:action:edit'); this.title = "Edit";
this.editVisible = true; this.editVisible = true;
}, },
// CRO // CRO

View File

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

View File

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

View File

@ -1,37 +1,29 @@
<template> <template>
<box-content> <box-content>
<div class="search"> <div class="search">
<el-form :inline="true" class="base-search-form"> <el-form :inline="true" size="small" class="base-search-form">
<!-- Hospital --> <el-form-item label="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>
<!-- Province --> <el-form-item label="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>
<!-- City --> <el-form-item label="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"> <el-button type="primary" icon="el-icon-search" @click="handleSearch">Search</el-button>
{{ $t('common:button:search') }} <el-button type="primary" icon="el-icon-refresh-left" @click="handleReset">Reset</el-button>
</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"
>{{ $t('common:button:new') }}</el-button> >New</el-button>
</span> </span>
</div> </div>
<!-- hospital列表 --> <!-- hospital列表 -->
@ -44,102 +36,92 @@
@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="$t('institutions:hospitals:label:hospital')" 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="$t('institutions:hospitals:label:universityAffiliated')" label="University Affiliated"
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="$t('institutions:hospitals:label:universityAffiliatedCN')" label="University Affiliated CN"
min-width="170" min-width="170"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<!-- Country -->
<el-table-column
prop="Country"
:label="$t('institutions:hospitals:label:country')"
width="120"
show-overflow-tooltip
sortable="custom"
/>
<!-- Country CN -->
<el-table-column
prop="CountryCN"
:label="$t('institutions:hospitals:label:countryCN')"
width="140"
show-overflow-tooltip
sortable="custom"
/>
<!-- Province -->
<el-table-column
prop="Province"
:label="$t('institutions:hospitals:label:province')"
width="120"
show-overflow-tooltip
sortable="custom"
/>
<!-- Province CN -->
<el-table-column
prop="ProvinceCN"
:label="$t('institutions:hospitals:label:provinceCN')"
width="140"
show-overflow-tooltip
sortable="custom"
/>
<!-- City -->
<el-table-column
prop="City"
:label="$t('institutions:hospitals:label:city')"
width="120"
show-overflow-tooltip
sortable="custom"
/>
<!-- City CN -->
<el-table-column
prop="CityCN"
:label="$t('institutions:hospitals:label:cityCN')"
width="130"
show-overflow-tooltip
sortable="custom"
/>
<el-table-column :label="$t('common:action:action')" width="150"> <el-table-column
prop="Country"
label="Country"
width="120"
show-overflow-tooltip
sortable="custom"
/>
<el-table-column
prop="CountryCN"
label="Country CN"
width="140"
show-overflow-tooltip
sortable="custom"
/>
<el-table-column
prop="Province"
label="Province"
width="120"
show-overflow-tooltip
sortable="custom"
/>
<el-table-column
prop="ProvinceCN"
label="Province CN"
width="140"
show-overflow-tooltip
sortable="custom"
/>
<el-table-column
prop="City"
label="City"
width="120"
show-overflow-tooltip
sortable="custom"
/>
<el-table-column
prop="CityCN"
label="City CN"
width="120"
show-overflow-tooltip
sortable="custom"
/>
<el-table-column label="Action" width="150">
<template slot-scope="scope"> <template slot-scope="scope">
<el-button <el-button
type="text" circle
icon="el-icon-edit-outline"
title="编辑"
@click="handleEdit(scope.row)" @click="handleEdit(scope.row)"
> />
{{ $t('common:button:edit') }}
</el-button>
<el-button <el-button
type="text" circle
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>
@ -208,13 +190,13 @@ export default {
// //
handleAddHospital() { handleAddHospital() {
this.rowData = {} this.rowData = {}
this.editDialog.title = this.$t('common:button:new') this.editDialog.title = 'Add'
this.editDialog.visible = true this.editDialog.visible = true
}, },
// //
handleEdit(row) { handleEdit(row) {
this.rowData = row this.rowData = row
this.editDialog.title = this.$t('common:action:edit') this.editDialog.title = 'Edit'
this.editDialog.visible = true this.editDialog.visible = true
}, },
// //

View File

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

View File

@ -1,49 +1,46 @@
<template> <template>
<box-content> <box-content>
<div class="search"> <div class="search">
<el-form :inline="true" class="base-search-form"> <el-form :inline="true" size="small" class="base-search-form">
<!-- Site Name --> <el-form-item label="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>
<!-- Alias Name --> <el-form-item label="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>
<!-- Country --> <el-form-item label="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>
<!-- City --> <el-form-item label="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"
{{ $t('common:button:search') }} >Search</el-button
</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>
@ -56,131 +53,111 @@
@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="$t('institutions:sites:label:siteCode')" label="Site Code"
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="$t('institutions:sites:label:siteName')" label="Site Name"
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="$t('institutions:sites:label:aliasName')" label="Alias Name"
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="$t('institutions:sites:label:country')" 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="$t('institutions:sites:label:city')" 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="$t('institutions:sites:label:address')" 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="$t('institutions:sites:label:affiliatedHospital')" label="Affiliated Hospital"
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="$t('institutions:sites:label:directorName')" label="Director Name"
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="$t('institutions:sites:label:directorPhone')" label="Director Phone"
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="$t('institutions:sites:label:contactName')" label="Contact Name"
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="$t('institutions:sites:label:contactPhone')" label="Contact Phone"
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="$t('institutions:sites:label:createTime')" label="CreateTime"
min-width="160" min-width="160"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<el-table-column :label="$t('common:action:action')" fixed="right" width="150"> <el-table-column label="Action" fixed="right" width="150">
<template slot-scope="scope"> <template slot-scope="scope">
<el-button <el-button
type="text" circle
icon="el-icon-edit-outline"
title="编辑"
@click="handleEdit(scope.row)" @click="handleEdit(scope.row)"
> />
{{ $t('common:button:edit') }}
</el-button>
<el-button <el-button
type="text" circle
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>
@ -380,7 +357,7 @@ export default {
data() { data() {
return { return {
editVisible: false, editVisible: false,
title: this.$t('common:button:new'), title: "Add",
searchData: searchDataDefault(), searchData: searchDataDefault(),
list: [], list: [],
total: 0, total: 0,
@ -462,13 +439,13 @@ export default {
// Site // Site
handleAddSite() { handleAddSite() {
this.rowData = {}; this.rowData = {};
this.title = this.$t('common:button:new'); this.title = "Add";
this.editVisible = true; this.editVisible = true;
}, },
// Site // Site
handleEdit(row) { handleEdit(row) {
this.rowData = row; this.rowData = row;
this.title = this.$t('common:action:edit'); this.title = "Edit";
this.editVisible = true; this.editVisible = true;
}, },
// Site // Site

View File

@ -8,20 +8,16 @@
label-width="150px" label-width="150px"
> >
<div class="base-dialog-body"> <div class="base-dialog-body">
<!-- Sponsor Name --> <el-form-item label="Sponsor Name: " prop="SponsorName">
<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>
<!-- Sponsor NameCN --> <el-form-item label="Sponsor NameCN: " prop="SponsorName">
<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>
<!-- Sponsor Code --> <el-form-item label="Sponsor Code: " prop="SponsorCode">
<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>
<!-- Level --> <el-form-item label="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"
@ -38,17 +34,15 @@
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>
@ -81,16 +75,16 @@ export default {
}, },
rules: { rules: {
SponsorName: [ SponsorName: [
{ required: true, message: this.$t('common:ruleMessage:specify'), trigger: "blur" }, { required: true, message: "Please specify", trigger: "blur" },
{ max: 500, message: this.$t('common:ruleMessage:maxLength') + ' 500' }, { max: 500, message: "The maximum length is 500" },
], ],
SponsorNameCN: [ SponsorNameCN: [
{ required: true, message: this.$t('common:ruleMessage:specify'), trigger: "blur" }, { required: true, message: "Please specify", trigger: "blur" },
{ max: 500, message: this.$t('common:ruleMessage:maxLength') + ' 500' }, { max: 500, message: "The maximum length is 500" },
], ],
SponsorCode: [ SponsorCode: [
{ required: true, message: this.$t('common:ruleMessage:specify'), trigger: "blur" }, { required: true, message: "Please specify", trigger: "blur" },
{ max: 50, message: this.$t('common:ruleMessage:maxLength') + ' 50' }, { max: 50, message: "The maximum length is 50" },
], ],
}, },
}; };
@ -109,7 +103,7 @@ export default {
.then((res) => { .then((res) => {
this.btnLoading = false; this.btnLoading = false;
if (res.IsSuccess) { if (res.IsSuccess) {
this.$message.success(this.$t('common:message:savedSuccessfully')); this.$message.success("Saved successfully");
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" class="base-search-form"> <el-form :inline="true" size="small" class="base-search-form">
<!-- Sponsor Name --> <el-form-item label="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"
{{ $t('common:button:search') }} >Search</el-button
</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"
>{{ $t('common:button:new') }}</el-button >New</el-button
> >
</span> </span>
</div> </div>
@ -37,34 +37,30 @@
@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="$t('institutions:sponsors:label:sponsorCode')" label="Sponsor Code"
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="$t('institutions:sponsors:label:sponsorName')" label="Sponsor Name"
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="$t('institutions:sponsors:label:sponsorNameCN')" label="Sponsor NameCN"
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="$t('institutions:sponsors:label:level')" label="Level"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
> >
@ -72,20 +68,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="$t('common:action:action')" min-width="150"> <el-table-column label="Action" min-width="150">
<template slot-scope="scope"> <template slot-scope="scope">
<el-button <el-button
type="text" circle
icon="el-icon-edit-outline"
title="编辑"
@click="handleEdit(scope.row)" @click="handleEdit(scope.row)"
> />
{{ $t('common:button:edit') }}
</el-button>
<el-button <el-button
type="text" circle
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>
@ -164,13 +160,13 @@ export default {
// Sponsor // Sponsor
handleAddSponsor() { handleAddSponsor() {
this.rowData = {}; this.rowData = {};
this.title = this.$t('common:button:new'); this.title = "Add";
this.editVisible = true; this.editVisible = true;
}, },
// Sponsor // Sponsor
handleEdit(row) { handleEdit(row) {
this.rowData = row; this.rowData = row;
this.title = this.$t('common:action:edit'); this.title = "Edit";
this.editVisible = true; this.editVisible = true;
}, },
// Sponsor // Sponsor

View File

@ -1,20 +1,16 @@
<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">
<!-- Hospitals --> <el-tab-pane label="Hospitals" name="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>
<!-- Sites --> <el-tab-pane label="Sites" name="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>
<!-- CROs --> <el-tab-pane label="CROs" name="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>
<!-- Sponsors --> <el-tab-pane label="Sponsors" name="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" class="base-search-form"> <el-form :inline="true" size="mini" 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,24 +12,12 @@
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item> <el-form-item>
<el-button <el-button type="primary" @click="handleReset">Reset</el-button>
type="primary" <el-button type="primary" @click="handleSearch">Search</el-button>
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" @click="handleAdd"></el-button> <el-button type="primary" size="mini" @click="handleAdd"></el-button>
</span> </span>
</div> </div>
<el-table <el-table
@ -80,22 +68,25 @@
/> />
</template> </template>
</el-table-column> </el-table-column>
<el-table-column label="操作" width="200" fixed="right"> <el-table-column label="操作" width="300" fixed="right">
<template slot-scope="scope"> <template slot-scope="scope">
<el-button <el-button
type="text" type="primary"
size="mini"
@click="handleEdit(scope.row)" @click="handleEdit(scope.row)"
> >
编辑 编辑
</el-button> </el-button>
<el-button <el-button
type="text" type="success"
size="mini"
@click="handleChild(scope.row)" @click="handleChild(scope.row)"
> >
子项 子项
</el-button> </el-button>
<el-button <el-button
type="text" type="danger"
size="mini"
@click="handleDelete(scope.row)" @click="handleDelete(scope.row)"
> >
删除 删除

View File

@ -63,16 +63,18 @@
/> />
</template> </template>
</el-table-column> </el-table-column>
<el-table-column label="操作" width="150" fixed="right"> <el-table-column label="操作" width="300" fixed="right">
<template slot-scope="scope"> <template slot-scope="scope">
<el-button <el-button
type="text" type="primary"
size="mini"
@click="handleEdit(scope.row)" @click="handleEdit(scope.row)"
> >
编辑 编辑
</el-button> </el-button>
<el-button <el-button
type="text" type="danger"
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" class="base-search-form"> <el-form :inline="true" size="mini" 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,24 +12,12 @@
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item> <el-form-item>
<el-button <el-button type="primary" @click="handleReset">Reset</el-button>
type="primary" <el-button type="primary" @click="handleSearch">Search</el-button>
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" @click="handleAdd"></el-button> <el-button type="primary" size="mini" @click="handleAdd"></el-button>
</span> </span>
</div> </div>
<el-table <el-table
@ -80,22 +68,25 @@
/> />
</template> </template>
</el-table-column> </el-table-column>
<el-table-column label="操作" width="200" fixed="right"> <el-table-column label="操作" width="300" fixed="right">
<template slot-scope="scope"> <template slot-scope="scope">
<el-button <el-button
type="text" type="primary"
size="mini"
@click="handleEdit(scope.row)" @click="handleEdit(scope.row)"
> >
编辑 编辑
</el-button> </el-button>
<el-button <el-button
type="text" type="success"
size="mini"
@click="handleChild(scope.row)" @click="handleChild(scope.row)"
> >
子项 子项
</el-button> </el-button>
<el-button <el-button
type="text" type="danger"
size="mini"
@click="handleDelete(scope.row)" @click="handleDelete(scope.row)"
> >
删除 删除

View File

@ -183,13 +183,16 @@
<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,13 +65,15 @@
<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="text" type="primary"
size="mini"
@click="handleEdit(scope.row)" @click="handleEdit(scope.row)"
> >
编辑 编辑
</el-button> </el-button>
<el-button <el-button
type="text" type="danger"
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" class="base-search-form"> <el-form :inline="true" size="mini" 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,25 +15,13 @@
<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 <el-button type="primary" @click="handleReset">Reset</el-button>
type="primary" <el-button type="primary" @click="handleSearch">Search</el-button>
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" @click="handleAdd"></el-button> <el-button type="primary" size="mini" @click="handleAdd"></el-button>
<el-button type="primary" @click="handleBatchAdd"></el-button> <el-button type="primary" size="mini" @click="handleBatchAdd"></el-button>
</span> </span>
</div> </div>
<el-table <el-table
@ -98,19 +86,22 @@
<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="text" type="primary"
size="mini"
@click="handleEdit(scope.row)" @click="handleEdit(scope.row)"
> >
编辑 编辑
</el-button> </el-button>
<el-button <el-button
type="text" type="success"
size="mini"
@click="handleChild(scope.row)" @click="handleChild(scope.row)"
> >
子项 子项
</el-button> </el-button>
<el-button <el-button
type="text" type="danger"
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" class="base-search-form"> <el-form :inline="true" size="mini" 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,25 +12,13 @@
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item> <el-form-item>
<el-button <el-button type="primary" @click="handleReset">Reset</el-button>
type="primary" <el-button type="primary" @click="handleSearch">Search</el-button>
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" @click="handleSetting"></el-button> <el-button type="primary" size="mini" @click="handleSetting"></el-button>
<el-button type="primary" @click="handleAdd"></el-button> <el-button type="primary" size="mini" @click="handleAdd"></el-button>
</span> </span>
</div> </div>
<el-table <el-table
@ -84,19 +72,22 @@
<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="text" type="primary"
size="mini"
@click="handleEdit(scope.row)" @click="handleEdit(scope.row)"
> >
编辑 编辑
</el-button> </el-button>
<el-button <el-button
type="text" type="success"
size="mini"
@click="handleChild(scope.row)" @click="handleChild(scope.row)"
> >
子项 子项
</el-button> </el-button>
<el-button <el-button
type="text" type="danger"
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" class="base-search-form"> <el-form :inline="true" size="mini" 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,24 +10,12 @@
<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 <el-button type="primary" @click="handleReset">Reset</el-button>
type="primary" <el-button type="primary" @click="handleSearch">Search</el-button>
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" @click="handleAdd">New</el-button> <el-button type="primary" size="mini" @click="handleAdd">New</el-button>
</span> </span>
</div> </div>
<el-table <el-table
@ -62,16 +50,18 @@
<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="text" type="primary"
size="mini"
@click="handleEdit(scope.row)" @click="handleEdit(scope.row)"
> >
编辑 Edit
</el-button> </el-button>
<el-button <el-button
type="text" type="danger"
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,25 +3,15 @@
<!-- 搜索框 --> <!-- 搜索框 -->
<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" icon="el-icon-search" @click="handleSearch"> <el-button type="primary" @click="handleReset">Reset</el-button>
{{ $t('common:button:search') }} <el-button type="primary" @click="handleSearch">Search</el-button>
</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;">
@ -30,7 +20,7 @@
size="mini" size="mini"
@click="handleAdd" @click="handleAdd"
> >
{{ $t('common:button:new') }} New
</el-button> </el-button>
</span> </span>
@ -47,65 +37,58 @@
@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="$t('dictionary:sign:label:code')" label="Code"
sortable="custom" sortable="custom"
show-overflow-tooltip show-overflow-tooltip
/> />
<!-- 模板 -->
<el-table-column <el-table-column
prop="Name" prop="Name"
:label="$t('dictionary:sign:label:name')" label="模板"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<!-- 签名内容(EN) -->
<el-table-column <el-table-column
prop="Value" prop="Value"
:label="$t('dictionary:sign:label:value')" label="签名内容(EN)"
show-overflow-tooltip show-overflow-tooltip
/> />
<!-- 签名内容(CN) -->
<el-table-column <el-table-column
prop="ValueCN" prop="ValueCN"
:label="$t('dictionary:sign:label:valueCN')" label="签名内容(CN)"
show-overflow-tooltip show-overflow-tooltip
/> />
<!-- 更新时间 -->
<el-table-column <el-table-column
prop="UpdateTime" prop="UpdateTime"
:label="$t('dictionary:sign:label:updateTime')" label="更新时间"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<!-- 创建时间 -->
<el-table-column <el-table-column
prop="CreateTime" prop="CreateTime"
:label="$t('dictionary:sign:label:createTime')" label="创建时间"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<el-table-column :label="$t('common:action: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="text" type="text"
@click="handleEdit(scope.row)" @click="handleEdit(scope.row)"
> >
{{ $t('common:button:edit') }} 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)"> <el-button type="text" @click="handleDelete(scope.row)">Delete</el-button>
{{ $t('common:button:delete') }}
</el-button>
</template> </template>
</el-table-column> </el-table-column>
@ -130,7 +113,7 @@
<el-dialog <el-dialog
v-if="configVisible" v-if="configVisible"
:visible.sync="configVisible" :visible.sync="configVisible"
:title="$t('dictionary:sign:button:config')" title="场景配置"
:fullscreen="true" :fullscreen="true"
append-to-body append-to-body
custom-class="base-dialog-wrapper" custom-class="base-dialog-wrapper"
@ -184,13 +167,13 @@ export default {
// //
handleAdd() { handleAdd() {
this.rowData = {} this.rowData = {}
this.title = this.$t('common:button:new') this.title = 'Add'
this.editVisible = true this.editVisible = true
}, },
// //
handleEdit(row) { handleEdit(row) {
this.rowData = { ...row } this.rowData = { ...row }
this.title = this.$t('common:button:edit') this.title = '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" class="base-search-form"> <el-form :inline="true" size="mini" 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" @click="handleAdd"> <el-button type="primary" size="mini" @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,19 +3,18 @@
ref="organForm" ref="organForm"
v-loading="loading" v-loading="loading"
:model="form" :model="form"
label-width="170px" label-width="130px"
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="$t('dictionary:template:criterionConfig:table:criterionType')" prop="CriterionType"> <el-form-item label="标准类型" 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"
@ -25,8 +24,7 @@
/> />
</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"
@ -36,26 +34,23 @@
/> />
</el-select> </el-select>
</el-form-item> </el-form-item>
<!-- 是否配置完成 -->
<el-form-item v-if="form.Id !== ''" :label="$t('dictionary:template:criterionConfig:table:isCompleteConfig')"> <el-form-item v-if="form.Id !== ''" label="是否配置完成">
<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="$t('dictionary:template:criterionConfig:table:showOrder')" prop="ShowOrder"> <el-form-item label="显示序号: " 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>
<!-- eICRF仅展示阅片Tab --> <el-form-item v-if="form.Id !== ''" label="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,36 +8,32 @@
label-width="160px" label-width="160px"
size="small" size="small"
> >
<el-form-item :label="$t('template:anonymization:label:group')" prop="Group"> <el-form-item 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="$t('template:anonymization:label:element')" prop="Group"> <el-form-item label="Element: " prop="Group">
<el-input v-model="form.Element" /> <el-input v-model="form.Element" />
</el-form-item> </el-form-item>
<!-- tag Description --> <el-form-item label="tag Description: " prop="Group">
<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>
<!-- Tag DescriptionCN --> <el-form-item label="Tag DescriptionCN: " prop="Group">
<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>
<!-- Value Representation --> <el-form-item label="Value Representation: " prop="Group">
<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>
<!-- Is Fixed --> <el-form-item label="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="$t('template:anonymization:label:valueReplace')"> <el-form-item label="Replace Value: ">
<el-input v-model="form.ReplaceValue" /> <el-input v-model="form.ReplaceValue" />
</el-form-item> </el-form-item>
<el-form-item :label="$t('template:anonymization:label:isEnable')"> <el-form-item label="Is Enable: ">
<el-switch <el-switch
v-model="form.IsEnable" v-model="form.IsEnable"
:active-value="true" :active-value="true"
@ -47,8 +43,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">{{ $t('common:button:cancel') }}</el-button> <el-button :disabled="btnLoading" size="small" type="primary" @click="handleCancle">Cancel</el-button>
<el-button size="small" type="primary" :loading="btnLoading" @click="handleSave">{{ $t('common:button:save') }}</el-button> <el-button size="small" type="primary" :loading="btnLoading" @click="handleSave">Save</el-button>
</template> </template>
</base-model> </base-model>
</template> </template>
@ -86,7 +82,7 @@ export default {
IsAdd: false IsAdd: false
}, },
rules: { rules: {
Group: [{ required: true, message: this.$t('common:ruleMessage:specify'), trigger: 'blur' }] Group: [{ required: true, message: 'Please specify', trigger: 'blur' }]
}, },
model_cfg: { visible: false, showClose: true, width: '600px', title: '' } model_cfg: { visible: false, showClose: true, width: '600px', title: '' }
} }
@ -112,7 +108,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(this.$t('common:message:savedSuccessfully')) this.$message.success('Saved successfully!')
this.model_cfg.visible = false this.model_cfg.visible = false
this.$emit('getList') this.$emit('getList')
}).catch(() => { }).catch(() => {

View File

@ -2,21 +2,17 @@
<box-content> <box-content>
<!-- 搜索框 --> <!-- 搜索框 -->
<div class="search"> <div class="search">
<el-form :inline="true" class="base-search-form"> <el-form :inline="true" size="mini" class="base-search-form">
<!-- Group --> <el-form-item label="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>
<!-- Element --> <el-form-item label="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>
<!-- Tag Description --> <el-form-item label="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>
<!-- Tag DescriptionCN --> <el-form-item label="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>
@ -33,7 +29,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" @click="handleAdd">{{ $t('common:button:new') }}</el-button> <el-button type="primary" size="mini" @click="handleAdd">New</el-button>
</span> </span>
</div> </div>
@ -42,42 +38,37 @@
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="$t('template:anonymization:label:group')" label="Group"
show-overflow-tooltip show-overflow-tooltip
/> />
<!-- Element -->
<el-table-column <el-table-column
prop="Element" prop="Element"
:label="$t('template:anonymization:label:element')" 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="$t('template:anonymization:label:tagDescription')" label="Tag Description"
min-width="110" min-width="110"
/> />
<!-- Tag DescriptionCN -->
<el-table-column <el-table-column
prop="TagDescriptionCN" prop="TagDescriptionCN"
:label="$t('template:anonymization:label:tagDescriptionCN')" label="Tag DescriptionCN"
min-width="110" min-width="110"
/> />
<!-- Value Representation -->
<el-table-column <el-table-column
prop="ValueRepresentation" prop="ValueRepresentation"
:label="$t('template:anonymization:label:valueRepresentation')" label="Value Representation"
min-width="110" min-width="110"
/> />
<!-- Is Fixed --> <el-table-column label="Is Fixed" width="100">
<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"
@ -87,14 +78,12 @@
/> />
</template> </template>
</el-table-column> </el-table-column>
<!-- Value Replace -->
<el-table-column <el-table-column
prop="ReplaceValue" prop="ReplaceValue"
:label="$t('template:anonymization:label:valueReplace')" label="Value Replace"
min-width="110" min-width="110"
/> />
<!-- Is Enable --> <el-table-column label="Is Enable" width="100" fixed="right">
<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"
@ -104,19 +93,21 @@
/> />
</template> </template>
</el-table-column> </el-table-column>
<el-table-column :label="$t('common:action: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="text" type="primary"
size="mini"
@click="handleEdit(scope.row)" @click="handleEdit(scope.row)"
> >
{{ $t('common:button:edit') }} Edit
</el-button> </el-button>
<el-button <el-button
type="text" type="danger"
size="mini"
@click="handleDelete(scope.row)" @click="handleDelete(scope.row)"
> >
{{ $t('common:button:delete') }} Delete
</el-button> </el-button>
</template> </template>
</el-table-column> </el-table-column>
@ -162,7 +153,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(this.$t('common:message:savedSuccessfully')) this.$message.success('Saved successfully!')
this.loading = false this.loading = false
}).catch(() => { }).catch(() => {
this.loading = false this.loading = false
@ -170,12 +161,12 @@ export default {
}, },
handleAdd() { handleAdd() {
this.$nextTick(() => { this.$nextTick(() => {
this.$refs['AddDICOMConfig'].openDialog(this.$t('common:button:new'), {}) this.$refs['AddDICOMConfig'].openDialog('New Anonymization', {})
}) })
}, },
handleEdit(row) { handleEdit(row) {
this.$nextTick(() => { this.$nextTick(() => {
this.$refs['AddDICOMConfig'].openDialog(this.$t('common:action:edit'), row) this.$refs['AddDICOMConfig'].openDialog('Edit Anonymization', row)
}) })
}, },
handleDelete(row) { handleDelete(row) {

View File

@ -2,13 +2,11 @@
<box-content> <box-content>
<!-- 搜索框 --> <!-- 搜索框 -->
<div class="search"> <div class="search">
<el-form :inline="true" class="base-search-form"> <el-form :inline="true" size="mini" 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"
@ -18,8 +16,7 @@
/> />
</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"
@ -43,8 +40,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>
<el-button type="primary" @click="handleAdd">{{ $t('common:button:new') }}</el-button>
</span> </span>
</div> </div>
@ -53,152 +49,113 @@
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="40" /> <el-table-column type="index" width="60" />
<!-- 临床数据名称 -->
<el-table-column <el-table-column
prop="ClinicalDataSetName" prop="ClinicalDataSetName"
:label="$t('trials:processCfg:title:clinicalDataName')" label="临床数据名称"
show-overflow-tooltip show-overflow-tooltip
min-width="160"
/> />
<!-- 临床数据名称EN -->
<el-table-column <el-table-column
prop="ClinicalDataSetEnName" prop="ClinicalDataSetEnName"
:label="$t('dictionary:clinicalData:label:clinicalDataNameEn')" label="临床数据名称EN"
show-overflow-tooltip show-overflow-tooltip
min-width="190"
/> />
<!-- 上传人 -->
<el-table-column <el-table-column
prop="UploadRole" prop="UploadRole"
:label="$t('trials:processCfg:title:uploader')" :label="$t('trials:uploadMonitor:table: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="$t('trials:processCfg:title:dataLevel')" label="数据级别"
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="$t('trials:processCfg:title:transferType')" label="传输方式"
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:processCfg:label:criterion')" :label="$t('trials:auditRecord:table: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="$t('trials:processCfg:title:module')" label="模板名称"
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
prop="EnFileName"
:label="$t('trials:processCfg:title:enModule')"
show-overflow-tooltip
min-width="140"
>
<template slot-scope="scope">
{{ scope.row.EnFileName }}
</template>
</el-table-column>
<!-- 状态 -->
<el-table-column <el-table-column
prop="IsEnable" prop="IsEnable"
:label="$t('dictionary:clinicalData:label:status')" label="状态"
show-overflow-tooltip show-overflow-tooltip
min-width="120"
> >
<template slot-scope="scope"> <template slot-scope="scope">
<!-- <el-tag v-if="scope.row.IsEnable"></el-tag> <el-tag v-if="scope.row.IsEnable"></el-tag>
<el-tag v-else type="danger">禁用</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> </template>
</el-table-column> </el-table-column>
<!-- 创建时间 -->
<el-table-column <el-table-column
prop="CreateTime" prop="CreateTime"
:label="$t('dictionary:clinicalData:label:CreateTime')" label="创建时间"
show-overflow-tooltip show-overflow-tooltip
min-width="140"
/> />
<el-table-column :label="$t('common:action:action')" min-width="250" fixed="right"> <el-table-column label="操作" width="340" fixed="right">
<template slot-scope="scope"> <template slot-scope="scope">
<!-- 问题配置 -->
<el-button <el-button
type="text" type="primary"
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
v-if="$i18n.locale === 'zh'" type="primary"
type="text" size="mini"
:disabled="!scope.row.FileName" :disabled="!scope.row.FileName"
@click="handleDownloadTpl(scope.row.Path)" @click="handleDownloadTpl(scope.row)"
> >
{{ $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="text" type="primary"
size="mini"
@click="handleEdit(scope.row)" @click="handleEdit(scope.row)"
> >
{{ $t('common:action:edit') }} 编辑
</el-button> </el-button>
<!-- 删除 -->
<el-button <el-button
type="text" type="danger"
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>
@ -208,11 +165,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="600px" width="500px"
append-to-body append-to-body
custom-class="base-dialog-wrapper" custom-class="base-dialog-wrapper"
> >
<clinical-data-form ref="addOrEditCD" :data="currentRow" @close="addOrEditCD.visible = false" @getList="getList" /> <ClinicalDataForm 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"
@ -223,7 +180,7 @@
append-to-body append-to-body
custom-class="base-dialog-wrapper" custom-class="base-dialog-wrapper"
> >
<clinical-question-config ref="QuestionConfigVisible" :data="currentRow" @close="QuestionConfigVisible.visible = false" @getList="getList" /> <ClinicalQuestionConfig ref="QuestionConfigVisible" :data="currentRow" @close="QuestionConfigVisible.visible = false" @getList="getList" />
</el-dialog> </el-dialog>
</box-content> </box-content>
</template> </template>
@ -261,8 +218,7 @@ 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() {
@ -275,13 +231,13 @@ export default {
// //
handleAdd() { handleAdd() {
this.currentRow = {} this.currentRow = {}
this.addOrEditCD.title = this.$t('common:button:new') this.addOrEditCD.title = '新增'
this.addOrEditCD.visible = true this.addOrEditCD.visible = true
}, },
// //
handleEdit(row) { handleEdit(row) {
this.currentRow = { ...row } this.currentRow = { ...row }
this.addOrEditCD.title = this.$t('common:action:edit') this.addOrEditCD.title = '编辑'
this.addOrEditCD.visible = true this.addOrEditCD.visible = true
}, },
// //
@ -297,13 +253,13 @@ export default {
this.loading = false this.loading = false
if (res.IsSuccess) { if (res.IsSuccess) {
this.getList() this.getList()
this.$message.success(this.$t('common:message:deletedSuccessfully')) this.$message.success('删除成功!')
} }
}).catch(() => { this.loading = false }) }).catch(() => { this.loading = false })
}) })
}, },
handleDownloadTpl(path) { handleDownloadTpl(row) {
window.open(this.OSSclientConfig.basePath + path, '_blank') window.open(this.OSSclientConfig.basePath + row.Path, '_blank')
}, },
// //
handleSortByColumn(column) { handleSortByColumn(column) {

View File

@ -5,13 +5,12 @@
:model="form" :model="form"
size="small" size="small"
:rules="rules" :rules="rules"
label-width="200px" label-width="110px"
> >
<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" style="width:100%;"> <el-select v-model="form.ClinicalDataSetEnum" placeholder="请选择" 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"
@ -20,10 +19,11 @@
/> />
</el-select> </el-select>
</el-form-item> </el-form-item>
<!-- 上传人 -->
<el-form-item :label="$t('trials:processCfg:title:uploader')" prop="UploadRole"> <el-form-item :label="$t('trials:studyList:table: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,10 +35,11 @@
/> />
</el-select> </el-select>
</el-form-item> </el-form-item>
<!-- 数据级别 -->
<el-form-item :label="$t('trials:processCfg:title:dataLevel')" prop="ClinicalDataLevel"> <el-form-item label="数据级别" 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
@ -50,10 +51,11 @@
/> />
</el-select> </el-select>
</el-form-item> </el-form-item>
<!-- 传输方式 -->
<el-form-item :label="$t('trials:processCfg:title:transferType')" prop="ClinicalUploadType"> <el-form-item label="传输方式" 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
@ -65,13 +67,13 @@
/> />
</el-select> </el-select>
</el-form-item> </el-form-item>
<!-- 阅片标准 -->
<el-form-item <el-form-item
:label="$t('trials:processCfg:label:criterion')" :label="$t('trials:auditRecord:table: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%;"
> >
@ -83,8 +85,7 @@
/> />
</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"
@ -100,51 +101,19 @@
:on-exceed="handleExceed" :on-exceed="handleExceed"
:disabled="form.Type === ''" :disabled="form.Type === ''"
> >
<el-button size="small" type="primary"> <el-button size="small" type="primary">选择</el-button>
{{ $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"
> >
{{ $t('system:tip:file:docx') }} (必须是doc/docx格式)
</span> </span>
</el-upload> </el-upload>
</div> </div>
</el-form-item> </el-form-item>
<!-- 英文模板 -->
<el-form-item v-if="form.ClinicalUploadType === 1" :label="$t('trials:processCfg:title:enModule')"> <el-form-item v-if="form.Id !== ''" label="是否启用">
<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>
@ -191,8 +160,6 @@ export default {
UploadRole: null, UploadRole: null,
FileName: '', FileName: '',
Path: '', Path: '',
EnFileName: '',
EnPath: '',
IsEnable: true, IsEnable: true,
CriterionEnumList: [] CriterionEnumList: []
}, },
@ -206,7 +173,6 @@ export default {
loading: false, loading: false,
btnLoading: false, btnLoading: false,
fileList: [], fileList: [],
enFileList: [],
systemCriterionSelectList: [] systemCriterionSelectList: []
} }
}, },
@ -229,14 +195,6 @@ export default {
} }
] ]
} }
if (this.data.EnPath) {
this.enFileList = [
{
name: this.data.EnFileName,
path: this.data.EnPath
}
]
}
} }
}, },
save() { save() {
@ -273,7 +231,7 @@ export default {
this.fileList = [] this.fileList = []
return true return true
} else { } else {
this.$alert(this.$t('system:tip:file:docx')) this.$alert('(必须是doc/docx格式)')
return false return false
} }
@ -289,33 +247,7 @@ export default {
} }
}, },
handleExceed(files, fileList) { handleExceed(files, fileList) {
this.$message.warning(this.$t('trials:processCfg:title:onlyOneFile')) this.$message.warning(`只允许上传一个文件`)
},
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']
@ -343,7 +275,7 @@ export default {
</script> </script>
<style lang="scss" scoped> <style lang="scss" scoped>
.upload-container{ .upload-container{
::v-deep .el-upload { /deep/ .el-upload {
width: 100%; width: 100%;
text-align: left; text-align: left;
} }

View File

@ -2,49 +2,39 @@
<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" icon="el-icon-search" @click="handleSearch"> <el-button type="primary" @click="handleReset"></el-button>
{{ $t('common:button:search') }} <el-button type="primary" @click="handleSearch"></el-button>
</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>
@ -62,92 +52,81 @@
label="" label=""
width="50" width="50"
/> />
<!-- 名称 -->
<el-table-column <el-table-column
prop="QuestionName" prop="QuestionName"
:label="$t('trials:readingUnit:qsList:title:qName')" label="名称"
show-overflow-tooltip show-overflow-tooltip
/> />
<!-- 名称(EN) -->
<el-table-column <el-table-column
prop="QuestionEnName" prop="QuestionEnName"
:label="$t('trials:readingUnit:qsList:title:qNameEn')" label="名称(EN)"
show-overflow-tooltip show-overflow-tooltip
/> />
<!-- 题型 -->
<el-table-column <el-table-column
prop="Type" prop="Type"
:label="$t('trials:readingUnit:qsList:title:type')" label="题型"
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="$t('trials:readingUnit:qsList:title:type')" label="选项"
show-overflow-tooltip show-overflow-tooltip
> >
</el-table-column> </el-table-column>
<!-- 是否显示 -->
<el-table-column <el-table-column
prop="ClinicalQuestionShowEnum" prop="ClinicalQuestionShowEnum"
:label="$t('trials:readingUnit:qsList:title:isShow')" label="是否显示"
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="$t('trials:qcCfg:table:isRequired')" label="是否必填"
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="$t('common:action:action')" label="操作"
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"
@ -155,7 +134,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>
@ -170,7 +149,7 @@
append-to-body append-to-body
custom-class="base-dialog-wrapper" custom-class="base-dialog-wrapper"
> >
<clinical-question-form <ClinicalQuestionForm
ref="addOrEdit" ref="addOrEdit"
:list="this.list" :list="this.list"
:clinical-id="clinicalId" :clinical-id="clinicalId"
@ -275,8 +254,7 @@ 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')
}) })
}, },
@ -293,19 +271,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.$t('common:button:add') this.addOrEdit.title = '添加'
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.$t('trials:enrolledReviews:button:view') this.addOrEdit.title = '查看'
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.$t('trials:readingUnit:qsList:title:edit') this.addOrEdit.title = '编辑'
this.addOrEdit.visible = true this.addOrEdit.visible = true
}, },
handleDelete(row) { handleDelete(row) {
@ -320,14 +298,14 @@ export default {
this.loading = false this.loading = false
if (res.IsSuccess) { if (res.IsSuccess) {
this.getList() this.getList()
this.$message.success(this.$t('common:message:deletedSuccessfully')) this.$message.success('删除成功!')
} }
}).catch(() => { this.loading = false }) }).catch(() => { this.loading = false })
}) })
}, },
handleConfig(row) { handleConfig(row) {
this.rowData = { ...row } this.rowData = { ...row }
this.config.title = this.$t('trials:readingUnit:qsList:title:tableQs') this.config.title = `表格问题`
this.config.visible = true this.config.visible = true
}, },
// //

View File

@ -6,11 +6,10 @@
size="small" size="small"
:rules="rules" :rules="rules"
:disabled="type === 'look'" :disabled="type === 'look'"
label-width="180px" label-width="130px"
> >
<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"
@ -20,35 +19,31 @@
/> />
</el-select> </el-select>
</el-form-item> </el-form-item>
<!-- 问题名称 -->
<el-form-item <el-form-item
:label="$t('trials:readingUnit:qsList:title:qName')" label="问题名称"
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="$t('dictionary:template:criterionConfig:title:qsNameEn')" label="问题名称EN"
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="$t('trials:qcCfg:table:typeValue')" label="选项"
prop="TypeValue" prop="TypeValue"
> >
<el-input <el-input
v-model="form.TypeValue" v-model="form.TypeValue"
:placeholder="$t('trials:qcCfg:message:typeValue')" placeholder="选项请用‘|’分割多个选项"
/> />
</el-form-item> </el-form-item>
<!-- 小数位数 -->
<el-form-item <el-form-item
v-if="form.ClinicalQuestionType === 'number'" v-if="form.ClinicalQuestionType === 'number'"
:label="$t('trials:processCfg:form:digitPlaces')" label="小数位数"
prop="DigitPlaces" prop="DigitPlaces"
> >
<el-radio-group <el-radio-group
@ -64,17 +59,16 @@
</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="$t('trials:readingUnit:qsList:title:unit')" label="单位"
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="$t('trials:readingUnit:qsList:title:isShow')" prop="ClinicalQuestionShowEnum"> <el-form-item v-if="form.ClinicalQuestionType !== 'group'" label="是否显示" 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)})"
@ -88,10 +82,9 @@
</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="$t('trials:readingUnit:qsList:title:parentId')" label="显示依赖父问题"
prop="ParentId" prop="ParentId"
> >
<el-select <el-select
@ -108,7 +101,7 @@
</el-select> </el-select>
</el-form-item> </el-form-item>
<!-- 显示时依赖父问题触发值 --> <!-- 显示时依赖父问题触发值 -->
<el-form-item v-if="form.ParentId && form.ClinicalQuestionShowEnum===1" :label="$t('trials:qcCfg:table:parentTriggerValue')" prop="ParentTriggerValue"> <el-form-item v-if="form.ParentId && form.ClinicalQuestionShowEnum===1" label="显示触发值" 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"
@ -118,8 +111,7 @@
/> />
</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"
> >
@ -132,8 +124,7 @@
</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"
@ -156,8 +147,7 @@
</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"
@ -165,8 +155,7 @@
: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"
@ -174,12 +163,10 @@
: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"
@ -240,7 +227,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(this.$t('trials:qcCfg:message:msg1'))) callback(new Error('选项不允许存在相同值'))
} else { } else {
callback() callback()
} }
@ -277,29 +264,29 @@ export default {
}, },
rules: { rules: {
Type: [ Type: [
{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' } { required: true, message: '请选择', trigger: 'blur' }
], ],
LesionType: [ LesionType: [
{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' } { required: true, message: '请选择', trigger: 'blur' }
], ],
QuestionName: [{ required: true, message: this.$t('common:ruleMessage:specify'), trigger: 'blur' }, QuestionName: [{ required: true, message: '请注明', trigger: 'blur' },
{ max: 300, message: this.$t('common:ruleMessage:maxLength') + ' 300' }], { max: 300, message: '最大长度为 300' }],
QuestionGenre: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }], QuestionGenre: [{ required: true, message: '请选择', trigger: 'blur' }],
TypeValue: [{ required: true, message: this.$t('common:ruleMessage:specify'), trigger: 'blur' }, TypeValue: [{ required: true, message: '请注明', trigger: 'blur' },
{ validator: validateTypeVal, trigger: 'blur' }, { validator: validateTypeVal, trigger: 'blur' },
{ max: 500, message: this.$t('common:ruleMessage:maxLength') + ' 500' }], { max: 500, message: '最大长度为 500' }],
DictionaryCode: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }], DictionaryCode: [{ required: true, message: '请选择', trigger: 'blur' }],
IsCheckDate: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }], IsCheckDate: [{ required: true, message: '请选择', trigger: 'blur' }],
ClinicalQuestionShowEnum: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }], ClinicalQuestionShowEnum: [{ required: true, message: '请选择', trigger: 'blur' }],
IsRequired: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }], IsRequired: [{ required: true, message: '请选择', trigger: 'blur' }],
ParentId: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }], ParentId: [{ required: true, message: '请选择', trigger: 'blur' }],
ParentTriggerValue: [ ParentTriggerValue: [
{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' } { required: true, message: '请选择', trigger: 'blur' }
], ],
RelevanceId: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }], RelevanceId: [{ required: true, message: '请选择', trigger: 'blur' }],
RelevanceValue: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }], RelevanceValue: [{ required: true, message: '请选择', trigger: 'blur' }],
GroupName: [{ required: true, message: this.$t('common:ruleMessage:specify'), trigger: 'blur' }, GroupName: [{ required: true, message: '请注明', trigger: 'blur' },
{ max: 50, message: this.$t('common:ruleMessage:maxLength') + ' 50' }] { max: 50, message: '最大长度为 50' }]
}, },
loading: false, loading: false,
btnLoading: false, btnLoading: false,

View File

@ -9,8 +9,7 @@
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)})"
@ -24,31 +23,28 @@
/> />
</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="$t('trials:readingUnit:qsList:title:qName')" label="问题名称"
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="$t('trials:readingUnit:qsList:title:typeValue')" label="选项"
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="$t('trials:readingUnit:qsList:message:msg3')" placeholder="选项请用‘|’分割多个选项"
/> />
</el-form-item> </el-form-item>
<!-- 小数位数 -->
<el-form-item <el-form-item
v-if="form.ClinicalTableQuestionType === 'number'" v-if="form.ClinicalTableQuestionType === 'number'"
:label="$t('trials:readingUnit:qsList:title:digitPlaces')" label="小数位数"
> >
<el-radio-group <el-radio-group
v-model="form.DigitPlaces" v-model="form.DigitPlaces"
@ -62,18 +58,19 @@
</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="$t('trials:readingUnit:qsList:title:unit')" label="单位"
> >
<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="$t('dictionary:clinicalDataQs:title:qsMark')" label="问题标记"
> >
<el-select <el-select
v-model="form.clinicalTableQuestionMarkEnum" v-model="form.clinicalTableQuestionMarkEnum"
@ -87,17 +84,16 @@
/> />
</el-select> </el-select>
</el-form-item> </el-form-item>
<!-- 是否必填 --> <!-- 数值单位 -->
<el-form-item <el-form-item
:label="$t('trials:readingUnit:qsList:title:isRequired')" label="是否必填"
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" :key="`IsRequired${item.value}`" :label="item.value">{{ item.label }}</el-radio> <el-radio v-for="item of $d.QuestionRequired" :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"
@ -160,7 +156,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(this.$t('trials:qcCfg:message:msg1'))) callback(new Error('选项不允许存在相同值'))
} else { } else {
callback() callback()
} }
@ -197,26 +193,26 @@ export default {
}, },
rules: { rules: {
Type: [ Type: [
{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' } { required: true, message: '请选择', trigger: 'blur' }
], ],
QuestionName: [{ required: true, message: this.$t('common:ruleMessage:specify'), trigger: 'blur' }, QuestionName: [{ required: true, message: '请注明', trigger: 'blur' },
{ max: 300, message: this.$t('common:ruleMessage:maxLength') + ' 300' }], { max: 300, message: '最大长度为 300' }],
TypeValue: [{ required: true, message: this.$t('common:ruleMessage:specify'), trigger: 'blur' }, TypeValue: [{ required: true, message: '请注明', trigger: 'blur' },
{ validator: validateTypeVal, trigger: 'blur' }, { validator: validateTypeVal, trigger: 'blur' },
{ max: 200, message: this.$t('common:ruleMessage:maxLength') + ' 200' }], { max: 200, message: '最大长度为 200' }],
ShowQuestion: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }], ShowQuestion: [{ required: true, message: '请选择', trigger: 'blur' }],
IsRequired: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }], IsRequired: [{ required: true, message: '请选择', trigger: 'blur' }],
ParentId: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }], ParentId: [{ required: true, message: '请选择', trigger: 'blur' }],
ParentTriggerValue: [ ParentTriggerValue: [
{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' } { required: true, message: '请选择', trigger: 'blur' }
], ],
RelevanceId: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }], RelevanceId: [{ required: true, message: '请选择', trigger: 'blur' }],
RelevanceValue: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }], RelevanceValue: [{ required: true, message: '请选择', trigger: 'blur' }],
DataTableName: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }], DataTableName: [{ required: true, message: '请选择', trigger: 'blur' }],
DataTableColumn: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }], DataTableColumn: [{ required: true, message: '请选择', trigger: 'blur' }],
// DictionaryCode: [{ required: true, message: '', trigger: 'blur' }], // DictionaryCode: [{ required: true, message: '', trigger: 'blur' }],
DependParentId: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }] DependParentId: [{ required: true, message: '请选择', 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,45 +20,39 @@
size="small" size="small"
height="500" height="500"
> >
<!-- 序号 -->
<el-table-column <el-table-column
prop="ShowOrder" prop="ShowOrder"
:label="$t('trials:qcCfg:table:order')" label="序号"
min-width="70" min-width="70"
/> />
<!-- 名称 -->
<el-table-column <el-table-column
prop="QuestionName" prop="QuestionName"
:label="$t('trials:readingUnit:qsList:title:qName')" label="名称"
show-overflow-tooltip show-overflow-tooltip
/> />
<!-- 名称(EN) -->
<el-table-column <el-table-column
prop="QuestionEnName" prop="QuestionEnName"
:label="$t('trials:readingUnit:qsList:title:qNameEn')" label="名称(EN)"
show-overflow-tooltip show-overflow-tooltip
/> />
<!-- 类型 -->
<el-table-column <el-table-column
prop="Type" prop="Type"
:label="$t('trials:readingUnit:qsList:title:type')" label="类型"
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="$t('trials:readingUnit:qsList:title:typeValue')" label="选项"
show-overflow-tooltip show-overflow-tooltip
min-width="110" min-width="110"
/> />
<!-- 是否必填 -->
<el-table-column <el-table-column
prop="IsRequired" prop="IsRequired"
:label="$t('trials:qcCfg:table:isRequired')" label="是否必填"
min-width="90" min-width="90"
show-overflow-tooltip show-overflow-tooltip
> >
@ -66,40 +60,36 @@
{{ $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="$t('common:action:action')" label="操作"
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>
@ -114,7 +104,7 @@
append-to-body append-to-body
custom-class="base-dialog-wrapper" custom-class="base-dialog-wrapper"
> >
<clinical-question-table-form <ClinicalQuestionTableForm
:clinical-id="clinicalId" :clinical-id="clinicalId"
:clinical-info="clinicalInfo" :clinical-info="clinicalInfo"
ref="addOrEdit" ref="addOrEdit"
@ -175,7 +165,7 @@ export default {
handleLook(row) { handleLook(row) {
this.type = 'look' this.type = 'look'
this.rowData = { ...row } this.rowData = { ...row }
this.addOrEdit.title = this.$t('common:button:edit') this.addOrEdit.title = '编辑'
this.addOrEdit.visible = true this.addOrEdit.visible = true
}, },
getList() { getList() {
@ -188,13 +178,13 @@ export default {
handleAdd() { handleAdd() {
this.type = 'add' this.type = 'add'
this.rowData = {} this.rowData = {}
this.addOrEdit.title = this.$t('common:button:add') this.addOrEdit.title = '添加'
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.$t('common:button:edit') this.addOrEdit.title = '编辑'
this.addOrEdit.visible = true this.addOrEdit.visible = true
}, },
handleDelete(row) { handleDelete(row) {
@ -209,7 +199,7 @@ export default {
this.loading = false this.loading = false
if (res.IsSuccess) { if (res.IsSuccess) {
this.getList() this.getList()
this.$message.success(this.$t('common:message:deletedSuccessfully')) this.$message.success('删除成功!')
} }
}).catch(() => { this.loading = false }) }).catch(() => { this.loading = false })
}) })

View File

@ -4,7 +4,6 @@
<div> <div>
</div> </div>
<div> <div>
<!-- 配置 -->
<el-button <el-button
size="mini" size="mini"
type="primary" type="primary"
@ -12,7 +11,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>
@ -22,62 +21,55 @@
: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="$t('dictionary:template:criterionDictionary:table:code')" label="字典表名"
show-overflow-tooltip show-overflow-tooltip
> >
</el-table-column> </el-table-column>
<!-- 描述 -->
<el-table-column <el-table-column
prop="Description" prop="Description"
:label="$t('dictionary:template:criterionDictionary:table:description')" label="描述"
show-overflow-tooltip show-overflow-tooltip
> >
</el-table-column> </el-table-column>
<!-- 子项数量 -->
<el-table-column <el-table-column
prop="Count" prop="Count"
:label="$t('dictionary:template:criterionDictionary:table:count')" label="子项数量"
show-overflow-tooltip show-overflow-tooltip
> >
</el-table-column> </el-table-column>
<!-- 排序 -->
<el-table-column <el-table-column
prop="ShowOrder" prop="ShowOrder"
:label="$t('dictionary:template:criterionDictionary:table:showOrder')" label="排序"
show-overflow-tooltip show-overflow-tooltip
> >
</el-table-column> </el-table-column>
<!-- 操作 -->
<el-table-column <el-table-column
prop="Description" prop="Description"
:label="$t('common:action:action')" label="操作"
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="text" type="danger"
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>
@ -107,7 +99,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
@ -130,24 +122,21 @@
{{ 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="$t('dictionary:template:criterionDictionary:table:code')" label="字典表名"
show-overflow-tooltip show-overflow-tooltip
> >
</el-table-column> </el-table-column>
<!-- 描述 -->
<el-table-column <el-table-column
prop="Description" prop="Description"
:label="$t('dictionary:template:criterionDictionary:table:description')" label="描述"
show-overflow-tooltip show-overflow-tooltip
> >
</el-table-column> </el-table-column>
<!-- 排序 -->
<el-table-column <el-table-column
prop="ShowOrder" prop="ShowOrder"
:label="$t('dictionary:template:criterionDictionary:table:showOrder')" label="排序"
show-overflow-tooltip show-overflow-tooltip
> >
</el-table-column> </el-table-column>
@ -181,6 +170,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: '全局配置' }, 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: '' },
@ -226,8 +216,7 @@ 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 => {
@ -262,10 +251,9 @@ 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.$t('common:message:deletedSuccessfully')) this.$message.success('删除成功')
this.loading = false this.loading = false
this.getList() this.getList()
}).catch(() => { this.loading = false }) }).catch(() => { this.loading = false })
@ -277,7 +265,7 @@ export default {
</script> </script>
<style lang="scss" scoped> <style lang="scss" scoped>
::v-deep .el-form-item__content{ /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,44 +24,39 @@
> >
<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="$t('dictionary:template:criterionDictionary:table:code')" label="键值"
show-overflow-tooltip show-overflow-tooltip
/> />
<!-- 中文值 -->
<el-table-column <el-table-column
prop="ValueCN" prop="ValueCN"
:label="$t('dictionary:template:criterionDictionary:table:valueCN')" label="中文值"
show-overflow-tooltip show-overflow-tooltip
> >
</el-table-column> </el-table-column>
<!-- 英文值 -->
<el-table-column <el-table-column
prop="Value" prop="Value"
:label="$t('dictionary:template:criterionDictionary:table:value')" label="英文值"
show-overflow-tooltip show-overflow-tooltip
> >
</el-table-column> </el-table-column>
<!-- 描述 -->
<el-table-column <el-table-column
prop="Description" prop="Description"
:label="$t('dictionary:template:criterionDictionary:table:description')" label="描述"
show-overflow-tooltip show-overflow-tooltip
> >
</el-table-column> </el-table-column>
<!-- 分组 -->
<el-table-column <el-table-column
prop="Description" prop="Description"
:label="$t('dictionary:template:criterionDictionary:table:group')" label="分组"
show-overflow-tooltip show-overflow-tooltip
> >
<template slot-scope="scope"> <template slot-scope="scope">
@ -89,7 +84,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
@ -105,31 +100,27 @@
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="$t('dictionary:template:criterionDictionary:table:code')" label="键值"
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="$t('dictionary:template:criterionDictionary:table:valueCN')" label="中文值"
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="$t('dictionary:template:criterionDictionary:table:value')" label="英文值"
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="$t('dictionary:template:criterionDictionary:table:description')" label="描述"
show-overflow-tooltip show-overflow-tooltip
> >
</el-table-column> </el-table-column>
@ -161,7 +152,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: this.$t('template:criterionDictionary:message:msg2') }, // config: { visible: false, title: '标准字典值' },
selectedList: [] selectedList: []
} }
}, },
@ -176,7 +167,7 @@ export default {
CrterionDictionaryGroup: v CrterionDictionaryGroup: v
}).then(res => { }).then(res => {
this.loading = false this.loading = false
this.$message.success(this.$t('common:message:savedSuccessfully')) this.$message.success('设置成功')
this.getList() this.getList()
}).catch(() => {this.loading = false}) }).catch(() => {this.loading = false})
}, },
@ -240,7 +231,7 @@ export default {
</script> </script>
<style lang="scss" scoped> <style lang="scss" scoped>
::v-deep .el-form-item__content{ /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: this.$t('common:ruleMessage:specify'), trigger: ['blur', 'change']}, message: '请注明', 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;
} }
::v-deep .el-form-item__content{ /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{
::v-deep .el-upload--picture-card { /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="220px" label-width="140px"
> >
<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="$t('trials:readingUnit:qsList:title:type')" prop="Type"> <el-form-item label="类型" prop="Type">
<el-select <el-select
v-model="form.Type" v-model="form.Type"
clearable clearable
@ -33,23 +33,22 @@
<!-- 分组名称 --> <!-- 分组名称 -->
<el-form-item <el-form-item
v-if="form.Type === 'group'" v-if="form.Type === 'group'"
:label="$t('trials:readingUnit:qsList:title:groupName')" label="分组名称"
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="$t('dictionary:template:criterionConfig:title:groupNameEn')" label="分组名称EN"
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="$t('trials:readingUnit:qsList:title:qsName')" label="问题名称"
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' },
@ -58,10 +57,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="$t('dictionary:template:criterionConfig:title:qsNameEn')" label="问题名称EN"
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}` }
@ -71,12 +70,10 @@
</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="$t('trials:readingUnit:qsList:title:qsGroupName')" label="问题分组"
: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' }
]" ]"
@ -94,10 +91,9 @@
/> />
</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="$t('trials:readingUnit:qsList:title:isShow')" label="是否显示"
prop="ShowQuestion" prop="ShowQuestion"
> >
<el-radio-group <el-radio-group
@ -121,7 +117,7 @@
<!-- 显示时依赖父问题 --> <!-- 显示时依赖父问题 -->
<el-form-item <el-form-item
v-if="form.Type !== 'group' && form.ShowQuestion === 1" v-if="form.Type !== 'group' && form.ShowQuestion === 1"
:label="$t('trials:readingUnit:qsList:title:parentId')" label="显示依赖父问题"
prop="ParentId" prop="ParentId"
> >
<el-select <el-select
@ -144,7 +140,7 @@
<!-- 显示时依赖父问题触发值 --> <!-- 显示时依赖父问题触发值 -->
<el-form-item <el-form-item
v-if="form.ParentId && form.ShowQuestion === 1" v-if="form.ParentId && form.ShowQuestion === 1"
:label="$t('trials:readingUnit:qsList:title:parentTriggerValueList')" label="显示触发值"
prop="ParentTriggerValueList" prop="ParentTriggerValueList"
> >
<el-select v-model="form.ParentTriggerValueList" clearable multiple> <el-select v-model="form.ParentTriggerValueList" clearable multiple>
@ -156,10 +152,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="$t('trials:readingUnit:qsList:title:isRequired')" prop="IsRequired" label="是否必填"
prop="IsRequired"
> >
<el-radio-group <el-radio-group
v-model="form.IsRequired" v-model="form.IsRequired"
@ -180,10 +176,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="$t('trials:readingUnit:qsList:title:relevanceId')" label="必填依赖父问题"
prop="RelevanceId" prop="RelevanceId"
> >
<el-select <el-select
@ -203,10 +199,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="$t('trials:readingUnit:qsList:title:relevanceValueList')" label="必填触发值"
prop="RelevanceValueList" prop="RelevanceValueList"
> >
<el-select v-model="form.RelevanceValueList" clearable multiple> <el-select v-model="form.RelevanceValueList" clearable multiple>
@ -218,7 +214,6 @@
/> />
</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' ||
@ -226,7 +221,7 @@
form.Type === 'calculation' || form.Type === 'calculation' ||
form.Type === 'number' form.Type === 'number'
" "
:label="$t('trials:readingUnit:qsList:title:isJudgeQuestion')" label="是否裁判问题"
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' }
@ -268,9 +263,8 @@
</el-radio> </el-radio>
</el-radio-group> </el-radio-group>
</el-form-item> --> </el-form-item> -->
<!-- 导出结果 -->
<el-form-item <el-form-item
:label="$t('trials:readingUnit:qsList:title:ExportResult')" label="导出结果"
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>
@ -283,9 +277,9 @@
</el-option> </el-option>
</el-select> </el-select>
</el-form-item> </el-form-item>
<!-- 限制编辑 -->
<el-form-item <el-form-item
:label="$t('trials:readingUnit:qsList:title:limitEdit')" label="限制编辑"
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="[
@ -301,9 +295,8 @@
> >
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
<!-- 全局阅片是否显示 -->
<el-form-item <el-form-item
:label="$t('trials:readingUnit:qsList:title:globalReadingShowType')" label="全局阅片是否显示"
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' }
@ -318,9 +311,8 @@
> >
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
<!-- 问题标识 -->
<el-form-item <el-form-item
:label="$t('dictionary:template:criterionConfig:table:questionType')" label="问题标识"
v-if="form.Type !== 'group' && form.Type !== 'summary'" v-if="form.Type !== 'group' && form.Type !== 'summary'"
prop="QuestionType" prop="QuestionType"
> >
@ -333,9 +325,8 @@
/> />
</el-select> </el-select>
</el-form-item> </el-form-item>
<!-- 是否在阅片页面显示 -->
<el-form-item <el-form-item
:label="$t('trials:readingUnit:qsList:title:isShowInDicom')" label="是否在阅片页面显示"
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' }
@ -350,16 +341,14 @@
> >
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
<!-- 注释 -->
<el-form-item <el-form-item
:label="$t('trials:readingUnit:qsList:title:Remark')" label="注释"
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="$t('trials:readingUnit:qsList:title:order')" label="序号"
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' }
@ -372,8 +361,7 @@
/> />
</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"
@ -384,8 +372,7 @@
</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"
@ -396,18 +383,16 @@
</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="$t('trials:readingUnit:label:QuestionGenre')" label="选项类型"
prop="QuestionGenre" prop="QuestionGenre"
:rules="[{ required: form.Type !== 'calculation', message: this.$t('common:ruleMessage:select') }]" :rules="[{ required: form.Type !== 'calculation', message: '请选择' }]"
> >
<el-radio-group <el-radio-group
v-model="form.QuestionGenre" v-model="form.QuestionGenre"
@ -417,7 +402,7 @@
} }
" "
> >
<el-radio :label="-1"> {{ this.$t('common:title:none') }} </el-radio> <el-radio :label="-1"> </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"
@ -428,23 +413,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="$t('trials:qcCfg:table:typeValue')" label="选项"
prop="TypeValue" prop="TypeValue"
> >
<el-input <el-input
v-model="form.TypeValue" v-model="form.TypeValue"
:placeholder="$t('trials:qcCfg:message:typeValue')" placeholder="选项请用‘|’分割多个选项"
@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="$t('trials:readingUnit:label:DictionaryCode')" label="关联字典"
prop="DictionaryCode" prop="DictionaryCode"
> >
<el-select <el-select
@ -464,8 +449,8 @@
/> />
</el-select> </el-select>
</el-form-item> </el-form-item>
<!-- 默认值 -->
<el-form-item v-if="form.QuestionGenre === 3" :label="$t('trials:readingUnit:qsList:title:defaultValue')"> <el-form-item v-if="form.QuestionGenre === 3" label="默认值">
<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"
@ -475,8 +460,7 @@
/> />
</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('|') : []"
@ -486,10 +470,9 @@
/> />
</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="$t('trials:readingUnit:qsList:title:highlightAnswers')" label="高亮标记值"
prop="HighlightAnswerList" prop="HighlightAnswerList"
> >
<el-select v-model="form.HighlightAnswerList" clearable multiple> <el-select v-model="form.HighlightAnswerList" clearable multiple>
@ -511,9 +494,8 @@
</template> </template>
</el-select> </el-select>
</el-form-item> </el-form-item>
<!-- 分组标识 -->
<el-form-item <el-form-item
:label="$t('dictionary:template:criterionConfig:table:groupClassify')" label="分组标识"
v-if="form.Type === 'group'" v-if="form.Type === 'group'"
prop="GroupClassify" prop="GroupClassify"
> >
@ -526,10 +508,9 @@
/> />
</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="$t('trials:readingUnit:qsList:title:MaxAnswerLength')" label="最大长度"
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' }
@ -537,10 +518,9 @@
> >
<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="$t('trials:readingUnit:qsList:title:maxQuestionCount')" label="最大行数"
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' }
@ -553,16 +533,16 @@
:max="10" :max="10"
/> />
</el-form-item> </el-form-item>
<el-form-item v-if="form.Type === 'table' || form.Type === 'basicTable'" :label="$t('trials:readingUnit:qsList:title:orderMark')"> <el-form-item v-if="form.Type === 'table' || form.Type === 'basicTable'" label="自增序号前缀">
<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="$t('trials:readingUnit:qsList:title:valueType')" label="数值类型"
prop="ValueType" prop="ValueType"
:rules="[{ required: true, message: this.$t('common:ruleMessage:select') }]" :rules="[{ required: true, message: '请选择' }]"
> >
<el-radio-group v-model="form.ValueType"> <el-radio-group v-model="form.ValueType">
<el-radio <el-radio
@ -575,10 +555,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="$t('trials:readingUnit:qsList:title:unit')" label="单位"
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' }
@ -594,10 +574,9 @@
</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="$t('dictionary:template:criterionConfig:table:tableType')" label="表格类型标识"
prop="LesionType" prop="LesionType"
> >
<el-select v-model="form.LesionType" clearable> <el-select v-model="form.LesionType" clearable>
@ -609,10 +588,9 @@
/> />
</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="$t('dictionary:template:criterionConfig:table:tableType')" label="表格类型标识"
prop="LesionType" prop="LesionType"
> >
<el-select v-model="form.LesionType" clearable> <el-select v-model="form.LesionType" clearable>
@ -624,10 +602,9 @@
/> />
</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="$t('dictionary:template:criterionConfig:table:relatedDictionaryCode')" label="关联字典"
> >
<el-select <el-select
v-model="form.DictionaryCode" v-model="form.DictionaryCode"
@ -646,10 +623,9 @@
/> />
</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="$t('trials:readingUnit:qsList:title:imageCount')" label="最大上传个数"
> >
<el-input-number <el-input-number
v-model="form.ImageCount" v-model="form.ImageCount"
@ -661,7 +637,7 @@
<!-- 文件类型 --> <!-- 文件类型 -->
<el-form-item <el-form-item
v-if="form.Type === 'upload'" v-if="form.Type === 'upload'"
:label="$t('trials:readingUnit:qsList:title:FileType')" label="文件类型"
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'] }]"
> >
@ -684,10 +660,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="$t('dictionary:template:criterionConfig:table:classifyQuestion')" label="分类数据来源"
prop="ClassifyQuestionId" prop="ClassifyQuestionId"
> >
<el-select v-model="form.ClassifyQuestionId" clearable> <el-select v-model="form.ClassifyQuestionId" clearable>
@ -695,10 +671,9 @@
: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="$t('dictionary:template:criterionConfig:table:classifyAlgorithms')" label="分类算法"
prop="ClassifyAlgorithms" prop="ClassifyAlgorithms"
> >
<div> <div>
@ -810,7 +785,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(this.$t('trials:readingUnit:qsList:message:msg0'))) callback(new Error('选项不允许存在相同值'))
} else { } else {
callback() callback()
} }
@ -865,34 +840,34 @@ export default {
ClassifyAlgorithms: null, ClassifyAlgorithms: null,
}, },
rules: { rules: {
Type: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }], Type: [{ required: true, message: '请选择', trigger: 'blur' }],
LesionType: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }], LesionType: [{ required: true, message: '请选择', 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: this.$t('common:ruleMessage:select'), trigger: 'blur' }], QuestionGenre: [{ required: true, message: '请选择', trigger: 'blur' }],
TypeValue: [ TypeValue: [
{ required: true, message: this.$t('common:ruleMessage:specify'), trigger: 'blur' }, { required: true, message: '请注明', trigger: 'blur' },
{ validator: validateTypeVal, trigger: 'blur' }, { validator: validateTypeVal, trigger: 'blur' },
{ max: 500, message: `${this.$t('common:ruleMessage:maxLength')} 500` }, { max: 500, message: '最大长度为 500' },
], ],
DictionaryCode: [ DictionaryCode: [
{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }, { required: true, message: '请选择', trigger: 'blur' },
], ],
ShowQuestion: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }], ShowQuestion: [{ required: true, message: '请选择', trigger: 'blur' }],
IsRequired: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }], IsRequired: [{ required: true, message: '请选择', trigger: 'blur' }],
ParentId: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }], ParentId: [{ required: true, message: '请选择', trigger: 'blur' }],
ParentTriggerValueList: [ ParentTriggerValueList: [
{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }, { required: true, message: '请选择', trigger: 'blur' },
], ],
RelevanceId: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }], RelevanceId: [{ required: true, message: '请选择', trigger: 'blur' }],
RelevanceValueList: [ RelevanceValueList: [
{ required: true, message: this.$t('common:ruleMessage:select'), trigger: 'blur' }, { required: true, message: '请选择', trigger: 'blur' },
], ],
GroupName: [ GroupName: [
{ required: true, message: this.$t('common:ruleMessage:specify'), trigger: 'blur' }, { required: true, message: '请注明', trigger: 'blur' },
{ max: 50, message: `${this.$t('common:ruleMessage:maxLength')} 50` }, { max: 50, message: '最大长度为 50' },
], ],
// ExportIdentification: [ // ExportIdentification: [
// { required: true, message: '', trigger: 'blur' }, // { required: true, message: '', trigger: 'blur' },

View File

@ -1,15 +1,13 @@
<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"
@ -17,8 +15,7 @@
: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,12 +1,10 @@
<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>
@ -29,7 +27,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)"
@ -37,7 +35,7 @@
type="primary" type="primary"
@click="handleAdd" @click="handleAdd"
> >
{{ $t('common:button:add') }} 添加
</el-button> </el-button>
</div> </div>
@ -51,89 +49,72 @@
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="$t('trials:readingUnit:qsList:title:groupName')" label="分组"
show-overflow-tooltip show-overflow-tooltip
min-width="120"
/> />
<!-- 分组(EN) -->
<el-table-column <el-table-column
prop="GroupEnName" prop="GroupEnName"
:label="$t('dictionary:template:criterionConfig:title:groupNameEn')" label="分组(EN)"
show-overflow-tooltip show-overflow-tooltip
min-width="140"
/> />
<!-- 名称 -->
<el-table-column <el-table-column
prop="QuestionName" prop="QuestionName"
:label="$t('trials:readingUnit:qsList:title:qsName')" label="名称"
show-overflow-tooltip show-overflow-tooltip
min-width="140"
/> />
<!-- 名称(EN) -->
<el-table-column <el-table-column
prop="QuestionEnName" prop="QuestionEnName"
:label="$t('dictionary:template:criterionConfig:title:qsNameEn')" label="名称(EN)"
show-overflow-tooltip show-overflow-tooltip
min-width="160"
/> />
<!-- 题型 -->
<el-table-column <el-table-column
prop="Type" prop="Type"
:label="$t('trials:readingUnit:qsList:title:type')" label="题型"
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="ShowQuestion"
:label="$t('trials:readingUnit:qsList:title:isShow')"
show-overflow-tooltip
min-width="100"
>
<template slot-scope="scope">
{{ $fd('ShowQuestion',scope.row.ShowQuestion) }}
</template>
</el-table-column>
<!-- 是否必填 -->
<el-table-column <el-table-column
prop="IsRequired" prop="IsRequired"
:label="$t('trials:readingUnit:qsList:title:isRequired')" label="是否必填"
show-overflow-tooltip show-overflow-tooltip
min-width="100"
> >
<template slot-scope="scope"> <template slot-scope="scope">
{{ $fd('QuestionRequired',scope.row.IsRequired) }} {{ $fd('QuestionRequired',scope.row.IsRequired) }}
</template> </template>
</el-table-column> </el-table-column>
<!-- 是否裁判问题 --> <el-table-column
prop="ShowQuestion"
label="是否显示"
show-overflow-tooltip
>
<template slot-scope="scope">
{{ $fd('ShowQuestion',scope.row.ShowQuestion) }}
</template>
</el-table-column>
<el-table-column <el-table-column
prop="IsJudgeQuestion" prop="IsJudgeQuestion"
:label="$t('trials:readingUnit:qsList:title:isJudgeQuestion')" label="是否裁判问题"
min-width="200" width="120"
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="$t('trials:readingUnit:qsList:title:isShowInDicom')" label="是否在阅片页面显示"
min-width="200" width="150"
show-overflow-tooltip show-overflow-tooltip
> >
<template slot-scope="scope"> <template slot-scope="scope">
@ -148,11 +129,10 @@
show-overflow-tooltip show-overflow-tooltip
> >
</el-table-column> --> </el-table-column> -->
<!-- 是否在全局阅片显示 -->
<el-table-column <el-table-column
prop="GlobalReadingShowType" prop="GlobalReadingShowType"
:label="$t('trials:readingUnit:qsList:title:globalReadingShowType')" label="是否在全局阅片显示"
min-width="240" width="160"
show-overflow-tooltip show-overflow-tooltip
> >
<template slot-scope="scope"> <template slot-scope="scope">
@ -173,8 +153,8 @@
<!-- 问题标识 --> <!-- 问题标识 -->
<el-table-column <el-table-column
prop="QuestionType" prop="QuestionType"
:label="$t('dictionary:template:criterionConfig:table:questionType')" label="问题标识"
min-width="160" width="140"
show-overflow-tooltip show-overflow-tooltip
> >
<template slot-scope="scope"> <template slot-scope="scope">
@ -205,52 +185,54 @@
</el-table-column> </el-table-column>
<el-table-column <el-table-column
prop="" prop=""
:label="$t('common:action:action')" label="操作"
width="200" 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="text" type="primary"
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="text" type="primary"
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="text" type="primary"
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="text" type="danger"
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>
@ -259,11 +241,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="800px" width="650px"
append-to-body append-to-body
custom-class="base-dialog-wrapper" custom-class="base-dialog-wrapper"
> >
<criterion-question-form <CriterionQuestionForm
ref="addOrEdit" ref="addOrEdit"
:data="rowData" :data="rowData"
:type="type" :type="type"
@ -379,19 +361,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.$t('common:button:new') this.addOrEdit.title = '添加'
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.$t('common:button:view') this.addOrEdit.title = '查看'
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.$t('common:button:edit') this.addOrEdit.title = '编辑'
this.addOrEdit.visible = true this.addOrEdit.visible = true
}, },
handleDelete(row) { handleDelete(row) {
@ -406,7 +388,7 @@ export default {
this.loading = false this.loading = false
if (res.IsSuccess) { if (res.IsSuccess) {
this.getList() this.getList()
this.$message.success(this.$t('common:message:deletedSuccessfully')) this.$message.success('删除成功!')
} }
}).catch(() => { this.loading = false }) }).catch(() => { this.loading = false })
}) })

View File

@ -2,15 +2,14 @@
<box-content> <box-content>
<!-- 搜索框 --> <!-- 搜索框 -->
<div class="search"> <div class="search">
<el-form :inline="true" class="base-search-form"> <el-form :inline="true" size="mini" 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="$t('dictionary:template:criterionConfig:table:criterionType')" label="标准类型"
> >
<el-select v-model="searchData.CriterionType" clearable style="width:120px;"> <el-select v-model="searchData.CriterionType" clearable style="width:120px;">
<el-option <el-option
@ -21,9 +20,8 @@
/> />
</el-select> </el-select>
</el-form-item> </el-form-item>
<!-- 标准分组 -->
<el-form-item <el-form-item
:label="$t('dictionary:template:criterionConfig:table:criterionGroup')" label="标准分组"
> >
<el-select v-model="searchData.CriterionGroup" clearable style="width:120px;"> <el-select v-model="searchData.CriterionGroup" clearable style="width:120px;">
<el-option <el-option
@ -34,9 +32,8 @@
/> />
</el-select> </el-select>
</el-form-item> </el-form-item>
<!-- 是否配置完成 -->
<el-form-item <el-form-item
:label="$t('dictionary:template:criterionConfig:table:isCompleteConfig')" label="是否配置完成"
> >
<el-select v-model="searchData.IsCompleteConfig" clearable style="width:120px;"> <el-select v-model="searchData.IsCompleteConfig" clearable style="width:120px;">
<el-option <el-option
@ -47,9 +44,8 @@
/> />
</el-select> </el-select>
</el-form-item> </el-form-item>
<!-- 是否启用 -->
<el-form-item <el-form-item
:label="$t('dictionary:template:criterionConfig:table:isEnable')" label="是否启用"
> >
<el-select v-model="searchData.IsEnable" clearable style="width:120px;"> <el-select v-model="searchData.IsEnable" clearable style="width:120px;">
<el-option <el-option
@ -74,8 +70,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>
<el-button type="primary" @click="handleAdd">{{$t('common:button:new')}}</el-button>
</span> </span>
</div> </div>
@ -84,49 +79,44 @@
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="$t('trials:auditRecord:table:criterion')" label="标准名称"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
width="180"
/> />
<!-- 标准类型 -->
<el-table-column <el-table-column
prop="CriterionType" prop="CriterionType"
:label="$t('dictionary:template:criterionConfig:table:criterionType')" label="标准类型"
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="$t('dictionary:template:criterionConfig:table:criterionGroup')" label="标准分组"
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="$t('dictionary:template:criterionConfig:table:isCompleteConfig')" label="是否配置完成"
sortable="custom" sortable="custom"
width="220"
> >
<template slot-scope="scope"> <template slot-scope="scope">
@ -138,33 +128,29 @@
{{ $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="$t('dictionary:template:criterionConfig:table:description')" label="描述"
show-overflow-tooltip show-overflow-tooltip
/> />
<!-- 是否启用 -->
<el-table-column <el-table-column
prop="IsEnable" prop="IsEnable"
:label="$t('dictionary:template:criterionConfig:table:isEnable')" label="是否启用"
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="$t('dictionary:template:criterionConfig:table:showOrder')" label="显示序号"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
/> />
<!-- eICRF仅展示阅片Tab -->
<el-table-column <el-table-column
prop="IseCRFShowInDicomReading" prop="IseCRFShowInDicomReading"
:label="$t('dictionary:template:criterionConfig:table:isECRFShowInDicomReading')" label="eICRF仅展示阅片Tab"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
width="210" width="210"
@ -173,36 +159,36 @@
{{ $fd('YesOrNo', scope.row.IseCRFShowInDicomReading) }} {{ $fd('YesOrNo', scope.row.IseCRFShowInDicomReading) }}
</template> </template>
</el-table-column> </el-table-column>
<el-table-column :label="$t('common:action:action')" min-width="220px"> <el-table-column label="Action" min-width="200px">
<template slot-scope="scope"> <template slot-scope="scope">
<!-- 编辑 -->
<el-button <el-button
type="text" type="primary"
size="mini"
@click="handleEdit(scope.row)" @click="handleEdit(scope.row)"
> >
{{ $t('common:button:edit') }} 编辑
</el-button> </el-button>
<!-- eCRF -->
<el-button <el-button
type="text" type="primary"
size="mini"
@click="handleConfig(scope.row)" @click="handleConfig(scope.row)"
> >
{{ $t('dictionary:template:criterionConfig:button:eCRF') }} eCRF
</el-button> </el-button>
<!-- 基础数据 -->
<el-button <el-button
type="text" type="primary"
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="text" type="danger"
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>
@ -218,9 +204,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="600px" width="500px"
> >
<add-criterion <AddCriterion
:data="rowData" :data="rowData"
@close="addDialog.visible = false" @close="addDialog.visible = false"
@getList="getList" @getList="getList"
@ -241,7 +227,7 @@
<el-dialog <el-dialog
v-if="configBaseDataVisible" v-if="configBaseDataVisible"
:title="`${this.$t('trials:readingUnit:readingCriterion:title:baseDataCfg')} (${rowData.CriterionName})`" :title="'基础数据配置' + `(${rowData.CriterionName})`"
:visible.sync="configBaseDataVisible" :visible.sync="configBaseDataVisible"
:close-on-click-modal="false" :close-on-click-modal="false"
:fullscreen="true" :fullscreen="true"
@ -306,17 +292,17 @@ export default {
}).catch(() => { this.loading = false }) }).catch(() => { this.loading = false })
}, },
handleAdd() { handleAdd() {
this.addDialog.title = this.$t('common:button:new') this.addDialog.title = '添加'
this.addDialog.visible = true this.addDialog.visible = true
this.rowData = {} this.rowData = {}
}, },
handleEdit(row) { handleEdit(row) {
this.addDialog.title = this.$t('common:button:edit') this.addDialog.title = '编辑'
this.addDialog.visible = true this.addDialog.visible = true
this.rowData = { ...row } this.rowData = { ...row }
}, },
handleDelete(row) { handleDelete(row) {
this.$confirm(this.$t('trials:readingUnit:baseDataCfg:message:deleteConfirm'), { this.$confirm('是否确认删除', {
distinguishCancelAndClose: true, distinguishCancelAndClose: true,
type: 'warning' type: 'warning'
}).then(() => { }).then(() => {
@ -324,7 +310,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:deletedSuccessfully')) this.$message.success(this.$t('common:message:savedSuccessfully'))
this.getList() this.getList()
} }
}).catch(() => { this.loading = false }) }).catch(() => { this.loading = false })
@ -333,10 +319,10 @@ export default {
changeStatus(callback, row) { changeStatus(callback, row) {
var message = '' var message = ''
if (callback) { if (callback) {
message = this.$t('trials:readingUnit:baseDataCfg:message:updateConfirm') message = '是否确认更改?'
row.IsCompleteConfig = false row.IsCompleteConfig = false
} else { } else {
message = this.$t('trials:readingUnit:baseDataCfg:message:updateConfirm') message = '是否确认更改?'
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,7 +84,6 @@
<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,13 +1,10 @@
<template> <template>
<div style="position: relative"> <div style="position: relative">
<el-form size="small" :inline="true" style="position: relative;"> <el-form size="small" :inline="true" label-width="130px" style="position: relative;">
<!-- 阅片规则 --> <el-divider content-position="left">阅片规则</el-divider>
<el-divider content-position="left">{{ $t('dictionary:template:globalConfig:readingRules') }}</el-divider> <el-form-item label="是否必须全局阅片">
<!-- 是否必须全局阅片 -->
<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"
@ -15,13 +12,11 @@
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" style="position: relative"> <el-form size="small" :inline="true" label-width="110px" 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"
@ -29,10 +24,9 @@
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"
@ -40,34 +34,30 @@
:data="list" :data="list"
stripe stripe
> >
<!-- 序号 -->
<el-table-column <el-table-column
prop="" prop=""
:label="$t('dictionary:template:globalConfig:order')" label="序号"
width="80" 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="ValueCN" prop="ValueCN"
:label="$t('dictionary:template:globalConfig:valueCN')" label="中文值"
show-overflow-tooltip show-overflow-tooltip
> >
</el-table-column> </el-table-column>
<!-- 英文值 -->
<el-table-column <el-table-column
prop="Value" prop="Value"
:label="$t('dictionary:template:globalConfig:value')" label="英文值"
show-overflow-tooltip show-overflow-tooltip
> >
</el-table-column> </el-table-column>
<!-- 是否基线评估 -->
<el-table-column <el-table-column
prop="IsBaseLineUse" prop="IsBaseLineUse"
:label="$t('dictionary:template:globalConfig:isBaseLineUse')" label="是否基线评估"
show-overflow-tooltip show-overflow-tooltip
> >
<template slot-scope="scope"> <template slot-scope="scope">
@ -80,10 +70,9 @@
<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="$t('dictionary:template:globalConfig:isFollowVisitUse')" label="是否随访评估"
show-overflow-tooltip show-overflow-tooltip
> >
<template slot-scope="scope"> <template slot-scope="scope">
@ -104,14 +93,12 @@
> >
<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"
@ -125,24 +112,21 @@
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="$t('dictionary:template:globalConfig:valueCN')" label="中文值"
show-overflow-tooltip show-overflow-tooltip
> >
</el-table-column> </el-table-column>
<!-- 英文值 -->
<el-table-column <el-table-column
prop="Value" prop="Value"
:label="$t('dictionary:template:globalConfig:value')" label="英文值"
show-overflow-tooltip show-overflow-tooltip
> >
</el-table-column> </el-table-column>
<!-- 是否基线评估 -->
<el-table-column <el-table-column
prop="IsBaseLineUse" prop="IsBaseLineUse"
:label="$t('dictionary:template:globalConfig:isBaseLineUse')" label="是否基线评估"
show-overflow-tooltip show-overflow-tooltip
> >
<template slot-scope="scope"> <template slot-scope="scope">
@ -154,10 +138,9 @@
<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="$t('dictionary:template:globalConfig:isFollowVisitUse')" label="是否随访评估"
show-overflow-tooltip show-overflow-tooltip
> >
<template slot-scope="scope"> <template slot-scope="scope">
@ -173,12 +156,8 @@
</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 :disabled="loading" size="small" type="primary" @click="config.visible = false">取消</el-button>
{{ $t('common:button:cancel') }} <el-button size="small" type="primary" :loading="loading" @click="handleSave"></el-button>
</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>
@ -207,8 +186,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: this.$t('dictionary:template:globalConfig:updateType'), appendToBody: true, width: '600px', configType: 0 }, config: { visible: false, title: '评估更新类型', appendToBody: true, width: '600px', configType: 0 },
selectedList: [], selectedList: [],
IsMustGlobalReading: false, IsMustGlobalReading: false,
form: { form: {
@ -290,10 +269,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.$t('dictionary:template:globalConfig:isMustGlobalReading') this.config.title = '是否必须全局阅片'
this.config.visible = true this.config.visible = true
} else { } else {
this.config.title = this.$t('dictionary:template:globalConfig:updateType') this.config.title = '评估更新类型'
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 => {
@ -343,4 +322,8 @@ export default {
} }
</script> </script>
<style scoped>
/deep/ .el-form-item__content{
width: calc(100% - 130px);
}
</style>

View File

@ -1,13 +1,10 @@
<template> <template>
<div> <div>
<el-form size="small" :inline="true" style="position: relative;"> <el-form size="small" :inline="true" label-width="110px" style="position: relative;">
<!-- 阅片规则 --> <el-divider content-position="left">阅片规则</el-divider>
<el-divider content-position="left">{{ $t('dictionary:template:globalConfig:readingRules') }}</el-divider> <el-form-item label="是否肿瘤学阅片" style="width: 100%">
<!-- 是否肿瘤学阅片 -->
<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"
@ -15,13 +12,11 @@
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" style="position: relative"> <el-form size="small" :inline="true" label-width="110px" 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"
@ -29,10 +24,9 @@
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
@ -41,27 +35,24 @@
:data="list" :data="list"
stripe stripe
> >
<!-- 序号 -->
<el-table-column <el-table-column
prop="" prop=""
:label="$t('dictionary:template:globalConfig:order')" label="序号"
width="80" 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="ValueCN" prop="ValueCN"
:label="$t('dictionary:template:globalConfig:valueCN')" label="中文值"
show-overflow-tooltip show-overflow-tooltip
> >
</el-table-column> </el-table-column>
<!-- 英文值 -->
<el-table-column <el-table-column
prop="Value" prop="Value"
:label="$t('dictionary:template:globalConfig:value')" label="英文值"
show-overflow-tooltip show-overflow-tooltip
> >
</el-table-column> </el-table-column>
@ -69,14 +60,12 @@
<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"
@ -91,17 +80,15 @@
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="$t('dictionary:template:globalConfig:valueCN')" label="中文值"
show-overflow-tooltip show-overflow-tooltip
> >
</el-table-column> </el-table-column>
<!-- 英文值 -->
<el-table-column <el-table-column
prop="Value" prop="Value"
:label="$t('dictionary:template:globalConfig:value')" label="英文值"
show-overflow-tooltip show-overflow-tooltip
> >
</el-table-column> </el-table-column>
@ -109,12 +96,8 @@
</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 :disabled="loading" size="small" type="primary" @click="config.visible = false">取消</el-button>
{{ $t('common:button:cancel') }} <el-button size="small" type="primary" :loading="loading" @click="handleSave"></el-button>
</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>
@ -126,7 +109,7 @@ import { getSystemOncologyInfo, setSystemOncologyInfo, getCriterionDictionary }
export default { export default {
props: { props: {
data: { data: {
type: Object, type: String,
default() { return {} } default() { return {} }
}, },
criterionId: { criterionId: {
@ -146,7 +129,8 @@ export default {
rowData: {}, rowData: {},
activeName: '0', activeName: '0',
addOrEdit: { visible: false, title: '' }, addOrEdit: { visible: false, title: '' },
config: { visible: false, title: this.$t('dictionary:template:oncologyConfig:reviewResult'), appendToBody: true, width: '600px', configType: 0 }, preview: { visible: false, title: 'eCRF预览' },
config: { visible: false, title: '肿瘤学阅片结果', appendToBody: true, width: '600px', configType: 0 },
selectedList: [], selectedList: [],
OncologyAssessType: [], OncologyAssessType: [],
IsOncologyReading: true IsOncologyReading: true
@ -193,10 +177,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.$t('dictionary:template:oncologyConfig:isOncologyReading') this.config.title = '是否肿瘤学阅片'
this.config.visible = true this.config.visible = true
} else { } else {
this.config.title = this.$t('dictionary:template:oncologyConfig:reviewResult') this.config.title = '肿瘤学阅片结果'
this.config.visible = true this.config.visible = true
this.$nextTick(() => { this.$nextTick(() => {
var a = this.OncologyAssessType.filter(v => { var a = this.OncologyAssessType.filter(v => {
@ -237,3 +221,9 @@ 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