feat: wip default message to sales transactions.

This commit is contained in:
Ahmed Bouhuolia
2023-12-14 20:47:52 +02:00
parent 33e5d1a979
commit 217321380a
18 changed files with 325 additions and 38 deletions

View File

@@ -1,14 +1,14 @@
// @ts-nocheck
import { PreferencesCreditNotesBoot } from './PreferencesCreditNotesFormBoot';
import PreferencesInvoiceFormPage from './PreferencesCreditNotesFormPage';
import { PreferencesCreditNotesFormPage } from './PreferencesCreditNotesFormPage';
/**
* items preferences.
*/
export default function PreferencesCreditNotes() {
export function PreferencesCreditNotes() {
return (
<PreferencesCreditNotesBoot>
<PreferencesInvoiceFormPage />
<PreferencesCreditNotesFormPage />
</PreferencesCreditNotesBoot>
);
}

View File

@@ -6,4 +6,4 @@ const Schema = Yup.object().shape({
customerNotes: Yup.string().optional(),
});
export const PreferencesEstimatesFormSchema = Schema;
export const PreferencesCreditNotesFormSchema = Schema;

View File

@@ -27,7 +27,7 @@ export function PreferencesCreditNotesForm({ isSubmitting }) {
{/* ---------- Terms & Conditions ---------- */}
<FFormGroup
name={'termsConditions'}
label={<T id={'pref.estimates.termsConditions.field'} />}
label={<T id={'pref.creditNotes.termsConditions.field'} />}
labelInfo={<FieldRequiredHint />}
fastField={true}
>
@@ -42,7 +42,7 @@ export function PreferencesCreditNotesForm({ isSubmitting }) {
{/* ---------- Customer Notes ---------- */}
<FFormGroup
name={'customerNotes'}
label={<T id={'pref.estimates.customerNotes.field'} />}
label={<T id={'pref.creditNotes.customerNotes.field'} />}
fastField={true}
>
<FTextArea

View File

@@ -1,9 +1,11 @@
// @ts-nocheck
import React from 'react';
import styled from 'styled-components';
import classNames from 'classnames';
import { CLASSES } from '@/constants/classes';
import { useSettings } from '@/hooks/query';
import PreferencesPageLoader from '../PreferencesPageLoader';
import { Card } from '@/components';
const PreferencesCreditNotesFormContext = React.createContext();
@@ -15,7 +17,6 @@ function PreferencesCreditNotesBoot({ ...props }) {
const provider = {
organization: {},
};
// Detarmines whether if any query is loading.
const isLoading = isSettingsLoading;
@@ -26,15 +27,28 @@ function PreferencesCreditNotesBoot({ ...props }) {
CLASSES.PREFERENCES_PAGE_INSIDE_CONTENT_ACCOUNTANT,
)}
>
{isLoading ? (
<PreferencesPageLoader />
) : (
<PreferencesCreditNotesFormContext.Provider value={provider} {...props} />
)}
<PreferencesCreditNotesCard>
{isLoading ? (
<PreferencesPageLoader />
) : (
<PreferencesCreditNotesFormContext.Provider
value={provider}
{...props}
/>
)}
</PreferencesCreditNotesCard>
</div>
);
}
const PreferencesCreditNotesCard = styled(Card)`
padding: 25px;
.bp4-form-group {
max-width: 600px;
}
`;
const usePreferencesCreditNotesFormContext = () =>
React.useContext(PreferencesCreditNotesFormContext);

View File

@@ -6,7 +6,7 @@ import { Intent } from '@blueprintjs/core';
import { AppToaster } from '@/components';
import { PreferencesCreditNotesFormSchema } from './PreferencesCreditNotesForm.schema';
import { usePreferencesInvoiceFormContext } from './PreferencesCreditNotesFormBoot';
import { usePreferencesCreditNotesFormContext } from './PreferencesCreditNotesFormBoot';
import { PreferencesCreditNotesForm } from './PreferencesCreditNotesForm';
import withDashboardActions from '@/containers/Dashboard/withDashboardActions';
@@ -18,16 +18,16 @@ const defaultValues = {
};
/**
* Preferences - .
* Preferences - Credit Notes.
*/
function PreferencesCreditNotesFormPageRoot({
// #withDashboardActions
changePreferencesPageTitle,
}) {
const { organization } = usePreferencesInvoiceFormContext();
const { organization } = usePreferencesCreditNotesFormContext();
useEffect(() => {
changePreferencesPageTitle(intl.get('preferences.estimates'));
changePreferencesPageTitle(intl.get('preferences.creditNotes'));
}, [changePreferencesPageTitle]);
// Initial values.

View File

@@ -1,14 +1,14 @@
// @ts-nocheck
import { PreferencesEstimatesBoot } from './PreferencesEstimatesFormBoot';
import PreferencesInvoiceFormPage from './PreferencesEstimatesFormPage';
import { PreferencesEstimatesFormPage } from './PreferencesEstimatesFormPage';
/**
* items preferences.
* Estimates preferences.
*/
export default function PreferencesEstimates() {
export function PreferencesEstimates() {
return (
<PreferencesEstimatesBoot>
<PreferencesInvoiceFormPage />
<PreferencesEstimatesFormPage />
</PreferencesEstimatesBoot>
);
}

View File

@@ -6,7 +6,7 @@ import { Intent } from '@blueprintjs/core';
import { AppToaster } from '@/components';
import { PreferencesEstimatesFormSchema } from './PreferencesEstimatesForm.schema';
import { usePreferencesInvoiceFormContext } from './PreferencesEstimatesFormBoot';
import { usePreferencesEstimatesFormContext } from './PreferencesEstimatesFormBoot';
import { PreferencesEstimatesForm } from './PreferencesEstimatesForm';
import withDashboardActions from '@/containers/Dashboard/withDashboardActions';
@@ -24,7 +24,7 @@ function PreferencesEstimatesFormPageRoot({
// #withDashboardActions
changePreferencesPageTitle,
}) {
const { organization } = usePreferencesInvoiceFormContext();
const { organization } = usePreferencesEstimatesFormContext();
useEffect(() => {
changePreferencesPageTitle(intl.get('preferences.estimates'));

View File

@@ -1,9 +1,11 @@
// @ts-nocheck
import React from 'react';
import classNames from 'classnames';
import styled from 'styled-components';
import { CLASSES } from '@/constants/classes';
import { useSettings } from '@/hooks/query';
import PreferencesPageLoader from '../PreferencesPageLoader';
import { Card } from '@/components';
const PreferencesInvoiceFormContext = React.createContext();
@@ -26,15 +28,25 @@ function PreferencesInvoicesBoot({ ...props }) {
CLASSES.PREFERENCES_PAGE_INSIDE_CONTENT_ACCOUNTANT,
)}
>
{isLoading ? (
<PreferencesPageLoader />
) : (
<PreferencesInvoiceFormContext.Provider value={provider} {...props} />
)}
<PreferencesInvoicesCard>
{isLoading ? (
<PreferencesPageLoader />
) : (
<PreferencesInvoiceFormContext.Provider value={provider} {...props} />
)}
</PreferencesInvoicesCard>
</div>
);
}
const PreferencesInvoicesCard = styled(Card)`
padding: 25px;
.bp4-form-group{
max-width: 600px;
}
`;
const usePreferencesInvoiceFormContext = () =>
React.useContext(PreferencesInvoiceFormContext);

View File

@@ -7,7 +7,7 @@ import { Intent } from '@blueprintjs/core';
import { AppToaster } from '@/components';
import { PreferencesInvoiceFormSchema } from './PreferencesInvoiceForm.schema';
import { usePreferencesInvoiceFormContext } from './PreferencesInvoiceFormBoot';
import { PreferencesGeneralForm } from './PreferencesInvoicesForm';
import { PreferencesInvoicesForm } from './PreferencesInvoicesForm';
import withDashboardActions from '@/containers/Dashboard/withDashboardActions';
import { compose, transformToForm } from '@/utils';
@@ -59,7 +59,7 @@ function PreferencesInvoiceFormPage({
initialValues={initialValues}
validationSchema={PreferencesInvoiceFormSchema}
onSubmit={handleFormSubmit}
component={PreferencesGeneralForm}
component={PreferencesInvoicesForm}
/>
);
}

View File

@@ -5,17 +5,15 @@ import { Button, Intent } from '@blueprintjs/core';
import { useHistory } from 'react-router-dom';
import {
FieldRequiredHint,
FormattedMessage as T,
FFormGroup,
FInputGroup,
FTextArea,
} from '@/components';
/**
* Preferences general form.
*/
export function PreferencesGeneralForm({ isSubmitting }) {
export function PreferencesInvoicesForm({ isSubmitting }) {
const history = useHistory();
// Handle close click.
@@ -29,7 +27,6 @@ export function PreferencesGeneralForm({ isSubmitting }) {
<FFormGroup
name={'termsConditions'}
label={<T id={'pref.invoices.termsConditions.field'} />}
labelInfo={<FieldRequiredHint />}
fastField={true}
>
<FTextArea

View File

@@ -0,0 +1,14 @@
// @ts-nocheck
import { PreferencesReceiptsBoot } from './PreferencesReceiptsFormBoot';
import { PreferencesReceiptsFormPage } from './PreferencesReceiptsFormPage';
/**
* Preferences - Receipts.
*/
export function PreferencesReceipts() {
return (
<PreferencesReceiptsBoot>
<PreferencesReceiptsFormPage />
</PreferencesReceiptsBoot>
);
}

View File

@@ -0,0 +1,9 @@
// @ts-nocheck
import * as Yup from 'yup';
const Schema = Yup.object().shape({
termsConditions: Yup.string().optional(),
customerNotes: Yup.string().optional(),
});
export const PreferencesReceiptsFormSchema = Schema;

View File

@@ -0,0 +1,78 @@
// @ts-nocheck
import styled from 'styled-components';
import { Form } from 'formik';
import { Button, Intent } from '@blueprintjs/core';
import { useHistory } from 'react-router-dom';
import {
FormattedMessage as T,
FFormGroup,
FTextArea,
} from '@/components';
/**
* Preferences general form.
*/
export function PreferencesReceiptsForm({ isSubmitting }) {
const history = useHistory();
// Handle close click.
const handleCloseClick = () => {
history.go(-1);
};
return (
<Form>
{/* ---------- Terms & Conditions ---------- */}
<FFormGroup
name={'termsConditions'}
label={<T id={'pref.receipts.termsConditions.field'} />}
fastField={true}
>
<FTextArea
medium={'true'}
name={'termsConditions'}
fastField={true}
fill={true}
/>
</FFormGroup>
{/* ---------- Customer Notes ---------- */}
<FFormGroup
name={'customerNotes'}
label={<T id={'pref.receipts.customerNotes.field'} />}
fastField={true}
>
<FTextArea
medium={'true'}
name={'tax_number'}
fastField={true}
fill={true}
/>
</FFormGroup>
<CardFooterActions>
<Button loading={isSubmitting} intent={Intent.PRIMARY} type="submit">
<T id={'save'} />
</Button>
<Button onClick={handleCloseClick}>
<T id={'close'} />
</Button>
</CardFooterActions>
</Form>
);
}
const CardFooterActions = styled.div`
padding-top: 16px;
border-top: 1px solid #e0e7ea;
margin-top: 30px;
.bp4-button {
min-width: 70px;
+ .bp4-button {
margin-left: 10px;
}
}
`;

View File

@@ -0,0 +1,56 @@
// @ts-nocheck
import React from 'react';
import classNames from 'classnames';
import styled from 'styled-components';
import { CLASSES } from '@/constants/classes';
import { useSettings } from '@/hooks/query';
import PreferencesPageLoader from '../PreferencesPageLoader';
import { Card } from '@/components';
const PreferencesReceiptsFormContext = React.createContext();
function PreferencesReceiptsBoot({ ...props }) {
// Fetches organization settings.
const { isLoading: isSettingsLoading } = useSettings();
// Provider state.
const provider = {
organization: {},
};
// Detarmines whether if any query is loading.
const isLoading = isSettingsLoading;
return (
<div
className={classNames(
CLASSES.PREFERENCES_PAGE_INSIDE_CONTENT,
CLASSES.PREFERENCES_PAGE_INSIDE_CONTENT_ACCOUNTANT,
)}
>
<PreferencesReceiptsCard>
{isLoading ? (
<PreferencesPageLoader />
) : (
<PreferencesReceiptsFormContext.Provider
value={provider}
{...props}
/>
)}
</PreferencesReceiptsCard>
</div>
);
}
const PreferencesReceiptsCard = styled(Card)`
padding: 25px;
.bp4-form-group {
max-width: 600px;
}
`;
const usePreferencesReceiptsFormContext = () =>
React.useContext(PreferencesReceiptsFormContext);
export { PreferencesReceiptsBoot, usePreferencesReceiptsFormContext };

View File

@@ -0,0 +1,69 @@
// @ts-nocheck
import React, { useEffect } from 'react';
import intl from 'react-intl-universal';
import { Formik } from 'formik';
import { Intent } from '@blueprintjs/core';
import { AppToaster } from '@/components';
import { PreferencesReceiptsFormSchema } from './PreferencesReceiptsForm.schema';
import { usePreferencesReceiptsFormContext } from './PreferencesReceiptsFormBoot';
import { PreferencesReceiptsForm } from './PreferencesReceiptsForm';
import withDashboardActions from '@/containers/Dashboard/withDashboardActions';
import { compose, transformToForm } from '@/utils';
const defaultValues = {
termsConditions: '',
customerNotes: '',
};
/**
* Preferences - Receipts.
*/
function PreferencesReceiptsFormPageRoot({
// #withDashboardActions
changePreferencesPageTitle,
}) {
const { organization } = usePreferencesReceiptsFormContext();
useEffect(() => {
changePreferencesPageTitle(intl.get('preferences.receipts'));
}, [changePreferencesPageTitle]);
// Initial values.
const initialValues = {
...defaultValues,
...transformToForm(organization.metadata, defaultValues),
};
// Handle the form submit.
const handleFormSubmit = (values, { setSubmitting }) => {
// Handle request success.
const onSuccess = (response) => {
AppToaster.show({
message: intl.get('preferences.receipts.success_message'),
intent: Intent.SUCCESS,
});
setSubmitting(false);
};
// Handle request error.
const onError = () => {
setSubmitting(false);
};
// updateOrganization({ ...values })
// .then(onSuccess)
// .catch(onError);
};
return (
<Formik
initialValues={initialValues}
validationSchema={PreferencesReceiptsFormSchema}
onSubmit={handleFormSubmit}
component={PreferencesReceiptsForm}
/>
);
}
export const PreferencesReceiptsFormPage = compose(withDashboardActions)(
PreferencesReceiptsFormPageRoot,
);