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

mendersoftware / gui / 1235064739

01 Apr 2024 05:03AM UTC coverage: 83.603% (-16.4%) from 99.964%
1235064739

Pull #4368

gitlab-ci

web-flow
chore: Bump the development-dependencies group with 18 updates

Bumps the development-dependencies group with 18 updates:

| Package | From | To |
| --- | --- | --- |
| [@babel/core](https://github.com/babel/babel/tree/HEAD/packages/babel-core) | `7.24.0` | `7.24.3` |
| [@babel/eslint-parser](https://github.com/babel/babel/tree/HEAD/eslint/babel-eslint-parser) | `7.23.10` | `7.24.1` |
| [@babel/plugin-transform-runtime](https://github.com/babel/babel/tree/HEAD/packages/babel-plugin-transform-runtime) | `7.24.0` | `7.24.3` |
| [@babel/preset-env](https://github.com/babel/babel/tree/HEAD/packages/babel-preset-env) | `7.24.0` | `7.24.3` |
| [@babel/preset-react](https://github.com/babel/babel/tree/HEAD/packages/babel-preset-react) | `7.23.3` | `7.24.1` |
| [@testing-library/react](https://github.com/testing-library/react-testing-library) | `14.2.1` | `14.2.2` |
| [@typescript-eslint/eslint-plugin](https://github.com/typescript-eslint/typescript-eslint/tree/HEAD/packages/eslint-plugin) | `7.1.0` | `7.4.0` |
| [@typescript-eslint/parser](https://github.com/typescript-eslint/typescript-eslint/tree/HEAD/packages/parser) | `7.1.0` | `7.4.0` |
| [autoprefixer](https://github.com/postcss/autoprefixer) | `10.4.17` | `10.4.19` |
| [core-js](https://github.com/zloirock/core-js/tree/HEAD/packages/core-js) | `3.36.0` | `3.36.1` |
| [esbuild-loader](https://github.com/privatenumber/esbuild-loader) | `4.0.3` | `4.1.0` |
| [eslint-plugin-react](https://github.com/jsx-eslint/eslint-plugin-react) | `7.33.2` | `7.34.1` |
| [eslint-plugin-sonarjs](https://github.com/SonarSource/eslint-plugin-sonarjs) | `0.24.0` | `0.25.0` |
| [eslint-webpack-plugin](https://github.com/webpack-contrib/eslint-webpack-plugin) | `4.0.1` | `4.1.0` |
| [msw](https://github.com/mswjs/msw) | `2.2.2` | `2.2.13` |
| [postcss](https://github.com/postcss/postcss) | `8.4.35` | `8.4.38` |
| [webpack](https://github.com/webpack/webpack) | `5.90.3` | `5.91.0` |
| [yarn](https://github.com/yarnpkg/yarn) | ... (continued)
Pull Request #4368: chore: Bump the development-dependencies group with 18 updates

4434 of 6325 branches covered (70.1%)

8408 of 10057 relevant lines covered (83.6%)

140.68 hits per line

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

72.73
/src/js/components/devices/widgets/deviceadditionwidget.js
1
// Copyright 2021 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, { useState } from 'react';
15

16
import { ArrowDropDown as ArrowDropDownIcon, Launch as LaunchIcon } from '@mui/icons-material';
17
import { Button, ButtonGroup, Menu, MenuItem } from '@mui/material';
18
import { makeStyles } from 'tss-react/mui';
19

20
import { canAccess } from '../../../constants/appConstants';
21
import DocsLink from '../../common/docslink';
22

23
const useStyles = makeStyles()(() => ({
4✔
24
  buttonStyle: { textTransform: 'none' }
25
}));
26

27
export const DeviceAdditionWidget = ({ features, innerRef, onConnectClick, onMakeGatewayClick, onPreauthClick, tenantCapabilities }) => {
4✔
28
  const [anchorEl, setAnchorEl] = useState();
5✔
29
  const [selectedIndex, setSelectedIndex] = useState(0);
5✔
30
  const { classes } = useStyles();
5✔
31

32
  const options = [
5✔
33
    { action: onConnectClick, title: 'Connect a new device', value: 'connect', canAccess },
34
    { action: onPreauthClick, title: 'Preauthorize a device', value: 'preauth', canAccess },
35
    {
36
      action: onMakeGatewayClick,
37
      title: 'Promote a device to gateway',
38
      value: 'makegateway',
39
      canAccess: ({ features, tenantCapabilities }) => features.isHosted && tenantCapabilities.isEnterprise
5!
40
    },
41
    {
42
      component: DocsLink,
43
      path: 'client-installation/overview',
44
      title: 'Learn how to connect devices',
45
      value: 'learntoconnect',
46
      canAccess
47
    }
48
  ];
49

50
  const handleToggle = event => {
5✔
51
    const anchor = anchorEl ? null : event?.currentTarget.parentElement;
×
52
    setAnchorEl(anchor);
×
53
  };
54

55
  const handleSelection = index => {
5✔
56
    setSelectedIndex(index);
×
57
    handleToggle();
×
58
    options[index].action(true);
×
59
  };
60

61
  return (
5✔
62
    <>
63
      <ButtonGroup className="muted device-addition-widget" ref={innerRef} style={{ height: 'max-content' }}>
64
        <Button className={classes.buttonStyle} onClick={options[selectedIndex].action} variant="text">
65
          {options[selectedIndex].title}
66
        </Button>
67
        <Button className={classes.buttonStyle} size="small" onClick={handleToggle} variant="text">
68
          <ArrowDropDownIcon />
69
        </Button>
70
      </ButtonGroup>
71
      <Menu id="device-connection-menu" anchorEl={anchorEl} keepMounted open={Boolean(anchorEl)} onClose={handleToggle} variant="menu">
72
        {options.reduce((accu, option, index) => {
73
          if (!option.canAccess({ features, tenantCapabilities })) {
20✔
74
            return accu;
5✔
75
          }
76
          // eslint-disable-next-line no-unused-vars
77
          const { canAccess, component, title, value, ...optionProps } = option;
15✔
78
          const item = component ? (
15✔
79
            <MenuItem {...optionProps} key={value} component={component}>
80
              {title}
81
              <LaunchIcon style={{ fontSize: '10pt' }} />
82
            </MenuItem>
83
          ) : (
84
            <MenuItem className={classes.buttonStyle} key={value} onClick={() => handleSelection(index)}>
×
85
              {title}
86
            </MenuItem>
87
          );
88
          accu.push(item);
15✔
89
          return accu;
15✔
90
        }, [])}
91
      </Menu>
92
    </>
93
  );
94
};
95

96
export default DeviceAdditionWidget;
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