@bos-model-alpha/data
Version:
数据管理
325 lines (324 loc) • 22.8 kB
JavaScript
var __makeTemplateObject = (this && this.__makeTemplateObject) || function (cooked, raw) {
if (Object.defineProperty) { Object.defineProperty(cooked, "raw", { value: raw }); } else { cooked.raw = raw; }
return cooked;
};
var __assign = (this && this.__assign) || function () {
__assign = Object.assign || function(t) {
for (var s, i = 1, n = arguments.length; i < n; i++) {
s = arguments[i];
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
t[p] = s[p];
}
return t;
};
return __assign.apply(this, arguments);
};
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
};
var __generator = (this && this.__generator) || function (thisArg, body) {
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
function verb(n) { return function (v) { return step([n, v]); }; }
function step(op) {
if (f) throw new TypeError("Generator is already executing.");
while (_) try {
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
if (y = 0, t) op = [op[0] & 2, t.value];
switch (op[0]) {
case 0: case 1: t = op; break;
case 4: _.label++; return { value: op[1], done: false };
case 5: _.label++; y = op[1]; op = [0]; continue;
case 7: op = _.ops.pop(); _.trys.pop(); continue;
default:
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
if (t[2]) _.ops.pop();
_.trys.pop(); continue;
}
op = body.call(thisArg, _);
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
}
};
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
import { useEffect, useState } from 'react';
import { Modal, Form, Select, Input, Button, Upload, Checkbox, Divider, message, Progress } from 'antd';
import styled from '@emotion/styled';
import cookies from 'react-cookies';
import { Icon } from '@bos-alpha/common/lib/components';
import * as services from '@bos-alpha/common/lib/services';
import { downFile, setItem, getItem } from '@bos-alpha/common/lib/utils';
import { prefixCls } from '@bos-alpha/common';
import importIcon from '../img-base64/database-import';
// 支持的数据库类型
var databaseTypes = [
{
label: 'MySQL(TCP/IP)',
value: 'MySQL'
},
{
label: 'Oracle',
value: 'Oracle'
},
{
label: 'MongoDB',
value: 'MongoDB'
},
{
label: 'PgSQL',
value: 'PgSQL'
},
{
label: 'Microsoft SQL Server(TPC/IP)',
value: 'SQLServer'
}
];
// 数据库默认端口
var portMap = {
MySQL: '3306',
Oracle: '1521',
MongoDB: '27017',
PgSQL: '5432',
SQLServer: '1433'
};
var progressStatus = {
'0': 'active',
'1': 'active',
'2': 'success',
'-1': 'exception'
};
var timer = null;
export var DatabaseImport = function () {
var _a = useState(false), visible = _a[0], setVisible = _a[1];
var _b = useState(), file = _b[0], setFile = _b[1];
var _c = useState(1), step = _c[0], setStep = _c[1];
var form = Form.useForm()[0];
var _d = useState(false), testOk = _d[0], setTestOk = _d[1];
var _e = useState(), connect = _e[0], setConnect = _e[1];
// 导入选项
var _f = useState(true), addChecked = _f[0], setAddChecked = _f[1];
var _g = useState(true), updateChecked = _g[0], setUpdateChecked = _g[1];
// 导入任务id
var _h = useState(''), taskId = _h[0], setTaskId = _h[1];
// 任务进度
var _j = useState({
progress: 0,
remark: '',
status: '0',
statusText: '',
taskId: ''
}), progressInfo = _j[0], setProgressInfo = _j[1];
useEffect(function () {
if (!visible)
return;
var databaseLocalKey = getItem('database_local_key');
if (databaseLocalKey) {
form.setFieldsValue(__assign({}, databaseLocalKey));
}
else {
form.setFieldsValue({
type: databaseTypes[0].value
});
}
}, [visible]); // eslint-disable-line react-hooks/exhaustive-deps
useEffect(function () {
if (taskId === '') {
if (timer)
window.clearInterval(timer);
return;
}
timer = window.setInterval(function () {
loopQueryProgress();
}, 1000);
}, [taskId]); // eslint-disable-line react-hooks/exhaustive-deps
var loopQueryProgress = function () {
services
.getImportTaskStatus(taskId, {
params: {
t: new Date().getTime()
}
})
.then(function (res) {
setProgressInfo(__assign(__assign({}, res), { statusText: progressStatus[res.status], progress: parseInt(res.progress) }));
if (res.status === '-1') {
Modal.error({
title: '从第三方数据库导入数据失败',
okText: '确定',
cancelText: '取消',
content: (_jsxs("div", { children: [_jsx("p", { children: "\u4ECE\u7B2C\u4E09\u65B9\u6570\u636E\u5E93\u5BFC\u5165\u6570\u636E\u5931\u8D25, \u8BF7\u68C0\u67E5\u6570\u636E\u5E93\u8FDE\u63A5\u548C\u5BFC\u5165\u914D\u7F6E\u3002\u9519\u8BEF\u4FE1\u606F\u5982\u4E0B" }), (res.errorMsg || []).map(function (item, index) { return (_jsxs("p", { children: [index, ": ", item] })); })] })),
onOk: function () {
setStep(1);
setVisible(false);
},
onCancel: function () {
setStep(1);
setVisible(false);
}
});
setTaskId('');
}
// 已完成
else if (res.status === '2') {
setTaskId('');
setStep(1);
setVisible(false);
message.success('导入完成!');
}
})
.catch(function (err) {
setTaskId('');
setStep(1);
setVisible(false);
});
};
var getTemp = function () { return __awaiter(void 0, void 0, void 0, function () {
var res;
return __generator(this, function (_a) {
switch (_a.label) {
case 0: return [4 /*yield*/, services.getTemplate({
params: {
name: '第三方数据库数据导入配置文件.xlsx',
access_token: cookies.load('access_token')
}
})];
case 1:
res = _a.sent();
downFile(res.data, '第三方数据库数据导入配置文件.xlsx');
return [2 /*return*/];
}
});
}); };
var onImportChange = function (file) {
setFile(file);
return false;
};
// 测试连接
var onTestConfirm = function () { return __awaiter(void 0, void 0, void 0, function () {
var vals;
return __generator(this, function (_a) {
switch (_a.label) {
case 0: return [4 /*yield*/, form.validateFields()];
case 1:
vals = _a.sent();
return [4 /*yield*/, services.connectDatabase({
data: vals
})];
case 2:
_a.sent();
message.success('测试连接成功,点击“下一步”按钮导入第三方数据库数据');
setConnect(vals);
setItem('database_local_key', __assign(__assign({}, vals), { password: undefined }));
setTestOk(true);
return [2 /*return*/];
}
});
}); };
// 确定
var onConfirm = function () { return __awaiter(void 0, void 0, void 0, function () {
return __generator(this, function (_a) {
if (!file || (file && !file.name))
return [2 /*return*/, message.error('请选择导入文件')];
if (file.name.indexOf('xls') === -1)
return [2 /*return*/, message.error('选择文件格式不正确')];
Modal.confirm({
title: '导入第三方数据库',
content: "\u672C\u64CD\u4F5C\u5C06\u4F1A\u66F4\u6539\u73B0\u6709BOS\u5BF9\u8C61\u548C\u5173\u7CFB\u6570\u636E\uFF0C\u786E\u5B9A\u8981\u6267\u884C\u6B64\u64CD\u4F5C\u5417\uFF1F",
okText: '确定',
cancelText: '取消',
okButtonProps: {
shape: 'round',
style: {
width: '106px'
}
},
cancelButtonProps: {
shape: 'round',
style: {
width: '106px'
}
},
onOk: function () {
return new Promise(function (resolve, reject) { return __awaiter(void 0, void 0, void 0, function () {
return __generator(this, function (_a) {
services
.importDatabaseFile({
data: {
file: file,
connect: JSON.stringify(connect),
insert: addChecked,
update: updateChecked
}
})
.then(function (res) {
message.success(res.remark);
setProgressInfo(__assign(__assign({}, res), { statusText: progressStatus[res.status], progress: parseInt(res.progress) }));
setTaskId(res.taskId);
resolve(res);
})
.catch(function (err) {
resolve(err);
});
return [2 /*return*/];
});
}); });
}
});
return [2 /*return*/];
});
}); };
return (_jsxs(_Fragment, { children: [_jsxs(Btn, __assign({ onClick: function () { return setVisible(true); } }, { children: [_jsx("img", { className: "icon", src: importIcon, alt: "" }), "\u4ECE\u7B2C\u4E09\u65B9\u6570\u636E\u5E93\u5BFC\u5165"] })), _jsx(Modal, __assign({ visible: visible, width: 814, bodyStyle: {
height: 503,
position: 'relative'
}, title: "\u4ECE\u7B2C\u4E09\u65B9\u6570\u636E\u5E93\u5BFC\u5165\u6570\u636E", onCancel: function () {
setStep(1);
setVisible(false);
}, maskClosable: false, forceRender: true, footer: null }, { children: step === 1 ? (_jsxs(ImportModal, { children: [_jsxs(StepBar, { children: [_jsx("span", { className: "left-border" }), _jsx("span", { children: "\u7B2C 1 \u6B65\uFF1A\u8FDE\u63A5\u7B2C\u4E09\u65B9\u6570\u636E\u5E93" })] }), _jsxs(Form, __assign({ form: form, className: "config-form", labelCol: { span: 6 }, wrapperCol: { span: 16 }, labelAlign: "left" }, { children: [_jsx(Form.Item, __assign({ label: "\u6570\u636E\u8FDE\u63A5\u7C7B\u578B", name: "type" }, { children: _jsx(Select, { className: "form-ipt", options: databaseTypes, placeholder: "\u8BF7\u9009\u62E9\u6570\u636E\u8FDE\u63A5\u7C7B\u578B", onChange: function (val) {
form.setFieldsValue({
port: portMap[val]
});
} }) })), _jsx(Form.Item, __assign({ label: "\u4E3B\u673A\u540D/IP", name: "ip", rules: [
{
required: true,
message: '请输入主机名/IP'
}
] }, { children: _jsx(Input, { className: "form-ipt", placeholder: "\u8BF7\u8F93\u5165\u4E3B\u673A\u540D/IP" }) })), _jsx(Form.Item, __assign({ label: "\u7AEF\u53E3", name: "port", rules: [
{
required: true,
message: '请输入端口'
}
] }, { children: _jsx(Input, { className: "form-ipt", placeholder: "\u8BF7\u8F93\u5165\u7AEF\u53E3" }) })), _jsx(Form.Item, __assign({ label: "\u7528\u6237\u540D", name: "username", rules: [
{
required: true,
message: '请输入用户名'
}
] }, { children: _jsx(Input, { className: "form-ipt", placeholder: "\u8BF7\u8F93\u5165\u7528\u6237\u540D" }) })), _jsx(Form.Item, __assign({ label: "\u5BC6\u7801", name: "password", rules: [
{
required: true,
message: '请输入密码'
}
] }, { children: _jsx(Input.Password, { className: "form-ipt", placeholder: "\u8BF7\u8F93\u5165\u5BC6\u7801" }) })), _jsx(Form.Item, __assign({ label: "\u6570\u636E\u5E93", name: "database", rules: [
{
required: true,
message: '请输入数据库'
}
] }, { children: _jsx(Input, { className: "form-ipt", placeholder: "\u8BF7\u8F93\u5165\u6570\u636E\u5E93" }) }))] })), _jsxs(FooterBtns, { children: [_jsx(Button, __assign({ type: "default", shape: "round", className: "btn", onClick: function () { return setVisible(false); } }, { children: "\u53D6\u6D88" })), _jsx(Button, __assign({ type: "primary", shape: "round", className: "btn", onClick: onTestConfirm }, { children: "\u6D4B\u8BD5\u8FDE\u63A5" })), _jsx(Button, __assign({ type: "default", shape: "round", disabled: !testOk, className: "btn", onClick: function () { return setStep(2); } }, { children: "\u4E0B\u4E00\u6B65" }))] })] })) : step === 2 ? (_jsxs(ImportModal, { children: [_jsxs(StepBar, { children: [_jsx("span", { className: "left-border" }), _jsx("span", { children: "\u7B2C 2 \u6B65\uFF1A\u5BFC\u5165\u7B2C\u4E09\u65B9\u6570\u636E\u5E93\u6570\u636E" })] }), _jsxs(TempSelect, { children: [_jsx("div", { children: "\u9009\u62E9\u6570\u636E\u5BFC\u5165\u914D\u7F6E\u6587\u4EF6\uFF1A" }), _jsx(Input, { className: "file-ipt", type: "text", disabled: true, value: file === null || file === void 0 ? void 0 : file.name, placeholder: "\u8BF7\u9009\u62E9\u6570\u636E\u5BFC\u5165\u914D\u7F6E\u6587\u4EF6" }), _jsx(Upload, __assign({ accept: ".xls,.xlsx", showUploadList: false, beforeUpload: onImportChange }, { children: _jsx(Button, __assign({ type: "primary", shape: "round" }, { children: "\u9009\u62E9" })) })), _jsx(Button, __assign({ className: "download-btn", type: "link", onClick: getTemp }, { children: "\u4E0B\u8F7D\u6A21\u677F" }))] }), _jsx(Divider, __assign({ orientation: "left" }, { children: "\u5BFC\u5165\u9009\u9879" })), _jsx("div", __assign({ className: "import-check" }, { children: _jsx(Checkbox, __assign({ checked: addChecked, onChange: function (e) {
return setAddChecked(e.target.checked);
} }, { children: "\u65B0\u589EBOS\u5B9E\u4F8B\u6570\u636E\uFF08\u53C2\u8003\u6765\u6E90\u6570\u636E\uFF0C\u65B0\u589EBOS\u5BF9\u8C61\u548C\u5173\u7CFB\u5B9E\u4F8B\u6570\u636E\uFF09" })) })), _jsx("div", __assign({ className: "import-check" }, { children: _jsx(Checkbox, __assign({ checked: updateChecked, onChange: function (e) {
return setUpdateChecked(e.target.checked);
} }, { children: "\u66F4\u65B0BOS\u5B9E\u4F8B\u6570\u636E\uFF08\u53C2\u8003\u6765\u6E90\u6570\u636E\uFF0C\u66F4\u65B0BOS\u4E2D\u5DF2\u5B58\u5728\u7684\u5BF9\u8C61\u548C\u5173\u7CFB\u5B9E\u4F8B\u6570\u636E\uFF09" })) })), taskId ? (_jsxs("div", __assign({ className: "progress-bar" }, { children: [_jsxs("div", __assign({ className: "progress-tip" }, { children: [progressInfo.status === '1' && (_jsx(Icon, { className: "progress-icon", type: "iconicon_daibanrenwu" })), progressInfo.status === '2' && (_jsx(Icon, { className: "progress-icon", type: "iconicon_success" })), _jsxs("span", { children: [" ", progressInfo.remark] })] })), _jsx(Progress, { status: progressInfo.statusText, percent: progressInfo.progress })] }))) : null, _jsxs(FooterBtns, { children: [_jsx(Button, __assign({ type: "default", shape: "round", className: "btn", onClick: function () { return setStep(1); } }, { children: "\u53D6\u6D88\u5BFC\u5165" })), _jsx(Button, __assign({ type: "primary", shape: "round", className: "btn", disabled: !!taskId, onClick: onConfirm }, { children: "\u5F00\u59CB\u5BFC\u5165" }))] })] })) : null }))] }));
};
var Btn = styled.span(templateObject_1 || (templateObject_1 = __makeTemplateObject(["\n margin: 0 16px;\n display: flex;\n color: #444;\n cursor: pointer;\n & > .icon {\n width: 20px;\n height: 20px;\n }\n"], ["\n margin: 0 16px;\n display: flex;\n color: #444;\n cursor: pointer;\n & > .icon {\n width: 20px;\n height: 20px;\n }\n"])));
var ImportModal = styled.div(templateObject_2 || (templateObject_2 = __makeTemplateObject(["\n color: rgba(0, 0, 0, 0.85);\n .import-check {\n margin-bottom: 10px;\n }\n .", "-divider-inner-text {\n padding-left: 0;\n font-weight: 400;\n font-size: 14px;\n }\n .", "-divider-horizontal.", "-divider-with-text-left:before {\n display: none;\n }\n .config-form {\n padding: 0 120px;\n .form-ipt {\n width: 334px;\n }\n }\n .progress-bar {\n padding-top: 30px;\n .progress-icon {\n margin-right: 5px;\n }\n }\n"], ["\n color: rgba(0, 0, 0, 0.85);\n .import-check {\n margin-bottom: 10px;\n }\n .", "-divider-inner-text {\n padding-left: 0;\n font-weight: 400;\n font-size: 14px;\n }\n .", "-divider-horizontal.", "-divider-with-text-left:before {\n display: none;\n }\n .config-form {\n padding: 0 120px;\n .form-ipt {\n width: 334px;\n }\n }\n .progress-bar {\n padding-top: 30px;\n .progress-icon {\n margin-right: 5px;\n }\n }\n"])), prefixCls, prefixCls, prefixCls);
var StepBar = styled.div(templateObject_3 || (templateObject_3 = __makeTemplateObject(["\n color: #333;\n display: flex;\n height: 32px;\n line-height: 32px;\n margin-bottom: 15px;\n background: linear-gradient(\n 12deg,\n rgba(83, 246, 253, 0.16),\n rgba(0, 112, 255, 0.14)\n );\n & > .left-border {\n margin-right: 8px;\n display: inline-block;\n height: 100%;\n width: 4px;\n background: linear-gradient(\n 230deg,\n rgba(83, 246, 253, 0.4),\n rgba(0, 112, 255, 0.4)\n );\n }\n"], ["\n color: #333;\n display: flex;\n height: 32px;\n line-height: 32px;\n margin-bottom: 15px;\n background: linear-gradient(\n 12deg,\n rgba(83, 246, 253, 0.16),\n rgba(0, 112, 255, 0.14)\n );\n & > .left-border {\n margin-right: 8px;\n display: inline-block;\n height: 100%;\n width: 4px;\n background: linear-gradient(\n 230deg,\n rgba(83, 246, 253, 0.4),\n rgba(0, 112, 255, 0.4)\n );\n }\n"])));
var TempSelect = styled.div(templateObject_4 || (templateObject_4 = __makeTemplateObject(["\n display: flex;\n align-items: center;\n & > .file-ipt {\n width: 400px;\n margin-right: 15px;\n }\n"], ["\n display: flex;\n align-items: center;\n & > .file-ipt {\n width: 400px;\n margin-right: 15px;\n }\n"])));
var FooterBtns = styled.div(templateObject_5 || (templateObject_5 = __makeTemplateObject(["\n position: absolute;\n bottom: 24px;\n width: 100%;\n display: flex;\n justify-content: center;\n padding-top: 40px;\n & > .btn {\n width: 106px;\n margin: 0 5px;\n }\n"], ["\n position: absolute;\n bottom: 24px;\n width: 100%;\n display: flex;\n justify-content: center;\n padding-top: 40px;\n & > .btn {\n width: 106px;\n margin: 0 5px;\n }\n"])));
var templateObject_1, templateObject_2, templateObject_3, templateObject_4, templateObject_5;