1
0
card/src/App.vue

1830 lines
54 KiB
Vue
Raw Normal View History

2023-03-31 19:51:52 +00:00
<template>
<div id="app">
2023-03-31 19:52:34 +00:00
<link rel="stylesheet" href="https://syui.ai/bower_components/icomoon/css/icomoon.css" />
<link rel="stylesheet" href="https://syui.ai/bower_components/font-awesome/css/all.min.css" />
<div class="menu">
<a href="/" class="top-icon"><span class="icon-ai"></span></a>
<code v-if="loc === 'te'"><a href="https://bsky.app/profile/yui.syui.ai" target="_blank">@yui.syui.ai</a> /ten</code>
<code v-else-if="loc === 'pr'"><a href="https://bsky.app/profile/yui.syui.ai" target="_blank">@yui.syui.ai</a> /fav 1234567</code>
<code v-else-if="loc === 'docs' || loc === 'en'"><a href="https://bsky.app/profile/yui.syui.ai" target="_blank">@yui.syui.ai</a> /help</code>
<code v-else><a href="https://bsky.app/profile/yui.syui.ai" target="_blank">@yui.syui.ai</a> /card</code>
2023-03-31 19:51:52 +00:00
</div>
2023-03-31 19:52:34 +00:00
<div class="search-form">
<form @submit.prevent="page">
<input v-model="userid" placeholder="user" value="userid">
<input type="submit">
</form>
<form @submit.prevent="submit">
<input v-model="id" placeholder="id" value="id">
<input type="submit">
</form>
</div>
<p>
<a href="/docs"><button>help</button></a> <a href="/en"><button>en</button></a> <a href="/pr"><button>fav</button></a> <a href="/te"><button>ten</button></a> <button v-if="loc.length == 0" v-on:click="did_enable = !did_enable">did</button> <a v-else href="/di"><button>did</button></a>
</p>
<div v-if="loc.length > 1">
<div v-if="cards" class="bluesky-card">
<h3>
<span v-if="bsky_mode === true"><a :href='"https://bsky.app/profile/" + did' target="_blank">{{ loc }}</a></span>
<span v-else>{{ loc }}</span>
<span v-for="iii in rcards.data" class="card-owner-badge">
<a :href="'/owner#' + iii.id" v-if="iii.owner == loc" target="_blank"><span class="icon-ai"></span></a>
</span>
<span v-for="iii in rcards.data">
<span v-for="iiii in iii.owner" class="card-bluesky-badge">
<a :href="'/owner#' + iiii.user" v-if="iiii.user == loc" target="_blank">
<span class="icon-ai"></span>
</a>
</span>
</span>
<span v-if="this.all === true" class="card-all-badge">
<span class="icon-ai"></span>
</span>
<span v-if="cards.data.find((v) => v.card == 65)" class="card-room-badge">
<span class="icon-ai"></span>
</span>
<span v-if="this.badge_aiten === true" class="card-aiten-badge">
<span class="icon-power"></span>
</span>
</h3>
<div class="card-all-badge-bottom" >
<img src="/card/badge_1.png" v-if="cards.data.find((v) => v.card == 18)">
<img src="/card/badge_2.png" v-if="cards.data.find((v) => v.card == 41)">
<img src="/card/badge_3.png" v-if="cards.data.find((v) => v.card == 45)">
<img src="/card/badge_4.png" v-if="cards.data.find((v) => v.card == 75)">
<img src="/card/badge_5.png" v-if="cards.data.find((v) => v.card == 94)">
<img src="/card/badge_6.png" v-if="26 == (cards.data.filter((v) => v.card >= 96 && v.card <= 121).length)">
</div>
<div class="card_kira_center">
<button v-on:click="cardoriginstatus" class="card_origin_status"><span class="icon-ai"></span></button> <button v-if="cards.data.filter((v) => v.skill == '3d' && (v.card >= 0 && v.card <= 14 || v.card == 64))[0]" v-on:click="glb_status = !glb_status"><i class="fa-solid fa-star-half-stroke"></i></button> <button v-if="model == true || cards.data.filter((v) => v.skill == 'model').length >= 1" v-on:click="vrmviewer" class="unity"><i class="fa-solid fa-cube" id="vrm_button"></i></button>
</div>
<span class="card-fav" v-if="card_origin_status">
<span class="card-fav" v-for="k in cards.data">
<tr class="card-status-first" v-if="k.status == 'first' && k.card !== null" >
<span class="card-wrapper">
<span class="reflection">
<img :src='"/card/card_" + k.card + ".webp"' class="card">
</span>
<span class="card pattern"></span>
<span class="card color"></span>
<span class="card highlight"></span>
</span>
</tr>
<tr class="card-status-first" v-else-if="k.status == 'second' && k.card !== null">
<span class="card-wrapper">
<span class="reflection">
<img :src='"/card/card_" + k.card + ".webp"' class="card">
</span>
<span class="card pattern-s"></span>
<span class="card color-s"></span>
<span class="card highlight-s"></span>
</span>
</tr>
<tr class="card-status-first" v-else-if="k.status == 'third' && k.card !== null">
<span class="card-wrapper">
<span class="reflection">
<img :src='"/card/card_" + k.card + ".webp"' class="card">
</span>
<span class="card pattern-t"></span>
<span class="card color-t"></span>
<span class="card highlight-t"></span>
</span>
</tr>
<tr class="card-status-first" v-else-if="k.status == 'fourth' && k.card !== null">
<span class="card-wrapper">
<span class="reflection">
<img :src='"/card/card_" + k.card + ".webp"' class="card">
</span>
<span class="card pattern-f"></span>
<span class="card color-f"></span>
<span class="card highlight-f"></span>
</span>
</tr>
<tr class="card-status-first" v-else-if="k.status == 'yui' && k.card !== null">
<span class="card-wrapper">
<span class="reflection">
<img :src='"/card/card_" + k.card + ".webp"' class="card">
</span>
<span class="card pattern-yui"></span>
<span class="card color-yui"></span>
<span class="card highlight-yui"></span>
</span>
</tr>
</span>
</span>
<div class="vrm" v-if="iframe_status == true">
<iframe src="https://vrm.syui.ai" allowfullscreen frameborder="0"></iframe>
<table>
<tbody>
<tr>
<td>attack</td>
<td>{{ model_attack }}</td>
</tr>
<tr>
<td>critical</td>
<td>{{ model_critical }}</td>
</tr>
<tr>
<td>critical_d</td>
<td>{{ model_critical_d }}</td>
</tr>
</tbody>
</table>
</div>
<div class="glb" v-if="glb_status == true">
<model-viewer v-if="glb_next !== 0" class="ar" :src="'/obj/card_' + glb_next + '.glb'" ar-modes="scene-viewer webxr quick-look" auto-rotate autoplay ar camera-controls></model-viewer>
<model-viewer v-else class="ar" :src="'/obj/card_' + cards.data.filter((v) => v.skill == '3d' && (v.card >= 1 && v.card <= 14 || v.card == 64))[0].card + '.glb'" ar-modes="scene-viewer webxr quick-look" auto-rotate autoplay ar camera-controls></model-viewer>
<span v-for="(ii, index) in cards.data.filter((v) => v.skill == '3d' && (v.card >= 1 && v.card <= 14 || v.card == 64))" class="glb">
<img :src='"/card/card_" + ii.card + ".webp"' v-on:click="glb_next = ii.card">
</span>
</div>
<!--
first(ファースト) second(セカンド) third(サード) fourth(フォース) fifth(フィフス) sixth(スィクスス) seventh(セヴンス) eighth(エイトス) ninth(ナインス) tenth(テンス) eleventh(イレヴンス) twelfth(トウェルフス) thirteenth(サーティーンス) fifteenth(フィフティーンス) sixteenth(スィクスティーンス) seventeenth(セヴンティーンス) eighteenth(エイティーンス) nineteenth(ナインティーンス) twentieth(トウィンティイス)
-->
<span class="menu-right-top" v-if="cards.data.find((v) => v.card == 43)">
<button v-on:click="book_user = !book_user">book</button>
</span>
<div class="book-list" v-if="cards.data.find((v) => v.card == 43)" v-show="book_user">
<a href="/book/1/ZGlkOnBsYzo0aHFqZm43bTZuNWhubzNkb2FtdWhnZWY/index.html">
<img :src='"/card/card_" + 43 + ".webp"'>
</a>
</div>
<div class="book-list" v-if="cards.data.filter((v) => v.card >= 48 && v.card <= 59)" v-show="chara_user">
<span v-for="ii in cards.data.filter((v) => v.card >= 48 && v.card <= 59)" class="book-list">
<a :href="ii.url">
<img :src='"/card/card_" + ii.card + ".webp"'>
</a>
</span>
</div>
<div class="card-fav" v-if="user_fav != '0'"><span class="menu-right-top">
</span>
<table class="card-fav">
<span class="card-fav-su">
{{ ii = cards.data.find((v) => v.id == user_fav) }}
</span>
<thead v-if="ii.status == 'first' && ii.card !== null" class="card-fav">
<tr class="card-status-first">
<span class="card-wrapper">
<span class="reflection">
<img :src='"/card/card_" + ii.card + ".webp"' class="card">
</span>
<span class="card pattern"></span>
<span class="card color"></span>
<span class="card highlight"></span>
</span>
</tr>
</thead>
<thead v-else-if="ii.status == 'second' && ii.card !== null" class="card-fav">
<tr class="card-status-first">
<span class="card-wrapper">
<span class="reflection">
<img :src='"/card/card_" + ii.card + ".webp"' class="card">
</span>
<span class="card pattern-s"></span>
<span class="card color-s"></span>
<span class="card highlight-s"></span>
</span>
</tr>
</thead>
<thead v-else-if="ii.status == 'third' && ii.card !== null" class="card-fav">
<tr class="card-status-first">
<span class="card-wrapper">
<span class="reflection">
<img :src='"/card/card_" + ii.card + ".webp"' class="card">
</span>
<span class="card pattern-t"></span>
<span class="card color-t"></span>
<span class="card highlight-t"></span>
</span>
</tr>
</thead>
<thead v-else-if="ii.status == 'yui' && ii.card !== null" class="card-fav">
<tr class="card-status-first">
<span class="card-wrapper">
<span class="reflection">
<img :src='"/card/card_" + ii.card + ".webp"' class="card">
</span>
<span class="card pattern-yui"></span>
<span class="card color-yui"></span>
<span class="card highlight-yui"></span>
</span>
</tr>
</thead>
<thead v-else-if="ii.status == 'fourth' && ii.card !== null" class="card-fav">
<tr class="card-status-first">
<span class="card-wrapper">
<span class="reflection">
<img :src='"/card/card_" + ii.card + ".webp"' class="card">
</span>
<span class="card pattern-f"></span>
<span class="card color-f"></span>
<span class="card highlight-f"></span>
</span>
</tr>
</thead>
<thead v-else-if="ii.status == 'fifth' && ii.card !== null" class="card-fav">
<tr class="card-status-first">
<span class="card-wrapper">
<span class="reflection">
<img :src='"/card/card_" + ii.card + ".webp"' class="card">
</span>
<span class="card pattern-fifth"></span>
<span class="card color-fifth"></span>
<span class="card highlight-fifth"></span>
</span>
</tr>
</thead>
<thead v-else-if="ii.card !== null" class="card-fav">
<tr class="author" v-if="ii.author == 'yui'">
<img :src='"/card/card_origin2_" + ii.card + ".webp"'>
</tr>
<tr v-else-if="ii.author">
<img :src='"/card/card_origin_" + ii.card + ".webp"'>
</tr>
<tr v-else>
<img :src='"/card/card_" + ii.card + ".webp"'>
</tr>
</thead>
<tbody><tr v-if='ii.author'>@{{ ii.author }}</tr></tbody>
<tbody><tr><span v-if="ii.skill == 'critical'" class="icon-sandar"></span><span v-if="ii.skill == 'post'" class="icon-moon"></span><span v-if="ii.skill == 'luck'" class="icon-api"></span><span v-if="ii.skill == 'ten'" class="icon-power"></span><span v-if="ii.skill == 'lost'">●</span><span v-if="ii.skill == 'dragon'" class="icon-home"></span><span v-if="ii.skill == 'nyan'">▲</span><span v-if="ii.skill == 'yui'" class="icon-ai"></span><span v-if="ii.skill == '3d'"></span> {{ ii.cp }}</tr></tbody>
<tbody><tr class="card-fav-status"> {{ ii.status }}</tr></tbody>
<tbody v-if="info == true"><tr>ID {{ ii.card }}</tr>
<tr>CID {{ ii.id }}</tr></tbody>
</table>
</div>
<div class="card-button" >
<button v-on:click="cardtime">new</button> <button v-on:click="sort">cp</button> <button v-on:click="sortcard" >card</button> <button v-on:click="cardinfo">info</button>
</div>
<div class="menu-right"><code><strong>ID</strong> {{ id }}</code> <code><span class="icon-power"></span> {{ aiten }}</code> <code><i class="fa-solid fa-cube"></i> {{ cards.data.filter((v) => v.skill == 'lost').length }}</code>
<code class="moji-comp" v-if="26 == (cards.data.filter((v) => v.card >= 96 && v.card <= 121).length)" v-on:click="background_change"><span class="icon-ai"></span> {{ (cards.data.filter((v) => v.card >= 96 && v.card <= 121).length) }}</code>
<code v-else><span class="icon-ai"></span> {{ (cards.data.filter((v) => v.card >= 96 && v.card <= 121).length) }}</code>
</div>
<div class="moji" v-if="moji_status == true">
<table>
<thead>
<td v-for="(mm, index) in cards.data.filter((v) => v.card >= 96 && v.card <= 121)">
<img :src='"/card/card_" + mm.card + ".webp"'>
</td>
</thead>
</table>
</div>
<table id="card-box">
<span v-for="(ii, index) in cards.data">
<span v-if="ii.status == 'normal' && ii.card !== null">
<thead v-if="ii.card == 43">
<td v-if="ii.author == 'yui'" class="author">
<span class="author_card">@{{ ii.author }}</span>
<img :src='"/card/card_origin2_" + ii.card + ".webp"'>
</td>
<td v-else-if='ii.author' class="author">
<span class="author_card">@{{ ii.author }}</span>
<img :src='"/card/card_origin_" + ii.card + ".webp"'>
</td>
<td v-else>
<a href="/book/1/ZGlkOnBsYzo0aHFqZm43bTZuNWhubzNkb2FtdWhnZWY/index.html"><img :src='"/card/card_" + ii.card + ".webp"'></a>
</td>
</thead>
<thead v-else>
<td v-if="ii.author == 'yui'" class="author">
<span class="author_card">@{{ ii.author }}</span>
<img :src='"/card/card_origin2_" + ii.card + ".webp"'>
</td>
<td v-else-if='ii.author' class="author">
<span class="author_card">@{{ ii.author }}</span>
<img :src='"/card/card_origin_" + ii.card + ".webp"'>
</td>
<td v-else>
<img :src='"/card/card_" + ii.card + ".webp"'>
</td>
</thead>
<tbody><tr><span v-if="ii.skill == 'critical'" class="icon-sandar"></span><span v-if="ii.skill == 'post'" class="icon-moon"></span><span v-if="ii.skill == 'luck'" class="icon-api"></span><span v-if="ii.skill == 'ten'" class="icon-power"></span><span v-if="ii.skill == 'dragon'" class="icon-home"></span><span v-if="ii.skill == 'nyan'">▲</span><span v-if="ii.skill == 'yui'" class="icon-ai"></span><span v-if="ii.skill == '3d'">■</span><span v-if="ii.skill == 'model'"><i class="fa-solid fa-cube"></i></span> {{ ii.cp }}</tr></tbody>
<tbody v-if="info == true"><tr>ID {{ ii.card }}</tr>
<tr>CID {{ ii.id }}</tr>
<tr>{{ ii.skill }}</tr>
<tr> {{ ii.status }}</tr></tbody>
</span>
<span v-else-if="ii.card !== null">
<thead>
<td v-if="ii.author == 'yui'" class="author">
<span class="reflection" v-if="ii.card == 43">
<span class="author_card">@{{ ii.author }}</span>
<img :src='"/card/card_origin2_" + ii.card + ".webp"'>
</span>
<span class="reflection" v-else>
<span class="author_card">@{{ ii.author }}</span>
<img :src='"/card/card_origin2_" + ii.card + ".webp"'>
</span>
</td>
<td v-else-if='ii.author' class="author">
<span class="reflection" v-if="ii.card == 43">
<span class="author_card">@{{ ii.author }}</span>
<img :src='"/card/card_origin_" + ii.card + ".webp"'>
</span>
<span class="reflection" v-else>
<span class="author_card">@{{ ii.author }}</span>
<img :src='"/card/card_origin_" + ii.card + ".webp"'>
</span>
</td>
<td v-else>
<span class="reflection" v-if="ii.card == 43">
<a href="/book/1/ZGlkOnBsYzo0aHFqZm43bTZuNWhubzNkb2FtdWhnZWY/index.html"><img :src='"/card/card_" + ii.card + ".webp"'></a>
</span>
<span class="reflection" v-else-if="ii.skill == '3d'">
<a href="#thd_skill" class="thd_link"><img :src='"/card/card_" + ii.card + ".webp"'></a>
</span>
<!--ちらつき-->
<span v-else>
<img :src='"/card/card_" + ii.card + ".webp"'>
</span>
<!--ちらつき-->
</td>
</thead>
<tbody><tr><span v-if="ii.skill == 'critical'" class="icon-sandar"></span><span v-if="ii.skill == 'post'" class="icon-moon"></span><span v-if="ii.skill == 'luck'" class="icon-api"></span><span v-if="ii.skill == 'ten'" class="icon-power"></span><span v-if="ii.skill == 'dragon'" class="icon-home"></span><span v-if="ii.skill == 'nyan'">▲</span><span v-if="ii.skill == 'yui'" class="icon-ai"></span><span v-if="ii.skill == '3d'">■</span><span v-if="ii.skill == 'model'"><i class="fa-solid fa-cube"></i></span> {{ ii.cp }}</tr></tbody>
<tbody v-if="info == true"><tr>ID {{ ii.card }}</tr>
<tr>CID {{ ii.id }}</tr>
<tr>{{ ii.skill }}</tr>
<tr> {{ ii.status }}</tr></tbody>
</span>
</span>
</table>
</div>
</div>
<div v-if="loc === 'di'" class="text-content">
<h3>did</h3>
<blockquote class="did">
<p>
Decentralized identifiers (DIDs) are a new type of identifier that enables verifiable, decentralized digital identity. A DID refers to any subject (e.g., a person, organization, thing, data model, abstract entity, etc.) as determined by the controller of the DID. In contrast to typical, federated identifiers, DIDs have been designed so that they may be decoupled from centralized registries, identity providers, and certificate authorities. Specifically, while other parties might be used to help enable the discovery of information related to a DID, the design enables the controller of a DID to prove control over it without requiring permission from any other party. DIDs are URIs that associate a DID subject with a DID document allowing trustable interactions associated with that subject.
</p>
<p>
Each DID document can express cryptographic material, verification methods, or services, which provide a set of mechanisms enabling a DID controller to prove control of the DID. Services enable trusted interactions associated with the DID subject. A DID might provide the means to return the DID subject itself, if the DID subject is an information resource such as a data model.
</p>
<p>
This document specifies the DID syntax, a common data model, core properties, serialized representations, DID operations, and an explanation of the process of resolving DIDs to the resources that they represent.
</p>
</blockquote>
<p><a href="https://www.w3.org/TR/did-core/" target="_blank">https://www.w3.org/TR/did-core/</a> </p>
<p></p>
</div>
<div v-if="loc.length == 0">
<div v-if="cards" class="bluesky-card">
<p>user : <a :href='"/" + user.data.username'><code>{{ user.data.username }}</code></a></p>
<p>id : <code>{{ user.data.id }}</code></p>
<p>did : <code>{{ user.data.did }}</code></p>
<p>aiten : <code>{{ user.data.aiten }}</code></p>
<p>handle : <code>{{ user.data.handle }}</code></p>
<p v-if="user.data.delete == true">status : <code>delete</code></p>
<p>created_at : <code>{{ user.data.created_at }}</code></p>
<span v-for="ii in cards.data">
<img :src='"/card/card_" + ii.card + ".webp"'>{{ ii.cp }}
</span>
</div>
<div v-if="ucard" class="bluesky-card">
<h3><a :href='"/" + userid'>{{ userid }}</a></h3>
<span v-for="u in ucard.data">
<img :src='"/card/card_" + u.card + ".webp"'>{{ u.cp }}
</span>
</div>
<div v-if="record" class="bluesky-record">
<li v-for="i in record.data">
<p v-if="i.delete === false"><span class="menu-right-top">
<button v-if="i.model === true"><i class="fa-solid fa-cube"></i></button> <button v-if="i.fav != '0'">✧</button> <a :href="'https://git.syui.ai/' + i.username" target="_blank"><button v-if="i.username == 'ai'"><i class="fa-brands fa-git-alt"></i></button></a> <button>ID {{ i.id }}</button></span></p>
<p v-if="i.delete === false"><span class="text"><a :href="'/' + i.username">{{ i.username }}</a></span></p>
<span class="menu-right-did" v-if="i.delete === false && did_enable === true && i.did.includes('did:') === true">
<button><a :href="'https://plc.directory/' + i.did + '/log'" target="_blank">{{ i.did }}</a></button>
</span>
<span v-else-if="i.did.includes('http') === true && did_enable === true" class="menu-right-did" >
<button><a :href="i.did" target="_blank">{{ i.did }}</a></button>
</span>
</li>
</div>
</div>
<div v-if="loc === 'vr'" class="text-content">
<h3>3Dモデル</h3>
<p>アイの3Dモデルを育成することができます</p>
<p>モデルを有効にするには <i class="fa-solid fa-cube"></i> カードが必要になります</p>
<p><i class="fa-solid fa-cube"></i> カードは低確率で排出されます</p>
<h3>動作環境</h3>
<table>
<thead>
<tr>
<th>ios/safari</th>
</tr>
</thead>
<tbody>
<tr>
<td>ios17</td>
<td class="green">ok</td>
</tr>
<tr>
<td>ios16</td>
<td class="red">no</td>
</tr>
</tbody>
</table>
<p><li>Allow WebGL in Web Workers</li></p>
<p><li>GPU Process: Canvas Rendering</li></p>
<p><li>GPU Process: DOM Rendering</li></p>
<p><li>OffscreenCanvas in Workers</li></p>
<p><li>OffscreenCanvas</li></p>
<table>
<thead>
<tr>
<th>pc</th>
</tr>
</thead>
<tbody>
<tr>
<td>chrome/chromium</td>
<td class="green">ok</td>
</tr>
<tr>
<td>edge</td>
<td class="green">ok</td>
</tr>
<tr>
<td>safari</td>
<td class="green">yes</td>
</tr>
<tr>
<td>firefox</td>
<td class="red">no</td>
</tr>
</tbody>
</table>
<h3>天性レベル</h3>
<p>それぞれの天性レベルはモデルになったカードに属します</p>
<table>
<thead>
<tr>
</tr>
</thead>
<tbody>
<tr>
<td>モード</td>
<td>アタック</td>
<td>スキル</td>
<td>バースト</td>
</tr>
<tr>
<td>card:2</td>
<td>card:9</td>
<td>card:3</td>
<td>card:7</td>
</tr>
</tbody>
</table>
<p>他で使用するカードの効果が天性レベルx10されることがあります</p>
<p>モデルが有効であれば<code>/ten pay</code>でレベルを上げられます</p>
<table>
<thead>
<tr>
<th>正式名称</th>
</tr>
</thead>
<tbody>
<tr>
<td>mode</td>
<td>attack</td>
<td>skill</td>
<td>burst (limit)</td>
</tr>
<tr>
<td>アイモード</td>
<td>通常攻撃</td>
<td>原子スキル</td>
<td>原子バースト</td>
</tr>
</tbody>
</table>
<h3>固有天性</h3>
<p>キャラごとに固有天性が3つあります</p>
<table>
<thead>
<tr>
<th>固有天性</th>
</tr>
</thead>
<tbody>
<tr>
<td>量子テレポート</td>
<td>記憶した場所に移動</td>
</tr>
<tr>
<td>電子浮遊</td>
<td>空を飛べる</td>
</tr>
<tr>
<td>大気バリア</td>
<td>空間の影響を受けない</td>
</tr>
</tbody>
</table>
<h3>会心系</h3>
<p>ステータスには会心率と会心ダメージがあります</p>
<p><code>/ten</code>で勝利するとステータスが上がります</p>
<table>
<thead>
<tr>
<th>会心系</th>
</tr>
</thead>
<tbody>
<tr>
<td>会心率</td>
<td>会心ダメージ</td>
</tr>
<tr>
<td>+1%</td>
<td>+10%</td>
</tr>
</tbody>
</table>
<h3>その他</h3>
<p>キャラのレベルはlostのカード数によって算出されます</p>
</div>
<div v-if="loc === 'docs'" class="text-content">
<p>カードは1日に1回引くことができます</p>
<p>カードの排出率は以下のとおりです</p>
<table>
<thead>
<tr>
<th>status</th>
</tr>
</thead>
<tbody>
<tr>
<td>normal</td>
<td>rare</td>
<td>super</td>
</tr>
<tr>
<td>90%</td>
<td>9%</td>
<td>1%</td>
</tr>
</tbody>
</table>
<p>カードには強さを表す数字が入っています</p>
<table>
<thead>
<tr>
<th>cp</th>
</tr>
</thead>
<tbody>
<tr>
<td>normal</td>
<td>rare</td>
<td>super</td>
</tr>
<tr>
<td>+0~200</td>
<td>+0~450</td>
<td>+0~800</td>
</tr>
</tbody>
</table>
<h3>対戦について</h3>
<p><code>@yui.syui.ai /card -b</code></p>
<p>ランダムマッチ手持ちの上位3枚のうち1枚がランダムで選ばれます</p>
<h3>レイドについて</h3>
<p><code>@yui.syui.ai /card -r</code></p>
<p>レイドバトル手持ちで一番強いカードが選ばれます</p>
<h3>mastodon</h3>
<p><code><a href="https://mstdn.syui.ai/@yui" target="_blank">@yui@syui.ai</a> /card</code></p>
<p>mastodonからもカードを引くことができます</p>
<p>ユーザー名が同じの場合カードは共通です</p>
<h3>activitypub mode</h3>
<p><code>@yui.syui.ai /card ap=false</code></p>
<p>bsky.socialからactivitypub modeを<code>true</code>/<code>false</code>に切り替える</p>
<h3>秘密</h3>
<p><code>レアカード</code>を3枚集めるといいことがあるかも</p>
<p>集めた人は<a href="https://bsky.app/profile/syui.ai">@syui</a>まで連絡してみて</p>
<p>ただしリアルカードに変わるのはこちらの<a href="/owner">所有者</a>がいないカードに限られます</p>
<h3>link</h3>
<p><a class="menu-link" href="/fa">fanart</a> <a class="menu-link" href="/ph">photo</a> <a class="menu-link" href="/te">aiten</a> <a class="menu-link" href="/pr">fav</a> <a class="menu-link" href="/vr">model</a></p>
</div>
<div v-if="loc === 'en'" class="text-content">
<p>Cards can be drawn once a day</p>
<p>Card emission rates are as follows</p>
<table>
<thead>
<tr>
<th>status</th>
</tr>
</thead>
<tbody>
<tr>
<td>normal</td>
<td>rare</td>
<td>super</td>
</tr>
<tr>
<td>90%</td>
<td>9%</td>
<td>1%</td>
</tr>
</tbody>
</table>
<p>The cards have numbers(cp) on them indicating their strength.</p>
<table>
<thead>
<tr>
<th>cp</th>
</tr>
</thead>
<tbody>
<tr>
<td>normal</td>
<td>rare</td>
<td>super</td>
</tr>
<tr>
<td>+0~200</td>
<td>+0~450</td>
<td>+0~800</td>
</tr>
</tbody>
</table>
<h3>battle</h3>
<p><code>@yui.syui.ai /card -b</code></p>
<p>Random match, one of the top 3 cards on hand will be chosen at random</p>
<h3>mastodon</h3>
<p><code><a href="https://mstdn.syui.ai/@yui" target="_blank">@yui@syui.ai</a> /card</code></p>
<p>support mastodon</p>
<h3>activitypub</h3>
<p><code>@yui.syui.ai /card ap=false</code></p>
<p>activitypub mode disable</p>
<h3>secret</h3>
<p>card <a href="/owner">owner</a></p>
<h3>link</h3>
<p><a class="menu-link" href="/fa">fanart</a> <a class="menu-link" href="/ph">photo</a> <a class="menu-link" href="/te">aiten</a> <a class="menu-link" href="/pr">fav</a></p>
</div>
<div v-if="loc === 'owner'" class="text-content">
<div v-for="(ii, index) in rcards.data">
<div v-show="ii.id !== 0">
<div v-show="ii.id < 15" class="card-owner-one">
<button :id="ii.id">card : {{ii.id }} / {{ ii.h }}</button>
<p><img :src='"/card/card_" + ii.id + ".webp"'></p>
<p v-if="ii.owner">owner : <a :href="'/' + ii.owner">{{ ii.owner }}</a></p>
<p v-if="ii.owner === null">owner : none</p>
</div>
<div v-show="ii.id == 22" class="card-owner-one">
<button :id="ii.id">card : {{ii.id }} / {{ ii.h }}</button>
<span v-if='ii.owner == "none"' class="card-black">
<p><img :src='"/card/card_" + ii.id + ".webp"'></p>
</span>
<span v-else>
<p><img :src='"/card/card_" + ii.id + ".webp"'></p>
</span>
<p v-if="ii.owner">owner : <a :href="'/' + ii.owner">{{ ii.owner }}</a></p>
<p v-if="ii.owner === null">owner : none</p>
</div>
<div v-show="ii.id == 25" class="card-owner-one">
<button :id="ii.id">card : {{ii.id }} / {{ ii.h }}</button>
<p><img :src='"/card/card_" + ii.id + ".webp"'></p>
<p v-if="ii.owner">owner : <a :href="'/' + ii.owner">{{ ii.owner }}</a></p>
<p v-if="ii.owner === null">owner : none</p>
</div>
<div v-show="ii.id == 26" class="card-owner-one">
<button :id="ii.id">card : {{ii.id }} / {{ ii.h }}</button>
<p><img :src='"/card/card_" + ii.id + ".webp"'></p>
<p v-if="ii.owner">owner : <a :href="'/' + ii.owner">{{ ii.owner }}</a></p>
<p v-if="ii.owner === null">owner : none</p>
</div>
<div v-show="ii.id == 27" class="card-owner-one">
<button :id="ii.id">card : {{ii.id }} / {{ ii.h }}</button>
<span v-if='ii.owner == "none"' class="card-black">
<p><img :src='"/card/card_" + ii.id + ".webp"'></p>
</span>
<span v-else>
<p><img :src='"/card/card_" + ii.id + ".webp"'></p>
</span>
<p v-if="ii.owner">owner : <a :href="'/' + ii.owner">{{ ii.owner }}</a></p>
<p v-if="ii.owner === null">owner : none</p>
</div>
<div v-show="ii.id == 29" class="card-owner-one">
<button :id="ii.id">card : {{ii.id }} / {{ ii.h }}</button>
<span v-if='ii.owner == "none"' class="card-black">
<p><img :src='"/card/card_" + ii.id + ".webp"'></p>
</span>
<span v-else>
<p><img :src='"/card/card_" + ii.id + ".webp"'></p>
</span>
<p v-if="ii.owner">owner : <a :href="'/' + ii.owner">{{ ii.owner }}</a></p>
<p v-if="ii.owner === null">owner : none</p>
</div>
<div v-show="ii.id == 33" class="card-owner-one">
<button :id="ii.id">card : {{ii.id }} / {{ ii.h }}</button>
<span v-if='ii.owner == "none"' class="card-black">
<p><img :src='"/card/card_" + ii.id + ".webp"'></p>
</span>
<span v-else>
<p><img :src='"/card/card_" + ii.id + ".webp"'></p>
</span>
<p v-if="ii.owner">owner : <a :href="'/' + ii.owner">{{ ii.owner }}</a></p>
<p v-if="ii.owner === null">owner : none</p>
</div>
<div v-show="ii.id == 36" class="card-owner-one">
<button :id="ii.id">card : {{ii.id }} / {{ ii.h }}</button>
<span v-if='ii.owner == "none"' class="card-black">
<p><img :src='"/card/card_" + ii.id + ".webp"'></p>
</span>
<span v-else>
<p><img :src='"/card/card_" + ii.id + ".webp"'></p>
</span>
<p v-if="ii.owner">owner : <a :href="'/' + ii.owner">{{ ii.owner }}</a></p>
<p v-if="ii.owner === null">owner : none</p>
</div>
<div v-show="ii.id == 39" class="card-owner-one">
<button :id="ii.id">card : {{ii.id }} / {{ ii.h }}</button>
<p><img :src='"/card/card_" + ii.id + ".webp"'></p>
<p v-if="ii.owner">owner :<span v-for="(iii, index) in ii.owner"> <a :href="'/' + iii.user">{{ iii.user }}</a>, </span></p>
<p v-if="ii.owner === null">owner : none</p>
</div>
<div v-show="ii.id == 40" class="card-owner-one">
<button :id="ii.id">card : {{ii.id }} / {{ ii.h }}</button>
<p><img :src='"/card/card_" + ii.id + ".webp"'></p>
<p v-if="ii.owner">owner :<span v-for="(iii, index) in ii.owner"> <a :href="'/' + iii.user">{{ iii.user }}</a>, </span></p>
<p v-if="ii.owner === null">owner : none</p>
</div>
<div v-show="ii.id == 41" class="card-owner-one">
<button :id="ii.id">card : {{ii.id }} / {{ ii.h }}</button>
<p><img :src='"/card/card_" + ii.id + ".webp"'></p>
<p v-if="ii.owner">owner : <a :href="'/' + ii.owner">{{ ii.owner }}</a></p>
<p v-if="ii.owner === null">owner : none</p>
</div>
<div v-show="ii.id == 44" class="card-owner-one">
<button :id="ii.id">card : {{ii.id }} / {{ ii.h }}</button>
<p><img :src='"/card/card_" + ii.id + ".webp"'></p>
<p v-if="ii.owner">owner : <a :href="'/' + ii.owner">{{ ii.owner }}</a></p>
<p v-if="ii.owner === null">owner : none</p>
</div>
<div v-show="ii.id == 45" class="card-owner-one">
<button :id="ii.id">card : {{ii.id }} / {{ ii.h }}</button>
<p><img :src='"/card/card_" + ii.id + ".webp"'></p>
<p v-if="ii.owner">owner :<span v-for="(iii, index) in ii.owner"> <a :href="'/' + iii.user">{{ iii.user }}</a>, </span></p>
<p v-if="ii.owner === null">owner : none</p>
</div>
</div>
</div>
</div>
<div v-if="loc === 'te'" class="text-content">
<div class="iten-start">
<h3><span class="icon-power"></span> AITEN</h3>
</div>
<div v-for="(ii, index) in rcards.data">
<div v-show="ii.id !== 0">
<div v-show="ii.id < 15" class="card-owner-one">
<p :id="ii.id"><button>id:{{ ii.id }}</button></p>
<p :id="ii.id">[{{ ii.ten }}] {{ ii.h }} / {{ ii.id }}00</p>
<p><img :src='"/card/card_" + ii.id + ".webp"'></p>
</div>
<div v-show="ii.id == 29 || ii.id == 33 || ii.id == 36 || ii.id == 46 || ii.id == 47 || ii.id == 60 || ii.id == 64 || ii.id == 67 || ii.id == 69 || ii.id == 76 || ii.id == 77 || ii.id == 78|| ii.id == 86|| ii.id == 89 || ii.id == 90 || ii.id == 95||ii.id == 121" class="card-owner-one">
<p :id="ii.id"><button>id:{{ ii.id }}</button></p>
<p :id="ii.id">[{{ ii.ten }}] {{ ii.h }} / {{ ii.id }}00 <span class="icon-power"></span></p>
<p><img :src='"/card/card_" + ii.id + ".webp"'></p>
</div>
</div>
</div>
</div>
<div v-if="loc === 'te'" class="text-content">
<div class="iten-start">
<p><code>/ten h</code> : ヘルプ</p>
<p><code>/ten start</code> : 7ターンまでに文字をそろえる</p>
<p><span class="icon-power"></span> はカードを持ってる人しか出せない</p>
<blockquote>ACEHIKMOSTUWYZ</blockquote>
</div>
</div>
<div v-if="loc === 'fa'" class="text-content">
<p><code>/fa &lt;share-url&gt; &lt;img-url&gt;</code></p>
<span v-for="(iii, index) in fanarts.data" class="fan-body">
<div class="viewer" v-if="iii.delete !== true">
<p><a :href="iii.link"><img :src="iii.img"/></a></p>
<p>author : <a :href="'https://bsky.app/profile/' + iii.author">{{ iii.author }}</a></p>
</div>
</span>
</div>
<div v-if="loc === 'ph'" class="text-content">
<p><code>/ph &lt;share-url&gt; &lt;img-url&gt;</code></p>
<span v-for="(iii, index) in photos.data" class="fan-body">
<div class="viewer" v-if="iii.delete !== true">
<p><a :href="iii.link"><img :src="iii.img"/></a></p>
<p>author : <a :href="'https://bsky.app/profile/' + iii.author">{{ iii.author }}</a></p>
</div>
</span>
2023-03-31 19:51:52 +00:00
</div>
2023-03-31 19:52:34 +00:00
<div v-if="loc === 'pr'" class="text-content">
<p>お気に入りのカードを1枚だけ登録できます</p>
<p>数字は自身のカードボックスにある <button>info</button> で確認します</p>
<p><img src="/img/docs_fav.jpg"></p>
<p>下記のコマンドを実行して登録します</p>
<p><code>@yui.syui.ai /fav 1</code></p>
<p>もとに戻すときは <code>0</code> を指定します</p>
<p><code>/fav b</code>でバトルできます</p>
<p>1日のバトルポイントを消費します</p>
</div>
<footer>
© syui
</footer>
2023-03-31 19:51:52 +00:00
</div>
</template>
<script>
import axios from 'axios'
2023-03-31 19:52:34 +00:00
import moment from "moment";
var loc = window.location.pathname.split('/').slice(-1)[0];
2023-03-31 19:51:52 +00:00
export default {
name: "App",
2023-03-31 19:52:34 +00:00
metaInfo() {
if (loc) {
return {
title: "card.syui.ai",
titleTemplate: '%s/' + loc,
meta: [
{property: 'og:title', content: '%s/' + loc}
]
}
} else {
return {
title: "card.syui.ai",
titleTemplate: '%s',
meta: [
{property: 'og:title', content: '%s'}
]
}
}
2023-03-31 19:51:52 +00:00
},
data () {
return {
2023-03-31 19:52:34 +00:00
host: window.location.host,
all: null,
badge_aiten: null,
2023-03-31 19:51:52 +00:00
card: null,
cards: null,
2023-03-31 19:52:34 +00:00
loc: window.location.pathname.split('/').slice(-1)[0],
2023-03-31 19:51:52 +00:00
id: null,
2023-03-31 19:52:34 +00:00
model: null,
2023-03-31 19:51:52 +00:00
record: null,
url: null,
user: null,
2023-03-31 19:52:34 +00:00
userid: null,
ucard: null,
status: null,
premium: false,
premium_text: null,
rcards: null,
fanarts: null,
photos: null,
info: false,
time: null,
aiten: null,
fav: null,
card_fav: null,
user_fav: null,
book_user: null,
glb_status: false,
glb_next: 0,
moji_status: false,
did_enable: null,
chara_user: null,
card_sed: false,
card_status: null,
card_skill: null,
model_attack: null,
model_critical: null,
model_critical_d: null,
game_lv: null,
api_url: null,
bsky_mode: false,
did: null,
card_origin_status: false,
useragent: window.navigator.userAgent.toLowerCase(),
iframe_status: false,
sort_key: null,
2023-03-31 19:51:52 +00:00
}
},
2023-03-31 19:52:34 +00:00
components: {
2023-03-31 19:51:52 +00:00
},
2023-03-31 19:52:34 +00:00
filters: {
moment: function(date) {
return moment.unix(date).format("YYYY.MM.DD");
2023-03-31 19:51:52 +00:00
},
2023-03-31 19:52:34 +00:00
},
mounted() {
this.loadComponent();
if (window.location.host === "localhost:8080") {
this.api_url = "/api/";
} else if (window.location.host === "192.168.11.12:8080"){
this.api_url = "/api/";
} else {
if (location.protocol !== "https:") {
location.replace("https:" + location.href.substring(location.protocol.length));
}
this.api_url = "https://api.syui.ai/";
}
if (loc === 'owner' || loc === 'te'){
axios
.get("/json/card.json")
.then(response => (this.rcards = response));
if (loc.length > 1){
axios
.get(url,{ crossdomain: true })
.then(response => (this.cards = response));
}
} else if (loc === 'fa'){
axios
.get("/json/fanart.json")
.then(response => (this.fanarts = response));
} else if (loc === 'ph'){
2023-03-31 19:51:52 +00:00
axios
2023-03-31 19:52:34 +00:00
.get("/json/photo.json")
.then(response => (this.photos = response));
} else {
let url = this.api_url + "users?itemsPerPage=3000";
axios.get(url,{ crossdomain: true })
.then(response => {
this.record = response;
this.id = this.record.data.find((v) => v.username == loc).id;
this.model = this.record.data.find((v) => v.username == loc).model;
this.did = this.record.data.find((v) => v.username == loc).did;
this.aiten = this.record.data.find((v) => v.username == loc).aiten;
this.bsky_mode = this.record.data.find((v) => v.username == loc).bsky;
this.user_fav = this.record.data.find((v) => v.username == loc).fav;
this.game_lv = this.record.data.find((v) => v.username == loc).game_lv;
this.model_attack = this.record.data.find((v) => v.username == loc).model_attack;
this.model_critical = this.record.data.find((v) => v.username == loc).model_critical;
this.model_critical_d = this.record.data.find((v) => v.username == loc).model_critical_d;
this.user_room = this.record.data.find((v) => v.username == loc).room;
let url = this.api_url + "users/" + this.id + "/card?itemsPerPage=3000";
axios
.get("/json/card.json")
.then(response => (this.rcards = response));
if (loc.length > 1){
axios
.get(url,{ crossdomain: true })
.then(response => { this.cards = response
for (let i = 1; i <= 14; i++) {
this.all = this.cards.data.some(
b => b.card === i,
);
if (this.all === false) {
break;
}
}
for (let i = 65; i <= 67; i++) {
this.badge_aiten = this.cards.data.some(
b => b.card === i,
);
if (this.badge_aiten === false) {
break;
}
}
});
}
})
.catch(error => console.log(error));
}},
computed: {
loadComponent() {
return () => import('@google/model-viewer');
}
},
methods: {
submit() {
let url = this.api_url + "users/" + this.id + "/card?itemsPerPage=3000";
axios
.get(url,{ crossdomain: true })
.then(response => (this.cards = response));
axios
.get(this.api_url + "users/" + this.id,{ crossdomain: true })
.then(response => (this.user = response));
},
page() {
this.id = this.record.data.find((v) => v.username == this.userid).id;
let url = this.api_url + "users/" + this.id + "/card?itemsPerPage=4000";
axios
.get(url,{ crossdomain: true })
.then(response => (this.ucard = response));
//window.location.href = '/' + this.user;
},
sort(){
if (this.premium) {
this.premium = false;
let url = this.api_url + "users/" + this.id + "/card?itemsPerPage=4000";
}
return this.cards.data.sort((a, b) => {
return b.cp - a.cp;
});
},
sortcard(){
if (this.premium) {
this.premium = false;
}
return this.cards.data.sort((a, b) => {
return b.card - a.card;
});
},
sortBy(key) {
this.sort_key = key;
},
tagsort(){
this.memo.sort(function(a,b){
if(a.updatedTs < b.updatedTs) return -1;
if(a.updatedTs > b.updatedTs) return 1;
return 0;
});
},
cardinfo(){
this.cards = {};
let url = this.api_url + "users/" + this.id + "/card?itemsPerPage=4000";
axios
.get(url,{ crossdomain: true })
.then(response => (this.cards = response));
if (this.info == false) {
this.info = true;
} else {
this.info = false;
}
},
cardtime(){
this.cards.data = this.cards.data.slice().reverse();
this.time = true;
},
cardurl(){
return this.cards.data.sort((a,b) => {
this.premium = true;
if (a.url !== "https://card.syui.ai") {
this.cards.data = this.cards.data.slice().reverse();
} else {
a.url = null;
a.card = null;
}
});
},
cardoriginstatus() {
if (this.card_origin_status == false) {
this.card_origin_status = true;
} else {
this.card_origin_status = false;
}
},
background_change() {
let e = document.body;
if (this.moji_status == true) {
this.moji_status = false;
e.style.backgroundColor = '#f1f1f1';
} else {
this.moji_status = true;
e.style.backgroundColor = '#343434';
}
},
vrmviewer() {
if (this.iframe_status == false) {
this.iframe_status = true;
} else {
this.iframe_status = false;
}
}
2023-03-31 19:51:52 +00:00
}
}
</script>
<style>
2023-03-31 19:52:34 +00:00
body{
background-color: #f1f1f1;
font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
font-size: 18px;
}
a {
color: #847e00;
text-decoration: none;
}
a:hover {
color: #008CCF;
}
a.menu-link {
line-height: 100px;
background-color:#fff;
padding: 10px;
}
2023-03-31 19:51:52 +00:00
div#app {
list-style: none;
2023-03-31 19:52:34 +00:00
margin: 0 100px;
2023-03-31 19:51:52 +00:00
}
.bluesky-avatar img {
width: 55px;
}
span.time {
color: blue;
}
span.name {
font-weight: 700;
background-color: #a3c3ff1a;
padding:10px;
}
span.text {
font-weight: 400;
font-size: 19px;
}
2023-03-31 19:52:34 +00:00
2023-03-31 19:51:52 +00:00
.bluesky-record p {
padding:0 20px 0;
}
.bluesky-record {
border-radius: 10px;
2023-03-31 19:52:34 +00:00
margin: 50px 0px 0 0;
2023-03-31 19:51:52 +00:00
}
2023-03-31 19:52:34 +00:00
2023-03-31 19:51:52 +00:00
footer#footer {
text-align: center;
}
span.text {
word-break: break-all;
}
p.tl-avatar img {
width: 20px;
}
2023-03-31 19:52:34 +00:00
2023-03-31 19:51:52 +00:00
img {
2023-03-31 19:52:34 +00:00
width: 200px;
border-radius: 7px;
2023-03-31 19:51:52 +00:00
}
code {
2023-03-31 19:52:34 +00:00
line-height: 100px;
padding: 10px 20px;
background-color: #fff;
margin: 0 10px 0 10px;
2023-03-31 19:51:52 +00:00
}
2023-03-31 19:52:34 +00:00
2023-03-31 19:51:52 +00:00
li {
list-style-type: none;
2023-03-31 19:52:34 +00:00
background-color: #fff;
padding:10px;
margin:10px 0px;
}
footer {
margin : 100px;
text-align: center;
}
span.card-owner-badge a {
color: #abae00;
padding:0 5px;
}
span.card-bluesky-badge a {
color: #0db2ff;
padding:0 5px;
}
span.card-all-badge {
color: #ff7c00;
padding:0 5px;
}
span.card-aiten-badge {
color: #abae00;
padding:0 5px;
}
span.card-room-badge {
text-shadow: rgba(0, 0, 0, 0.77) 0px 0 5px;
color: #fff700;
padding:0 5px;
}
.card-all-badge-bottom img {
padding: 0 7px 0 0;
width:25px;
}
blockquote {
background-color: #abae00;
margin: 0px;
padding: 20px 50px;
text-align: center;
color: #fff;
}
.menu span.icon-ai {
color: #fff700;
font-size: 23px;
padding: 10px;
}
.card-owner-one {
background-color: #fff;
padding: 2px 15px;
margin-bottom: 15px;
}
.menu-right-top {
float: right;
padding:0px 0px 0px 5px;
}
.menu-right-did {
padding:0px 0px 0px 5px;
}
.menu-right-did a {
color: #f1f1f1;
}
span.menu-right-top a.menu-link span.icon-ai {
color: #ccc;
}
thead.card-fav {
background-color: #fff;
}
tbody {
padding: 10px;
background-color: #fff;
}
table {
margin-bottom: 2em;
margin-top: 2em;
width: 100%;
border-spacing: 15px;
text-align: center;
}
table.card-fav {
border-spacing: 2px;
}
tr {
line-height:40px;
}
button {
padding:3px 10px;
border-radius: 2px;
border: solid 1px #847e00;
background-color: #847e00;
color: #fff;
}
button:hover {
border: solid 1px #f1f1f1;
}
.card-button {
float: right;
}
.bluesky-card h3 {
margin-top: 60px;
}
span.card-fav-su {
display:none;
}
span.pattern-s {
background: repeating-radial-gradient(circle at -150% -25%, #000, #777 3px, #000 3px);
background-position: 50% 50%;
background-size: 120% 120%;
mix-blend-mode: color-dodge;
opacity: 0.3;
}
span.color-s {
background: linear-gradient(115deg, transparent 20%, #000 30%, transparent 48% 52%, #000 70%, transparent);
background-position: 50% 50%;
background-size: 200% 200%;
mix-blend-mode: overlay;
}
span.card-wrapper:hover > span.pattern-s {
background-position: calc(50% + (var(--ratio-x) * -50%)) calc(50% + (var(--ratio-y) * -50%));
}
span.card-wrapper:hover > span.color-s {
background-position: calc(50% + (var(--ratio-x) * -50%)) calc(50% + (var(--ratio-y) * -50%));
}
span.card-wrapper:hover > span.highlight-s {
background-repeat: no-repeat;
}
span.pattern-t {
background: repeating-radial-gradient(circle at -150% -25%, #c71585, #777 3px, #ffff00 3px);
background-position: 50% 50%;
background-size: 120% 120%;
mix-blend-mode: color-dodge;
opacity: 0.3;
}
span.color-t {
background: linear-gradient(115deg, transparent 20%, #c71585 30%, transparent 48% 52%, #c71585 70%, transparent);
background-position: 50% 50%;
background-size: 200% 200%;
mix-blend-mode: overlay;
}
span.card-wrapper:hover > span.pattern-t {
background-position: calc(50% + (var(--ratio-x) * -50%)) calc(50% + (var(--ratio-y) * -50%));
}
span.card-wrapper:hover > span.color-t {
background-position: calc(50% + (var(--ratio-x) * -50%)) calc(50% + (var(--ratio-y) * -50%));
2023-03-31 19:51:52 +00:00
}
2023-03-31 19:52:34 +00:00
span.card-wrapper:hover > span.highlight-t {
background-repeat: no-repeat;
}
span.pattern-yui {
background: repeating-radial-gradient(circle at -150% -25%, #ffff00, #000 3px, #ffff00 3px);
background-position: 50% 50%;
background-size: 120% 120%;
mix-blend-mode: color-dodge;
opacity: 0.3;
}
span.color-yui {
background: linear-gradient(115deg, transparent 20%, #ffff00 30%, transparent 48% 52%, #ffff00 70%, transparent);
background-position: 50% 50%;
background-size: 200% 200%;
mix-blend-mode: overlay;
}
span.card-wrapper:hover > span.pattern-yui {
background-position: calc(50% + (var(--ratio-x) * -50%)) calc(50% + (var(--ratio-y) * -50%));
}
span.card-wrapper:hover > span.color-yui {
background-position: calc(50% + (var(--ratio-x) * -50%)) calc(50% + (var(--ratio-y) * -50%));
}
span.card-wrapper:hover > span.highlight-yui {
background-repeat: no-repeat;
}
span.pattern-f {
background: repeating-radial-gradient(circle at -150% -25%, #000, #32cd32 3px, #1e90ff 3px);
background-position: 50% 50%;
background-size: 120% 120%;
mix-blend-mode: color-dodge;
opacity: 0.3;
}
span.color-f {
background: linear-gradient(115deg, transparent 20%, #00ffff 30%, transparent 48% 52%, #40e0d0 70%, transparent);
background-position: 50% 50%;
background-size: 200% 200%;
mix-blend-mode: overlay;
}
span.card-wrapper:hover > span.pattern-f {
background-position: calc(50% + (var(--ratio-x) * -50%)) calc(50% + (var(--ratio-y) * -50%));
}
span.card-wrapper:hover > span.color-f {
background-position: calc(50% + (var(--ratio-x) * -50%)) calc(50% + (var(--ratio-y) * -50%));
}
span.pattern-fifth {
background: repeating-radial-gradient(circle at -150% -25%, #000, #990033 3px, #990033 3px);
background-position: 50% 50%;
background-size: 120% 120%;
mix-blend-mode: color-dodge;
opacity: 0.3;
}
span.color-fifth {
background: linear-gradient(115deg, transparent 20%, #FF0000 30%, transparent 48% 52%, #990033 70%, transparent);
background-position: 50% 50%;
background-size: 200% 200%;
mix-blend-mode: overlay;
}
span.card-wrapper:hover > span.pattern-fifth {
background-position: calc(50% + (var(--ratio-x) * -50%)) calc(50% + (var(--ratio-y) * -50%));
}
span.card-wrapper:hover > span.color-fifth {
background-position: calc(50% + (var(--ratio-x) * -50%)) calc(50% + (var(--ratio-y) * -50%));
}
span.card-wrapper:hover > span.highlight-yui {
background-repeat: no-repeat;
}
span.pattern {
background: repeating-radial-gradient(circle at -150% -25%, #fff, #777 3px, #fff 3px);
background-position: 50% 50%;
background-size: 120% 120%;
mix-blend-mode: color-dodge;
opacity: 0.3;
}
span.color {
background: linear-gradient(115deg, transparent 20%, #40A4BF 30%, transparent 48% 52%, #404FBF 70%, transparent);
background-position: 50% 50%;
background-size: 200% 200%;
mix-blend-mode: overlay;
}
span.card-wrapper:hover > span.pattern {
background-position: calc(50% + (var(--ratio-x) * -50%)) calc(50% + (var(--ratio-y) * -50%));
}
span.card-wrapper:hover > span.color {
background-position: calc(50% + (var(--ratio-x) * -50%)) calc(50% + (var(--ratio-y) * -50%));
}
span.card-wrapper:hover > span.highlight {
background: radial-gradient(circle at calc(var(--ratio-x) * 100%) calc(var(--ratio-y) * 100%), hsl(0 0% 100% / 0.2), transparent 50%);
background-repeat: no-repeat;
}
img.card {
transform: translateY(6px);
}
span.card {
aspect-ratio: 5/7;
border-radius: 7px;
box-shadow: 0px 4px 8px rgba(0, 0, 0, .2);
position: absolute;
width: 100%;
height: 96%;
}
span.card-wrapper {
display: grid;
place-items: center;
position: absolute;
}
tr.card-status-first {
place-items: center;
position: relative;
display: grid;
margin: 0;
position: relative;
height: calc(40vh);
}
span.reflection{
display: block;
position:relative;
overflow:hidden;
}
span.reflection:after {
content:"";
height:100%;
width:30px;
position:absolute;
top:-180px;
left:0;
background-color: #ffffffa8;
opacity:0;
-webkit-transform: rotate(45deg);
-webkit-animation: reflection 4s ease-in-out infinite;
}
@keyframes reflection {
0% { -webkit-transform: scale(0) rotate(45deg); opacity: 0; }
80% { -webkit-transform: scale(0) rotate(45deg); opacity: 0.5; }
81% { -webkit-transform: scale(4) rotate(45deg); opacity: 1; }
100% { -webkit-transform: scale(50) rotate(45deg); opacity: 0; }
}
.viewer {
background-color: #fff;
margin: 10px 0px;
padding: 20px;
}
span.card-black p {
width: fit-content;
background: #000;
}
span.card-black p img {
opacity: 0.7;
}
.book-list {
background-color:#fff;
margin-bottom: 30px;
padding:10px 50px 10px 50px;
}
.book-list a img {
width:150px;
}
thead.card-fav tr img {
border-radius: 30px;
padding: 20px;
}
span.book-list {
padding:10px;
}
.memo-body-content {
background-color:#fff;
padding: 10px 30px 10px 30px;
margin-bottom: 15px;
}
p.memo-time {
text-align: right;
}
.card-all-badge-bottom {
margin: 0 0 10px 0;
}
.memo-body-content p code {
background-color: #f1f1f1;
padding: 4px 5px 4px 5px;
margin: 2px;
border-radius: 4px;
}
span.author_card {
position: absolute;
font-size: 9px;
transform: scale(0.7);
width: 200px;
bottom: 2%;
color:#1f1f1f;
-webkit-text-size-adjust: 100%;
}
td.author {
position: relative;
}
.card_kira_center {
text-align: center;
margin: 10px 0 30px 0;
}
.card_kira_center button {
background-color: #343434;
}
button.card_origin_status {
border-radius: 2px;
background-color: #343434;
}
button.card_origin_status:hover {
color:#ffff00;
}
a.top-icon {
padding:0 5px 0 15px;
}
model-viewer {
text-align: center;
align-content: center;
width: auto;
height: 330px;
}
model-viewer.ar {
padding-bottom : 20px;
}
.sed_relative {
position: relative;
}
img.sed_model {
position: absolute;
width: 50px;
top: 50px;
left: 85px;
}
.vrm_button {
text-align: center;
padding: 0px 0px 50px 0px;
}
i#vrm_button {
font-size: 26px;
color: #fff;
}
iframe {
width: 100%;
height: 600px;
}
button.unity {
background-color: #343434;
}
button.unity i#vrm_button {
font-size:13px;
}
button.unity i#vrm_button:hover {
color: #fff700;
}
.text-content {
padding: 50px;
margin: 30px;
}
2023-03-31 19:51:52 +00:00
@media screen and (max-width:1000px) {
2023-03-31 19:52:34 +00:00
tr.card-status-first {
height: calc(45vh);
}
.card-button {
float: none;
margin-bottom: 20px;
}
.moji {
display: none;
}
.text-content{
padding: 50px 0 50px 0;
margin: 30px 0 30px 0;
}
div#app{list-style:none;margin:0px}
.bluesky-avatar img{width:55px}
span.time{color:#00f}
span.name{background-color:rgba(163,195,255,.10196078431372549);padding:10px}
.bluesky-record li{}
.bluesky-record p{padding:0 20px 0}
.bluesky-record{border-radius:10px;margin:0px 0px 0 0}
footer#footer{text-align:center}
2023-03-31 19:51:52 +00:00
span.text {
word-break: break-all;
}
2023-03-31 19:52:34 +00:00
code {
padding: 10px;
background-color: #fff;
margin: 0 10px 0 10px;
}
.book-list {
text-align: center;
}
span.author_card {
font-size: 3px;
-webkit-text-size-adjust: 300%;
}
}
@media screen and (min-width:1800px) {
tr.card-status-first {
height: calc(30vh);
}
}
@media screen and (min-width:2000px) {
tr.card-status-first {
height: calc(25vh);
}
}
td.red {
background-color:#FFCCCC;
}
td.green {
background-color:#CCFF00;
}
code.moji-comp {
color: #fff700;
background-color: #000;
}
.moji {
background-color:#343434;
}
.moji img {
width: 100%;
}
.menu {
background-color: #343434;
margin: 0 0 30px 0;
color: #f1f1f1;
}
.menu code {
background-color: #343434;
padding: 0;
}
.menu code a {
color: #fff700;
}
.menu code a:hover {
color: #847e00;
}
.menu a:hover span.icon-ai{
color: #847e00;
}
.search-form {
float: right;
}
span.menu-right-top a:hover button {
color: #343434;
}
.glb {
text-align: center;
}
.glb img {
width: 66px;
}
span.glb {
margin:5px;
}
.menu-right code {
padding: 0;
word-break: break-all;
}
blockquote.did {
background-color: #fff;
color: #000;
text-align: left;
2023-03-31 19:51:52 +00:00
}
</style>