| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558 |
- {extend name="../../base/view/common/base" /}
- {block name="style"}
- <style>
- ::-webkit-scrollbar { display: none; width: 6px; height: 6px; }
- ::-webkit-scrollbar-thumb { border-radius: 10px; background-color: #e1e1e1;}
- .disk-left{width:180px; position: relative; float:left; height:calc(100vh - 86px); overflow-y: auto; border:1px solid #eeeeee; background-color:#fbfbfb; padding:15px 0; user-select: none;}
- .disk-left::-webkit-scrollbar {width: 0;}
- .disk-left h3{font-size:18px; height:30px; padding-left:10px; font-weight:800}
-
- .disk-table{margin-left:120px; overflow:hidden; height:calc(100vh - 56px);border:1px solid #eeeeee; border-left:0; background-color:#fff;}
- .layui-btn.tool-add{padding:0 12px;}
-
- .disk-path{height:40px;padding:0 4px 0 12px;}
- .disk-breadcrumb{float:left; padding:7px 0}
- .disk-breadcrumb span{color:#666; margin:0 8px; font-size:10px;}
- .layui-tab{margin:0;}
- .file-item {height:calc(100vh - 206px); overflow-y: auto;}
- .disk-path .layui-form-checkbox[lay-skin=primary]>div{padding-right:4px}
- .layui-tabs-header li{padding:0 12px;}
- /** 共享空间 **/
- .disk-group {display: flex; flex-direction: column; width: 180px; border-right: 1px solid #f6f6f6; padding-top:12px;}
- .disk-group ul::-webkit-scrollbar { display: block; }
- .disk-group ul { flex: 1; overflow: hidden; overflow-y: auto;}
- .disk-group ul li {display: flex; align-items: center; justify-content: space-between; cursor:pointer; padding-left:12px; padding-right:4px; height: 42px; color: #666666; }
- .disk-group ul li i.layui-icon-component{ margin-right:4px; font-size:20px;font-weight:800;}
- .disk-group ul li i.layui-icon-more-vertical{font-size:20px; padding-right:12px;}
- .disk-group ul li > span { display: flex; flex: 1; overflow: hidden; margin-right: 0.5rem; text-overflow: ellipsis; white-space: nowrap; }
- .disk-group ul li.active { background: #F2FAFF; color:#1e9fff;}
- .disk-group ul li:hover { background: #f5f7fa; color:#1e9fff;}
- .disk-group ul li .dropdown:hover dl { display: block; }
- .disk-group ul li .dropdown dl { position: absolute; top: 36px; right: -15px; z-index: 10000; display: none; padding: 5px 0; width: 88px; border-radius: 2px; text-align: center; background-color: #ffffff; box-shadow: #cccccc 0 0 10px; }
- .disk-group ul li .dropdown dl dd { height: 32px; line-height: 32px; }
- .disk-group ul li .dropdown dl dd:hover { color: #4a5dff; background-color: #edefff; }
- .disk-group ul li .dropdown dl::before { position: absolute; top: -16px; left: 44px; z-index: 12; display: block; padding: 0; width: 0; height: 0; border-top: 8px solid transparent; border-right: 8px solid transparent; border-bottom: 8px solid #ffffff; border-left: 8px solid transparent; content: ""; box-sizing: content-box; }
- .group-footer { display: flex; align-items: center; justify-content: center; width: 100%; height: 50px; position:absolute;bottom:0; border-top: 1px solid #f2f2f2; border-right: 1px solid #f2f2f2; }
-
- /** 文件 **/
- .file-item .file-subject { flex: 1; overflow: hidden; overflow-y: auto; margin: 10px; box-sizing: border-box; }
- .file-item .file-subject:hover::-webkit-scrollbar { display: block; }
- .file-item .file-subject ul { display: flex; flex-wrap: wrap; }
- .file-item .file-subject ul li {position: relative; height: 144px; margin:20px 10px; padding: 6px; border: 1px solid rgba(0, 0, 0, 0.05); border-radius: 3px; transition: all 0.2s ease-in-out; }
- .file-item .file-subject ul li:hover {border: 1px solid #eee; background-color:#f8f8f8;}
- .file-item .file-subject ul li.on {border: 1px solid #ff5722; }
- .file-item .file-subject ul li img { width: 86px; height: 86px; padding:16px;}
- .file-item .file-subject ul li img.file-image { width: 118px; height: 118px; padding:0; border-radius: 2px; }
- .file-item .file-subject ul li video { width: 60px; height: 60px; border-radius: 3px; }
- .file-item .file-subject ul li p {overflow: hidden; margin: 5px 0 0; width: 118px; font-size: 13px; text-align: center; text-overflow: ellipsis; white-space: nowrap; }
- .file-item .file-subject ul li .file-check{position: absolute; width:20px; height:20px; left: 0; top: 0; display: none; font-size: 14px; border-radius:2px 0 4px 0; text-align: center; line-height: 20px; color: #ffffff; background-color:#fff; border-right:1px solid #eee; border-bottom:1px solid #eee; cursor:pointer;}
- .file-item .file-subject ul li:hover .file-check{display: block;}
- .file-item .file-subject ul li.on .file-check{ display: block; background: #ff5722; border-color:#ff5722}
- .file-item .file-subject ul li .layui-btn-ctrl{position:absolute; top:0; right:0; opacity: 0;}
- .file-item .file-subject ul li:hover .layui-btn-ctrl{opacity: 1;}
- .file-folder,.file-image,.file-pdf,.file-video,.file-audio{cursor:pointer;}
- .file-item .file-subject ul li .has-star{position: absolute; width:20px; height:20px; right: 32px; top: 75px; border-radius:50%; text-align: center; line-height: 20px; color: #ffffff; background-color:#ffb800; border:1px solid #fff; padding:2px;}
-
- .file-item .file-subject ul li .file-info{position: absolute; width:100%; height:23px; left: 0; top: 0; text-align:center; font-size: 12px; line-height: 23px; background-color:rgba(0,0,0,.12);border-radius:2px 2px 0 0;}
-
- .file-footer { display: flex; align-items: center; padding: 5px 15px 0; height: 45px; border-top: 1px solid #f2f2f2; text-align: center; background: #ffffff; }
- /** 无数据 **/
- .file-item .empty { display: flex; flex: 1; align-items: center; flex-direction: column; justify-content: center; overflow: hidden; text-align: center; color: #cccccc; }
- .file-item .empty i { font-size: 180px; }
- .file-item .empty p { width: 180px; text-align: center; }
- </style>
- {/block}
- <!-- 主体 -->
- {block name="body"}
- <div class="p-page">
- <div class="disk-left">
- <h3>共享空间</h3>
- <div class="disk-group">
- <ul id="group">
- <li data-id="1" class="active"><i class="layui-icon layui-icon-component"></i><span>公司共享</span></li>
- </ul>
- </div>
- <div class="group-footer">
- <span class="layui-btn layui-btn-primary layui-btn-sm add-new">创建共享空间</span>
- </div>
- </div>
- <div class="disk-table">
- <form class="layui-form gg-form-bar border-b" lay-filter="barsearchform">
- <div class="layui-input-inline" style="width:312px">
- <div class="layui-btn-group">
- <span class="layui-btn tool-add" id="uploadBtn"><strong class="iconfont icon-shangchuan"></strong> 上传文件</span>
- <span class="layui-btn layui-btn-normal tool-add" id="addArticle"><strong class="iconfont icon-lunwenguanli"></strong> 新建文档</span>
- <span class="layui-btn layui-btn-warm tool-add" id="addFolder"><strong class="iconfont icon-xiangmuguanli"></strong> 新建目录</span>
- </div>
- </div>
- <div class="layui-input-inline" style="width:300px">
- <input type="text" name="keywords" placeholder="输入关键字,文件名称/目录名称" class="layui-input" autocomplete="off" />
- </div>
- <div class="layui-input-inline" style="width:150px">
- <input type="hidden" name="pid" value="0" />
- <input type="hidden" name="ext" value="" />
- <input type="hidden" name="group_id" value="1" />
- <input type="hidden" name="group_name" value="公司共享" />
- <input type="hidden" name="limit" value="30" />
- <button class="layui-btn layui-btn-normal" lay-submit="" lay-filter="webform"><i class="layui-icon layui-icon-search mr-1"></i>搜索</button>
- <button type="reset" class="layui-btn layui-btn-reset">清空</button>
- </div>
- </form>
- <div class="disk-path layui-form border-b">
- <div class="disk-breadcrumb" id="diskPath"><i class="layui-icon layui-icon-windows"></i> <a href="javascript:void(0);" data-id="1">公司共享</a></div>
- <div class="layui-input-inline" style="width:450px; float:right;">
- <div class="layui-tabs layui-tab-brief" id="tab">
- <ul class="layui-tabs-header">
- <li class="layui-this" lay-id="">全部</li>
- <li lay-id="image">图片</li>
- <li lay-id="video">视频</li>
- <li lay-id="audio">音频</li>
- <li lay-id="office">Office文件</li>
- <li lay-id="pdf">在线文档</li>
- <li lay-id="zip">压缩包</li>
- </ul>
- </div>
- </div>
- </div>
-
- <div class="file-item">
- <!-- 主体 -->
- <div class="file-subject">
- <ul id="filesBox"></ul>
- </div>
- </div>
- <!-- 页脚 -->
- <div class="file-footer">
- <div id="laypage"></div>
- </div>
- </div>
- </div>
- {/block}
- <!-- /主体 -->
- <!-- 脚本 -->
- {block name="script"}
- <script>
- const typeExt=['','image','video','audio','office','pdf','zip'];
- const fileExt={
- image:['jpg','jpeg','png','gif'],
- office:['doc','docx','xls','xlsx','ppt','pptx'],
- pdf:['txt','pdf','article'],
- zip:['zip','rar','7z','gz','tar'],
- video:['mpg','mp4','mpeg','avi','wmv','mov','flv','m4v'],
- audio:['mp3','wav','wma','flac','midi']
- };
-
- function isValidFileName(fileName) {
- const illegalChars = /[\\\/\*\:"<>|\?]/;
- return !illegalChars.test(fileName);
- }
-
- const moduleInit = ['tool','uploadPlus'];
- function gouguInit() {
- var tool = layui.tool,uploadPlus = layui.uploadPlus,form = layui.form,laypage = layui.laypage,tabs = layui.tabs,dropdown = layui.dropdown;
-
- let fileGroup = [{id:0,title:'公司共享'}];
- tabs.on('afterChange(tab)', function(data){
- if(data.index==0){
- $('[name="ext"]').val('');
- }
- else{
- let ext = typeExt[data.index];
- $('[name="ext"]').val(fileExt[ext]);
- }
- $('[lay-filter="webform"]').click();
- return false;
- });
- //上传文件
- var attachment = new uploadPlus({
- "title":'上传文件',
- "target":'uploadBtn',
- "attachment":{
- "type":1,//0ajax多文件模式,1ajax单文件单记录模式
- "ajaxSave":function(res){
- $.ajax({
- url: "/disk/index/add_upload",
- type:'post',
- data:{
- 'pid':$('[name="pid"]').val(),
- 'group_id':$('[name="group_id"]').val(),
- 'action_id':res.data.id,
- 'name':res.data.name,
- 'id':0,
- 'file_size':res.data.filesize,
- 'file_ext':res.data.fileext
- },
- success: function (e) {
- layer.msg(e.msg);
- if (e.code == 0) {
- $('[lay-filter="webform"]').click();
- }
- }
- })
- }
- }
- })
-
- let ctrl_callback = function (e) {
- if(e.code == 0){
- layer.closeAll();
- layer.msg(e.msg);
- $('[lay-filter="webform"]').click();
- }
- else{
- layer.msg(e.msg);
- }
- }
-
- //顶部目录操作
- $('#diskPath').on('click','a',function(){
- let id=$(this).data('id');
- $('[name="pid"]').val(id);
- let data = form.val('barsearchform');
- get_files(data);
- })
-
- //新增在线文档
- $('#addArticle').on('click',function(){
- tool.side('/disk/index/add_article?pid='+$('[name="pid"]').val()+'&group_id='+$('[name="group_id"]').val());
- })
-
- //新增目录
- $('#addFolder').on('click',function(){
- layer.prompt({title: '请输入目录名称'}, function(val, index, elem){
- if(val==''){
- layer.msg('目录名称不能为空');
- return false;
- }
- if(isValidFileName(val)==false){
- layer.msg('目录名称不能包含下列任何字符:\/:*?".<>|');
- return false;
- }
- $.ajax({
- url: "/disk/index/add_folder",
- type:'post',
- data:{
- 'id':0,
- 'pid':$('[name="pid"]').val(),
- 'group_id':$('[name="group_id"]').val(),
- 'name':val
- },
- success: ctrl_callback
- })
- });
- })
-
- //查看文件
- $('#filesBox').on('click','.file-item',function(){
- let id = $(this).parent().data('id');
- let href = $(this).data('href');
- let ext = $(this).data('ext');
- if(ext == 'video'){
- tool.videoView(href);
- }
- else if(ext == 'audio'){
- tool.audioView(href);
- }
- else if(ext == 'image'){
- tool.photoView(href);
- }
- else if(ext == 'pdf'){
- tool.pdfView(href);
- }
- else if(ext == 'article'){
- tool.articleView(id);
- }
- else if(ext == 'folder'){
- $('[name="pid"]').val(id);
- let data = form.val('barsearchform');
- get_files(data);
- }
- else{
- return false;
- }
- })
-
- //重命名文件
- $('#filesBox').on('click','.name-edit',function(){
- let id = $(this).parent().parent().data('id');
- let title = $(this).parent().parent().data('title');
- let ext = $(this).parent().parent().data('ext');
- let types = $(this).parent().parent().data('types');
- title = title.toString().replace(/\.[^.]+$/, "");
- layer.prompt({title: '重命名',value:title}, function(val, index, elem){
- if(val==''){
- layer.msg('文件名不能为空');
- return false;
- }
- if(isValidFileName(val)==false){
- layer.msg('文件名不能包含下列任何字符:\/:*?".<>|');
- return false;
- }
- if(types == 0){
- val = val+'.'+ext;
- }
- tool.post("/disk/index/rename", {id:id,name:val,group_id:$('[name="group_id"]').val(),pid:$('[name="pid"]').val()}, ctrl_callback);
- });
- })
-
- //单文件删除
- $('#filesBox').on('click','.file-delete',function(){
- let id = $(this).parent().parent().data('id');
- layer.confirm('确定要删除该文件吗?请慎重', { icon: 3, title: '提示' }, function (index) {
- tool.delete("/disk/index/del", {ids:id}, ctrl_callback);
- });
- })
-
- //单文件移动
- $('#filesBox').on('click','.file-move',function(){
- let ids = $(this).parent().parent().data('id');
- layer.open({
- type: 2,
- title: '移动到',
- area: ['720px', '480px'],
- content: '/disk/index/move?group_id='+$('[name="group_id"]').val(),
- maxmin: true,
- btn: ['移动到此', '取消'],
- btnAlign: 'c',
- yes: function(index, layero){
- // 获取 iframe 的窗口对象
- let iframeWin = window[layero.find('iframe')[0]['name']];
- let pid = iframeWin.$('#folder').val();
- let group_id = iframeWin.$('#group_id').val();
- tool.post("/disk/index/move", {ids:ids,pid:pid,group_id:group_id}, ctrl_callback);
- }
- });
- })
-
-
- $('body').on('click','.add-new',function(){
- add_group(0,'');
- });
-
- $('#group').on('click','li span',function(){
- let li=$(this).parent();
- li.addClass('active').siblings().removeClass('active');
- let id=li.data('id');
- let name=li.text();
- $('[name="pid"]').val(0);
- $('[name="group_id"]').val(id);
- $('[name="group_name"]').val(name);
- $('#tab').find('li').eq(0).click();
- //$('[lay-filter="webform"]').click();
- });
-
- function add_group(id,val){
- var title = '创建共享空间';
- if(id>0){
- title = '重命名共享空间';
- }
- layer.prompt({
- title: title,
- value: val,
- yes: function(index, layero) {
- // 获取文本框输入的值
- var value = layero.find(".layui-layer-input").val();
- if (value!='') {
- let callback = function (e) {
- layer.msg(e.msg);
- if(e.code==0){
- location.reload();
- }
- }
- tool.post("/disk/index/add_group", {id: id,title: value}, callback);
- layer.close(index);
- } else {
- layer.msg('请填写共享空间名称');
- }
- }
- })
- }
-
- function del_group(id) {
- layer.confirm('确定要删除该共享空间吗?请慎重', { icon: 3, title: '提示' }, function (index) {
- let callback = function (e) {
- layer.closeAll();
- layer.msg(e.msg);
- if(e.code==0){
- location.reload();
- }
- }
- tool.delete("/disk/index/del_group", {id:id}, callback);
- });
- }
-
- function get_group(){
- $.ajax({
- url:"/disk/api/get_group",
- success:function(res){
- if(res.code==0){
- var group=res.data,item='';
- if(group.length>0){
- for(var a=0;a<group.length;a++){
- item+='<li data-id="'+group[a].id+'" data-title="'+group[a].title+'"><i class="layui-icon layui-icon-component"></i><span>'+group[a].title+'</span><i class="layui-icon layui-icon-more-vertical dropdown-on"></i></li>';
- }
- $('#group').append(item);
- fileGroup = fileGroup.concat(group);
- // 自定义事件
- dropdown.render({
- elem: '.dropdown-on',
- trigger: 'hover',
- align: 'right',
- data: [{
- title: '重命名共享空间',
- id: 100
- },{
- title: '删除该共享空间',
- id: 101
- },{
- title: '设置空间成员',
- id: 102
- },{
- title: '设置空间管理员',
- id: 103
- }],
- click: function(data, othis){
- let id = $(this.elem).parent().data('id');
- let title = $(this.elem).parent().data('title');
- if(data.id==100){
- add_group(id,title);
- }else if(data.id==101){
- del_group(id);
- }else if(data.id==102){
- tool.side('/disk/api/memberlist?id='+id);
- }else if(data.id==103){
- tool.side('/disk/api/adminlist?id='+id);
- }
- }
- });
- }
- }
- }
- });
- }
-
- //加载数据
- var data = form.val('barsearchform');
- get_files(data);
- get_group();
-
- form.on('submit(webform)', function (data) {
- get_files(data.field);
- return false;
- });
- $('.layui-btn-reset').click(function(){
- setTimeout(function(){
- $('[lay-filter="webform"]').click();
- },200)
- })
-
- function get_files(param){
- var loadIndex = layer.load(0);
- $.ajax({
- url:"/disk/index/sharelist",
- data:param,
- complete:function(){
- layer.close(loadIndex)
- },
- success:function(res){
- $('[name="select_all"]').prop('checked', false);
- form.render('checkbox');
- if(res.code==0){
- laypage.render({
- elem: 'laypage',
- limit:param['limit'],
- curr:param['page'],
- count: res.count, // 数据总数
- jump: function(obj, first){
- //console.log(obj.curr); // 得到当前页,以便向服务端请求对应页的数据。
- //console.log(obj.limit); // 得到每页显示的条数
- // 首次不执行
- if(!first){
- var data = form.val('barsearchform');
- data['page'] = obj.curr;
- get_files(data);
- }
- }
- });
- let folder = res.totalRow;
- let folderHtml='<i class="layui-icon layui-icon-windows"></i> <a href="javascript:void(0);" data-id="0">'+$('[name="group_name"]').val()+'</a>';
- if(folder.length>0){
- for(var f=0;f<folder.length;f++){
- folderHtml+='<span> 〉</span><a href="javascript:void(0);" data-id="'+folder[f].id+'">'+folder[f].name+'</a>';
- }
- }
- $('#diskPath').html(folderHtml);
-
- var item=res.data,li='';
- if(item.length>0){
- for(var a=0;a<item.length;a++){
- let type = '',ext="zip";
- // 判断元素是否在数组中
- let path='/static/home/images/icon/file.png';
- if (fileExt.image.includes(item[a].file_ext)) {
- path=item[a].thumbpath;
- type = '0,1,3,4,5';
- ext="image";
- }
- if (fileExt.office.includes(item[a].file_ext)) {
- type = '0,1,3,4,5';
- ext="office";
- path='/static/home/images/icon/'+item[a].file_ext+'.png';
- }
- if (item[a].file_ext == 'pdf' || item[a].file_ext == 'txt') {
- type = '0,1,3,4,5';
- ext="pdf";
- path='/static/home/images/icon/'+item[a].file_ext+'.png';
- }
- if (fileExt.video.includes(item[a].file_ext)) {
- type = '0,1,3,4,5';
- ext="video";
- path='/static/home/images/icon/video.png';
- }
- if (fileExt.audio.includes(item[a].file_ext)) {
- type = '0,1,3,4,5';
- ext="audio";
- path='/static/home/images/icon/audio.png';
- }
- if (fileExt.zip.includes(item[a].file_ext)) {
- type = '0,1,3,4,5';
- ext="zip";
- path='/static/home/images/icon/rar.png';
- }
- if(item[a].types==1){
- type = '1,2,3,4,5';
- ext="article";
- path='/static/home/images/icon/article.png';
- }
- if(item[a].types==2){
- type = '3,4,5';
- ext="folder";
- path='/static/home/images/icon/folder.png';
- }
- ctrl = '<span class="layui-btn layui-btn-xs layui-btn-normal file-ctrl" data-ctrl="disk" data-fileid="'+item[a].id+'" data-actionid="'+item[a].action_id+'" data-href="'+item[a].filepath+'" data-filename="'+item[a].name+'" data-ext="'+ext+'" data-type="'+type+'">操作</span>';
-
- li+='<li data-id="'+item[a].id+'" data-title="'+item[a].name+'" data-ext="'+item[a].file_ext+'" data-types="'+item[a].types+'"><img src="'+path+'" alt="'+item[a].name+'" style="object-fit: contain;" class="file-item file-'+ext+'" data-href="'+item[a].filepath+'" data-ext="'+ext+'"><p title="'+item[a].name+'">'+item[a].name+'</p>\
- <div class="layui-btn-ctrl">'+ctrl+'\
- <span class="name-edit" style="display:none;" id="fileEdit'+item[a].id+'" title="重命名"></span>\
- <span class="file-delete" style="display:none;" id="fileDel'+item[a].id+'" title="删除"></span>\
- <span class="file-move" style="display:none;" id="fileMove'+item[a].id+'" title="移动"></span>\
- </div></li>';
- }
- $('#filesBox').html(li);
- $('#laypage').show();
- }
- else{
- $('#filesBox').html('<div class="empty"><i class="layui-icon layui-icon-upload"></i><p>无文件文件,赶紧去上传吧!</p></div>');
- $('#laypage').hide();
- }
- }
- }
- });
- }
- }
- </script>
- {/block}
- <!-- /脚本 -->
|