Compare commits
	
		
			42 Commits
		
	
	
		
			0a6341f2df
			...
			release
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| b20e9d6271 | |||
| 97fdedc6ac | |||
| 291e83d732 | |||
| e94bf01439 | |||
| 7da9e16b63 | |||
|   | 8f58012cdb | ||
| 0d21be23a1 | |||
| 8b4bce6251 | |||
| 13601e4f28 | |||
| e2fd1f603c | |||
| 12052f7aba | |||
| 157da46a07 | |||
| 998fe67c15 | |||
| 6e065045ad | |||
| 0eecba7c88 | |||
| 518a2bc6ef | |||
| 2b18f5f759 | |||
| 32f41aae32 | |||
| 50ee7f1bb6 | |||
| 870b970e00 | |||
| 20b4f9b122 | |||
| 65d075fb76 | |||
| b73c38a531 | |||
| 2921bbeca1 | |||
| 81b9b82028 | |||
| 1bd8eab491 | |||
| 5009e95433 | |||
|   | 8f8fdacbfd | ||
| c00d4f60a9 | |||
| 09184f93df | |||
| fb1d20dd96 | |||
| c14961d1d2 | |||
| e7fb45a544 | |||
| f107f658c9 | |||
| 35f1a49162 | |||
| 78615ee324 | |||
| 52bedbd4c6 | |||
| 89ca9e55ed | |||
|   | 0a3c9daac4 | ||
| c98b17938f | |||
| 72b2043164 | |||
| e2fe3cd998 | 
							
								
								
									
										29
									
								
								docs/minecraft/en.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,29 @@ | |||||||
