mirror of
				https://github.com/yude-jp/yude.jp
				synced 2025-10-25 17:48:39 +09:00 
			
		
		
		
	Make widget for Public keys listing
This commit is contained in:
		
							
								
								
									
										92
									
								
								pages/components/PublicKeys.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										92
									
								
								pages/components/PublicKeys.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,92 @@ | ||||
| import React, { useState, useEffect } from 'react'; | ||||
| import useTranslation from 'next-translate/useTranslation' | ||||
| import { faKey, faEye, faDownload } from '@fortawesome/free-solid-svg-icons' | ||||
| import { FontAwesomeIcon } from '@fortawesome/react-fontawesome' | ||||
| import { useRouter } from 'next/router' | ||||
| import Link from 'next/link' | ||||
|  | ||||
| export default function Modal() { | ||||
|   const [showModal, setShowModal] = React.useState(false); | ||||
|   const router = useRouter() | ||||
|   const { t, lang } = useTranslation("common") | ||||
|   const { locale, locales, defaultLocale, pathname } = router | ||||
|   const close = t('common:close') | ||||
|   const keys = t('profile:keys') | ||||
|   const view = t('profile:view') | ||||
|   const fingerprint = t('profile:fingerprint') | ||||
|   const download = t('profile:download') | ||||
|  | ||||
|   return ( | ||||
|     <> | ||||
|       <button | ||||
|         className="bg-pink-600 text-white active:bg-pink-600 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" | ||||
|         onClick={() => setShowModal(true)} | ||||
|       > | ||||
|         <FontAwesomeIcon icon={faKey} className="w-5 h-5 inline"/> {keys} | ||||
|       </button> | ||||
|       {showModal ? ( | ||||
|         <> | ||||
|           <div | ||||
|             className="justify-center items-center flex overflow-x-hidden overflow-y-auto fixed inset-0 z-50 outline-none focus:outline-none" | ||||
|           > | ||||
|             <div className="relative mx-auto w-4/5 max-h-1/2 -mt-96 max-w-3xl"> | ||||
|               {/* Modal content */} | ||||
|               <div className="border-0 rounded-lg shadow-lg relative flex flex-col w-full bg-white outline-none focus:outline-none"> | ||||
|                 {/* Modal body */} | ||||
|                 <div className="relative p-2 flex-auto text-black text-left"> | ||||
|                  | ||||
|                 <p className="text-2xl"><FontAwesomeIcon icon={faKey} className="w-5 h-5 inline"/> {keys}</p> | ||||
|           <ul className="list-disc my-2"> | ||||
|           <li> | ||||
|             <span className="font-bold">PGP </span> | ||||
|             <Link href="/static/yudejp.gpg"> | ||||
|               <a className="hover:underline"> | ||||
|                 <FontAwesomeIcon icon={faDownload} className="w-5 h-5 inline"/>  | ||||
|                 {download} | ||||
|               </a> | ||||
|             </Link> | ||||
|             <p>{fingerprint}:</p> | ||||
|             <div className="overflow-x-auto"> | ||||
|               <div className="whitespace-nowrap"> | ||||
|                 <code>3745 F270 DB4E 8975 6B07  62BE EB0F E5D9 25C4 A968</code> | ||||
|               </div> | ||||
|             </div> | ||||
|           </li> | ||||
|           <li> | ||||
|             <span className="font-bold">SSH </span> | ||||
|             <Link href="https://github.com/yude.keys"> | ||||
|               <a className="hover:underline"> | ||||
|                 <FontAwesomeIcon icon={faEye} className="w-5 h-5 inline"/>  | ||||
|                 {view} | ||||
|               </a> | ||||
|             </Link> | ||||
|             <p>{fingerprint}:</p> | ||||
|             <div className="overflow-x-auto"> | ||||
|               <div className="whitespace-nowrap"> | ||||
|               <code>2048 SHA256:xwSL4DORWmroWdC6P0GU1m1yZl/cXqjo9rCCWqqO+Dc</code> | ||||
|               </div> | ||||
|             </div> | ||||
|           </li> | ||||
|             </ul> | ||||
|                  | ||||
|                 </div> | ||||
|                 {/* Modal footer for close button */} | ||||
|                 <div className="flex items-center justify-end p-6 border-t border-solid border-blueGray-200 rounded-b"> | ||||
|                   <button | ||||
|                     className="text-red-500 background-transparent font-bold uppercase px-6 py-2 text-sm outline-none focus:outline-none mr-1 mb-1 ease-linear transition-all duration-150" | ||||
|                     type="button" | ||||
|                     onClick={() => setShowModal(false)} | ||||
|                   > | ||||
|                     {close} | ||||
|                   </button> | ||||
|                 </div> | ||||
|               </div> | ||||
|             </div> | ||||
|           </div> | ||||
|           <div className="opacity-25 fixed inset-0 z-40 bg-black"></div> | ||||
|         </> | ||||
|       ) : null} | ||||
|     </> | ||||
|   ); | ||||
| } | ||||
| @@ -1,7 +1,7 @@ | ||||
| import Layout from "./components/Layout" | ||||
| import useTranslation from 'next-translate/useTranslation' | ||||
| import { faDiscord, faTwitter, faGithub, faKeybase, faInstagram, faMastodon, faSteam } from '@fortawesome/free-brands-svg-icons' | ||||
| import { faEnvelope, faBirthdayCake, faMapPin, faSchool, faPhone, faInfo, faKey, faDownload, faEye } from '@fortawesome/free-solid-svg-icons' | ||||
| import { faEnvelope, faBirthdayCake, faMapPin, faSchool, faPhone, faInfo } from '@fortawesome/free-solid-svg-icons' | ||||
| import { FontAwesomeIcon } from '@fortawesome/react-fontawesome' | ||||
| import Link from 'next/link' | ||||
| import Image from 'next/image' | ||||
| @@ -10,6 +10,7 @@ import { useRouter } from 'next/router' | ||||
| import DiscordPlaying from './components/DiscordPlaying' | ||||
| import Spotify from './components/Spotify' | ||||
| import WakaTime from './components/WakaTime' | ||||
| import PublicKeys from './components/PublicKeys' | ||||
|  | ||||
| export default function About(props) { | ||||
|   const router = useRouter() | ||||
| @@ -28,10 +29,6 @@ export default function About(props) { | ||||
|   const grade = t('grade') | ||||
|   const icon_1 = t('icon_1') | ||||
|   const icon_2 = t('icon_2') | ||||
|   const keys = t('keys') | ||||
|   const download = t('download') | ||||
|   const fingerprint = t('fingerprint') | ||||
|   const view = t('view') | ||||
|  | ||||
|   return ( | ||||
|  | ||||
| @@ -159,51 +156,13 @@ export default function About(props) { | ||||
|             </Link> | ||||
|           </div> | ||||
|         </div> | ||||
|  | ||||
|         { | ||||
|          // Keys | ||||
|         } | ||||
|         <div className="text-left my-6"> | ||||
|             <p className="text-2xl"><FontAwesomeIcon icon={faKey} className="w-5 h-5 inline"/> {keys}</p> | ||||
|           <ul className="list-disc my-2"> | ||||
|           <li> | ||||
|             <span className="font-bold">GPG </span> | ||||
|             <Link href="/static/yudejp.gpg"> | ||||
|               <a className="hover:underline"> | ||||
|                 <FontAwesomeIcon icon={faDownload} className="w-5 h-5 inline"/>  | ||||
|                 {download} | ||||
|               </a> | ||||
|             </Link> | ||||
|             <p>{fingerprint}:</p> | ||||
|             <div className="overflow-x-auto"> | ||||
|               <div className="whitespace-nowrap"> | ||||
|                 3745 F270 DB4E 8975 6B07  62BE EB0F E5D9 25C4 A968 | ||||
|                 </div> | ||||
|             </div> | ||||
|           </li> | ||||
|           <li> | ||||
|             <span className="font-bold">SSH </span> | ||||
|             <Link href="https://github.com/yude.keys"> | ||||
|               <a className="hover:underline"> | ||||
|                 <FontAwesomeIcon icon={faEye} className="w-5 h-5 inline"/>  | ||||
|                 {view} | ||||
|               </a> | ||||
|             </Link> | ||||
|             <p>{fingerprint}:</p> | ||||
|             <div className="overflow-x-auto"> | ||||
|               <div className="whitespace-nowrap"> | ||||
|                 2048 SHA256:xwSL4DORWmroWdC6P0GU1m1yZl/cXqjo9rCCWqqO+Dc | ||||
|               </div> | ||||
|             </div> | ||||
|           </li> | ||||
|             </ul> | ||||
|         </div> | ||||
|          | ||||
|         { | ||||
|          // WakaTime | ||||
|          // Buttons | ||||
|         } | ||||
|         <div className="text-left my-6"> | ||||
|         <div className="text-center my-6 space-x-5"> | ||||
|         <WakaTime /> | ||||
|         <PublicKeys /> | ||||
|         </div> | ||||
|         <div> | ||||
|         </div> | ||||
|   | ||||
		Reference in New Issue
	
	Block a user