1
0
Fork 0
mirror of https://github.com/muerwre/vault-frontend.git synced 2025-04-26 05:16:41 +07:00

notifications: for nodes

This commit is contained in:
Fedor Katurov 2023-03-16 16:37:43 +06:00
parent 14bf5be65f
commit d9544e917b
13 changed files with 156 additions and 27 deletions

View file

@ -3,7 +3,7 @@ import React, { FC, ReactElement } from 'react';
import { Hoverable } from '~/components/common/Hoverable';
import { SubTitle } from '~/components/common/SubTitle';
import { Group } from '~/components/containers/Group';
import { NodeRelatedItem } from '~/components/node/NodeRelatedItem';
import { NodeThumbnail } from '~/components/node/NodeThumbnail';
import { INode } from '~/types';
import styles from './styles.module.scss';
@ -21,7 +21,7 @@ const NodeRelated: FC<IProps> = ({ title, items }) => {
<div className={styles.grid}>
{items.map((item) => (
<Hoverable key={item.id} className={styles.item}>
<NodeRelatedItem item={item} />
<NodeThumbnail item={item} />
</Hoverable>
))}
</div>

View file

@ -3,7 +3,7 @@ import React, { FC, memo } from 'react';
import classNames from 'classnames';
import { Group } from '~/components/containers/Group';
import cell_style from '~/components/node/NodeRelatedItem/styles.module.scss';
import cell_style from '~/components/node/NodeThumbnail/styles.module.scss';
import { Placeholder } from '~/components/placeholders/Placeholder';
import { range } from '~/utils/ramda';

View file

@ -8,13 +8,17 @@ import { Icon } from '~/components/input/Icon';
import { imagePresets } from '~/constants/urls';
import { useColorGradientFromString } from '~/hooks/color/useColorGradientFromString';
import { useGotoNode } from '~/hooks/node/useGotoNode';
import { INode } from '~/types';
import { getURL, getURLFromString } from '~/utils/dom';
import styles from './styles.module.scss';
type IProps = {
item: Partial<INode>;
type NodeThumbnailProps = {
item: {
thumbnail?: string;
title?: string;
is_promoted?: boolean;
id?: number;
};
};
type CellSize = 'small' | 'medium' | 'large';
@ -33,7 +37,7 @@ const getTitleLetters = (title?: string): string => {
: words[0].substr(0, 2).toUpperCase();
};
const NodeRelatedItem: FC<IProps> = memo(({ item }) => {
const NodeThumbnail: FC<NodeThumbnailProps> = memo(({ item }) => {
const onClick = useGotoNode(item.id);
const [is_loaded, setIsLoaded] = useState(false);
const [width, setWidth] = useState(0);
@ -118,4 +122,4 @@ const NodeRelatedItem: FC<IProps> = memo(({ item }) => {
);
});
export { NodeRelatedItem };
export { NodeThumbnail };