200 lines
9.8 KiB
TypeScript
200 lines
9.8 KiB
TypeScript
import {
|
|
ArticleIcon,
|
|
BellIcon,
|
|
GroupFeedsIcon,
|
|
HashtagIcon,
|
|
MediaIcon,
|
|
PlusIcon,
|
|
TrendingIcon,
|
|
} from '@shared/icons';
|
|
import { TitleBar } from '@shared/titleBar';
|
|
import { WidgetWrapper } from '@shared/widgets';
|
|
|
|
import { TOPICS, WIDGET_KIND } from '@stores/constants';
|
|
|
|
import { useWidget } from '@utils/hooks/useWidget';
|
|
import { Widget } from '@utils/types';
|
|
|
|
export function WidgetList({ widget }: { widget: Widget }) {
|
|
const { replaceWidget } = useWidget();
|
|
|
|
return (
|
|
<WidgetWrapper>
|
|
<TitleBar id={widget.id} title="Add widgets" />
|
|
<div className="flex-1 overflow-y-auto pb-10 scrollbar-none">
|
|
<div className="flex flex-col gap-6 px-3">
|
|
<div className="rounded-xl bg-neutral-100 p-3 dark:bg-neutral-900">
|
|
<h3 className="mb-2.5 text-sm font-semibold uppercase text-neutral-700 dark:text-neutral-300">
|
|
Topics
|
|
</h3>
|
|
<div className="flex flex-col gap-3">
|
|
{TOPICS.sort((a, b) => a.title.localeCompare(b.title)).map(
|
|
(topic, index) => (
|
|
<div
|
|
key={index}
|
|
className="inline-flex h-14 w-full items-center justify-between rounded-lg bg-white px-3 hover:shadow-md hover:shadow-neutral-200/50 dark:hover:shadow-neutral-800/50"
|
|
>
|
|
<div className="inline-flex items-center gap-2.5">
|
|
<div className="h-9 w-9 shrink-0 rounded-md">
|
|
<img
|
|
src={`/${topic.title.toLowerCase()}.jpg`}
|
|
alt={topic.title}
|
|
className="h-9 w-9 rounded-md"
|
|
/>
|
|
</div>
|
|
<p className="font-medium">{topic.title}</p>
|
|
</div>
|
|
<button
|
|
type="button"
|
|
onClick={() =>
|
|
replaceWidget.mutate({
|
|
currentId: widget.id,
|
|
widget: {
|
|
kind: WIDGET_KIND.topic,
|
|
title: topic.title,
|
|
content: JSON.stringify(topic.content),
|
|
},
|
|
})
|
|
}
|
|
className="inline-flex h-6 items-center gap-1 rounded-md bg-neutral-100 pl-1.5 pr-2.5 text-sm font-medium hover:bg-blue-500 hover:text-white dark:bg-neutral-900"
|
|
>
|
|
<PlusIcon className="h-3 w-3" />
|
|
Add
|
|
</button>
|
|
</div>
|
|
)
|
|
)}
|
|
</div>
|
|
</div>
|
|
<div className="rounded-xl bg-neutral-100 p-3 dark:bg-neutral-900">
|
|
<h3 className="mb-2.5 text-sm font-semibold uppercase text-neutral-700 dark:text-neutral-300">
|
|
Newsfeed
|
|
</h3>
|
|
<div className="flex flex-col gap-3">
|
|
<div className="inline-flex h-14 w-full items-center justify-between rounded-lg bg-white px-3 hover:shadow-md hover:shadow-neutral-200/50 dark:hover:shadow-neutral-800/50">
|
|
<div className="inline-flex items-center gap-2.5">
|
|
<div className="inline-flex h-9 w-9 shrink-0 items-center justify-center rounded-md bg-neutral-100">
|
|
<ArticleIcon className="h-4 w-4" />
|
|
</div>
|
|
<p className="font-medium">Article</p>
|
|
</div>
|
|
<button
|
|
type="button"
|
|
className="inline-flex h-6 items-center gap-1 rounded-md bg-neutral-100 pl-1.5 pr-2.5 text-sm font-medium hover:bg-blue-500 hover:text-white dark:bg-neutral-900"
|
|
>
|
|
<PlusIcon className="h-3 w-3" />
|
|
Add
|
|
</button>
|
|
</div>
|
|
<div className="inline-flex h-14 w-full items-center justify-between rounded-lg bg-white px-3 hover:shadow-md hover:shadow-neutral-200/50 dark:hover:shadow-neutral-800/50">
|
|
<div className="inline-flex items-center gap-2.5">
|
|
<div className="inline-flex h-9 w-9 shrink-0 items-center justify-center rounded-md bg-neutral-100">
|
|
<MediaIcon className="h-4 w-4" />
|
|
</div>
|
|
<p className="font-medium">Media</p>
|
|
</div>
|
|
<button
|
|
type="button"
|
|
className="inline-flex h-6 items-center gap-1 rounded-md bg-neutral-100 pl-1.5 pr-2.5 text-sm font-medium hover:bg-blue-500 hover:text-white dark:bg-neutral-900"
|
|
>
|
|
<PlusIcon className="h-3 w-3" />
|
|
Add
|
|
</button>
|
|
</div>
|
|
<div className="inline-flex h-14 w-full items-center justify-between rounded-lg bg-white px-3 hover:shadow-md hover:shadow-neutral-200/50 dark:hover:shadow-neutral-800/50">
|
|
<div className="inline-flex items-center gap-2.5">
|
|
<div className="inline-flex h-9 w-9 shrink-0 items-center justify-center rounded-md bg-neutral-100">
|
|
<GroupFeedsIcon className="h-4 w-4" />
|
|
</div>
|
|
<p className="font-medium">Group feeds</p>
|
|
</div>
|
|
<button
|
|
type="button"
|
|
className="inline-flex h-6 items-center gap-1 rounded-md bg-neutral-100 pl-1.5 pr-2.5 text-sm font-medium hover:bg-blue-500 hover:text-white dark:bg-neutral-900"
|
|
>
|
|
<PlusIcon className="h-3 w-3" />
|
|
Add
|
|
</button>
|
|
</div>
|
|
<div className="inline-flex h-14 w-full items-center justify-between rounded-lg bg-white px-3 hover:shadow-md hover:shadow-neutral-200/50 dark:hover:shadow-neutral-800/50">
|
|
<div className="inline-flex items-center gap-2.5">
|
|
<div className="inline-flex h-9 w-9 shrink-0 items-center justify-center rounded-md bg-neutral-100">
|
|
<HashtagIcon className="h-4 w-4" />
|
|
</div>
|
|
<p className="font-medium">Hashtag</p>
|
|
</div>
|
|
<button
|
|
type="button"
|
|
className="inline-flex h-6 items-center gap-1 rounded-md bg-neutral-100 pl-1.5 pr-2.5 text-sm font-medium hover:bg-blue-500 hover:text-white dark:bg-neutral-900"
|
|
>
|
|
<PlusIcon className="h-3 w-3" />
|
|
Add
|
|
</button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div className="rounded-xl bg-neutral-100 p-3 dark:bg-neutral-900">
|
|
<h3 className="mb-2.5 text-sm font-semibold uppercase text-neutral-700 dark:text-neutral-300">
|
|
Nostr Band
|
|
</h3>
|
|
<div className="flex flex-col gap-3">
|
|
<div className="inline-flex h-14 w-full items-center justify-between rounded-lg bg-white px-3 hover:shadow-md hover:shadow-neutral-200/50 dark:hover:shadow-neutral-800/50">
|
|
<div className="inline-flex items-center gap-2.5">
|
|
<div className="inline-flex h-9 w-9 shrink-0 items-center justify-center rounded-md bg-neutral-100">
|
|
<TrendingIcon className="h-4 w-4" />
|
|
</div>
|
|
<p className="font-medium">Trending posts</p>
|
|
</div>
|
|
<button
|
|
type="button"
|
|
className="inline-flex h-6 items-center gap-1 rounded-md bg-neutral-100 pl-1.5 pr-2.5 text-sm font-medium hover:bg-blue-500 hover:text-white dark:bg-neutral-900"
|
|
>
|
|
<PlusIcon className="h-3 w-3" />
|
|
Add
|
|
</button>
|
|
</div>
|
|
<div className="inline-flex h-14 w-full items-center justify-between rounded-lg bg-white px-3 hover:shadow-md hover:shadow-neutral-200/50 dark:hover:shadow-neutral-800/50">
|
|
<div className="inline-flex items-center gap-2.5">
|
|
<div className="inline-flex h-9 w-9 shrink-0 items-center justify-center rounded-md bg-neutral-100">
|
|
<TrendingIcon className="h-4 w-4" />
|
|
</div>
|
|
<p className="font-medium">Trending users</p>
|
|
</div>
|
|
<button
|
|
type="button"
|
|
className="inline-flex h-6 items-center gap-1 rounded-md bg-neutral-100 pl-1.5 pr-2.5 text-sm font-medium hover:bg-blue-500 hover:text-white dark:bg-neutral-900"
|
|
>
|
|
<PlusIcon className="h-3 w-3" />
|
|
Add
|
|
</button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div className="rounded-xl bg-neutral-100 p-3 dark:bg-neutral-900">
|
|
<h3 className="mb-2.5 text-sm font-semibold uppercase text-neutral-700 dark:text-neutral-300">
|
|
Other
|
|
</h3>
|
|
<div className="flex flex-col gap-3">
|
|
<div className="inline-flex h-14 w-full items-center justify-between rounded-lg bg-white px-3 hover:shadow-md hover:shadow-neutral-200/50 dark:hover:shadow-neutral-800/50">
|
|
<div className="inline-flex items-center gap-2.5">
|
|
<div className="inline-flex h-9 w-9 shrink-0 items-center justify-center rounded-md bg-neutral-100">
|
|
<BellIcon className="h-4 w-4" />
|
|
</div>
|
|
<p className="font-medium">Notification</p>
|
|
</div>
|
|
<button
|
|
type="button"
|
|
className="inline-flex h-6 items-center gap-1 rounded-md bg-neutral-100 pl-1.5 pr-2.5 text-sm font-medium hover:bg-blue-500 hover:text-white dark:bg-neutral-900"
|
|
>
|
|
<PlusIcon className="h-3 w-3" />
|
|
Add
|
|
</button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</WidgetWrapper>
|
|
);
|
|
}
|