fastlion-amis
Version:
一种MIS页面生成工具
201 lines (200 loc) • 12.8 kB
JavaScript
Object.defineProperty(exports, "__esModule", { value: true });
exports.LionCellImgRenderer = exports.LionCellImg = void 0;
var tslib_1 = require("tslib");
var react_1 = (0, tslib_1.__importDefault)(require("react"));
var factory_1 = require("../../../../factory");
var Popover_1 = (0, tslib_1.__importDefault)(require("antd/lib/Popover"));
var LabelPrint_1 = require("../../LabelPrint");
var CellPopover_1 = (0, tslib_1.__importDefault)(require("./CellPopover"));
var LodopFuncs_1 = require("../../../../utils/print/LodopFuncs");
var utils_1 = require("../../utils/utils");
var helper_1 = require("../../../../utils/helper");
var errImg = '';
var LionCellImg = /** @class */ (function (_super) {
(0, tslib_1.__extends)(LionCellImg, _super);
function LionCellImg(props) {
var _a, _b, _c;
var _this = _super.call(this, props) || this;
_this.baseURL = '';
_this.matchPdfImg = function (str) {
return /(.jpe?)g|(.png)|(.pdf)/i.test(str);
};
// 打印
_this.handleLabelPrint = function () {
var list = _this.files.filter(function (_, mediaIndex) { return _this.state.selectList.includes(mediaIndex); });
// if (!this.matchPdfImg(current?.title)) {
// return;
// }
_this.setState({
ctx: (0, tslib_1.__assign)((0, tslib_1.__assign)({}, _this.state.ctx), { items: list, rows: list, selectedItems: list, unSelectedItems: [] })
}, function () {
var LODOP = (0, LodopFuncs_1.getLodop)();
if (LODOP) {
_this.setState({
_print_visible: true
});
}
});
};
// 选中操作
_this.handleSelect = function (type) {
// let indexList = [...new Array(this.state.files.length).keys()]
var indexList = [];
_this.state.files.map(function (item, index) {
if (!item.err) {
indexList.push(index);
}
});
switch (type) {
case 'all':
_this.setState({
selectList: indexList
});
break;
case 'invert':
var invertList = indexList.filter(function (item) { return !_this.state.selectList.includes(item); });
_this.setState({
selectList: invertList
});
break;
case 'clear':
_this.setState({
selectList: []
});
break;
default: break;
}
};
_this.initFiles = _this.initFiles.bind(_this);
_this.handleImageError = _this.handleImageError.bind(_this);
_this.handleCheckMedia = _this.handleCheckMedia.bind(_this);
_this.handlePreviewMedia = _this.handlePreviewMedia.bind(_this);
_this.handleLabelPrint = _this.handleLabelPrint.bind(_this);
_this.handleSelect = _this.handleSelect.bind(_this);
_this.handleDownloadMedia = _this.handleDownloadMedia.bind(_this);
_this.baseURL = (_c = (_b = (_a = props.env) === null || _a === void 0 ? void 0 : _a.axiosInstance) === null || _b === void 0 ? void 0 : _b.defaults) === null || _c === void 0 ? void 0 : _c.baseURL;
process.env.NODE_ENV === 'development' && (_this.baseURL = 'https://saasdev.fastlion.cn/saas');
var files = _this.initFiles();
_this.state = {
files: files,
selectList: [],
visible: false,
_print_visible: false,
ctx: {
items: [],
rows: [],
selectedItems: [],
unSelectedItems: [],
ids: ''
}
};
return _this;
}
LionCellImg.prototype.initFiles = function () {
var _this = this;
var files = [];
var value = this.props.value;
if (value) {
var fileMd5 = value.value, fileList = value.info;
if (fileMd5 && Array.isArray(fileList) && fileList.length) {
this.files = fileList; // 存一个原数据,打印用
var fileMd5List_1 = fileMd5.split(',');
files = fileList.map(function (item, index) {
return {
value: fileMd5List_1[index],
src: _this.baseURL + (item.thumbnailAddr || (item === null || item === void 0 ? void 0 : item.addr)),
originalSrc: _this.baseURL + item.preview,
downloadSrc: _this.baseURL + (item === null || item === void 0 ? void 0 : item.addr),
title: item.name || '',
};
});
}
}
return files;
};
LionCellImg.prototype.componentDidUpdate = function (prevProps) {
if (prevProps.value !== this.props.value) {
this.setState({
files: this.initFiles()
}, function () {
// console.log(this.state.files)
});
}
};
// 下载
LionCellImg.prototype.handleDownloadMedia = function () {
var _a = this.state, files = _a.files, selectList = _a.selectList;
files.filter(function (_, mediaIndex) { return selectList.includes(mediaIndex); }).map(function (item) {
(0, utils_1.downloadFile)(item.downloadSrc, item.title);
});
};
LionCellImg.prototype.handleImageLoaded = function (el, index) {
};
// 错误处理
LionCellImg.prototype.handleImageError = function (el, index) {
var files = this.state.files.concat();
var file = files[index];
file.src = errImg;
file.err = true;
files.splice(index, 1, file);
this.setState({ files: files });
};
LionCellImg.prototype.handleCheckMedia = function (index) {
var list = this.state.selectList.concat();
var findIndex = list.findIndex(function (item) { return item === index; });
if (~findIndex) {
list = list.filter(function (item) { return item !== index; });
}
else {
list.push(index);
}
this.setState({ selectList: list });
};
LionCellImg.prototype.handlePreviewMedia = function (index) {
var onImageEnlarge = this.props.onImageEnlarge;
var files = this.state.files;
onImageEnlarge && onImageEnlarge({
src: files[index].src,
originalSrc: files[index].originalSrc,
index: index,
list: files
});
};
LionCellImg.prototype.render = function () {
var _this = this;
var _a = this.props, cx = _a.classnames, popOverContainer = _a.popOverContainer;
var _b = this.state, selectList = _b.selectList, files = _b.files;
return (react_1.default.createElement(react_1.default.Fragment, null,
react_1.default.createElement("div", { className: cx('Cell-img') }, files && files.length
? react_1.default.createElement(Popover_1.default, { content: react_1.default.createElement(CellPopover_1.default, { mediaList: files, selectList: selectList, printMedia: this.handleLabelPrint, downloadMedia: this.handleDownloadMedia, selectMedia: this.handleSelect, checkMedia: this.handleCheckMedia, previewMedia: this.handlePreviewMedia }), trigger: (0, helper_1.isMobile)() ? [] : 'hover',
// trigger="click"
placement: 'bottom', destroyTooltipOnHide: true, getPopupContainer: popOverContainer, overlayClassName: 'table-media-format-popover' },
react_1.default.createElement("div", { className: cx('Cell-img-wrapper') }, files.map(function (item, index) {
return react_1.default.createElement("img", { key: item.value || index, src: item.src, className: cx('Cell-img'),
// onLoad={(e) => this.handleImageLoaded(e, index)}
onError: function (e) { return _this.handleImageError(e, index); } });
})))
: "-"),
this.state._print_visible && react_1.default.createElement(LabelPrint_1.ModalPrint, (0, tslib_1.__assign)({ type: "lion-print" }, this.props, { isFilePrint: true, isSingleFilePrint: true, ctx: this.state.ctx, show: this.state._print_visible, onHide: function () { _this.setState({ _print_visible: false }); } }))));
};
LionCellImg.defaultProps = {
title: '附件图片'
};
return LionCellImg;
}(react_1.default.Component));
exports.LionCellImg = LionCellImg;
var LionCellImgRenderer = /** @class */ (function (_super) {
(0, tslib_1.__extends)(LionCellImgRenderer, _super);
function LionCellImgRenderer() {
return _super !== null && _super.apply(this, arguments) || this;
}
LionCellImgRenderer = (0, tslib_1.__decorate)([
(0, factory_1.Renderer)({
type: 'lion-cell-img'
})
], LionCellImgRenderer);
return LionCellImgRenderer;
}(LionCellImg));
exports.LionCellImgRenderer = LionCellImgRenderer;
//# sourceMappingURL=./renderers/Lion/Table/LionCellImg/LionCellImg.js.map
;