update: 2026-03-28 20:59
This commit is contained in:
64
InfoGenie-frontend/public/60sapi/实用功能/配色方案.html
Normal file
64
InfoGenie-frontend/public/60sapi/实用功能/配色方案.html
Normal file
@@ -0,0 +1,64 @@
|
||||
<!DOCTYPE html>
|
||||
<html lang="zh-CN">
|
||||
<head>
|
||||
<meta charset="UTF-8"><meta name="viewport" content="width=device-width,initial-scale=1">
|
||||
<title>配色方案</title>
|
||||
<style>
|
||||
*{margin:0;padding:0;box-sizing:border-box}
|
||||
body{font-family:'KaiTi','楷体',serif;background:#f9fafb;color:#1f2937;line-height:1.6;min-height:100vh}
|
||||
.header{background:linear-gradient(135deg,#065f46,#059669);color:#fff;padding:16px;display:flex;align-items:center;gap:12px;position:sticky;top:0;z-index:10}
|
||||
.header h1{flex:1;font-size:16px;font-weight:700}.btn{width:36px;height:36px;border:none;border-radius:10px;background:rgba(255,255,255,.15);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px}.btn:hover{background:rgba(255,255,255,.25)}
|
||||
.body{max-width:720px;margin:0 auto;padding:20px 16px 40px}
|
||||
.form{display:flex;flex-direction:column;gap:10px;margin-bottom:20px;background:#fff;border-radius:16px;padding:20px;box-shadow:0 1px 4px rgba(0,0,0,.05)}
|
||||
.form label{font-size:12px;font-weight:600;color:#6b7280}
|
||||
.form input{padding:11px 14px;border:2px solid #e5e7eb;border-radius:10px;font-size:13px;font-family:inherit;transition:border-color .2s}
|
||||
.form input:focus{border-color:#4ade80;outline:none}
|
||||
.form button{display:inline-flex;align-items:center;justify-content:center;gap:5px;padding:11px 22px;border:none;border-radius:10px;background:linear-gradient(135deg,#4ade80,#22c55e);color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}
|
||||
.form button:hover{transform:translateY(-1px)}.form button:disabled{opacity:.5;cursor:not-allowed;transform:none}
|
||||
.info-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px}
|
||||
.info-card{background:#fff;border-radius:12px;padding:14px 16px;box-shadow:0 1px 3px rgba(0,0,0,.04)}
|
||||
.info-label{font-size:11px;color:#9ca3af;margin-bottom:3px}.info-val{font-size:14px;font-weight:600;word-break:break-all}
|
||||
.quote{background:linear-gradient(135deg,#f0fdf4,#ecfdf5);border-radius:20px;padding:28px 20px;text-align:center;border:1px solid rgba(34,197,94,.12)}
|
||||
.quote-text{font-size:16px;line-height:2;color:#374151;font-weight:500}
|
||||
.loader{display:flex;flex-direction:column;align-items:center;padding:40px 0;color:#9ca3af;gap:10px;font-size:13px}
|
||||
.spinner{width:24px;height:24px;border:3px solid #e5e7eb;border-top-color:#059669;border-radius:50%;animation:spin 1s linear infinite}
|
||||
@keyframes spin{to{transform:rotate(360deg)}}
|
||||
.err{text-align:center;padding:20px;color:#ef4444;font-size:14px}
|
||||
</style>
|
||||
<script src="/60sapi/ig-embed.js"></script>
|
||||
<script src="/60sapi/sixty-runtime.js"></script>
|
||||
</head>
|
||||
<body>
|
||||
<div class="header">
|
||||
<button class="btn" onclick="history.back()">←</button>
|
||||
<h1>🎨 配色方案</h1>
|
||||
</div>
|
||||
<div class="body">
|
||||
<div class="form" id="formArea"><label>基础色</label>
|
||||
<input id="input_color" placeholder="如 #4ade80" onkeydown="if(event.key==='Enter')query()">
|
||||
<button onclick="query()" id="submitBtn">🔍 查询</button></div>
|
||||
<div id="result"></div>
|
||||
</div>
|
||||
<script>
|
||||
async function query(){
|
||||
const params=new URLSearchParams({encoding:'json'});
|
||||
const v_color=document.getElementById('input_color').value.trim();if(v_color)params.set('color',v_color);
|
||||
|
||||
const el=document.getElementById('result');
|
||||
const btn=document.getElementById('submitBtn');
|
||||
btn.disabled=true;btn.textContent='查询中...';
|
||||
el.innerHTML='<div class="loader"><div class="spinner"></div><span>查询中...</span></div>';
|
||||
try{
|
||||
const res=await fetch(window.__SIXTY_API_BASE__+'/v2/color/palette?'+params.toString(),{headers:{Accept:'application/json'}});
|
||||
const json=await res.json();
|
||||
const d=json.data!==undefined?json.data:json;
|
||||
if(typeof d==='string'){el.innerHTML=`<div class="quote"><div class="quote-text">${d}</div></div>`;return}
|
||||
if(Array.isArray(d)){let h='';d.forEach((item,i)=>{const t=item.title||item.name||String(item);h+=`<div class="info-card"><div class="info-label">#${i+1}</div><div class="info-val">${t}</div></div>`});el.innerHTML=`<div class="info-grid">${h}</div>`;return}
|
||||
if(d&&typeof d==='object'){const entries=Object.entries(d).filter(([k])=>!['code','ok','api_updated'].includes(k));let h='';entries.forEach(([k,v])=>{h+=`<div class="info-card"><div class="info-label">${k}</div><div class="info-val">${typeof v==='object'?JSON.stringify(v):String(v)}</div></div>`});el.innerHTML=`<div class="info-grid">${h}</div>`;return}
|
||||
el.innerHTML=`<div class="quote"><div class="quote-text">${String(d)}</div></div>`;
|
||||
}catch(e){el.innerHTML=`<div class="err">查询失败:${e.message}</div>`}
|
||||
finally{btn.disabled=false;btn.textContent='🔍 查询'}
|
||||
}
|
||||
</script>
|
||||
</body>
|
||||
</html>
|
||||
Reference in New Issue
Block a user