|  | # Rules | ||||||
|  | The following applies in addition to [yude.jp Terms of Service](https://yude.jp/tos): | ||||||
|  | * You can build your house / facility / etc. anywhere in the world. | ||||||
|  | * Don't troll. | ||||||
|  | * Don't cheat. | ||||||
|  |  | ||||||
|  | # List of available commands | ||||||
|  | * `/ll`: Switch the visibility of spawn checker. | ||||||
|  | * `/mvspawn`: Teleport to spawn point of the world you're in. | ||||||
|  |  | ||||||
|  | # Convenient functionalities | ||||||
|  | ## Bulk destruction | ||||||
|  | You can destroy wood logs and ore blocks at once by destroying with sneaking.\ | ||||||
|  | ## Block protection | ||||||
|  | You can protect your chests, doors, furnaces, etc. by pasting sign like the image below.\ | ||||||
|  | You can also create a shared block by writing the player ID across multiple lines. \ | ||||||
|  |  | ||||||
|  | ## Skills | ||||||
|  | You can use skills powered by mcMMO. | ||||||
|  |  | ||||||
|  | # Facility introduction | ||||||
|  | ## Shrine (by shirachan_1204) | ||||||
|  |  | ||||||
|  | ## Iron Golem Trap (by yude & kuwazi_) | ||||||
|  |  | ||||||
|  | ## Huge field (by yude & kuwazi_) | ||||||
|  |  | ||||||
|  | ## Giant sugar cane field  (by yude) | ||||||
|  |  | ||||||
							
								
								
									
										28
									
								
								docs/minecraft/ja.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,28 @@ | |||||||
|  | # ルール | ||||||
|  | [yude.jp サービス利用規約](https://yude.jp/tos) に加えて、以下が適用されます。 | ||||||
|  | * ワールドのどこであっても自由に建築することができます。 | ||||||
|  | * トロール (荒らし) を行わないでください。 | ||||||
|  | * チートを行わないでください。 | ||||||
|  | # 使用可能なコマンドの一覧 | ||||||
|  | * `/ll`: スポーンチェッカーの表示を切り替えます。 | ||||||
|  | * `/mvspawn`: ワールドのスポーン地点へ転移します。 | ||||||
|  |  | ||||||
|  | # 便利機能 | ||||||
|  | ## 一括破壊 | ||||||
|  | 木や鉱石ブロックをスニーク (しゃがむ) しながら破壊すると一括破壊できます。 | ||||||
|  | ## ブロックの保護 | ||||||
|  | 看板を画像のように貼り付けることで、チェストやドア、かまどなどを保護できます。\ | ||||||
|  | 複数行に渡ってプレイヤー ID を書くことで、共有ブロックを作ることもできます。\ | ||||||
|  |  | ||||||
|  | ## スキル | ||||||
|  | mcMMO を導入しているので、プラグインによるスキルを利用できます。   | ||||||
|  |  | ||||||
|  | # 施設紹介 | ||||||
|  | ## 神社 (by shirachan_1204) | ||||||
|  |  | ||||||
|  | ## アイアンゴーレムトラップ (by yude & kuwazi_) | ||||||
|  |  | ||||||
|  | ## 巨大畑 (by yude & kuwazi_) | ||||||
|  |  | ||||||
|  | ## 巨大サトウキビ畑 (by yude) | ||||||
|  |  | ||||||
							
								
								
									
										14
									
								
								docs/mutual/en.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,14 @@ | |||||||
|  | # Mutual links | ||||||
|  | Publishing the website whose links to yude.jp. | ||||||
|  |  | ||||||
|  | ## Link listing | ||||||
|  | ### カービィ★KIRBYの家 `https://exout.net/~kirby3ds/` | ||||||
|  | [](https://exout.net/~kirby3ds/) | ||||||
|  |  | ||||||
|  | ### こーげんやさい `https://nona-takahara.github.io/` | ||||||
|  | [](https://nona-takahara.github.io/) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | ## To those who want to link yude.jp | ||||||
|  | Thank you! You can use the banner below to link this website. | ||||||
|  | [](https://yude.jp) | ||||||
							
								
								
									
										14
									
								
								docs/mutual/ja.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,14 @@ | |||||||
|  | # 相互リンク | ||||||
|  | この Web サイトをリンクしてくださっている方のページを掲載します。 | ||||||
|  |  | ||||||
|  | ## リンク一覧 | ||||||
|  | ### カービィ★KIRBYの家 `https://exout.net/~kirby3ds/` | ||||||
|  | [](https://exout.net/~kirby3ds/) | ||||||
|  |  | ||||||
|  | ### こーげんやさい `https://nona-takahara.github.io/` | ||||||
|  | [](https://nona-takahara.github.io/) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | ## このサイトをリンクしてくださる方へ | ||||||
|  | ありがとうございます!以下のバナーを使用して、この Web サイトをリンクすることができます。 | ||||||
|  | [](https://yude.jp) | ||||||
| @@ -5,7 +5,7 @@ | |||||||
|       "*": ["common"], |       "*": ["common"], | ||||||
|       "/": ["index", "minecraft", "common"], |       "/": ["index", "minecraft", "common"], | ||||||
|       "/profile": ["profile", "common"], |       "/profile": ["profile", "common"], | ||||||
|       "/status": ["status", "common"], |       "/server": ["server", "common"], | ||||||
|       "/house": ["house", "common"], |       "/house": ["house", "common"], | ||||||
|       "/tos": ["tos", "common"], |       "/tos": ["tos", "common"], | ||||||
|       "/hcunews": ["hcunews", "common"], |       "/hcunews": ["hcunews", "common"], | ||||||
|   | |||||||
| @@ -4,5 +4,7 @@ | |||||||
|     "tos": "yude.jp Terms of Service", |     "tos": "yude.jp Terms of Service", | ||||||
|     "yes_playing": "Playing {{playing}}", |     "yes_playing": "Playing {{playing}}", | ||||||
|     "listening": "Listening to {{listening}}", |     "listening": "Listening to {{listening}}", | ||||||
|     "close": "Close" |     "close": "Close", | ||||||
|  |     "mutual": "Mutual links", | ||||||
|  |     "status": "Service Status" | ||||||
| } | } | ||||||
| @@ -4,5 +4,7 @@ | |||||||
|     "tos": "yude.jp サービス利用規約", |     "tos": "yude.jp サービス利用規約", | ||||||
|     "yes_playing": "{{playing}} をプレイ中", |     "yes_playing": "{{playing}} をプレイ中", | ||||||
|     "listening": "{{listening}} を再生中", |     "listening": "{{listening}} を再生中", | ||||||
|     "close": "閉じる" |     "close": "閉じる", | ||||||
|  |     "mutual": "相互リンク", | ||||||
|  |     "status": "サービスの状態" | ||||||
| } | } | ||||||
| @@ -12,21 +12,27 @@ const App = () => { | |||||||
|     };   |     };   | ||||||
|     fetchData(); |     fetchData(); | ||||||
|   }, []); |   }, []); | ||||||
|   const status = data.members && data.members[0].status; |   const str = JSON.stringify(data) | ||||||
|  |   let status = 0 | ||||||
|  |   if (str.indexOf("status") !== -1){ | ||||||
|  |     status = data.members && data.members[0].status; | ||||||
|  |   } | ||||||
|   return ( |   return ( | ||||||
|   <> |   <> | ||||||
|   <div className="z-50 w-6 transform translate-y-3/4 -translate-x-full"> |   <div className="z-50 w-6 transform translate-y-3/4 -translate-x-full"> | ||||||
|   { |   { | ||||||
|     (() => { |     (() => { | ||||||
|  |       if (status == 0) { | ||||||
|  |         return <div className="text-gray-700 rounded-full bg-gray-500 flex w-6 h-6"></div> | ||||||
|  |       }else{ | ||||||
|       if (status == "online"){ |       if (status == "online"){ | ||||||
|         return <div className="text-green-700 rounded-full bg-green-500 flex w-6 h-6"></div> |         return <div className="text-green-700 rounded-full bg-green-500 flex w-6 h-6"></div> | ||||||
|       } else if (status == "idle"){ |       } else if (status == "idle"){ | ||||||
|         return <div className="text-yellow-700 rounded-full bg-green-500 flex w-6 h-6"></div> |         return <div className="text-yellow-700 rounded-full bg-green-500 flex w-6 h-6"></div> | ||||||
|       } else if (status == "dnd"){ |  | ||||||
|         return <div className="text-yellow-700 rounded-full bg-red-500 flex w-6 h-6"></div> |  | ||||||
|       } else { |       } else { | ||||||
|         return <div className="text-gray-700 rounded-full bg-red-500 flex w-6 h-6"></div> |         return <div className="text-yellow-700 rounded-full bg-red-500 flex w-6 h-6"></div> | ||||||
|       }  |       }  | ||||||
|  |     } | ||||||
|     })() |     })() | ||||||
|   } |   } | ||||||
|   </div> |   </div> | ||||||
|   | |||||||
| @@ -19,6 +19,9 @@ export default function Footer(props) { | |||||||
|                 <p className="text-sm font-bold mb-2"> |                 <p className="text-sm font-bold mb-2"> | ||||||
|                     <Link href="/tos"><a className="hover:underline">{t('tos')}</a></Link> |                     <Link href="/tos"><a className="hover:underline">{t('tos')}</a></Link> | ||||||
|                 </p> |                 </p> | ||||||
|  |                 <p className="text-sm font-bold mb-2"> | ||||||
|  |                     <Link href="https://status.yude.jp"><a className="hover:underline">{t('status')}</a></Link> | ||||||
|  |                 </p> | ||||||
|             </div> |             </div> | ||||||
|           </div> |           </div> | ||||||
|         </div> |         </div> | ||||||
|   | |||||||
| @@ -2,6 +2,8 @@ import React from "react"; | |||||||
| import Popper from "popper.js"; | import Popper from "popper.js"; | ||||||
| import { useRouter } from 'next/router' | import { useRouter } from 'next/router' | ||||||
| import Link from 'next/link'; | import Link from 'next/link'; | ||||||
|  | import { faLanguage } from '@fortawesome/free-solid-svg-icons' | ||||||
|  | import { FontAwesomeIcon } from '@fortawesome/react-fontawesome' | ||||||
|  |  | ||||||
| const Dropdown = ({ color }) => { | const Dropdown = ({ color }) => { | ||||||
|   const router = useRouter() |   const router = useRouter() | ||||||
| @@ -29,7 +31,7 @@ const Dropdown = ({ color }) => { | |||||||
|     <> |     <> | ||||||
|  |  | ||||||
| <div className="text-left mr-2 ml-2 my-3 float-right"> | <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 shadow-sm px-4 py-2 bg-white text-sm font-medium text-gray-700 hover:bg-gray-50 focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-offset-gray-100 focus:ring-indigo-500" id="options-menu" aria-haspopup="true" aria-expanded="true" |     <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" | ||||||
|     style={{ transition: "all .15s ease" }} |     style={{ transition: "all .15s ease" }} | ||||||
|     ref={btnDropdownRef} |     ref={btnDropdownRef} | ||||||
|     onClick={() => { |     onClick={() => { | ||||||
| @@ -38,19 +40,19 @@ const Dropdown = ({ color }) => { | |||||||
|         : openDropdownPopover(); |         : openDropdownPopover(); | ||||||
|     }} |     }} | ||||||
|     > |     > | ||||||
|       言語 / Languages |       <FontAwesomeIcon icon={faLanguage} className="w-12 h-9" /> | ||||||
|       <svg className="-mr-1 ml-2 h-5 w-3" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20" fill="currentColor" aria-hidden="true"> |       <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" /> |         <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> |       </svg> | ||||||
|     </button>   |     </button>   | ||||||
|   <div ref={popoverDropdownRef} className={ |   <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"}> |               (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"}> | ||||||
|     <div className="py-1" role="menu" aria-orientation="vertical" aria-labelledby="options-menu"> |     <div className="py-1" role="menu" aria-orientation="vertical" aria-labelledby="options-menu"> | ||||||
|     <Link href="#" locale="ja"> |     <Link href="#" locale="ja"> | ||||||
|       <a href="#" className="block px-4 py-2 text-sm text-gray-700 hover:bg-gray-100 hover:text-gray-900" role="menuitem">日本語</a> |       <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> | ||||||
|     </Link> |     </Link> | ||||||
|     <Link href="#" locale="en"> |     <Link href="#" locale="en"> | ||||||
|       <a href="#" className="block px-4 py-2 text-sm text-gray-700 hover:bg-gray-100 hover:text-gray-900" role="menuitem">English</a> |       <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> | ||||||
|     </Link> |     </Link> | ||||||
|     </div> |     </div> | ||||||
|   </div> |   </div> | ||||||
|   | |||||||
| @@ -1,14 +1,12 @@ | |||||||
| import Head from "next/head" |  | ||||||
| import Link from "next/link" |  | ||||||
| import "tailwindcss/tailwind.css"; | import "tailwindcss/tailwind.css"; | ||||||
| import useTranslation from 'next-translate/useTranslation' |  | ||||||
| import { useRouter } from 'next/router' | import { useRouter } from 'next/router' | ||||||
| import React, { useEffect, useState } from 'react' | import React, { useEffect, useState } from 'react' | ||||||
| import { useTheme } from "next-themes"; | import { useTheme } from "next-themes"; | ||||||
|  | import { faMoon, faSun } from '@fortawesome/free-solid-svg-icons' | ||||||
|  | import { FontAwesomeIcon } from '@fortawesome/react-fontawesome' | ||||||
|  |  | ||||||
| const Layout = (props) => { | const ThemeSelector = (props) => { | ||||||
|   const { title, children } = props |   const { title, children } = props | ||||||
|   const siteTitle = "yude.jp" |  | ||||||
|   const router = useRouter() |   const router = useRouter() | ||||||
|   const { locale, locales, defaultLocale, pathname } = router |   const { locale, locales, defaultLocale, pathname } = router | ||||||
|    |    | ||||||
| @@ -23,13 +21,13 @@ const Layout = (props) => { | |||||||
|     } |     } | ||||||
|   }; |   }; | ||||||
|   return ( |   return ( | ||||||
|       <button className="my-4 text-2xl" onClick={switchTheme}> |       <button className="inline-flex rounded-md border border-gray-300 dark:border-gray-800 shadow-sm px-2 bg-white font-medium text-gray-700 hover:bg-gray-50 dark:bg-gray-700 dark:text-white my-3 py-1 text-2xl focus:outline-none" onClick={switchTheme}> | ||||||
|         {theme === 'light' ? ( |         {theme !== undefined && (theme === "light" ? ( | ||||||
|           <span>🌙</span> |           <FontAwesomeIcon icon={faMoon} className="w-10 h-7" /> | ||||||
|         ) : ( |         ) : ( | ||||||
|           <span>🌄</span> |           <FontAwesomeIcon icon={faSun} className="w-10 h-7" /> | ||||||
|         )} |         ))} | ||||||
|       </button> |       </button> | ||||||
|   ) |   ) | ||||||
| } | } | ||||||
| export default Layout | export default ThemeSelector | ||||||
| @@ -1,30 +1,19 @@ | |||||||
| import Layout from "./components/Layout" | import Layout from "./components/Layout" | ||||||
| import Link from 'next/link' | import Link from 'next/link' | ||||||
| import { faDiscord, faGit, faMastodon, faGithub } from '@fortawesome/free-brands-svg-icons' | import { faDiscord, faGit, faMastodon, faGithub } from '@fortawesome/free-brands-svg-icons' | ||||||
| import { faBlog, faBook, faUser, faServer, faHouseUser } from '@fortawesome/free-solid-svg-icons' | import { faBlog, faBook, faUser, faServer, faHouseUser, faHeart } from '@fortawesome/free-solid-svg-icons' | ||||||
| import { FontAwesomeIcon } from '@fortawesome/react-fontawesome' | import { FontAwesomeIcon } from '@fortawesome/react-fontawesome' | ||||||
| import Image from 'next/image' | import Image from 'next/image' | ||||||
| import useTranslation from 'next-translate/useTranslation' | import useTranslation from 'next-translate/useTranslation' | ||||||
| import { useRouter } from 'next/router' | import { useRouter } from 'next/router' | ||||||
|  |  | ||||||
| export default function Index(props) { | export default function Index(props) { | ||||||
|    |  | ||||||
|   // Translation |  | ||||||
|   const router = useRouter() |   const router = useRouter() | ||||||
|   const { locale, locales, defaultLocale, pathname } = router |   const { locale, locales, defaultLocale, pathname } = router | ||||||
|   const { t, lang } = useTranslation("index") |   const { t, lang } = useTranslation("index") | ||||||
|   const home = t('home') |  | ||||||
|   const profile = t('profile') |  | ||||||
|   const blog = t('blog') |  | ||||||
|   const status = t('status') |  | ||||||
|   const house = t('house') |  | ||||||
|   const discord = t('discord') |  | ||||||
|   const mastodon = t('mastodon') |  | ||||||
|   const minecraft = t('minecraft:title') |  | ||||||
|  |  | ||||||
|   return ( |   return ( | ||||||
|  |     <Layout title={t('home')}> | ||||||
|     <Layout title={home}> |  | ||||||
|       <div className="my-9 text-center"> |       <div className="my-9 text-center"> | ||||||
|         <div className="m-10"> |         <div className="m-10"> | ||||||
|         <Image |         <Image | ||||||
| @@ -35,14 +24,13 @@ export default function Index(props) { | |||||||
|             unoptimized = {true} |             unoptimized = {true} | ||||||
|         /> |         /> | ||||||
|         </div> |         </div> | ||||||
|         <div className="grid grid-cols-5 gap-10"> |         <div className="grid grid-cols-4 gap-10"> | ||||||
|         <div className="has-tooltip"><span className="tooltip rounded shadow-lg p-1 bg-yellow-600 transform translate-y-10 -translate-x-10">{profile}</span><Link href="/profile"><a><FontAwesomeIcon icon={faUser} className="w-10 h-10 fill-current inline transition duration-200 ease-in-out transform hover:-translate-y-1 hover:scale-110" /></a></Link></div> |         <div><Link href="/profile"><a><FontAwesomeIcon icon={faUser} className="w-10 h-10 fill-current inline transition duration-200 ease-in-out transform hover:-translate-y-1 hover:scale-110" /></a></Link></div> | ||||||
|         <div className="has-tooltip"><span className="tooltip rounded shadow-lg p-1 bg-yellow-600 transform translate-y-10 -translate-x-9">{blog}</span><Link href="https://blog.yude.jp"><a><FontAwesomeIcon icon={faBlog} className="w-10 h-10 fill-current inline transition duration-200 ease-in-out transform hover:-translate-y-1 hover:scale-110" /></a></Link></div> |         <div><Link href="/server"><a><FontAwesomeIcon icon={faServer} className="w-10 h-10 fill-current inline transition duration-200 ease-in-out transform hover:-translate-y-1 hover:scale-110" /></a></Link></div> | ||||||
|         <div className="has-tooltip"><span className="tooltip rounded shadow-lg p-1 bg-yellow-600 transform translate-y-10 -translate-x-12">{status}</span><Link href="/status"><a><FontAwesomeIcon icon={faServer} className="w-10 h-10 fill-current inline transition duration-200 ease-in-out transform hover:-translate-y-1 hover:scale-110" /></a></Link></div> |         <div><Link href="/house"><a><FontAwesomeIcon icon={faHouseUser} className="w-10 h-10 fill-current inline transition duration-200 ease-in-out transform hover:-translate-y-1 hover:scale-110" /></a></Link></div> | ||||||
|         <div className="has-tooltip"><span className="tooltip rounded shadow-lg p-1 bg-yellow-600 transform translate-y-10 -translate-x-5">{house}</span><Link href="/house"><a><FontAwesomeIcon icon={faHouseUser} className="w-10 h-10 fill-current inline transition duration-200 ease-in-out transform hover:-translate-y-1 hover:scale-110" /></a></Link></div> |         <div><Link href="https://scrapbox.io/yude"><a><FontAwesomeIcon icon={faBook} className="w-10 h-10 fill-current inline transition duration-200 ease-in-out transform hover:-translate-y-1 hover:scale-110" /></a></Link></div> | ||||||
|         <div className="has-tooltip"><span className="tooltip rounded shadow-lg p-1 bg-yellow-600 transform translate-y-10 -translate-x-4">Scrapbox</span><Link href="https://scrapbox.io/yude"><a><FontAwesomeIcon icon={faBook} className="w-10 h-10 fill-current inline transition duration-200 ease-in-out transform hover:-translate-y-1 hover:scale-110" /></a></Link></div> |         <div><Link href="https://discord.gg/X6srY7X"><a><FontAwesomeIcon icon={faDiscord} className="w-10 h-10 fill-current inline transition duration-200 ease-in-out transform hover:-translate-y-1 hover:scale-110" /></a></Link></div> | ||||||
|         <div className="has-tooltip"><span className="tooltip rounded shadow-lg p-1 bg-yellow-600 transform translate-y-10 -translate-x-16">{discord}</span><Link href="https://discord.gg/X6srY7X"><a><FontAwesomeIcon icon={faDiscord} className="w-10 h-10 fill-current inline transition duration-200 ease-in-out transform hover:-translate-y-1 hover:scale-110" /></a></Link></div> |         <div><Link href="https://matrix.to/#/!oriLSKSTauvVrpdzZX:matrix.org?via=matrix.org"><a> | ||||||
|         <div className="has-tooltip"><span className="tooltip rounded shadow-lg p-1 bg-yellow-600 transform translate-y-10 -translate-x-10">Spaces on Matrix</span><Link href="https://matrix.to/#/!oriLSKSTauvVrpdzZX:matrix.org?via=matrix.org"><a> |  | ||||||
|         <svg version="1.1" viewBox="0 0 27.9 32" className="fill-current text-black dark:text-white w-10 h-10 inline transition duration-200 ease-in-out transform hover:-translate-y-1 hover:scale-110"> |         <svg version="1.1" viewBox="0 0 27.9 32" className="fill-current text-black dark:text-white w-10 h-10 inline transition duration-200 ease-in-out transform hover:-translate-y-1 hover:scale-110"> | ||||||
|          <g transform="translate(-.095 .005)"> |          <g transform="translate(-.095 .005)"> | ||||||
|           <path d="m27.1 31.2v-30.5h-2.19v-0.732h3.04v32h-3.04v-0.732z"/> |           <path d="m27.1 31.2v-30.5h-2.19v-0.732h3.04v32h-3.04v-0.732z"/> | ||||||
| @@ -51,14 +39,35 @@ export default function Index(props) { | |||||||
|          </g> |          </g> | ||||||
|         </svg> |         </svg> | ||||||
|         </a></Link></div> |         </a></Link></div> | ||||||
|         <div className="has-tooltip"><span className="tooltip rounded shadow-lg p-1 bg-yellow-600 transform translate-y-10 -translate-x-16">GitHub Organization</span><Link href="https://github.com/yudejp"><a><FontAwesomeIcon icon={faGithub} className="w-10 h-10 fill-current inline transition duration-200 ease-in-out transform hover:-translate-y-1 hover:scale-110" /></a></Link></div> |         <div><Link href="https://github.com/yudejp"><a><FontAwesomeIcon icon={faGithub} className="w-10 h-10 fill-current inline transition duration-200 ease-in-out transform hover:-translate-y-1 hover:scale-110" /></a></Link></div> | ||||||
|         <div className="has-tooltip"><span className="tooltip rounded shadow-lg p-1 bg-yellow-600 transform translate-y-10">Gitea</span><Link href="https://git.yude.jp"><a><FontAwesomeIcon icon={faGit} className="w-10 h-10 fill-current inline transition duration-200 ease-in-out transform hover:-translate-y-1 hover:scale-110" /></a></Link></div> |         <div><Link href="https://git.yude.jp"><a><FontAwesomeIcon icon={faGit} className="w-10 h-10 fill-current inline transition duration-200 ease-in-out transform hover:-translate-y-1 hover:scale-110" /></a></Link></div> | ||||||
|         <div className="has-tooltip"><span className="tooltip rounded shadow-lg p-1 bg-yellow-600 transform translate-y-10 -translate-x-12">{mastodon}</span><Link href="https://mstdn.yude.jp"><a><FontAwesomeIcon icon={faMastodon} className="w-10 h-10 fill-current inline transition duration-200 ease-in-out transform hover:-translate-y-1 hover:scale-110" /></a></Link></div> |         <div><Link href="https://mstdn.yude.jp"><a><FontAwesomeIcon icon={faMastodon} className="w-10 h-10 fill-current inline transition duration-200 ease-in-out transform hover:-translate-y-1 hover:scale-110" /></a></Link></div> | ||||||
|         <div className="has-tooltip"><span className="tooltip rounded shadow-lg p-1 bg-yellow-600 transform translate-y-10 -translate-x-12">{minecraft}</span><Link href="/minecraft"><a> |         <div><Link href="/minecraft"><a> | ||||||
|         <svg className="fill-current text-black dark:text-white w-10 h-10 inline transition duration-200 ease-in-out transform hover:-translate-y-1 hover:scale-110" version="1.1" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 304.8 304.8"> |         <svg className="fill-current text-black dark:text-white w-10 h-10 inline transition duration-200 ease-in-out transform hover:-translate-y-1 hover:scale-110" version="1.1" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 304.8 304.8"> | ||||||
|           <path d="M 39.10262 126.138 L 39.16748 12.39574 L 152.7982 12.33506 L 266.4289 12.27438 L 266.4289 126.0773 L 266.4289 239.8803 L 152.7333 239.8803 L 39.03775 239.8803 L 39.10262 126.138 Z M 260.4857 126.0776 L 260.4857 18.55703 L 152.8628 18.55703 L 45.23985 18.55703 L 45.23985 126.0776 L 45.23985 233.5982 L 152.8628 233.5982 L 260.4857 233.5982 L 260.4857 126.0776 Z M 103.8963 162.9245 L 103.8963 126.0776 L 116.1702 126.0776 L 128.4441 126.0776 L 128.4441 113.8758 L 128.4441 101.674 L 152.8628 101.674 L 177.2814 101.674 L 177.2814 113.8758 L 177.2814 126.0776 L 189.3835 126.0776 L 201.4856 126.0776 L 201.6573 150.5415 C 201.7517 163.9967 201.829 180.5779 201.8291 187.3885 L 201.8293 199.7715 L 189.6869 199.7715 L 177.5446 199.7715 L 177.4776 187.5093 L 177.4106 175.2471 L 152.7982 175.1855 L 128.1857 175.1239 L 128.1857 187.4477 L 128.1857 199.7715 L 116.041 199.7715 L 103.8963 199.7715 L 103.8963 162.9245 Z M 79.34843 77.02888 L 79.34843 52.62534 L 103.7671 52.62534 L 128.1857 52.62534 L 128.1857 77.02888 L 128.1857 101.4324 L 103.7671 101.4324 L 79.34843 101.4324 L 79.34843 77.02888 Z M 177.5398 77.02888 L 177.5398 52.62534 L 201.9585 52.62534 L 226.3771 52.62534 L 226.3771 77.02888 L 226.3771 101.4324 L 201.9585 101.4324 L 177.5398 101.4324 L 177.5398 77.02888 Z"/> |           <path d="M 39.10262 126.138 L 39.16748 12.39574 L 152.7982 12.33506 L 266.4289 12.27438 L 266.4289 126.0773 L 266.4289 239.8803 L 152.7333 239.8803 L 39.03775 239.8803 L 39.10262 126.138 Z M 260.4857 126.0776 L 260.4857 18.55703 L 152.8628 18.55703 L 45.23985 18.55703 L 45.23985 126.0776 L 45.23985 233.5982 L 152.8628 233.5982 L 260.4857 233.5982 L 260.4857 126.0776 Z M 103.8963 162.9245 L 103.8963 126.0776 L 116.1702 126.0776 L 128.4441 126.0776 L 128.4441 113.8758 L 128.4441 101.674 L 152.8628 101.674 L 177.2814 101.674 L 177.2814 113.8758 L 177.2814 126.0776 L 189.3835 126.0776 L 201.4856 126.0776 L 201.6573 150.5415 C 201.7517 163.9967 201.829 180.5779 201.8291 187.3885 L 201.8293 199.7715 L 189.6869 199.7715 L 177.5446 199.7715 L 177.4776 187.5093 L 177.4106 175.2471 L 152.7982 175.1855 L 128.1857 175.1239 L 128.1857 187.4477 L 128.1857 199.7715 L 116.041 199.7715 L 103.8963 199.7715 L 103.8963 162.9245 Z M 79.34843 77.02888 L 79.34843 52.62534 L 103.7671 52.62534 L 128.1857 52.62534 L 128.1857 77.02888 L 128.1857 101.4324 L 103.7671 101.4324 L 79.34843 101.4324 L 79.34843 77.02888 Z M 177.5398 77.02888 L 177.5398 52.62534 L 201.9585 52.62534 L 226.3771 52.62534 L 226.3771 77.02888 L 226.3771 101.4324 L 201.9585 101.4324 L 177.5398 101.4324 L 177.5398 77.02888 Z"/> | ||||||
|         </svg> |         </svg> | ||||||
|         </a></Link></div> |         </a></Link></div> | ||||||
|  |         <div><Link href="/mutual"><a><FontAwesomeIcon icon={faHeart} className="w-10 h-10 fill-current inline transition duration-200 ease-in-out transform hover:-translate-y-1 hover:scale-110" /></a></Link></div> | ||||||
|  |         </div> | ||||||
|  |         <div className="mx-auto mt-10"> | ||||||
|  |           <Link href="https://www.eff.org/pages/blue-ribbon-campaign"> | ||||||
|  |             <a> | ||||||
|  |               <Image | ||||||
|  |                 src="/static/images/brstrip.gif" | ||||||
|  |                 width={150} | ||||||
|  |                 height={41} | ||||||
|  |               /> | ||||||
|  |             </a> | ||||||
|  |           </Link> | ||||||
|  |           <Link href="https://sites.google.com/site/happybusy/"> | ||||||
|  |             <a> | ||||||
|  |               <Image | ||||||
|  |                 src="/static/images/busy_banner.png" | ||||||
|  |                 width={200} | ||||||
|  |                 height={42} | ||||||
|  |               /> | ||||||
|  |             </a> | ||||||
|  |           </Link> | ||||||
|         </div> |         </div> | ||||||
|       </div> |       </div> | ||||||
|     </Layout> |     </Layout> | ||||||
|   | |||||||
| @@ -7,6 +7,10 @@ import Image from 'next/image' | |||||||
| import { faMap, faCopy } from '@fortawesome/free-solid-svg-icons' | import { faMap, faCopy } from '@fortawesome/free-solid-svg-icons' | ||||||
| import { FontAwesomeIcon } from '@fortawesome/react-fontawesome' | import { FontAwesomeIcon } from '@fortawesome/react-fontawesome' | ||||||
| import Link from 'next/link' | import Link from 'next/link' | ||||||
|  | import ReactMarkdown from "react-markdown" | ||||||
|  | import gfm from 'remark-gfm'; | ||||||
|  | import ja from '../docs/minecraft/ja.md' | ||||||
|  | import en from '../docs/minecraft/en.md' | ||||||
|  |  | ||||||
| export default function About(props) { | export default function About(props) { | ||||||
|     const router = useRouter() |     const router = useRouter() | ||||||
| @@ -42,17 +46,24 @@ export default function About(props) { | |||||||
|                   </button> |                   </button> | ||||||
|                 </p> |                 </p> | ||||||
|                 <p>{t('version')}: 1.17</p> |                 <p>{t('version')}: 1.17</p> | ||||||
|                 <Link href="https://dynmap.yude.jp"> |                 <Link href="https://bluemap.yude.jp"> | ||||||
|                 <a> |                 <a> | ||||||
|                 <button |                 <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" |                 type="button" | ||||||
|               > |               > | ||||||
|                 <FontAwesomeIcon icon={faMap} className="w-5 h-5 inline"/> Dynmap |                 <FontAwesomeIcon icon={faMap} className="w-5 h-5 inline"/> BlueMap | ||||||
|               </button> |               </button> | ||||||
|               </a> |               </a> | ||||||
|               </Link> |               </Link> | ||||||
|               </div> |               </div> | ||||||
|  |                | ||||||
|  |               {lang === 'ja' ? ( | ||||||
|  |                 <ReactMarkdown plugins={[gfm]} children={ja} /> | ||||||
|  |               ) : ( | ||||||
|  |                 <ReactMarkdown plugins={[gfm]} children={en} /> | ||||||
|  |               )} | ||||||
|  |  | ||||||
|             </div> |             </div> | ||||||
|             </Layout> |             </Layout> | ||||||
|         ) |         ) | ||||||
|   | |||||||
							
								
								
									
										25
									
								
								pages/mutual.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,25 @@ | |||||||
|  | import Layout from "./components/Layout" | ||||||
|  | import useTranslation from 'next-translate/useTranslation' | ||||||
|  | import { useRouter } from 'next/router' | ||||||
|  | import React from "react" | ||||||
|  | import ReactMarkdown from "react-markdown" | ||||||
|  | import gfm from 'remark-gfm'; | ||||||
|  | import ja from '../docs/mutual/ja.md' | ||||||
|  | import en from '../docs/mutual/en.md' | ||||||
|  |  | ||||||
|  | export default function Tos(props) { | ||||||
|  |     const router = useRouter() | ||||||
|  |     const { locale, locales, defaultLocale, pathname } = router | ||||||
|  |     const { t, lang } = useTranslation("common") | ||||||
|  |     return( | ||||||
|  |         <Layout title={t('common:mutual')}> | ||||||
|  |         <div> | ||||||
|  |         {lang === 'ja' ? ( | ||||||
|  |           <ReactMarkdown plugins={[gfm]} children={ja} /> | ||||||
|  |         ) : ( | ||||||
|  |           <ReactMarkdown plugins={[gfm]} children={en} /> | ||||||
|  |         )} | ||||||
|  |         </div> | ||||||
|  |         </Layout> | ||||||
|  |         ) | ||||||
|  |     } | ||||||
| @@ -28,7 +28,7 @@ export default function About(props) { | |||||||
|         <div> |         <div> | ||||||
|           <div className="flex mb-10 justify-center"> |           <div className="flex mb-10 justify-center"> | ||||||
|           <Image |           <Image | ||||||
|             className   = "rounded-full hover:animate-rumble z-0" |             className   = "rounded-full hover:animate-rumble z-0 p-15" | ||||||
|             src         = "/static/images/avatar.png" |             src         = "/static/images/avatar.png" | ||||||
|             alt         = "yude's avatar" |             alt         = "yude's avatar" | ||||||
|             width       = {200} |             width       = {200} | ||||||
| @@ -139,6 +139,32 @@ export default function About(props) { | |||||||
|             </a> |             </a> | ||||||
|             </Link> |             </Link> | ||||||
|           </div> |           </div> | ||||||
|  |           <div className="hover:underline"> | ||||||
|  |             <Link href="#"> | ||||||
|  |             <a> | ||||||
|  |             <svg version="1.0" xmlns="http://www.w3.org/2000/svg" className="w-12 h-12 inline lg:w-12 lg:h-12 md:w-12 md:h-12 fill-current text-black dark:text-white" viewBox="0 0 700 700"> | ||||||
|  |             <g transform="translate(-100.000000,900.000000) scale(0.100000,-0.100000)" fill="#FFFFF"> | ||||||
|  |             <path d="M2965 8314 c-481 -86 -868 -442 -990 -910 -44 -169 -47 -268 -42 | ||||||
|  |             -1579 3 -1204 4 -1232 24 -1325 111 -501 467 -858 973 -976 66 -15 150 -18 | ||||||
|  |             691 -21 560 -4 618 -3 633 12 15 15 16 208 16 2396 0 1622 -3 2386 -10 2400 | ||||||
|  |             -10 18 -27 19 -613 18 -476 -1 -619 -4 -682 -15z m905 -2400 l0 -2026 -407 5 | ||||||
|  |             c-375 4 -415 6 -490 25 -322 83 -561 331 -628 654 -22 101 -22 2589 -1 2688 | ||||||
|  |             60 281 255 514 518 619 132 53 193 59 621 60 l387 1 0 -2026z"/> | ||||||
|  |             <path d="M3051 7329 c-63 -12 -159 -60 -210 -105 -105 -91 -157 -220 -149 | ||||||
|  |             -372 4 -79 9 -100 41 -164 47 -97 118 -168 215 -216 67 -33 84 -37 171 -40 79 | ||||||
|  |             -3 107 0 160 18 217 73 348 284 311 500 -43 257 -287 429 -539 379z"/> | ||||||
|  |             <path d="M4757 8323 c-4 -3 -7 -1087 -7 -2409 0 -2181 1 -2402 16 -2408 27 | ||||||
|  |             -10 803 -6 899 4 406 46 764 293 959 660 25 47 58 126 75 175 63 188 61 138 | ||||||
|  |             61 1575 0 1147 -2 1318 -16 1391 -99 521 -496 914 -1018 1004 -70 12 -178 15 | ||||||
|  |             -526 15 -240 0 -440 -3 -443 -7z m1068 -2178 c156 -41 284 -160 336 -312 33 | ||||||
|  |             -94 32 -232 -1 -318 -61 -158 -181 -269 -335 -310 -250 -65 -516 86 -589 334 | ||||||
|  |             -22 76 -21 204 4 282 75 245 335 389 585 324z"/> | ||||||
|  |             </g> | ||||||
|  |             </svg> | ||||||
|  |             <p className="font-mono text-xl">SW-5543-5143-8814</p> | ||||||
|  |             </a> | ||||||
|  |             </Link> | ||||||
|  |           </div> | ||||||
|         </div> |         </div> | ||||||
|          |          | ||||||
|         { |         { | ||||||
|   | |||||||
| @@ -3,10 +3,10 @@ import useTranslation from 'next-translate/useTranslation' | |||||||
| 
 | 
 | ||||||
| import { useRouter } from 'next/router' | import { useRouter } from 'next/router' | ||||||
| 
 | 
 | ||||||
| export default function About(props) { | export default function Server(props) { | ||||||
|   const router = useRouter() |   const router = useRouter() | ||||||
|   const { locale, locales, defaultLocale, pathname } = router |   const { locale, locales, defaultLocale, pathname } = router | ||||||
|   const { t, lang } = useTranslation("status") |   const { t, lang } = useTranslation("server") | ||||||
| 
 | 
 | ||||||
|   return ( |   return ( | ||||||
| 
 | 
 | ||||||
							
								
								
									
										
											BIN
										
									
								
								public/static/images/banner_new.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 5.6 KiB | 
							
								
								
									
										
											BIN
										
									
								
								public/static/images/brstrip.gif
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 2.2 KiB | 
| Before Width: | Height: | Size: 6.4 KiB After Width: | Height: | Size: 2.7 KiB | 
| Before Width: | Height: | Size: 1.4 MiB After Width: | Height: | Size: 890 KiB | 
							
								
								
									
										
											BIN
										
									
								
								public/static/images/minecraft/golem_trap.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 526 KiB | 
							
								
								
									
										
											BIN
										
									
								
								public/static/images/minecraft/large_field.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 958 KiB | 
							
								
								
									
										
											BIN
										
									
								
								public/static/images/minecraft/lockette/chest.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 9.8 KiB | 
							
								
								
									
										
											BIN
										
									
								
								public/static/images/minecraft/shrine.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 464 KiB | 
							
								
								
									
										
											BIN
										
									
								
								public/static/images/minecraft/sugarcane.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 332 KiB | 
							
								
								
									
										
											BIN
										
									
								
								public/static/images/mutual/kirby3ds.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 2.7 KiB | 
							
								
								
									
										
											BIN
										
									
								
								public/static/images/mutual/nona-takahara.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 8.4 KiB | 
| @@ -13,9 +13,6 @@ | |||||||
|       @apply list-disc mx-10 |       @apply list-disc mx-10 | ||||||
|     } |     } | ||||||
|    } |    } | ||||||
|    a { |  | ||||||
|       @apply hover:underline |  | ||||||
|    } |  | ||||||
|    .tooltip { |    .tooltip { | ||||||
|     @apply invisible absolute; |     @apply invisible absolute; | ||||||
|   } |   } | ||||||
|   | |||||||