MyFile.vue 135 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930293129322933293429352936293729382939294029412942294329442945294629472948294929502951295229532954295529562957295829592960296129622963296429652966296729682969297029712972297329742975297629772978297929802981298229832984298529862987298829892990299129922993299429952996299729982999300030013002300330043005300630073008300930103011301230133014301530163017301830193020302130223023302430253026302730283029303030313032303330343035303630373038303930403041304230433044304530463047304830493050305130523053305430553056305730583059306030613062306330643065306630673068306930703071307230733074307530763077307830793080308130823083308430853086308730883089309030913092309330943095309630973098309931003101310231033104310531063107310831093110311131123113311431153116311731183119312031213122312331243125312631273128312931303131313231333134313531363137313831393140314131423143314431453146314731483149315031513152315331543155315631573158315931603161316231633164316531663167316831693170317131723173317431753176317731783179318031813182318331843185318631873188318931903191319231933194319531963197319831993200320132023203320432053206320732083209321032113212321332143215321632173218321932203221322232233224322532263227322832293230323132323233323432353236323732383239324032413242324332443245324632473248324932503251325232533254325532563257325832593260326132623263326432653266326732683269327032713272327332743275327632773278
  1. <template>
  2. <div>
  3. <div class="bigBox">
  4. <div class="settingBox" @click="mouseClick">
  5. <!-- 设置盒子顶部搜索 -->
  6. <div class="topSearch">
  7. <div class="spaceName">{{spaceName}}</div>
  8. <div>
  9. <el-icon v-hasRole="['dept']" @click="createNewMenu(1, true)" color="#505870" size="24">
  10. <Plus />
  11. </el-icon>
  12. <!-- @click="createNewFile" -->
  13. </div>
  14. </div>
  15. <!-- 方块点击盒子 -->
  16. <div
  17. style="height: 83vh;overflow-y: auto;">
  18. <div class="searchBox">
  19. <div v-if="leftShowList === 2" style="width:100%">
  20. <el-input v-model="searchFire" @keyup.enter="fileBlur" @input="fileBlur" class="searchFire" size="large"
  21. placeholder="搜索文件夹" />
  22. <el-icon class="SearchIcon" @click="fileBlur">
  23. <Search />
  24. </el-icon>
  25. </div>
  26. <div v-else style="width:100%">
  27. <el-input v-model="searchFolderTree" @keyup.enter="folderBlur" class="searchFire" size="large"
  28. placeholder="搜索文件夹" />
  29. <el-icon class="SearchIcon" @click="folderBlur">
  30. <Search />
  31. </el-icon>
  32. </div>
  33. <div class="left_changeShow">
  34. <img v-if="leftShowList === 2" src="@/assets/images/squre.png" alt="">
  35. <img v-else src="@/assets/images/Frame_187.png" alt="">
  36. </div>
  37. </div>
  38. <!-- v-for盒子 -->
  39. <div v-if="false" style="display: flex;justify-content: flex-start;align-items: flex-start;flex-wrap: wrap;align-content: flex-start;overflow-y: auto;">
  40. <template v-for="(item, index) in fileMenu" :key="index">
  41. <div class="setBox" >
  42. <el-dropdown trigger="click" class="selectChe">
  43. <span class="el-dropdown-link">
  44. ...
  45. </span>
  46. <template #dropdown>
  47. <el-dropdown-menu>
  48. <el-dropdown-item @click="restName(item, index)">重命名</el-dropdown-item>
  49. <el-dropdown-item v-if="item.dirType == '2' && isDept" @click="upFirstFoler(item)">编辑</el-dropdown-item>
  50. <el-dropdown-item v-if="isDept" @click="delName(item, index)">删除</el-dropdown-item>
  51. </el-dropdown-menu>
  52. </template>
  53. </el-dropdown>
  54. <div class="left_fileBox" @click="changeFile(item, index)">
  55. <el-tooltip
  56. class="box-item tool-tip"
  57. effect="dark"
  58. placement="top-start"
  59. v-if="item.encryptLevel"
  60. >
  61. <template #content> 安全级别: {{ item.encryptLevel == 'L1'?'敏感':(item.encryptLevel == 'L2'?'涉密':(item.encryptLevel == 'L3'?'机密':'绝密')) }} </template>
  62. <img :src="item.dirType=='1'?fileStyle:ordinaryList" style="width: 72px;height: 72px;" class="shouzhi">
  63. </el-tooltip>
  64. <img :src="item.dirType=='1'?fileStyle:ordinaryList" class="shouzhi" style="width: 72px;height: 72px;" v-else>
  65. <el-tooltip
  66. class="box-item tool-tip"
  67. effect="dark"
  68. placement="top-start"
  69. > <template #content> <span>{{ item.dirName }}</span></template>
  70. <p class="ellipsis-text shouzhi">{{ item.dirName }}</p>
  71. </el-tooltip>
  72. <img class="levelImg shouzhi" v-if="item.isEncrypt === 'Y' && item.encryptLevel" :src="getLevelImg(item.encryptLevel)" alt="">
  73. </div>
  74. </div>
  75. </template>
  76. </div>
  77. <LeftList v-else :spaceType="2" :collectId="collectId" :isDept="isDept" @treeRClick="treeRClick" :searchFolderTree="searchFolderTree" :ListtreeData="ListtreeData" @listfolderClick="listfolderClick"></LeftList>
  78. </div>
  79. <div class="expansion">
  80. <div class="top_box">
  81. <span style="margin-left: 5px;font-size: 14px;font-weight: 800;">{{ formatStorage(useSpace) }}/{{ allSpace + "G" }}({{percent()}}%)</span>
  82. <span style="margin-left: 5px;font-size: 14px;color: #2E6BC8;cursor: pointer;"
  83. @click="askApply">扩容申请</span>
  84. </div>
  85. <el-progress style="margin-left: 8px;margin-top: 8px;width:100%" :stroke-width="18" color='#2E6BC8' :text-inside="true" :percentage="percent()">
  86. <span style="width:0"></span>
  87. </el-progress>
  88. </div>
  89. </div>
  90. <!-- 右侧大盒子 -->
  91. <div class="mesBox">
  92. <!-- 展示文件夹盒子 -->
  93. <!-- 文件夹 -->
  94. <div>
  95. <!-- 众多功能 -->
  96. <div class="manyUse">
  97. <div class="useMenu">
  98. <!-- <div v-if="(thisRole.some(item=>item == 'upload') || (isDept && thisFolder.dirId)) && (pathLabelData.length || leftShowList == 1)&& thisFolder.parentId != 0" -->
  99. <div v-if="(thisRole.some(item=>item == 'upload') || (isDept))"
  100. style="display: flex;width: 92px;height: 32px;justify-content: flex-start;align-items: center;line-height: 18px;">
  101. <div style="margin-left: 5px;">
  102. <img src="../../assets/images/upload.png" style="width: 24px;height: 24px;" alt="">
  103. </div>
  104. <div style="margin-left: 5px;">
  105. <span style="color: black;cursor: pointer;" @click="uploadModal = true" class="shouzhi">上传
  106. </span>
  107. </div>
  108. </div>
  109. <div v-else
  110. style="display: flex;width: 92px;opacity:0.5;height: 32px;justify-content: flex-start;align-items: center;line-height: 18px;">
  111. <div style="margin-left: 5px;">
  112. <img src="../../assets/images/upload.png" style="width: 24px;height: 24px;" alt="">
  113. </div>
  114. <div style="margin-left: 5px;">
  115. <span style="color: black;cursor: pointer;" class="shouzhi">上传
  116. </span>
  117. </div>
  118. </div>
  119. <div v-if="!isDept"></div>
  120. <div v-else-if="(!thisFolder.dirType) || !isDept"
  121. style="display: flex;width: 102px;opacity:0.5;height: 32px;justify-content: flex-start;align-items: center;">
  122. <div style="margin-left: 5px;">
  123. <el-icon
  124. style="background-color: #7084B4;width: 24px;height: 24px;border-radius: 50%;color: white;"
  125. >
  126. <Plus />
  127. </el-icon>
  128. </div>
  129. <div style="margin-left: 5px;">
  130. <span style="font-size: 14px;" class="shouzhi">新建目录</span>
  131. </div>
  132. </div>
  133. <div v-else
  134. style="display: flex;width: 102px;height: 32px;justify-content: flex-start;align-items: center;">
  135. <div style="margin-left: 5px;">
  136. <el-icon
  137. style="background-color: #7084B4;width: 24px;height: 24px;border-radius: 50%;color: white;"
  138. @click="createNewMenu(0)">
  139. <Plus />
  140. </el-icon>
  141. </div>
  142. <div style="margin-left: 5px;" @click="createNewMenu(0)">
  143. <span style="font-size: 14px;" class="shouzhi">新建目录</span>
  144. </div>
  145. </div>
  146. <template v-for="(item, index) in useMenu" :key="index">
  147. <div :class="{ 'isCheck': (haveCheck && thisRole.some(item=>item == 'delete')||haveCheck && isDept) }"
  148. style="display: flex;width: 82px;opacity:0.5;height: 32px;justify-content: flex-start;align-items: center;line-height: 18px;cursor: pointer;"
  149. @click="getMenu(item, index,(haveCheck && thisRole.some(item=>item == 'delete')||haveCheck && isDept))">
  150. <div style="margin-left: 5px;">
  151. <img :src="item.img" style="width: 24px;height: 24px;" alt="">
  152. </div>
  153. <div style="margin-left: 5px;">
  154. <span style="font-size: 14px;" class="shouzhi">{{ item.name }}</span>
  155. </div>
  156. </div>
  157. </template>
  158. <div v-if="(isDept && thisFolder.dirId)"
  159. style="display: flex;width: 92px;height: 32px;justify-content: flex-start;align-items: center;line-height: 18px;">
  160. <div style="margin-left: 5px;">
  161. <img src="../../assets/images/scanFile.png" style="width: 24px;height: 24px;" alt="">
  162. </div>
  163. <div style="margin-left: 5px;">
  164. <span style="color: black;cursor: pointer;" @click="scannerFile">扫描
  165. </span>
  166. </div>
  167. </div>
  168. <!-- <div v-else
  169. style="display: flex;width: 92px;opacity:0.5;height: 32px;justify-content: flex-start;align-items: center;line-height: 18px;">
  170. <div style="margin-left: 5px;">
  171. <img src="../../assets/images/scanFile.png" style="width: 24px;height: 24px;" alt="">
  172. </div>
  173. <div style="margin-left: 5px;">
  174. <span style="color: black;cursor: pointer;">扫描
  175. </span>
  176. </div>
  177. </div> -->
  178. </div>
  179. <div class="tip">
  180. <img src="@/assets/images/mouseRight.png" alt="">
  181. <span>使用右键进行文件操作</span>
  182. </div>
  183. </div>
  184. <div v-show="false">
  185. <!-- 面包屑功能栏 -->
  186. <div class="breadBox">
  187. <!-- 左侧 -->
  188. <div style="display: flex;justify-content: space-around;align-items: center;margin-left: 10px;">
  189. <!-- 前进后退 -->
  190. <!-- <div style="display: flex;justify-content: space-around;align-items: center;margin-right: 5px;" >
  191. <img style="display:block;width: 11px;height: 11px;" :src="blueLeft" alt=""
  192. @click="arrowLift">
  193. <img style="display:block;width: 16px;height: 16px;" :src="grayRight" alt="">
  194. </div> -->
  195. <!-- 面包屑 -->
  196. <div class="topPath">
  197. <span @click="backTopPath">{{ topPath }}</span>
  198. <PathLabel v-if="!loadingPreview" @folderClick="folderClick" :pathLabelData='pathLabelData'></PathLabel>
  199. <!-- <BreadMenu></BreadMenu> -->
  200. </div>
  201. </div>
  202. <!-- 右侧 -->
  203. <div>
  204. <img
  205. src="@/assets/images/sort.png"
  206. @click="changeSort"
  207. v-if="isAsc == 'asc'"
  208. alt=""
  209. />
  210. <img
  211. src="@/assets/images/Frame_188.png"
  212. @click="changeSort"
  213. v-else
  214. alt=""
  215. />
  216. <!-- //控制宫格展示 -->
  217. <img
  218. v-if="fileGrid"
  219. src="@/assets/images/squre.png"
  220. class="shouzhi palace-grid"
  221. alt=""
  222. @click="changeShow(true)"
  223. />
  224. <img
  225. v-else
  226. src="@/assets/images/Frame_187.png"
  227. class="shouzhi palace-grid"
  228. alt=""
  229. @click="changeShow(false)"
  230. />
  231. <!-- <img :src="squre" alt="" @click="gridChange" class="shouzhi"> -->
  232. </div>
  233. </div>
  234. <!-- </div> -->
  235. <!-- 展示文件夹盒子 -->
  236. <!-- 文件夹 -->
  237. <div class="showBox">
  238. <div class="detailBox file-jia" @click="mouseClick">
  239. <el-collapse v-model="folder">
  240. <el-collapse-item name="1" class="custom-collapse-item">
  241. <template #title>
  242. <span class="file-title">文件夹</span>
  243. </template>
  244. <el-table v-if="fileGrid == 1" :data="folderList" height="37vh" style="width: 100%" :scrollbar-always-on="true"
  245. @selection-change="handleSelectionChange1" :single-select="true" @row-click="folderClick"
  246. @row-contextmenu="folderRClick" ref="taskTableRef">
  247. <!-- <el-table-column type="selection" width="55" /> -->
  248. <el-table-column label="名称" :show-overflow-tooltip="true" :tooltip-options="{showAfter: 1000}" width="600">
  249. <template #default="scope">
  250. <span class="juzhong">
  251. <el-icon v-if="scope.row.isFavorite == 'N'" @click.stop="collectByStar(scope.row,true)" class="juli">
  252. <Star />
  253. </el-icon>
  254. <img v-else @click.stop="delCollect(scope.row,true)" src="../../assets/images/yellowstar.png" alt="" class="juli">
  255. <img :src="scope.row.dirType=='1'?fileBox:ordinary" style="width: 20px;height: 24px;"
  256. alt="" class="juli">
  257. <span class="shouzhi"> {{ scope.row.dirName }}</span>
  258. </span>
  259. </template>
  260. </el-table-column>
  261. <el-table-column prop="createTime" label="时间" width="280" />
  262. <el-table-column prop="dirType" label="类型">
  263. <template #default="scope">
  264. <span v-if="scope.row.dirType == '1'">普通目录</span>
  265. <span v-else>组织目录</span>
  266. </template>
  267. </el-table-column>
  268. <el-table-column label="加密等级">
  269. <template #default="scope">
  270. <span>
  271. {{setTablelevel(scope.row.encryptLevel)}}
  272. </span>
  273. </template>
  274. </el-table-column>
  275. </el-table>
  276. <PlaceGridFolder v-else @folderClick="folderClick" :folderList="folderList" :restName="restName"
  277. :collectFolder="collectFolder" @collectByStar="collectByStar" @delCollect="delCollect" @setScroll="setScroll" @folderRClick="folderRClick" :getAllTop="getAllTop" @folderBack="folderBack" :thisFolder="thisFolder" :impDirId="impDirId">
  278. </PlaceGridFolder>
  279. </el-collapse-item>
  280. </el-collapse>
  281. <!-- 右键唤出的菜单 -->
  282. <div class="right_menu" v-if="folderVisible"
  283. :style="{ left: folderleft + 'px', top: foldertop + 'px' }">
  284. <!-- <div class="menu_item" @click="folderClick(null, null)">
  285. <img src="@/assets/images/trash.png" alt="" />
  286. <span>打开</span>
  287. </div> -->
  288. <div class="menu_item" @click="restName(null, null)">
  289. <img src="@/assets/images/textbox.png" alt="" />
  290. <span class="shouzhi">重命名</span>
  291. </div>
  292. <div class="menu_item" @click="collectFolder">
  293. <img src="@/assets/images/collect.png" alt="" />
  294. <span class="shouzhi">收藏</span>
  295. </div>
  296. <div class="menu_item" v-if="clickRow.dirType === '2' && isDept" @click="upFirstFoler(null)">
  297. <img src="@/assets/images/notePencil.png" alt="" />
  298. <span class="shouzhi">编辑</span>
  299. </div>
  300. <div class="menu_item" v-if="isDept" @click="delFolderMenu">
  301. <img src="@/assets/images/trash.png" alt="" />
  302. <span>删除</span>
  303. </div>
  304. </div>
  305. </div>
  306. <!-- 文件 -->
  307. <div class="fileTable">
  308. <el-collapse v-model="files" >
  309. <el-collapse-item name="2" class="">
  310. <template #title>
  311. <span class="file-title">文件</span>
  312. </template>
  313. <el-table v-el-table-infinite-scroll="setScroll" :infinite-scroll-distance="30" :infinite-scroll-disabled="tableBeEnd" v-if="fileGrid == 1" :height="fileHeight" :data="fileList" :scrollbar-always-on="true" style="width: 100%"
  314. @row-contextmenu="handleRowClick" @selection-change="handleSelectionChange"
  315. @row-click="mouseClick" :default-sort="{ prop: 'createTime', order: 'descending' }">
  316. <el-table-column type="selection" width="55" />
  317. <el-table-column label="名称" width="600">
  318. <template #default="scope">
  319. <span style="white-space: nowrap;overflow: hidden;text-overflow: ellipsis;" class="juzhong">
  320. <el-icon v-if="scope.row.isFavorite == 'N'" @click.stop="collectByStar(scope.row,false)">
  321. <Star />
  322. </el-icon>
  323. <img v-else @click.stop="delCollect(scope.row,false)" src="../../assets/images/yellowstar.png" alt="" class="juli">
  324. <img :src="setImg(scope.row.fileType)" style="width:22px;height:22px;" alt="" class="juli">
  325. <el-tooltip
  326. class="box-item"
  327. effect="dark"
  328. placement="top"
  329. :show-after="1000"
  330. :content="scope.row.fileName"
  331. >
  332. <!-- <template #content> {{ scope.row.encryptLevel == 'L1'?'敏感':(scope.row.encryptLevel == 'L2'?'涉密':(scope.row.encryptLevel == 'L3'?'机密':'绝密')) }} </template> -->
  333. <span class="shouzhi">{{ scope.row.fileName }}</span>
  334. </el-tooltip>
  335. </span>
  336. </template>
  337. </el-table-column>
  338. <el-table-column prop="createTime" label="时间" sortable width="280" />
  339. <el-table-column prop="fileType" label="类型" />
  340. <el-table-column label="大小">
  341. <template #default="scope">
  342. <span>
  343. {{ formatFileSize(scope.row.fileSize) }}
  344. </span>
  345. </template>
  346. </el-table-column>
  347. </el-table>
  348. <PalaceGridFile v-else :fileHeight="fileHeight" @showFile="showFile" :getAllTop="getAllTop" @navBack="navBack"
  349. @lastBB="lastBB" @collectByStar="collectByStar" @delCollect="delCollect" @setScroll="setScroll" @handleRowClick="handleRowClick" @onlineCase="onlineCase" @shareBack="shareBack" :thisFolder="thisFolder" :fileList="fileList"></PalaceGridFile>
  350. </el-collapse-item>
  351. </el-collapse>
  352. </div>
  353. </div>
  354. </div>
  355. <ListShow @handleSelectionChange="handleSelectionChange" :fileList="fileList" @changeListSort="changeListSort" @delCollect="delCollect" @collectByStar="collectByStar" @handleRowClick="handleRowClick"></ListShow>
  356. </div>
  357. </div>
  358. <div :class="{'setCli':!noMenuItem}" v-if="cliCC" :style="{ left: xz + 'px', top: yz -100 + 'px' }">
  359. <template v-for="(item, index) in filterMouseCli()" :key="index">
  360. <p @click="chooseSet(item, index, 1)" :class="{'hasLine':item.name == '删除'||item.name == '文字识别','btmLine':(item.name == '收藏' && !noHis)||item.name == '下载'}" v-if="!noMenuItem" class="chooseSet shouzhi">
  361. <img :src="item.img" alt="">
  362. <span class="shouzhi"></span>{{ item.name }}
  363. <span v-if="item.name == '在线编辑' || item.name == '协作' ? true : false"
  364. style="color: #7084B4;float: right;position: relative;" class="arrow">></span>
  365. </p>
  366. </template>
  367. </div>
  368. <div class="setCli1" v-if="anyP" :style="{ left: xz + 155 + 'px', top: yz + 'px' }">
  369. <p @click="chooseSet1(0)" class="chooseSet">
  370. <img src="../../assets/images/user.png" alt="">
  371. 选择人员
  372. </p>
  373. <p class="chooseSet" @click="goLock">
  374. <img src="../../assets/images/archiveTray.png" alt="">
  375. 归档
  376. </p>
  377. </div>
  378. <!-- 扩容弹窗 -->
  379. <div>
  380. <SpaceBig v-if="spaces" :spaces="spaces" :impSpaceId="impSpaceId" @getSpaceC="getSpaceC"></SpaceBig>
  381. </div>
  382. <!-- 新增文件夹弹窗 -->
  383. <div>
  384. <CreateFloder v-if="folderCase" :getFirstFolder="getFirstFolder" :thisType="thisFolder" :thisRole="thisRole" :folderCase="folderCase" @getChildrenC="getChildrenC" :oneOrTwo="oneOrTwo"
  385. :impDirId="impDirId" :impSpaceId="impSpaceId" :newDirId="newDirId" :newSpaceId="newSpaceId" :upFolderData="upFolderData" :thisFolderRole="thisFolderRole"
  386. :refreshFile="refreshFile">
  387. </CreateFloder>
  388. </div>
  389. <!-- 文件上传 -->
  390. <div>
  391. <el-dialog :close-on-click-modal="false" v-model="uploadModal" title="文件上传" width="30%" @close="closeUpload">
  392. <el-upload class="upload-demo" :file-list="fileArr" :limit="10" :on-change="upBefore" drag :http-request="onSuccess" multiple
  393. :on-remove="handleRemove"
  394. element-loading-text="上传中..."
  395. element-loading-background="rgba(255, 255, 255, 0.8)"
  396. v-loading="loadingUpload"
  397. >
  398. <el-icon class="el-icon--upload"><upload-filled /></el-icon>
  399. <div class="el-upload__text">拖入或<em>点击上传</em></div>
  400. <template #tip>
  401. <div class="el-upload__tip">请选择或拖入文件(一次最多上传10个文件)&nbsp;&nbsp;&nbsp;仅支持上传文件格式</div>
  402. </template>
  403. </el-upload>
  404. <template #footer>
  405. <span class="dialog-footer">
  406. <el-button @click="closeUpload">取消</el-button>
  407. <el-button type="primary" @click="sureUpload">确认</el-button>
  408. </span>
  409. </template>
  410. </el-dialog>
  411. </div>
  412. <!-- 文件重命名 -->
  413. <div>
  414. <el-dialog v-model="fileNameChange" :close-on-click-modal="false" title="重命名" width="30%">
  415. <el-form :model="nameForm" label-width="120px">
  416. <el-form-item label="新名字">
  417. <el-input v-model="nameForm.name" placeholder="请输入不多于32位字符" maxlength="32"></el-input>
  418. </el-form-item>
  419. </el-form>
  420. <template #footer>
  421. <span class="dialog-footer">
  422. <el-button @click="fileNameChange = false">取消</el-button>
  423. <el-button type="primary" @click="sureChangeName">
  424. 确认
  425. </el-button>
  426. </span>
  427. </template>
  428. </el-dialog>
  429. </div>
  430. <!-- 文件收藏 -->
  431. <div>
  432. <FileCollect v-if="collects" :collects="collects" @getCollects="getCollects" :copyFileName="copyFileName"
  433. :copyFileId="copyFileId" @refreshFile="refreshFile" :isFolder="isFolder" :clickRow="clickRow"></FileCollect>
  434. </div>
  435. <!-- 中栏重命名 -->
  436. <div>
  437. <FolderReName v-if="rename" :rename="rename" :selectedBox="selectedBox" :getAllTop="refreshFile"
  438. :copyFolderName="copyFolderName" @getRename="getRename">
  439. </FolderReName>
  440. </div>
  441. <ImgPreview :previewData="previewData" :copyFileType="copyFileType" :showPreview="showPreview"
  442. @closeImgPreview="closeImgPreview"></ImgPreview>
  443. <div>
  444. <FileTree v-if="fileTrees" :fileTrees="fileTrees" :newSpaceId="newSpaceId" :fileId="clickRowId"
  445. @getChildren="getChildren" :copyOrMove="copyOrMove"></FileTree>
  446. </div>
  447. <!-- 穿梭框 -->
  448. <div>
  449. <TransferModal v-if="thanks" :thanks="thanks" :clickRowId="clickRowId" :workOrEdit="workOrEdit"
  450. @getCback="getCback"></TransferModal>
  451. </div>
  452. </div>
  453. </div>
  454. <!-- 图片预览 -->
  455. <!-- 历史版本 -->
  456. <historyList v-if="openForwardFile" :openFile="openForwardFile" :docId="clickRowId" :name="nameForm.name"
  457. :copyRow="copyRow" @setHisData="setHisData" @close="openForwardFile = false" :fileUserTreeData="fileUserTreeData.data"
  458. @changeMsgClose="changeMsgClose" :historyTotal="historyTotal">
  459. </historyList>
  460. <!-- 历史版本 -->
  461. <!-- 二次密码验证 -->
  462. <inputPassword v-if="showInputPassword" @sureCode="sureCode" :isCode="isCode" :inputTitle="inputTitle" @surePass="surePass" @closeIptPass="closeIptPass" :showInputPassword="showInputPassword"></inputPassword>
  463. <div v-loading.fullscreen="loadingPreview" v-if="loadingPreview" class="lodingBox"></div>
  464. <!-- 扫描文档 -->
  465. <ScanFile v-if="openScan" :openScan="openScan" :scannerFiles="scannerFiles" @saveScanFile="saveScanFile" @closeOpen="closeOpen"></ScanFile>
  466. <!-- 可用扫描仪信息 -->
  467. <div>
  468. <el-dialog :close-on-click-modal="false" v-model="checkScanner" title="扫描仪" width="30%">
  469. <div v-for="item in scannerList" :key="item.scannerId" @click="checkScanFn(item)" id="Onescan" :class="{'checkScan':item.scannerId ==checkScanId }">
  470. <img src="@/assets/images/scanImg.png" alt="">
  471. {{item.scannerName}}
  472. </div>
  473. <template #footer>
  474. <span class="dialog-footer">
  475. <el-button @click="closeCheckScanner">取消</el-button>
  476. <el-button type="primary" @click="sureScaner">确认</el-button>
  477. </span>
  478. </template>
  479. </el-dialog>
  480. </div>
  481. <!-- 扫描文件移动到 -->
  482. <MoveTo v-if="openScanMove" :spaceType='2' :scanFileArr="scanFileArr" :thisFolder="thisFolder" :openScanMove="openScanMove" @closeOpenScanMove='closeOpenScanMove'></MoveTo>
  483. <TreeMenu v-show="showTreeMenu" :spaceType='2' @delCollect="delCollect" @collectFolder="collectFolder" :noEdit="noEdit" :clickRow="clickRow" :isDept="isDept" @upFirstFoler="upFirstFoler" @restName="restName" @delName="delName" :xz="xz" :yz="yz"></TreeMenu>
  484. <!-- 查看历史记录的iframe -->
  485. <el-dialog
  486. v-model="showHis"
  487. title="历史记录"
  488. width="1250px"
  489. :close-delay='200'
  490. :before-close="closeHis"
  491. >
  492. <iframe :key="nowTime" :src="hisIfarmeData.src" :name="nowTime" id="iframeHis" frameborder="0" width="1200px"
  493. height="800px" class="iframeBox" ></iframe>
  494. <!-- <PreHistory v-if="showHis" style="width:1200px;" :historyDocId="historyDocId" :historyFileId="historyFileId"></PreHistory> -->
  495. </el-dialog>
  496. </template>
  497. <script>
  498. import { ref, toRaw, onMounted,onActivated ,inject,watch} from 'vue'
  499. import PreHistory from "@/components/PreHistory/PreHistory.vue"
  500. import myfile from '../../api/myfile/myfile'
  501. import { delFavorite } from '@/api/biz/favorite.js'
  502. import documents from '../../api/document/document'
  503. import {getInfo,delInfo}from "@/api/biz/info.js"
  504. import fileCount from '../../api/fileCount/fileCount'
  505. import FileTree from './components/FileTree.vue'
  506. import BreadMenu from './components/BreadMenu.vue'
  507. import FileEdit from '@/views/myfile/components/FileEdit.vue'
  508. import TransferModal from './modalComponebts/Transfer.vue'
  509. import CreateFloder from './modalComponebts/CreateFloder.vue'
  510. import FileCollect from '@/views/myfile/modalComponebts/FileCollect.vue'
  511. import FolderReName from './modalComponebts/FolderReName.vue'
  512. import SpaceBig from './modalComponebts/SpaceBig.vue'
  513. // import PlaceGridFolder from './components/PlaceGridFolder.vue'
  514. // import PalaceGridFile from './components/PalaceGridFile.vue'
  515. import PlaceGridFolder from '@/views/myfile/components/PlaceGridFolder.vue'
  516. import PalaceGridFile from '@/views/myfile/components/PalaceGridFile.vue'
  517. import ImgFile from "./jsComponents/ImgFile"
  518. import LeftList from "@/components/LeftList/LeftList.vue"
  519. import ListShow from "@/components/ListShow/ListShow.vue"
  520. import { Search } from '@element-plus/icons-vue'
  521. import blueLeft from '../../assets/images/blueLeft.png'
  522. import grayRight from "../../assets/images/grayRight.png"
  523. import sort from '../../assets/images/sort.png'
  524. import squre from '../../assets/images/squre.png'
  525. import delImg from '../../assets/images/trash.png'
  526. import level1 from "@/assets/images/level1.png";
  527. import level2 from "@/assets/images/level2.png";
  528. import level3 from "@/assets/images/level3.png";
  529. import level4 from "@/assets/images/level4.png";
  530. import { ElMessage ,ElLoading ,ElMessageBox} from 'element-plus'
  531. import ImgPreview from '@/components/ImgPreview/ImgPreview.vue'
  532. import ScanFile from '@/components/ScanFile/ScanFile.vue'
  533. import MoveTo from '@/components/MoveTo/MoveTo.vue'
  534. import PathLabel from '@/components/PathLabel/index.vue'
  535. import { preview } from "@/api/common/common.js";
  536. import historyList from "@/components/historyList/index.vue"; //选择文件发送的列表,历史版本
  537. import inputPassword from "./components/inputPassword.vue"; //选择文件发送的列表,历史版本
  538. import { listVersion } from "@/api/biz/version";
  539. import useUserStore from "@/store/modules/user";
  540. import { useRouter, useRoute,onBeforeRouteUpdate } from "vue-router";
  541. import { canPreviewFile,rightMenuRole,publicRightMenuRole } from "@/utils/index.js"
  542. import fileSpace from '../../api/filespace/fileSpace';
  543. import { getLeveldetail } from '../../api/level/level';
  544. import { encrypt, decrypt } from "@/utils/jsencrypt";
  545. import ordinaryList from "@/assets/images/ordinaryList.png";
  546. import ordinary from "@/assets/images/ordinary.png";
  547. import fileStyle from "@/assets/images/fileStyle.png";fileBox
  548. import fileBox from "@/assets/images/fileBox.png";
  549. import { getLevel } from '@/api/level/level.js';
  550. import { listInfo,selectInfo ,getFileByScanerId} from '@/api/scanner/info.js';
  551. import Cookies from "js-cookie";
  552. import elTableInfiniteScroll from 'el-table-infinite-scroll'
  553. import { getConfigKey } from "@/api/system/config.js"
  554. import { setIcon } from "@/utils/index.js";
  555. import uploadApi from '../../api/upload/upload'
  556. import TreeMenu from '@/components/TreeMenu/TreeMenu.vue'
  557. export default {
  558. directives: {
  559. 'el-table-infinite-scroll': elTableInfiniteScroll
  560. },
  561. setup() {
  562. const { proxy } = getCurrentInstance();
  563. const levelList = ref()
  564. let fileTrees = ref(false)//filetree父传子
  565. let thanks = ref(false)//transfer父传子
  566. let collects = ref(false)//文件收藏父传子
  567. let rename = ref(false)//文件夹重命名
  568. let spaces = ref(false)//空间扩容父传子
  569. let folderCase = ref(false)
  570. let fileGrid = ref(sessionStorage.getItem('fileGrid') || 1)
  571. let folderGrid = ref(true)
  572. let editOnline = ref(true)
  573. let searchFire = ref('')
  574. let selectedIndex = ref(0)
  575. let folder = ref(['1'])
  576. let files = ref(['2'])
  577. let folderList = ref([])
  578. let cliCC = ref(false)
  579. let anyP = ref(false)
  580. let uploadModal = ref(false)
  581. let collectImg = ref(true)
  582. let selectedBox = ref(-1)
  583. let clickRowId = ref(0)
  584. let trandata = ref()
  585. let folderId = ref('')
  586. let fileId = ref('')
  587. let tranvalue = ref([])
  588. let useSpace = ref(0)
  589. let allSpace = ref(0)
  590. let fileArr = ref([])
  591. let copyDirId = ref(0)//需要操作的dirid
  592. let copySpaceId = ref(0)//需要操作的spaceid
  593. let copyDocId = ref(0)//需要操作的docid
  594. let copyFileId = ref(0)//需要操作的fileid
  595. let copyFileSize = ref(0)//需要操作的filesize
  596. let copyFileType = ref('')//需要操作的文件类型
  597. let copyFileName = ref("")//需要操作的文件名
  598. let copyFolderName = ref("")
  599. let copySpaceCup = ref(0)
  600. let directoryId = ref('')
  601. let impSpaceId = ref("")
  602. let impDirId = ref("")
  603. let impNum = ref(0)
  604. let copyParentId = ref("")//文件夹
  605. let needBag = ref("")
  606. let copyOrMove = ref(0)//0代表复制,1代表移动
  607. let oneOrTwo = ref(0)//0代表二级,1代表一级
  608. let sortNum = ref(0)
  609. let folderTotal = ref(0)//文件夹total
  610. let fileTotal = ref(0)//文件total
  611. const openForwardFile = ref(false) //历史版本展示
  612. const delMoreFile = ref([]) //删除多个文件夹
  613. const historyTotal = ref(0)
  614. const historyPrew = ref(false)
  615. const leftNewFile = ref(false) //解决左侧点击后不能显示的问题
  616. let xz = ref(0)
  617. let yz = ref(0)
  618. const fileUserTreeData = reactive({ data: {} });
  619. let fileList = ref()
  620. let menuList = ref([
  621. {
  622. name: "我的空间",
  623. choose: "我的空间"
  624. }
  625. ])
  626. const fileHeight=ref('38vh')
  627. const pageSize = ref(10)
  628. let useMenu = ref([
  629. // {
  630. // img: ImgFile.copy,
  631. // name: "复制"
  632. // },
  633. // {
  634. // img: ImgFile.clipboard,
  635. // name: "粘贴"
  636. // },
  637. // {
  638. // img: ImgFile.share,
  639. // name: "分享给"
  640. // },
  641. {
  642. img: delImg,
  643. name: "删除"
  644. },
  645. ])
  646. let arrorMenu = ref([
  647. {
  648. img: ImgFile.file,
  649. name: "文件"
  650. },
  651. {
  652. img: ImgFile.folder,
  653. name: '文件夹'
  654. },
  655. {
  656. img: ImgFile.image,
  657. name: "图片"
  658. },
  659. {
  660. img: ImgFile.filmSlate,
  661. name: "视频"
  662. },
  663. {
  664. img: ImgFile.musicNotes,
  665. name: "音频"
  666. }
  667. ])
  668. let mouseCli = ref([
  669. {
  670. img: ImgFile.previewIcon,
  671. name: "打开"
  672. },
  673. {
  674. img: ImgFile.downLoad,
  675. name: "下载"
  676. },
  677. {
  678. img: ImgFile.textbox,
  679. name: "重命名"
  680. },
  681. // {
  682. // img: ImgFile.goon,
  683. // name: "发送"
  684. // },
  685. {
  686. img: ImgFile.share,
  687. name: "分享"
  688. },
  689. {
  690. img: ImgFile.collect,
  691. name: "收藏"
  692. },
  693. {
  694. img: ImgFile.icc,
  695. name: "文字识别"
  696. },
  697. {
  698. img: ImgFile.history,
  699. name: "历史版本"
  700. },
  701. {
  702. img: ImgFile.trash,
  703. name: "删除"
  704. }
  705. ])
  706. let nameForm = ref({
  707. name: ""
  708. })
  709. let ordinaryFolder = ref([ {
  710. img: ImgFile.previewIcon,
  711. name: "打开"
  712. },
  713. {
  714. img: ImgFile.collect,
  715. name: "收藏"
  716. },
  717. {
  718. img: ImgFile.downLoad,
  719. name: "下载"
  720. }
  721. ])
  722. let fileNameChange = ref(false)
  723. let fileMenu = ref([])
  724. let copyRow = ref({})
  725. let newDirId = ref('')
  726. let newSpaceId = ref('')
  727. let workOrEdit = ref(0)
  728. const showPreview = ref(false)//控制图片预览组件显示
  729. const previewData = ref()//需要预览的文件的数据
  730. const router = useRouter(); //注册路由
  731. const route = useRoute(); //注册路由
  732. const folderVisible = ref(false); //显示文件夹右键菜单
  733. const foldertop = ref(0);
  734. const folderleft = ref(0);
  735. const thisFolder = ref({}); //当前右键的文件夹
  736. const folderCheckout = ref(false)//是否有勾选
  737. const fileCheckout = ref(false)//是否有勾选
  738. const haveCheck = ref(false)//是否有勾选
  739. const onlyView = ref(false) //预览
  740. const topPath = ref()//顶部路径
  741. const isFolder = ref('N') //是否为文件夹
  742. const clickRow = ref()//当前右键的行数据
  743. const backFolder = ref()//上一级的文件夹
  744. const thisFolderRole = ref({})//文件夹安全等级
  745. const thisRole = ref([])//文件夹权限
  746. const showInputPassword = ref(false)
  747. const chooseRow = ref()
  748. const chooseNum = ref()
  749. const loadingPreview = ref(false)
  750. const noMenuItem = ref(false)
  751. const addTab = inject("addTab");
  752. const addFileTab = inject("addFileTab");
  753. const upFileData = inject("upFileData");
  754. const addFolderAdd = inject("addFolderAdd");
  755. const delFolderDataFn = inject("delFolderDataFn");
  756. const delFileFn = inject("delFileFn");
  757. const filePageNum = ref(1) //获取文件分页
  758. const tableBeEnd = ref(true)//控制下拉是否到底
  759. const tableTotal = ref(0)//表格数据总数
  760. const spaceName = ref()
  761. const isDept = ref(false)// 是否管理员
  762. const loadingUpload = ref(false);//文件上传加载
  763. let fileBig = ref(0);
  764. const maxFileSize = ref()//能上传的最大size
  765. const scannerList = ref() // 扫描仪数据
  766. const checkScanId = ref() // 选中的scan的id
  767. const checkScanner = ref(false) //显示扫描仪选择框
  768. const scannerFiles = ref([]) //选择的扫描仪的文件
  769. const openScanMove = ref(false)
  770. const pathLabelData = ref([
  771. ])
  772. //控制宫格展示
  773. const isList = ref(false); //控制显示方式
  774. const openScan = ref(false)//控制扫描文档显示
  775. const scanFileArr = ref([]) //认领的扫描文件数组
  776. const delMoreFolder = ref([])
  777. const inputTitle = ref()//验证框标题
  778. const isCode = ref(false)// 验证的类型
  779. const isAsc = ref("desc");
  780. const clickPath = inject("clickPath");
  781. const leftShowList = ref()
  782. const thisFirst = ref()
  783. const ListtreeData = ref()
  784. const searchFolderTree = ref()
  785. const showTreeMenu = ref(false)
  786. const noEdit = ref(false)//树形节点 右键是否可编辑
  787. const collectId = ref()
  788. const showHis = ref(false)
  789. const hisIfarmeData = ref({
  790. // src: `${window.location.origin}/fileEdit?clickRowId=7567&canEdit=0&canCopy=0&history=0&fileId=0`,
  791. })
  792. const noHis = ref(false)
  793. const setHisData = (data)=>{
  794. hisIfarmeData.value = {
  795. // src:`${window.location.origin}/fileEdit?clickRowId=${data.docId}&canEdit=0&canCopy=0&history=1&fileId=${data.fileId}`,
  796. src:`${window.location.origin}/preHistory?clickRowId=${data.docId}&fileId=${data.fileId}`,
  797. }
  798. showHis.value = true
  799. const dom = document.getElementById('iframeHis')
  800. if(dom){
  801. dom.contentWindow.location.reload();
  802. }
  803. // console.log(21);
  804. setTimeout(() => {
  805. iframeSize()
  806. }, 200);
  807. // console.log('data',data);
  808. }
  809. // 控制iframe大小
  810. const iframeSize = () => {
  811. // console.log('执行ifSize',par);
  812. const outIframe = document.getElementById("iframeHis");
  813. const inIframe =
  814. outIframe.contentDocument.getElementsByTagName("iframe")[0];
  815. if(inIframe==null){
  816. // console.log('没有inF');
  817. setTimeout(() => {
  818. // console.log('==============');
  819. iframeSize()
  820. }, 200);
  821. return
  822. }
  823. // console.log('outIframe', outIframe);
  824. // console.error(outIframe.parentElement);
  825. inIframe.style.height = outIframe.style.height =
  826. outIframe.parentElement.offsetHeight - 40 + "px";
  827. inIframe.style.width = outIframe.style.width =
  828. outIframe.parentElement.offsetWidth - 80+ "px";
  829. }
  830. const closeHis = ()=>{
  831. // hisIfarmeData.value = {}
  832. showHis.value = false
  833. }
  834. const changeSort = async () => {
  835. isAsc.value == "asc" ? (isAsc.value = "desc") : (isAsc.value = "asc")
  836. // refreshFile()
  837. let obj = {
  838. pageNum: 1,
  839. pageSize: 9999,
  840. isAsc: isAsc.value,
  841. orderByColumn: "createTime"
  842. }
  843. documents.getALLdocumentByType({ parentId: thisFolder.value.dirId?thisFolder.value.dirId:impDirId.value, spaceId: impSpaceId.value,isAsc: isAsc.value,orderByColumn: "createTime",pageNum: obj.pageNum, pageSize: obj.pageSize },2).then(res => {
  844. // fileMenu.value = res.rows
  845. folderList.value = res.rows
  846. })
  847. const query = `${thisFolder.value.dirId?thisFolder.value.dirId:impDirId.value}?isAsc=${isAsc.value}&orderByColumn=createTime&pageSize=9999&pageNum=1`
  848. myfile.getById(query).then(res => {
  849. if (res.code === 200) {
  850. fileList.value = res.rows
  851. fileTotal.value = res.total
  852. // console.log('fileList.value',fileList.value);
  853. }
  854. // console.log('not200');
  855. })
  856. }
  857. const changeListSort = async (listAsc)=>{
  858. const query = `${thisFolder.value.dirId}?isAsc=${listAsc}&orderByColumn=createTime&pageSize=9999&pageNum=1`
  859. myfile.getById(query)
  860. .then(res => {
  861. if (res.code === 200) {
  862. fileList.value = res.rows;
  863. }
  864. })
  865. .catch(error => {
  866. console.error("myfile.getAllFileMenu 调用失败:", error);
  867. });
  868. }
  869. const changeShow =async (fileGrids) => {
  870. // console.log('fileGrid',fileGrid.value);
  871. filePageNum.value = 1
  872. if(fileGrid.value == 1){
  873. fileGrid.value = 0 // 变宫格
  874. pageSize.value = 30+pageSize.value
  875. if(thisFolder.value.dirId){
  876. const query = `${thisFolder.value.dirId}?isAsc=${isAsc.value}&orderByColumn=createTime&pageSize=9999&pageNum=${filePageNum.value}`
  877. const res = await myfile.getById(query)
  878. // console.log('filessetScrollres',res);
  879. if (res.code === 200) {
  880. // const newarr = res.rows.concat(toRaw(fileList.value))
  881. const newarr = res.rows
  882. // console.log('newarr',newarr);
  883. fileList.value = JSON.parse(JSON.stringify(newarr))
  884. if(newarr.length < tableTotal.value){
  885. //获取后的数量<total就可以再次获取
  886. setTimeout(()=>{
  887. tableBeEnd.value = false
  888. },1000)
  889. }
  890. }
  891. }
  892. }else{
  893. fileGrid.value = 1
  894. pageSize.value = 20
  895. }
  896. sessionStorage.setItem('fileGrid',fileGrid.value)
  897. };
  898. const upFolderData = ref()// 修改的文件夹的数据
  899. // const isUpFolder = ref(false)
  900. // 获取文件夹,中栏,文件
  901. function getAllTop() {
  902. documents.getTop(2).then(res => {
  903. // console.log('getAllTopres',res);
  904. if(!res){
  905. // console.log('nores');
  906. return
  907. }
  908. let userMe = [res]
  909. impDirId.value = userMe[0].dirId//固定
  910. impSpaceId.value = userMe[0].spaceId//固定
  911. newSpaceId.value = userMe[0].spaceId//变化
  912. newDirId.value = userMe[0].dirId//变化
  913. topPath.value = userMe[0].dirPath
  914. spaceName.value = userMe[0].dirPath
  915. let obj = {
  916. pageNum: 1,
  917. pageSize: 9999,
  918. isAsc: isAsc.value,
  919. orderByColumn: "createTime",
  920. }
  921. documents.getALLdocumentByType({ parentId: userMe[0].dirId - 0, spaceId: userMe[0].spaceId,isAsc: isAsc.value,orderByColumn: "createTime", pageNum: obj.pageNum, pageSize: 9999 },2).then(res => {
  922. fileMenu.value = res.rows
  923. folderList.value = res.rows
  924. })
  925. myfile.getById(userMe[0].dirId - 0, obj).then(res => {
  926. if (res.code === 200) {
  927. fileList.value = res.rows
  928. fileTotal.value = res.total
  929. if (fileTotal.value / 10 != 1) {
  930. let x = Math.trunc(fileTotal.value / 10) + 1
  931. for (var i = 1; i <= x; i++) {
  932. obj.pageNum = i
  933. myfile.getById(userMe[0].dirId - 0, obj).then(res => {
  934. fileList.value = fileList.value.concat(res.rows)
  935. const uniqueFileList = Array.from(new Set(fileList.value.map(item => item.docId)))
  936. .map(docId => fileList.value.find(item => item.docId === docId));
  937. // 合并数组并更新 fileList.value
  938. fileList.value = uniqueFileList
  939. })
  940. }
  941. }
  942. // console.log('fileList.value',fileList.value);
  943. }
  944. // console.log('not200');
  945. })
  946. })
  947. }
  948. const getFirstFolder = ()=>{
  949. getFileTree()
  950. let obj = {
  951. pageNum: 1,
  952. pageSize: 9999
  953. }
  954. documents.getALLdocumentByType({ parentId: impDirId.value, spaceId: impSpaceId.value,isAsc: isAsc.value,orderByColumn: "createTime", pageNum: obj.pageNum, pageSize: obj.pageSize },2).then(res => {
  955. fileMenu.value = res.rows
  956. // 如果label没有值说明不在一级目录下
  957. if(!pathLabelData.value[0]){
  958. folderList.value = res.rows
  959. }
  960. })
  961. }
  962. function fileBlur() {
  963. if (searchFire.value == '') {
  964. getAllTop()
  965. } else {
  966. const searchTerm = searchFire.value.trim().toLowerCase(); // 转换为小写字母并去除首尾空格
  967. fileMenu.value = fileMenu.value.filter(item => {
  968. const dirName = item.dirName.trim();
  969. return dirName.includes(searchTerm);
  970. });
  971. }
  972. }
  973. function getSpaceList() {
  974. getFileTree()
  975. myfile.fileType(2).then(res => {
  976. useSpace.value = res.data.usedCap
  977. allSpace.value = res.data.spaceCap
  978. })
  979. }
  980. //获取文件树
  981. function getFileTree() {
  982. documents.fileTree(2).then((res) => {
  983. res.disabled = true;
  984. ListtreeData.value = [res];
  985. function getAllNodeIds(nodes) {
  986. nodes.forEach((node) => {
  987. if (node.remark) {
  988. node.remark = JSON.parse(node.remark);
  989. }
  990. if (node.children && node.children.length > 0) {
  991. getAllNodeIds(node.children);
  992. }
  993. });
  994. return nodes;
  995. }
  996. // 调用递归函数获取所有节点的 id
  997. getAllNodeIds(ListtreeData.value);
  998. // console.log("treedataarr", arr);
  999. // console.log("treeData", treeData.value);
  1000. });
  1001. }
  1002. function changeFile(row, num) {
  1003. const labelItem = {
  1004. name:row.dirName,
  1005. dirId:row.dirId
  1006. }
  1007. pathLabelData.value = [labelItem]
  1008. const addData = {
  1009. path:'/department'+row.dirId,
  1010. name:row.dirName,
  1011. clickRowId:toRaw(row)
  1012. }
  1013. // addFolderAdd(addData) //加了这句代码界面会渲染两次
  1014. const itemData = {
  1015. name: row.dirName,
  1016. path:'/department' + row.dirId
  1017. }
  1018. // sessionStorage.setItem('newTab',JSON.stringify(itemData))
  1019. window.parent.$setOpenTab(itemData)
  1020. thisFolder.value = row
  1021. // topPath.value = row.dirPath
  1022. if(row.isEncrypt === "Y" && row.encryptLevel){
  1023. getLeveldetailFn(row.encryptLevel)
  1024. }else{
  1025. thisFolderRole.value = {}
  1026. }
  1027. thisRole.value = row.dirRole?row.dirRole.split(','):[]
  1028. copyParentId.value = row.parentId
  1029. newDirId.value = row.dirId
  1030. newSpaceId.value = row.spaceId
  1031. documents.getALLdocumentByType({ parentId: row.dirId - 0, spaceId: row.spaceId - 0, pageNum: 1, pageSize: 9999 ,isAsc: isAsc.value,orderByColumn: "createTime"},2).then(res => {
  1032. folderList.value = res.rows
  1033. // if (res.code === 200) {
  1034. if (res.rows.length === 0) {
  1035. myfile.getById(`${newDirId.value}?pageNum=1&pageSize=9999&isAsc=${isAsc.value}&orderByColumn=createTime`)
  1036. .then(res => {
  1037. if (res.code === 200) {
  1038. fileList.value = res.rows;
  1039. }
  1040. })
  1041. .catch(error => {
  1042. console.error("myfile.getAllFileMenu 调用失败:", error);
  1043. });
  1044. } else {
  1045. myfile.getById(`${row.dirId - 0}?pageNum=1&pageSize=9999&isAsc=${isAsc.value}&orderByColumn=createTime`)
  1046. .then(res => {
  1047. if (res.code === 200) {
  1048. fileList.value = res.rows;
  1049. }
  1050. })
  1051. .catch(error => {
  1052. console.error("myfile.getAllFileMenu 调用失败:", error);
  1053. });
  1054. }
  1055. // }
  1056. })
  1057. selectedIndex.value = num
  1058. const newItem = {
  1059. name: row.dirName,
  1060. choose: row.dirName,
  1061. dirIds: row.dirId,
  1062. spaceIds: row.spaceId
  1063. };
  1064. // 检查 newItem 是否已存在于 menuList 中
  1065. const isItemExist = menuList.value.some(item => item.choose === newItem.choose);
  1066. // 如果不存在,则添加它
  1067. if (!isItemExist) {
  1068. menuList.value.push(newItem);
  1069. }
  1070. }
  1071. function folderBlur() {
  1072. // if (searchFire.value == '') {
  1073. // getAllTop()
  1074. // } else {
  1075. // const searchTerm = searchFire.value.trim().toLowerCase(); // 转换为小写字母并去除首尾空格
  1076. // fileMenu.value = fileMenu.value.filter(item => {
  1077. // const dirName = item.dirName.trim();
  1078. // return dirName.includes(searchTerm);
  1079. // });
  1080. // }
  1081. }
  1082. // x图标事件
  1083. function shotdown(row) {
  1084. menuList.value = menuList.value.filter(item => item.name !== row.name)
  1085. selectedIndex.value = -1
  1086. if (!editOnline.value) {
  1087. editOnline.value = true
  1088. }
  1089. }
  1090. // 文件名表格每一行点击事件
  1091. function handleRowClick(row, col, e) {
  1092. // console.log('thisFolder',thisFolder.value);
  1093. isFolder.value = "N"
  1094. clickRow.value = row
  1095. const canEditArr = ['.doc', '.docm', '.docx', '.dot', '.dotm', '.dotx', '.txt', '.djvu', '.xps', '.csv', '.fods', '.ods', '.ots', '.xls', '.xlsm', '.xlsx', '.xlt', '.xltm', '.xltx', '.fodp', '.odp', '.otp', '.doc', '.docm', '.docx', '.dot', '.dotm', '.dotx', '.epub', '.fodt', '.htm', '.html', '.mht', '.odt', '.ott', '.rtf', '.txt', '.djvu', '.xps', '.wps','.dps','.et', '.pptx','.pdf','.PDF']
  1096. if(!canEditArr.includes(row.fileType)){
  1097. noHis.value = true
  1098. }else{
  1099. noHis.value = false
  1100. }
  1101. e.preventDefault();
  1102. e.stopPropagation();
  1103. xz.value = e.pageX
  1104. yz.value = e.pageY
  1105. if ((window.innerHeight - e.clientY)<300) {
  1106. yz.value = e.pageY - 100
  1107. }
  1108. //如果带有(重命名)-前缀 只允许进行重命名操作
  1109. const regExp = /^\(重命名\)-/
  1110. if(regExp.test(clickRow.value.fileName)){
  1111. yz.value = e.pageY + 100
  1112. }
  1113. copyRow.value = row
  1114. clickRowId.value = row.docId
  1115. copyDirId.value = row.dirId
  1116. copySpaceId.value = row.spaceId
  1117. copyFileId.value = row.fileId
  1118. copyFileSize.value = row.fileSize
  1119. copyFileType.value = row.fileType
  1120. nameForm.value.name = row.fileName
  1121. copyFileName.value = row.fileName
  1122. if (cliCC.value === true) {
  1123. cliCC.value = false
  1124. } else {
  1125. cliCC.value = true
  1126. }
  1127. }
  1128. // 树节点右键事件
  1129. function treeRClick(row, col, e,Edit) {
  1130. // console.log('row', row);
  1131. // isFolder.value = "N"
  1132. clickRow.value = row
  1133. e.preventDefault();
  1134. e.stopPropagation();
  1135. xz.value = e.pageX
  1136. yz.value = e.pageY
  1137. noEdit.value = Edit
  1138. showTreeMenu.value = true
  1139. }
  1140. // 申请扩容
  1141. async function askApply() {
  1142. const res = await fileSpace.querySpace(impSpaceId.value)
  1143. if(res.data){
  1144. ElMessage({ message: '已存在扩容申请', type: 'error' })
  1145. return
  1146. }
  1147. spaces.value = true
  1148. }
  1149. //mouse弹框
  1150. async function chooseSet(row, index, num) {
  1151. // 权限控制
  1152. if(thisFolderRole.value && thisFolderRole.value.roles){
  1153. if (thisFolderRole.value.roles.l0700) {
  1154. const codeArr = localStorage.getItem('codeArr');
  1155. let codeArrObj
  1156. if(codeArr){
  1157. codeArrObj = JSON.parse(codeArr)
  1158. }
  1159. if ((!codeArrObj) || !codeArrObj.some(item => item === clickRow.value.docId)) {
  1160. chooseRow.value = row
  1161. chooseNum.value = num
  1162. inputTitle.value = '请输入私有安全访问码'
  1163. isCode.value = true
  1164. showInputPassword.value = true
  1165. return
  1166. }
  1167. // console.log('needc');
  1168. }else if(thisFolderRole.value.roles.l0600){
  1169. const passArr = localStorage.getItem('passArr');
  1170. // console.log('passArr',passArr);
  1171. let passArrObj
  1172. if(passArr){
  1173. passArrObj = JSON.parse(passArr)
  1174. }
  1175. if((!passArrObj) || !passArrObj.some(item=>item === clickRow.value.docId)){
  1176. chooseRow.value = row
  1177. chooseNum.value = num
  1178. inputTitle.value = '请输入登录密码'
  1179. isCode.value = false
  1180. showInputPassword.value = true
  1181. return
  1182. }
  1183. // console.log('needc');
  1184. }
  1185. }
  1186. // console.log('chooseSetrow',row);
  1187. // console.log('chooseSetnum',num);
  1188. if (row.name == '在线编辑' || row.name == '协作') {
  1189. cliCC.value = true
  1190. }
  1191. if (row.name == '分享') {
  1192. workOrEdit.value = num
  1193. thanks.value = true
  1194. } else {
  1195. thanks.value = false
  1196. }
  1197. if (row.name == '协作') {
  1198. workOrEdit.value = num
  1199. if (anyP.value) {
  1200. anyP.value = false
  1201. } else {
  1202. anyP.value = true
  1203. }
  1204. } else {
  1205. anyP.value = false
  1206. }
  1207. if (row.name == '删除') {
  1208. ElMessageBox.confirm(
  1209. `是否确认删除名为"${clickRow.value.fileName}"的文件?`,
  1210. '系统提示',
  1211. {
  1212. confirmButtonText: '确认',
  1213. cancelButtonText: '取消',
  1214. type: 'warning',
  1215. }
  1216. )
  1217. .then(() => {
  1218. const has =hasThisTab(clickRowId.value)
  1219. if(has){
  1220. ElMessage({
  1221. type: "info",
  1222. message: "请先关闭文件"
  1223. })
  1224. return
  1225. }
  1226. myfile.delMenu(clickRowId.value).then(res => {
  1227. if (res.code === 200) {
  1228. ElMessage({
  1229. type: "success",
  1230. message: "删除成功"
  1231. })
  1232. // getAllTop()
  1233. refreshFile()
  1234. }
  1235. })
  1236. })
  1237. .catch(() => {
  1238. return
  1239. })
  1240. }
  1241. if (row.name === '复制到...') {
  1242. copyOrMove.value = 0
  1243. fileTrees.value = true
  1244. }
  1245. if (row.name === '移动到...') {
  1246. copyOrMove.value = 1
  1247. fileTrees.value = true
  1248. }
  1249. if (row.name === '重命名') {
  1250. const has = hasThisTab(copyRow.value.docId)
  1251. if(!has){
  1252. fileNameChange.value = true
  1253. }else{
  1254. ElMessage({
  1255. type: "info",
  1256. message: "请先关闭文件"
  1257. })
  1258. }
  1259. }
  1260. if (row.name === "下载") {
  1261. // location.href = `${import.meta.env.VITE_APP_BASE_API}/api/download/${copyFileId.value}`;
  1262. downLoadfile()
  1263. }
  1264. if (row.name === '收藏') {
  1265. if(clickRow.value.isFavorite === "Y"){
  1266. return ElMessage({
  1267. type: "error",
  1268. message: "请勿重复收藏"
  1269. })
  1270. }
  1271. collects.value = true
  1272. }
  1273. if (row.name === '文字识别') {
  1274. const itemData = {
  1275. name: '文字识别',
  1276. path: `/identifyFont`
  1277. }
  1278. const ocrData = {
  1279. docId: copyRow.value.docId,
  1280. fileId: copyRow.value.fileId,
  1281. fileType: copyFileType.value
  1282. }
  1283. window.parent.$setOpenTab(itemData)
  1284. sessionStorage.setItem('ocrData',JSON.stringify(ocrData))
  1285. sessionStorage.setItem('textData','')
  1286. sessionStorage.setItem('showImg','')
  1287. }
  1288. if (row.name === '打开') {
  1289. loadingPreview.value = true
  1290. const filePreview = canPreviewFile(copyFileType.value)
  1291. const canEditArr = ['.doc', '.docm', '.docx', '.dot', '.dotm', '.dotx', '.txt', '.djvu', '.xps', '.csv', '.fods', '.ods', '.ots', '.xls', '.xlsm', '.xlsx', '.xlt', '.xltm', '.xltx', '.fodp', '.odp', '.otp', '.doc', '.docm', '.docx', '.dot', '.dotm', '.dotx', '.epub', '.fodt', '.htm', '.html', '.mht', '.odt', '.ott', '.rtf', '.txt', '.djvu', '.xps', '.wps','.dps','.et', '.pptx','.pdf','.PDF']
  1292. if (filePreview) {
  1293. // 文件
  1294. getInfo(clickRow.value.docId).then((res)=>{
  1295. // console.log('res',res);
  1296. clickRow.value = res.data
  1297. if(clickRow.value.isFiled === "Y" || !canEditArr.includes(copyFileType.value) || !toRaw(thisRole.value).some(item=>item == "edit")){
  1298. //归档了或者不允许编辑的格式 就是预览
  1299. if(thisFolderRole.value &&thisFolderRole.value.roles&& thisFolderRole.value.roles.l0800){
  1300. const itemData = {
  1301. name: clickRow.value.fileName,
  1302. path: `${window.location.origin}/fileEdit?clickRowId=${clickRow.value.docId}&canEdit=0&canCopy=1&history=0&fileId=0`
  1303. }
  1304. // sessionStorage.setItem('newTab',JSON.stringify(itemData))
  1305. window.parent.$setOpenTab(itemData)
  1306. }else{
  1307. const itemData = {
  1308. name: clickRow.value.fileName,
  1309. path: `${window.location.origin}/fileEdit?clickRowId=${clickRow.value.docId}&canEdit=0&canCopy=0&history=0&fileId=0`
  1310. }
  1311. // sessionStorage.setItem('newTab',JSON.stringify(itemData))
  1312. window.parent.$setOpenTab(itemData)
  1313. }
  1314. }else{ // 编辑
  1315. //--------------------------
  1316. loadingPreview.value = false
  1317. if(thisFolderRole.value &&thisFolderRole.value.roles&& thisFolderRole.value.roles.l0800){
  1318. const itemData = {
  1319. name: clickRow.value.fileName,
  1320. path: `${window.location.origin}/fileEdit?clickRowId=${clickRow.value.docId}&canEdit=1&canCopy=1&history=0&fileId=0`
  1321. }
  1322. // sessionStorage.setItem('newTab',JSON.stringify(itemData))
  1323. window.parent.$setOpenTab(itemData)
  1324. }else{
  1325. const itemData = {
  1326. name: clickRow.value.fileName,
  1327. path: `${window.location.origin}/fileEdit?clickRowId=${clickRow.value.docId}&canEdit=1&canCopy=0&history=0&fileId=0`
  1328. }
  1329. // sessionStorage.setItem('newTab',JSON.stringify(itemData))
  1330. window.parent.$setOpenTab(itemData)
  1331. }
  1332. cliCC.value = false
  1333. loadingPreview.value = false
  1334. //---------------------------
  1335. }
  1336. })
  1337. onlyView.value = true
  1338. // editOnline.value = false
  1339. cliCC.value = false
  1340. } else {
  1341. const res = await preview(copyRow.value.docId)
  1342. showPreview.value = true
  1343. previewData.value = URL.createObjectURL(res)
  1344. }
  1345. loadingPreview.value = false
  1346. // console.log('filePreview', filePreview);
  1347. // // console.log('res',res);
  1348. // const res = await preview(copyFileId.value)
  1349. // showPreview.value = true
  1350. // previewData.value = URL.createObjectURL(res)
  1351. } else if (row.name === "历史版本") {
  1352. const resHistory = await listVersion({ docId: clickRowId.value })
  1353. historyTotal.value = resHistory.total
  1354. fileUserTreeData.data = resHistory.rows;
  1355. openForwardFile.value = true
  1356. }
  1357. }
  1358. //判断标签是否存在
  1359. const hasThisTab = (clickRowId) => {
  1360. const storage = sessionStorage.getItem("tagList");
  1361. if (storage) {
  1362. const oldStorage = JSON.parse(storage);
  1363. // 判断是否存在相同的标签
  1364. if (oldStorage.find((item) => item.path.includes(clickRowId))) {
  1365. // ElMessage({ message: "该页面已经打开", type: "info" });
  1366. return 1;
  1367. }else{
  1368. return 0;
  1369. }
  1370. }
  1371. };
  1372. function chooseSet1(num) {
  1373. workOrEdit.value = num
  1374. thanks.value = true
  1375. anyP.value = false
  1376. }
  1377. function createNewMenu(num,leftNewFiles) {
  1378. if (leftNewFiles) {
  1379. leftNewFile.value = true //解决左侧点击文件后不显示的问题
  1380. }else{
  1381. leftNewFile.value = false
  1382. }
  1383. upFolderData.value = null
  1384. oneOrTwo.value = num
  1385. folderCase.value = true
  1386. }
  1387. function cancleHistoryPrew(val) {
  1388. historyPrew.value = false
  1389. }
  1390. const closeOpen = ()=>{
  1391. openScan.value = false
  1392. }
  1393. function createNewFile() {
  1394. addFile.value = true
  1395. }
  1396. function arrowClick(row, num) {
  1397. if (row.name === '文件') {
  1398. uploadModal.value = true
  1399. } else {
  1400. uploadModal.value = false
  1401. }
  1402. }
  1403. // 确认上传
  1404. function sureUpload() {
  1405. loadingUpload.value = true;
  1406. if (useSpace.value * 1024 * 1024 + fileBig.value / 1024 > allSpace.value * 1024 * 1024) {
  1407. ElMessage({
  1408. message: "超过最大容量,请联系管理员扩容",
  1409. type: "error",
  1410. })
  1411. loadingUpload.value = false;
  1412. return
  1413. }
  1414. if (fileArr.value.length > 0) {
  1415. let form=new FormData();
  1416. for (var i = 0; i < fileArr.value.length; i++) {
  1417. form.append("files",fileArr.value[i]);
  1418. }
  1419. form.append("spaceId",newSpaceId.value)
  1420. form.append("dirId",newDirId.value)
  1421. // console.error(fileArr.value);
  1422. uploadApi.uploadFileMany(form).then(res => {
  1423. if (res.code === 200) {
  1424. ElMessage({
  1425. message: "上传文件成功",
  1426. type: "success"
  1427. })
  1428. // getAllTop()
  1429. refreshFile()
  1430. uploadModal.value = false
  1431. loadingUpload.value = false;
  1432. fileArr.value = []
  1433. fileBig.value = 0
  1434. }
  1435. }).catch(err => {
  1436. loadingUpload.value = false;
  1437. fileArr.value = []
  1438. })
  1439. } else {
  1440. loadingUpload.value = false;
  1441. return ElMessage({ message: "请选择文件", type: "error" })
  1442. }
  1443. }
  1444. function onSuccess(files, val) {
  1445. const maxSize = (maxFileSize.value-0)*1024*1024
  1446. if(files.file.size<maxSize){
  1447. fileArr.value.push(files.file)
  1448. }
  1449. }
  1450. //关闭文件上传
  1451. const closeUpload =() =>{
  1452. uploadModal.value = false;
  1453. fileArr.value = [];
  1454. fileBig.value = 0
  1455. loadingUpload.value = false
  1456. }
  1457. // 移除上传的某些文件
  1458. const handleRemove = (file,rawFile) => {
  1459. // fileArr.value = [...rawFile]
  1460. fileBig.value = fileBig.value - file.size
  1461. fileArr.value = rawFile.map(item=>{
  1462. if(item.raw){
  1463. return item.raw
  1464. }else{
  1465. return item
  1466. }
  1467. })
  1468. }
  1469. // 筛选后缀图片
  1470. function getImage(file) {
  1471. if (file === '.txt') {
  1472. return ImgFile.txt
  1473. } else if (file === '.xlxs' || file === '.docx') {
  1474. return ImgFile.xlxs
  1475. } else if (file === '.pptx') {
  1476. return ImgFile.pptx
  1477. } else if (file === '.word') {
  1478. return ImgFile.word
  1479. } else if (file === '.pdf') {
  1480. return ImgFile.pdf
  1481. }
  1482. }
  1483. // 表格多选框
  1484. function handleSelectionChange(val) {
  1485. delMoreFile.value = val //删除多项的数据
  1486. if (val.length) {
  1487. folderCheckout.value = true
  1488. haveCheck.value = true
  1489. } else {
  1490. folderCheckout.value = false
  1491. haveCheck.value = false
  1492. }
  1493. }
  1494. // 文件夹
  1495. function handleSelectionChange1(val) {
  1496. delMoreFolder.value = val //删除多项的数据
  1497. if (val.length) {
  1498. fileCheckout.value = true
  1499. haveCheck.value = true
  1500. }else{
  1501. haveCheck.value = false
  1502. fileCheckout.value = false
  1503. }
  1504. }
  1505. // 重命名
  1506. function restName(row, index) {
  1507. // 判断是点击打开还是右键菜单打开
  1508. row = row ? row : clickRow.value
  1509. copyFolderName.value = row.dirName
  1510. selectedBox.value = row.dirId
  1511. setTimeout(() => {
  1512. rename.value = true
  1513. }, 200);
  1514. }
  1515. async function getMenu(row, num,canDo) {
  1516. if (row.name === '删除') {
  1517. if(!canDo) return
  1518. ElMessageBox.confirm(
  1519. '是否确认删除文件?',
  1520. '系统提示',
  1521. {
  1522. confirmButtonText: '确认',
  1523. cancelButtonText: '取消',
  1524. type: 'warning',
  1525. }
  1526. )
  1527. .then(async () => {
  1528. const datas = delMoreFile.value.map(item=>{
  1529. return item.docId
  1530. })
  1531. let candel = false
  1532. await datas.forEach(item=>{
  1533. if(hasThisTab(item)){//删除的这批里面有打开的
  1534. ElMessage({
  1535. type: "info",
  1536. message: "请先关闭打开的文件"
  1537. })
  1538. candel = true
  1539. return
  1540. }
  1541. })
  1542. if(candel)return
  1543. const filesStr = datas.join(',')
  1544. loadingPreview.value = true
  1545. // console.log('filesStr',filesStr);
  1546. delInfo(filesStr).then(res=>{
  1547. if (res.code === 200) {
  1548. ElMessage({
  1549. message: "删除成功",
  1550. type: "success"
  1551. })
  1552. // getAllTop()
  1553. loadingPreview.value = false
  1554. refreshFile()
  1555. }
  1556. })
  1557. })
  1558. .catch(() => {
  1559. return false
  1560. })
  1561. }
  1562. }
  1563. function delName(row, num) {
  1564. row = row ? row : clickRow.value
  1565. ElMessageBox.confirm(
  1566. `是否确认删除名为"${row.dirName}"的文件夹?`,
  1567. '系统提示',
  1568. {
  1569. confirmButtonText: '确认',
  1570. cancelButtonText: '取消',
  1571. type: 'warning',
  1572. }
  1573. )
  1574. .then(() => {
  1575. documents.delDocument(row.dirId).then(res => {
  1576. if (res.code === 200) {
  1577. // 如果当前打开的是要删除的这个文件夹
  1578. if(thisFolder.value.dirId === row.dirId){
  1579. getAllTop()
  1580. pathLabelData.value = []
  1581. }else{
  1582. getFirstFolder()
  1583. }
  1584. getSpaceList()
  1585. ElMessage({
  1586. message: "删除成功",
  1587. type: "success"
  1588. })
  1589. delFolder(row)
  1590. }
  1591. })
  1592. })
  1593. .catch(() => {
  1594. return false
  1595. })
  1596. }
  1597. const delFolder = (row)=>{
  1598. delFolderDataFn(row)
  1599. // console.log('tableData',tableData);
  1600. }
  1601. // 计算百分比
  1602. function percent() {
  1603. let numP = 0;
  1604. if (useSpace.value && allSpace.value) {
  1605. numP = (useSpace.value / allSpace.value) * 100;
  1606. }
  1607. if(numP<0)return 0
  1608. if(numP>100)return 100
  1609. return numP.toFixed(2) - 0; // 将结果保留两位小数
  1610. }
  1611. // 文件夹每行点击事件
  1612. function folderClick(row, list,e,jump) {
  1613. if(!pathLabelData.value[0]&& leftShowList.value === 2){
  1614. // 创建标签
  1615. const addData = {
  1616. path: '/department' + row.dirId,
  1617. name: row.dirName,
  1618. clickRowId: toRaw(row)
  1619. }
  1620. addFolderAdd(addData)
  1621. }
  1622. // 初始化分页数据
  1623. tableBeEnd.value = true
  1624. filePageNum.value = 1
  1625. tableTotal.value = 0
  1626. // 上一级dirId就是下一级的parentId
  1627. // 判断是点击打开还是右键菜单打开
  1628. if(row){
  1629. backFolder.value = thisFolder.value
  1630. thisFolder.value = row;
  1631. if(pathLabelData.value[0]){
  1632. // 有值就说明是二级及以后的数据
  1633. const oldArr = toRaw(pathLabelData.value)
  1634. let newArr
  1635. if(jump == undefined){
  1636. newArr = oldArr.push({
  1637. name:toRaw(row).dirName,
  1638. dirId:toRaw(row).dirId
  1639. })
  1640. }else{ // jump有值说明是点击过来的 后面的要截取掉
  1641. newArr = oldArr.splice(jump+1)
  1642. }
  1643. pathLabelData.value = JSON.parse(JSON.stringify(oldArr))
  1644. }else{
  1645. const labelItem = {
  1646. name:row.dirName,
  1647. dirId:row.dirId
  1648. }
  1649. pathLabelData.value = [labelItem]
  1650. }
  1651. }else{
  1652. row =thisFolder.value
  1653. }
  1654. if(row.isEncrypt === "Y" && row.encryptLevel){
  1655. getLeveldetailFn(row.encryptLevel)
  1656. }else{
  1657. thisFolderRole.value = {}
  1658. }
  1659. thisRole.value = row.dirRole?row.dirRole.split(','):[]
  1660. // console.log('row1', toRaw(row));
  1661. // topPath.value = row.dirPath
  1662. // console.log('topPath',toRaw(topPath.value));
  1663. newDirId.value = row.dirId
  1664. newSpaceId.value = row.spaceId
  1665. const query = `${newDirId.value}?isAsc=${isAsc.value}&orderByColumn=createTime&pageSize=9999&pageNum=${filePageNum.value}`
  1666. documents.getALLdocumentByType({
  1667. parentId: newDirId.value - 0,
  1668. spaceId: newSpaceId.value - 0,
  1669. isAsc: isAsc.value,
  1670. orderByColumn: "createTime"
  1671. },2).then(res => {
  1672. folderList.value = res.rows
  1673. if (res.rows.length === 0) {
  1674. myfile.getById(query).then(res => {
  1675. if (res.code === 200) {
  1676. tableTotal.value =res.total
  1677. if(res.rows.length<res.total){
  1678. //第一次拿到的数据少于总数开启下拉事件
  1679. tableBeEnd.value = false
  1680. }
  1681. fileList.value = res.rows
  1682. }
  1683. })
  1684. } else {
  1685. myfile.getById(query).then(res => {
  1686. if (res.code === 200) {
  1687. tableTotal.value =res.total
  1688. if(res.rows.length<res.total){
  1689. //第一次拿到的数据少于总数开启下拉事件
  1690. tableBeEnd.value = false
  1691. }
  1692. fileList.value = JSON.parse(JSON.stringify(res.rows))
  1693. // console.log('fileList',toRaw(fileList.value));
  1694. }
  1695. })
  1696. }
  1697. })
  1698. setTimeout(() => {
  1699. sessionStorage.setItem('folderArr','')
  1700. }, 1500);
  1701. }
  1702. // 左边树节点每行点击事件
  1703. function listfolderClick(row,firstData) {
  1704. leftNewFile.value = false
  1705. if(row){
  1706. thisFolder.value = row
  1707. }
  1708. row = row?row:thisFolder.value
  1709. if (row.isEncrypt === "Y") {
  1710. getLeveldetailFn(row.encryptLevel)
  1711. } else {
  1712. thisFolderRole.value = null
  1713. }
  1714. thisRole.value = row.dirRole?row.dirRole.split(','):[]
  1715. // console.log('row',row);
  1716. // console.log('rowthisFolderRole',thisFolderRole.value);
  1717. newDirId.value = row.dirId
  1718. newSpaceId.value = row.spaceId
  1719. const query = `${newDirId.value}?isAsc=${isAsc.value}&orderByColumn=createTime&pageSize=9999&pageNum=1`
  1720. documents.getALLdocumentByType({
  1721. parentId: newDirId.value - 0,
  1722. spaceId: newSpaceId.value - 0,
  1723. isAsc: isAsc.value,
  1724. orderByColumn: "createTime"
  1725. }, 2).then(res => {
  1726. folderList.value = res.rows
  1727. if (res.rows.length === 0) {
  1728. myfile.getById(query).then(res => {
  1729. // console.log('res = ',res);
  1730. if (res.code === 200) {
  1731. tableTotal.value = res.total
  1732. if (res.rows.length < res.total) {
  1733. //第一次拿到的数据少于总数开启下拉事件
  1734. tableBeEnd.value = false
  1735. }
  1736. fileList.value = JSON.parse(JSON.stringify(res.rows))
  1737. }
  1738. // console.log('folderClickshijian1',tableTotal.value,tableBeEnd.value);
  1739. })
  1740. } else {
  1741. myfile.getById(query).then(res => {
  1742. if (res.code === 200) {
  1743. tableTotal.value = res.total
  1744. if (res.rows.length < res.total) {
  1745. //第一次拿到的数据少于总数开启下拉事件
  1746. tableBeEnd.value = false
  1747. }
  1748. fileList.value = JSON.parse(JSON.stringify(res.rows))
  1749. }
  1750. // console.log('fileList',fileList.value);
  1751. })
  1752. }
  1753. })
  1754. }
  1755. // 确认文件重命名
  1756. function sureChangeName() {
  1757. myfile.editNewMenu({
  1758. dirId: copyDirId.value - 0,
  1759. docId: clickRowId.value - 0,
  1760. fileId: copyFileId.value,
  1761. fileName: nameForm.value.name,
  1762. fileSize: copyFileSize.value - 0,
  1763. fileType: copyFileType.value,
  1764. remark: '',
  1765. spaceId: copySpaceId.value - 0,
  1766. }).then(res => {
  1767. if (res.code === 200) {
  1768. ElMessage({
  1769. message: "重命名成功",
  1770. type: "success"
  1771. })
  1772. // upFileData({
  1773. // docId:clickRowId.value - 0,
  1774. // fileName:nameForm.value.name
  1775. // })
  1776. fileNameChange.value = false
  1777. refreshFile()
  1778. }
  1779. })
  1780. }
  1781. // 判断id
  1782. function isId() {
  1783. if (directoryId.value === '') {
  1784. directoryId.value = 0
  1785. getAllTop()
  1786. }
  1787. if (folderId.value === '') {
  1788. folderId.value = 0
  1789. getAllTop()
  1790. }
  1791. }
  1792. //关闭图片预览事件
  1793. const closeImgPreview = () => {
  1794. // console.log('close');
  1795. showPreview.value = false
  1796. }
  1797. function getChildren(data) {
  1798. fileTrees.value = data
  1799. refreshFile()
  1800. }
  1801. function getCback(data) {
  1802. thanks.value = data
  1803. }
  1804. function getChildrenC(data) {
  1805. folderCase.value = data
  1806. }
  1807. function getCollects(data) {
  1808. collects.value = data
  1809. }
  1810. function getRename() {
  1811. rename.value = false
  1812. }
  1813. function getSpaceC(data) {
  1814. spaces.value = data
  1815. }
  1816. function navBack(data, name) {
  1817. nameForm.value.name = name
  1818. fileNameChange.value = data
  1819. }
  1820. function onlineCase(data, uid, row) {
  1821. editOnline.value = data
  1822. clickRowId.value = uid
  1823. copyRow = row
  1824. }
  1825. function shareBack(data, num) {
  1826. thanks.value = data
  1827. workOrEdit.value = num
  1828. }
  1829. function showFile(data, e, a) {
  1830. editOnline.value = data
  1831. clickRowId.value = e
  1832. copyRow = a
  1833. }
  1834. function folderBack(dir, spa, nam) {
  1835. selectedBox.value = dir
  1836. copyFolderName.value = nam
  1837. copyFileName.value = spa
  1838. }
  1839. //历史版本
  1840. const forwardTreeData = reactive({ data: {} });
  1841. const historycopyRow = ref({})
  1842. function changeMsgClose(val, item) {
  1843. if (val) {
  1844. historycopyRow.value = item
  1845. editOnline.value = false
  1846. cliCC.value = false
  1847. historyPrew.value = true
  1848. }
  1849. openForwardFile.value = val
  1850. }
  1851. function lastBB(data, row, num) {
  1852. openForwardFile.value = data
  1853. historyTotal.value = row
  1854. fileUserTreeData.data = num
  1855. }
  1856. //对mouseCli数组进行筛选,实现菜单的区分显示
  1857. const filterMouseCli = () => {
  1858. const canPreviewArray = ['.doc','.dps','.et','.wps', '.docm', '.docx', '.dot', '.dotm', '.dotx', '.epub', '.fodt', '.htm', '.html', '.mht', '.odt', '.ott', '.pdf', '.rtf', '.txt', '.djvu', '.xps', '.csv', '.fods', '.ods', '.ots', '.xls', '.xlsm', '.xlsx', '.xlt', '.xltm', '.xltx', '.fodp', '.odp', '.otp', '.pot', '.potm', '.potx', '.pps', '.ppsm', '.ppsx', '.ppt', '.pptm', '.pptx']
  1859. const typeArr = ['.png', '.jpg', '.jpeg', '.JPG','.PNG', '.mp3', '.mp4']
  1860. const imgTypeArr = ['.png', '.jpg', '.jpeg', '.JPG','.PNG','.webg']
  1861. const canEditArr = ['.doc', '.dps','.et','.docm', '.docx', '.dot', '.dotm', '.dotx', '.txt', '.djvu', '.xps', '.csv', '.fods', '.ods', '.ots', '.xls', '.xlsm', '.xlsx', '.xlt', '.xltm', '.xltx', '.fodp', '.odp', '.otp','.doc', '.docm', '.docx', '.dot', '.dotm', '.dotx', '.epub', '.fodt', '.htm', '.html', '.mht', '.odt', '.ott', '.rtf', '.txt', '.djvu', '.xps', '.wps','.pptx','.pdf','.PDF']
  1862. let arr = []
  1863. //如果带有(重命名)-前缀 只允许进行重命名操作
  1864. const regExp = /^\(重命名\)-/
  1865. if(regExp.test(clickRow.value.fileName)){
  1866. return arr = mouseCli.value.filter(item => item.name === "重命名")
  1867. }
  1868. if (!(typeArr.includes(copyFileType.value) || canPreviewArray.includes(copyFileType.value))) {
  1869. arr = mouseCli.value.filter(item => item.name !== "打开")
  1870. } else {
  1871. arr = toRaw(mouseCli.value)
  1872. }
  1873. if (!canEditArr.includes(copyFileType.value)) {
  1874. arr = arr.filter(item => item.name !== "在线编辑" && item.name !== "协作" && item.name !== "历史版本")
  1875. }
  1876. if (!imgTypeArr.includes(copyFileType.value)) {
  1877. arr = arr.filter(item => item.name !== "文字识别")
  1878. }
  1879. // console.log('thisFolderRole',thisFolderRole.value);
  1880. if(thisFolderRole.value?.roles){
  1881. // 加密登记
  1882. // console.log('thisFolderRole',thisFolderRole.value);
  1883. arr = rightMenuRole(toRaw(thisFolderRole.value),arr)
  1884. }
  1885. // console.log('thisRole.value',thisRole.value);
  1886. if(thisRole.value.length){
  1887. //权限
  1888. arr = publicRightMenuRole(toRaw(thisRole.value),arr)
  1889. }
  1890. if(thisFolder.value.dirType == '1' && !isDept.value){
  1891. arr = ordinaryFolder.value
  1892. }
  1893. if(arr.length<1){
  1894. noMenuItem.value = true
  1895. }else{
  1896. noMenuItem.value = false
  1897. }
  1898. return arr
  1899. }
  1900. function mouseClick() {
  1901. // console.log(1);
  1902. if (cliCC.value) {
  1903. cliCC.value = false
  1904. }
  1905. if (anyP) {
  1906. anyP.value = false
  1907. }
  1908. }
  1909. // 文件夹右键事件
  1910. const folderRClick = (row, col, e) => {
  1911. e.preventDefault();
  1912. e.stopPropagation();
  1913. // thisFolder.value = '' //先清空
  1914. let thisRow = toRaw(row)
  1915. // console.log('thisFolder',thisFolder.value);
  1916. clickRow.value = thisRow
  1917. copyFolderName.value = row.dirName
  1918. // 唤出右键菜单,思路:获取鼠标位置来定位菜单
  1919. folderVisible.value = true;
  1920. foldertop.value = e.pageY;
  1921. folderleft.value = e.pageX;
  1922. };
  1923. // 关闭文件夹右键菜单
  1924. const closeRMenu = () => {
  1925. // console.log("close");
  1926. folderVisible.value = false;
  1927. };
  1928. // 关闭tree右键菜单
  1929. const closeTreeRMenu = () => {
  1930. // console.log("close");
  1931. showTreeMenu.value = false;
  1932. };
  1933. // 文件夹收藏事件
  1934. const collectFolder = () => {
  1935. if(clickRow.value.isFavorite === "Y"){
  1936. return ElMessage({
  1937. type: "error",
  1938. message: "请勿重复收藏"
  1939. })
  1940. }
  1941. isFolder.value = 'Y'
  1942. // clickRow.value = thisFolder.value
  1943. // thisFolder.value = ''
  1944. copyFileName.value = clickRow.value.dirName
  1945. collects.value = true
  1946. }
  1947. // 左箭头事件
  1948. const arrowLift =async () => {
  1949. // router.go(-1)
  1950. // console.log(1);
  1951. topPath.value = backFolder.value.dirPath
  1952. // console.log('topPath',toRaw(topPath.value));
  1953. newDirId.value = backFolder.value.parentId
  1954. newSpaceId.value = backFolder.value.spaceId
  1955. documents.getALLdocumentByType({
  1956. parentId: newDirId.value - 0,
  1957. spaceId: newSpaceId.value - 0
  1958. },2).then(res => {
  1959. folderList.value = res.rows
  1960. if (res.rows.length === 0) {
  1961. myfile.getById(newDirId.value).then(res => {
  1962. if (res.code === 200) {
  1963. fileList.value = res.rows
  1964. }
  1965. })
  1966. } else {
  1967. myfile.getById(newDirId.value).then(res => {
  1968. if (res.code === 200) {
  1969. fileList.value = JSON.parse(JSON.stringify(res.rows))
  1970. // console.log('fileList',toRaw(fileList.value));
  1971. }
  1972. })
  1973. }
  1974. })
  1975. }
  1976. // 归档
  1977. function goLock() {
  1978. fileCount.lockActor(clickRowId.value).then(res => {
  1979. if (res.code === 200) {
  1980. ElMessage({
  1981. type: "success",
  1982. message: "归档成功"
  1983. })
  1984. cliCC.value = false
  1985. anyP.value = false
  1986. }
  1987. })
  1988. }
  1989. function formatFileSize(fileSize) {
  1990. if (fileSize >= 1024 * 1024 * 1024) {
  1991. // 大于等于1GB,显示GB
  1992. return (fileSize / (1024 * 1024 * 1024)).toFixed(2) + 'GB';
  1993. } else if (fileSize >= 1024 * 1024) {
  1994. // 大于等于1MB,显示MB
  1995. return (fileSize / (1024 * 1024)).toFixed(2) + 'MB';
  1996. } else if (fileSize >= 1024) {
  1997. // 大于等于1KB,显示KB
  1998. return (fileSize / 1024).toFixed(2) + 'KB';
  1999. } else {
  2000. // 小于1KB,显示字节
  2001. return fileSize + 'B';
  2002. }
  2003. }
  2004. function formatStorage(sizeInGB) {
  2005. if(sizeInGB<=0) return "0KB"
  2006. if (sizeInGB >= 1) {
  2007. return sizeInGB.toFixed(2) + 'GB';
  2008. } else {
  2009. const sizeInMB = sizeInGB * 1024;
  2010. if (sizeInMB >= 1) {
  2011. return sizeInMB.toFixed(2) + 'MB';
  2012. } else {
  2013. const sizeInKB = sizeInMB * 1024;
  2014. return sizeInKB.toFixed(2) + 'KB';
  2015. }
  2016. }
  2017. }
  2018. //刷新
  2019. const refreshFile = (left,edit)=>{
  2020. // console.log('ref',toRaw(thisFolder.value));
  2021. if(left){
  2022. leftNewFile.value = true
  2023. }
  2024. if(edit){
  2025. getFirstFolder()
  2026. }
  2027. if (toRaw(thisFolder.value)?.dirId && !leftNewFile.value && leftShowList.value === 2 ) {//如果点开了文件夹
  2028. folderClick()
  2029. } else if(toRaw(thisFolder.value)?.dirId && !leftNewFile.value && leftShowList.value === 1){
  2030. listfolderClick()
  2031. }else {
  2032. getAllTop()
  2033. getFirstFolder()
  2034. }
  2035. getSpaceList()
  2036. }
  2037. //star收藏事件
  2038. const collectByStar = (row,isfolder)=>{
  2039. // console.log('row',row);
  2040. if(isfolder){
  2041. let thisRow = toRaw(row)
  2042. isFolder.value = 'Y'
  2043. clickRow.value = thisRow
  2044. copyFolderName.value = row.dirName
  2045. copyFileName.value = clickRow.value.dirName
  2046. }else{
  2047. isFolder.value = "N"
  2048. clickRow.value = row
  2049. copyRow.value = row
  2050. clickRowId.value = row.docId
  2051. copyDirId.value = row.dirId
  2052. copyFileName.value = row.fileName
  2053. }
  2054. collects.value = true
  2055. }
  2056. const backTopPath = ()=>{
  2057. // pathLabelData.value = ([])
  2058. // getAllTop()
  2059. const addData = {
  2060. path: '/department',
  2061. label: '部门文件'
  2062. }
  2063. clickPath(null,addData)
  2064. }
  2065. // 取消文件收藏
  2066. const delCollect = async (row,isfolder)=>{
  2067. const thisRow = toRaw(row)
  2068. let query = {}
  2069. if(isfolder){
  2070. query = {
  2071. isFolder:"Y",
  2072. relaId:thisRow.dirId
  2073. }
  2074. }else{
  2075. query = {
  2076. isFolder:"N",
  2077. relaId:thisRow.docId
  2078. }
  2079. }
  2080. const res = await delFavorite(query)
  2081. ElMessage({
  2082. type: "success",
  2083. message: "已取消收藏"
  2084. })
  2085. refreshFile()
  2086. }
  2087. //获取安全图标
  2088. const getLevelImg = (level)=>{
  2089. switch (level) {
  2090. case "L1":
  2091. return level1;
  2092. break;
  2093. case "L2":
  2094. return level2;
  2095. break;
  2096. case "L3":
  2097. return level3;
  2098. break;
  2099. case "L4":
  2100. return level4;
  2101. break;
  2102. return level1;
  2103. break;
  2104. }
  2105. }
  2106. const getLevelList = async ()=>{
  2107. const res = await getLevel()
  2108. if(res.rows){
  2109. levelList.value = res.rows.map(item=>{
  2110. return {
  2111. levelCode:item.levelCode,
  2112. levelName:item.levelName
  2113. }
  2114. })
  2115. }
  2116. }
  2117. const setImg = (type)=>{
  2118. return setIcon(type)
  2119. }
  2120. const setTablelevel = (level)=>{
  2121. const thisItem = levelList.value.find(item=>item.levelCode == level)
  2122. if(thisItem){
  2123. return thisItem.levelName
  2124. }else{
  2125. return '未加密'
  2126. }
  2127. }
  2128. //获取权限详情
  2129. const getLeveldetailFn =async (data)=>{
  2130. const res = await getLeveldetail(data)
  2131. // console.log('getLeveldetailFn',res);
  2132. if(res.code === 200){
  2133. thisFolderRole.value = res.data
  2134. thisFolderRole.value.accessCode = thisFolder.value.accessCode
  2135. }
  2136. // console.log('thisFolderRole',thisFolderRole.value);
  2137. }
  2138. const closeIptPass = ()=>{
  2139. showInputPassword.value = false
  2140. }
  2141. //输入验证密码后
  2142. const surePass = (pass)=>{
  2143. const passwordCookies = Cookies.get("pass");
  2144. // const oldPass = decrypt(passwordCookies)
  2145. // console.log('pass',pass);
  2146. // console.log('oldPass',oldPass);
  2147. // console.log('clickRow',clickRow);
  2148. showInputPassword.value = false
  2149. if(pass === passwordCookies){
  2150. const passArr = localStorage.getItem('passArr');
  2151. // console.log('passArr',passArr);
  2152. if(!passArr){
  2153. const newArr = []
  2154. newArr.push(clickRow.value.docId)
  2155. localStorage.setItem('passArr',JSON.stringify(newArr))
  2156. }else{
  2157. const passArrObj = JSON.parse(passArr)
  2158. passArrObj.push(clickRow.value.docId)
  2159. localStorage.setItem('passArr',JSON.stringify(passArrObj))
  2160. }
  2161. // 设置销毁
  2162. setTimeout(()=>{
  2163. const passArr = localStorage.getItem('passArr');
  2164. const passArrObj = JSON.parse(passArr)
  2165. const newArr = passArrObj.filter(item=>item != clickRow.value.docId)
  2166. localStorage.setItem('passArr',JSON.stringify(newArr))
  2167. },1000*30)
  2168. chooseSet(chooseRow.value,null,chooseNum.value)
  2169. }else{
  2170. ElMessage({ message: "验证失败", type: "error" })
  2171. }
  2172. }
  2173. //输入私有码后
  2174. const sureCode =async (pass) => {
  2175. // console.log('oldPass',passwordCookies);
  2176. // console.log('clickRow',clickRow);
  2177. const query={
  2178. code:pass,
  2179. dirId:thisFolder.value.dirId
  2180. }
  2181. const res = await documents.matches(query)
  2182. showInputPassword.value = false
  2183. if (res.data) {
  2184. const codeArr = localStorage.getItem('codeArr');
  2185. // console.log('passArr',passArr);
  2186. if (!codeArr) {
  2187. const newArr = []
  2188. newArr.push(clickRow.value.docId)
  2189. localStorage.setItem('codeArr', JSON.stringify(newArr))
  2190. } else {
  2191. const codeArrObj = JSON.parse(codeArr)
  2192. codeArrObj.push(clickRow.value.docId)
  2193. localStorage.setItem('codeArr', JSON.stringify(codeArrObj))
  2194. }
  2195. // 设置销毁
  2196. setTimeout(() => {
  2197. const codeArr = localStorage.getItem('codeArr');
  2198. const codeArrObj = JSON.parse(codeArr)
  2199. // console.log('```passArrObj',passArrObj);
  2200. const newArr = codeArrObj.filter(item => item != clickRow.value.docId)
  2201. // console.log('```newArr',newArr);
  2202. localStorage.setItem('codeArr', JSON.stringify(newArr))
  2203. }, 1000 * 30)
  2204. chooseSet(chooseRow.value, null, chooseNum.value)
  2205. } else {
  2206. ElMessage({ message: "验证失败", type: "error" })
  2207. }
  2208. }
  2209. const downLoadfile = ()=>{
  2210. myfile.fileDown(clickRow.value.docId).then(res=>{
  2211. var reader = new FileReader();
  2212. reader.onloadend = function(event){
  2213. //event 就是你要的返回内容
  2214. //因为返回的报错格式是字符串,手动转换成对象,转换成功表示请求失败
  2215. //转换失败就意味着你拿到的result是文件流,那么直接手动下载就好
  2216. try{
  2217. let data = JSON.parse(event.target.result)
  2218. }catch(err){
  2219. const link = document.createElement('a'); // 创建a标签
  2220. let blob = new Blob([res]);
  2221. link.style.display = 'none';
  2222. link.href = URL.createObjectURL(blob); // 创建下载的链接
  2223. link.setAttribute('download', clickRow.value.fileName+clickRow.value.fileType); // 给下载后的文件命名
  2224. document.body.appendChild(link);
  2225. link.click(); // 点击下载
  2226. document.body.removeChild(link); // 完成移除元素
  2227. window.URL.revokeObjectURL(link.href); // 释放blob对象
  2228. }
  2229. };
  2230. reader.readAsText(res);
  2231. })
  2232. }
  2233. // 触底加载事件
  2234. const setScroll =async ()=>{
  2235. if(tableBeEnd.value)return
  2236. // console.log('tableBeEnd.value',tableBeEnd.value);
  2237. filePageNum.value = filePageNum.value+1
  2238. const query = `${thisFolder.value.dirId}?pageSize=9999&pageNum=${filePageNum.value}`
  2239. // -------------先禁止掉事件 定时器1秒钟后才能再次触发
  2240. tableBeEnd.value = true
  2241. // --------------------
  2242. const res = await myfile.getById(query)
  2243. if (res.code === 200) {
  2244. // const newarr = res.rows.concat(toRaw(fileList.value))
  2245. const newarr = toRaw(fileList.value).concat(res.rows)
  2246. fileList.value = JSON.parse(JSON.stringify(newarr))
  2247. if(newarr.length < tableTotal.value){
  2248. //获取后的数量<total就可以再次获取
  2249. setTimeout(()=>{
  2250. tableBeEnd.value = false
  2251. },1000)
  2252. }
  2253. }
  2254. // console.log('query',query);
  2255. // console.log('fileList',fileList.value);
  2256. }
  2257. // 获取用户信息
  2258. const getUserInfo =async ()=>{
  2259. const userStore = useUserStore();
  2260. const userId = toRaw(userStore.roles)
  2261. if(userId.some(item=>item == 'dept')){
  2262. isDept.value = true
  2263. }else{
  2264. isDept.value = false
  2265. }
  2266. // console.log('isDept',isDept.value);
  2267. }
  2268. //修改文件夹权限
  2269. const upFirstFoler =async (item)=>{
  2270. oneOrTwo.value = item?1:0
  2271. // console.log('upFirstFoler',item);
  2272. item = item || clickRow.value
  2273. const res = await myfile.getDir(item.dirId)
  2274. upFolderData.value = toRaw(res.data)
  2275. folderCase.value = true
  2276. }
  2277. const upBefore = (file,files)=>{
  2278. // console.log('file',file.size);
  2279. const maxSize = (maxFileSize.value-0)*1024*1024
  2280. // console.log('maxSize',maxSize);
  2281. if(file.size>maxSize){
  2282. files.pop()
  2283. ElMessage({ message: file.name+'上传失败,上传文件大小最大为'+maxFileSize.value+'M', type: 'error' })
  2284. }else{
  2285. fileBig.value = file.size + fileBig.value
  2286. // fileArr.value.push(file.raw)
  2287. }
  2288. }
  2289. //获取扫描仪列表
  2290. const scannerFile =async ()=>{
  2291. const res = await selectInfo()
  2292. scannerList.value = res.rows
  2293. checkScanner.value = true
  2294. checkScanId.value = null
  2295. // console.log('scanner',res);
  2296. }
  2297. // 选择扫描仪
  2298. const checkScanFn = (item)=>{
  2299. checkScanId.value = item.scannerId
  2300. }
  2301. // 确认选择扫描仪 获取扫描仪下文件列表
  2302. const sureScaner =async ()=>{
  2303. if(!checkScanId.value) return
  2304. const res = await getFileByScanerId(checkScanId.value)
  2305. scannerFiles.value = res.data
  2306. checkScanner.value = false
  2307. openScan.value = true
  2308. }
  2309. // 关闭窗口
  2310. const closeCheckScanner = ()=>{
  2311. checkScanner.value = false
  2312. }
  2313. // 移动到事件
  2314. const saveScanFile = (arr)=>{
  2315. openScan.value = false
  2316. scanFileArr.value = arr
  2317. openScanMove.value = true
  2318. }
  2319. // 关闭窗口
  2320. const closeOpenScanMove = ()=>{
  2321. openScanMove.value = false
  2322. refreshFile()
  2323. }
  2324. const changeLeftShow = ()=>{
  2325. leftShowList.value = leftShowList.value == 1?2:1
  2326. if(leftShowList.value == 2){
  2327. getFirstFolder()
  2328. fileList.value = []
  2329. }else{
  2330. refreshFile()
  2331. }
  2332. thisFolder.value = {}
  2333. localStorage.setItem('leftShowList',leftShowList.value)
  2334. if(leftShowList.value === 1){
  2335. // 创建标签
  2336. const addData = {
  2337. path: '/department',
  2338. label: '部门文件'
  2339. }
  2340. clickPath(null,addData)
  2341. }
  2342. if(leftShowList.value === 2){
  2343. // 创建标签
  2344. const addData = {
  2345. path: '/department',
  2346. label: '部门文件'
  2347. }
  2348. clickPath(null,addData)
  2349. }
  2350. }
  2351. // 别处过来需要层层打开的文件夹
  2352. const openFolderPath = ()=>{
  2353. const FolderStr = sessionStorage.getItem('folderArr')
  2354. let foldersArr
  2355. if(FolderStr){
  2356. foldersArr = JSON.parse(FolderStr)
  2357. }else{
  2358. return
  2359. }
  2360. const oldLabelData = []
  2361. foldersArr.forEach((item,index)=>{
  2362. if(index<foldersArr.length - 1){
  2363. oldLabelData.push({
  2364. name:item.dirName,
  2365. dirId:item.dirId
  2366. })
  2367. }
  2368. })
  2369. pathLabelData.value = JSON.parse(JSON.stringify(oldLabelData))
  2370. // 打开文件夹
  2371. folderClick(foldersArr[foldersArr.length - 1])
  2372. // sessionStorage.setItem('folderArr','')
  2373. // console.log('pathLabelData',pathLabelData.value);
  2374. }
  2375. const delFolderMenu = ()=>{
  2376. ElMessageBox.confirm(
  2377. `是否确认删除名为"${clickRow.value.dirName}"的文件夹?`,
  2378. '系统提示',
  2379. {
  2380. confirmButtonText: '确认',
  2381. cancelButtonText: '取消',
  2382. type: 'warning',
  2383. }
  2384. )
  2385. .then(() => {
  2386. documents.delDocument(clickRow.value.dirId).then(res => {
  2387. if (res.code === 200) {
  2388. ElMessage({
  2389. message: "删除成功",
  2390. type: "success"
  2391. })
  2392. if(!thisFolder.value?.dirId){
  2393. delFolderDataFn(clickRow.value)
  2394. }
  2395. // getAllTop()
  2396. refreshFile()
  2397. } else {
  2398. ElMessage({
  2399. message: "删除失败,目录应不为空",
  2400. type: "error"
  2401. })
  2402. }
  2403. })
  2404. })
  2405. .catch(() => {
  2406. return false
  2407. })
  2408. }
  2409. watch(() => folder.value, async(newValue, oldValue) => {
  2410. // console.log('iFrameData 发生改变了', newValue, oldValue);
  2411. filePageNum.value = 1
  2412. if(!newValue.length){
  2413. fileHeight.value = '75vh'
  2414. if(!thisFolder.value.dirId)return
  2415. if(fileGrid.value == 0){
  2416. pageSize.value = 20
  2417. }else{
  2418. pageSize.value = 80
  2419. }
  2420. const query = `${thisFolder.value.dirId}?pageSize=9999&pageNum=${filePageNum.value}`
  2421. const res = await myfile.getById(query)
  2422. // console.log('filessetScrollres',res);
  2423. if (res.code === 200) {
  2424. // const newarr = res.rows.concat(toRaw(fileList.value))
  2425. const newarr = res.rows
  2426. fileList.value = JSON.parse(JSON.stringify(newarr))
  2427. if(newarr.length < tableTotal.value){
  2428. //获取后的数量<total就可以再次获取
  2429. setTimeout(()=>{
  2430. tableBeEnd.value = false
  2431. },1000)
  2432. }
  2433. }
  2434. }else{
  2435. if(fileGrid.value == 0){
  2436. pageSize.value = 10
  2437. }else{
  2438. pageSize.value = 50
  2439. }
  2440. fileHeight.value = '38vh'
  2441. if(!thisFolder.value.dirId)return
  2442. const query = `${thisFolder.value.dirId}?pageSize=9999&pageNum=${filePageNum.value}`
  2443. const res = await myfile.getById(query)
  2444. // console.log('filessetScrollres',res);
  2445. if (res.code === 200) {
  2446. // const newarr = res.rows.concat(toRaw(fileList.value))
  2447. const newarr = res.rows
  2448. fileList.value = JSON.parse(JSON.stringify(newarr))
  2449. if(newarr.length < tableTotal.value){
  2450. //获取后的数量<total就可以再次获取
  2451. setTimeout(()=>{
  2452. tableBeEnd.value = false
  2453. },1000)
  2454. }
  2455. }
  2456. }
  2457. });
  2458. onMounted(() => {
  2459. const hasMsg = localStorage.getItem('leftShowList')
  2460. if (route.query.clickRowId) {
  2461. const newRow = JSON.parse(route.query.clickRowId)
  2462. collectId.value = newRow
  2463. }
  2464. if(!hasMsg){
  2465. getConfigKey("dir.style.config").then(response => {
  2466. leftShowList.value = response.msg - 0;
  2467. });
  2468. }else{
  2469. leftShowList.value = hasMsg - 0
  2470. }
  2471. getAllTop()
  2472. getSpaceList()
  2473. getUserInfo()
  2474. getLevelList()
  2475. getConfigKey("file.size.limit").then(response => {
  2476. // console.log('response',response);
  2477. maxFileSize.value = response.msg
  2478. });
  2479. openFolderPath()
  2480. // 添加监听,点击其他地方关闭文件夹右键菜单
  2481. window.addEventListener("click", closeRMenu, true);
  2482. window.addEventListener("contextmenu", closeRMenu, true);
  2483. window.addEventListener("mousewheel", mouseClick, true);
  2484. window.addEventListener("click", mouseClick, true);
  2485. window.addEventListener("contextmenu", mouseClick, true);
  2486. window.addEventListener("click", closeTreeRMenu, true);
  2487. window.addEventListener("contextmenu", closeTreeRMenu, true);
  2488. })
  2489. onActivated(()=>{
  2490. // console.log('onActivated.query',route.query);
  2491. loadingPreview.value = true
  2492. //给pagesize复制
  2493. if(fileGrid.value == 0){
  2494. pageSize.value = 20
  2495. }else{
  2496. if(!folder.value.length){
  2497. pageSize.value = 80
  2498. }else{
  2499. pageSize.value = 30+pageSize.value
  2500. }
  2501. }
  2502. setTimeout(()=>{
  2503. if(route.query.clickRowId){
  2504. const newRow = JSON.parse(route.query.clickRowId)
  2505. // console.log('newRow',newRow);
  2506. myfile.getDir(newRow).then(res=>{
  2507. // console.log('tores',res);
  2508. thisFolder.value = res.data
  2509. // 这里点的是一级目录 所以重新给pathLabelData赋值
  2510. const labelItem = {
  2511. name:res.data.dirName,
  2512. dirId:res.data.dirId
  2513. }
  2514. pathLabelData.value = [labelItem]
  2515. openFolderPath()
  2516. refreshFile()
  2517. })
  2518. }
  2519. //查看是否有本地存储的文件夹信息
  2520. const json = sessionStorage.getItem('openFolder')
  2521. const openFolder =json? JSON.parse(json):''
  2522. if(openFolder){
  2523. const newRow = JSON.parse(openFolder.clickRowId)
  2524. // console.log('newRow',newRow);
  2525. myfile.getDir(newRow).then(res=>{
  2526. // console.log('tores',res);
  2527. thisFolder.value = res.data
  2528. // 这里点的是一级目录 所以重新给pathLabelData赋值
  2529. const labelItem = {
  2530. name:res.data.dirName,
  2531. dirId:res.data.dirId
  2532. }
  2533. pathLabelData.value = [labelItem]
  2534. //清楚该项本地存储
  2535. sessionStorage.setItem('openFolder','')
  2536. // openFolderPath()
  2537. // refreshFile()
  2538. })
  2539. }
  2540. const hasMsg = localStorage.getItem('leftShowList')
  2541. if(!hasMsg){
  2542. getConfigKey("dir.style.config").then(response => {
  2543. leftShowList.value = response.msg - 0;
  2544. });
  2545. }else{
  2546. leftShowList.value = hasMsg - 0
  2547. }
  2548. loadingPreview.value = false
  2549. },500)
  2550. })
  2551. // 监听路由变化
  2552. // onBeforeRouteUpdate((to,from)=>{
  2553. // console.log('to',to);
  2554. // console.log('from',from);
  2555. // if(to.name == 'department'){
  2556. // loadingPreview.value = true
  2557. // const thisdirId = to.params.dirId
  2558. // console.log('thisdirId',thisdirId);
  2559. // setTimeout(()=>{
  2560. // if(thisdirId){
  2561. // myfile.getDir(thisdirId).then(res=>{
  2562. // console.log('tores',res);
  2563. // thisFolder.value = res.data
  2564. // refreshFile()
  2565. // })
  2566. // }
  2567. // loadingPreview.value = false
  2568. // },500)
  2569. // }
  2570. // // docId = to.query.clickRowId
  2571. // // console.log(docId, "doc");
  2572. // // console.log(copyRow, "row");
  2573. // // edit();
  2574. // })
  2575. return {
  2576. getSpaceList,
  2577. folderList,//文件夹的数据
  2578. fileList,//文件夹的数据
  2579. searchFire,//搜索文件的model
  2580. changeFile,//切换右侧视图的file
  2581. menuList,//右侧切换
  2582. selectedIndex,//当前选中下标
  2583. shotdown,//筛选出当前数据
  2584. useMenu,
  2585. arrorMenu,
  2586. blueLeft,//返回
  2587. ordinaryList,
  2588. ordinary,
  2589. fileStyle,
  2590. fileBox,
  2591. grayRight,//前进
  2592. squre,//视图切换
  2593. sort,//排序
  2594. folder,
  2595. files,
  2596. handleRowClick,
  2597. askApply,//申请扩容
  2598. cliCC,
  2599. mouseCli,//文件点击弹框
  2600. chooseSet,
  2601. trandata,
  2602. tranvalue,
  2603. anyP,
  2604. chooseSet1,
  2605. fileMenu,
  2606. createNewMenu,
  2607. // delBoser,
  2608. clickRowId,
  2609. createNewFile,
  2610. // fileUpload,
  2611. getImage,//筛选文件类型
  2612. handleSelectionChange,
  2613. handleSelectionChange1,
  2614. selectedBox,//重命名相关
  2615. restName,//重命名相关
  2616. getMenu,
  2617. folderId,
  2618. fileId,
  2619. // getAllMiddle,//拿到所有空间信息
  2620. delName,//删除空间信息
  2621. useSpace,//使用空间
  2622. allSpace,//总空间
  2623. percent,
  2624. arrowClick,
  2625. uploadModal,
  2626. sureUpload,
  2627. onSuccess,
  2628. fileArr,
  2629. directoryId,
  2630. folderClick,
  2631. copyDirId,//复制移动需要的↓
  2632. copyDocId,
  2633. copySpaceId,
  2634. copyFileId,
  2635. copyFileName,
  2636. copyFileSize,
  2637. copyFileType,
  2638. sureChangeName,//文件重命名
  2639. fileNameChange,//文件重命名模态框
  2640. nameForm,
  2641. collectImg,//收藏小星星
  2642. sortNum,
  2643. needBag,
  2644. isId,
  2645. editOnline,//在线编辑
  2646. copyParentId,
  2647. copyRow,
  2648. getAllTop,
  2649. newDirId,
  2650. newSpaceId,
  2651. showPreview,//控制图片预览
  2652. closeImgPreview,//关闭预览事件
  2653. previewData,//预览文件数据
  2654. router,
  2655. fileTrees,
  2656. getChildren,//子传父
  2657. copyOrMove,
  2658. impDirId,
  2659. impNum,
  2660. leftNewFile,
  2661. impSpaceId,
  2662. //历史版本=========
  2663. openForwardFile,
  2664. forwardTreeData,
  2665. fileUserTreeData,
  2666. filterMouseCli,
  2667. changeMsgClose,
  2668. historyPrew,
  2669. historycopyRow,
  2670. thanks,
  2671. getCback,
  2672. mouseClick,
  2673. folderVisible,
  2674. foldertop,
  2675. folderleft,
  2676. thisFolder,
  2677. folderRClick,
  2678. closeRMenu,
  2679. cancleHistoryPrew,
  2680. historyTotal,
  2681. //历史版本=========
  2682. fileUserTreeData,
  2683. thanks,
  2684. getCback,
  2685. mouseClick,
  2686. workOrEdit,
  2687. folderCase,//新建文件夹传值
  2688. getChildrenC,
  2689. oneOrTwo,//父传子判断
  2690. folderCheckout,
  2691. fileCheckout,
  2692. haveCheck,
  2693. onlyView,
  2694. goLock,
  2695. collects,//收藏父传子
  2696. getCollects,//收藏子传父
  2697. folderTotal,
  2698. fileTotal,
  2699. delMoreFile,//删除多个文件夹
  2700. topPath,
  2701. xz,//文件右键菜单left
  2702. yz,//文件右键菜单top
  2703. formatFileSize,
  2704. isFolder,
  2705. clickRow,
  2706. rename,
  2707. getRename,//文件夹重命名子传父
  2708. copyFolderName,
  2709. spaces,//空间扩容父传子
  2710. getSpaceC,//空间扩容子传父
  2711. copySpaceCup,
  2712. fileGrid,
  2713. folderGrid,
  2714. collectFolder,
  2715. arrowLift,
  2716. formatStorage,
  2717. showFile,
  2718. navBack,
  2719. onlineCase,
  2720. lastBB,
  2721. shareBack,
  2722. folderBack,
  2723. refreshFile,
  2724. delCollect,
  2725. backFolder,
  2726. collectByStar,
  2727. getLevelImg,
  2728. level1,
  2729. level2,
  2730. level3,
  2731. level4,
  2732. getLeveldetailFn,
  2733. thisFolderRole,
  2734. showInputPassword,
  2735. closeIptPass,
  2736. surePass,
  2737. chooseRow,
  2738. chooseNum,
  2739. loadingPreview,
  2740. thisRole,
  2741. noMenuItem,
  2742. downLoadfile,
  2743. addTab,
  2744. addFileTab,
  2745. addFolderAdd,
  2746. ordinaryFolder,
  2747. filePageNum,
  2748. setScroll,
  2749. tableBeEnd,
  2750. tableTotal,
  2751. spaceName,
  2752. getUserInfo,
  2753. isDept,
  2754. upFirstFoler,
  2755. //控制宫格展示
  2756. changeShow,
  2757. isList,
  2758. upFolderData,
  2759. setTablelevel,
  2760. levelList,
  2761. getLevelList,
  2762. closeUpload,
  2763. handleRemove,
  2764. loadingUpload,
  2765. fileBlur,
  2766. pathLabelData,
  2767. backTopPath,
  2768. maxFileSize,
  2769. upBefore,
  2770. getFirstFolder,
  2771. openScan,
  2772. closeOpen,
  2773. scannerFile,
  2774. scannerList,
  2775. checkScanner,
  2776. checkScanId,
  2777. checkScanFn,
  2778. closeCheckScanner,
  2779. sureScaner,
  2780. scannerFiles,
  2781. saveScanFile,
  2782. openScanMove,
  2783. closeOpenScanMove,
  2784. scanFileArr,
  2785. setImg,
  2786. fileHeight,
  2787. pageSize,
  2788. delMoreFolder,
  2789. inputTitle,
  2790. isCode,
  2791. sureCode,
  2792. upFileData,
  2793. fileBig,
  2794. isAsc,
  2795. changeSort,
  2796. clickPath,
  2797. leftShowList,
  2798. changeLeftShow,
  2799. listfolderClick,
  2800. ListtreeData,
  2801. getFileTree,
  2802. searchFolderTree,
  2803. treeRClick,
  2804. showTreeMenu,
  2805. closeTreeRMenu,
  2806. delFolder,
  2807. changeListSort,
  2808. folderBlur,
  2809. delFolderDataFn,
  2810. openFolderPath,
  2811. delFolderMenu,
  2812. noEdit,
  2813. delFileFn,
  2814. collectId,
  2815. setHisData,
  2816. showHis,
  2817. closeHis,
  2818. hisIfarmeData,
  2819. noHis,
  2820. hasThisTab
  2821. }
  2822. },
  2823. watch: {
  2824. },
  2825. components: {
  2826. BreadMenu,
  2827. FileEdit,
  2828. ImgPreview,
  2829. FileTree,
  2830. historyList,
  2831. TransferModal,
  2832. CreateFloder,
  2833. FileCollect,
  2834. FolderReName,
  2835. SpaceBig,
  2836. PlaceGridFolder,
  2837. PalaceGridFile,
  2838. inputPassword,
  2839. PathLabel,
  2840. ScanFile,
  2841. MoveTo,
  2842. LeftList,
  2843. ListShow,
  2844. TreeMenu,
  2845. PreHistory
  2846. },
  2847. }
  2848. </script>
  2849. <style lang="scss" scoped>
  2850. @import "@/assets/styles/my-common.scss";
  2851. .lodingBox{
  2852. position:absolute;
  2853. top: 0;
  2854. left: 0;
  2855. width: 100vh;
  2856. height: 100vh;
  2857. z-index: 10000000;
  2858. }
  2859. p {
  2860. margin: 0;
  2861. padding: 0;
  2862. }
  2863. .bigBox {
  2864. width: 100%;
  2865. height: 100vh;
  2866. display: flex;
  2867. justify-content: flex-start;
  2868. overflow: hidden;
  2869. }
  2870. .settingBox {
  2871. width: 25vw;
  2872. height: 100vh;
  2873. // border: 1px solid black;
  2874. border-radius: 4px;
  2875. /* margin: 5px 5px; */
  2876. margin-right: 8px;
  2877. background-color: white;
  2878. }
  2879. .topSearch {
  2880. width: 100%;
  2881. height: 48px;
  2882. background-color: #EBEFF6;
  2883. display: flex;
  2884. justify-content: space-between;
  2885. align-items: center;
  2886. padding-left: 16px;
  2887. padding-right: 16px;
  2888. }
  2889. .searchFire {
  2890. // width: 248px;
  2891. width: 100%;
  2892. height: 32px;
  2893. }
  2894. .searchBox{
  2895. display: flex;
  2896. justify-content: space-between;
  2897. align-items: center;
  2898. position: relative;
  2899. padding: 8px 16px;
  2900. .SearchIcon {
  2901. color: gray;
  2902. position: absolute;
  2903. right: calc(5% + 34px);
  2904. top: 35%;
  2905. }
  2906. .left_changeShow{
  2907. margin-left: 10px;
  2908. width: 24px;
  2909. height: 24px;
  2910. img{
  2911. width: 24px;
  2912. height: 24px;
  2913. }
  2914. }
  2915. }
  2916. .setBox {
  2917. width: 88px;
  2918. height: 112px;
  2919. text-align: center;
  2920. margin-left: 5px;
  2921. margin-top: 5px;
  2922. position: relative;
  2923. .left_fileBox{
  2924. position: relative;
  2925. margin-top: 10px;
  2926. .levelImg{
  2927. width: 32px;
  2928. height: 32px;
  2929. position: absolute;
  2930. right: 5%;
  2931. bottom: 20%;
  2932. }
  2933. }
  2934. }
  2935. .setBox:hover {
  2936. background-color: #EEF9FF;
  2937. }
  2938. .setBox:hover .selectChe {
  2939. background-color: #EEF9FF;
  2940. display: block;
  2941. z-index: 1000;
  2942. }
  2943. .selectChe {
  2944. display: none;
  2945. width: 20px;
  2946. height: 20px;
  2947. background: rgba(255, 255, 255, 0.7);
  2948. border-radius: 4px 4px 4px 4px;
  2949. position: absolute;
  2950. top: 2px;
  2951. right: 2px;
  2952. line-height: 10px;
  2953. }
  2954. .mesBox {
  2955. width: 75vw;
  2956. height: 96vh;
  2957. border-radius: 4px;
  2958. background-color: white;
  2959. }
  2960. .checkScan{
  2961. background-color: #eee;
  2962. }
  2963. .useBox {
  2964. width: 100%;
  2965. height: 24px;
  2966. }
  2967. .tables {
  2968. display: inline-block;
  2969. width: 112px;
  2970. height: 22px;
  2971. border-radius: 4px;
  2972. line-height: 21px;
  2973. text-align: center;
  2974. font-size: 12px;
  2975. margin-left: 5px;
  2976. position: relative;
  2977. white-space: nowrap;
  2978. overflow: hidden;
  2979. text-overflow: ellipsis;
  2980. }
  2981. .tableLis {
  2982. display: inline-block;
  2983. width: 112px;
  2984. height: 22px;
  2985. border-radius: 4px;
  2986. background-color: #EBEFF6;
  2987. line-height: 21px;
  2988. text-align: center;
  2989. font-size: 12px;
  2990. margin-left: 5px;
  2991. position: relative;
  2992. white-space: nowrap;
  2993. overflow: hidden;
  2994. text-overflow: ellipsis;
  2995. max-width: auto;
  2996. }
  2997. .manyUse {
  2998. width: 100%;
  2999. height: 48px;
  3000. /* background-color: gray; */
  3001. line-height: 48px;
  3002. display: flex;
  3003. justify-content:space-between;
  3004. align-items: center;
  3005. .useMenu{
  3006. height: 100%;
  3007. display: flex;
  3008. align-items: center;
  3009. line-height: 48px;
  3010. }
  3011. .tip{
  3012. display: flex;
  3013. align-items: center;
  3014. margin-right: 24px;
  3015. color: #2E6BC8;
  3016. font-size: 14px;
  3017. }
  3018. }
  3019. .el-dropdown-link {
  3020. color: white;
  3021. cursor: pointer;
  3022. }
  3023. .breadBox {
  3024. width: 100%;
  3025. height: 24px;
  3026. display: flex;
  3027. justify-content: space-between;
  3028. align-items: center;
  3029. background-color: #F6F7F9;
  3030. .topPath {
  3031. display: flex;
  3032. margin-left: 4px;
  3033. align-items: center;
  3034. cursor: pointer;
  3035. color: #6F85B5;
  3036. font-size: 12px;
  3037. }
  3038. }
  3039. :deep(.el-collapse-item__header) {
  3040. height: 24px !important;
  3041. background-color: #EBEFF6 !important;
  3042. }
  3043. .detailBox {
  3044. width: 100%;
  3045. height: 50%;
  3046. // overflow-y: auto;
  3047. }
  3048. .showBox{
  3049. height: calc(100% - 48px - 24px);
  3050. }
  3051. :deep(.el-dialog__header) {
  3052. background-color: #ECEFF7;
  3053. margin-right: 0px;
  3054. }
  3055. :deep(.el-collapse-item__content) {
  3056. // height: 235px;
  3057. overflow-y: auto;
  3058. padding-bottom: 0;
  3059. }
  3060. :deep(.el-scrollbar__wrap) {
  3061. height: 100% !important;
  3062. // overflow-y: auto;
  3063. }
  3064. .fileTable {
  3065. height: 50%;
  3066. // overflow-y: auto;
  3067. // margin-top: 55px;
  3068. }
  3069. .setCli {
  3070. width: 156px;
  3071. max-height: auto;
  3072. position: absolute;
  3073. top: -70px;
  3074. left: 300px;
  3075. flex-wrap: 400;
  3076. background-color: white;
  3077. border: 1px solid gray;
  3078. border-radius: 4px;
  3079. z-index: 3;
  3080. overflow-y: auto;
  3081. // font-size: 16px;
  3082. }
  3083. .setCli1 {
  3084. width: 156px;
  3085. height: auto;
  3086. position: absolute;
  3087. background-color: white;
  3088. border: 1px solid gray;
  3089. border-radius: 4px;
  3090. z-index: 100;
  3091. overflow-y: auto;
  3092. }
  3093. .chooseSet {
  3094. width: 140px;
  3095. height: 30px;
  3096. line-height: 30px;
  3097. margin: 5px auto;
  3098. font-size: 13px;
  3099. cursor: pointer;
  3100. // display: flex;
  3101. // align-items: center;
  3102. // position: relative;
  3103. img {
  3104. margin-right: 4px;
  3105. vertical-align: middle;
  3106. }
  3107. }
  3108. .hasLine{
  3109. border-top: 1px solid #C1CCE3;
  3110. }
  3111. .btmLine{
  3112. border-bottom: 1px solid #C1CCE3;
  3113. }
  3114. .chooseSet:hover {
  3115. width: 140px;
  3116. height: 30px;
  3117. line-height: 30px;
  3118. margin: 5px auto;
  3119. font-size: 13px;
  3120. background-color: #F5F7F9;
  3121. /* color: white; */
  3122. }
  3123. :deep([data-v-69cdaa40] .el-collapse-item__header) {
  3124. padding-left: 10px;
  3125. }
  3126. :deep(.el-collapse-item__content) {
  3127. // height: 235px;
  3128. overflow-y: auto;
  3129. }
  3130. .ellipsis-text {
  3131. white-space: nowrap;
  3132. overflow: hidden;
  3133. text-overflow: ellipsis;
  3134. max-width: auto;
  3135. }
  3136. .right_menu {
  3137. width: 156px;
  3138. position: absolute;
  3139. padding: 8px;
  3140. box-shadow: 0px 2px 10px 1px rgba(199, 203, 216);
  3141. border-radius: 4px 4px 4px 4px;
  3142. border: 1px solid gray;
  3143. background-color: #fff;
  3144. z-index: 10000;
  3145. .menu_item {
  3146. width: 100%;
  3147. height: 30px;
  3148. border-radius: 4px 4px 4px 4px;
  3149. line-height: 30px;
  3150. display: flex;
  3151. margin: 5px auto;
  3152. align-items: center;
  3153. font-size: 13px;
  3154. &:hover {
  3155. background-color: #f5f7f9;
  3156. }
  3157. span {
  3158. margin-left: 4px;
  3159. }
  3160. }
  3161. }
  3162. // 扩容盒子
  3163. .expansion{
  3164. margin: 0 16px;
  3165. border-top: 1px solid #C1CCE3 ;
  3166. .top_box{
  3167. margin-top: 16px;
  3168. width: 100%;
  3169. display: flex;
  3170. justify-content: space-between;
  3171. }
  3172. }
  3173. #Onescan{
  3174. height: 48px;
  3175. line-height: 48px;
  3176. font-size: 14px;
  3177. display: flex;
  3178. align-items: center;
  3179. }
  3180. .isCheck {
  3181. opacity: 1 !important;
  3182. }
  3183. :deep(.el-tag__content) {
  3184. display: block;
  3185. }
  3186. :deep(.el-icon el-tag__close) {
  3187. display: block;
  3188. }
  3189. :deep(.el-collapse-item__content) {
  3190. height: 100%;
  3191. border-bottom: none;
  3192. }
  3193. // // 隐藏全选按钮
  3194. // .file-jia {
  3195. // :deep(.el-table th.el-table__cell:nth-child(1) .cell) {
  3196. // visibility: hidden;
  3197. // }
  3198. // }
  3199. .file-title{
  3200. color: #2E6BC8;
  3201. margin-left: 3%;
  3202. }
  3203. ::v-deep .el-collapse-item__arrow {
  3204. position: relative;
  3205. color: #2e6bc8;
  3206. right: 97%;
  3207. }
  3208. :deep(.el-collapse-item__header) {
  3209. padding-left: 10px;
  3210. box-sizing: border-box;
  3211. }
  3212. .palace-grid{
  3213. margin-left: 4px;
  3214. margin-right: 20px;
  3215. }
  3216. </style>