• 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

45.0
/src/js/components/common/detailstable.js
1
// Copyright 2022 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 from 'react';
15

16
// material ui
17
import { Sort as SortIcon } from '@mui/icons-material';
18
import { Checkbox, Table, TableBody, TableCell, TableHead, TableRow } from '@mui/material';
19
import { makeStyles } from 'tss-react/mui';
20

21
import { SORTING_OPTIONS } from '../../constants/appConstants';
22

23
const useStyles = makeStyles()(() => ({
19✔
24
  header: {
25
    '.columnHeader': {
26
      display: 'table-cell'
27
    },
28
    '.columnHeader .sortIcon': {
29
      marginBottom: -6
30
    },
31
    '.nonSortable': { cursor: 'initial' }
32
  }
33
}));
34

35
export const DetailsTable = ({
19✔
36
  className = '',
65✔
37
  columns,
38
  items,
39
  onChangeSorting,
40
  onItemClick,
41
  sort = {},
37✔
42
  style = {},
72✔
43
  tableRef,
44
  onRowSelected = undefined,
37✔
45
  selectedRows = []
37✔
46
}) => {
47
  const { classes } = useStyles();
72✔
48

49
  const onRowSelection = selectedRow => {
72✔
50
    let updatedSelection = [...selectedRows];
×
51
    const selectedIndex = updatedSelection.indexOf(selectedRow);
×
52
    if (selectedIndex === -1) {
×
53
      updatedSelection.push(selectedRow);
×
54
    } else {
55
      updatedSelection.splice(selectedIndex, 1);
×
56
    }
57
    onRowSelected(updatedSelection);
×
58
  };
59

60
  const onSelectAllClick = () => {
72✔
61
    let newSelectedRows = Array.from({ length: items.length }, (_, index) => index);
×
62
    if (selectedRows.length && selectedRows.length <= items.length) {
×
63
      newSelectedRows = [];
×
64
    }
65
    onRowSelected(newSelectedRows);
×
66
  };
67

68
  return (
72✔
69
    <Table className={`margin-bottom ${className}`} style={style} ref={tableRef}>
70
      <TableHead className={classes.header}>
71
        <TableRow>
72
          {onRowSelected !== undefined && (
107✔
73
            <TableCell>
74
              <Checkbox indeterminate={false} checked={selectedRows.length === items.length} onChange={onSelectAllClick} />
75
            </TableCell>
76
          )}
77
          {columns.map(({ extras, key, renderTitle, sortable, title }) => (
78
            <TableCell key={key} className={`columnHeader ${sortable ? '' : 'nonSortable'}`} onClick={() => (sortable ? onChangeSorting(key) : null)}>
341!
79
              {renderTitle ? renderTitle(extras) : title}
341✔
80
              {sortable && <SortIcon className={`sortIcon ${sort.key === key ? 'selected' : ''} ${(sort.direction === SORTING_OPTIONS.desc).toString()}`} />}
551✔
81
            </TableCell>
82
          ))}
83
        </TableRow>
84
      </TableHead>
85
      <TableBody>
86
        {items.map((item, index) => (
87
          <TableRow className={onItemClick ? 'clickable' : ''} hover key={item.id || index}>
490✔
88
            {onRowSelected !== undefined && (
867✔
89
              <TableCell>
90
                <Checkbox checked={selectedRows.includes(index)} onChange={() => onRowSelection(index)} />
×
91
              </TableCell>
92
            )}
93
            {columns.map(column => (
94
              <TableCell className="relative" key={column.key} onClick={() => (onItemClick ? onItemClick(item) : null)}>
1,962!
95
                {column.render(item, column.extras)}
96
              </TableCell>
97
            ))}
98
          </TableRow>
99
        ))}
100
      </TableBody>
101
    </Table>
102
  );
103
};
104

105
export default DetailsTable;
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