aboutsummaryrefslogtreecommitdiffstats
path: root/server/sonar-web/design-system
diff options
context:
space:
mode:
authorAmbroise C <ambroise.christea@sonarsource.com>2023-10-18 10:47:16 +0200
committersonartech <sonartech@sonarsource.com>2023-10-18 20:03:04 +0000
commit669c64ce03389e7f58bc8dd4a0bc885dde814f4d (patch)
tree6be992a73a586a9795188475496101bc91ea1eaa /server/sonar-web/design-system
parentc250a3fe5e458fadddb38d22f558c8a2882fa6dd (diff)
downloadsonarqube-669c64ce03389e7f58bc8dd4a0bc885dde814f4d.tar.gz
sonarqube-669c64ce03389e7f58bc8dd4a0bc885dde814f4d.zip
SONAR-20679 Import trend icons from SC
Diffstat (limited to 'server/sonar-web/design-system')
-rw-r--r--server/sonar-web/design-system/src/components/icons/TrendDownIcon.tsx24
-rw-r--r--server/sonar-web/design-system/src/components/icons/TrendIcon.tsx86
-rw-r--r--server/sonar-web/design-system/src/components/icons/TrendUpIcon.tsx24
-rw-r--r--server/sonar-web/design-system/src/components/icons/index.ts3
4 files changed, 87 insertions, 50 deletions
diff --git a/server/sonar-web/design-system/src/components/icons/TrendDownIcon.tsx b/server/sonar-web/design-system/src/components/icons/TrendDownIcon.tsx
deleted file mode 100644
index 764a0729987..00000000000
--- a/server/sonar-web/design-system/src/components/icons/TrendDownIcon.tsx
+++ /dev/null
@@ -1,24 +0,0 @@
-/*
- * SonarQube
- * Copyright (C) 2009-2023 SonarSource SA
- * mailto:info AT sonarsource DOT com
- *
- * This program is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write to the Free Software Foundation,
- * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- */
-
-import { ArrowDownRightIcon as OcticonArrowDownRightIcon } from '@primer/octicons-react';
-import { OcticonHoc } from './Icon';
-
-export const TrendDownIcon = OcticonHoc(OcticonArrowDownRightIcon, 'TrendDownIcon');
diff --git a/server/sonar-web/design-system/src/components/icons/TrendIcon.tsx b/server/sonar-web/design-system/src/components/icons/TrendIcon.tsx
new file mode 100644
index 00000000000..534d525fd55
--- /dev/null
+++ b/server/sonar-web/design-system/src/components/icons/TrendIcon.tsx
@@ -0,0 +1,86 @@
+/*
+ * SonarQube
+ * Copyright (C) 2009-2023 SonarSource SA
+ * mailto:info AT sonarsource DOT com
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 3 of the License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public License
+ * along with this program; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+ */
+
+import { useTheme } from '@emotion/react';
+import { themeColor } from '../../helpers/theme';
+import { CustomIcon, IconProps } from './Icon';
+
+export const enum TrendDirection {
+ Down = 'down',
+ Up = 'up',
+ Equal = 'equal',
+}
+
+export const enum TrendType {
+ Positive = 'positive',
+ Negative = 'negative',
+ Neutral = 'neutral',
+ Disabled = 'disabled',
+}
+
+interface Props extends IconProps {
+ direction: TrendDirection;
+ type: TrendType;
+}
+
+export function TrendIcon(props: Readonly<Props>) {
+ const theme = useTheme();
+ const { direction, type, ...iconProps } = props;
+
+ const fill = themeColor(
+ (
+ {
+ [TrendType.Positive]: 'iconTrendPositive',
+ [TrendType.Negative]: 'iconTrendNegative',
+ [TrendType.Neutral]: 'iconTrendNeutral',
+ [TrendType.Disabled]: 'iconTrendDisabled',
+ } as const
+ )[type],
+ )({ theme });
+
+ return (
+ <CustomIcon {...iconProps}>
+ {direction === TrendDirection.Up && (
+ <path
+ aria-label="trend-up"
+ clipRule="evenodd"
+ d="M4.75802 4.3611a.74997.74997 0 0 1 .74953-.74953H11.518a.74985.74985 0 0 1 .5298.21967.74967.74967 0 0 1 .2197.52986v6.0104a.75043.75043 0 0 1-.2286.5132.75053.75053 0 0 1-.5209.2104.75017.75017 0 0 1-.5209-.2104.75054.75054 0 0 1-.2287-.5132V6.1713l-5.26085 5.2609a.75014.75014 0 0 1-1.06066 0 .75004.75004 0 0 1 0-1.0607l5.26088-5.26086H5.50755a.75001.75001 0 0 1-.74953-.74954Z"
+ fill={fill}
+ fillRule="evenodd"
+ />
+ )}
+ {direction === TrendDirection.Down && (
+ <path
+ aria-label="trend-down"
+ clipRule="evenodd"
+ d="M11.5052 4.14237a.75026.75026 0 0 1 .5299.21967.74997.74997 0 0 1 .2196.52986v6.0104a.7501.7501 0 0 1-.2196.5299.75027.75027 0 0 1-.5299.2196H5.49479a.74976.74976 0 0 1-.51314-.2286.75004.75004 0 0 1 0-1.0418.74976.74976 0 0 1 .51314-.2286h4.20022L4.43413 4.8919a.75001.75001 0 0 1 1.06066-1.06066l5.26091 5.26087V4.8919a.74997.74997 0 0 1 .2196-.52986.75008.75008 0 0 1 .5299-.21967Z"
+ fill={fill}
+ fillRule="evenodd"
+ />
+ )}
+ {direction === TrendDirection.Equal && (
+ <g aria-label="trend-equal">
+ <rect fill={fill} height="1.5" rx=".75" width="8" x="4" y="5" />
+ <rect fill={fill} height="1.5" rx=".75" width="8" x="4" y="9" />
+ </g>
+ )}
+ </CustomIcon>
+ );
+}
diff --git a/server/sonar-web/design-system/src/components/icons/TrendUpIcon.tsx b/server/sonar-web/design-system/src/components/icons/TrendUpIcon.tsx
deleted file mode 100644
index cbf92fec67f..00000000000
--- a/server/sonar-web/design-system/src/components/icons/TrendUpIcon.tsx
+++ /dev/null
@@ -1,24 +0,0 @@
-/*
- * SonarQube
- * Copyright (C) 2009-2023 SonarSource SA
- * mailto:info AT sonarsource DOT com
- *
- * This program is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write to the Free Software Foundation,
- * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- */
-
-import { ArrowUpRightIcon as OcticonArrowUpRightIcon } from '@primer/octicons-react';
-import { OcticonHoc } from './Icon';
-
-export const TrendUpIcon = OcticonHoc(OcticonArrowUpRightIcon, 'TrendUpIcon');
diff --git a/server/sonar-web/design-system/src/components/icons/index.ts b/server/sonar-web/design-system/src/components/icons/index.ts
index a6264cb3a1f..c8147f4f3c4 100644
--- a/server/sonar-web/design-system/src/components/icons/index.ts
+++ b/server/sonar-web/design-system/src/components/icons/index.ts
@@ -84,8 +84,7 @@ export { StatusReopenedIcon } from './StatusReopenedIcon';
export { StatusResolvedIcon } from './StatusResolvedIcon';
export { TestFileIcon } from './TestFileIcon';
export { TrashIcon } from './TrashIcon';
-export { TrendDownIcon } from './TrendDownIcon';
-export { TrendUpIcon } from './TrendUpIcon';
+export { TrendDirection, TrendIcon, TrendType } from './TrendIcon';
export { TriangleDownIcon } from './TriangleDownIcon';
export { TriangleLeftIcon } from './TriangleLeftIcon';
export { TriangleRightIcon } from './TriangleRightIcon';