diff --git a/src/components/pages/Manage.tsx b/src/components/pages/Manage.tsx index 280c175a3..c0b771753 100644 --- a/src/components/pages/Manage.tsx +++ b/src/components/pages/Manage.tsx @@ -1,5 +1,6 @@ import React, { useState } from 'react'; import { TextField, Button, Box, Typography, Select, MenuItem } from '@material-ui/core'; +import Download from '@material-ui/icons/Download'; import { useFormik } from 'formik'; import * as yup from 'yup'; @@ -83,6 +84,30 @@ export default function Manage() { const [severity, setSeverity] = useState('success'); const [message, setMessage] = useState('Saved'); + const genShareX = withEmbed => { + let config = { + Version: '13.2.1', + Name: 'Zipline', + DestinationType: 'ImageUploader, TextUploader', + RequestMethod: 'POST', + RequestURL: `${window.location.protocol + '//' + window.location.hostname + (window.location.port ? ':' + window.location.port : '')}/api/upload`, + Headers: { + Authorization: user?.token, + ...(withEmbed && {Embed: 'true'}) + }, + URL: '$json:url$', + Body: 'MultipartFormData', + FileFormName: 'file' + }; + var pseudoElement = document.createElement('a'); + pseudoElement.setAttribute('href', 'data:text/plain;charset=utf-8,' + encodeURIComponent(JSON.stringify(config, null, '\t'))); + pseudoElement.setAttribute('download', `zipline${withEmbed ? '_embed' : ''}.sxcu`); + pseudoElement.style.display = 'none'; + document.body.appendChild(pseudoElement); + pseudoElement.click(); + pseudoElement.parentNode.removeChild(pseudoElement); + }; + const formik = useFormik({ initialValues: { username: user.username, @@ -217,6 +242,9 @@ export default function Manage() { >Save Theme + ShareX Config + + ); -} \ No newline at end of file +}