@onehat/ui
Version:
Base UI for OneHat apps
223 lines (214 loc) • 12.5 kB
JavaScript
/**
* COPYRIGHT NOTICE
* This file is categorized as "Custom Source Code"
* and is subject to the terms and conditions defined in the
* "LICENSE.txt" file, which is part of this source code package.
*/
import { useState, } from 'react';
import clsx from 'clsx';
import Excel from '../Icons/Excel';
import Panel from '../Panel/Panel.js';
import Form from '../Form/Form.js';
import useAdjustedWindowSize from '../../Hooks/useAdjustedWindowSize.js';
import downloadWithFetch from '../../Functions/downloadWithFetch.js';
import withAlert from '../Hoc/withAlert.js';
import withComponent from '../Hoc/withComponent.js';
import Download from '../Icons/Download';
import Upload from '../Icons/Upload';
import Cookies from 'js-cookie';
import _ from 'lodash';
function UploadsDownloadsWindow(props) {
const {
Repository,
columnsConfig = [],
uploadHeaders,
downloadHeaders,
uploadParams = {},
downloadParams = {},
isDownloadOnly = false,
onUpload,
// withComponent
self,
// withAlert
alert,
showInfo,
} = props,
[importFile, setImportFile] = useState(null),
[width, height] = useAdjustedWindowSize(400, 450),
onDownload = (isTemplate = false) => {
const win = window.open('');
win.document.write('<html><head><title>Downloading</title></head><body><img style="position:absolute;top:50%;left:50%;transform:translate(-50%, -50%);" src="' +
'' +
'"></body></html>');
const
baseURL = Repository.api.baseURL,
columns = columnsConfig.map((column) => {
return column.fieldName;
}),
order = Repository.getSortField() + ' ' + Repository.getSortDirection(),
model = Repository.name,
url = baseURL + 'Reports/getReport',
download_token = 'dl' + (new Date()).getTime(),
options = {
// method: 'GET',
method: 'POST',
body: JSON.stringify({
download_token,
report_id: 1,
columns,
order,
model,
isTemplate,
...Repository._params,
...downloadParams,
}),
headers: _.merge({ 'Content-Type': 'application/json' }, Repository.headers, downloadHeaders),
};
downloadWithFetch(url, options);
const interval = setInterval(function() {
const cookie = Cookies.get(download_token);
if (win.window && cookie) {
clearInterval(interval);
Cookies.remove(download_token);
win.window.close();
}
}, 1000);
},
onDownloadTemplate = () => {
onDownload(true);
},
onUploadLocal = async () => {
const
url = Repository.api.baseURL + Repository.name + '/uploadBatch',
result = await Repository._send('POST', url, { importFile, ...uploadParams, }, uploadHeaders)
.catch(error => {
if (Repository.debugMode) {
console.log(url + ' error', error);
console.log('response:', error.response);
}
});
if (Repository.debugMode) {
console.log('Result ' + url, result);
}
const
parsed = JSON.parse(result.data),
{
data,
success,
message,
} = parsed;
if (!success) {
const msgElements = ['Could not upload.'];
if (message === 'Errors') {
// assemble the errors from the upload
_.each(data, (obj) => {
// {
// "2": "ID does not exist."
// }
const line = Object.entries(obj)
.map(([key, value]) => `Line ${key}: ${value}`)
.join("\n");
msgElements.push(line);
});
}
alert(msgElements.join("\n"));
} else {
setImportFile(null);
self.formSetValue('file', null);
showInfo("Upload successful.\n");
if (onUpload) {
onUpload();
}
}
};
const items = [
{
type: 'DisplayField',
text: 'Download an Excel file of the current grid contents.',
},
{
type: 'Button',
text: 'Download',
isEditable: false,
icon: Excel,
_icon: {
size: 'md',
},
onPress: () => onDownload(),
className: 'mb-5',
},
];
if (!isDownloadOnly) {
items.push({
type: 'DisplayField',
text: 'Upload an Excel file to the current grid.',
});
items.push({
type: 'File',
name: 'file',
onChangeValue: setImportFile,
accept: '.xlsx',
});
items.push({
type: 'Row',
className: 'mt-2',
items: [
{
type: 'Button',
text: 'Upload',
isEditable: false,
icon: Upload,
_icon: {
size: 'md',
},
isDisabled: !importFile,
onPress: onUploadLocal,
},
{
type: 'Button',
text: 'Get Template',
icon: Download,
isEditable: false,
onPress: onDownloadTemplate,
},
],
});
}
return <Panel
{...props}
parent={self}
reference="UploadsDownloadsWindow"
isCollapsible={false}
title="Uploads & Downloads"
className={clsx(
'flex-none',
'bg-white',
'shadow-lg',
)}
style={{
height,
width,
}}
>
<Form
{...props}
parent={self}
reference="form"
hideResetButton={true}
items={[
{
"type": "Column",
"flex": 1,
"defaults": {},
"items": items,
},
]}
// record={selection}
// onCancel={onCancel}
// onSave={onSave}
// onClose={onClose}
// onDelete={onDelete}
/>
</Panel>;
}
export default withComponent(withAlert(UploadsDownloadsWindow));