|
| 1 | +import React from "react"; |
| 2 | +import PropTypes from "prop-types"; |
| 3 | + |
| 4 | +import { t } from "ttag"; |
| 5 | + |
| 6 | +import { |
| 7 | + allEngines, |
| 8 | + engineSupersedesMap, |
| 9 | +} from "metabase/entities/databases/forms"; |
| 10 | + |
| 11 | +import Warnings from "metabase/query_builder/components/Warnings"; |
| 12 | + |
| 13 | +import { |
| 14 | + CardContent, |
| 15 | + DriverWarningContainer, |
| 16 | + IconContainer, |
| 17 | +} from "./DriverWarning.styled"; |
| 18 | +import ExternalLink from "metabase/components/ExternalLink"; |
| 19 | +import MetabaseSettings from "metabase/lib/settings"; |
| 20 | + |
| 21 | +const propTypes = { |
| 22 | + engine: PropTypes.string.isRequired, |
| 23 | +}; |
| 24 | + |
| 25 | +const driverUpgradeHelpLink = MetabaseSettings.docsUrl( |
| 26 | + "administration-guide/01-managing-databases", |
| 27 | +); |
| 28 | + |
| 29 | +function getSupersedesWarningContent(newDriver, supersedesDriver) { |
| 30 | + return ( |
| 31 | + <div> |
| 32 | + <p className="text-medium m0"> |
| 33 | + {t`This is our new ${ |
| 34 | + allEngines[newDriver]["driver-name"] |
| 35 | + } driver, which is faster and more reliable.`} |
| 36 | + </p> |
| 37 | + <p>{t`The old driver has been deprecated and will be removed in the next release. If you really |
| 38 | + need to use it, you can select ${ |
| 39 | + allEngines[supersedesDriver]["driver-name"] |
| 40 | + } now.`}</p> |
| 41 | + </div> |
| 42 | + ); |
| 43 | +} |
| 44 | + |
| 45 | +function getSupersededByWarningContent(engine) { |
| 46 | + return ( |
| 47 | + <div> |
| 48 | + <p className="text-medium m0"> |
| 49 | + {t`This driver has been deprecated and will be removed in the next release.`} |
| 50 | + </p> |
| 51 | + <p className="text-medium m0"> |
| 52 | + {t`We recommend that you upgrade to the new ${ |
| 53 | + allEngines[engine]["driver-name"] |
| 54 | + } driver, which is faster and more reliable.`} |
| 55 | + </p> |
| 56 | + <ExternalLink |
| 57 | + href={driverUpgradeHelpLink} |
| 58 | + className="text-brand text-bold" |
| 59 | + > |
| 60 | + {t`How to upgrade a driver`} |
| 61 | + </ExternalLink> |
| 62 | + </div> |
| 63 | + ); |
| 64 | +} |
| 65 | + |
| 66 | +function DriverWarning({ engine, ...props }) { |
| 67 | + const supersededBy = engineSupersedesMap["superseded_by"][engine]; |
| 68 | + const supersedes = engineSupersedesMap["supersedes"][engine]; |
| 69 | + |
| 70 | + if (!supersedes && !supersededBy) { |
| 71 | + return null; |
| 72 | + } |
| 73 | + |
| 74 | + const tooltipWarning = supersedes ? t`New driver` : t`Driver deprecated`; |
| 75 | + const warningContent = supersedes |
| 76 | + ? getSupersedesWarningContent(engine, supersedes) |
| 77 | + : getSupersededByWarningContent(supersededBy); |
| 78 | + |
| 79 | + return ( |
| 80 | + <DriverWarningContainer p={2} {...props}> |
| 81 | + <IconContainer> |
| 82 | + <Warnings |
| 83 | + className="mx2 text-gold" |
| 84 | + warnings={[tooltipWarning]} |
| 85 | + size={20} |
| 86 | + /> |
| 87 | + </IconContainer> |
| 88 | + <CardContent flexDirection="column" justify="center" className="ml2"> |
| 89 | + {warningContent} |
| 90 | + </CardContent> |
| 91 | + </DriverWarningContainer> |
| 92 | + ); |
| 93 | +} |
| 94 | + |
| 95 | +DriverWarning.propTypes = propTypes; |
| 96 | + |
| 97 | +export default DriverWarning; |
0 commit comments