chat button

prompt/act-as-tech-troubleshooter
f 2 weeks ago
parent 768a390e9b
commit 72df762e87

@ -340,6 +340,18 @@
margin: 0; margin: 0;
font-size: 0.95rem; font-size: 0.95rem;
opacity: 0.8; opacity: 0.8;
display: flex;
flex-direction: column;
gap: 0.3rem;
}
.platform-hint {
font-size: 0.75rem;
opacity: 0.6;
margin: 0;
}
.platform-pills {
display: flex; display: flex;
gap: 0.5rem; gap: 0.5rem;
align-items: center; align-items: center;
@ -356,6 +368,7 @@
color: var(--accent-color); color: var(--accent-color);
border: 1px solid var(--accent-color); border: 1px solid var(--accent-color);
text-decoration: none; text-decoration: none;
cursor: pointer;
transition: all 0.2s ease; transition: all 0.2s ease;
} }
@ -364,14 +377,55 @@
transform: translateY(-1px); transform: translateY(-1px);
} }
.platform-tag.active {
background: var(--accent-color);
color: white;
transform: translateY(-1px);
}
.dark-mode .platform-tag { .dark-mode .platform-tag {
background: rgba(16, 185, 129, 0.2); background: rgba(16, 185, 129, 0.2);
} }
.dark-mode .platform-tag:hover {
background: rgba(16, 185, 129, 0.25);
}
.dark-mode .platform-tag.active {
background: var(--accent-color);
}
.dark-mode .site-description { .dark-mode .site-description {
color: var(--text-color-dark); color: var(--text-color-dark);
} }
.action-buttons {
display: flex;
gap: 8px;
align-items: center;
}
.chat-button {
background: transparent;
border: none;
cursor: pointer;
padding: 2px;
color: var(--accent-color);
opacity: 0.8;
transition: opacity 0.2s ease;
z-index: 2;
flex-shrink: 0;
}
.chat-button:hover {
opacity: 1;
}
.chat-button svg {
width: 16px;
height: 16px;
}
.layout-wrapper { .layout-wrapper {
display: flex; display: flex;
flex-direction: column; flex-direction: column;
@ -777,12 +831,50 @@
margin-top: 20px; margin-top: 20px;
padding-top: 16px; padding-top: 16px;
border-top: 1px solid #e1e4e8; border-top: 1px solid #e1e4e8;
display: flex;
justify-content: space-between;
align-items: center;
} }
.dark-mode .modal-footer { .dark-mode .modal-footer {
border-color: #2d2d2d; border-color: #2d2d2d;
} }
.modal-footer-left {
display: flex;
align-items: center;
gap: 8px;
}
.modal-footer-right {
display: flex;
align-items: center;
gap: 12px;
}
.modal-chat-button {
display: flex;
align-items: center;
gap: 6px;
padding: 6px 12px;
border-radius: 6px;
font-size: 0.9rem;
background: var(--accent-color);
color: white;
border: none;
cursor: pointer;
transition: all 0.2s ease;
}
.modal-chat-button:hover {
background: var(--accent-color-hover);
}
.modal-chat-button svg {
width: 16px;
height: 16px;
}
.modal-contributor { .modal-contributor {
font-size: 0.8rem; font-size: 0.8rem;
color: var(--accent-color); color: var(--accent-color);
@ -913,11 +1005,15 @@
<h1 class="site-title">prompts.chat</h1> <h1 class="site-title">prompts.chat</h1>
<p class="site-slogan">World's First & Most Famous Prompts Directory</p> <p class="site-slogan">World's First & Most Famous Prompts Directory</p>
<div class="site-description"> <div class="site-description">
<a href="https://chat.openai.com" target="_blank" class="platform-tag">ChatGPT</a> <p class="platform-hint">Choose your AI platform</p>
<a href="https://claude.ai/new" target="_blank" class="platform-tag">Claude</a> <div class="platform-pills">
<a href="https://gemini.google.com" target="_blank" class="platform-tag">Gemini</a> <button class="platform-tag" data-platform="chatgpt" data-url="https://chat.openai.com">ChatGPT</button>
<a href="https://meta.ai" target="_blank" class="platform-tag">Llama</a> <button class="platform-tag" data-platform="claude" data-url="https://claude.ai/new">Claude</button>
<a href="https://chat.mistral.ai" target="_blank" class="platform-tag">Mistral</a> <button class="platform-tag" data-platform="perplexity" data-url="https://perplexity.ai">Perplexity</button>
<button class="platform-tag" data-platform="gemini" data-url="https://gemini.google.com">Gemini</button>
<button class="platform-tag" data-platform="llama" data-url="https://meta.ai">Llama</button>
<button class="platform-tag" data-platform="mistral" data-url="https://chat.mistral.ai/chat">Mistral</button>
</div>
</div> </div>
</div> </div>
<div class="header-right"> <div class="header-right">
@ -1286,8 +1382,8 @@
const promptElements = document.querySelectorAll('h2[id^=act] + p + blockquote'); const promptElements = document.querySelectorAll('h2[id^=act] + p + blockquote');
promptElements.forEach((blockquote) => { promptElements.forEach((blockquote) => {
const title = blockquote.previousElementSibling.previousElementSibling.textContent; const title = blockquote.previousElementSibling.previousElementSibling.textContent.trim();
const content = blockquote.textContent; const content = blockquote.textContent.trim();
// Extract contributor from the paragraph element // Extract contributor from the paragraph element
const contributorParagraph = blockquote.previousElementSibling; const contributorParagraph = blockquote.previousElementSibling;
@ -1325,12 +1421,19 @@
card.innerHTML = ` card.innerHTML = `
<div class="prompt-title"> <div class="prompt-title">
${title} ${title}
<button class="copy-button" title="Copy prompt"> <div class="action-buttons">
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"> <button class="chat-button" title="Open in AI Chat" onclick="openInChat(this, '${encodeURIComponent(content.trim())}')">
<rect x="9" y="9" width="13" height="13" rx="2" ry="2"></rect> <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round">
<path d="M5 15H4a2 2 0 0 1-2-2V4a2 2 0 0 1 2-2h9a2 2 0 0 1 2 2v1"></path> <path d="M21 15a2 2 0 0 1-2 2H7l-4 4V5a2 2 0 0 1 2-2h14a2 2 0 0 1 2 2z"></path>
</svg> </svg>
</button> </button>
<button class="copy-button" title="Copy prompt" onclick="copyPrompt(this, '${encodeURIComponent(content.trim())}')">
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round">
<path d="M16 4h2a2 2 0 0 1 2 2v14a2 2 0 0 1-2 2H6a2 2 0 0 1-2-2V6a2 2 0 0 1 2-2h2"></path>
<rect x="8" y="2" width="8" height="4" rx="1" ry="1"></rect>
</svg>
</button>
</div>
</div> </div>
<p class="prompt-content">${content}</p> <p class="prompt-content">${content}</p>
<a href="https://github.com/${contributor}" class="contributor-badge" target="_blank" rel="noopener">@${contributor}</a> <a href="https://github.com/${contributor}" class="contributor-badge" target="_blank" rel="noopener">@${contributor}</a>
@ -1420,7 +1523,17 @@
</div> </div>
<div class="modal-content"></div> <div class="modal-content"></div>
<div class="modal-footer"> <div class="modal-footer">
<a class="modal-contributor" target="_blank" rel="noopener"></a> <div class="modal-footer-left">
<a class="modal-contributor" target="_blank" rel="noopener"></a>
</div>
<div class="modal-footer-right">
<button class="modal-chat-button" onclick="openModalChat()">
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round">
<path d="M21 15a2 2 0 0 1-2 2H7l-4 4V5a2 2 0 0 1 2-2h14a2 2 0 0 1 2 2z"></path>
</svg>
Start Chat
</button>
</div>
</div> </div>
</div> </div>
</div> </div>
@ -1440,12 +1553,32 @@
const modalContent = modalOverlay.querySelector('.modal-content'); const modalContent = modalOverlay.querySelector('.modal-content');
const modalCopyButton = modalOverlay.querySelector('.modal-copy-button'); const modalCopyButton = modalOverlay.querySelector('.modal-copy-button');
const modalContributor = modalOverlay.querySelector('.modal-contributor'); const modalContributor = modalOverlay.querySelector('.modal-contributor');
const modalChatButton = modalOverlay.querySelector('.modal-chat-button');
if (!modalTitle || !modalContent) return; if (!modalTitle || !modalContent) return;
modalTitle.textContent = title; modalTitle.textContent = title;
modalContent.textContent = content; modalContent.textContent = content;
// Update chat button text with platform name and handle visibility
const platform = document.querySelector('.platform-tag.active');
if (platform) {
const shouldHideChat = ['gemini', 'llama'].includes(platform.dataset.platform);
modalChatButton.style.display = shouldHideChat ? 'none' : 'flex';
if (!shouldHideChat) {
modalChatButton.innerHTML = `
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round">
<path d="M21 15a2 2 0 0 1-2 2H7l-4 4V5a2 2 0 0 1 2-2h14a2 2 0 0 1 2 2z"></path>
</svg>
Chat with ${platform.textContent}
`;
}
}
// Store content for chat button
modalChatButton.dataset.content = content;
// Find the contributor for this prompt // Find the contributor for this prompt
const promptCard = Array.from(document.querySelectorAll('.prompt-card')).find(card => const promptCard = Array.from(document.querySelectorAll('.prompt-card')).find(card =>
card.querySelector('.prompt-title').textContent.trim() === title.trim() card.querySelector('.prompt-title').textContent.trim() === title.trim()
@ -1495,6 +1628,90 @@
// Optional: Remove modal from DOM when hidden // Optional: Remove modal from DOM when hidden
modalOverlay.remove(); modalOverlay.remove();
} }
let selectedPlatform = localStorage.getItem('selected-platform') || 'chatgpt'; // Get from localStorage or default to chatgpt
// Platform toggle functionality
document.querySelectorAll('.platform-tag').forEach(button => {
button.addEventListener('click', () => {
document.querySelectorAll('.platform-tag').forEach(btn => btn.classList.remove('active'));
button.classList.add('active');
selectedPlatform = button.dataset.platform;
localStorage.setItem('selected-platform', selectedPlatform);
// Hide/show chat buttons based on platform
const chatButtons = document.querySelectorAll('.chat-button, .modal-chat-button');
const shouldHideChat = ['gemini', 'llama'].includes(selectedPlatform);
chatButtons.forEach(btn => {
btn.style.display = shouldHideChat ? 'none' : 'flex';
});
});
});
// Set active platform from localStorage and handle initial button visibility
const platformToActivate = document.querySelector(`[data-platform="${selectedPlatform}"]`) ||
document.querySelector('[data-platform="chatgpt"]');
platformToActivate.classList.add('active');
// Set initial chat button visibility
const shouldHideChat = ['gemini', 'llama'].includes(selectedPlatform);
document.querySelectorAll('.chat-button, .modal-chat-button').forEach(btn => {
btn.style.display = shouldHideChat ? 'none' : 'flex';
});
// Function to open prompt in selected AI chat platform
function openInChat(button, encodedPrompt) {
const promptText = decodeURIComponent(encodedPrompt);
const platform = document.querySelector('.platform-tag.active');
if (!platform) return;
const baseUrl = platform.dataset.url;
let url;
switch (platform.dataset.platform) {
case 'chatgpt':
url = `${baseUrl}?prompt=${encodeURIComponent(promptText)}`;
break;
case 'claude':
url = `${baseUrl}?q=${encodeURIComponent(promptText)}`;
break;
case 'perplexity':
url = `${baseUrl}/search?q=${encodeURIComponent(promptText)}`;
break;
case 'mistral':
url = `${baseUrl}?q=${encodeURIComponent(promptText)}`;
break;
default:
url = `${baseUrl}?q=${encodeURIComponent(promptText)}`;
}
window.open(url, '_blank');
}
// Existing copy function
async function copyPrompt(button, encodedPrompt) {
const promptText = decodeURIComponent(encodedPrompt);
try {
await navigator.clipboard.writeText(promptText);
const originalHTML = button.innerHTML;
button.innerHTML = '<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M20 6L9 17l-5-5"/></svg>';
setTimeout(() => {
button.innerHTML = originalHTML;
}, 1000);
} catch (err) {
console.error('Failed to copy text: ', err);
}
}
// Function to handle chat button click in modal
function openModalChat() {
const modalContent = document.querySelector('.modal-content');
if (modalContent) {
const content = modalContent.textContent;
openInChat(null, encodeURIComponent(content.trim()));
}
}
</script> </script>
<style>video { max-width: 100% !important; }</style> <style>video { max-width: 100% !important; }</style>
<!-- Google tag (gtag.js) --> <!-- Google tag (gtag.js) -->

Loading…
Cancel
Save