CreateFloder.vue 9.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235
  1. <template>
  2. <div>
  3. <div>
  4. <el-dialog v-model="addBoser" title="新建目录" width="30%" @close="diClose">
  5. <el-form :model="boserForm" label-width="120px">
  6. <el-form-item label="目录名称">
  7. <el-input v-model="boserForm.dirName" placeholder="请输入不多于32位字符" maxlength='32' />
  8. </el-form-item>
  9. <!-- <el-form-item label="目录分类">
  10. <el-radio-group v-model="boserForm.dirType">
  11. <el-radio :label="1">公开目录</el-radio>
  12. <el-radio :label="2">组织目录</el-radio>
  13. </el-radio-group>
  14. </el-form-item> -->
  15. <el-form-item label="是否加密" v-if="!(FolderRole && !free )">
  16. <el-switch v-model="boserForm.isEncrypt" active-value="Y" inactive-value="N" />
  17. </el-form-item>
  18. <el-form-item label="加密等级" v-if="!(FolderRole && !free) && boserForm.isEncrypt === 'Y'">
  19. <el-radio-group v-model="boserForm.encryptLevel">
  20. <el-radio :label="item.levelCode" v-for="item in levelList" :key="item">{{item.levelName}}</el-radio>
  21. </el-radio-group>
  22. </el-form-item>
  23. <el-form-item label="私有访问码" v-if="!(FolderRole && !free) && boserForm.isEncrypt === 'Y'&& needCode">
  24. <el-input v-model="boserForm.accessCode" type="password" show-password />
  25. </el-form-item>
  26. </el-form>
  27. <template #footer>
  28. <span class="dialog-footer">
  29. <el-button @click="addBack">取消</el-button>
  30. <el-button type="primary" @click="sureAddBoser">
  31. 确认
  32. </el-button>
  33. </span>
  34. </template>
  35. </el-dialog>
  36. </div>
  37. </div>
  38. </template>
  39. <script>
  40. import { ref, onMounted, toRef,toRaw,inject ,watch } from 'vue';
  41. import documents from '../../../api/document/document';
  42. import { getLevel } from '@/api/level/level.js';
  43. import { ElMessage } from 'element-plus';
  44. import { sm3 ,sm2} from "sm-crypto";
  45. export default {
  46. props: {
  47. folderCase: {
  48. type: Boolean,
  49. required: true
  50. },
  51. oneOrTwo: {
  52. type: Number,
  53. required: true
  54. },
  55. impDirId: {
  56. type: Number,
  57. required: true
  58. },
  59. impSpaceId: {
  60. type: Number,
  61. required: true
  62. },
  63. newDirId: {
  64. type: Number,
  65. required: true
  66. },
  67. newSpaceId: {
  68. type: Number,
  69. required: true
  70. },
  71. thisFolderRole: {
  72. type: Object,
  73. required: true,
  74. default: ()=>{},
  75. },
  76. refreshFile: Function,
  77. },
  78. setup(props, { emit }) {
  79. let { addBack, sureAddBoser, diClose } = toRef(props)
  80. const upFirstFolderData = inject("upFirstFolderData");
  81. let result = props.folderCase
  82. let free = props.oneOrTwo
  83. let spId = props.impSpaceId
  84. let drId = props.impDirId
  85. let newspid = props.newSpaceId
  86. let newdrid = props.newDirId
  87. const FolderRole = props.thisFolderRole
  88. console.log("FolderRole",props);
  89. let addBoser = ref(false)
  90. let boserForm = ref({
  91. dirName: "",
  92. dirType:1,
  93. isEncrypt:"N",
  94. encryptLevel:"L1",
  95. accessCode:''
  96. })
  97. const levelList = ref([])
  98. const needCode = ref(false) // 需要私有码
  99. function inital() {
  100. console.log(free, 'free');
  101. addBoser.value = result
  102. }
  103. function backTo() {
  104. addBoser.value = false
  105. emit("getChildrenC", addBoser.value)
  106. }
  107. function addFloder() {
  108. if (boserForm.value.dirName === '') {
  109. ElMessage({
  110. type: "error",
  111. message: "目录名称不能为空"
  112. })
  113. } else {
  114. if (free === 1) { //一级目录
  115. if (boserForm.value.accessCode === '' && needCode.value) {
  116. ElMessage({
  117. type: "error",
  118. message: "私有访问码不能为空"
  119. })
  120. return
  121. }
  122. documents.addDocument(
  123. {
  124. "dirName": boserForm.value.dirName,
  125. "parentId": drId - 0,
  126. "spaceId": spId - 0,
  127. "isEncrypt":boserForm.value.isEncrypt,
  128. "encryptLevel":boserForm.value.isEncrypt == "Y"?boserForm.value.encryptLevel:null,
  129. "accessCode":boserForm.value.accessCode?sm3(boserForm.value.accessCode):''
  130. }
  131. ).then(res => {
  132. if (res.code === 200) {
  133. ElMessage({
  134. message: '添加一级目录成功',
  135. type: 'success',
  136. })
  137. }
  138. addBoser.value = false
  139. emit("getChildrenC", addBoser.value)
  140. props.refreshFile()
  141. })
  142. console.log('1111', 1111)
  143. } else { //二级目录
  144. let query = {}
  145. if(FolderRole){ // 如果是父级有权限就直接用父级
  146. query={
  147. "dirName": boserForm.value.dirName,
  148. "parentId": newdrid - 0,
  149. "spaceId": newspid - 0,
  150. "isEncrypt":"Y",
  151. "encryptLevel":FolderRole.levelCode,
  152. "accessCode":FolderRole.accessCode
  153. }
  154. console.log('query',query);
  155. console.log('FolderRole',FolderRole);
  156. }else{
  157. if (boserForm.value.accessCode === '' && needCode.value) {
  158. ElMessage({
  159. type: "error",
  160. message: "私有访问码不能为空"
  161. })
  162. return
  163. }
  164. query={
  165. "dirName": boserForm.value.dirName,
  166. "parentId": newdrid - 0,
  167. "spaceId": newspid - 0,
  168. "isEncrypt":boserForm.value.isEncrypt,
  169. "encryptLevel":boserForm.value.isEncrypt == "Y"?boserForm.value.encryptLevel:null,
  170. "accessCode":boserForm.value.accessCode?sm3(boserForm.value.accessCode):''
  171. }
  172. }
  173. documents.addDocument(
  174. query
  175. ).then(res => {
  176. if (res.code === 200) {
  177. ElMessage({
  178. message: '添加成功',
  179. type: 'success',
  180. })
  181. }
  182. addBoser.value = false
  183. emit("getChildrenC", addBoser.value)
  184. props.refreshFile()
  185. })
  186. }
  187. }
  188. }
  189. const getLevelList = async ()=>{
  190. const res = await getLevel()
  191. if(res.rows){
  192. levelList.value = res.rows
  193. }
  194. // console.log('level',res);
  195. }
  196. //监听加密等级
  197. watch(() => boserForm.value.encryptLevel, (newValue, oldValue) => {
  198. const thisRole = levelList.value.find(item=>item.levelCode == newValue)
  199. console.log('thisRole',thisRole);
  200. if(thisRole.roles.l0700){
  201. needCode.value = true
  202. }else{
  203. needCode.value = false
  204. }
  205. }, {
  206. deep: true
  207. });
  208. onMounted(() => {
  209. inital()
  210. getLevelList()
  211. })
  212. return {
  213. addBoser,
  214. boserForm,
  215. inital,
  216. addBack: backTo,
  217. sureAddBoser: addFloder,
  218. diClose: backTo,
  219. spId,
  220. drId,
  221. newdrid,
  222. newspid,
  223. levelList,
  224. getLevelList,
  225. FolderRole,
  226. free,
  227. needCode
  228. }
  229. }
  230. }
  231. </script>
  232. <style lang="scss" scoped></style>