UNPKG

@onehat/ui

Version:
223 lines (214 loc) 12.5 kB
/** * 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));