aos-element
Version:
A Component Library for Vue.js.
606 lines (558 loc) • 19.6 kB
JavaScript
module.exports =
/******/ (function(modules) { // webpackBootstrap
/******/ // The module cache
/******/ var installedModules = {};
/******/
/******/ // The require function
/******/ function __webpack_require__(moduleId) {
/******/
/******/ // Check if module is in cache
/******/ if(installedModules[moduleId]) {
/******/ return installedModules[moduleId].exports;
/******/ }
/******/ // Create a new module (and put it into the cache)
/******/ var module = installedModules[moduleId] = {
/******/ i: moduleId,
/******/ l: false,
/******/ exports: {}
/******/ };
/******/
/******/ // Execute the module function
/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
/******/
/******/ // Flag the module as loaded
/******/ module.l = true;
/******/
/******/ // Return the exports of the module
/******/ return module.exports;
/******/ }
/******/
/******/
/******/ // expose the modules object (__webpack_modules__)
/******/ __webpack_require__.m = modules;
/******/
/******/ // expose the module cache
/******/ __webpack_require__.c = installedModules;
/******/
/******/ // define getter function for harmony exports
/******/ __webpack_require__.d = function(exports, name, getter) {
/******/ if(!__webpack_require__.o(exports, name)) {
/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter });
/******/ }
/******/ };
/******/
/******/ // define __esModule on exports
/******/ __webpack_require__.r = function(exports) {
/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
/******/ }
/******/ Object.defineProperty(exports, '__esModule', { value: true });
/******/ };
/******/
/******/ // create a fake namespace object
/******/ // mode & 1: value is a module id, require it
/******/ // mode & 2: merge all properties of value into the ns
/******/ // mode & 4: return value when already ns object
/******/ // mode & 8|1: behave like require
/******/ __webpack_require__.t = function(value, mode) {
/******/ if(mode & 1) value = __webpack_require__(value);
/******/ if(mode & 8) return value;
/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
/******/ var ns = Object.create(null);
/******/ __webpack_require__.r(ns);
/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value });
/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
/******/ return ns;
/******/ };
/******/
/******/ // getDefaultExport function for compatibility with non-harmony modules
/******/ __webpack_require__.n = function(module) {
/******/ var getter = module && module.__esModule ?
/******/ function getDefault() { return module['default']; } :
/******/ function getModuleExports() { return module; };
/******/ __webpack_require__.d(getter, 'a', getter);
/******/ return getter;
/******/ };
/******/
/******/ // Object.prototype.hasOwnProperty.call
/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
/******/
/******/ // __webpack_public_path__
/******/ __webpack_require__.p = "/dist/";
/******/
/******/
/******/ // Load entry module and return exports
/******/ return __webpack_require__(__webpack_require__.s = 176);
/******/ })
/************************************************************************/
/******/ ({
/***/ 0:
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; });
/* globals __VUE_SSR_CONTEXT__ */
// IMPORTANT: Do NOT use ES2015 features in this file (except for modules).
// This module is a runtime utility for cleaner component module output and will
// be included in the final webpack user bundle.
function normalizeComponent (
scriptExports,
render,
staticRenderFns,
functionalTemplate,
injectStyles,
scopeId,
moduleIdentifier, /* server only */
shadowMode /* vue-cli only */
) {
// Vue.extend constructor export interop
var options = typeof scriptExports === 'function'
? scriptExports.options
: scriptExports
// render functions
if (render) {
options.render = render
options.staticRenderFns = staticRenderFns
options._compiled = true
}
// functional template
if (functionalTemplate) {
options.functional = true
}
// scopedId
if (scopeId) {
options._scopeId = 'data-v-' + scopeId
}
var hook
if (moduleIdentifier) { // server build
hook = function (context) {
// 2.3 injection
context =
context || // cached call
(this.$vnode && this.$vnode.ssrContext) || // stateful
(this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional
// 2.2 with runInNewContext: true
if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') {
context = __VUE_SSR_CONTEXT__
}
// inject component styles
if (injectStyles) {
injectStyles.call(this, context)
}
// register component module identifier for async chunk inferrence
if (context && context._registeredComponents) {
context._registeredComponents.add(moduleIdentifier)
}
}
// used by ssr in case component is cached and beforeCreate
// never gets called
options._ssrRegister = hook
} else if (injectStyles) {
hook = shadowMode
? function () {
injectStyles.call(
this,
(options.functional ? this.parent : this).$root.$options.shadowRoot
)
}
: injectStyles
}
if (hook) {
if (options.functional) {
// for template-only hot-reload because in that case the render fn doesn't
// go through the normalizer
options._injectStyles = hook
// register for functional component in vue file
var originalRender = options.render
options.render = function renderWithStyleInjection (h, context) {
hook.call(context)
return originalRender(h, context)
}
} else {
// inject component registration as beforeCreate hook
var existing = options.beforeCreate
options.beforeCreate = existing
? [].concat(existing, hook)
: [hook]
}
}
return {
exports: scriptExports,
options: options
}
}
/***/ }),
/***/ 14:
/***/ (function(module, exports) {
module.exports = require("aos-element/lib/utils/popup");
/***/ }),
/***/ 176:
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
// ESM COMPAT FLAG
__webpack_require__.r(__webpack_exports__);
// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/aos-files-tree/src/main.vue?vue&type=template&id=3af968ba&
var render = function() {
var _vm = this
var _h = _vm.$createElement
var _c = _vm._self._c || _h
return _c(
"div",
{ staticClass: "aos-files-tree" },
[
_c("el-tree", {
attrs: {
"default-expand-all": "",
data: _vm.categorys,
props: _vm.defaultProps
},
on: { "node-click": _vm.handleNodeClick },
scopedSlots: _vm._u([
{
key: "default",
fn: function(ref) {
var node = ref.node
var data = ref.data
return _c("span", { staticClass: "aos-files-tree__tree-item" }, [
_c(
"span",
{
class: { "aos-files-tree__required": data.required },
attrs: { title: node.label }
},
[_vm._v(_vm._s(node.label))]
)
])
}
}
])
})
],
1
)
}
var staticRenderFns = []
render._withStripped = true
// CONCATENATED MODULE: ./packages/aos-files-tree/src/main.vue?vue&type=template&id=3af968ba&
// EXTERNAL MODULE: external "viewerjs-optimize"
var external_viewerjs_optimize_ = __webpack_require__(29);
var external_viewerjs_optimize_default = /*#__PURE__*/__webpack_require__.n(external_viewerjs_optimize_);
// EXTERNAL MODULE: external "aos-element/lib/utils/popup"
var popup_ = __webpack_require__(14);
// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/aos-files-tree/src/main.vue?vue&type=script&lang=js&
//
//
//
//
//
//
//
//
//
//
//
//
//
//
/* harmony default export */ var mainvue_type_script_lang_js_ = ({
name: 'AosFilesTree',
props: {
// 业务类型
businessModel: {
type: String,
required: true
},
// 业务主键
businessPk: {
type: String,
required: true
},
// 业务场景
businessScene: {
type: String,
default: ''
}
},
data: function data() {
return {
defaultProps: {
label: 'name',
children: 'children'
},
viewer: '',
categorys: [],
files: '',
fileItems: '',
currentContainerId: '',
currentContainer: '',
imgFileTypeList: ['png', 'jpg', 'jpeg', 'gif', 'tif', 'bmp', 'svg', 'webp']
};
},
created: function created() {
this.getFileDetail();
},
beforeDestroy: function beforeDestroy() {
if (this.viewer) {
this.viewer = null;
}
this.removeContainer();
},
methods: {
// 获取附件详细
getFileDetail: function getFileDetail() {
var _this = this;
if (this.viewer) {
this.viewer.destroy();
}
var params = {
businessModel: this.businessModel,
businessKey: this.businessPk,
businessScene: this.businessScene
};
return this.$http({
url: '/oss/api/fids/file-detail-by-business',
method: 'get',
params: params
}).then(function (res) {
//categorys 一级标题,
// files 二级标题
// fileItems 文件明细
_this.categorys = res.data.categorys;
_this.files = res.data.files;
_this.fileItems = res.data.fileItems;
_this.formatArray();
}).catch(function (res) {
_this.$message({
type: 'error',
message: '请求附件详情出错'
});
});
},
// 格式化当前模板需要使用到的数据格式
formatArray: function formatArray() {
var _this2 = this;
// 构建对应小类别的文件详细
this.files.forEach(function (item) {
// let showDisagreeUpload = false;
// let realShowDisagreeUpload = false;
var agree = 0;
var disAgree = 0;
item.detailChildren = [];
item.icon = 'document';
if (item.sampleId) {
item.exampleImgUrl = '/oss/api/fids/sample/' + item.sampleId;
} else {
item.exampleImgUrl = null;
}
_this2.fileItems.forEach(function (childItem) {
childItem.thumbFileUrl = '/oss/api/fids/download-thumb/' + childItem.id;
childItem.realFileUrl = '/oss/api/fids/download/' + childItem.id;
childItem.approveDone = true;
childItem.approveAgree = false;
// childItem.showDisagreeUpload = false;
if (childItem.auditStatus === 'new') {
childItem.showItemDelete = true;
childItem.stateMessage = "未审批";
childItem.stateDisAgree = false;
childItem.stateAgree = false;
childItem.approveDone = false;
} else if (childItem.auditStatus === 'qualified') {
childItem.showItemDelete = false;
childItem.stateMessage = "审批通过";
childItem.stateAgree = true; // 控制是否显示审批通过颜色
childItem.stateDisAgree = false; // 控制是否显示审批未通过颜色
childItem.approveAgree = true;
} else if (childItem.auditStatus === 'unqualified') {
childItem.showItemDelete = false;
childItem.stateMessage = "审批未通过";
childItem.stateDisAgree = true;
childItem.stateAgree = false;
// if(this.showDisagreeUpload){
// childItem.showDisagreeUpload = true;
// }
} else {
childItem.showItemDelete = true;
childItem.stateMessage = "未审批";
childItem.stateDisAgree = false;
childItem.stateAgree = false;
childItem.approveDone = false;
}
if (childItem.ruFileId === item.id) {
item.detailChildren.push(childItem);
childItem.filesTypeName = item.name;
if (childItem.auditStatus === 'unqualified') {
disAgree++;
} else {
agree++;
}
// realShowDisagreeUpload = childItem.showDisagreeUpload || showDisagreeUpload;
}
});
item.agree = agree;
item.disAgree = disAgree;
item.name = item.name + ('(' + item.detailChildren.length + ')');
if (item.detailChildren <= 0) {
delete item.detailChildren;
}
// if(agree < item.children.length){
// realShowDisagreeUpload = true;
// } else {
// realShowDisagreeUpload = false;
// }
// item.showDisagreeUpload = realShowDisagreeUpload;
});
// 判断当前已上传的图片是否已超出显示
this.files.forEach(function (item) {
var fileItemsLenegth = item.agree;
if (item.quantity.indexOf('+') > -1) {
item.fileCountMessage = '需要上传最少' + parseInt(item.quantity, 0) + '份资料';
item.approveAgreeNumber = parseInt(item.quantity, 0);
item.showItemUpload = true;
if (fileItemsLenegth >= parseInt(item.quantity.substring(0, 1), 0)) {
item.isAready = true;
} else {
item.isAready = false;
}
if (parseInt(item.quantity.substring(0, 1), 0) !== 0) {
item.required = true;
} else {
item.required = false;
}
} else if (item.quantity.indexOf('-') > -1) {
var maxLength = parseInt(item.quantity.substring(0, 1), 0);
item.approveAgreeNumber = 0;
item.fileCountMessage = '需要上传最多' + parseInt(item.quantity, 0) + '份资料';
if (fileItemsLenegth < maxLength) {
item.showItemUpload = true;
} else {
item.showItemUpload = false;
}
item.isAready = true;
item.required = false;
} else if (item.quantity.indexOf('~') > -1) {
var minLength = parseInt(item.quantity.substring(0, 1), 0);
var _maxLength = parseInt(item.quantity.substring(2), 0);
item.approveAgreeNumber = minLength;
item.fileCountMessage = "需要上传最少" + minLength + "份资料" + ",最多" + _maxLength + "份资料";
if (fileItemsLenegth < _maxLength) {
item.showItemUpload = true;
} else {
item.showItemUpload = false;
}
if (fileItemsLenegth >= minLength) {
item.isAready = true;
} else {
item.isAready = false;
}
item.required = true;
} else {
var length = parseInt(item.quantity, 0);
item.approveAgreeNumber = length;
item.fileCountMessage = "需要上传" + length + "份资料";
if (fileItemsLenegth < length) {
item.showItemUpload = true;
item.isAready = false;
} else {
item.isAready = true;
item.showItemUpload = false;
}
item.required = true;
}
});
this.categorys.forEach(function (item) {
item.children = [];
item.icon = 'folder-opened';
_this2.files.forEach(function (childItem) {
if (item.id === childItem.ruCategoryId) {
item.children.push(childItem);
}
});
if (item.children.length <= 0) {
delete item.children;
}
});
},
removeContainer: function removeContainer(id) {
var dom = document.getElementById('aos-files-tree-' + this.currentContainerId);
if (!id) {
if (dom) {
document.body.removeChild(dom);
}
} else if (this.currentContainerId && this.currentContainerId !== id) {
if (dom) {
document.body.removeChild(dom);
}
}
},
createImgList: function createImgList(list, id) {
var _this3 = this;
var container = document.createElement('div');
container.id = 'aos-files-tree-' + id;
container.style.position = 'absolute';
container.style.top = '-10000px';
container.style.left = '-10000px';
if (list && list.length > 0) {
list.forEach(function (item) {
if (_this3.imgFileTypeList.includes(item.fileExt)) {
var imgItem = document.createElement('img');
imgItem.src = item.thumbFileUrl;
imgItem.alt = item.fileName;
imgItem.title = item.fileName;
container.appendChild(imgItem);
}
});
}
document.body.append(container);
return container;
},
handleNodeClick: function handleNodeClick(data) {
if (!data.detailChildren || data.detailChildren && data.detailChildren.length <= 0) return;
this.removeContainer(data.id);
var container = this.currentContainer;
if (this.viewer) {
this.viewer.destroy();
this.viewer = null;
}
var children = data.detailChildren;
if (!this.currentContainerId || this.currentContainerId && this.currentContainerId !== data.id) {
container = this.createImgList(children, data.id);
}
this.currentContainerId = data.id;
this.currentContainer = container;
this.viewer = new external_viewerjs_optimize_default.a(document.getElementById('aos-files-tree-' + data.id), {
className: 'aos-img-viewer-container ' + ('aos-files-tree-' + data.id),
zIndex: popup_["PopupManager"].nextZIndex() + 101
});
container.children[0].click();
}
}
});
// CONCATENATED MODULE: ./packages/aos-files-tree/src/main.vue?vue&type=script&lang=js&
/* harmony default export */ var src_mainvue_type_script_lang_js_ = (mainvue_type_script_lang_js_);
// EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js
var componentNormalizer = __webpack_require__(0);
// CONCATENATED MODULE: ./packages/aos-files-tree/src/main.vue
/* normalize component */
var component = Object(componentNormalizer["a" /* default */])(
src_mainvue_type_script_lang_js_,
render,
staticRenderFns,
false,
null,
null,
null
)
/* hot reload */
if (false) { var api; }
component.options.__file = "packages/aos-files-tree/src/main.vue"
/* harmony default export */ var main = (component.exports);
// CONCATENATED MODULE: ./packages/aos-files-tree/index.js
main.install = function (Vue) {
Vue.component(main.name, main);
};
/* harmony default export */ var aos_files_tree = __webpack_exports__["default"] = (main);
/***/ }),
/***/ 29:
/***/ (function(module, exports) {
module.exports = require("viewerjs-optimize");
/***/ })
/******/ });