doc_template.vue 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176
  1. <template>
  2. <div class="ele-body" style="height:60vh;overflow: auto;">
  3. <el-card shadow="never" v-loading="loading">
  4. <ele-split-layout
  5. width="210px"
  6. allow-collapse
  7. :right-style="{ overflow: 'hidden' }"
  8. >
  9. <div>
  10. <!-- 操作按钮 -->
  11. <ele-toolbar class="ele-toolbar-actions">
  12. <div style="margin: 5px 0"> </div>
  13. </ele-toolbar>
  14. <div class="ele-border-lighter sys-organization-list" style="height: 65vh">
  15. <el-tree
  16. ref="tree"
  17. :data="data"
  18. highlight-current
  19. :draggable="true"
  20. node-key="id"
  21. :props="{ label: 'name', children: 'sonDirectoryList' }"
  22. :expand-on-click-node="false"
  23. :default-expand-all="true"
  24. @node-click="onNodeClick"
  25. >
  26. <span class="custom-tree-node" slot-scope="{ node, data }">
  27. <ElementTreeLine
  28. :node="node"
  29. :showLabelLine="true"
  30. :indent="20"
  31. >
  32. <img src="../../assets/wjj.png" />
  33. <span>{{ node.label }}</span>
  34. </ElementTreeLine>
  35. </span>
  36. </el-tree>
  37. </div>
  38. </div>
  39. <template v-slot:content>
  40. <FileTableList
  41. ref="tableRef"
  42. :parentData="current"
  43. :disabledTableList="disabledTableList"
  44. />
  45. </template>
  46. </ele-split-layout>
  47. </el-card>
  48. <!-- {{current?.id}} -->
  49. </div>
  50. </template>
  51. <script>
  52. //
  53. import FileTableList from './file-table-listTemplate.vue';
  54. import { getDocTreeListAPI } from './api';
  55. import { mapGetters } from 'vuex';
  56. import ElementTreeLine from 'element-tree-line';
  57. // css
  58. import 'element-tree-line/dist/style.scss';
  59. export default {
  60. components: { FileTableList, ElementTreeLine },
  61. data() {
  62. return {
  63. loading: true,
  64. // 列表数据
  65. data: [],
  66. fileType:0,
  67. // 选中数据
  68. current: {}
  69. };
  70. },
  71. props: {
  72. lcyStatus: '', //1:文档工作区 2:文档归档区 3:文档发布区 4:文档废止区
  73. disabledTableList: {
  74. //已选择列表
  75. default: () => []
  76. }
  77. },
  78. computed: {
  79. ...mapGetters(['user'])
  80. },
  81. created() {
  82. this.query();
  83. },
  84. methods: {
  85. /* 查询 */
  86. async query() {
  87. this.loading = true;
  88. let query = {
  89. type: this.fileType,
  90. currentUserId: this.user.info.userId
  91. };
  92. this.data = await getDocTreeListAPI(query);
  93. this.current = null;
  94. this.$nextTick(() => {
  95. this.$refs.tree.setCurrentKey(this.data[0].id);
  96. this.onNodeClick(this.data[0]);
  97. });
  98. this.loading = false;
  99. },
  100. /* 选择数据 */
  101. onNodeClick(row) {
  102. if (row) {
  103. this.current = row;
  104. this.$nextTick(() => {
  105. this.$refs.tableRef.reload();
  106. });
  107. } else {
  108. this.current = null;
  109. }
  110. },
  111. getTableList() {
  112. return this.$refs.tableRef.getTableList();
  113. }
  114. }
  115. };
  116. </script>
  117. <style lang="scss" scoped>
  118. .sys-organization-list {
  119. height: calc(100vh - 180px);
  120. box-sizing: border-box;
  121. border-width: 1px;
  122. border-style: solid;
  123. overflow: auto;
  124. }
  125. .sys-organization-list :deep(.el-tree-node__content) {
  126. height: 30px;
  127. & > .el-tree-node__expand-icon {
  128. margin-left: 10px;
  129. }
  130. }
  131. .custom-tree-node {
  132. display: flex;
  133. align-items: center;
  134. }
  135. :deep(.el-popover) {
  136. min-width: 50px;
  137. position: fixed;
  138. }
  139. :deep(.el-link--inner) {
  140. padding: 3px 0;
  141. }
  142. // :deep(.element-tree-node-line-hor) {
  143. // border-bottom: 1px solid #dcdfe6;
  144. // }
  145. // :deep(.element-tree-node-line-ver) {
  146. // border-left: 1px solid #dcdfe6;
  147. // }
  148. </style>
  149. <style lang="scss">
  150. .el-tree
  151. > .el-tree-node
  152. > .el-tree-node__content:nth-of-type(1)
  153. .element-tree-node-line-hor {
  154. border: none;
  155. }
  156. .el-tree
  157. > .el-tree-node
  158. > .el-tree-node__content:nth-of-type(1)
  159. .element-tree-node-line-ver {
  160. border: none;
  161. }
  162. </style>