forked from React-Group/interstellar_ai
Merge branch 'main' of interstellardevelopment.org:React-Group/interstellar_ai
This commit is contained in:
commit
238e82bb95
15 changed files with 806 additions and 501 deletions
|
@ -11,6 +11,7 @@ import {
|
||||||
checkCredentials,
|
checkCredentials,
|
||||||
deleteAccount,
|
deleteAccount,
|
||||||
} from '../backend/database';
|
} from '../backend/database';
|
||||||
|
import { equal } from 'assert';
|
||||||
|
|
||||||
const Settings: React.FC<{ closeSettings: () => void; accountName: string }> = ({ closeSettings, accountName }) => {
|
const Settings: React.FC<{ closeSettings: () => void; accountName: string }> = ({ closeSettings, accountName }) => {
|
||||||
|
|
||||||
|
@ -85,9 +86,43 @@ const Settings: React.FC<{ closeSettings: () => void; accountName: string }> = (
|
||||||
const [fontFamily, setFontFamily] = useState(() => getComputedStyle(document.documentElement).getPropertyValue('--font-family').trim());
|
const [fontFamily, setFontFamily] = useState(() => getComputedStyle(document.documentElement).getPropertyValue('--font-family').trim());
|
||||||
const [fontSize, setFontSize] = useState(() => getComputedStyle(document.documentElement).getPropertyValue('--font-size').trim());
|
const [fontSize, setFontSize] = useState(() => getComputedStyle(document.documentElement).getPropertyValue('--font-size').trim());
|
||||||
const [burgerMenu, setBurgerMenu] = useState(() => getComputedStyle(document.documentElement).getPropertyValue('--burger-menu-background-color').trim());
|
const [burgerMenu, setBurgerMenu] = useState(() => getComputedStyle(document.documentElement).getPropertyValue('--burger-menu-background-color').trim());
|
||||||
|
const [faqBackgroundColor, setFaqBackgroundColor] = useState(() => getComputedStyle(document.documentElement).getPropertyValue('--faq-background-color').trim());
|
||||||
|
const [faqHeadingColor, setFaqHeadingColor] = useState(() => getComputedStyle(document.documentElement).getPropertyValue('--faq-heading-color').trim());
|
||||||
|
const [faqItemBackgroundColor, setFaqItemBackgroundColor] = useState(() => getComputedStyle(document.documentElement).getPropertyValue('--faq-item-background-color').trim());
|
||||||
|
const [faqItemHeadingColor, setFaqItemHeadingColor] = useState(() => getComputedStyle(document.documentElement).getPropertyValue('--faq-item-heading-color').trim());
|
||||||
|
const [faqItemTextColor, setFaqItemTextColor] = useState(() => getComputedStyle(document.documentElement).getPropertyValue('--faq-item-text-color').trim());
|
||||||
|
const [faqItemHoverBackgroundColor, setFaqItemHoverBackgroundColor] = useState(() => getComputedStyle(document.documentElement).getPropertyValue('--faq-item-hover-background-color').trim());
|
||||||
|
const [popupBackgroundColor, setPopupBackgroundColor] = useState(() => getComputedStyle(document.documentElement).getPropertyValue('--popup-background-color').trim());
|
||||||
|
const [overlayTextColor, setOverlayTextColor] = useState(() => getComputedStyle(document.documentElement).getPropertyValue('--overlay-text-color').trim());
|
||||||
|
|
||||||
|
|
||||||
// Theme selection
|
// Theme selection
|
||||||
const [selectedTheme, setSelectedTheme] = useState(() => localStorage.getItem('selectedTheme') || 'default');
|
const [selectedTheme, setSelectedTheme] = useState<string>('');
|
||||||
|
|
||||||
|
useEffect(() => {
|
||||||
|
const savedTheme = localStorage.getItem('selectedTheme');
|
||||||
|
if (savedTheme) {
|
||||||
|
setSelectedTheme(savedTheme);
|
||||||
|
// Apply the saved theme on initial load
|
||||||
|
switch (savedTheme) {
|
||||||
|
case 'IOMARKET':
|
||||||
|
applyIOMarketTheme();
|
||||||
|
break;
|
||||||
|
case 'WHITE':
|
||||||
|
applyWhiteTheme();
|
||||||
|
break;
|
||||||
|
case 'BLACK':
|
||||||
|
applyBlackTheme();
|
||||||
|
break;
|
||||||
|
case 'CUSTOM':
|
||||||
|
// Handle custom theme application here if necessary
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
applyIOMarketTheme();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}, []); // Runs only once when the component mounts
|
||||||
|
|
||||||
// API Keys
|
// API Keys
|
||||||
const [mistral, setmistral] = useState(() => getComputedStyle(document.documentElement).getPropertyValue('--online-la-plateforme').trim());
|
const [mistral, setmistral] = useState(() => getComputedStyle(document.documentElement).getPropertyValue('--online-la-plateforme').trim());
|
||||||
|
@ -146,8 +181,16 @@ const Settings: React.FC<{ closeSettings: () => void; accountName: string }> = (
|
||||||
openai,
|
openai,
|
||||||
anthropic,
|
anthropic,
|
||||||
google,
|
google,
|
||||||
|
// Additional theme settings
|
||||||
|
faqBackgroundColor,
|
||||||
|
faqHeadingColor,
|
||||||
|
faqItemBackgroundColor,
|
||||||
|
faqItemHeadingColor,
|
||||||
|
faqItemTextColor,
|
||||||
|
faqItemHoverBackgroundColor,
|
||||||
|
popupBackgroundColor,
|
||||||
|
overlayTextColor,
|
||||||
};
|
};
|
||||||
|
|
||||||
// Update local storage
|
// Update local storage
|
||||||
for (const [key, value] of Object.entries(settings)) {
|
for (const [key, value] of Object.entries(settings)) {
|
||||||
if (typeof value === 'boolean') {
|
if (typeof value === 'boolean') {
|
||||||
|
@ -196,6 +239,15 @@ const Settings: React.FC<{ closeSettings: () => void; accountName: string }> = (
|
||||||
openai,
|
openai,
|
||||||
anthropic,
|
anthropic,
|
||||||
google,
|
google,
|
||||||
|
// Additional theme settings
|
||||||
|
faqBackgroundColor,
|
||||||
|
faqHeadingColor,
|
||||||
|
faqItemBackgroundColor,
|
||||||
|
faqItemHeadingColor,
|
||||||
|
faqItemTextColor,
|
||||||
|
faqItemHoverBackgroundColor,
|
||||||
|
popupBackgroundColor,
|
||||||
|
overlayTextColor,
|
||||||
]);
|
]);
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
|
@ -311,11 +363,45 @@ const Settings: React.FC<{ closeSettings: () => void; accountName: string }> = (
|
||||||
}
|
}
|
||||||
|
|
||||||
if (settings.burgerMenu) {
|
if (settings.burgerMenu) {
|
||||||
setBurgerMenu(settings.fontSize);
|
setBurgerMenu(settings.burgerMenu);
|
||||||
document.documentElement.style.setProperty('--burger-menu-background-color:', settings.burgerMenu);
|
document.documentElement.style.setProperty('--burger-menu-background-color', settings.burgerMenu);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Additional theme settings
|
||||||
|
if (settings.faqBackgroundColor) {
|
||||||
|
document.documentElement.style.setProperty('--faq-background-color', settings.faqBackgroundColor);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (settings.faqHeadingColor) {
|
||||||
|
document.documentElement.style.setProperty('--faq-heading-color', settings.faqHeadingColor);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (settings.faqItemBackgroundColor) {
|
||||||
|
document.documentElement.style.setProperty('--faq-item-background-color', settings.faqItemBackgroundColor);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (settings.faqItemHeadingColor) {
|
||||||
|
document.documentElement.style.setProperty('--faq-item-heading-color', settings.faqItemHeadingColor);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (settings.faqItemTextColor) {
|
||||||
|
document.documentElement.style.setProperty('--faq-item-text-color', settings.faqItemTextColor);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (settings.faqItemHoverBackgroundColor) {
|
||||||
|
document.documentElement.style.setProperty('--faq-item-hover-background-color', settings.faqItemHoverBackgroundColor);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (settings.popupBackgroundColor) {
|
||||||
|
document.documentElement.style.setProperty('--popup-background-color', settings.popupBackgroundColor);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (settings.overlayTextColor) {
|
||||||
|
document.documentElement.style.setProperty('--overlay-text-color', settings.overlayTextColor);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
// Function to handle updating all credentials
|
// Function to handle updating all credentials
|
||||||
const handleUpdateCredentials = async () => {
|
const handleUpdateCredentials = async () => {
|
||||||
// Update account information
|
// Update account information
|
||||||
|
@ -532,28 +618,31 @@ const Settings: React.FC<{ closeSettings: () => void; accountName: string }> = (
|
||||||
<select
|
<select
|
||||||
value={selectedTheme}
|
value={selectedTheme}
|
||||||
onChange={(e) => {
|
onChange={(e) => {
|
||||||
const theme = e.target.value; // Get the selected value from the event
|
const theme = e.target.value;
|
||||||
setSelectedTheme(theme); // Update state for selected theme
|
if (theme !== "default") {
|
||||||
|
setSelectedTheme(theme);
|
||||||
|
localStorage.setItem("selectedTheme", theme);
|
||||||
|
|
||||||
// Apply the appropriate theme based on selection
|
// Apply the appropriate theme based on selection
|
||||||
switch (theme) { // Use 'theme' instead of 'selectedTheme'
|
switch (theme) {
|
||||||
case 'IOMARKET':
|
case 'IOMARKET':
|
||||||
applyIOMarketTheme(); // Call the function to apply the IOMARKET theme
|
applyIOMarketTheme();
|
||||||
break;
|
break;
|
||||||
case 'WHITE':
|
case 'WHITE':
|
||||||
applyWhiteTheme(); // Call the function to apply the WHITE theme
|
applyWhiteTheme();
|
||||||
break;
|
break;
|
||||||
case 'BLACK':
|
case 'BLACK':
|
||||||
applyBlackTheme(); // Call the function to apply the BLACK theme
|
applyBlackTheme();
|
||||||
break;
|
break;
|
||||||
case 'CUSTOM':
|
case 'CUSTOM':
|
||||||
// Handle custom theme logic here if necessary
|
// Handle custom theme logic here if necessary
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
applyIOMarketTheme(); // Fallback to the IOMARKET theme
|
applyIOMarketTheme();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}} // Handle theme selection
|
}
|
||||||
|
}}
|
||||||
>
|
>
|
||||||
<option value="default">Select your style...</option>
|
<option value="default">Select your style...</option>
|
||||||
<option value="IOMARKET">IOMARKET</option>
|
<option value="IOMARKET">IOMARKET</option>
|
||||||
|
@ -562,10 +651,10 @@ const Settings: React.FC<{ closeSettings: () => void; accountName: string }> = (
|
||||||
<option value="CUSTOM">CUSTOM</option>
|
<option value="CUSTOM">CUSTOM</option>
|
||||||
</select>
|
</select>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
{/* Conditionally render theme settings only if "CUSTOM" is selected */}
|
{/* Conditionally render theme settings only if "CUSTOM" is selected */}
|
||||||
{selectedTheme === 'CUSTOM' && (
|
{selectedTheme === 'CUSTOM' && (
|
||||||
<>
|
<>
|
||||||
|
{/* Font Size */}
|
||||||
<div className="settings-option">
|
<div className="settings-option">
|
||||||
<p>Font Size</p>
|
<p>Font Size</p>
|
||||||
<input
|
<input
|
||||||
|
@ -582,6 +671,7 @@ const Settings: React.FC<{ closeSettings: () => void; accountName: string }> = (
|
||||||
<span>{fontSize}</span>
|
<span>{fontSize}</span>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
{/* Background Color */}
|
||||||
<div className="settings-option">
|
<div className="settings-option">
|
||||||
<p>Background Color</p>
|
<p>Background Color</p>
|
||||||
<input
|
<input
|
||||||
|
@ -595,6 +685,7 @@ const Settings: React.FC<{ closeSettings: () => void; accountName: string }> = (
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
{/* Text Color */}
|
||||||
<div className="settings-option">
|
<div className="settings-option">
|
||||||
<p>Text Color</p>
|
<p>Text Color</p>
|
||||||
<input
|
<input
|
||||||
|
@ -608,6 +699,7 @@ const Settings: React.FC<{ closeSettings: () => void; accountName: string }> = (
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
{/* Input Background Color */}
|
||||||
<div className="settings-option">
|
<div className="settings-option">
|
||||||
<p>Input Background Color</p>
|
<p>Input Background Color</p>
|
||||||
<input
|
<input
|
||||||
|
@ -621,6 +713,7 @@ const Settings: React.FC<{ closeSettings: () => void; accountName: string }> = (
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
{/* Input Button Color */}
|
||||||
<div className="settings-option">
|
<div className="settings-option">
|
||||||
<p>Input Button Color</p>
|
<p>Input Button Color</p>
|
||||||
<input
|
<input
|
||||||
|
@ -634,6 +727,7 @@ const Settings: React.FC<{ closeSettings: () => void; accountName: string }> = (
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
{/* Input Button Hover Color */}
|
||||||
<div className="settings-option">
|
<div className="settings-option">
|
||||||
<p>Input Button Hover Color</p>
|
<p>Input Button Hover Color</p>
|
||||||
<input
|
<input
|
||||||
|
@ -647,6 +741,7 @@ const Settings: React.FC<{ closeSettings: () => void; accountName: string }> = (
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
{/* User Message Background Color */}
|
||||||
<div className="settings-option">
|
<div className="settings-option">
|
||||||
<p>User Message Background Color</p>
|
<p>User Message Background Color</p>
|
||||||
<input
|
<input
|
||||||
|
@ -660,6 +755,7 @@ const Settings: React.FC<{ closeSettings: () => void; accountName: string }> = (
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
{/* User Message Text Color */}
|
||||||
<div className="settings-option">
|
<div className="settings-option">
|
||||||
<p>User Message Text Color</p>
|
<p>User Message Text Color</p>
|
||||||
<input
|
<input
|
||||||
|
@ -673,6 +769,7 @@ const Settings: React.FC<{ closeSettings: () => void; accountName: string }> = (
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
{/* AI Message Background Color */}
|
||||||
<div className="settings-option">
|
<div className="settings-option">
|
||||||
<p>AI Message Background Color</p>
|
<p>AI Message Background Color</p>
|
||||||
<input
|
<input
|
||||||
|
@ -686,6 +783,7 @@ const Settings: React.FC<{ closeSettings: () => void; accountName: string }> = (
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
{/* AI Message Text Color */}
|
||||||
<div className="settings-option">
|
<div className="settings-option">
|
||||||
<p>AI Message Text Color</p>
|
<p>AI Message Text Color</p>
|
||||||
<input
|
<input
|
||||||
|
@ -699,6 +797,7 @@ const Settings: React.FC<{ closeSettings: () => void; accountName: string }> = (
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
{/* Button Background Color */}
|
||||||
<div className="settings-option">
|
<div className="settings-option">
|
||||||
<p>Button Background Color</p>
|
<p>Button Background Color</p>
|
||||||
<input
|
<input
|
||||||
|
@ -712,6 +811,7 @@ const Settings: React.FC<{ closeSettings: () => void; accountName: string }> = (
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
{/* Button Hover Background Color */}
|
||||||
<div className="settings-option">
|
<div className="settings-option">
|
||||||
<p>Button Hover Background Color</p>
|
<p>Button Hover Background Color</p>
|
||||||
<input
|
<input
|
||||||
|
@ -725,6 +825,7 @@ const Settings: React.FC<{ closeSettings: () => void; accountName: string }> = (
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
{/* Models Background Color */}
|
||||||
<div className="settings-option">
|
<div className="settings-option">
|
||||||
<p>Models Background Color</p>
|
<p>Models Background Color</p>
|
||||||
<input
|
<input
|
||||||
|
@ -738,6 +839,7 @@ const Settings: React.FC<{ closeSettings: () => void; accountName: string }> = (
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
{/* History Background Color */}
|
||||||
<div className="settings-option">
|
<div className="settings-option">
|
||||||
<p>History Background Color</p>
|
<p>History Background Color</p>
|
||||||
<input
|
<input
|
||||||
|
@ -751,6 +853,7 @@ const Settings: React.FC<{ closeSettings: () => void; accountName: string }> = (
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
{/* Left Panel Background Color */}
|
||||||
<div className="settings-option">
|
<div className="settings-option">
|
||||||
<p>Left Panel Background Color</p>
|
<p>Left Panel Background Color</p>
|
||||||
<input
|
<input
|
||||||
|
@ -764,6 +867,7 @@ const Settings: React.FC<{ closeSettings: () => void; accountName: string }> = (
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
{/* Conversation Background Color */}
|
||||||
<div className="settings-option">
|
<div className="settings-option">
|
||||||
<p>Conversation Background Color</p>
|
<p>Conversation Background Color</p>
|
||||||
<input
|
<input
|
||||||
|
@ -777,6 +881,7 @@ const Settings: React.FC<{ closeSettings: () => void; accountName: string }> = (
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
{/* Pop-up Text Color */}
|
||||||
<div className="settings-option">
|
<div className="settings-option">
|
||||||
<p>Pop-up Text Color</p>
|
<p>Pop-up Text Color</p>
|
||||||
<input
|
<input
|
||||||
|
@ -790,19 +895,7 @@ const Settings: React.FC<{ closeSettings: () => void; accountName: string }> = (
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div className="settings-option">
|
{/* Input Border Color */}
|
||||||
<p>Burger Menu Color</p>
|
|
||||||
<input
|
|
||||||
type="color"
|
|
||||||
value={burgerMenu}
|
|
||||||
onChange={(e) => {
|
|
||||||
const newColor = e.target.value;
|
|
||||||
setBurgerMenu(newColor);
|
|
||||||
document.documentElement.style.setProperty('--burger-menu-background-color', newColor);
|
|
||||||
}}
|
|
||||||
/>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div className="settings-option">
|
<div className="settings-option">
|
||||||
<p>Input Border Color</p>
|
<p>Input Border Color</p>
|
||||||
<input
|
<input
|
||||||
|
@ -816,6 +909,7 @@ const Settings: React.FC<{ closeSettings: () => void; accountName: string }> = (
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
{/* Font Family */}
|
||||||
<div className="settings-option">
|
<div className="settings-option">
|
||||||
<p>Font Family</p>
|
<p>Font Family</p>
|
||||||
<select
|
<select
|
||||||
|
@ -843,6 +937,117 @@ const Settings: React.FC<{ closeSettings: () => void; accountName: string }> = (
|
||||||
</select>
|
</select>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
{/* FAQ Background Color */}
|
||||||
|
<div className="settings-option">
|
||||||
|
<p>FAQ Background Color</p>
|
||||||
|
<input
|
||||||
|
type="color"
|
||||||
|
value={faqBackgroundColor}
|
||||||
|
onChange={(e) => {
|
||||||
|
const newColor = e.target.value;
|
||||||
|
setFaqBackgroundColor(newColor);
|
||||||
|
document.documentElement.style.setProperty('--faq-background-color', newColor);
|
||||||
|
}}
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
{/* FAQ Heading Color */}
|
||||||
|
<div className="settings-option">
|
||||||
|
<p>FAQ Heading Color</p>
|
||||||
|
<input
|
||||||
|
type="color"
|
||||||
|
value={faqHeadingColor}
|
||||||
|
onChange={(e) => {
|
||||||
|
const newColor = e.target.value;
|
||||||
|
setFaqHeadingColor(newColor);
|
||||||
|
document.documentElement.style.setProperty('--faq-heading-color', newColor);
|
||||||
|
}}
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
{/* FAQ Item Background Color */}
|
||||||
|
<div className="settings-option">
|
||||||
|
<p>FAQ Item Background Color</p>
|
||||||
|
<input
|
||||||
|
type="color"
|
||||||
|
value={faqItemBackgroundColor}
|
||||||
|
onChange={(e) => {
|
||||||
|
const newColor = e.target.value;
|
||||||
|
setFaqItemBackgroundColor(newColor);
|
||||||
|
document.documentElement.style.setProperty('--faq-item-background-color', newColor);
|
||||||
|
}}
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
{/* FAQ Item Heading Color */}
|
||||||
|
<div className="settings-option">
|
||||||
|
<p>FAQ Item Heading Color</p>
|
||||||
|
<input
|
||||||
|
type="color"
|
||||||
|
value={faqItemHeadingColor}
|
||||||
|
onChange={(e) => {
|
||||||
|
const newColor = e.target.value;
|
||||||
|
setFaqItemHeadingColor(newColor);
|
||||||
|
document.documentElement.style.setProperty('--faq-item-heading-color', newColor);
|
||||||
|
}}
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
{/* FAQ Item Text Color */}
|
||||||
|
<div className="settings-option">
|
||||||
|
<p>FAQ Item Text Color</p>
|
||||||
|
<input
|
||||||
|
type="color"
|
||||||
|
value={faqItemTextColor}
|
||||||
|
onChange={(e) => {
|
||||||
|
const newColor = e.target.value;
|
||||||
|
setFaqItemTextColor(newColor);
|
||||||
|
document.documentElement.style.setProperty('--faq-item-text-color', newColor);
|
||||||
|
}}
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
{/* FAQ Item Hover Background Color */}
|
||||||
|
<div className="settings-option">
|
||||||
|
<p>FAQ Item Hover Background Color</p>
|
||||||
|
<input
|
||||||
|
type="color"
|
||||||
|
value={faqItemHoverBackgroundColor}
|
||||||
|
onChange={(e) => {
|
||||||
|
const newColor = e.target.value;
|
||||||
|
setFaqItemHoverBackgroundColor(newColor);
|
||||||
|
document.documentElement.style.setProperty('--faq-item-hover-background-color', newColor);
|
||||||
|
}}
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
{/* Popup Background Color */}
|
||||||
|
<div className="settings-option">
|
||||||
|
<p>Popup Background Color</p>
|
||||||
|
<input
|
||||||
|
type="color"
|
||||||
|
value={popupBackgroundColor}
|
||||||
|
onChange={(e) => {
|
||||||
|
const newColor = e.target.value;
|
||||||
|
setPopupBackgroundColor(newColor);
|
||||||
|
document.documentElement.style.setProperty('--popup-background-color', newColor);
|
||||||
|
}}
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
{/* Overlay Text Color */}
|
||||||
|
<div className="settings-option">
|
||||||
|
<p>Overlay Text Color</p>
|
||||||
|
<input
|
||||||
|
type="color"
|
||||||
|
value={overlayTextColor}
|
||||||
|
onChange={(e) => {
|
||||||
|
const newColor = e.target.value;
|
||||||
|
setOverlayTextColor(newColor);
|
||||||
|
document.documentElement.style.setProperty('--overlay-text-color', newColor);
|
||||||
|
}}
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
</>
|
</>
|
||||||
)}
|
)}
|
||||||
</div>
|
</div>
|
||||||
|
@ -1033,7 +1238,17 @@ const Settings: React.FC<{ closeSettings: () => void; accountName: string }> = (
|
||||||
mistral,
|
mistral,
|
||||||
openai,
|
openai,
|
||||||
anthropic,
|
anthropic,
|
||||||
google
|
google,
|
||||||
|
|
||||||
|
// Additional theme settings if needed
|
||||||
|
faqBackgroundColor,
|
||||||
|
faqHeadingColor,
|
||||||
|
faqItemBackgroundColor,
|
||||||
|
faqItemHeadingColor,
|
||||||
|
faqItemTextColor,
|
||||||
|
faqItemHoverBackgroundColor,
|
||||||
|
popupBackgroundColor,
|
||||||
|
overlayTextColor,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@ -1059,7 +1274,7 @@ const Settings: React.FC<{ closeSettings: () => void; accountName: string }> = (
|
||||||
<button className="apply" onClick={() => {
|
<button className="apply" onClick={() => {
|
||||||
applySettings;
|
applySettings;
|
||||||
getAllLocalStorageItems();
|
getAllLocalStorageItems();
|
||||||
closeSettings(); // This is invoked when the button is clicked
|
closeSettings();
|
||||||
}}>
|
}}>
|
||||||
Apply
|
Apply
|
||||||
</button>
|
</button>
|
||||||
|
|
|
@ -92,5 +92,66 @@ export const applyBlackTheme = () => {
|
||||||
document.documentElement.style.setProperty('--input-border-color', '#3c3c3c'); // Input border color
|
document.documentElement.style.setProperty('--input-border-color', '#3c3c3c'); // Input border color
|
||||||
document.documentElement.style.setProperty('--font-family', "'Poppins', 'sans-serif'"); // Font family
|
document.documentElement.style.setProperty('--font-family', "'Poppins', 'sans-serif'"); // Font family
|
||||||
document.documentElement.style.setProperty('--font-size', '16px'); // Font size
|
document.documentElement.style.setProperty('--font-size', '16px'); // Font size
|
||||||
document.documentElement.style.setProperty('--burger-menu-background-color', '#79832e'); // Font size
|
document.documentElement.style.setProperty('--burger-menu-background-color', '# 79832e'); // Font size
|
||||||
};
|
};
|
||||||
|
|
||||||
|
export const applyCustomTheme = () => {
|
||||||
|
// Theme variables
|
||||||
|
const themeVariables = {
|
||||||
|
backgroundColor: localStorage.getItem('backgroundColor'),
|
||||||
|
textColor: localStorage.getItem('textColor'),
|
||||||
|
inputBackgroundColor: localStorage.getItem('inputBackgroundColor'),
|
||||||
|
inputButtonColor: localStorage.getItem('inputButtonColor'),
|
||||||
|
inputButtonHoverColor: localStorage.getItem('inputButtonHoverColor'),
|
||||||
|
userMessageBackgroundColor: localStorage.getItem('userMessageBackgroundColor'),
|
||||||
|
userMessageTextColor: localStorage.getItem('userMessageTextColor'),
|
||||||
|
aiMessageBackgroundColor: localStorage.getItem('aiMessageBackgroundColor'),
|
||||||
|
aiMessageTextColor: localStorage.getItem('aiMessageTextColor'),
|
||||||
|
buttonBackgroundColor: localStorage.getItem('buttonBackgroundColor'),
|
||||||
|
buttonHoverBackgroundColor: localStorage.getItem('buttonHoverBackgroundColor'),
|
||||||
|
modelsBackgroundColor: localStorage.getItem('modelsBackgroundColor'),
|
||||||
|
historyBackgroundColor: localStorage.getItem('historyBackgroundColor'),
|
||||||
|
leftPanelBackgroundColor: localStorage.getItem('leftPanelBackgroundColor'),
|
||||||
|
conversationBackgroundColor: localStorage.getItem('conversationBackgroundColor'),
|
||||||
|
popUpTextColor: localStorage.getItem('popUpTextColor'),
|
||||||
|
inputBorderColor: localStorage.getItem('inputBorderColor'),
|
||||||
|
fontFamily: localStorage.getItem('fontFamily'),
|
||||||
|
fontSize: localStorage.getItem('fontSize'),
|
||||||
|
burgerMenu: localStorage.getItem('burgerMenu'),
|
||||||
|
faqBackgroundColor: localStorage.getItem('faqBackgroundColor'),
|
||||||
|
faqHeadingColor: localStorage.getItem('faqHeadingColor'),
|
||||||
|
faqItemBackgroundColor: localStorage.getItem('faqItemBackgroundColor'),
|
||||||
|
faqItemHeadingColor: localStorage.getItem('faqItemHeadingColor'),
|
||||||
|
faqItemTextColor: localStorage.getItem('faqItemTextColor'),
|
||||||
|
faqItemHoverBackgroundColor: localStorage.getItem('faqItemHoverBackgroundColor'),
|
||||||
|
popupBackgroundColor: localStorage.getItem('popupBackgroundColor'),
|
||||||
|
overlayTextColor: localStorage.getItem('overlayTextColor'),
|
||||||
|
};
|
||||||
|
|
||||||
|
document.documentElement.style.setProperty('--background-color', themeVariables.backgroundColor || '#121212'); // Main background color
|
||||||
|
document.documentElement.style.setProperty('--text-color', themeVariables.textColor || '#e0e0e0'); // Main text color
|
||||||
|
document.documentElement.style.setProperty('--input-background-color', themeVariables.inputBackgroundColor || '#1e1e1e'); // Input fields background
|
||||||
|
document.documentElement.style.setProperty('--input-button-color', themeVariables.inputButtonColor || '#3c3c3c'); // Button color
|
||||||
|
document.documentElement.style.setProperty('--input-button-hover-color', themeVariables.inputButtonHoverColor || '#5a5a5a'); // Button hover color
|
||||||
|
document.documentElement.style.setProperty('--user-message-background-color', themeVariables.userMessageBackgroundColor || '#000000'); // User messages background
|
||||||
|
document.documentElement.style.setProperty('--user-message-text-color', themeVariables.userMessageTextColor || '#ffffff'); // User messages text color
|
||||||
|
document.documentElement.style.setProperty('--ai-message-background-color', themeVariables.aiMessageBackgroundColor || '#202020'); // AI messages background
|
||||||
|
document.documentElement.style.setProperty('--ai-message-text-color', themeVariables.aiMessageTextColor || '#ffffff'); // AI messages text color
|
||||||
|
document.documentElement.style.setProperty('--button-background-color', themeVariables.buttonBackgroundColor || '#3c3c3c'); // Button background color
|
||||||
|
document.documentElement.style.setProperty('--button-hover-background-color', themeVariables.buttonHoverBackgroundColor || '#5a5a5a'); // Button hover color
|
||||||
|
document.documentElement.style.setProperty('--models-background-color', themeVariables.modelsBackgroundColor || '#1e1e1e'); // Models section background
|
||||||
|
document.documentElement.style.setProperty('--history-background-color', themeVariables.historyBackgroundColor || '#1a1a1a'); // History background
|
||||||
|
document.documentElement.style.setProperty('--left-panel-background-color', themeVariables.leftPanelBackgroundColor || '#1e1e1e'); // Left panel background
|
||||||
|
document.documentElement.style.setProperty('--conversation-background-color', themeVariables.conversationBackgroundColor || '#2c2c2c'); // Conversation container background
|
||||||
|
document.documentElement.style.setProperty('--faq-background-color', themeVariables.faqBackgroundColor || '#2c2c2c'); // FAQ section background
|
||||||
|
document.documentElement.style.setProperty('--faq-heading-color', themeVariables.faqHeadingColor || '#ffffff'); // FAQ heading color
|
||||||
|
document.documentElement.style.setProperty('--faq-item-background-color', themeVariables.faqItemBackgroundColor || '#3c3c3c'); // FAQ items background
|
||||||
|
document.documentElement.style.setProperty('--faq-item-heading-color', themeVariables.faqItemHeadingColor || '#ffffff'); // FAQ items heading color
|
||||||
|
document.documentElement.style.setProperty('--faq-item-text-color', themeVariables.faqItemTextColor || '#e0e0e0'); // FAQ items text color
|
||||||
|
document.documentElement.style.setProperty('--faq-item-hover-background-color', themeVariables.faqItemHoverBackgroundColor || '#5a5a5a'); // FAQ items hover background
|
||||||
|
document.documentElement.style.setProperty('--input-border-color', themeVariables.inputBorderColor || '#3c3c3c'); // Input border color
|
||||||
|
document.documentElement.style.setProperty('--font-family', themeVariables.fontFamily || "'Poppins', 'sans-serif'"); // Font family
|
||||||
|
document.documentElement.style.setProperty('--font-size', themeVariables.fontSize || '16px'); // Font size
|
||||||
|
document.documentElement.style.setProperty('--burger-menu-background-color', themeVariables.burgerMenu || '#79832e'); // Burger menu background color
|
||||||
|
|
||||||
|
}
|
||||||
|
|
29
app/page.tsx
29
app/page.tsx
|
@ -7,6 +7,8 @@ import Documentation from './components/Documentation'; // Ensure the import pat
|
||||||
import History from './components/History';
|
import History from './components/History';
|
||||||
import Models from './components/Models';
|
import Models from './components/Models';
|
||||||
import Credits from './components/Credits';
|
import Credits from './components/Credits';
|
||||||
|
import Settings from './components/Settings';
|
||||||
|
import { applyIOMarketTheme, applyWhiteTheme, applyBlackTheme, applyCustomTheme } from './components/theme'
|
||||||
import Head from 'next/head';
|
import Head from 'next/head';
|
||||||
import './styles/master.css';
|
import './styles/master.css';
|
||||||
|
|
||||||
|
@ -26,6 +28,33 @@ const LandingPage: React.FC = () => {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
const [selectedTheme, setSelectedTheme] = useState<string>('');
|
||||||
|
|
||||||
|
useEffect(() => {
|
||||||
|
const savedTheme = localStorage.getItem('selectedTheme');
|
||||||
|
if (savedTheme) {
|
||||||
|
setSelectedTheme(savedTheme);
|
||||||
|
// Apply the saved theme on initial load
|
||||||
|
switch (savedTheme) {
|
||||||
|
case 'IOMARKET':
|
||||||
|
applyIOMarketTheme();
|
||||||
|
break;
|
||||||
|
case 'WHITE':
|
||||||
|
applyWhiteTheme();
|
||||||
|
break;
|
||||||
|
case 'BLACK':
|
||||||
|
applyBlackTheme();
|
||||||
|
break;
|
||||||
|
case 'CUSTOM':
|
||||||
|
applyCustomTheme();
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
applyIOMarketTheme();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}, []); // Runs only once when the component mounts
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<>
|
<>
|
||||||
<Header
|
<Header
|
||||||
|
|
|
@ -2,8 +2,8 @@
|
||||||
.container{
|
.container{
|
||||||
display: flex;
|
display: flex;
|
||||||
width: 100vw;
|
width: 100vw;
|
||||||
height: 100vh;
|
height: 90dvh;
|
||||||
padding-top: 12vh;
|
padding-top: 1dvh;
|
||||||
}
|
}
|
||||||
|
|
||||||
.left-panel {
|
.left-panel {
|
||||||
|
@ -13,13 +13,13 @@
|
||||||
border-radius: 0 1em 0 0;
|
border-radius: 0 1em 0 0;
|
||||||
margin-left: 0;
|
margin-left: 0;
|
||||||
padding-right: 1em;
|
padding-right: 1em;
|
||||||
height: 100%;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.left-panel.hidden {
|
.left-panel.hidden {
|
||||||
opacity: 0; /* Fade out when hidden */
|
opacity: 0; /* Fade out when hidden */
|
||||||
width: 0; /* Collapse width to 0 */
|
width: 0; /* Collapse width to 0 */
|
||||||
visibility: hidden; /* Hide visibility while collapsing */
|
visibility: hidden; /* Hide visibility while collapsing */
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.conversation-container {
|
.conversation-container {
|
||||||
|
@ -27,15 +27,10 @@
|
||||||
transition: margin-left 0.3s ease; /* Smooth margin adjustment */
|
transition: margin-left 0.3s ease; /* Smooth margin adjustment */
|
||||||
background-color: var(--conversation-background-color); /* Use variable for background color */
|
background-color: var(--conversation-background-color); /* Use variable for background color */
|
||||||
border-radius: 1em 0 0 0;
|
border-radius: 1em 0 0 0;
|
||||||
height: 100%;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Adjust margin-left when panel is shown or hidden */
|
|
||||||
.conversation-container.expanded {
|
|
||||||
margin-left: 1vw;
|
|
||||||
}
|
|
||||||
|
|
||||||
.conversation-container.collapsed {
|
.conversation-container.collapsed {
|
||||||
margin-left: 1vw; /* Space for the left panel */
|
margin-left: 1vw; /* Space for the left panel */
|
||||||
bottom: 0;
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,8 +5,8 @@
|
||||||
|
|
||||||
.credits-section {
|
.credits-section {
|
||||||
max-width: 900px;
|
max-width: 900px;
|
||||||
height: 80vh;
|
height: 80dvh;
|
||||||
margin: 0 auto;
|
margin: auto;
|
||||||
background: var(--doc-background-color); /* Use variable for background */
|
background: var(--doc-background-color); /* Use variable for background */
|
||||||
padding: 2rem;
|
padding: 2rem;
|
||||||
border-radius: 8px;
|
border-radius: 8px;
|
||||||
|
@ -15,20 +15,20 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
.title {
|
.title {
|
||||||
font-size: 2rem;
|
font-size: calc(var(--font-size)*2);
|
||||||
color: var(--doc-title-color); /* Use variable for title color */
|
color: var(--doc-title-color); /* Use variable for title color */
|
||||||
margin-bottom: 1.5rem;
|
margin-bottom: 1.5rem;
|
||||||
}
|
}
|
||||||
|
|
||||||
.subtitle {
|
.subtitle {
|
||||||
font-size: 1.5rem;
|
font-size: calc(var(--font-size)*1.5);
|
||||||
color: var(--doc-subtitle-color); /* Use variable for subtitle color */
|
color: var(--doc-subtitle-color); /* Use variable for subtitle color */
|
||||||
margin-top: 2rem;
|
margin-top: 2rem;
|
||||||
margin-bottom: 1rem;
|
margin-bottom: 1rem;
|
||||||
}
|
}
|
||||||
|
|
||||||
.paragraph {
|
.paragraph {
|
||||||
font-size: 1rem;
|
font-size: calc(var(--font-size));
|
||||||
color: var(--doc-paragraph-color); /* Use variable for paragraph color */
|
color: var(--doc-paragraph-color); /* Use variable for paragraph color */
|
||||||
margin-bottom: 1.5rem;
|
margin-bottom: 1.5rem;
|
||||||
line-height: 1.6;
|
line-height: 1.6;
|
||||||
|
|
|
@ -7,8 +7,8 @@
|
||||||
|
|
||||||
.documentation-section {
|
.documentation-section {
|
||||||
max-width: 900px;
|
max-width: 900px;
|
||||||
height: 80vh;
|
height: 80dvh;
|
||||||
margin: 0 auto;
|
margin: auto;
|
||||||
background: var(--doc-background-color); /* Use variable for background */
|
background: var(--doc-background-color); /* Use variable for background */
|
||||||
padding: 2rem;
|
padding: 2rem;
|
||||||
border-radius: 8px;
|
border-radius: 8px;
|
||||||
|
@ -17,27 +17,27 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
.title {
|
.title {
|
||||||
font-size: 2rem;
|
font-size: calc(var(--font-size)*2);
|
||||||
color: var(--doc-title-color); /* Use variable for title color */
|
color: var(--doc-title-color); /* Use variable for title color */
|
||||||
margin-bottom: 1.5rem;
|
margin-bottom: 1.5rem;
|
||||||
}
|
}
|
||||||
|
|
||||||
.subtitle {
|
.subtitle {
|
||||||
font-size: 1.5rem;
|
font-size: calc(var(--font-size)*1.5);
|
||||||
color: var(--doc-subtitle-color); /* Use variable for subtitle color */
|
color: var(--doc-subtitle-color); /* Use variable for subtitle color */
|
||||||
margin-top: 2rem;
|
margin-top: 2rem;
|
||||||
margin-bottom: 1rem;
|
margin-bottom: 1rem;
|
||||||
}
|
}
|
||||||
|
|
||||||
.subsection-title {
|
.subsection-title {
|
||||||
font-size: 1.25rem;
|
font-size: calc(var(--font-size)*1.25);
|
||||||
color: var(--doc-subsection-title-color); /* Use variable for subsection title color */
|
color: var(--doc-subsection-title-color); /* Use variable for subsection title color */
|
||||||
margin-top: 1.5rem;
|
margin-top: 1.5rem;
|
||||||
margin-bottom: 0.75rem;
|
margin-bottom: 0.75rem;
|
||||||
}
|
}
|
||||||
|
|
||||||
.paragraph {
|
.paragraph {
|
||||||
font-size: 1rem;
|
font-size: calc(var(--font-size));
|
||||||
color: var(--doc-paragraph-color); /* Use variable for paragraph color */
|
color: var(--doc-paragraph-color); /* Use variable for paragraph color */
|
||||||
margin-bottom: 1.5rem;
|
margin-bottom: 1.5rem;
|
||||||
line-height: 1.6;
|
line-height: 1.6;
|
||||||
|
|
|
@ -1,14 +1,10 @@
|
||||||
html,
|
|
||||||
body {
|
body {
|
||||||
height: 100vh;
|
height: 100dvh;
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
position: relative;
|
position: relative;
|
||||||
}
|
}
|
||||||
|
|
||||||
body {
|
body {
|
||||||
display: flex;
|
|
||||||
justify-content: center;
|
|
||||||
align-items: center;
|
|
||||||
background-color: var(--background-color);
|
background-color: var(--background-color);
|
||||||
color: var(--text-color);
|
color: var(--text-color);
|
||||||
font-family: var(--font-family);
|
font-family: var(--font-family);
|
||||||
|
@ -19,11 +15,6 @@ body {
|
||||||
header {
|
header {
|
||||||
background-color: var(--header-background-color);
|
background-color: var(--header-background-color);
|
||||||
color: var(--header-text-color);
|
color: var(--header-text-color);
|
||||||
padding: 1rem; /* Adjust padding as needed */
|
|
||||||
}
|
|
||||||
|
|
||||||
main{
|
|
||||||
height: 100%;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
button {
|
button {
|
||||||
|
|
|
@ -1,10 +1,8 @@
|
||||||
header{
|
header{
|
||||||
position: absolute;
|
position: relative;
|
||||||
padding: 0 20px;
|
padding: 0 20px;
|
||||||
top: 0;
|
|
||||||
left: 0;
|
|
||||||
width: 100%;
|
width: 100%;
|
||||||
height: 10vh;
|
height: 10dvh;
|
||||||
display: flex;
|
display: flex;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
justify-content: center;
|
justify-content: center;
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
.history-background {
|
.history-background {
|
||||||
grid-column: 1/2;
|
grid-column: 1/2;
|
||||||
grid-row: 1/2;
|
grid-row: 1/2;
|
||||||
height: 45%;
|
height: 40dvh;
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
background-color: var(--history-background-color);
|
background-color: var(--history-background-color);
|
||||||
padding: 1em;
|
padding: 1em;
|
||||||
|
@ -39,5 +39,7 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
.history-models{
|
.history-models{
|
||||||
height: 100%;
|
position: relative;
|
||||||
|
height: 90dvh;
|
||||||
|
/* padding-bottom: 3dvh; */
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,7 +1,5 @@
|
||||||
/* Input Section */
|
/* Input Section */
|
||||||
.input {
|
.input {
|
||||||
grid-column: 2/3;
|
|
||||||
grid-row: 4/5;
|
|
||||||
border-radius: 8px;
|
border-radius: 8px;
|
||||||
background-color: var(--input-background-color);
|
background-color: var(--input-background-color);
|
||||||
padding: 1em;
|
padding: 1em;
|
||||||
|
@ -13,7 +11,12 @@
|
||||||
justify-content: space-between;
|
justify-content: space-between;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
height: auto;
|
height: auto;
|
||||||
height: 10vh;
|
height: 10dvh;
|
||||||
|
position: absolute;
|
||||||
|
left: 0.25vw;
|
||||||
|
bottom: 3dvh;
|
||||||
|
right: 0.25vw;
|
||||||
|
box-shadow: 0 -1px 10px rgba(0, 0, 0, 0.5);
|
||||||
}
|
}
|
||||||
|
|
||||||
.input input {
|
.input input {
|
||||||
|
@ -44,8 +47,8 @@
|
||||||
border-radius: 8px;
|
border-radius: 8px;
|
||||||
font-size: 1.5em;
|
font-size: 1.5em;
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
height: 50px;
|
height: 8dvh;
|
||||||
width: 75px;
|
width: 8vw;
|
||||||
display: flex;
|
display: flex;
|
||||||
justify-content: center;
|
justify-content: center;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
|
|
|
@ -1,13 +1,18 @@
|
||||||
.model-background {
|
.model-background {
|
||||||
|
position: absolute;
|
||||||
|
left: 1em;
|
||||||
|
bottom: 4dvh;
|
||||||
|
right: 0;
|
||||||
grid-column: 1/2;
|
grid-column: 1/2;
|
||||||
grid-row: 1/2;
|
grid-row: 1/2;
|
||||||
height: 45%;
|
padding-bottom: 1px;
|
||||||
|
overflow: scroll;
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
background-color: var(--history-background-color);
|
background-color: var(--history-background-color);
|
||||||
padding: 1em;
|
padding: 1em;
|
||||||
margin: 0 1em;
|
|
||||||
margin-right: 0;
|
margin-right: 0;
|
||||||
border-radius: 1em;
|
border-radius: 1em;
|
||||||
|
height: 45dvh;
|
||||||
}
|
}
|
||||||
|
|
||||||
.models {
|
.models {
|
||||||
|
@ -69,6 +74,7 @@
|
||||||
transition: opacity 0.5s ease;
|
transition: opacity 0.5s ease;
|
||||||
pointer-events: none;
|
pointer-events: none;
|
||||||
opacity: 0;
|
opacity: 0;
|
||||||
|
border-radius: 5%;
|
||||||
}
|
}
|
||||||
|
|
||||||
.overlay img {
|
.overlay img {
|
||||||
|
|
|
@ -4,13 +4,14 @@
|
||||||
grid-row: 1 / 4;
|
grid-row: 1 / 4;
|
||||||
background-color: var(--output-background-color);
|
background-color: var(--output-background-color);
|
||||||
margin: 1em;
|
margin: 1em;
|
||||||
|
padding-bottom: 14dvh;
|
||||||
display: flex;
|
display: flex;
|
||||||
flex-direction: column;
|
flex-direction: column;
|
||||||
justify-content: flex-start;
|
justify-content: flex-start;
|
||||||
font-size: 1em;
|
font-size: 1em;
|
||||||
overflow-y: auto;
|
overflow-y: auto;
|
||||||
width: calc(100% - 2em); /* Corrected calculation for width */
|
width: calc(100% - 2em); /* Corrected calculation for width */
|
||||||
height: 70vh;
|
height: 90dvh;
|
||||||
}
|
}
|
||||||
|
|
||||||
#conversation {
|
#conversation {
|
||||||
|
|
|
@ -2,4 +2,6 @@
|
||||||
margin: 0;
|
margin: 0;
|
||||||
padding: 0;
|
padding: 0;
|
||||||
box-sizing: border-box;
|
box-sizing: border-box;
|
||||||
|
scroll-behavior: smooth;
|
||||||
|
transition: all 0.2s ease-in-out;
|
||||||
}
|
}
|
||||||
|
|
|
@ -8,7 +8,6 @@
|
||||||
|
|
||||||
/* Header styles */
|
/* Header styles */
|
||||||
header {
|
header {
|
||||||
position: fixed;
|
|
||||||
top: 0;
|
top: 0;
|
||||||
left: 0;
|
left: 0;
|
||||||
margin-top: 0px;
|
margin-top: 0px;
|
||||||
|
@ -20,11 +19,10 @@
|
||||||
.container {
|
.container {
|
||||||
display: flex;
|
display: flex;
|
||||||
flex-direction: column;
|
flex-direction: column;
|
||||||
align-items: center;
|
|
||||||
width: 100vw;
|
width: 100vw;
|
||||||
overflow: scroll;
|
overflow: hidden;
|
||||||
margin: 0;
|
margin: 0;
|
||||||
padding: 7em 0 0 0 ;
|
padding: 1dvh 0 0 0 ;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Left panel styles */
|
/* Left panel styles */
|
||||||
|
@ -58,6 +56,7 @@
|
||||||
min-width: 100%;
|
min-width: 100%;
|
||||||
margin-left: 0;
|
margin-left: 0;
|
||||||
border-radius: none;
|
border-radius: none;
|
||||||
|
height: 10vh;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Grid styles */
|
/* Grid styles */
|
||||||
|
@ -79,6 +78,7 @@
|
||||||
margin: 0 auto;
|
margin: 0 auto;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
width: 90%;
|
width: 90%;
|
||||||
|
bottom: 10dvh
|
||||||
}
|
}
|
||||||
|
|
||||||
.input input {
|
.input input {
|
||||||
|
|
|
@ -16,6 +16,7 @@
|
||||||
border-bottom-right-radius: 0;
|
border-bottom-right-radius: 0;
|
||||||
margin-left: auto;
|
margin-left: auto;
|
||||||
text-align: left;
|
text-align: left;
|
||||||
|
margin-right: 1.5vw;
|
||||||
}
|
}
|
||||||
|
|
||||||
.ai-message {
|
.ai-message {
|
||||||
|
@ -27,6 +28,7 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
.ai-container{
|
.ai-container{
|
||||||
|
position: relative;
|
||||||
height: min-content;
|
height: min-content;
|
||||||
bottom: 0;
|
bottom: 0;
|
||||||
width: 100%;
|
width: 100%;
|
||||||
|
|
Loading…
Reference in a new issue