CommonTemplate.vue 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412
  1. <template>
  2. <div class="symptomTagGroupWrapper clearfix">
  3. <div class="bottomPartLeft">
  4. <p class="poolTitle">标签池</p>
  5. <div class="pool">
  6. <el-input
  7. placeholder="请输入搜索内容"
  8. v-model="searchVal"
  9. >
  10. <i
  11. slot="prefix"
  12. class="el-input__icon el-icon-search"
  13. ></i>
  14. </el-input>
  15. <ul class="tagList templateTagList">
  16. <li
  17. v-for="(item, index) in leftTagsList"
  18. class="tagItem"
  19. :key='item.id'
  20. :title="'[ '+item.tagName+' ]'"
  21. :style="getStyle(item)?styles:null"
  22. @click='selectLeftTag(item, index, $event)'
  23. >
  24. <p class="tagName ellipsis">{{item.tagName}} </p>
  25. </li>
  26. </ul>
  27. </div>
  28. </div>
  29. <div class="bottomPartMid fl">
  30. <p><span
  31. class="el-icon-arrow-right"
  32. @click="toRightList"
  33. ></span></p>
  34. <p><span
  35. class="el-icon-arrow-left"
  36. @click="toLeftList"
  37. ></span></p>
  38. </div>
  39. <div class="bottomPartRight bottomPartRightTemplate">
  40. <p class="poolTitle">模板内容:</p>
  41. <el-form
  42. class="subTemplate"
  43. ref="groups"
  44. :model="form"
  45. >
  46. <el-form-item
  47. label="选择归属:"
  48. prop="region"
  49. size="mini"
  50. >
  51. <el-select
  52. v-model="form.region"
  53. placeholder="请选择模板归属"
  54. >
  55. <el-option
  56. v-for="item in Adscriptions"
  57. :label="item.name"
  58. :value="item.val"
  59. :key="item.id"
  60. ></el-option>
  61. </el-select>
  62. <el-button size="mini">添加</el-button>
  63. <el-button size="mini">删除子模板</el-button>
  64. <el-button size="mini">插入输入栏</el-button>
  65. <el-button icon="el-icon-arrow-left" class="changeOrder changeOrderPub"></el-button>
  66. <el-button icon="el-icon-arrow-right" class="changeOrderPub"></el-button>
  67. </el-form-item>
  68. </el-form>
  69. <ul class="tagList operationPool templateTagLists">
  70. <li
  71. class="tagItem operationItem"
  72. v-for="(item) in rightTagsList2"
  73. :key='item.id'
  74. :style="getStyle2(item)?styles:null"
  75. @click='selectRightTag(item)'
  76. >
  77. <div class="inputBox">
  78. <el-input
  79. v-if="item.type === 'input'"
  80. placeholder=""
  81. v-model="item.text"
  82. >
  83. </el-input>
  84. </div>
  85. <p
  86. v-if="item.tagName"
  87. class="tagName ellipsis"
  88. :title="'[ '+item.tagName+' ]'"
  89. >{{item.tagName}} </p>
  90. </li>
  91. </ul>
  92. </div>
  93. </div>
  94. </template>
  95. <script>
  96. import api from '@api/icss.js';
  97. import utils from '@api/utils.js';
  98. export default {
  99. props: {
  100. pool: {
  101. default: () => [],
  102. type: Array
  103. },
  104. type: {
  105. default: '',
  106. type: String
  107. },
  108. sexType: {
  109. default: '',
  110. type: String
  111. },
  112. options: {
  113. default: () => [],
  114. type: Array
  115. },
  116. },
  117. data() {
  118. return {
  119. Adscriptions: [
  120. { name: '添加病情变化', val: '1', id: '001' },
  121. { name: '病程变化', val: '2', id: '002' },
  122. { name: '添加其他症状', val: '3', id: '003' },
  123. ],
  124. form: {
  125. region: '1', //归属
  126. },
  127. leftTagsList: [],
  128. selectLeftTagsList: [],
  129. rightTagsList: [],
  130. rightTagsList2: [],
  131. selectRightTagsList: [],
  132. searchVal: '',
  133. styles: {
  134. background: '#eae7e7'
  135. },
  136. }
  137. },
  138. mounted() {
  139. this.rightTagsList2 = this.options
  140. let newArr = []
  141. for (let i = 0; i < this.rightTagsList2.length; i++) {
  142. if (this.rightTagsList2[i].tagType == 8) {
  143. newArr.push({ text: this.rightTagsList2[i].tagName, type: 'input', id: i + ',,,' })
  144. } else {
  145. if (i === 0) {
  146. newArr.push({ text: '', type: 'input', id: i + ',,,' })
  147. }
  148. newArr.push(this.rightTagsList2[i])
  149. if (!this.rightTagsList2[i + 1] || this.rightTagsList2[i + 1] && this.rightTagsList2[i + 1].tagType != 8) {
  150. newArr.push({ text: '', type: 'input', id: i + ',,,,' })
  151. }
  152. }
  153. }
  154. this.rightTagsList2 = newArr
  155. this.$emit('changeActionData', this.rightTagsList2, false);
  156. this.searchTagList()
  157. // this.leftTagsList = this.pool
  158. // console.log('TAGPOOL', this.pool)
  159. },
  160. watch: {
  161. pool(newVal, preVal) {
  162. this.leftTagsList = newVal
  163. },
  164. searchVal(newVal, preVal) {
  165. if (newVal.trim() == '') {
  166. this.searchTagList()
  167. } else if (newVal.trim() != preVal.trim()) {
  168. this.searchTagList()
  169. }
  170. },
  171. },
  172. methods: {
  173. selectLeftTag(tag, index, e) {
  174. const hasTag = this.isHasTag(tag, this.selectLeftTagsList)
  175. if (hasTag) {
  176. this.selectLeftTagsList = this.selectLeftTagsList.filter(item => item.id !== tag.id)
  177. } else {
  178. this.selectLeftTagsList.push(tag);
  179. }
  180. },
  181. selectRightTag(tag) {
  182. const hasTag = this.isHasTag(tag, this.selectRightTagsList)
  183. if (hasTag) {
  184. this.selectRightTagsList = this.selectRightTagsList.filter(item => item.id !== tag.id)
  185. } else {
  186. this.selectRightTagsList.push(tag);
  187. }
  188. },
  189. isHasTag(item, arr) {
  190. for (let i = 0; i < arr.length; i++) {
  191. if (arr[i].id === item.id) {
  192. return true;
  193. }
  194. }
  195. return false;
  196. },
  197. getStyle(item) { //左侧选中状态
  198. return this.isHasTag(item, this.selectLeftTagsList)
  199. },
  200. getStyle2(item) {
  201. return this.isHasTag(item, this.selectRightTagsList)
  202. },
  203. toLeftList() {
  204. for (let i = 0; i < this.selectRightTagsList.length; i++) {
  205. this.rightTagsList = this.rightTagsList.filter(item => item.id !== this.selectRightTagsList[i].id)
  206. }
  207. for (let i = 0; i < this.selectRightTagsList.length; i++) {//每次往回移时同时删掉下面输入框
  208. if (this.selectRightTagsList[i].type !== 'input') {
  209. for (let j = 0; j < this.rightTagsList2.length; j++) {
  210. if (this.selectRightTagsList[i].id === this.rightTagsList2[j].id) {
  211. if (this.rightTagsList2.length === 3) {
  212. this.rightTagsList2 = []
  213. } else {
  214. this.rightTagsList2.splice(j, 2)
  215. }
  216. }
  217. }
  218. }
  219. }
  220. this.selectLeftTagsList = []
  221. this.selectRightTagsList = []
  222. this.searchTagList()
  223. this.$emit('changeActionData', this.rightTagsList2, false);
  224. },
  225. toRightList() {
  226. this.rightTagsList.push(...this.selectLeftTagsList);
  227. let textItem = { text: '', type: 'input' }
  228. for (let i = 0; i < this.selectLeftTagsList.length; i++) { //选中标签每个前后加入输入框
  229. if (this.rightTagsList2.length === 0) {
  230. let textItem1 = JSON.parse(JSON.stringify(textItem))
  231. textItem1.id = this.selectLeftTagsList[i].id + ',,'
  232. this.rightTagsList2.push(textItem1)
  233. }
  234. this.rightTagsList2.push(this.selectLeftTagsList[i]);
  235. let textItem2 = JSON.parse(JSON.stringify(textItem))
  236. textItem2.id = this.selectLeftTagsList[i].id + ','
  237. this.rightTagsList2.push(JSON.parse(JSON.stringify(textItem2)))
  238. }
  239. for (let i = 0; i < this.rightTagsList.length; i++) {
  240. this.leftTagsList = this.leftTagsList.filter(item => item.id !== this.rightTagsList[i].id)
  241. }
  242. this.selectLeftTagsList = []
  243. this.selectRightTagsList = []
  244. this.$emit('changeActionData', this.rightTagsList2, false);
  245. },
  246. searchTagList() {
  247. let notIds = []
  248. for (let i = 0; i < this.rightTagsList.length; i++) {
  249. if (typeof this.rightTagsList2[i].id === 'number') {
  250. notIds.push(this.rightTagsList2[i].id)
  251. }
  252. }
  253. let param = {
  254. "tagName": this.searchVal,
  255. "type": this.type || '',
  256. "notIds": notIds,
  257. }
  258. api.searchTagList(param).then((res) => {
  259. if (res.data.code === '0') {
  260. this.leftTagsList = res.data.data
  261. this.selectLeftTagsList = []
  262. this.selectRightTagsList = []
  263. }
  264. })
  265. }
  266. }
  267. }
  268. </script>
  269. <style lang="less" scoped>
  270. @import "../../less/common.less";
  271. .symptomTagGroupWrapper {
  272. .bottomPartLeft {
  273. width: 30%;
  274. box-sizing: border-box;
  275. float: left;
  276. }
  277. .poolTitle {
  278. box-sizing: border-box;
  279. margin-bottom: 20px;
  280. }
  281. .inputBox {
  282. width: 100px;
  283. }
  284. .search {
  285. width: 100%;
  286. border-bottom: 1px solid @icssBorder;
  287. box-sizing: border-box;
  288. height: 30px;
  289. }
  290. .tagList {
  291. overflow-y: auto;
  292. border: 1px solid @icssBorder;
  293. }
  294. .tagItem {
  295. line-height: 30px;
  296. padding: 0px 10px;
  297. box-sizing: border-box;
  298. }
  299. .operationPool {
  300. position: relative;
  301. width: 85%;
  302. padding: 10px;
  303. box-sizing: border-box;
  304. }
  305. .tagName {
  306. line-height: 30px;
  307. }
  308. .tagName:before {
  309. content: "[";
  310. }
  311. .tagName::after {
  312. content: "]";
  313. }
  314. .bottomPartMid {
  315. width: 8%;
  316. margin-top: 60px;
  317. p {
  318. width: 100%;
  319. text-align: center;
  320. span {
  321. cursor: pointer;
  322. display: inline-block;
  323. width: 30px;
  324. height: 40px;
  325. line-height: 40px;
  326. margin: 0 auto;
  327. border: 1px solid @icssBorder;
  328. margin-bottom: 15px;
  329. font-size: 18px;
  330. }
  331. }
  332. }
  333. .bottomPartRight {
  334. float: left;
  335. width: 60%;
  336. .changeOrder {
  337. margin-left: 20px;
  338. }
  339. }
  340. .templateTagList {
  341. height: 450px;
  342. }
  343. .templateTagLists {
  344. height: 468px;
  345. width: 98%;
  346. }
  347. button {
  348. // margin-top: 20px;
  349. }
  350. .operationItem {
  351. display: inline-block;
  352. line-height: 40px;
  353. margin: 0 5px 10px 0;
  354. text-align: center;
  355. float: left;
  356. p {
  357. padding: 5px 0;
  358. }
  359. }
  360. .active {
  361. color: #abcdef;
  362. }
  363. }
  364. </style>
  365. <style lang="less">
  366. @import "../../less/common.less";
  367. .bottomPartRightTemplate {
  368. .subTemplate {
  369. // display: inline-block;
  370. }
  371. .el-form-item__content {
  372. .el-input__inner {
  373. height: 30px;
  374. line-height:30px;
  375. border-radius:5px;
  376. font-size: 14px;
  377. }
  378. .el-select {
  379. margin-right:10px;
  380. }
  381. .el-button--mini[data-v-2db8be7a], .el-button--mini.is-round[data-v-2db8be7a] {
  382. padding: 5px 8px 4px;
  383. }
  384. .el-button--mini[data-v-2db8be7a].changeOrderPub, .el-button--mini.is-round[data-v-2db8be7a].changeOrderPub {
  385. padding: 5px 12px;
  386. }
  387. .el-button:hover {
  388. color: @adminBase;
  389. border-color: @adminBase;
  390. outline: 0;
  391. opacity: 1;
  392. background-color: #fff;
  393. }
  394. .el-button:active {
  395. color: @adminBase;
  396. border-color: @adminBase;
  397. outline: 0;
  398. }
  399. .el-button:focus {
  400. background-color: #fff;
  401. color: @adminBase;
  402. opacity: 1;
  403. }
  404. }
  405. }
  406. </style>