|
- // material-ui
- import {
- Button,
- Grid, TextField,
- Typography
- } from '@mui/material';
- import MainCard from "components/MainCard";
- import { useForm } from "react-hook-form";
- import * as React from "react";
- import * as DateUtils from "utils/DateUtils";
- import { ThemeProvider } from "@emotion/react";
- // import { useNavigate } from "react-router-dom";
- import { PNSPS_BUTTON_THEME } from "../../../themes/buttonConst";
- import { FormattedMessage, useIntl } from "react-intl";
-
- import {DatePicker} from "@mui/x-date-pickers/DatePicker";
- import dayjs from "dayjs";
- import {DemoItem} from "@mui/x-date-pickers/internals/demo";
- import {LocalizationProvider} from "@mui/x-date-pickers/LocalizationProvider";
- import {AdapterDayjs} from "@mui/x-date-pickers/AdapterDayjs";
- // ==============================|| DASHBOARD - DEFAULT ||============================== //
- const SearchPublicNoticeForm = ({ applySearch, searchCriteria, onGridReady }) => {
- // const navigate = useNavigate()
-
- const [minDate, setMinDate] = React.useState(searchCriteria.dateFrom);
- const [maxDate, setMaxDate] = React.useState(searchCriteria.dateTo);
-
- const [fromDateValue, setFromDateValue] = React.useState("dd / mm / yyyy");
- const [toDateValue, setToDateValue] = React.useState("dd / mm / yyyy");
-
- const intl = useIntl();
-
- React.useEffect(() => {
- // console.log(minDate)
- setFromDateValue(minDate);
- }, [minDate]);
-
- React.useEffect(() => {
- setToDateValue(maxDate);
- }, [maxDate]);
-
- const _sx = {
- padding: "4 2 4 2",
- boxShadow: 1,
- border: 1,
- borderColor: '#DDD',
- '& .MuiDataGrid-cell': {
- borderTop: 1,
- borderBottom: 1,
- borderColor: "#EEE"
- },
- '& .MuiDataGrid-footerContainer': {
- border: 1,
- borderColor: "#EEE"
- }
- }
-
- const marginBottom = 2.5;
- const { reset, register, handleSubmit } = useForm()
- const onSubmit = (data) => {
- let sentDateFrom = "";
- let sentDateTo = "";
- if( fromDateValue!="dd / mm / yyyy"&&toDateValue!="dd / mm / yyyy"){
- sentDateFrom = DateUtils.dateValue(fromDateValue)!="Invalid Date"?DateUtils.dateValue(fromDateValue):""
- sentDateTo = DateUtils.dateValue(toDateValue)!="Invalid Date"?DateUtils.dateValue(toDateValue):""
- }
- const temp = {
- key: data.key,
- dateFrom: sentDateFrom,
- dateTo: sentDateTo,
- };
- applySearch(temp);
- };
-
-
- function resetForm() {
- setMinDate(DateUtils.dateValue(new Date().setDate(new Date().getDate()-14)))
- setMaxDate(DateUtils.dateValue(new Date()))
- reset();
- localStorage.setItem('searchCriteria',"")
- }
-
-
- return (
- <MainCard xs={12} md={12} lg={12}
- border={false}
- content={false}
- sx={_sx}
- >
-
- <form onSubmit={handleSubmit(onSubmit)}>
- <Grid container sx={{ backgroundColor: '#ffffff', ml: 2, mt: 1, mb: marginBottom }} width="98%">
- {/*row 1*/}
- <Grid item justifyContent="space-between" alignItems="center" sx={{ mt: 1, ml: 3, mb: marginBottom }}>
- <Typography variant="pnspsFormHeader" >
- <FormattedMessage id="search"></FormattedMessage>
- </Typography>
- </Grid>
- {/*row 2*/}
- <Grid container display="flex" alignItems={"center"}>
- <Grid item xs={9} s={6} md={5} lg={3} sx={{ ml: 3, mr: 3, mb: marginBottom }}>
- <TextField
- fullWidth
- {...register("key")}
- id='key'
- label={intl.formatMessage({ id: 'keyword' }) + ":"}
- defaultValue={searchCriteria.key}
- InputLabelProps={{
- shrink: true
- }}
- />
- </Grid>
-
- <Grid item xs={12} s={6} md={6} lg={4} sx={{ ml: 3, mr: 3, mb: 3 }}>
- <Grid container>
- <Grid item xs={5.25} s={5.25} md={5.25} lg={5.5}>
- <LocalizationProvider dateAdapter={AdapterDayjs}>
- <DemoItem components={['DatePicker']}>
- <DatePicker
- id="dateFrom"
- // onError={(newError) => setReceiptFromError(newError)}
- slotProps={{
- field: { readOnly: true, },
- // textField: {
- // helperText: receiptFromErrorMessage,
- // },
- }}
- format="DD/MM/YYYY"
- aria-label={intl.formatMessage({id: 'dateFrom'})}
- label={intl.formatMessage({id: 'dateFrom'})}
- value={minDate === null ? null : dayjs(minDate)}
- maxDate={maxDate === null ? null : dayjs(maxDate)}
- onChange={(newValue) => {
- // console.log(newValue)
- if(newValue!=null){
- setMinDate(newValue);
- }
- }}
- />
- </DemoItem >
- </LocalizationProvider>
- </Grid>
-
- <Grid item xs={1.5} s={1.5} md={1.5} lg={1} sx={{mt:1.3, display: 'flex', justifyContent:"center", alignItems: 'flex-start'}}>
- <FormattedMessage id="to" />
- </Grid>
-
- <Grid item xs={5.25} s={5.25} md={5.25} lg={5.5}>
- <LocalizationProvider dateAdapter={AdapterDayjs}>
- <DemoItem components={['DatePicker']}>
- <DatePicker
- id="dateTo"
- // onError={(newError) => setReceiptFromError(newError)}
- slotProps={{
- field: { readOnly: true, },
- // textField: {
- // helperText: receiptFromErrorMessage,
- // },
- }}
- format="DD/MM/YYYY"
- aria-label={intl.formatMessage({id: 'dateTo'})}
- value={maxDate === null ? null : dayjs(maxDate)}
- minDate={minDate === null ? null : dayjs(minDate)}
- onChange={(newValue) => {
- // console.log(newValue)
- if(newValue!=null){
- setMaxDate(newValue);
- }
- }}
- />
- </DemoItem >
- </LocalizationProvider>
- </Grid>
- </Grid>
- </Grid>
-
- </Grid>
-
- {/*last row*/}
- <Grid container maxWidth justifyContent="flex-end">
- <ThemeProvider theme={PNSPS_BUTTON_THEME}>
- {/* <Grid item sx={{ ml: 3 }}>
- <Button
- variant="contained"
- color="green"
- onClick={() => {
- navigate('/setting/announcement/details/' + 0);
- }}
- >
- <FormattedMessage id="create"></FormattedMessage>
- </Button>
- </Grid> */}
- <Grid item sx={{ ml: 3 }}>
- <Button
- variant="contained"
- onClick={resetForm}
- >
- <FormattedMessage id="reset"></FormattedMessage>
- </Button>
- </Grid>
-
- <Grid item sx={{ ml: 3 }}>
- <Button
- variant="contained"
- type="submit"
- disabled={onGridReady}
- aria-label={intl.formatMessage({id: 'submit'})}
- >
- <FormattedMessage id="submit"></FormattedMessage>
- </Button>
- </Grid>
- </ThemeProvider>
- </Grid>
- </Grid>
- </form>
- </MainCard>
- );
- };
-
- export default SearchPublicNoticeForm;
|