| 1 |
- {"remainingRequest":"E:\\item\\newItem\\admin\\node_modules\\babel-loader\\lib\\index.js!E:\\item\\newItem\\admin\\node_modules\\cache-loader\\dist\\cjs.js??ref--0-0!E:\\item\\newItem\\admin\\node_modules\\vue-loader\\lib\\index.js??vue-loader-options!E:\\item\\newItem\\admin\\node_modules\\iview-loader\\index.js??ref--0-2!E:\\item\\newItem\\admin\\src\\pages\\system\\maintain\\systemFile\\opendir.vue?vue&type=script&lang=js&","dependencies":[{"path":"E:\\item\\newItem\\admin\\src\\pages\\system\\maintain\\systemFile\\opendir.vue","mtime":1677828270249},{"path":"E:\\item\\newItem\\admin\\babel.config.js","mtime":1677828270071},{"path":"E:\\item\\newItem\\admin\\.babelrc","mtime":1677828270070},{"path":"E:\\item\\newItem\\admin\\node_modules\\cache-loader\\dist\\cjs.js","mtime":499162500000},{"path":"E:\\item\\newItem\\admin\\node_modules\\babel-loader\\lib\\index.js","mtime":315532800000},{"path":"E:\\item\\newItem\\admin\\node_modules\\cache-loader\\dist\\cjs.js","mtime":499162500000},{"path":"E:\\item\\newItem\\admin\\node_modules\\vue-loader\\lib\\index.js","mtime":499162500000},{"path":"E:\\item\\newItem\\admin\\node_modules\\iview-loader\\index.js","mtime":1570440814000}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64:import _defineProperty from "E:/item/newItem/admin/node_modules/@vue/babel-preset-app/node_modules/@babel/runtime/helpers/esm/defineProperty.js";
import _asyncToGenerator from "E:/item/newItem/admin/node_modules/@vue/babel-preset-app/node_modules/@babel/runtime/helpers/esm/asyncToGenerator.js";
import "core-js/modules/es.array.find-index.js";
import "core-js/modules/es.object.to-string.js";
import "core-js/modules/es.regexp.to-string.js";
import "core-js/modules/es.number.constructor.js";
import "core-js/modules/es.array.slice.js";
import "core-js/modules/web.dom-collections.for-each.js";
import "core-js/modules/es.array.splice.js";
import "regenerator-runtime/runtime.js";
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
import { resolveComponent } from 'vue';
import { opendirListApi, openfileApi, savefileApi, opendirLoginApi, createFolder, createFile, delFolder, rename } from '@/api/system';
import CodeMirror from 'codemirror/lib/codemirror';
import loginFrom from './components/loginFrom';
import { setCookies, getCookies, removeCookies } from '@/libs/util'; // import Fullscreen from '@/components/main/components/fullscreen';

import * as monaco from 'monaco-editor';
export default {
  name: 'opendir',
  data: function data() {
    return {
      modals: false,
      //编辑器开关
      editor: '',
      //当前编辑器对象
      editorIndex: [//选项卡数组
      {
        tab: true,
        index: '0',
        title: '',
        icon: ''
      }],
      editorList: [],
      //编辑器数组
      indexEditor: 0,
      //当前编辑器索引
      code: '',
      //当前文件打开时的内容
      navList: [],
      //左侧导航数据
      navItem: {},
      //左侧导航点击是选中的数据
      contextData: null,
      //左侧导航右键点击是产生的数据对象
      fileType: '',
      // 文件操作类型 createFolder|创建文件夹 createFile|创建文件 delFolder|删除文件夹或者文件
      className: '',
      //全屏 class名
      // fullscreen:false,  // 是否全屏
      isSave: true,
      //当前文件是否保存
      isShowLogn: false,
      // 登录
      isShowList: false,
      // 登录之后列表
      spinShow: false,
      loading: false,
      tabList: [],
      columns4: [{
        title: '文件/文件夹名',
        slot: 'filename',
        minWidth: 150,
        back: '返回上级'
      }, {
        title: '文件/文件夹路径',
        key: 'real_path',
        minWidth: 150
      }, {
        title: '文件/文件夹大小',
        key: 'size',
        minWidth: 100
      }, {
        title: '是否可写',
        slot: 'isWritable',
        minWidth: 100
      }, {
        title: '更新时间',
        key: 'mtime',
        minWidth: 150
      }, {
        title: '操作',
        slot: 'action',
        minWidth: 150
      }],
      formItem: {
        //记录当前路径信息，获取文件列表时使用
        dir: '',
        superior: 0,
        filedir: '',
        fileToken: getCookies('file_token')
      },
      dir: '',
      //当前完整文件路径
      // rows: {},  //
      pathname: '',
      // 当前文件路径
      title: '',
      //当前文件标题
      formFile: {
        //重命名表单
        filename: ''
      },
      ruleInline: {
        filename: [{
          required: true,
          message: '请输入文件或文件夹的名字',
          trigger: 'blur'
        }]
      },
      formShow: false,
      //表单开关
      formTitle: '',
      //表单标题
      fileToken: getCookies('file_token')
    };
  },
  components: {
    loginFrom: loginFrom
  },
  mounted: function mounted() {
    this.initEditor();
  },
  created: function created() {
    this.getList();
  },
  beforeDestroy: function beforeDestroy() {
    removeCookies('file_token');
  },
  computed: {},
  methods: {
    // 点击行
    currentChange: function currentChange(currentRow) {
      if (currentRow.isDir) {
        this.open(currentRow);
      } else {
        this.edit(currentRow);
      }
    },

    /**
     * 文件列表
     * @param {Object} refresh   // 是否重新加载 bool
     * @param {Object} is_edit   // 是否是编辑器中的刷新 bool
     */
    getList: function getList(refresh, is_edit) {
      var _this = this;

      var params;

      if (refresh) {
        params = {
          dir: '',
          superior: 0,
          filedir: '',
          fileToken: this.fileToken
        };
      } else {
        params = this.formItem;
        params.fileToken = this.fileToken;
      }

      if (!is_edit) this.loading = true;
      opendirListApi(params).then( /*#__PURE__*/function () {
        var _ref = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee(res) {
          var data;
          return regeneratorRuntime.wrap(function _callee$(_context) {
            while (1) {
              switch (_context.prev = _context.next) {
                case 0:
                  data = res.data;

                  if (is_edit) {
                    _this.navList = data.navList;
                  } else {
                    _this.navListForTab = data.navList;
                    _this.tabList = data.list; // this.navList = data.navList;

                    _this.isShowList = true;
                  }

                  _this.dir = data.dir;
                  _this.isShowLogn = false;
                  _this.loading = false;

                case 5:
                case "end":
                  return _context.stop();
              }
            }
          }, _callee);
        }));

        return function (_x) {
          return _ref.apply(this, arguments);
        };
      }()).catch(function (res) {
        _this.catchFun(res);
      });
    },
    //新建文件后重新加载左侧导航
    getListItem: function getListItem(data) {
      var _this2 = this;

      opendirListApi(data).then( /*#__PURE__*/function () {
        var _ref2 = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee2(res) {
          return regeneratorRuntime.wrap(function _callee2$(_context2) {
            while (1) {
              switch (_context2.prev = _context2.next) {
                case 0:
                  _this2.$set(_this2.contextData, 'children', res.data.navList);

                case 1:
                case "end":
                  return _context2.stop();
              }
            }
          }, _callee2);
        }));

        return function (_x2) {
          return _ref2.apply(this, arguments);
        };
      }()).catch(function (res) {
        _this2.catchFun(res);
      });
    },
    // 返回上级
    goBack: function goBack(is_edit) {
      this.formItem = {
        dir: this.dir,
        superior: 1,
        filedir: ''
      };
      this.getList(false, is_edit);
    },
    // 打开
    open: function open(row) {
      // this.rows = row;
      this.formItem = {
        dir: row.path,
        superior: 0,
        filedir: row.filename,
        fileToken: this.fileToken
      };
      this.getList(false, false);
    },
    // 编辑
    edit: function edit(row) {
      this.navItem = row;
      this.spinShow = true;
      this.pathname = row.pathname;
      this.title = row.filename;
      this.editorIndex[0].title = row.filename;
      this.editorIndex[0].pathname = row.pathname;
      this.navList = this.navListForTab;
      this.dir = row.path; // 创建代码容器

      if (this.editorList.length <= 0) {
        this.initEditor();
      }

      this.openfile(row.pathname, false);
    },

    /**
     * 保存
     * @param {Object} index   // 当前索引
     * @param {Object} type    // true 不更新当前本地数据，false或者为空 更新当前数据
     */
    savefile: function savefile(index, type) {
      var code = this.editorList[index].editor.getValue();
      var data = {
        comment: code,
        filepath: this.editorList[index].path,
        fileToken: this.fileToken
      };
      var that = this;
      savefileApi(data).then( /*#__PURE__*/function () {
        var _ref3 = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee3(res) {
          return regeneratorRuntime.wrap(function _callee3$(_context3) {
            while (1) {
              switch (_context3.prev = _context3.next) {
                case 0:
                  if (!type) {
                    that.code = code;
                    that.isSave = true;
                    that.editorIndex[index].icon = '';
                    that.editorList[index].isSave = true;
                  }

                  that.$Message.success(res.msg);
                  that.$Modal.remove();

                case 3:
                case "end":
                  return _context3.stop();
              }
            }
          }, _callee3);
        }));

        return function (_x3) {
          return _ref3.apply(this, arguments);
        };
      }()).catch(function (res) {
        that.catchFun(res);
      });
    },
    // 刷新
    refreshfile: function refreshfile() {
      // 刷新编辑器
      if (this.editorList[this.indexEditor]) this.openfile(this.editorList[this.indexEditor].path, true);
    },
    //计算token过期时间
    getExpiresTime: function getExpiresTime(expiresTime) {
      var nowTimeNum = Math.round(new Date() / 1000);
      var expiresTimeNum = expiresTime - nowTimeNum;
      return parseFloat(parseFloat(parseFloat(expiresTimeNum / 60) / 60) / 24);
    },
    // 侧边栏异步加载
    loadData: function loadData(item, callback) {
      var _this3 = this;

      if (item.isDir) {
        this.formItem = {
          dir: item.path,
          superior: 0,
          filedir: item.title,
          fileToken: this.fileToken
        };
        opendirListApi(this.formItem).then( /*#__PURE__*/function () {
          var _ref4 = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee4(res) {
            return regeneratorRuntime.wrap(function _callee4$(_context4) {
              while (1) {
                switch (_context4.prev = _context4.next) {
                  case 0:
                    callback(res.data.navList);

                  case 1:
                  case "end":
                    return _context4.stop();
                }
              }
            }, _callee4);
          }));

          return function (_x4) {
            return _ref4.apply(this, arguments);
          };
        }()).catch(function (res) {
          if (res.status == 110008) {
            _this3.$Message.error(res.msg);

            _this3.isShowLogn = true;
            _this3.isShowList = false;
            _this3.loading = false;
          } else {
            _this3.catchFun(res);
          }
        });
      }
    },
    // 自定义显示
    renderContent: function renderContent(h, _ref5) {
      var _style;

      var root = _ref5.root,
          node = _ref5.node,
          data = _ref5.data;
      var that = this;
      return h('span', {
        style: (_style = {
          display: 'inline-block',
          cursor: 'pointer',
          userSelect: 'null',
          color: '#cccccc'
        }, _defineProperty(_style, "display", 'inline-block'), _defineProperty(_style, "width", '100%'), _defineProperty(_style, "borderRadis", '5px'), _style),
        on: {
          click: function click() {
            that.clickDir(data, root, node);
          },
          contextmenu: function contextmenu() {// that.handleContextDelFolder(data,root,node);
          }
        }
      }, [h('span', [h('Icon', {
        props: {
          type: data.isDir ? 'md-folder' : 'ios-document-outline'
        },
        style: {
          marginRight: '8px'
        }
      }), h('span', {
        attrs: {
          title: data.title
        }
      }, data.title)])]);
    },

    /**
     * 侧边栏点击事件
     * @param {Object} data
     */
    clickDir: function clickDir(data, root, node) {
      var that = this;
      that.navItem = data;
      that.pathname = data.pathname;

      if (!data.isDir) {
        var i = that.editorIndex.findIndex(function (e) {
          return e.pathname === data.pathname;
        });

        if (i > -1) {
          that.toggleEditor(i);
          that.indexEditor = i.toString();
        } else {
          var index = that.editorIndex.length; // 创建tabs

          that.editorIndex.push({
            tab: true,
            index: index.toString(),
            title: data.title,
            icon: '',
            pathname: data.pathname
          });
          that.indexEditor = index.toString(); // 创建代码容器

          that.initEditor();
          that.openfile(data.pathname, true);
        }
      }
    },
    //侧边栏右键点击事件
    handleContextMenu: function handleContextMenu(data, event, position) {
      position.left = Number(position.left.slice(0, -2)) + 75 + 'px';
      this.contextData = data;
    },
    // 文件操作类型 createFolder|创建文件夹 createFile|创建文件 delFolder|删除文件夹或者文件 renameFile|文件重命名
    //创建文件夹
    handleContextCreateFolder: function handleContextCreateFolder() {
      this.formFile.filename = '';
      this.formTitle = '创建文件夹';
      this.formShow = true;
      this.fileType = 'createFolder';
    },
    //创建文件
    handleContextCreateFile: function handleContextCreateFile() {
      this.formFile.filename = '';
      this.formTitle = '创建文件';
      this.formShow = true;
      this.fileType = 'createFile';
    },
    //删除文件
    handleContextDelFolder: function handleContextDelFolder() {
      var _this4 = this;

      var that = this;
      that.$Modal.confirm({
        title: '删除文件夹和文件',
        content: '您确定要删除改文件？',
        loading: true,
        onOk: function onOk() {
          var data = {
            path: that.contextData.pathname,
            fileToken: _this4.fileToken
          };
          delFolder(data).then( /*#__PURE__*/function () {
            var _ref6 = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee5(res) {
              return regeneratorRuntime.wrap(function _callee5$(_context5) {
                while (1) {
                  switch (_context5.prev = _context5.next) {
                    case 0:
                      that.loopDel(that.navList, that.contextData.nodeKey);
                      that.$Modal.remove();
                      that.$Message.success('删除成功');

                    case 3:
                    case "end":
                      return _context5.stop();
                  }
                }
              }, _callee5);
            }));

            return function (_x5) {
              return _ref6.apply(this, arguments);
            };
          }()).catch(function (res) {
            that.catchFun(res);
          });
        },
        onCancel: function onCancel() {
          that.$Message.info('取消删除');
        }
      });
    },
    //重命名
    handleContextRename: function handleContextRename() {
      this.formFile.filename = this.contextData.title;
      this.formTitle = '重命名文件';
      this.formShow = true;
      this.fileType = 'renameFile';
    },
    //打开文件
    openfile: function openfile(path, is_edit) {
      var that = this;
      var params = {
        filepath: path,
        fileToken: this.fileToken
      };
      openfileApi(params).then( /*#__PURE__*/function () {
        var _ref7 = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee6(res) {
          var data;
          return regeneratorRuntime.wrap(function _callee6$(_context6) {
            while (1) {
              switch (_context6.prev = _context6.next) {
                case 0:
                  data = res.data;
                  that.code = data.content; // 保存相对信息

                  that.editorList[that.indexEditor].path = path;
                  that.editorList[that.indexEditor].oldCode = that.code; //改变属性

                  that.changeModel(data.mode, that.code);

                  if (!is_edit) {
                    that.modals = true;
                    that.spinShow = false;
                  }

                case 6:
                case "end":
                  return _context6.stop();
              }
            }
          }, _callee6);
        }));

        return function (_x6) {
          return _ref7.apply(this, arguments);
        };
      }()).catch(function (res) {
        that.catchFun(res);
      });
    },

    /**
     * 初始化编辑器
     */
    initEditor: function initEditor() {
      var that = this;
      that.$nextTick(function () {
        console.log(monaco); // 初始化编辑器，确保dom已经渲染

        that.editor = monaco.editor.create(document.getElementById('container_' + that.indexEditor), {
          value: that.code,
          //编辑器初始显示文字
          language: 'sql',
          //语言支持自行查阅demo
          automaticLayout: true,
          //自动布局
          theme: 'vs',
          //官方自带三种主题vs, hc-black, or vs-dark
          foldingStrategy: 'indentation',
          // 代码可分小段折叠
          overviewRulerBorder: false,
          // 不要滚动条的边框
          scrollbar: {
            // 滚动条设置
            verticalScrollbarSize: 4,
            // 竖滚动条
            horizontalScrollbarSize: 10 // 横滚动条

          },
          autoIndent: true,
          // 自动布局
          tabSize: 4,
          // tab缩进长度
          autoClosingOvertype: 'always'
        }); //添加按键监听

        that.editor.addCommand(monaco.KeyMod.CtrlCmd | monaco.KeyCode.KEY_S, function () {
          that.savefile(that.indexEditor);
        });
        that.editor.onKeyUp(function () {
          // 当键盘按下，判断当前编辑器文本与已保存的编辑器文本是否一致
          if (that.editor.getValue() != that.code) {
            that.isSave = false;
            that.editorIndex[that.indexEditor].icon = 'md-warning';
            that.editorList[that.indexEditor].isSave = false;
          }
        });
        that.editorList.push({
          editor: that.editor,
          oldCode: that.code,
          path: '',
          isSave: true,
          index: that.indexEditor
        });
      });
    },

    /**
     * 切换语言
     * @param {Object} mode
     */
    changeModel: function changeModel(mode, value) {
      var oldModel = this.editorList[this.indexEditor].editor.getModel(); //获取旧模型
      // var value = this.editor.getValue();//获取旧的文本
      //创建新模型，value为旧文本，id为modeId，即语言（language.id）
      //modesIds即为支持语言
      // var modesIds = monaco.languages.getLanguages().map(function(lang) { return lang.id; });

      if (!mode) mode = oldModel.getLanguageId(); // if(!value) value = this.editor.getValue();

      var newModel = monaco.editor.createModel(value, mode); //将旧模型销毁

      if (oldModel) {
        oldModel.dispose();
      } //设置新模型


      this.editorList[this.indexEditor].editor.setModel(newModel);
    },
    // 文件操作类型 createFolder|创建文件夹 createFile|创建文件 delFolder|删除文件夹或者文件
    handleSubmit: function handleSubmit(name) {
      var _this5 = this;

      var that = this;
      var data = '';
      var dataItem = '';
      this.$refs[name].validate(function (valid) {
        if (valid) {
          switch (that.fileType) {
            case 'createFolder':
              data = {
                path: that.contextData.pathname,
                name: that.formFile.filename,
                fileToken: _this5.fileToken
              };
              createFolder(data).then( /*#__PURE__*/function () {
                var _ref8 = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee7(res) {
                  return regeneratorRuntime.wrap(function _callee7$(_context7) {
                    while (1) {
                      switch (_context7.prev = _context7.next) {
                        case 0:
                          dataItem = {
                            dir: that.contextData.path,
                            superior: 0,
                            filedir: that.contextData.title,
                            fileToken: _this5.fileToken
                          };
                          that.getListItem(dataItem);
                          if (that.formShow) that.formShow = false;
                          that.$Message.success('创建成功');

                        case 4:
                        case "end":
                          return _context7.stop();
                      }
                    }
                  }, _callee7);
                }));

                return function (_x7) {
                  return _ref8.apply(this, arguments);
                };
              }()).catch(function (res) {
                that.catchFun(res);
              });
              break;

            case 'createFile':
              data = {
                path: that.contextData.pathname,
                name: that.formFile.filename,
                fileToken: _this5.fileToken
              };
              createFile(data).then( /*#__PURE__*/function () {
                var _ref9 = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee8(res) {
                  return regeneratorRuntime.wrap(function _callee8$(_context8) {
                    while (1) {
                      switch (_context8.prev = _context8.next) {
                        case 0:
                          dataItem = {
                            dir: that.contextData.path,
                            superior: 0,
                            filedir: that.contextData.title,
                            fileToken: _this5.fileToken
                          };
                          that.getListItem(dataItem);
                          if (that.formShow) that.formShow = false;
                          that.$Message.success('创建成功');

                        case 4:
                        case "end":
                          return _context8.stop();
                      }
                    }
                  }, _callee8);
                }));

                return function (_x8) {
                  return _ref9.apply(this, arguments);
                };
              }()).catch(function (res) {
                that.catchFun(res);
              });
              break;

            case 'renameFile':
              data = {
                newname: that.contextData.path + '\\' + that.formFile.filename,
                oldname: that.contextData.pathname,
                fileToken: _this5.fileToken
              };
              rename(data).then( /*#__PURE__*/function () {
                var _ref10 = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee9(res) {
                  return regeneratorRuntime.wrap(function _callee9$(_context9) {
                    while (1) {
                      switch (_context9.prev = _context9.next) {
                        case 0:
                          that.$set(that.contextData, 'title', that.formFile.filename);
                          that.$Message.success('修改成功');
                          if (that.formShow) that.formShow = false;

                        case 3:
                        case "end":
                          return _context9.stop();
                      }
                    }
                  }, _callee9);
                }));

                return function (_x9) {
                  return _ref10.apply(this, arguments);
                };
              }()).catch(function (res) {
                that.catchFun(res);
              });
              break;
          }
        } else {
          _this5.$Message.error('Fail!');
        }
      });
    },

    /**
     * 退出表单
     */
    formExit: function formExit() {
      this.formShow = false;
    },

    /**
     * 处理接口回调
     * @param {Object} res
     */
    catchFun: function catchFun(res) {
      if (res.status) {
        if (res.status == 400) this.$Message.error(res.msg);

        if (res.status == 110008) {
          // this.$Message.error(res.msg);
          this.isShowLogn = true;
          this.isShowList = false;
          this.loading = false;
        }
      } else {// this.$Message.error('文件编码不被兼容，无法正确读取文件!');
      } //关闭蒙版层


      if (this.spinShow) this.spinShow = false; // 关闭文件列表展示

      if (this.loading) this.loading = false;
    },
    loopDel: function loopDel(data, nodeKey) {
      var _this6 = this;

      data.forEach(function (item, index) {
        if (item.nodeKey === nodeKey) {
          return data.splice(index, 1);
        }

        if (item.children.length > 0) {
          return _this6.loopDel(item.children, nodeKey);
        }
      });
    },

    /**
     * 窗口最大化
     */
    winChanges: function winChanges() {
      if (this.className) {
        this.className = '';
      } else {
        this.className = 'diy-fullscreen';
      }
    },

    /**
     * 切换选项卡
     * @param {Object} index
     */
    toggleEditor: function toggleEditor(index) {
      index = Number(index);
      this.code = this.editorList[index].oldCode; //设置文件打开时的代码

      this.editor = this.editorList[index].editor; //设置编辑器实例
    },
    handleTabRemove: function handleTabRemove(index) {
      var that = this; // 关闭选项卡

      that.editorIndex[index].tab = false; // 关闭选项卡
      // 判断当前文件有没有保存

      if (!that.editorList[index].isSave) {
        that.$Modal.confirm({
          title: '文件未保存',
          content: '您是否需要保存当前文件',
          loading: true,
          onOk: function onOk() {
            // 保存文件
            that.savefile(index);
          },
          onCancel: function onCancel() {
            that.$Message.info('取消保存');
          }
        });
      }
    },
    //编辑器状态变化
    editModalChange: function editModalChange() {
      var that = this;
      that.editorList.forEach(function (value, index) {
        if (value.isSave === false) {
          if (confirm("".concat(that.editorIndex[index].title, "\u6587\u4EF6\u672A\u4FDD\u5B58,\u662F\u5426\u8981\u4FDD\u5B58\u8BE5\u6587\u4EF6"))) {
            // 保存当前文件
            that.savefile(index, true);
          } else {
            that.$Message.info("\u5DF2\u53D6\u6D88".concat(that.editorIndex[index].title, "\u6587\u4EF6\u4FDD\u5B58"));
          }
        } // 销毁当前编辑器


        that.editorList[index].editor.dispose();
        that.editorList[index].editor = null;
      }); // 初始话数据

      that.modals = false; //编辑器开关

      that.editor = ''; //当前编辑器对象

      that.editorIndex = [//选项卡数组
      {
        tab: true,
        index: '0',
        title: '',
        icon: ''
      }];
      that.editorList = []; //编辑器数组

      that.indexEditor = '0'; //当前编辑器索引

      that.code = ''; //当前文件打开时的内容

      that.navList = []; //左侧导航数据

      that.navItem = {}; //左侧导航点击是选中的数据

      that.contextData = null; //左侧导航右键点击是产生的数据对象
    }
  }
};"},{"version":3,"mappings":"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","names":["opendirListApi","openfileApi","savefileApi","opendirLoginApi","createFolder","createFile","delFolder","rename","name","data","modals","editor","editorIndex","tab","index","title","icon","editorList","indexEditor","code","navList","navItem","contextData","fileType","className","isSave","isShowLogn","isShowList","spinShow","loading","tabList","columns4","slot","minWidth","back","key","formItem","dir","superior","filedir","fileToken","pathname","formFile","filename","ruleInline","required","message","trigger","formShow","formTitle","components","loginFrom","mounted","created","beforeDestroy","removeCookies","computed","methods","currentChange","currentRow","getList","refresh","is_edit","params","then","res","catch","getListItem","goBack","open","row","edit","savefile","type","comment","filepath","that","refreshfile","getExpiresTime","expiresTime","loadData","item","callback","renderContent","h","style","display","cursor","userSelect","color","on","click","contextmenu","props","marginRight","attrs","clickDir","root","node","handleContextMenu","event","position","handleContextCreateFolder","handleContextCreateFile","handleContextDelFolder","content","onOk","path","onCancel","handleContextRename","openfile","initEditor","console","value","language","automaticLayout","theme","foldingStrategy","overviewRulerBorder","scrollbar","verticalScrollbarSize","horizontalScrollbarSize","autoIndent","tabSize","autoClosingOvertype","oldCode","changeModel","mode","oldModel","handleSubmit","dataItem","newname","oldname","formExit","catchFun","loopDel","nodeKey","winChanges","toggleEditor","handleTabRemove","editModalChange"],"sourceRoot":"src/pages/system/maintain/systemFile","sources":["opendir.vue"],"sourcesContent":["<template>\r\n <div>\r\n <Card :bordered=\"false\" dis-hover class=\"ivu-mt\">\r\n <div v-if=\"isShowList\" class=\"backs\" @click=\"goBack(false)\">\r\n <Icon type=\"ios-folder-outline\" class=\"mr5 icon\" /><span>返回上级</span>\r\n </div>\r\n <Table\r\n v-if=\"isShowList\"\r\n ref=\"selection\"\r\n :columns=\"columns4\"\r\n :data=\"tabList\"\r\n :loading=\"loading\"\r\n no-data-text=\"暂无数据\"\r\n highlight-row\r\n class=\"mt20\"\r\n @on-current-change=\"currentChange\"\r\n no-filtered-data-text=\"暂无筛选结果\"\r\n >\r\n <template slot-scope=\"{ row }\" slot=\"filename\">\r\n <Icon type=\"ios-folder-outline\" v-if=\"row.isDir\" class=\"mr5\" />\r\n <Icon type=\"ios-document-outline\" v-else class=\"mr5\" />\r\n <span>{{ row.filename }}</span>\r\n </template>\r\n <template slot-scope=\"{ row }\" slot=\"isWritable\">\r\n <span v-text=\"row.isWritable ? '是' : '否'\"></span>\r\n </template>\r\n <template slot-scope=\"{ row, index }\" slot=\"action\">\r\n <a @click=\"open(row)\" v-if=\"row.isDir\">打开</a>\r\n <a @click=\"edit(row)\" v-else>编辑</a>\r\n </template>\r\n </Table>\r\n </Card>\r\n <Modal\r\n :class-name=\"className\"\r\n v-model=\"modals\"\r\n scrollable\r\n footer-hide\r\n closable\r\n :mask-closable=\"false\"\r\n width=\"80%\"\r\n :before-close=\"editModalChange\"\r\n >\r\n <p slot=\"header\" class=\"diy-header\" ref=\"diyHeader\">\r\n <span>{{ title }}</span>\r\n <Icon\r\n @click=\"winChanges\"\r\n class=\"diy-header-icon\"\r\n :type=\"className ? 'ios-contract' : 'ios-qr-scanner'\"\r\n size=\"20\"\r\n />\r\n </p>\r\n <div style=\"height: 100%\">\r\n <Button type=\"primary\" id=\"savefile\" class=\"diy-button\" @click=\"savefile(indexEditor)\">保存</Button>\r\n <Button id=\"refresh\" class=\"diy-button\" @click=\"refreshfile\">刷新</Button>\r\n\r\n <div class=\"file-box\">\r\n <div class=\"show-info\">\r\n <div class=\"show-text\" :title=\"navItem.pathname\">目录: {{ navItem.pathname }}</div>\r\n <div class=\"diy-button-list\">\r\n <Button class=\"diy-button\" @click=\"goBack(true)\">返回上一级</Button>\r\n <Button class=\"diy-button\" @click=\"getList(true, true)\">刷新</Button>\r\n </div>\r\n </div>\r\n <div class=\"file-left\">\r\n <Tree\r\n class=\"diy-tree-render\"\r\n :data=\"navList\"\r\n :render=\"renderContent\"\r\n :load-data=\"loadData\"\r\n @on-contextmenu=\"handleContextMenu\"\r\n expand-node\r\n >\r\n <template transfer slot=\"contextMenu\">\r\n <DropdownItem v-if=\"contextData && contextData.isDir\" @click.native=\"handleContextCreateFolder()\"\r\n >新建文件夹</DropdownItem\r\n >\r\n <DropdownItem v-if=\"contextData && contextData.isDir\" @click.native=\"handleContextCreateFile()\"\r\n >新建文件</DropdownItem\r\n >\r\n <DropdownItem @click.native=\"handleContextRename()\">重命名</DropdownItem>\r\n <DropdownItem @click.native=\"handleContextDelFolder()\" style=\"color: #ed4014\">删除</DropdownItem>\r\n </template>\r\n </Tree>\r\n </div>\r\n <div class=\"file-fix\"></div>\r\n <div class=\"file-content\">\r\n <Tabs\r\n type=\"card\"\r\n v-model=\"indexEditor\"\r\n style=\"height: 100%\"\r\n @on-click=\"toggleEditor\"\r\n :animated=\"false\"\r\n closable\r\n @on-tab-remove=\"handleTabRemove\"\r\n >\r\n <TabPane\r\n v-for=\"value in editorIndex\"\r\n :key=\"value.index\"\r\n :name=\"value.index.toString()\"\r\n :label=\"value.title\"\r\n :icon=\"value.icon\"\r\n v-if=\"value.tab\"\r\n >\r\n <div ref=\"container\" :id=\"'container_' + value.index\" style=\"height: 100%; min-height: 560px\"></div>\r\n </TabPane>\r\n </Tabs>\r\n </div>\r\n <Spin size=\"large\" fix v-if=\"spinShow\"></Spin>\r\n </div>\r\n </div>\r\n </Modal>\r\n\r\n <div v-show=\"formShow\" class=\"diy-from\">\r\n <div class=\"diy-from-header\">\r\n {{ formTitle\r\n }}<span :title=\"contextData ? contextData.pathname : ''\">{{ contextData ? contextData.pathname : '' }}</span>\r\n </div>\r\n <Form ref=\"formInline\" :model=\"formFile\" :rules=\"ruleInline\" inline>\r\n <FormItem prop=\"filename\" class=\"diy-file\">\r\n <Input type=\"text\" class=\"diy-file\" v-model=\"formFile.filename\" placeholder=\"请输入名字\">\r\n <Icon type=\"ios-folder-open-outline\" slot=\"prepend\"></Icon>\r\n </Input>\r\n </FormItem>\r\n <FormItem>\r\n <Button class=\"diy-button\" @click=\"handleSubmit('formInline')\">确定</Button>\r\n </FormItem>\r\n <FormItem>\r\n <Button class=\"diy-button\" @click=\"formExit()\">取消</Button>\r\n </FormItem>\r\n <div class=\"form-mask\" v-show=\"formShow\"></div>\r\n </Form>\r\n </div>\r\n </div>\r\n</template>\r\n\r\n<script>\r\nimport { resolveComponent } from 'vue';\r\nimport {\r\n opendirListApi,\r\n openfileApi,\r\n savefileApi,\r\n opendirLoginApi,\r\n createFolder,\r\n createFile,\r\n delFolder,\r\n rename,\r\n} from '@/api/system';\r\nimport CodeMirror from 'codemirror/lib/codemirror';\r\nimport loginFrom from './components/loginFrom';\r\nimport { setCookies, getCookies, removeCookies } from '@/libs/util';\r\n// import Fullscreen from '@/components/main/components/fullscreen';\r\nimport * as monaco from 'monaco-editor';\r\nexport default {\r\n name: 'opendir',\r\n data() {\r\n return {\r\n modals: false, //编辑器开关\r\n editor: '', //当前编辑器对象\r\n editorIndex: [\r\n //选项卡数组\r\n {\r\n tab: true,\r\n index: '0',\r\n title: '',\r\n icon: '',\r\n },\r\n ],\r\n editorList: [], //编辑器数组\r\n indexEditor: 0, //当前编辑器索引\r\n code: '', //当前文件打开时的内容\r\n navList: [], //左侧导航数据\r\n navItem: {}, //左侧导航点击是选中的数据\r\n contextData: null, //左侧导航右键点击是产生的数据对象\r\n\r\n fileType: '', // 文件操作类型 createFolder|创建文件夹 createFile|创建文件 delFolder|删除文件夹或者文件\r\n className: '', //全屏 class名\r\n // fullscreen:false, // 是否全屏\r\n isSave: true, //当前文件是否保存\r\n\r\n isShowLogn: false, // 登录\r\n isShowList: false, // 登录之后列表\r\n\r\n spinShow: false,\r\n loading: false,\r\n tabList: [],\r\n columns4: [\r\n {\r\n title: '文件/文件夹名',\r\n slot: 'filename',\r\n minWidth: 150,\r\n back: '返回上级',\r\n },\r\n {\r\n title: '文件/文件夹路径',\r\n key: 'real_path',\r\n minWidth: 150,\r\n },\r\n {\r\n title: '文件/文件夹大小',\r\n key: 'size',\r\n minWidth: 100,\r\n },\r\n {\r\n title: '是否可写',\r\n slot: 'isWritable',\r\n minWidth: 100,\r\n },\r\n {\r\n title: '更新时间',\r\n key: 'mtime',\r\n minWidth: 150,\r\n },\r\n {\r\n title: '操作',\r\n slot: 'action',\r\n minWidth: 150,\r\n },\r\n ],\r\n formItem: {\r\n //记录当前路径信息,获取文件列表时使用\r\n dir: '',\r\n superior: 0,\r\n filedir: '',\r\n fileToken: getCookies('file_token'),\r\n },\r\n dir: '', //当前完整文件路径\r\n // rows: {}, //\r\n pathname: '', // 当前文件路径\r\n title: '', //当前文件标题\r\n\r\n formFile: {\r\n //重命名表单\r\n filename: '',\r\n },\r\n ruleInline: {\r\n filename: [{ required: true, message: '请输入文件或文件夹的名字', trigger: 'blur' }],\r\n },\r\n formShow: false, //表单开关\r\n formTitle: '', //表单标题\r\n fileToken: getCookies('file_token'),\r\n };\r\n },\r\n\r\n components: {\r\n loginFrom,\r\n },\r\n mounted() {\r\n this.initEditor();\r\n },\r\n created() {\r\n this.getList();\r\n },\r\n beforeDestroy() {\r\n removeCookies('file_token');\r\n },\r\n computed: {},\r\n methods: {\r\n // 点击行\r\n currentChange(currentRow) {\r\n if (currentRow.isDir) {\r\n this.open(currentRow);\r\n } else {\r\n this.edit(currentRow);\r\n }\r\n },\r\n /**\r\n * 文件列表\r\n * @param {Object} refresh // 是否重新加载 bool\r\n * @param {Object} is_edit // 是否是编辑器中的刷新 bool\r\n */\r\n getList(refresh, is_edit) {\r\n let params;\r\n if (refresh) {\r\n params = {\r\n dir: '',\r\n superior: 0,\r\n filedir: '',\r\n fileToken: this.fileToken,\r\n };\r\n } else {\r\n params = this.formItem;\r\n params.fileToken = this.fileToken;\r\n }\r\n if (!is_edit) this.loading = true;\r\n opendirListApi(params)\r\n .then(async (res) => {\r\n let data = res.data;\r\n if (is_edit) {\r\n this.navList = data.navList;\r\n } else {\r\n this.navListForTab = data.navList;\r\n this.tabList = data.list;\r\n // this.navList = data.navList;\r\n this.isShowList = true;\r\n }\r\n this.dir = data.dir;\r\n this.isShowLogn = false;\r\n this.loading = false;\r\n })\r\n .catch((res) => {\r\n this.catchFun(res);\r\n });\r\n },\r\n //新建文件后重新加载左侧导航\r\n getListItem(data) {\r\n opendirListApi(data)\r\n .then(async (res) => {\r\n this.$set(this.contextData, 'children', res.data.navList);\r\n })\r\n .catch((res) => {\r\n this.catchFun(res);\r\n });\r\n },\r\n\r\n // 返回上级\r\n goBack(is_edit) {\r\n this.formItem = {\r\n dir: this.dir,\r\n superior: 1,\r\n filedir: '',\r\n };\r\n this.getList(false, is_edit);\r\n },\r\n // 打开\r\n open(row) {\r\n // this.rows = row;\r\n this.formItem = {\r\n dir: row.path,\r\n superior: 0,\r\n filedir: row.filename,\r\n fileToken: this.fileToken,\r\n };\r\n this.getList(false, false);\r\n },\r\n // 编辑\r\n edit(row) {\r\n this.navItem = row;\r\n this.spinShow = true;\r\n this.pathname = row.pathname;\r\n this.title = row.filename;\r\n this.editorIndex[0].title = row.filename;\r\n this.editorIndex[0].pathname = row.pathname;\r\n this.navList = this.navListForTab;\r\n this.dir = row.path;\r\n // 创建代码容器\r\n if (this.editorList.length <= 0) {\r\n this.initEditor();\r\n }\r\n this.openfile(row.pathname, false);\r\n },\r\n /**\r\n * 保存\r\n * @param {Object} index // 当前索引\r\n * @param {Object} type // true 不更新当前本地数据,false或者为空 更新当前数据\r\n */\r\n savefile(index, type) {\r\n let code = this.editorList[index].editor.getValue();\r\n let data = {\r\n comment: code,\r\n filepath: this.editorList[index].path,\r\n fileToken: this.fileToken,\r\n };\r\n let that = this;\r\n savefileApi(data)\r\n .then(async (res) => {\r\n if (!type) {\r\n that.code = code;\r\n that.isSave = true;\r\n that.editorIndex[index].icon = '';\r\n that.editorList[index].isSave = true;\r\n }\r\n that.$Message.success(res.msg);\r\n that.$Modal.remove();\r\n })\r\n .catch((res) => {\r\n that.catchFun(res);\r\n });\r\n },\r\n // 刷新\r\n refreshfile() {\r\n // 刷新编辑器\r\n if (this.editorList[this.indexEditor]) this.openfile(this.editorList[this.indexEditor].path, true);\r\n },\r\n //计算token过期时间\r\n getExpiresTime(expiresTime) {\r\n let nowTimeNum = Math.round(new Date() / 1000);\r\n let expiresTimeNum = expiresTime - nowTimeNum;\r\n return parseFloat(parseFloat(parseFloat(expiresTimeNum / 60) / 60) / 24);\r\n },\r\n // 侧边栏异步加载\r\n loadData(item, callback) {\r\n if (item.isDir) {\r\n this.formItem = {\r\n dir: item.path,\r\n superior: 0,\r\n filedir: item.title,\r\n fileToken: this.fileToken,\r\n };\r\n opendirListApi(this.formItem)\r\n .then(async (res) => {\r\n callback(res.data.navList);\r\n })\r\n .catch((res) => {\r\n if (res.status == 110008) {\r\n this.$Message.error(res.msg);\r\n this.isShowLogn = true;\r\n this.isShowList = false;\r\n this.loading = false;\r\n } else {\r\n this.catchFun(res);\r\n }\r\n });\r\n }\r\n },\r\n // 自定义显示\r\n renderContent(h, { root, node, data }) {\r\n let that = this;\r\n return h(\r\n 'span',\r\n {\r\n style: {\r\n display: 'inline-block',\r\n cursor: 'pointer',\r\n userSelect: 'null',\r\n color: '#cccccc',\r\n display: 'inline-block',\r\n width: '100%',\r\n borderRadis: '5px',\r\n },\r\n on: {\r\n click: () => {\r\n that.clickDir(data, root, node);\r\n },\r\n contextmenu: () => {\r\n // that.handleContextDelFolder(data,root,node);\r\n },\r\n },\r\n },\r\n [\r\n h('span', [\r\n h('Icon', {\r\n props: {\r\n type: data.isDir ? 'md-folder' : 'ios-document-outline',\r\n },\r\n style: {\r\n marginRight: '8px',\r\n },\r\n }),\r\n h(\r\n 'span',\r\n {\r\n attrs: {\r\n title: data.title,\r\n },\r\n },\r\n data.title,\r\n ),\r\n ]),\r\n ],\r\n );\r\n },\r\n /**\r\n * 侧边栏点击事件\r\n * @param {Object} data\r\n */\r\n clickDir(data, root, node) {\r\n let that = this;\r\n that.navItem = data;\r\n that.pathname = data.pathname;\r\n\r\n if (!data.isDir) {\r\n let i = that.editorIndex.findIndex((e) => {\r\n return e.pathname === data.pathname;\r\n });\r\n if (i > -1) {\r\n that.toggleEditor(i);\r\n that.indexEditor = i.toString();\r\n } else {\r\n let index = that.editorIndex.length;\r\n // 创建tabs\r\n that.editorIndex.push({\r\n tab: true,\r\n index: index.toString(),\r\n title: data.title,\r\n icon: '',\r\n pathname: data.pathname,\r\n });\r\n that.indexEditor = index.toString();\r\n // 创建代码容器\r\n that.initEditor();\r\n that.openfile(data.pathname, true);\r\n }\r\n }\r\n },\r\n //侧边栏右键点击事件\r\n handleContextMenu(data, event, position) {\r\n position.left = Number(position.left.slice(0, -2)) + 75 + 'px';\r\n this.contextData = data;\r\n },\r\n // 文件操作类型 createFolder|创建文件夹 createFile|创建文件 delFolder|删除文件夹或者文件 renameFile|文件重命名\r\n //创建文件夹\r\n handleContextCreateFolder() {\r\n this.formFile.filename = '';\r\n this.formTitle = '创建文件夹';\r\n this.formShow = true;\r\n this.fileType = 'createFolder';\r\n },\r\n //创建文件\r\n handleContextCreateFile() {\r\n this.formFile.filename = '';\r\n this.formTitle = '创建文件';\r\n this.formShow = true;\r\n this.fileType = 'createFile';\r\n },\r\n //删除文件\r\n handleContextDelFolder() {\r\n let that = this;\r\n that.$Modal.confirm({\r\n title: '删除文件夹和文件',\r\n content: '您确定要删除改文件?',\r\n loading: true,\r\n onOk: () => {\r\n let data = {\r\n path: that.contextData.pathname,\r\n fileToken: this.fileToken,\r\n };\r\n delFolder(data)\r\n .then(async (res) => {\r\n that.loopDel(that.navList, that.contextData.nodeKey);\r\n that.$Modal.remove();\r\n that.$Message.success('删除成功');\r\n })\r\n .catch((res) => {\r\n that.catchFun(res);\r\n });\r\n },\r\n onCancel: () => {\r\n that.$Message.info('取消删除');\r\n },\r\n });\r\n },\r\n //重命名\r\n handleContextRename() {\r\n this.formFile.filename = this.contextData.title;\r\n this.formTitle = '重命名文件';\r\n this.formShow = true;\r\n this.fileType = 'renameFile';\r\n },\r\n //打开文件\r\n openfile(path, is_edit) {\r\n let that = this;\r\n let params = {\r\n filepath: path,\r\n fileToken: this.fileToken,\r\n };\r\n openfileApi(params)\r\n .then(async (res) => {\r\n let data = res.data;\r\n that.code = data.content;\r\n // 保存相对信息\r\n that.editorList[that.indexEditor].path = path;\r\n that.editorList[that.indexEditor].oldCode = that.code;\r\n //改变属性\r\n that.changeModel(data.mode, that.code);\r\n if (!is_edit) {\r\n that.modals = true;\r\n that.spinShow = false;\r\n }\r\n })\r\n .catch((res) => {\r\n that.catchFun(res);\r\n });\r\n },\r\n /**\r\n * 初始化编辑器\r\n */\r\n initEditor() {\r\n let that = this;\r\n that.$nextTick(() => {\r\n console.log(monaco);\r\n // 初始化编辑器,确保dom已经渲染\r\n that.editor = monaco.editor.create(document.getElementById('container_' + that.indexEditor), {\r\n value: that.code, //编辑器初始显示文字\r\n language: 'sql', //语言支持自行查阅demo\r\n automaticLayout: true, //自动布局\r\n theme: 'vs', //官方自带三种主题vs, hc-black, or vs-dark\r\n foldingStrategy: 'indentation', // 代码可分小段折叠\r\n overviewRulerBorder: false, // 不要滚动条的边框\r\n scrollbar: {\r\n // 滚动条设置\r\n verticalScrollbarSize: 4, // 竖滚动条\r\n horizontalScrollbarSize: 10, // 横滚动条\r\n },\r\n autoIndent: true, // 自动布局\r\n tabSize: 4, // tab缩进长度\r\n autoClosingOvertype: 'always',\r\n });\r\n //添加按键监听\r\n that.editor.addCommand(monaco.KeyMod.CtrlCmd | monaco.KeyCode.KEY_S, function () {\r\n that.savefile(that.indexEditor);\r\n });\r\n that.editor.onKeyUp(() => {\r\n // 当键盘按下,判断当前编辑器文本与已保存的编辑器文本是否一致\r\n if (that.editor.getValue() != that.code) {\r\n that.isSave = false;\r\n that.editorIndex[that.indexEditor].icon = 'md-warning';\r\n that.editorList[that.indexEditor].isSave = false;\r\n }\r\n });\r\n that.editorList.push({\r\n editor: that.editor,\r\n oldCode: that.code,\r\n path: '',\r\n isSave: true,\r\n index: that.indexEditor,\r\n });\r\n });\r\n },\r\n /**\r\n * 切换语言\r\n * @param {Object} mode\r\n */\r\n changeModel(mode, value) {\r\n var oldModel = this.editorList[this.indexEditor].editor.getModel(); //获取旧模型\r\n // var value = this.editor.getValue();//获取旧的文本\r\n //创建新模型,value为旧文本,id为modeId,即语言(language.id)\r\n //modesIds即为支持语言\r\n // var modesIds = monaco.languages.getLanguages().map(function(lang) { return lang.id; });\r\n if (!mode) mode = oldModel.getLanguageId();\r\n // if(!value) value = this.editor.getValue();\r\n\r\n var newModel = monaco.editor.createModel(value, mode);\r\n //将旧模型销毁\r\n if (oldModel) {\r\n oldModel.dispose();\r\n }\r\n //设置新模型\r\n this.editorList[this.indexEditor].editor.setModel(newModel);\r\n },\r\n // 文件操作类型 createFolder|创建文件夹 createFile|创建文件 delFolder|删除文件夹或者文件\r\n handleSubmit(name) {\r\n let that = this;\r\n let data = '';\r\n let dataItem = '';\r\n this.$refs[name].validate((valid) => {\r\n if (valid) {\r\n switch (that.fileType) {\r\n case 'createFolder':\r\n data = {\r\n path: that.contextData.pathname,\r\n name: that.formFile.filename,\r\n fileToken: this.fileToken,\r\n };\r\n createFolder(data)\r\n .then(async (res) => {\r\n dataItem = {\r\n dir: that.contextData.path,\r\n superior: 0,\r\n filedir: that.contextData.title,\r\n fileToken: this.fileToken,\r\n };\r\n that.getListItem(dataItem);\r\n if (that.formShow) that.formShow = false;\r\n that.$Message.success('创建成功');\r\n })\r\n .catch((res) => {\r\n that.catchFun(res);\r\n });\r\n break;\r\n case 'createFile':\r\n data = {\r\n path: that.contextData.pathname,\r\n name: that.formFile.filename,\r\n fileToken: this.fileToken,\r\n };\r\n createFile(data)\r\n .then(async (res) => {\r\n dataItem = {\r\n dir: that.contextData.path,\r\n superior: 0,\r\n filedir: that.contextData.title,\r\n fileToken: this.fileToken,\r\n };\r\n that.getListItem(dataItem);\r\n if (that.formShow) that.formShow = false;\r\n that.$Message.success('创建成功');\r\n })\r\n .catch((res) => {\r\n that.catchFun(res);\r\n });\r\n break;\r\n case 'renameFile':\r\n data = {\r\n newname: that.contextData.path + '\\\\' + that.formFile.filename,\r\n oldname: that.contextData.pathname,\r\n fileToken: this.fileToken,\r\n };\r\n rename(data)\r\n .then(async (res) => {\r\n that.$set(that.contextData, 'title', that.formFile.filename);\r\n that.$Message.success('修改成功');\r\n if (that.formShow) that.formShow = false;\r\n })\r\n .catch((res) => {\r\n that.catchFun(res);\r\n });\r\n break;\r\n }\r\n } else {\r\n this.$Message.error('Fail!');\r\n }\r\n });\r\n },\r\n /**\r\n * 退出表单\r\n */\r\n formExit() {\r\n this.formShow = false;\r\n },\r\n\r\n /**\r\n * 处理接口回调\r\n * @param {Object} res\r\n */\r\n catchFun(res) {\r\n if (res.status) {\r\n if (res.status == 400) this.$Message.error(res.msg);\r\n if (res.status == 110008) {\r\n // this.$Message.error(res.msg);\r\n this.isShowLogn = true;\r\n this.isShowList = false;\r\n this.loading = false;\r\n }\r\n } else {\r\n // this.$Message.error('文件编码不被兼容,无法正确读取文件!');\r\n }\r\n //关闭蒙版层\r\n if (this.spinShow) this.spinShow = false;\r\n // 关闭文件列表展示\r\n if (this.loading) this.loading = false;\r\n },\r\n loopDel(data, nodeKey) {\r\n data.forEach((item, index) => {\r\n if (item.nodeKey === nodeKey) {\r\n return data.splice(index, 1);\r\n }\r\n if (item.children.length > 0) {\r\n return this.loopDel(item.children, nodeKey);\r\n }\r\n });\r\n },\r\n /**\r\n * 窗口最大化\r\n */\r\n winChanges() {\r\n if (this.className) {\r\n this.className = '';\r\n } else {\r\n this.className = 'diy-fullscreen';\r\n }\r\n },\r\n /**\r\n * 切换选项卡\r\n * @param {Object} index\r\n */\r\n toggleEditor(index) {\r\n index = Number(index);\r\n this.code = this.editorList[index].oldCode; //设置文件打开时的代码\r\n this.editor = this.editorList[index].editor; //设置编辑器实例\r\n },\r\n handleTabRemove(index) {\r\n let that = this;\r\n\r\n // 关闭选项卡\r\n that.editorIndex[index].tab = false; // 关闭选项卡\r\n // 判断当前文件有没有保存\r\n if (!that.editorList[index].isSave) {\r\n that.$Modal.confirm({\r\n title: '文件未保存',\r\n content: '您是否需要保存当前文件',\r\n loading: true,\r\n onOk: () => {\r\n // 保存文件\r\n that.savefile(index);\r\n },\r\n onCancel: () => {\r\n that.$Message.info('取消保存');\r\n },\r\n });\r\n }\r\n },\r\n //编辑器状态变化\r\n editModalChange() {\r\n let that = this;\r\n that.editorList.forEach(function (value, index) {\r\n if (value.isSave === false) {\r\n if (confirm(`${that.editorIndex[index].title}文件未保存,是否要保存该文件`)) {\r\n // 保存当前文件\r\n that.savefile(index, true);\r\n } else {\r\n that.$Message.info(`已取消${that.editorIndex[index].title}文件保存`);\r\n }\r\n }\r\n // 销毁当前编辑器\r\n that.editorList[index].editor.dispose();\r\n that.editorList[index].editor = null;\r\n });\r\n // 初始话数据\r\n that.modals = false; //编辑器开关\r\n that.editor = ''; //当前编辑器对象\r\n that.editorIndex = [\r\n //选项卡数组\r\n {\r\n tab: true,\r\n index: '0',\r\n title: '',\r\n icon: '',\r\n },\r\n ];\r\n that.editorList = []; //编辑器数组\r\n that.indexEditor = '0'; //当前编辑器索引\r\n that.code = ''; //当前文件打开时的内容\r\n that.navList = []; //左侧导航数据\r\n that.navItem = {}; //左侧导航点击是选中的数据\r\n that.contextData = null; //左侧导航右键点击是产生的数据对象\r\n },\r\n },\r\n};\r\n</script>\r\n<style scoped>\r\n.file-left /deep/ .ivu-tree-title {\r\n font-weight: 500;\r\n font-family: SourceHanSansSC-regular, '微软雅黑', Arial, Helvetica, sans-serif;\r\n}\r\n.file-content /deep/ .ivu-tabs.ivu-tabs-card > .ivu-tabs-bar .ivu-tabs-tab-active {\r\n border-bottom: 1px solid orange;\r\n}\r\n</style>\r\n<style scoped lang=\"stylus\">\r\n.file-left\r\n padding-left 10px\r\n >>>.ivu-icon-ios-arrow-forward\r\n font-size 18px !important;\r\n\t color #cccccc\r\n >>>.ivu-icon-ios-folder-outline\r\n font-size 14px !important;\r\n >>>.ivu-icon-ios-document-outline\r\n font-size 18px !important;\r\n\t>>>.ivu-icon-md-folder{\r\n \tfont-size 18px !important;\r\n\t color #d6ab34 !important;\r\n\t}\r\n >>> .ivu-table-row\r\n cursor pointer;\r\n.mr5\r\n margin-right 5px\r\n.backs\r\n cursor pointer;\r\n display inline-block;\r\n .icon\r\n margin-bottom 3px\r\n>>>.CodeMirror\r\n height: 70vh !important;\r\n\r\n.file-box\r\n\tdisplay: flex;\r\n\talign-items: flex-start;\r\n\tjustify-content: space-between;\r\n\tposition: relative;\r\n\theight: 95%;\r\n\tmin-height: 600px;\r\n\toverflow: hidden;\r\n.file-box\r\n\t.file-left\r\n\t\tposition: absolute;\r\n\t\ttop: 53px;\r\n\t\tleft: 0;\r\n\t\theight: 90%;\r\n\t\t// height: 100%;\r\n\t\t// min-height: 600px;\r\n\t\twidth:25%;\r\n\t\tmax-width: 250px;\r\n\t\toverflow: auto;\r\n\t\tbackground-color: #222222;\r\n\t\tbox-shadow: #000000 -6px 0 6px -6px inset;\r\n\t.file-fix\r\n\t\tflex: 1;\r\n\t\tmax-width: 250px;\r\n\t\theight: 76vh;\r\n\t\tmin-height: 600px;\r\n\t\t// bottom: 0px;\r\n\t\t// overflow: auto;\r\n\t\tmin-height: 600px;\r\n\t\tbackground-color: #222222;\r\n.file-box\r\n\t.file-content\r\n\t\t// position: absolute;\r\n\t\t// top: 53px;\r\n\t\t// left: 25%;\r\n\t\tflex: 3;\r\n\t\toverflow: hidden;\r\n\t\tmin-height: 600px;\r\n\t\theight: 100%;\r\n>>>.ivu-modal-body\r\n\t\tpadding: 0;\r\n>>>.ivu-modal-content\r\n\tbackground-color: #292929\r\n.diy-button\r\n\t// float: left;\r\n\theight: 35px;\r\n\tpadding: 0 15px;\r\n\tfont-size: 13px;\r\n\ttext-align: center;\r\n\tcolor: #fff;\r\n\tborder: 0;\r\n\tborder-right: 1px solid #4c4c4c;\r\n\tcursor: pointer;\r\n\tborder-radius: 0\r\n\tbackground-color: #565656\r\n\r\n.form-mask\r\n\tz-index: -1;\r\n\twidth: 100%;\r\n\theight: 100%;\r\n\tposition: fixed;\r\n\ttop: 0;\r\n\tleft: 0;\r\n\tright: 0;\r\n\tbottom: 0;\r\n\tmargin: auto;\r\n\tbackground: rgba(0,0,0,0.3);\r\n.diy-from-header\r\n\theight: 30px\r\n\tline-height: 30px;\r\n\tbackground-color: #fff;\r\n\ttext-align: left;\r\n\tpadding-left: 20px\r\n\tfont-size: 16px;\r\n\tmargin-bottom: 15px;\r\n\tspan\r\n\t\tdisplay: inline-block;\r\n\t\tfloat: right;\r\n\t\tcolor: #999;\r\n\t\ttext-align: right;\r\n\t\tfont-size: 12px;\r\n\t\twidth: 280px;\r\n\t\tword-break:keep-all;/* 不换行 */\r\n\t\twhite-space:nowrap;/* 不换行 */\r\n\t\toverflow:hidden;\r\n\t\ttext-overflow:ellipsis;\r\n.diy-from\r\n\tz-index: 9999;\r\n\twidth: 400px;\r\n\theight: 100px;\r\n\tposition: fixed;\r\n\ttop: 0;\r\n\tleft: 0;\r\n\tright: 0;\r\n\tbottom: 0;\r\n\tmargin: auto;\r\n\ttext-align: center;\r\n\tbackground-color: #2f2f2f;\r\n.show-info\r\n\tbackground-color: #383838;\r\n\tcolor: #FFF;\r\n\twidth: 25%;\r\n\tmax-width: 250px;\r\n\tposition: absolute;\r\n\ttop: 0;\r\n\tleft: 0;\r\n\tz-index: 1122;\r\n\t.diy-button\r\n\t\twidth: 50%;\r\n\t\theight: 25px;\r\n\t.diy-button-list\r\n\t\tdisplay: flex;\r\n\t\talign-items: center;\r\n\t.show-text\r\n\t\tpadding-left: 10px;\r\n\t\tword-break:keep-all;/* 不换行 */\r\n\t\twhite-space:nowrap;/* 不换行 */\r\n\t\toverflow:hidden;\r\n\t\ttext-overflow:ellipsis;\r\n\t\tpadding: 7px 5px;\r\nbody >>>.ivu-select-dropdown{\r\n\tbackground: #fff;\r\n}\r\n.diy-tree-render\r\n\t>>>li\r\n\t\toverflow: hidden;\r\n\t>>>.ivu-tree-title\r\n\t\twidth: 90%;\r\n\t\tmax-width:250px;\r\n\t\tpadding: 0;\r\n\t\tpadding-left: 5px\r\n>>>.ivu-tree-children\r\n\t\t.ivu-tree-title:hover\r\n\t\t\tbackground-color:#2f2f2f !important;\r\n.file-box\r\n\t.file-left::-webkit-scrollbar\r\n\t\twidth: 4px;\r\n.file-box\r\n\t.file-left::-webkit-scrollbar-thumb\r\n\t\tborder-radius: 10px;\r\n\t\t-webkit-box-shadow: inset 0 0 5px rgba(0,0,0,0.2);\r\n\t\tbackground: rgba(255, 255, 255, 0.2);\r\n.file-box\r\n\t.file-left::-webkit-scrollbar-track\r\n\t\t-webkit-box-shadow: inset 0 0 5px rgba(0,0,0,0.2);\r\n\t\tborder-radius: 0;\r\n\t\tbackground: rgba(0,0,0,0.1);\r\n.diy-header\r\n\tdisplay: flex;\r\n\talign-items: center;\r\n\tjustify-content: space-between;\r\n\t.diy-header-icon\r\n\t\tmargin-right: 30px;\r\n\t\tcursor: pointer;\r\n\t.diy-header-icon:hover\r\n\t\topacity: 0.8;\r\n// 自定义方法缩小\r\n>>>.diy-fullscreen\r\n\t\toverflow: hidden;\r\n\t\t.ivu-modal\r\n\t\t\ttop: 0px;\r\n\t\t\tleft: 0px;\r\n\t\t\tright: 0px;\r\n\t\t\tbottom: 0px;\r\n\t\t\theight: 100%;\r\n\t\t\twidth: 100% !important;\r\n\t\t\t.ivu-modal-content\r\n\t\t\t\theight: 100%;\r\n\t\t\t\t.ivu-modal-body\r\n\t\t\t\t\theight: 100%;\r\n\t\t\t.ivu-tabs\r\n\t\t\t\t.ivu-tabs-content-animated\r\n\t\t\t\t\theight: 92%;\r\n\t\t\t\t\tbackground-color:#2f2f2f !important;\r\n\t\t\t.ivu-tabs-content\r\n\t\t\t\theight: 100%\r\n\t\t\t.ivu-tabs\r\n\t\t\t\t.ivu-tabs-tabpane\r\n\t\t\t\t\theight: 92%\r\n>>>.ivu-modal\r\n\t\ttop: 70px;\r\n\t.ivu-modal-content\r\n\t\t.ivu-modal-body\r\n\t\t\tmin-height: 632px;\r\n\t\t\theight: 80vh;\r\n\t\t\toverflow: hidden;\r\n\t.ivu-tabs\r\n\t\t.ivu-tabs-content-animated\r\n\t\t\tmin-height:560px;\r\n\t\t\theight: 73vh;\r\n\t\t\tmargin-top: -1px;\r\n\t\t.ivu-tabs-tabpane\r\n\t\t\tmin-height:560px;\r\n\t\t\theight: 73vh;\r\n\t\t\tmargin-top: -1px;\r\n\t.ivu-tabs-nav .ivu-tabs-tab .ivu-icon\r\n\t\tcolor: #f00;\r\n>>>body .ivu-select-dropdown .ivu-dropdown-transfer\r\n\t\tbackground:red !important;\r\n// 导航栏右键样式 无效\r\n\r\n\r\n.file-left /deep/ .ivu-select-dropdown.ivu-dropdown-transfer .ivu-dropdown-menu .ivu-dropdown-item:hover{\r\n\tbackground-color: #e5e5e5 !important;\r\n}\r\n// 选项卡头部\r\n>>>.ivu-tabs.ivu-tabs-card > .ivu-tabs-bar .ivu-tabs-nav-container\r\n\tbackground-color: #333;\r\n</style>\r\n"]}]}
|