Skip to content

Commit

Permalink
feat(UISettings): add reShortNameFromAddress [YTFRONT-3861]
Browse files Browse the repository at this point in the history
  • Loading branch information
ma-efremoff committed Oct 13, 2023
1 parent 3256a2d commit 071b0ea
Show file tree
Hide file tree
Showing 6 changed files with 70 additions and 36 deletions.
10 changes: 9 additions & 1 deletion packages/ui/src/shared/ui-settings.ts
Original file line number Diff line number Diff line change
Expand Up @@ -66,10 +66,18 @@ export interface UISettings {
operationsMonitoring?: UISettingsMonitoring;

/**
* Allows to define regular expression to get hash-part from version of node by named group 'hash'
* Allows to define regular expression to extract hash-part from version of node by named group 'hash'
* @example reHashFromNodeVersion: '[^~]+(?<hash>[^+]+)'
*/
reHashFromNodeVersion?: string;

/**
* Allows to define regular expression to extract short-name from full address of host by named group 'shortname'.
* Also it supports optional named group 'suffix' that will pe appended to shortname as is.
* @example reShortNameFromAddress: '(?<shortname>.*)((\\.msk\\.my-domain\\.ru)|(\\.vla\\.my-domain\\.net))'
* @example reShortNameFromAddress: '(?<shortname>.*)((\\.msk\\.my-domain\\.ru)|(\\.vla\\.my-domain\\.net))'
*/
reShortNameFromAddress?: string;
}

export interface UISettingsMonitoring {
Expand Down
57 changes: 45 additions & 12 deletions packages/ui/src/ui/containers/Host/Host.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -6,38 +6,71 @@ import {getCluster} from '../../store/selectors/global';
import Link from '../../components/Link/Link';
import ClipboardButton from '../../components/ClipboardButton/ClipboardButton';
import {Tooltip} from '../../components/Tooltip/Tooltip';
import {uiSettings} from '../../config';

import './Host.scss';

function makeRegexpFromSettings() {
try {
return new RegExp(uiSettings.reShortNameFromAddress!);
} catch {
return undefined;
}
}

const reShortName = makeRegexpFromSettings();

function calcShortNameByRegExp(address: string) {
if (reShortName) {
const res = reShortName?.exec(address);
if (res?.groups?.shortname) {
return [res.groups.shortname, res.groups.suffix].filter(Boolean).join('');
}
}
return undefined;
}

function calcShortNameByMinus(address: string) {
const first = address.indexOf('-');
const second = address.indexOf('-', first + 1);
const res = address.substring(0, second);
if (res.length) {
return res;
}
const dotIndex = address.indexOf('.');
return dotIndex === -1 ? address : address.substring(0, dotIndex);
}

const block = cn('yt-host');

interface Props {
address: string;
className?: string;
copyBtnClassName?: string;
asText?: boolean;
onClick?: () => void;
useText?: boolean;
allowByRegexp?: boolean;
prefix?: React.ReactNode;
}

export function Host({address = '', prefix, className, asText, copyBtnClassName}: Props) {
export function Host({address = '', prefix, className, copyBtnClassName, onClick, useText}: Props) {
const host = React.useMemo(() => {
const first = address.indexOf('-');
const second = address.indexOf('-', first + 1);
const res = address.substring(0, second);
if (res.length) {
return res;
}
const dotIndex = address.indexOf('.');
return dotIndex === -1 ? address : address.substring(0, dotIndex);
return calcShortNameByRegExp(address) || calcShortNameByMinus(address);
}, [address]);

const cluster = useSelector(getCluster);

return (
<span className={block({hidden: !host}, className)}>
<span
className={block(
{hidden: !host},
['elements-monospace', className].filter(Boolean).join(' '),
)}
onClick={onClick}
>
{prefix}
<Tooltip content={address}>
{asText ? (
{useText ? (
host
) : (
<Link url={`/${cluster}/components/nodes/${address}`}>{host}</Link>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -61,7 +61,7 @@ export function NodeMaintenanceModal() {
headerProps={{
title: (
<>
<Host asText prefix={<>Edit &nbsp;</>} address={address} />
<Host useText prefix={<>Edit &nbsp;</>} address={address} />
</>
),
}}
Expand Down
14 changes: 11 additions & 3 deletions packages/ui/src/ui/pages/components/tabs/Versions/VersionsV2.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -47,6 +47,7 @@ import {getUISizes} from '../../../../store/selectors/global';
import templates, {ColumnAsTime, printColumnAsError} from '../../../../components/templates/utils';
import {VersionHostInfo} from '../../../../store/reducers/components/versions/versions_v2';
import {ClickableId, NodeColumnBanned, NodeColumnState} from '../NodeColumns';
import {Host} from '../../../../containers/Host/Host';

import './Versions.scss';

Expand Down Expand Up @@ -194,9 +195,16 @@ class VersionsV2 extends React.Component<ReduxProps> {
/>
),
error: (item) => printColumnAsError(item.error),
address: (item) => (
<ClickableId text={item.address} onClick={() => changeHostFilter(item.address)} />
),
address: (item) => {
return (
<Host
address={item.address}
onClick={() => changeHostFilter(item.address)}
useText
allowByRegexp
/>
);
},
state: (item) => <NodeColumnState state={item.state} />,
banned: (item) => <NodeColumnBanned banned={item.banned} />,
decommissioned: templates.get('components').decommissioned,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -238,7 +238,7 @@ $elements-table: '.elements-table';
}

&_host {
width: 400px;
width: 350px;
}
}
}
Expand Down
21 changes: 3 additions & 18 deletions packages/ui/src/ui/utils/components/nodes/tables.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@ import StatusBlock from '../../../components/StatusBlock/StatusBlock';
import ClipboardButton from '../../../components/ClipboardButton/ClipboardButton';
import NodeActions from '../../../pages/components/tabs/nodes/NodeActions/NodeActions';
import MemoryProgress from '../../../pages/components/tabs/nodes/MemoryProgress/MemoryProgress';
import {Host} from '../../../containers/Host/Host';

import hammer from '../../../common/hammer';
import {
Expand Down Expand Up @@ -688,24 +689,8 @@ export const NODES_TABLE_TEMPLATES: Templates = {
return hammer.format['Number'](item.IOWeight[mediumName]);
}
},
host(item, columnName) {
return (
<div
className="elements-column_type_id elements-column_with-hover-button"
title={item.host}
>
<span className="elements-monospace elements-ellipsis">
{hammer.format['Address'](item.host)}
</span>
&nbsp;
<ClipboardButton
text={item.host}
view="flat-secondary"
size="s"
title={'Copy ' + columnName}
/>
</div>
);
host(item) {
return <Host address={item.host} useText allowByRegexp />;
},
state(item) {
return <NodeColumnState state={item.state} />;
Expand Down

0 comments on commit 071b0ea

Please sign in to comment.