Software: Apache/2.4.41 (Ubuntu). PHP/8.0.30 uname -a: Linux apirnd 5.4.0-204-generic #224-Ubuntu SMP Thu Dec 5 13:38:28 UTC 2024 x86_64 uid=33(www-data) gid=33(www-data) groups=33(www-data) Safe-mode: OFF (not secure) /var/www/html/wincloud_gateway/node_modules/strapi-plugin-upload/admin/src/containers/SettingsPage/ drwxr-xr-x | |
| Viewing file: Select action/file-type: import React, { useEffect, useReducer, useRef } from 'react';
import { Header, Inputs } from '@buffetjs/custom';
import { Helmet } from 'react-helmet';
import { Text } from '@buffetjs/core';
import { isEqual } from 'lodash';
import { LoadingIndicatorPage, useGlobalContext, request } from 'strapi-helper-plugin';
import { getRequestUrl, getTrad } from '../../utils';
import SectionTitleWrapper from './SectionTitleWrapper';
import Wrapper from './Wrapper';
import init from './init';
import reducer, { initialState } from './reducer';
const SettingsPage = () => {
const { formatMessage } = useGlobalContext();
const [reducerState, dispatch] = useReducer(reducer, initialState, init);
const { initialData, isLoading, modifiedData } = reducerState.toJS();
const isMounted = useRef(true);
const getDataRef = useRef();
const abortController = new AbortController();
getDataRef.current = async () => {
try {
const { signal } = abortController;
const { data } = await request(getRequestUrl('settings', { method: 'GET', signal }));
if (isMounted.current) {
dispatch({
type: 'GET_DATA_SUCCEEDED',
data,
});
}
} catch (err) {
console.error(err);
}
};
useEffect(() => {
getDataRef.current();
return () => {
abortController.abort();
isMounted.current = false;
};
// eslint-disable-next-line react-hooks/exhaustive-deps
}, []);
const handleSubmit = async () => {
try {
await request(getRequestUrl('settings'), {
method: 'PUT',
body: modifiedData,
});
if (isMounted.current) {
dispatch({
type: 'SUBMIT_SUCCEEDED',
});
}
strapi.notification.toggle({
type: 'success',
message: { id: 'notification.form.success.fields' },
});
} catch (err) {
console.error(err);
}
};
const headerProps = {
title: {
label: formatMessage({ id: getTrad('settings.header.label') }),
},
content: formatMessage({
id: getTrad('settings.sub-header.label'),
}),
actions: [
{
color: 'cancel',
disabled: isEqual(initialData, modifiedData),
// TradId from the strapi-admin package
label: formatMessage({ id: 'app.components.Button.cancel' }),
onClick: () => {
dispatch({
type: 'CANCEL_CHANGES',
});
},
type: 'button',
},
{
disabled: false,
color: 'success',
// TradId from the strapi-admin package
label: formatMessage({ id: 'app.components.Button.save' }),
onClick: handleSubmit,
type: 'button',
},
],
};
const handleChange = ({ target: { name, value } }) => {
dispatch({
type: 'ON_CHANGE',
keys: name,
value,
});
};
if (isLoading) {
return <LoadingIndicatorPage />;
}
return (
<>
<Helmet title={formatMessage({ id: getTrad('page.title') })} />
<Header {...headerProps} />
<Wrapper>
<div className="container-fluid">
<div className="row">
<SectionTitleWrapper className="col-12">
<Text fontSize="xs" fontWeight="semiBold" color="#787E8F">
{formatMessage({ id: getTrad('settings.section.image.label') })}
</Text>
</SectionTitleWrapper>
<div className="col-6">
<Inputs
label={formatMessage({
id: getTrad('settings.form.responsiveDimensions.label'),
})}
description={formatMessage({
id: getTrad('settings.form.responsiveDimensions.description'),
})}
name="responsiveDimensions"
onChange={handleChange}
type="bool"
value={modifiedData.responsiveDimensions}
/>
</div>
<div className="col-6">
<Inputs
label={formatMessage({
id: getTrad('settings.form.sizeOptimization.label'),
})}
name="sizeOptimization"
onChange={handleChange}
type="bool"
value={modifiedData.sizeOptimization}
/>
</div>
</div>
<div className="row">
<div className="col-6">
<Inputs
label={formatMessage({
id: getTrad('settings.form.autoOrientation.label'),
})}
description={formatMessage({
id: getTrad('settings.form.autoOrientation.description'),
})}
name="autoOrientation"
onChange={handleChange}
type="bool"
value={modifiedData.autoOrientation}
/>
</div>
</div>
{/*
<Divider />
<div className="row">
<SectionTitleWrapper className="col-12">
<Text fontSize="xs" fontWeight="semiBold" color="#787E8F">
{formatMessage({ id: getTrad('settings.section.video.label') })}
</Text>
</SectionTitleWrapper>
<div className="col-6">
<Inputs
label={formatMessage({
id: getTrad('settings.form.videoPreview.label'),
})}
description={formatMessage({
id: getTrad('settings.form.videoPreview.description'),
})}
name="videoPreview"
onChange={handleChange}
type="bool"
value={modifiedData.videoPreview}
/>
</div>
</div> */}
</div>
</Wrapper>
</>
);
};
export default SettingsPage;
|
:: Command execute :: | |
--[ c99shell v. 2.5 [PHP 8 Update] [24.05.2025] | Generation time: 0.0224 ]-- |