From f08a6c55a64a05e8845ab2deb3b2ccc929a67194 Mon Sep 17 00:00:00 2001 From: Davit Date: Mon, 5 Aug 2024 11:50:09 +0400 Subject: [PATCH] fix overflowing bulkdeployment texts --- src/components/BulkDeployments/index.tsx | 5 +- src/components/DeploymentsByFilter/index.js | 98 ++++++++++----------- 2 files changed, 52 insertions(+), 51 deletions(-) diff --git a/src/components/BulkDeployments/index.tsx b/src/components/BulkDeployments/index.tsx index b6c326db..3808dbdb 100644 --- a/src/components/BulkDeployments/index.tsx +++ b/src/components/BulkDeployments/index.tsx @@ -2,6 +2,7 @@ import React, { FC } from 'react'; import CancelDeployment from 'components/CancelDeployment'; import { getDeploymentDuration } from 'components/Deployment'; +import { formatString } from 'components/DeploymentsByFilter'; import HoverTag from 'components/HoverTag'; import DeploymentLink from 'components/link/Deployment'; import DeploymentsLink from 'components/link/Deployments'; @@ -49,7 +50,7 @@ const BulkDeployments: FC = ({ deployments }) => (
- {deployment.environment.project.name} + {formatString(deployment.environment.project.name, 'project')}
@@ -57,7 +58,7 @@ const BulkDeployments: FC = ({ deployments }) => ( environmentSlug={deployment.environment.openshiftProjectName} projectSlug={deployment.environment.project.name} > - {deployment.environment.name} + {formatString(deployment.environment.name, 'environment')}
diff --git a/src/components/DeploymentsByFilter/index.js b/src/components/DeploymentsByFilter/index.js index 93be94a9..8945b1d6 100644 --- a/src/components/DeploymentsByFilter/index.js +++ b/src/components/DeploymentsByFilter/index.js @@ -11,6 +11,55 @@ import moment from 'moment'; import useSortableData from '../../lib/withSortedItems'; import { Deployments, DeploymentsDataTable, DeploymentsHeader } from './StyledDeploymentsByFilter'; +export const formatString = (textToEdit, labelClassToQuery) => { + // if the string is bigger than the data-row container, then add new lines. + const getTextWidth = string => { + // gets the width of a string that *will* be rendered + const canvas = new OffscreenCanvas(500, 200); + const context = canvas.getContext('2d'); + context.font = getComputedStyle(document.body).font; + return context.measureText(string).width; + }; + + const labelWidth = document.querySelector(`.data-row > .${labelClassToQuery}`)?.getBoundingClientRect().width; + + const editString = string => { + // find all "-" or "/" and replace with line breaks prefixed by the symbol found. + const regex = /[-\/]/g; + return string.replace(regex, match => match + '\n'); + }; + + const combine = strings => { + let combined = ''; + let line = ''; + + if (strings.length === 1) return strings[0]; + + for (let i = 0; i < strings.length; i++) { + const newLine = line + strings[i]; + const width = getTextWidth(newLine); + + if (width <= labelWidth + 30) { + line = newLine; + } else { + combined += line + '\n'; + line = strings[i]; + } + if (i === strings.length - 1 && getTextWidth(line) <= labelWidth + 30) { + combined += line; + } else if (i === strings.length - 1) { + combined += '\n' + line; + } + } + return combined; + }; + + if (labelWidth < getTextWidth(textToEdit)) { + return combine(editString(textToEdit).split('\n')); + } + return textToEdit; +}; + /** * The primary list of running deployments. */ @@ -22,55 +71,6 @@ const DeploymentsByFilter = ({ deployments }) => { const [searchTerm, setSearchTerm] = useState(''); const [hasFilter, setHasFilter] = useState(false); - const formatString = (textToEdit, labelClassToQuery) => { - // if the string is bigger than the data-row container, then add new lines. - const getTextWidth = string => { - // gets the width of a string that *will* be rendered - const canvas = new OffscreenCanvas(500, 200); - const context = canvas.getContext('2d'); - context.font = getComputedStyle(document.body).font; - return context.measureText(string).width; - }; - - const labelWidth = document.querySelector(`.data-row > .${labelClassToQuery}`)?.getBoundingClientRect().width; - - const editString = string => { - // find all "-" or "/" and replace with line breaks prefixed by the symbol found. - const regex = /[-\/]/g; - return string.replace(regex, match => match + '\n'); - }; - - const combine = strings => { - let combined = ''; - let line = ''; - - if (strings.length === 1) return strings[0]; - - for (let i = 0; i < strings.length; i++) { - const newLine = line + strings[i]; - const width = getTextWidth(newLine); - - if (width <= labelWidth + 30) { - line = newLine; - } else { - combined += line + '\n'; - line = strings[i]; - } - if (i === strings.length - 1 && getTextWidth(line) <= labelWidth + 30) { - combined += line; - } else if (i === strings.length - 1) { - combined += '\n' + line; - } - } - return combined; - }; - - if (labelWidth < getTextWidth(textToEdit)) { - return combine(editString(textToEdit).split('\n')); - } - return textToEdit; - }; - const handleSearchFilterChange = event => { setHasFilter(false);