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

mendersoftware / gui / 1113439055

19 Dec 2023 09:01PM UTC coverage: 82.752% (-17.2%) from 99.964%
1113439055

Pull #4258

gitlab-ci

mender-test-bot
chore: Types update

Signed-off-by: Mender Test Bot <mender@northern.tech>
Pull Request #4258: chore: Types update

4326 of 6319 branches covered (0.0%)

8348 of 10088 relevant lines covered (82.75%)

189.39 hits per line

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

88.89
/src/js/components/header/trialnotification.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 from 'react';
15
import { Link } from 'react-router-dom';
16

17
import { InfoOutlined as InfoIcon, Payment } from '@mui/icons-material';
18
import { Button } from '@mui/material';
19

20
import moment from 'moment';
21
import momentDurationFormatSetup from 'moment-duration-format';
22
import pluralize from 'pluralize';
23

24
import { MenderTooltipClickable } from '../common/mendertooltip';
25

26
momentDurationFormatSetup(moment);
3✔
27

28
const today = new Date();
3✔
29

30
const TrialInformation = () => (
3✔
31
  <>
×
32
    <h3>Trial plan</h3>
33
    <p>You&apos;re using the trial version of Mender – it&apos;s free for up to 10 devices for 12 months.</p>
34
    <p>
35
      <Link to="/settings/upgrade">Upgrade to a plan</Link> to add more devices and continue using Mender after the trial expires.
36
    </p>
37
    <p>
38
      Or compare the plans at {/* eslint-disable-next-line react/jsx-no-target-blank */}
39
      <a href={`https://mender.io/plans/pricing`} target="_blank" rel="noopener">
40
        mender.io/plans/pricing
41
      </a>
42
      .
43
    </p>
44
  </>
45
);
46

47
const TrialNotification = ({ iconClassName, sectionClassName, expiration }) => {
3✔
48
  const expirationDate = moment(expiration);
2✔
49
  const duration = moment.duration(expirationDate.diff(moment(today)));
2✔
50
  const daysLeft = Math.floor(duration.asDays());
2✔
51
  return (
2✔
52
    <div className={`flexbox centered ${sectionClassName}`}>
53
      <MenderTooltipClickable className="flexbox center-aligned muted margin-right-small" disableHoverListener={false} title={<TrialInformation />}>
54
        <>
55
          <InfoIcon className={iconClassName} style={{ marginRight: 2 }} />
56
          Trial plan
57
        </>
58
      </MenderTooltipClickable>
59
      <Button className={iconClassName} component={Link} startIcon={<Payment />} to="/settings/upgrade">
60
        Upgrade now
61
      </Button>
62

63
      {expiration && daysLeft <= 100 && daysLeft >= 0 && (
5✔
64
        <div className="muted">
65
          You have {daysLeft} {pluralize('day', daysLeft)} remaining on the trial plan
66
        </div>
67
      )}
68
    </div>
69
  );
70
};
71

72
export default TrialNotification;
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