feat: download redemption codes as file (#12)
This commit is contained in:
parent
9e2f2383b9
commit
f62a671fbe
@ -143,4 +143,13 @@ export function timestamp2string(timestamp) {
|
|||||||
':' +
|
':' +
|
||||||
second
|
second
|
||||||
);
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
export function downloadTextAsFile(text, filename) {
|
||||||
|
let blob = new Blob([text], { type: 'text/plain;charset=utf-8' });
|
||||||
|
let url = URL.createObjectURL(blob);
|
||||||
|
let a = document.createElement('a');
|
||||||
|
a.href = url;
|
||||||
|
a.download = filename;
|
||||||
|
a.click();
|
||||||
}
|
}
|
@ -1,7 +1,7 @@
|
|||||||
import React, { useEffect, useState } from 'react';
|
import React, { useEffect, useState } from 'react';
|
||||||
import { Button, Form, Header, Segment } from 'semantic-ui-react';
|
import { Button, Form, Header, Segment } from 'semantic-ui-react';
|
||||||
import { useParams } from 'react-router-dom';
|
import { useParams } from 'react-router-dom';
|
||||||
import { API, isAdmin, showError, showSuccess, quotatamp2string } from '../../helpers';
|
import { API, downloadTextAsFile, showError, showSuccess } from '../../helpers';
|
||||||
|
|
||||||
const EditRedemption = () => {
|
const EditRedemption = () => {
|
||||||
const params = useParams();
|
const params = useParams();
|
||||||
@ -11,7 +11,7 @@ const EditRedemption = () => {
|
|||||||
const originInputs = {
|
const originInputs = {
|
||||||
name: '',
|
name: '',
|
||||||
quota: 100,
|
quota: 100,
|
||||||
count: 1,
|
count: 1
|
||||||
};
|
};
|
||||||
const [inputs, setInputs] = useState(originInputs);
|
const [inputs, setInputs] = useState(originInputs);
|
||||||
const { name, quota, count } = inputs;
|
const { name, quota, count } = inputs;
|
||||||
@ -46,10 +46,10 @@ const EditRedemption = () => {
|
|||||||
res = await API.put(`/api/redemption/`, { ...localInputs, id: parseInt(redemptionId) });
|
res = await API.put(`/api/redemption/`, { ...localInputs, id: parseInt(redemptionId) });
|
||||||
} else {
|
} else {
|
||||||
res = await API.post(`/api/redemption/`, {
|
res = await API.post(`/api/redemption/`, {
|
||||||
...localInputs,
|
...localInputs
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
const { success, message } = res.data;
|
const { success, message, data } = res.data;
|
||||||
if (success) {
|
if (success) {
|
||||||
if (isEdit) {
|
if (isEdit) {
|
||||||
showSuccess('兑换码更新成功!');
|
showSuccess('兑换码更新成功!');
|
||||||
@ -60,6 +60,13 @@ const EditRedemption = () => {
|
|||||||
} else {
|
} else {
|
||||||
showError(message);
|
showError(message);
|
||||||
}
|
}
|
||||||
|
if (!isEdit && data) {
|
||||||
|
let text = "";
|
||||||
|
for (let i = 0; i < data.length; i++) {
|
||||||
|
text += data[i] + "\n";
|
||||||
|
}
|
||||||
|
downloadTextAsFile(text, `${inputs.name}.txt`);
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
return (
|
return (
|
||||||
|
Loading…
Reference in New Issue
Block a user