mirror of
https://github.com/yude-jp/yude.jp
synced 2025-10-16 21:28:38 +09:00
Compare commits
38 Commits
5a0e87d7d4
...
dependabot
Author | SHA1 | Date | |
---|---|---|---|
![]() |
8e1e6a6b4e | ||
79246ee600 | |||
98ad910a9b | |||
fc90f87285 | |||
b07d6412ff | |||
![]() |
6d6365c240 | ||
![]() |
1dd86ac2c8 | ||
![]() |
496fe5ee4b | ||
![]() |
cdcce3a39b | ||
7f3a8f8230 | |||
![]() |
fae52872f1 | ||
1c8bf364dd | |||
![]() |
ef653ed749 | ||
8deac1fede | |||
3fb52ddcfa | |||
![]() |
a36785dded | ||
c60270c1c6
|
|||
1b7319617b
|
|||
![]() |
aa6f4417e7 | ||
ae6c8aa9c9
|
|||
9389cc55f7
|
|||
ba0e41579a
|
|||
b35caef45c
|
|||
7ac1c7199f
|
|||
f697eb9b85
|
|||
16bb6398e4
|
|||
02b1adcf55
|
|||
34e335037c
|
|||
0cb27e3cda
|
|||
92459e594f
|
|||
c30312a46a
|
|||
5531b3a3bf
|
|||
f0cf3729a0
|
|||
ec530601b4
|
|||
30547e3b81
|
|||
2529afa286 | |||
b62f95d483
|
|||
2bd3b69da1
|
@@ -3,7 +3,7 @@
|
||||
<img alt="Next JS" src="https://img.shields.io/badge/nextjs-%23000000.svg?style=for-the-badge&logo=next.js&logoColor=white"/>
|
||||
<img alt="TailwindCSS" src="https://img.shields.io/badge/tailwindcss-%2338B2AC.svg?style=for-the-badge&logo=tailwind-css&logoColor=white"/>\
|
||||
Source code of [yude.jp](https://yude.jp).\
|
||||
Built with [Next.js](https://nextjs.org/) and [Tailwind CSS](https://tailwindcss.com/) and deployed on [Vercel](https://vercel.com).
|
||||
Built with [Next.js](https://nextjs.org/) and [Tailwind CSS](https://tailwindcss.com/) and deployed to [Cloudflare Pages](https://pages.cloudflare.com/).
|
||||
|
||||
## Development
|
||||
1. Run `yarn` to install dependencies.
|
||||
|
23
docs/services/en.md
Normal file
23
docs/services/en.md
Normal file
@@ -0,0 +1,23 @@
|
||||
# Available services on yude.jp
|
||||
|
||||
## Softwares
|
||||
* [AutoMuteUs](https://github.com/denverquane/automuteus)\
|
||||
Among Us helper; API: [`galactus.yude.jp`](https://galactus.yude.jp)
|
||||
* [Nextcloud](https://nc.yude.jp)
|
||||
* [Mastodon](https://mstdn.yude.jp)
|
||||
* [Misskey](https://misskey.yude.jp)
|
||||
* [Pleroma](https//pleroma.yude.jp)
|
||||
* TeamSpeak 3: `yude.jp`
|
||||
* [Gitea](https://git.yude.jp)
|
||||
* [h5ai](https://files.yude.jp)
|
||||
* [JMusicBot (forked)](https://discord.com/oauth2/authorize?client_id=429638220456656896&scope=bot&permissions=338963472)
|
||||
* [Owncast](https://live.yude.jp)
|
||||
* [Minecraft Server](https://yude.jp/minecraft)
|
||||
|
||||
## Anonymous communication
|
||||
### Tor
|
||||
* Relay: [yudejp](https://metrics.torproject.org/rs.html#details/CF762EF3C86B104C301511894547C72371F952A4)
|
||||
* Hidden Service: [yude3mzscyufx5u3zup72ium7tgecy3bd67p7t6vqhaywvr7e2gqpcqd.onion](http://yude3mzscyufx5u3zup72ium7tgecy3bd67p7t6vqhaywvr7e2gqpcqd.onion)
|
||||
|
||||
### I2P
|
||||
* Hidden Service: [yudejp.i2p/?i2paddresshelper=55ivoba6mo3mqlwvw5lqz7lchxqew2kh77kwkn5shefrj2dp3coq.b32.i2p](http://yudejp.i2p/?i2paddresshelper=55ivoba6mo3mqlwvw5lqz7lchxqew2kh77kwkn5shefrj2dp3coq.b32.i2p)
|
23
docs/services/ja.md
Normal file
23
docs/services/ja.md
Normal file
@@ -0,0 +1,23 @@
|
||||
# yude.jp で運用中のサービス
|
||||
|
||||
## ソフトウェア
|
||||
* [AutoMuteUs](https://github.com/denverquane/automuteus)\
|
||||
Among Us の自動ミュートボット; API: [`galactus.yude.jp`](https://galactus.yude.jp)
|
||||
* [Nextcloud](https://nc.yude.jp)
|
||||
* [Mastodon](https://mstdn.yude.jp)
|
||||
* [Misskey](https://misskey.yude.jp)
|
||||
* [Pleroma](https//pleroma.yude.jp)
|
||||
* TeamSpeak 3: `yude.jp`
|
||||
* [Gitea](https://git.yude.jp)
|
||||
* [h5ai](https://files.yude.jp)
|
||||
* [JMusicBot (フォーク)](https://discord.com/oauth2/authorize?client_id=429638220456656896&scope=bot&permissions=338963472)
|
||||
* [Owncast](https://live.yude.jp)
|
||||
* [Minecraft サーバー](https://yude.jp/minecraft)
|
||||
|
||||
## 秘匿化ネットワーク
|
||||
### Tor
|
||||
* リレー: [yudejp](https://metrics.torproject.org/rs.html#details/CF762EF3C86B104C301511894547C72371F952A4)
|
||||
* Hidden Service: [yude3mzscyufx5u3zup72ium7tgecy3bd67p7t6vqhaywvr7e2gqpcqd.onion](http://yude3mzscyufx5u3zup72ium7tgecy3bd67p7t6vqhaywvr7e2gqpcqd.onion)
|
||||
|
||||
### I2P
|
||||
* Hidden Service: [yudejp.i2p/?i2paddresshelper=55ivoba6mo3mqlwvw5lqz7lchxqew2kh77kwkn5shefrj2dp3coq.b32.i2p](http://yudejp.i2p/?i2paddresshelper=55ivoba6mo3mqlwvw5lqz7lchxqew2kh77kwkn5shefrj2dp3coq.b32.i2p)
|
@@ -60,5 +60,8 @@
|
||||
"service": "Service",
|
||||
"shape": "Shape",
|
||||
"tos": "yude.jp Terms of Service",
|
||||
"input": "en"
|
||||
"input": "en",
|
||||
"services": "Services",
|
||||
"contents": "Contents",
|
||||
"Blog": "Weblog"
|
||||
}
|
@@ -60,5 +60,8 @@
|
||||
"service": "サービス",
|
||||
"shape": "シェイプ",
|
||||
"tos": "yude.jp サービス利用規約",
|
||||
"input": "ja"
|
||||
"input": "ja",
|
||||
"services": "サービス",
|
||||
"contents": "コンテンツ",
|
||||
"blog": "ブログ"
|
||||
}
|
@@ -31,8 +31,8 @@
|
||||
"autoprefixer": "^10.3.4",
|
||||
"axios": "^0.21.4",
|
||||
"date-fns": "^2.24.0",
|
||||
"moment": "^2.29.1",
|
||||
"next": "^11.1.3",
|
||||
"moment": "^2.29.4",
|
||||
"next": "^12.1.0",
|
||||
"next-export-i18n": "^1.2.1",
|
||||
"next-seo": "^4.28.1",
|
||||
"next-themes": "^0.0.15",
|
||||
|
@@ -31,7 +31,7 @@ const Dropdown = ({ color }) => {
|
||||
<>
|
||||
|
||||
<div className="text-left mr-2 ml-2 my-3 float-right">
|
||||
<button type="button" className="inline-flex justify-center w-full rounded-md border border-gray-300 dark:border-gray-800 shadow-sm px-2 bg-white text-sm font-medium text-gray-700 hover:bg-gray-50 dark:bg-gray-700 dark:text-white focus:outline-none" id="options-menu" aria-haspopup="true" aria-expanded="true"
|
||||
<button type="button" className="inline-flex justify-center rounded-md border border-gray-300 dark:border-gray-800 shadow-sm px-2 bg-white text-sm font-medium text-gray-700 hover:bg-gray-50 dark:bg-gray-700 dark:text-white focus:outline-none h-10" id="options-menu" aria-haspopup="true" aria-expanded="true"
|
||||
style={{ transition: "all .15s ease" }}
|
||||
ref={btnDropdownRef}
|
||||
onClick={() => {
|
||||
@@ -40,19 +40,19 @@ const Dropdown = ({ color }) => {
|
||||
: openDropdownPopover();
|
||||
}}
|
||||
>
|
||||
<FontAwesomeIcon icon={faLanguage} className="text-4xl" />
|
||||
<FontAwesomeIcon icon={faLanguage} size="3x" />
|
||||
<svg className="-mr-1 ml-2 h-9 w-3" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20" fill="currentColor" aria-hidden="true">
|
||||
<path fillRule="evenodd" d="M5.293 7.293a1 1 0 011.414 0L10 10.586l3.293-3.293a1 1 0 111.414 1.414l-4 4a1 1 0 01-1.414 0l-4-4a1 1 0 010-1.414z" clipRule="evenodd" />
|
||||
</svg>
|
||||
</button>
|
||||
<div ref={popoverDropdownRef} className={
|
||||
(dropdownPopoverShow ? "block " : "hidden ") + "z-10 origin-top-right absolute right-0 mt-2 w-40 rounded-md shadow-lg bg-white ring-1 ring-black ring-opacity-5 dark:bg-gray-700"}>
|
||||
(dropdownPopoverShow ? "block " : "hidden ") + "z-10 origin-top-right absolute right-0 mt-2 rounded-md shadow-lg bg-white ring-1 ring-black ring-opacity-5 dark:bg-gray-700"}>
|
||||
<div className="py-1" role="menu" aria-orientation="vertical" aria-labelledby="options-menu">
|
||||
<LanguageSwitcher lang="ja">
|
||||
<a href="#" className="block px-4 py-2 text-sm text-gray-700 hover:bg-gray-100 hover:text-gray-700 dark:text-white dark:hover:bg-gray-800" role="menuitem">日本語</a>
|
||||
<a href="#" className="block px-4 py-2 text-gray-700 hover:bg-gray-100 hover:text-gray-700 dark:text-white dark:hover:bg-gray-800" role="menuitem">日本語</a>
|
||||
</LanguageSwitcher>
|
||||
<LanguageSwitcher lang="en">
|
||||
<a href="#" className="block px-4 py-2 text-sm text-gray-700 hover:bg-gray-100 hover:text-gray-700 dark:text-white dark:hover:bg-gray-800" role="menuitem">English</a>
|
||||
<a href="#" className="block px-4 py-2 text-gray-700 hover:bg-gray-100 hover:text-gray-700 dark:text-white dark:hover:bg-gray-800" role="menuitem">English</a>
|
||||
</LanguageSwitcher>
|
||||
</div>
|
||||
</div>
|
||||
|
@@ -11,7 +11,7 @@ const FontAwesomeMenu = (props) => {
|
||||
<div>
|
||||
<Link href={{ pathname: dest, query: query }}>
|
||||
<a>
|
||||
<FontAwesomeIcon icon={icon} className="text-4xl fill-current inline transition duration-200 ease-in-out transform hover:-translate-y-1 hover:scale-110" />
|
||||
<FontAwesomeIcon icon={icon} size="5x" className="w-9 h-9 fill-current inline transition duration-200 ease-in-out transform hover:-translate-y-1 hover:scale-110" />
|
||||
</a>
|
||||
</Link>
|
||||
</div>
|
||||
|
@@ -10,7 +10,7 @@ const Button = (props) => {
|
||||
<Link href={{ pathname: dest }}>
|
||||
<a>
|
||||
<button
|
||||
className="bg-pink-600 text-white active:bg-pink-600 mt-3 font-bold text-sm px-6 py-3 rounded shadow hover:shadow-lg outline-none focus:outline-none mr-1 mb-1 ease-linear transition-all duration-150"
|
||||
className="bg-pink-600 text-white active:bg-pink-600 mt-3 font-bold text-sm px-6 py-3 rounded shadow hover:shadow-lg outline-none focus:outline-none mr-1 mb-1 ease-linear transition-all duration-150"
|
||||
type="button"
|
||||
>
|
||||
<FontAwesomeIcon icon={icon} className="w-5 h-5 inline"/> {caption}
|
||||
|
@@ -10,7 +10,7 @@ const Contact = (props) => {
|
||||
<div className="hover:underline">
|
||||
<Link href={{ pathname: dest }}>
|
||||
<a>
|
||||
<FontAwesomeIcon icon={icon} className="w-7 h-7 inline lg:w-10 lg:h-10 md:w-7 md:h-7"/>
|
||||
<FontAwesomeIcon icon={icon} size="5x" className="w-9 h-9 fill-current inline transition duration-200 ease-in-out transform hover:-translate-y-1 hover:scale-110" />
|
||||
<p className="font-mono text-xl">{caption}</p>
|
||||
</a>
|
||||
</Link>
|
||||
|
@@ -1,12 +1,16 @@
|
||||
// React
|
||||
import React, { useState, useEffect } from 'react';
|
||||
import React from 'react';
|
||||
|
||||
// Font Awesome
|
||||
import { faUserClock } from '@fortawesome/free-solid-svg-icons'
|
||||
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome'
|
||||
|
||||
// i18n
|
||||
import { useTranslation } from 'next-export-i18n';
|
||||
|
||||
export default function Modal() {
|
||||
const [showModal, setShowModal] = React.useState(false);
|
||||
const { t } = useTranslation();
|
||||
|
||||
return (
|
||||
<>
|
||||
@@ -36,7 +40,7 @@ export default function Modal() {
|
||||
type="button"
|
||||
onClick={() => setShowModal(false)}
|
||||
>
|
||||
{close}
|
||||
{t('close')}
|
||||
</button>
|
||||
</div>
|
||||
</div>
|
||||
|
@@ -18,7 +18,7 @@ import MinecraftMenu from "./components/Menu/MinecraftMenu"
|
||||
|
||||
// Font Awesome
|
||||
import { faDiscord, faGit, faGithub } from '@fortawesome/free-brands-svg-icons'
|
||||
import { faBook, faUser, faServer, faHouseUser, faHeart } from '@fortawesome/free-solid-svg-icons'
|
||||
import { faBook, faUser, faServer, faScrewdriver, faHeart } from '@fortawesome/free-solid-svg-icons'
|
||||
|
||||
export default function Index(props) {
|
||||
const { t } = useTranslation();
|
||||
@@ -45,11 +45,10 @@ export default function Index(props) {
|
||||
<div className="grid grid-cols-3 gap-10">
|
||||
<FAMenu dest="/profile" query={query} icon={faUser} />
|
||||
<FAMenu dest="/server" query={query} icon={faServer} />
|
||||
<FAMenu dest="/house" query={query} icon={faHouseUser} />
|
||||
<FAMenu dest="https://scrapbox.io/yude" query={query} icon={faBook} />
|
||||
<FAMenu dest="https://discord.gg/X6srY7X" query={query} icon={faDiscord} />
|
||||
<FAMenu dest="https://github.com/yudejp" query={query} icon={faGithub} />
|
||||
<FAMenu dest="https://git.yude.jp" icon={faGit} query={query} />
|
||||
<FAMenu dest="/services" query={query} icon={faScrewdriver} />
|
||||
<FAMenu dest="https://discord.gg/X6srY7X" icon={faDiscord} />
|
||||
<FAMenu dest="https://github.com/yudejp" icon={faGithub} />
|
||||
<FAMenu dest="https://git.yude.jp" icon={faGit} />
|
||||
<MinecraftMenu query={query} />
|
||||
<FAMenu dest="/mutual" icon={faHeart} query={query} />
|
||||
</div>
|
||||
|
@@ -71,7 +71,7 @@ export default function About(props) {
|
||||
</button>
|
||||
</p>
|
||||
|
||||
<p>{t('version')}: 1.17</p>
|
||||
<p>{t('version')}: 1.18.1</p>
|
||||
|
||||
<Link href="https://bluemap.yude.jp">
|
||||
<a>
|
||||
|
@@ -30,7 +30,7 @@ export default function Tos(props) {
|
||||
title="相互リンク"
|
||||
description="yude.jp と相互にリンクを貼っている Web サイトの一覧"
|
||||
/>
|
||||
<Layout title={t('common:mutual')}>
|
||||
<Layout title={t('mutual')}>
|
||||
<div>
|
||||
{query["lang"] === 'ja' ? (
|
||||
<ReactMarkdown plugins={[gfm]}>
|
||||
|
@@ -6,7 +6,7 @@ import { useTranslation, useLanguageQuery } from 'next-export-i18n';
|
||||
|
||||
// Font Awesome
|
||||
import { faDiscord, faTwitter, faGithub, faKeybase, faInstagram, faMastodon, faSteam, faAmazon } from '@fortawesome/free-brands-svg-icons'
|
||||
import { faEnvelope, faBirthdayCake, faMapPin, faSchool, faPhone, faInfo, faLink, faMobile } from '@fortawesome/free-solid-svg-icons'
|
||||
import { faEnvelope, faBirthdayCake, faMapPin, faSchool, faPhone, faBlog, faBookDead, faInfo, faBookmark, faLink, faMobile } from '@fortawesome/free-solid-svg-icons'
|
||||
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome'
|
||||
|
||||
// Next.js, React
|
||||
@@ -86,6 +86,19 @@ export default function Profile(props) {
|
||||
<p className="ml-9">{t('hiroshima')}</p>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
{
|
||||
// Contents
|
||||
}
|
||||
<div>
|
||||
<div className="text-left">
|
||||
<p className="text-2xl"><FontAwesomeIcon icon={faBookDead} className="w-5 h-5 inline"/> {t('contents')}</p>
|
||||
</div>
|
||||
<div className="my-2 grid grid-cols-2 lg:grid-cols-5 md:grid-cols-3 sm:grid-cols-2justify-items-center gap-y-6">
|
||||
<Contact dest="https://blog.yude.jp" icon={faBlog} caption={t('blog')} />
|
||||
<Contact dest="https://scrapbox.io/yude" icon={faBookmark} caption="Scrapbox" />
|
||||
</div>
|
||||
</div>
|
||||
|
||||
{
|
||||
// Contact
|
||||
|
@@ -37,7 +37,7 @@ export default function Server(props) {
|
||||
<div className="flex-1"><p className="font-bold">OS </p>Arch Linux</div>
|
||||
<div className="flex-1"><p className="font-bold">{t('location')} </p>{t('hiroshima')}</div>
|
||||
</div>
|
||||
<iframe className="w-full h-96" src="https://mackerel.io/embed/public/embed/heHnGhDanoIDlf7jjxUe9yPVrsG3deeH5ptD8suErrq5w46crWEIYdLfzLoukzfF?period=24h" height="400" frameBorder="0" scrolling="no"></iframe>
|
||||
<a href="https://mackerel.io/orgs/yude/hosts/4dkbQuMQjvo/-/graphs/loadavg#period=10m"><img src="https://mackerel.io/embed/public/embed/heHnGhDanoIDlf7jjxUe9yPVrsG3deeH5ptD8suErrq5w46crWEIYdLfzLoukzfF.png?period=10m" className="w-full" /></a>
|
||||
|
||||
|
||||
{
|
||||
@@ -51,7 +51,7 @@ export default function Server(props) {
|
||||
<div className="flex-1"><p className="font-bold">OS </p>Ubuntu 20.04 LTS</div>
|
||||
<div className="flex-1"><p className="font-bold">{t('region')} </p>Japan Central (Osaka)</div>
|
||||
</div>
|
||||
<iframe className="w-full h-96" src="https://mackerel.io/embed/public/embed/vcn6LE4P2hh6GzvtMbIAWxsXpDh6eSoNyAXdhfYaj9yDN6FJwOHIiz9ktqToj1HG?period=24h" height="400" frameBorder="0" scrolling="no"></iframe>
|
||||
<a href="https://mackerel.io/orgs/yude/hosts/4ftHfeojMCU/-/graphs/loadavg#period=10m"><img src="https://mackerel.io/embed/public/embed/vcn6LE4P2hh6GzvtMbIAWxsXpDh6eSoNyAXdhfYaj9yDN6FJwOHIiz9ktqToj1HG.png?period=10m" className="w-full" /></a>
|
||||
|
||||
{
|
||||
// oracle2
|
||||
@@ -64,7 +64,20 @@ export default function Server(props) {
|
||||
<div className="flex-1"><p className="font-bold">OS </p>Ubuntu 20.04 LTS</div>
|
||||
<div className="flex-1"><p className="font-bold">{t('region')} </p>Japan Central (Osaka)</div>
|
||||
</div>
|
||||
<iframe className="w-full h-96" src="https://mackerel.io/embed/public/embed/wgmTz7aTgvwfyU6qVHrJJmQlpOHCUJK6qw0W9sJTX68WOI8TFtc27YvJ7dwkQEGv?period=24h" height="400" frameBorder="0" scrolling="no"></iframe>
|
||||
<a href="https://mackerel.io/orgs/yude/hosts/4frgQ1QuivJ/-/graphs/loadavg#period=10m"><img src="https://mackerel.io/embed/public/embed/wgmTz7aTgvwfyU6qVHrJJmQlpOHCUJK6qw0W9sJTX68WOI8TFtc27YvJ7dwkQEGv.png?period=10m" className="w-full" /></a>
|
||||
|
||||
{
|
||||
// oracle-a1-1
|
||||
}
|
||||
<h2 className="text-2xl text-left font-bold leading-7 sm:text-3xl sm:truncate">oracle-a1-1</h2>
|
||||
<div className="flex xl:w-2/3 text-center">
|
||||
<div className="flex-1"><p className="font-bold">{t('service')} </p>Oracle Cloud</div>
|
||||
<div className="flex-1"><p className="font-bold">{t('shape')} </p>VM.Standard.A1.Flex</div>
|
||||
<div className="flex-1"><p className="font-bold">RAM </p>6GB</div>
|
||||
<div className="flex-1"><p className="font-bold">OS </p>Ubuntu 20.04.3 LTS</div>
|
||||
<div className="flex-1"><p className="font-bold">{t('region')} </p>Japan Central (Osaka)</div>
|
||||
</div>
|
||||
<a href="https://mackerel.io/orgs/yude/hosts/4qzeqT6kToQ/-/graphs/loadavg#period=10m"><img src="https://mackerel.io/embed/public/embed/2C7NdtqLgGFGPiO2IctDGuaMdjBwhXyp0i8imkaJT2GFI55syPaxxACEYIRWDHnS.png?period=10m" className="w-full" /></a>
|
||||
|
||||
</div>
|
||||
</Layout>
|
||||
|
49
pages/services.js
Normal file
49
pages/services.js
Normal file
@@ -0,0 +1,49 @@
|
||||
// Base layout
|
||||
import Layout from "./components/Layout"
|
||||
|
||||
// i18n
|
||||
import { useTranslation, useLanguageQuery, LanguageSwitcher } from 'next-export-i18n';
|
||||
|
||||
// React Router etc.
|
||||
import { useRouter } from 'next/router'
|
||||
import React from "react"
|
||||
|
||||
// React Markdown
|
||||
import ReactMarkdown from "react-markdown"
|
||||
import gfm from 'remark-gfm';
|
||||
import ja from '../docs/services/ja.md'
|
||||
import en from '../docs/services/en.md'
|
||||
|
||||
// next-seo
|
||||
import { NextSeo } from 'next-seo';
|
||||
|
||||
export default function Tos(props) {
|
||||
const { t } = useTranslation();
|
||||
const [query] = useLanguageQuery();
|
||||
|
||||
if (!query) {
|
||||
return <p>Loading...</p>
|
||||
} else {
|
||||
return(
|
||||
<>
|
||||
<NextSeo
|
||||
title="サービス"
|
||||
description="yude.jp で運用中のサービス"
|
||||
/>
|
||||
<Layout title={t('services')}>
|
||||
<div>
|
||||
{query["lang"] === 'ja' ? (
|
||||
<ReactMarkdown plugins={[gfm]}>
|
||||
{ja}
|
||||
</ReactMarkdown>
|
||||
) : (
|
||||
<ReactMarkdown plugins={[gfm]}>
|
||||
{en}
|
||||
</ReactMarkdown>
|
||||
)}
|
||||
</div>
|
||||
</Layout>
|
||||
</>
|
||||
)
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user