Improve termsOfUse UI and error handling

This commit is contained in:
Yang Luo 2023-09-07 10:32:49 +08:00
parent ca6b27f922
commit 3459ef1479
3 changed files with 16 additions and 8 deletions

View File

@ -542,7 +542,7 @@ class ApplicationEditPage extends React.Component {
{Setting.getLabel(i18next.t("signup:Terms of Use"), i18next.t("signup:Terms of Use - Tooltip"))} :
</Col>
<Col span={22} >
<Input value={this.state.application.termsOfUse} style={{marginBottom: "10px"}} onChange={e => {
<Input prefix={<LinkOutlined />} value={this.state.application.termsOfUse} style={{marginBottom: "10px"}} onChange={e => {
this.updateApplicationField("termsOfUse", e.target.value);
}} />
<Upload maxCount={1} accept=".html" showUploadList={false}

View File

@ -50,11 +50,15 @@ window.fetch = async(url, option = {}) => {
requestFilters.forEach(filter => filter(url, option));
return new Promise((resolve, reject) => {
originalFetch(url, option).then(res => {
if (!url.startsWith("/api/get-organizations")) {
responseFilters.forEach(filter => filter(res.clone()));
}
resolve(res);
});
originalFetch(url, option)
.then(res => {
if (!url.startsWith("/api/get-organizations")) {
responseFilters.forEach(filter => filter(res.clone()));
}
resolve(res);
})
.catch(error => {
reject(error);
});
});
};

View File

@ -49,7 +49,11 @@ export const AgreementModal = (props) => {
function getTermsOfUseContent(url) {
return fetch(url, {
method: "GET",
}).then(r => r.text());
})
.then(r => r.text())
.catch(error => {
Setting.showMessage("error", `${i18next.t("general:Failed to get TermsOfUse URL")}: ${url}, ${error}`);
});
}
export function isAgreementRequired(application) {