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'
NODE_ENV = 'prop'
# base public path
VUE_APP_BASE_PATH = '/'
# 是否开启登陆限制 true:是 false:否
VUE_APP_LOGIN_FOR_PERMISSION = true

View File

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

View File

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

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

File diff suppressed because one or more lines are too long

View File

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

View File

@ -342,11 +342,3 @@ export function addNewUserSendEmail(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
})
}
// 文件记录-系统文件列表
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'
})
}
export function setNodicomStudyState(params) {
return request({
url: `/QCOperation/setNodicomStudyState`,
method: 'put',
params
})
}
export function setInstanceStatus(trialId, subjectVisitId, seriesId, instanceId, state) {
return request({
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({
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'
})
}
@ -3946,6 +3940,8 @@ export function updateTrialUserRole(data) {
})
}
// 获取报表配置
export function getTrialQuestionExportResult(data) {
return request({
@ -3970,28 +3966,3 @@ export function trialUserSendJoinEmail(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
})
}
// 修改检查名称列表
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">
<div class="box">
<div class="box-body">
<slot name="title-container" />
<div class="search">
<slot name="search-container" />
</div>
@ -25,35 +24,35 @@ export default {
props: {
noTitle: {
type: Boolean,
default: false,
},
default: false
}
},
computed: {
contentClass() {
return this.noTitle ? 'content-notitle' : 'content'
},
},
}
}
}
</script>
<style lang="scss">
.box-body {
.box-body{
padding: 0px;
background-color: #fff;
.el-card__body {
padding: 0px;
}
.search {
.search{
display: flex;
padding: 5px;
.mr5 {
margin-right: 5px;
.mr5{
margin-right:5px;
}
.el-form-item {
.el-form-item{
margin-bottom: 10px;
}
}
.page {
.page{
text-align: right;
padding-top: 3px;
}
@ -62,5 +61,5 @@ export default {
font-weight: bold;
font-size: 14px;
}
}
}
</style>

View File

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

View File

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

View File

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

View File

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

View File

@ -193,7 +193,7 @@
</el-col>
<!-- eslint-disable vue/no-use-v-if-with-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
:key="item.Id"
:question="item"
@ -593,7 +593,7 @@ export default {
<style lang="scss" scoped>
.my_dialog{
.criterion-form-item{
::v-deep .el-form-item__content{
>>>.el-form-item__content{
width: auto;
}
}
@ -614,7 +614,7 @@ export default {
margin-bottom: 0px;
}
.disabled{
::v-deep .el-upload--picture-card {
>>>.el-upload--picture-card {
display: none;
}
}

View File

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

View File

@ -92,7 +92,6 @@ export default {
try {
if (!this.form.userRoleId)
return this.$message.warning(this.$t('toggleRole:ruleMessage:select'))
zzSessionStorage.removeItem('lastWorkbench')
this.$emit('save', this.form.userRoleId)
} catch (err) {
console.log(err)
@ -112,11 +111,11 @@ export default {
margin: auto;
}
::v-deep .el-radio__original {
/deep/ .el-radio__original {
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 {
box-shadow: none !important;
}

View File

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

View File

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

View File

@ -567,7 +567,7 @@ export default {
for (let i = 0; i < arr.length; i++) {
let dicom = arr[i];
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]) {
studyObj[dicom.StudyId] = {
StudyId: dicom.StudyId,

View File

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

View File

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

View File

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

View File

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

View File

@ -7,15 +7,15 @@ import 'nprogress/nprogress.css'
import { getToken, removeToken } from '@/utils/auth'
import Vue from 'vue'
import { OSSclient } from './utils/oss'
import WHITELIST from './utils/whiteList'
import WHITELIST from "./utils/whiteList"
import { getTrialExtralConfig } from '@/api/trials'
// import getPageTitle from '@/utils/get-page-title'
NProgress.configure({ showSpinner: false })
const whiteList = WHITELIST
store.state.trials.whiteList = whiteList
router.beforeEach(async(to, from, next) => {
store.state.trials.whiteList = whiteList;
router.beforeEach(async (to, from, next) => {
NProgress.start()
// 设置页面标题
// 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 !==
store.state.trials.config.trialId
) {
const res = await getTrialExtralConfig({
TrialId: to.query.trialId
let res = await getTrialExtralConfig({
TrialId: to.query.trialId,
})
if (res.IsSuccess) {
store.dispatch('trials/setConfig', {
trialId: to.query.trialId,
...res.Result
...res.Result,
})
}
}
@ -45,13 +45,13 @@ router.beforeEach(async(to, from, next) => {
to.query.trialId !==
store.state.trials.config.trialId
) {
const res = await getTrialExtralConfig({
TrialId: to.query.trialId
let res = await getTrialExtralConfig({
TrialId: to.query.trialId,
})
if (res.IsSuccess) {
store.dispatch('trials/setConfig', {
trialId: to.query.trialId,
...res.Result
...res.Result,
})
}
}
@ -72,12 +72,12 @@ router.beforeEach(async(to, from, next) => {
NProgress.done()
} else if (from.path === '/researchForm') {
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}`)
NProgress.done()
} else if (from.path === '/researchDetail_m') {
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}`)
NProgress.done()
} else {
@ -107,7 +107,7 @@ router.beforeEach(async(to, from, next) => {
/* has no token*/
if (whiteList.indexOf(to.path) !== -1) {
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)
if (flag) {
next(`/researchLogin_m?trialId=${to.query.trialId}&lang=${lang}`)
@ -123,11 +123,11 @@ router.beforeEach(async(to, from, next) => {
}
} else {
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}`)
NProgress.done()
} 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}`)
NProgress.done()
} else if (to.path === '/ReviewersResearchForm') {

View File

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

View File

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

View File

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

View File

@ -12,7 +12,7 @@ import trials from './modules/trials'
import financials from './modules/financials'
import reading from './modules/reading'
import lang from './modules/lang'
import noneDicomReview from './modules/noneDicomReview'
Vue.use(Vuex)
const store = new Vuex.Store({
@ -27,8 +27,7 @@ const store = new Vuex.Store({
trials,
financials,
reading,
lang,
noneDicomReview
lang
},
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 = {}
data.StudyId = study.StudyId
data.StudyCode = study.StudyCode
data.StudyName = study.StudyName
data.Modalities = study.Modalities
data.SeriesCount = study.SeriesCount
data.InstanceCount = study.InstanceCount

View File

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

View File

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

View File

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

View File

@ -34,7 +34,7 @@ export function parseTime(time, cFormat) {
const time_str = format.replace(/{([ymdhisa])+}/g, (result, key) => {
const value = formatObj[key]
// Note: getDay() returns 0 on Sunday
if (key === 'a') { return ['日', '一', '二', '三', '四', '五', '六'][value] }
if (key === 'a') { return ['日', '一', '二', '三', '四', '五', '六'][value ] }
return value.toString().padStart(2, '0')
})
return time_str
@ -60,35 +60,3 @@ export function param2Obj(url) {
)
}
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;
unit = "MB/s";
}
store.state.trials.uploadTip = totalBytes.toFixed(3) + unit;
store.state.trials.uploadTip = totalBytes.toFixed(2) + unit;
}
if (timeList.length >= 5) {
delete bytesReceivedPerSecond[timeList[0]]

View File

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

View File

@ -41,13 +41,7 @@ async function ossGenerateSTS() {
let _vm = router.default.app
if (_vm._route.path !== '/trials/trials-panel/visit/crc-upload') {
var objectItem = objectName.split('/')
// 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()}`
objectItem[objectItem.length - 1] = new Date().getTime() + '_' + objectItem[objectItem.length - 1]
objectName = objectItem.join('/')
}
let res = await OSSclient.put(objectName, object)
@ -84,13 +78,7 @@ async function ossGenerateSTS() {
let _vm = router.default.app
if (_vm._route.path !== '/trials/trials-panel/visit/crc-upload') {
var objectItem = data.path.split('/')
// 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()}`
objectItem[objectItem.length - 1] = new Date().getTime() + '_' + objectItem[objectItem.length - 1]
data.path = objectItem.join('/')
}
let res = await customerHttp(OSSclient, data, progress);
@ -197,13 +185,7 @@ function uploadAWS(aws, data, progress) {
let _vm = router.default.app
if (_vm._route.path !== '/trials/trials-panel/visit/crc-upload') {
var objectItem = data.path.split('/')
// 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()}`
objectItem[objectItem.length - 1] = new Date().getTime() + '_' + objectItem[objectItem.length - 1]
data.path = objectItem.join('/')
}
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) => {
cornerstone.loadImage(imageId).then(async (image) => {
let canvas = document.createElement("canvas");
canvas.width = (width * 60) / height
canvas.height = 60
canvas.width = width;
canvas.height = height;
if (image) {
cornerstone.renderToCanvas(canvas, image);
// 将 Canvas 图像对象转换为 PNG 格式

View File

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

View File

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

View File

@ -17,7 +17,7 @@
</el-form-item>
<el-form-item label="是否内部角色: " prop="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-form-item>

View File

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

View File

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

View File

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

View File

@ -9,10 +9,10 @@
class="upload-temporary-file"
>
<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-form-item>
<el-form-item :label="$t('dictionary:attachment:label:businessScenario')" prop="BusinessScenarioEnum">
<el-form-item label="业务场景: " prop="BusinessScenarioEnum">
<el-select
v-model="form.BusinessScenarioEnum"
style="width:100%;"
@ -28,7 +28,7 @@
</el-select>
</el-form-item>
<el-form-item :label="$t('dictionary:attachment:export:form:file')">
<el-form-item label="文件: ">
<div class="upload-container">
<el-upload
class="upload-demo"
@ -60,7 +60,7 @@
</el-form-item>
<el-form-item v-if="form.Id !== ''" label="是否废除: ">
<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-form-item>
<el-form-item label="描述">

View File

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

View File

@ -78,7 +78,7 @@
<el-form-item v-if="form.Id !== ''" label="是否废除: ">
<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-form-item>
<el-form-item label="描述">

View File

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

View File

@ -9,7 +9,7 @@
class="upload-temporary-file"
>
<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-form-item>
<el-form-item
@ -76,9 +76,8 @@
:label="$t('dictionary:attachment:export: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 :label="true"></el-radio>
<el-radio :label="false"></el-radio>
</el-radio-group>
</el-form-item>
<el-form-item

View File

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

View File

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

View File

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

View File

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

View File

@ -2,13 +2,13 @@
<div class="app-container my_menu" >
<el-form :inline="true">
<el-form-item label="模块">
<el-select v-model="queryParams.ModuleTypeId" placeholder="模块" clearable >
<el-option v-for="item of dict.type.ModuleType" :key="`ModuleTypeId${item.value}`" :value="item.value" :label="item.raw.ValueCN" />
<el-select v-model="queryParams.ModuleTypeId" placeholder="模块" clearable size="small">
<el-option v-for="item of dict.type.ModuleType" :value="item.value" :label="item.raw.ValueCN" />
</el-select>
</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-plus" @click="handleAdd"></el-button>
<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>
@ -66,30 +66,42 @@
<template slot-scope="scope">
<el-button
v-if="scope.row.ModuleTypeValueCN && scope.row.ObjectTypeValueCN && scope.row.OptTypeValueCN && scope.row.ChildrenTypeValueCN "
size="mini"
type="text"
icon="el-icon-top"
@click="handleUpMove(scope.row)"
>上移</el-button>
<el-button
size="mini"
type="text"
icon="el-icon-edit"
@click="handleUpdate(scope.row)"
>修改</el-button>
<el-button
v-if="!(scope.row.ModuleTypeValueCN && scope.row.ObjectTypeValueCN && scope.row.OptTypeValueCN && scope.row.ChildrenTypeValueCN)"
size="mini"
type="text"
icon="el-icon-plus"
@click="handleAdd(scope.row)"
>新增</el-button>
<el-button
v-if="scope.row.ModuleTypeValueCN && scope.row.ObjectTypeValueCN && scope.row.OptTypeValueCN && scope.row.ChildrenTypeValueCN "
size="mini"
type="text"
icon="el-icon-plus"
@click="handleChildren(scope.row)"
>Children</el-button>
<el-button
v-if="scope.row.ModuleTypeValueCN && scope.row.ObjectTypeValueCN && scope.row.OptTypeValueCN && scope.row.ChildrenTypeValueCN "
size="mini"
type="text"
icon="el-icon-plus"
@click="handleCopy(scope.row)"
>复制到</el-button>
<el-button
size="mini"
type="text"
icon="el-icon-delete"
@click="handleDelete(scope.row)"
>删除</el-button>
</template>
@ -157,28 +169,28 @@
<el-col v-show="form.ConfigType === 'M' && title !== '复制'" :span="12">
<el-form-item label="功能模块" prop="menuType">
<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-form-item>
</el-col>
<el-col v-show="form.ConfigType === 'M' && title !== '复制'" :span="12">
<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" :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-form-item>
</el-col>
<el-col v-show="form.ConfigType === 'M' && title !== '复制'" :span="12">
<el-form-item label="对象类型" prop="menuType">
<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-form-item>
</el-col>
<el-col v-show="form.ConfigType === 'M' && title !== '复制'" :span="12">
<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" :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-form-item>
</el-col>
@ -283,7 +295,7 @@
</el-button>
</el-col>
</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-form-item>
<span slot="label">
@ -659,11 +671,11 @@
<div style="padding: 0 40px;display: flex;flex-direction: column">
<div style="text-align: right;height: 50px;">
<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-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-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-button type="primary" size="mini" @click="handleCope(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>
<box-content>
<div class="search">
<el-form :inline="true" class="base-search-form">
<!-- CRO Name -->
<el-form-item :label="$t('institutions:cros:label:croName')">
<el-form :inline="true" size="small" class="base-search-form">
<el-form-item label="CRO Name:">
<el-input v-model="searchData.CROName" style="width: 100px" />
</el-form-item>
<el-form-item>
<el-button type="primary" icon="el-icon-search" @click="handleSearch">
{{ $t('common:button:search') }}
</el-button>
<el-button type="primary" icon="el-icon-search" @click="handleSearch"
>Search</el-button
>
<el-button
type="primary"
icon="el-icon-refresh-left"
@click="handleReset"
>Reset</el-button
>
{{ $t('common:button:reset') }}
</el-button>
</el-form-item>
</el-form>
<span style="margin-left: auto">
<el-button
size="small"
type="primary"
style="margin-left: auto"
icon="el-icon-plus"
@click="handleAddCro"
>{{ $t('common:button:new') }}</el-button
>New</el-button
>
</span>
</div>
@ -36,34 +37,30 @@
@sort-change="handleSortByColumn"
>
<el-table-column type="index" width="40" />
<!-- CRO Code -->
<el-table-column
prop="CROCode"
:label="$t('institutions:cros:label:croCode')"
label="CRO Code"
min-width="150"
show-overflow-tooltip
sortable="custom"
/>
<!-- CRO Name -->
<el-table-column
prop="CROName"
:label="$t('institutions:cros:label:croName')"
label="CRO Name"
min-width="150"
show-overflow-tooltip
sortable="custom"
/>
<!-- CRO NameCN -->
<el-table-column
prop="CRONameCN"
:label="$t('institutions:cros:label:croNameCN')"
label="CRO NameCN"
min-width="150"
show-overflow-tooltip
sortable="custom"
/>
<!-- Level -->
<el-table-column
prop="IsTrialLevel"
:label="$t('institutions:cros:label:level')"
label="Level"
show-overflow-tooltip
sortable="custom"
>
@ -71,20 +68,20 @@
<span>{{ $fd("IsTrialLevel", String(scope.row.IsTrialLevel)) }}</span>
</template>
</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">
<el-button
type="text"
circle
icon="el-icon-edit-outline"
title="编辑"
@click="handleEdit(scope.row)"
>
{{ $t('common:button:edit') }}
</el-button>
/>
<el-button
type="text"
circle
icon="el-icon-delete"
title="删除"
@click="handleDelete(scope.row)"
>
{{ $t('common:button:delete') }}
</el-button>
/>
</template>
</el-table-column>
</el-table>
@ -163,13 +160,13 @@ export default {
// CRO
handleAddCro() {
this.rowData = {};
this.title =this.$t('common:button:new');
this.title = "Add";
this.editVisible = true;
},
// CRO
handleEdit(row) {
this.rowData = row;
this.title = this.$t('common:action:edit');
this.title = "Edit";
this.editVisible = true;
},
// CRO

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

@ -3,19 +3,18 @@
ref="organForm"
v-loading="loading"
:model="form"
label-width="170px"
label-width="130px"
size="small"
:rules="rules"
>
<div class="base-dialog-body">
<!-- 标准名称 -->
<el-form-item :label="$t('trials:auditRecord:table:criterion')" prop="CriterionName">
<el-form-item label="标准名称" prop="CriterionName">
<el-input
v-model="form.CriterionName"
/>
</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-option
v-for="item of $d.CriterionType"
@ -25,8 +24,7 @@
/>
</el-select>
</el-form-item>
<!-- 标准分组 -->
<el-form-item :label="$t('dictionary:template:criterionConfig:table:criterionGroup')" prop="CriterionGroup">
<el-form-item label="标准分组" prop="CriterionGroup">
<el-select v-model="form.CriterionGroup">
<el-option
v-for="item of $d.CriterionGroup"
@ -36,26 +34,23 @@
/>
</el-select>
</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-form-item>
<!-- 描述 -->
<el-form-item :label="$t('dictionary:template:criterionConfig:table:description')">
<el-form-item label="描述">
<el-input
v-model="form.Description"
/>
</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-form-item>
<!-- 是否启用 -->
<el-form-item v-if="form.Id !== ''" :label="$t('dictionary:template:criterionConfig:table:isEnable')">
<el-form-item v-if="form.Id !== ''" label="是否启用">
<el-switch v-model="form.IsEnable" />
</el-form-item>
<!-- eICRF仅展示阅片Tab -->
<el-form-item v-if="form.Id !== ''" :label="$t('dictionary:template:criterionConfig:table:isECRFShowInDicomReading')">
<el-form-item v-if="form.Id !== ''" label="eICRF仅展示阅片Tab">
<el-switch v-model="form.IseCRFShowInDicomReading" />
</el-form-item>
</div>

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

@ -25,7 +25,7 @@
:prop="question.Id"
:rules="[
{ 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':'']"
>
@ -396,7 +396,7 @@ export default {
flex-direction: row;
align-items: flex-start;
}
::v-deep .el-form-item__content{
/deep/ .el-form-item__content{
width: 500px;
}
.el-input{
@ -406,7 +406,7 @@ export default {
margin-bottom: 0px;
}
.disabled{
::v-deep .el-upload--picture-card {
/deep/ .el-upload--picture-card {
display: none;
}
}

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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