Added Open Graph Generator
This commit is contained in:
25
index.html
25
index.html
@@ -1,10 +1,31 @@
|
|||||||
<!doctype html>
|
<!doctype html>
|
||||||
<html lang="en">
|
<html lang="ru">
|
||||||
<head>
|
<head>
|
||||||
<meta charset="UTF-8" />
|
<meta charset="UTF-8" />
|
||||||
<link rel="icon" type="image/svg+xml" href="/vite.svg" />
|
<link rel="icon" type="image/svg+xml" href="/vite.svg" />
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
||||||
<title>Code Formatter</title>
|
|
||||||
|
<!-- Primary Meta Tags -->
|
||||||
|
<title>Code Formatter - Форматирование JSON и SQL</title>
|
||||||
|
<meta name="title" content="Code Formatter - Форматирование JSON и SQL" />
|
||||||
|
<meta name="description" content="Онлайн инструмент для форматирования и валидации JSON и SQL кода. Быстро, удобно, бесплатно." />
|
||||||
|
|
||||||
|
<!-- Open Graph / Facebook -->
|
||||||
|
<meta property="og:type" content="website" />
|
||||||
|
<meta property="og:url" content="https://formatter.abaidulin.ru/" />
|
||||||
|
<meta property="og:title" content="Code Formatter - Форматирование JSON и SQL" />
|
||||||
|
<meta property="og:description" content="Онлайн инструмент для форматирования и валидации JSON и SQL кода. Быстро, удобно, бесплатно." />
|
||||||
|
<meta property="og:image" content="https://formatter.abaidulin.ru/og-image.png" />
|
||||||
|
<meta property="og:image:width" content="1200" />
|
||||||
|
<meta property="og:image:height" content="630" />
|
||||||
|
|
||||||
|
<!-- Twitter -->
|
||||||
|
<meta property="twitter:card" content="summary_large_image" />
|
||||||
|
<meta property="twitter:url" content="https://formatter.abaidulin.ru/" />
|
||||||
|
<meta property="twitter:title" content="Code Formatter - Форматирование JSON и SQL" />
|
||||||
|
<meta property="twitter:description" content="Онлайн инструмент для форматирования и валидации JSON и SQL кода. Быстро, удобно, бесплатно." />
|
||||||
|
<meta property="twitter:image" content="https://formatter.abaidulin.ru/og-image.png" />
|
||||||
|
|
||||||
<!-- Google Fonts -->
|
<!-- Google Fonts -->
|
||||||
<link rel="preconnect" href="https://fonts.googleapis.com">
|
<link rel="preconnect" href="https://fonts.googleapis.com">
|
||||||
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
|
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
|
||||||
|
|||||||
143
og-preview-generator.html
Normal file
143
og-preview-generator.html
Normal file
@@ -0,0 +1,143 @@
|
|||||||
|
<!DOCTYPE html>
|
||||||
|
<html lang="ru">
|
||||||
|
<head>
|
||||||
|
<meta charset="UTF-8">
|
||||||
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||||
|
<title>OG Image Generator</title>
|
||||||
|
<style>
|
||||||
|
body {
|
||||||
|
margin: 0;
|
||||||
|
padding: 20px;
|
||||||
|
background: #f0f0f0;
|
||||||
|
font-family: Arial, sans-serif;
|
||||||
|
}
|
||||||
|
.preview-container {
|
||||||
|
max-width: 1200px;
|
||||||
|
margin: 0 auto;
|
||||||
|
}
|
||||||
|
.og-image {
|
||||||
|
width: 1200px;
|
||||||
|
height: 630px;
|
||||||
|
background: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%);
|
||||||
|
position: relative;
|
||||||
|
overflow: hidden;
|
||||||
|
box-shadow: 0 10px 40px rgba(0,0,0,0.3);
|
||||||
|
}
|
||||||
|
.bracket-left {
|
||||||
|
position: absolute;
|
||||||
|
left: 60px;
|
||||||
|
top: 50px;
|
||||||
|
font-family: 'Courier New', monospace;
|
||||||
|
font-size: 180px;
|
||||||
|
color: #0f4c75;
|
||||||
|
opacity: 0.2;
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
.bracket-right {
|
||||||
|
position: absolute;
|
||||||
|
right: 60px;
|
||||||
|
bottom: 50px;
|
||||||
|
font-family: 'Courier New', monospace;
|
||||||
|
font-size: 180px;
|
||||||
|
color: #0f4c75;
|
||||||
|
opacity: 0.2;
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
.content {
|
||||||
|
position: relative;
|
||||||
|
z-index: 2;
|
||||||
|
text-align: center;
|
||||||
|
padding-top: 150px;
|
||||||
|
}
|
||||||
|
.title {
|
||||||
|
font-size: 84px;
|
||||||
|
font-weight: bold;
|
||||||
|
color: #ffffff;
|
||||||
|
margin: 0;
|
||||||
|
text-shadow: 2px 2px 4px rgba(0,0,0,0.5);
|
||||||
|
}
|
||||||
|
.subtitle {
|
||||||
|
font-size: 42px;
|
||||||
|
color: #3282b8;
|
||||||
|
margin: 30px 0;
|
||||||
|
}
|
||||||
|
.features {
|
||||||
|
font-family: 'Courier New', monospace;
|
||||||
|
font-size: 32px;
|
||||||
|
color: #bbe1fa;
|
||||||
|
margin: 40px 0;
|
||||||
|
}
|
||||||
|
.url {
|
||||||
|
font-family: 'Courier New', monospace;
|
||||||
|
font-size: 28px;
|
||||||
|
color: #3282b8;
|
||||||
|
margin-top: 60px;
|
||||||
|
}
|
||||||
|
.instructions {
|
||||||
|
margin-top: 30px;
|
||||||
|
padding: 20px;
|
||||||
|
background: white;
|
||||||
|
border-radius: 8px;
|
||||||
|
max-width: 1200px;
|
||||||
|
margin-left: auto;
|
||||||
|
margin-right: auto;
|
||||||
|
}
|
||||||
|
.instructions h2 {
|
||||||
|
margin-top: 0;
|
||||||
|
}
|
||||||
|
.instructions code {
|
||||||
|
background: #f5f5f5;
|
||||||
|
padding: 2px 6px;
|
||||||
|
border-radius: 3px;
|
||||||
|
font-family: monospace;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<div class="preview-container">
|
||||||
|
<div class="og-image" id="ogImage">
|
||||||
|
<div class="bracket-left">{</div>
|
||||||
|
<div class="bracket-right">}</div>
|
||||||
|
<div class="content">
|
||||||
|
<h1 class="title">Code Formatter</h1>
|
||||||
|
<div class="subtitle">Форматирование JSON и SQL</div>
|
||||||
|
<div class="features">✓ Валидация ✓ Подсветка ✓ Минификация</div>
|
||||||
|
<div class="url">formatter.abaidulin.ru</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="instructions">
|
||||||
|
<h2>Инструкция по созданию og-image.png:</h2>
|
||||||
|
<ol>
|
||||||
|
<li>Откройте эту страницу в браузере</li>
|
||||||
|
<li>Сделайте скриншот области выше (1200x630px)</li>
|
||||||
|
<li>Или используйте инструменты разработчика:
|
||||||
|
<ul>
|
||||||
|
<li>Откройте DevTools (F12)</li>
|
||||||
|
<li>Введите в консоль команды ниже</li>
|
||||||
|
</ul>
|
||||||
|
</li>
|
||||||
|
<li>Сохраните как <code>og-image.png</code></li>
|
||||||
|
<li>Поместите в папку <code>/Users/at/python/claude-example/formatter/public/</code></li>
|
||||||
|
</ol>
|
||||||
|
|
||||||
|
<h3>Автоматическая генерация через консоль браузера:</h3>
|
||||||
|
<pre><code>const element = document.getElementById('ogImage');
|
||||||
|
html2canvas(element).then(canvas => {
|
||||||
|
const link = document.createElement('a');
|
||||||
|
link.download = 'og-image.png';
|
||||||
|
link.href = canvas.toDataURL();
|
||||||
|
link.click();
|
||||||
|
});
|
||||||
|
// Примечание: требуется библиотека html2canvas</code></pre>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
console.log('Для автоматического сохранения можно использовать:');
|
||||||
|
console.log('1. Расширение браузера для скриншотов');
|
||||||
|
console.log('2. Онлайн сервисы: opengraph.xyz, og-image.vercel.app');
|
||||||
|
console.log('3. Команду: npm install -g pageres-cli && pageres og-preview-generator.html 1200x630 --filename=og-image');
|
||||||
|
</script>
|
||||||
|
</body>
|
||||||
|
</html>
|
||||||
27
public/og-image.svg
Normal file
27
public/og-image.svg
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
<svg width="1200" height="630" xmlns="http://www.w3.org/2000/svg">
|
||||||
|
<defs>
|
||||||
|
<linearGradient id="bg" x1="0%" y1="0%" x2="100%" y2="100%">
|
||||||
|
<stop offset="0%" style="stop-color:#1a1a2e;stop-opacity:1" />
|
||||||
|
<stop offset="100%" style="stop-color:#16213e;stop-opacity:1" />
|
||||||
|
</linearGradient>
|
||||||
|
</defs>
|
||||||
|
|
||||||
|
<!-- Background -->
|
||||||
|
<rect width="1200" height="630" fill="url(#bg)"/>
|
||||||
|
|
||||||
|
<!-- Decorative code brackets -->
|
||||||
|
<text x="100" y="150" font-family="monospace" font-size="120" fill="#0f4c75" opacity="0.3">{</text>
|
||||||
|
<text x="1050" y="500" font-family="monospace" font-size="120" fill="#0f4c75" opacity="0.3">}</text>
|
||||||
|
|
||||||
|
<!-- Main title -->
|
||||||
|
<text x="600" y="250" font-family="Arial, sans-serif" font-size="72" font-weight="bold" fill="#ffffff" text-anchor="middle">Code Formatter</text>
|
||||||
|
|
||||||
|
<!-- Subtitle -->
|
||||||
|
<text x="600" y="330" font-family="Arial, sans-serif" font-size="36" fill="#3282b8" text-anchor="middle">Форматирование JSON и SQL</text>
|
||||||
|
|
||||||
|
<!-- Features -->
|
||||||
|
<text x="600" y="420" font-family="monospace" font-size="28" fill="#bbe1fa" text-anchor="middle">✓ Валидация ✓ Подсветка синтаксиса ✓ Минификация</text>
|
||||||
|
|
||||||
|
<!-- URL -->
|
||||||
|
<text x="600" y="520" font-family="monospace" font-size="24" fill="#3282b8" text-anchor="middle">formatter.abaidulin.ru</text>
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 1.3 KiB |
Reference in New Issue
Block a user