mirror of
https://github.com/usememos/memos.git
synced 2025-01-01 01:51:46 +08:00
chore: tweak tags style
This commit is contained in:
parent
e0977e53f7
commit
a4235bb4bf
4 changed files with 13 additions and 18 deletions
|
@ -11,10 +11,8 @@ import showRenameTagDialog from "../RenameTagDialog";
|
|||
|
||||
const TagsSection = () => {
|
||||
const t = useTranslate();
|
||||
const filterStore = useFilterStore();
|
||||
const tagStore = useTagStore();
|
||||
const memoList = useMemoList();
|
||||
const filter = filterStore.state;
|
||||
const tagAmounts = Object.entries(tagStore.getState().tagAmounts)
|
||||
.sort((a, b) => a[0].localeCompare(b[0]))
|
||||
.sort((a, b) => b[1] - a[1]);
|
||||
|
@ -55,9 +53,9 @@ const TagsSection = () => {
|
|||
</div>
|
||||
</div>
|
||||
{tagAmounts.length > 0 ? (
|
||||
<div className="w-full flex flex-row justify-start items-center relative flex-wrap gap-1">
|
||||
<div className="w-full flex flex-row justify-start items-center relative flex-wrap gap-x-2 gap-y-1">
|
||||
{tagAmounts.map(([tag, amount]) => (
|
||||
<TagContainer key={tag} tag={tag} amount={amount} tagQuery={filter.tag} />
|
||||
<TagContainer key={tag} tag={tag} amount={amount} />
|
||||
))}
|
||||
</div>
|
||||
) : (
|
||||
|
@ -73,18 +71,16 @@ const TagsSection = () => {
|
|||
interface TagContainerProps {
|
||||
tag: string;
|
||||
amount: number;
|
||||
tagQuery?: string;
|
||||
}
|
||||
|
||||
const TagContainer: React.FC<TagContainerProps> = (props: TagContainerProps) => {
|
||||
const t = useTranslate();
|
||||
const filterStore = useFilterStore();
|
||||
const tagStore = useTagStore();
|
||||
const { tag, amount, tagQuery } = props;
|
||||
const isActive = tagQuery === tag;
|
||||
const { tag, amount } = props;
|
||||
|
||||
const handleTagClick = () => {
|
||||
if (isActive) {
|
||||
if (filterStore.getState().tag === tag) {
|
||||
filterStore.setTagFilter(undefined);
|
||||
} else {
|
||||
filterStore.setTagFilter(tag);
|
||||
|
@ -106,14 +102,12 @@ const TagContainer: React.FC<TagContainerProps> = (props: TagContainerProps) =>
|
|||
|
||||
return (
|
||||
<div
|
||||
className={`shrink-0 w-auto max-w-full border text-sm rounded-md leading-6 flex flex-row justify-start items-center select-none hover:shadow-sm dark:hover:opacity-80 text-gray-600 dark:text-gray-400 dark:border-zinc-800 ${
|
||||
isActive && "bg-blue-50 dark:bg-zinc-800"
|
||||
}`}
|
||||
className={`shrink-0 w-auto max-w-full text-sm rounded-md leading-6 flex flex-row justify-start items-center select-none hover:opacity-80 text-gray-600 dark:text-gray-400 dark:border-zinc-800`}
|
||||
>
|
||||
<Dropdown>
|
||||
<MenuButton slots={{ root: "div" }}>
|
||||
<div className="shrink-0 group ml-1">
|
||||
<Icon.Hash className="group-hover:hidden w-4 h-auto shrink-0 opacity-60" />
|
||||
<div className="shrink-0 group">
|
||||
<Icon.Hash className="group-hover:hidden w-4 h-auto shrink-0 opacity-40" />
|
||||
<Icon.MoreVertical className="hidden group-hover:block w-4 h-auto shrink-0 opacity-60" />
|
||||
</div>
|
||||
</MenuButton>
|
||||
|
@ -128,9 +122,9 @@ const TagContainer: React.FC<TagContainerProps> = (props: TagContainerProps) =>
|
|||
</MenuItem>
|
||||
</Menu>
|
||||
</Dropdown>
|
||||
<div className="inline-flex flex-nowrap pl-0.5 pr-1 gap-1 cursor-pointer max-w-[calc(100%-20px)]" onClick={handleTagClick}>
|
||||
<span className="truncate">{tag}</span>
|
||||
<span className="opacity-60 shrink-0">({amount})</span>
|
||||
<div className="inline-flex flex-nowrap ml-0.5 gap-0.5 cursor-pointer max-w-[calc(100%-16px)]" onClick={handleTagClick}>
|
||||
<span className="truncate dark:opacity-80">{tag}</span>
|
||||
{amount > 1 && <span className="opacity-60 shrink-0">({amount})</span>}
|
||||
</div>
|
||||
</div>
|
||||
);
|
||||
|
|
|
@ -57,7 +57,7 @@ const UserStatisticsView = (props: Props) => {
|
|||
</div>
|
||||
<div className="w-full flex justify-between items-center">
|
||||
<div className="w-full flex justify-start items-center">
|
||||
<Icon.Hash className="w-4 h-auto mr-1" />
|
||||
<Icon.Tags className="w-4 h-auto mr-1" />
|
||||
<span className="block text-base sm:text-sm">{t("common.tags")}</span>
|
||||
</div>
|
||||
<span className="font-mono">{tags}</span>
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
.dialog-wrapper {
|
||||
@apply fixed top-0 left-0 flex flex-col justify-start items-center w-full h-full pt-16 pb-8 px-4 z-1000 overflow-x-hidden overflow-y-scroll bg-transparent transition-all hide-scrollbar bg-black bg-opacity-60;
|
||||
@apply fixed top-0 left-0 flex flex-col justify-start items-center w-full h-full pt-16 pb-8 px-4 z-2000 overflow-x-hidden overflow-y-scroll bg-transparent transition-all hide-scrollbar bg-black bg-opacity-60;
|
||||
|
||||
> .dialog-container {
|
||||
@apply max-w-full shadow flex flex-col justify-start items-start bg-white dark:bg-zinc-800 dark:text-gray-300 p-4 rounded-lg;
|
||||
|
|
|
@ -28,6 +28,7 @@ module.exports = {
|
|||
20: "20",
|
||||
100: "100",
|
||||
1000: "1000",
|
||||
2000: "2000",
|
||||
},
|
||||
gridTemplateRows: {
|
||||
7: "repeat(7, minmax(0, 1fr))",
|
||||
|
|
Loading…
Reference in a new issue