• Home
  • Features
  • Pricing
  • Docs
  • Announcements
  • Sign In

mendersoftware / gui / 1314233734

01 Jun 2024 04:11AM UTC coverage: 83.437% (-16.5%) from 99.964%
1314233734

Pull #4433

gitlab-ci

web-flow
chore: Bump the production-dependencies group with 4 updates

Bumps the production-dependencies group with 4 updates: [@reduxjs/toolkit](https://github.com/reduxjs/redux-toolkit), [@stripe/stripe-js](https://github.com/stripe/stripe-js), [axios](https://github.com/axios/axios) and [react-hook-form](https://github.com/react-hook-form/react-hook-form).


Updates `@reduxjs/toolkit` from 2.2.4 to 2.2.5
- [Release notes](https://github.com/reduxjs/redux-toolkit/releases)
- [Commits](https://github.com/reduxjs/redux-toolkit/compare/v2.2.4...v2.2.5)

Updates `@stripe/stripe-js` from 3.4.0 to 3.4.1
- [Release notes](https://github.com/stripe/stripe-js/releases)
- [Commits](https://github.com/stripe/stripe-js/compare/v3.4.0...v3.4.1)

Updates `axios` from 1.6.8 to 1.7.2
- [Release notes](https://github.com/axios/axios/releases)
- [Changelog](https://github.com/axios/axios/blob/v1.x/CHANGELOG.md)
- [Commits](https://github.com/axios/axios/compare/v1.6.8...v1.7.2)

Updates `react-hook-form` from 7.51.4 to 7.51.5
- [Release notes](https://github.com/react-hook-form/react-hook-form/releases)
- [Changelog](https://github.com/react-hook-form/react-hook-form/blob/master/CHANGELOG.md)
- [Commits](https://github.com/react-hook-form/react-hook-form/compare/v7.51.4...v7.51.5)

---
updated-dependencies:
- dependency-name: "@reduxjs/toolkit"
  dependency-type: direct:production
  update-type: version-update:semver-patch
  dependency-group: production-dependencies
- dependency-name: "@stripe/stripe-js"
  dependency-type: direct:production
  update-type: version-update:semver-patch
  dependency-group: production-dependencies
- dependency-name: axios
  dependency-type: direct:production
  update-type: version-update:semver-minor
  dependency-group: production-dependencies
- dependency-name: react-hook-form
  dependency-type: direct:production
  update-type: version-update:semver-patch
  dependency-group: production-dependencies
...

Signed-off-by: dependabot[bot] <support@github.com>
Pull Request #4433: chore: Bump the production-dependencies group with 4 updates

4476 of 6391 branches covered (70.04%)

8488 of 10173 relevant lines covered (83.44%)

140.36 hits per line

Source File
Press 'n' to go to next uncovered line, 'b' for previous

73.33
/src/js/components/common/forms/timeframe-picker.js
1
// Copyright 2020 Northern.tech AS
2
//
3
//    Licensed under the Apache License, Version 2.0 (the "License");
4
//    you may not use this file except in compliance with the License.
5
//    You may obtain a copy of the License at
6
//
7
//        http://www.apache.org/licenses/LICENSE-2.0
8
//
9
//    Unless required by applicable law or agreed to in writing, software
10
//    distributed under the License is distributed on an "AS IS" BASIS,
11
//    WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
//    See the License for the specific language governing permissions and
13
//    limitations under the License.
14
import React, { useEffect, useState } from 'react';
15
import { Controller, useFormContext } from 'react-hook-form';
16

17
import { DatePicker } from '@mui/x-date-pickers/DatePicker';
18

19
import moment from 'moment';
20

21
const ensureStartOfDay = date => {
8✔
22
  const momentDate = typeof date === 'string' ? moment(date.replace('Z', '')) : moment(date);
×
23
  return `${momentDate.format().split('T')[0]}T00:00:00.000`;
×
24
};
25

26
const ensureEndOfDay = date => {
8✔
27
  const momentDate = typeof date === 'string' ? moment(date.replace('Z', '')) : moment(date);
×
28
  return `${momentDate.format().split('T')[0]}T23:59:59.999`;
×
29
};
30

31
export const TimeframePicker = ({ tonight: propsTonight }) => {
8✔
32
  const [tonight] = useState(moment(propsTonight));
73✔
33
  const [maxStartDate, setMaxStartDate] = useState(tonight);
73✔
34
  const [minEndDate, setMinEndDate] = useState(tonight);
73✔
35

36
  const { control, setValue, watch, getValues } = useFormContext();
73✔
37

38
  const startDate = watch('startDate');
73✔
39
  const endDate = watch('endDate');
73✔
40

41
  useEffect(() => {
73✔
42
    let currentEndDate = getValues('endDate');
22✔
43
    if (startDate > currentEndDate) {
22!
44
      setValue('endDate', ensureEndOfDay(startDate));
×
45
    }
46
    setMinEndDate(moment(startDate));
22✔
47
  }, [startDate, getValues, setValue]);
48

49
  useEffect(() => {
73✔
50
    let currentStartDate = getValues('startDate');
17✔
51
    if (endDate < currentStartDate) {
17!
52
      setValue('startDate', ensureStartOfDay(endDate));
×
53
    }
54
    setMaxStartDate(moment(endDate));
17✔
55
  }, [endDate, getValues, setValue]);
56

57
  const handleChangeStartDate = date => ensureStartOfDay(date);
73✔
58

59
  const handleChangeEndDate = date => ensureEndOfDay(date);
73✔
60

61
  return (
73✔
62
    <div className="flexbox" style={{ flexWrap: 'wrap', gap: 15 }}>
63
      <Controller
64
        name="startDate"
65
        control={control}
66
        render={({ field: { onChange, value } }) => (
67
          <DatePicker
73✔
68
            disabled={!value}
69
            disableFuture
70
            format="MMMM Do"
71
            label="From"
72
            maxDate={maxStartDate}
73
            onChange={e => onChange(handleChangeStartDate(e))}
×
74
            value={value ? moment(value) : moment()}
73✔
75
          />
76
        )}
77
      />
78
      <Controller
79
        name="endDate"
80
        control={control}
81
        render={({ field: { onChange, value } }) => (
82
          <DatePicker
73✔
83
            disableFuture
84
            format="MMMM Do"
85
            label="To"
86
            minDate={minEndDate}
87
            onChange={e => onChange(handleChangeEndDate(e))}
×
88
            value={value ? moment(value) : moment()}
73✔
89
          />
90
        )}
91
      />
92
    </div>
93
  );
94
};
95

96
export default TimeframePicker;
STATUS · Troubleshooting · Open an Issue · Sales · Support · CAREERS · ENTERPRISE · START FREE · SCHEDULE DEMO
ANNOUNCEMENTS · TWITTER · TOS & SLA · Supported CI Services · What's a CI service? · Automated Testing

© 2025 Coveralls, Inc