interstellar_ai/app/components/settings/theme.ts
2024-10-07 11:16:51 +02:00

308 lines
24 KiB
TypeScript

export const applyIOMarketTheme = () => {
document.documentElement.style.setProperty('--header-background-color', '#7e7e7e');
document.documentElement.style.setProperty('--header-text-color', '#ffffff');
document.documentElement.style.setProperty('--background-color', '#8B9635');
document.documentElement.style.setProperty('--text-color', '#474D22');
document.documentElement.style.setProperty('--input-background-color', '#ffffff');
document.documentElement.style.setProperty('--input-button-color', '#8B9635');
document.documentElement.style.setProperty('--input-button-hover-color', '#6b7c2b');
document.documentElement.style.setProperty('--user-message-background-color', '#8B9635');
document.documentElement.style.setProperty('--user-message-text-color', '#000');
document.documentElement.style.setProperty('--ai-message-background-color', '#FCFCEB');
document.documentElement.style.setProperty('--ai-message-text-color', '#000');
document.documentElement.style.setProperty('--button-background-color', '#8B9635');
document.documentElement.style.setProperty('--button-hover-background-color', '#6b7c2b');
document.documentElement.style.setProperty('--models-background-color', '#ffffff');
document.documentElement.style.setProperty('--history-background-color', '#f9f9f9');
document.documentElement.style.setProperty('--left-panel-background-color', '#79832e');
document.documentElement.style.setProperty('--conversation-background-color', '#79832e');
document.documentElement.style.setProperty('--doc-background-color', '#ffffff');
document.documentElement.style.setProperty('--close-button-color', 'red');
document.documentElement.style.setProperty('--close-button-hover-color', '#9e0101');
document.documentElement.style.setProperty('--apply-button-color', '#8B9635');
document.documentElement.style.setProperty('--apply-button-hover-color', '#6b7c2b');
document.documentElement.style.setProperty('--burger-menu-background-color', '#79832e');
document.documentElement.style.setProperty('--overlay-text-color', 'white');
document.documentElement.style.setProperty('--faq-background-color', '#474D22');
document.documentElement.style.setProperty('--faq-heading-color', '#8B9635');
document.documentElement.style.setProperty('--faq-item-background-color', '#fefefe');
document.documentElement.style.setProperty('--faq-item-heading-color', '#474D22');
document.documentElement.style.setProperty('--faq-item-text-color', '#333');
document.documentElement.style.setProperty('--faq-item-hover-background-color', '#e0e0e0');
document.documentElement.style.setProperty('--popup-background-color', '#8B9635');
document.documentElement.style.setProperty('--pop-up-text', '#000');
document.documentElement.style.setProperty('--input-border-color', '#8B9635');
document.documentElement.style.setProperty('--font-family', "'Poppins', 'sans-serif'");
document.documentElement.style.setProperty('--font-size', '16px');
};
export const applyWhiteTheme = () => {
document.documentElement.style.setProperty('--header-background-color', '#f0f0f0'); // Lighter header background
document.documentElement.style.setProperty('--header-text-color', '#333'); // Dark text for contrast
document.documentElement.style.setProperty('--background-color', '#ffffff'); // White background
document.documentElement.style.setProperty('--text-color', '#000'); // Dark text color
document.documentElement.style.setProperty('--input-background-color', '#f9f9f9'); // Light input background
document.documentElement.style.setProperty('--input-button-color', '#cccccc'); // Light button color
document.documentElement.style.setProperty('--input-button-hover-color', '#b3b3b3'); // Slightly darker on hover
document.documentElement.style.setProperty('--user-message-background-color', '#e0e0e0'); // Light grey for user messages
document.documentElement.style.setProperty('--user-message-text-color', '#000'); // Dark text for contrast
document.documentElement.style.setProperty('--ai-message-background-color', '#f7f7f7'); // Very light background for AI messages
document.documentElement.style.setProperty('--ai-message-text-color', '#000'); // Dark text for readability
document.documentElement.style.setProperty('--button-background-color', '#cccccc'); // Light button background
document.documentElement.style.setProperty('--button-hover-background-color', '#b3b3b3'); // Darker on hover
document.documentElement.style.setProperty('--models-background-color', '#ffffff'); // White background for models section
document.documentElement.style.setProperty('--history-background-color', '#f9f9f9'); // Light background for history section
document.documentElement.style.setProperty('--left-panel-background-color', '#e0e0e0'); // Light grey for the left panel
document.documentElement.style.setProperty('--conversation-background-color', '#e0e0e0'); // Light grey conversation background
document.documentElement.style.setProperty('--doc-background-color', '#ffffff'); // White document background
document.documentElement.style.setProperty('--close-button-color', '#ff4d4d'); // Soft red close button
document.documentElement.style.setProperty('--close-button-hover-color', '#ff1a1a'); // Brighter red on hover
document.documentElement.style.setProperty('--apply-button-color', '#cccccc'); // Light button color for apply
document.documentElement.style.setProperty('--apply-button-hover-color', '#b3b3b3'); // Darker hover color for apply button
document.documentElement.style.setProperty('--burger-menu-background-color', '#e0e0e0'); // Light grey burger menu background
document.documentElement.style.setProperty('--overlay-text-color', '#333'); // Dark overlay text
document.documentElement.style.setProperty('--faq-background-color', '#f0f0f0'); // Light FAQ section background
document.documentElement.style.setProperty('--faq-heading-color', '#333'); // Dark heading for contrast
document.documentElement.style.setProperty('--faq-item-background-color', '#ffffff'); // White background for FAQ items
document.documentElement.style.setProperty('--faq-item-heading-color', '#000'); // Dark headings for FAQ items
document.documentElement.style.setProperty('--faq-item-text-color', '#666'); // Medium grey text color for readability
document.documentElement.style.setProperty('--faq-item-hover-background-color', '#eaeaea'); // Slight hover effect for FAQ items
document.documentElement.style.setProperty('--popup-background-color', '#ffffff'); // White popup background
document.documentElement.style.setProperty('--pop-up-text', '#000'); // Dark text for pop-ups
document.documentElement.style.setProperty('--input-border-color', '#cccccc'); // Light input border color
document.documentElement.style.setProperty('--font-family', "'Poppins', 'sans-serif'"); // Same font family
document.documentElement.style.setProperty('--font-size', '16px'); // Same font size
};
export const applyBlackTheme = () => {
document.documentElement.style.setProperty('--header-background-color', '#1a1a1a'); // Dark header background
document.documentElement.style.setProperty('--header-text-color', '#ffffff'); // White text for header
document.documentElement.style.setProperty('--background-color', '#2c2c2c'); // Dark main background
document.documentElement.style.setProperty('--text-color', '#f0f0f0'); // Light text color
document.documentElement.style.setProperty('--input-background-color', '#3d3d3d'); // Dark input background
document.documentElement.style.setProperty('--input-button-color', '#4caf50'); // Button color
document.documentElement.style.setProperty('--input-button-hover-color', '#66bb6a'); // Button hover color
document.documentElement.style.setProperty('--user-message-background-color', '#4caf50'); // User message background
document.documentElement.style.setProperty('--user-message-text-color', '#ffffff'); // User message text color
document.documentElement.style.setProperty('--ai-message-background-color', '#424242'); // AI message background
document.documentElement.style.setProperty('--ai-message-text-color', '#ffffff'); // AI message text color
document.documentElement.style.setProperty('--button-background-color', '#4caf50'); // Button background color
document.documentElement.style.setProperty('--button-hover-background-color', '#66bb6a'); // Button hover color
document.documentElement.style.setProperty('--models-background-color', '#3d3d3d'); // Dark background for models section
document.documentElement.style.setProperty('--history-background-color', '#333333'); // Dark history background
document.documentElement.style.setProperty('--left-panel-background-color', '#1a1a1a'); // Dark left panel background
document.documentElement.style.setProperty('--conversation-background-color', '#1a1a1a'); // Dark conversation container
document.documentElement.style.setProperty('--doc-background-color', '#000000'); // Dark document background
document.documentElement.style.setProperty('--close-button-color', '#f44336'); // Red close button color
document.documentElement.style.setProperty('--close-button-hover-color', '#d32f2f'); // Darker red hover color
document.documentElement.style.setProperty('--apply-button-color', '#4caf50'); // Apply button color
document.documentElement.style.setProperty('--apply-button-hover-color', '#66bb6a'); // Apply button hover color
document.documentElement.style.setProperty('--burger-menu-background-color', '#1a1a1a'); // Dark burger menu background
document.documentElement.style.setProperty('--overlay-text-color', '#ffffff'); // White overlay text
document.documentElement.style.setProperty('--faq-background-color', '#333333'); // Dark background for FAQ section
document.documentElement.style.setProperty('--faq-heading-color', '#4caf50'); // FAQ heading color
document.documentElement.style.setProperty('--faq-item-background-color', '#4c4c4c'); // Dark FAQ item background
document.documentElement.style.setProperty('--faq-item-heading-color', '#ffffff'); // White FAQ item heading
document.documentElement.style.setProperty('--faq-item-text-color', '#e0e0e0'); // Light text for FAQ items
document.documentElement.style.setProperty('--faq-item-hover-background-color', '#555555'); // Hover background for FAQ items
document.documentElement.style.setProperty('--popup-background-color', '#4caf50'); // Dark popup background
document.documentElement.style.setProperty('--pop-up-text', '#ffffff'); // White pop-up text
document.documentElement.style.setProperty('--input-border-color', '#4caf50'); // Input border color
document.documentElement.style.setProperty('--font-family', "'Poppins', 'sans-serif'"); // Font family
document.documentElement.style.setProperty('--font-size', '16px'); // Font size
};
export const applyCustomTheme = () => {
if (typeof localStorage !== 'undefined') {
const themeVariables = {
backgroundColor: localStorage.getItem('backgroundColor'),
headerBackground: localStorage.getItem('headerBackground'),
headerTextColor: localStorage.getItem('headerTextColor'),
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'),
docBackgroundColor: localStorage.getItem('docBackgroundColor'),
closeButtonColor: localStorage.getItem('closeButtonColor'),
closeButtonHoverColor: localStorage.getItem('closeButtonHoverColor'),
applyButtonColor: localStorage.getItem('applyButtonColor'),
applyButtonHoverColor: localStorage.getItem('applyButtonHoverColor'),
burgerMenu: localStorage.getItem('burgerMenu'),
overlayTextColor: localStorage.getItem('overlayTextColor'),
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'),
popUpText: localStorage.getItem('popUpText'),
inputBorderColor: localStorage.getItem('inputBorderColor'),
fontFamily: localStorage.getItem('fontFamily'),
fontSize: localStorage.getItem('fontSize'),
};
document.documentElement.style.setProperty('--header-background-color', themeVariables.headerBackground || '#7e7e7e');
document.documentElement.style.setProperty('--header-text-color', themeVariables.headerTextColor || '#ffffff');
document.documentElement.style.setProperty('--background-color', themeVariables.backgroundColor || '#121212');
document.documentElement.style.setProperty('--text-color', themeVariables.textColor || '#e0e0e0');
document.documentElement.style.setProperty('--input-background-color', themeVariables.inputBackgroundColor || '#1e1e1e');
document.documentElement.style.setProperty('--input-button-color', themeVariables.inputButtonColor || '#3c3c3c');
document.documentElement.style.setProperty('--input-button-hover-color', themeVariables.inputButtonHoverColor || '#5a5a5a');
document.documentElement.style.setProperty('--user-message-background-color', themeVariables.userMessageBackgroundColor || '#000000');
document.documentElement.style.setProperty('--user-message-text-color', themeVariables.userMessageTextColor || '#ffffff');
document.documentElement.style.setProperty('--ai-message-background-color', themeVariables.aiMessageBackgroundColor || '#202020');
document.documentElement.style.setProperty('--ai-message-text-color', themeVariables.aiMessageTextColor || '#ffffff');
document.documentElement.style.setProperty('--button-background-color', themeVariables.buttonBackgroundColor || '#3c3c3c');
document.documentElement.style.setProperty('--button-hover-background-color', themeVariables.buttonHoverBackgroundColor || '#5a5a5a');
document.documentElement.style.setProperty('--models-background-color', themeVariables.modelsBackgroundColor || '#1e1e1e');
document.documentElement.style.setProperty('--history-background-color', themeVariables.historyBackgroundColor || '#1a1a1a');
document.documentElement.style.setProperty('--left-panel-background-color', themeVariables.leftPanelBackgroundColor || '#1e1e1e');
document.documentElement.style.setProperty('--conversation-background-color', themeVariables.conversationBackgroundColor || '#2c2c2c');
document.documentElement.style.setProperty('--doc-background-color', themeVariables.docBackgroundColor || '#000000');
document.documentElement.style.setProperty('--close-button-color', themeVariables.closeButtonColor || '#f44336');
document.documentElement.style.setProperty('--close-button-hover-color', themeVariables.closeButtonHoverColor || '#d32f2f');
document.documentElement.style.setProperty('--apply-button-color', themeVariables.applyButtonColor || '#4caf50');
document.documentElement.style.setProperty('--apply-button-hover-color', themeVariables.applyButtonHoverColor || '#66bb6a');
document.documentElement.style.setProperty('--burger-menu-background-color', themeVariables.burgerMenu || '#79832e');
document.documentElement.style.setProperty('--overlay-text-color', themeVariables.overlayTextColor || '#ffffff');
document.documentElement.style.setProperty('--faq-background-color', themeVariables.faqBackgroundColor || '#333333');
document.documentElement.style.setProperty('--faq-heading-color', themeVariables.faqHeadingColor || '#4caf50');
document.documentElement.style.setProperty('--faq-item-background-color', themeVariables.faqItemBackgroundColor || '#4c4c4c');
document.documentElement.style.setProperty('--faq-item-heading-color', themeVariables.faqItemHeadingColor || '#ffffff');
document.documentElement.style.setProperty('--faq-item-text-color', themeVariables.faqItemTextColor || '#e0e0e0');
document.documentElement.style.setProperty('--faq-item-hover-background-color', themeVariables.faqItemHoverBackgroundColor || '#555555');
document.documentElement.style.setProperty('--popup-background-color', themeVariables.popupBackgroundColor || '#4caf50');
document.documentElement.style.setProperty('--pop-up-text', themeVariables.popUpText || '#ffffff');
document.documentElement.style.setProperty('--input-border-color', themeVariables.inputBorderColor || '#3c3c3c');
document.documentElement.style.setProperty('--font-family', themeVariables.fontFamily || "'Poppins', 'sans-serif'");
document.documentElement.style.setProperty('--font-size', themeVariables.fontSize || '16px');
};
}
// TypeScript types for color parameters
type Color = string;
export const applyBasicCustomTheme = (
primaryColor: Color,
secondaryColor: Color,
accentColor: Color,
backgroundColor: Color,
textColor: Color
) => {
// Calculate additional colors based on the provided colors
const headerBackgroundColor = secondaryColor; // Use secondary color for header background
const headerTextColor = lightenColor(textColor, 50); // Lighten text color for header
const inputButtonColor = primaryColor; // Use primary color for input buttons
const userMessageBackgroundColor = accentColor; // Use accent color for user messages
const aiMessageBackgroundColor = backgroundColor; // Use background color for AI messages
const buttonHoverBackgroundColor = darkenColor(primaryColor, 30); // Darken primary color for hover
const closeButtonColor = darkenColor(accentColor, 20); // Darkened accent color for close button
const closeButtonHoverColor = darkenColor(closeButtonColor, 10); // Darker close button hover color
const darkerAccentColor = darkenColor(accentColor, 20); // Darken accent color for contrast
const lightenedPrimaryColor = lightenColor(primaryColor, 10); // Lighten primary color for highlights
const lighterBackgroundColor = lightenColor(backgroundColor, 10); // Lighten background for contrast
const darkerBackgroundColor = darkenColor(backgroundColor, 20); // More pronounced dark background
// Set all CSS variables
document.documentElement.style.setProperty('--header-background-color', headerBackgroundColor);
document.documentElement.style.setProperty('--header-text-color', headerTextColor);
document.documentElement.style.setProperty('--background-color', backgroundColor);
document.documentElement.style.setProperty('--text-color', textColor);
document.documentElement.style.setProperty('--input-background-color', lightenColor(backgroundColor, 10));
document.documentElement.style.setProperty('--input-button-color', inputButtonColor);
document.documentElement.style.setProperty('--input-button-hover-color', buttonHoverBackgroundColor);
document.documentElement.style.setProperty('--user-message-background-color', userMessageBackgroundColor);
document.documentElement.style.setProperty('--user-message-text-color', lightenColor(textColor, 60));
document.documentElement.style.setProperty('--ai-message-background-color', aiMessageBackgroundColor);
document.documentElement.style.setProperty('--ai-message-text-color', lightenColor(textColor, 60));
document.documentElement.style.setProperty('--button-background-color', inputButtonColor);
document.documentElement.style.setProperty('--button-hover-background-color', buttonHoverBackgroundColor);
document.documentElement.style.setProperty('--models-background-color', darkerBackgroundColor);
document.documentElement.style.setProperty('--history-background-color', lighterBackgroundColor);
document.documentElement.style.setProperty('--left-panel-background-color', lightenColor(backgroundColor, 5));
document.documentElement.style.setProperty('--conversation-background-color', lightenColor(backgroundColor, 5));
document.documentElement.style.setProperty('--doc-background-color', lighterBackgroundColor);
document.documentElement.style.setProperty('--close-button-color', closeButtonColor);
document.documentElement.style.setProperty('--close-button-hover-color', closeButtonHoverColor);
document.documentElement.style.setProperty('--apply-button-color', inputButtonColor);
document.documentElement.style.setProperty('--apply-button-hover-color', buttonHoverBackgroundColor);
document.documentElement.style.setProperty('--burger-menu-background-color', lightenColor(backgroundColor, 5));
document.documentElement.style.setProperty('--overlay-text-color', lightenColor(textColor, 80));
document.documentElement.style.setProperty('--faq-background-color', lightenColor(backgroundColor, 10));
document.documentElement.style.setProperty('--faq-heading-color', lightenedPrimaryColor);
document.documentElement.style.setProperty('--faq-item-background-color', darkerAccentColor);
document.documentElement.style.setProperty('--faq-item-heading-color', '#000000');
document.documentElement.style.setProperty('--faq-item-text-color', '#000000');
document.documentElement.style.setProperty('--faq-item-hover-background-color', lightenColor(accentColor, 10));
document.documentElement.style.setProperty('--popup-background-color', accentColor);
document.documentElement.style.setProperty('--pop-up-text', lightenColor(textColor, 80));
document.documentElement.style.setProperty('--input-border-color', primaryColor);
if (typeof localStorage !== 'undefined') {
document.documentElement.style.setProperty('--font-family', localStorage.getItem("fontFamily") || "'Poppins', 'sans-serif'");
document.documentElement.style.setProperty('--font-size', localStorage.getItem("fontSize") || '16px');
}
};
// Helper function to darken a color (returns a darker version of the provided color)
const darkenColor = (color: Color, percent: number): Color => {
let r = parseInt(color.slice(1, 3), 16);
let g = parseInt(color.slice(3, 5), 16);
let b = parseInt(color.slice(5, 7), 16);
r = Math.floor(r * (1 - percent / 100));
g = Math.floor(g * (1 - percent / 100));
b = Math.floor(b * (1 - percent / 100));
return `#${((1 << 24) + (r << 16) + (g << 8) + b).toString(16).slice(1)}`;
};
// Helper function to lighten a color (returns a lighter version of the provided color)
const lightenColor = (color: Color, percent: number): Color => {
let r = parseInt(color.slice(1, 3), 16);
let g = parseInt(color.slice(3, 5), 16);
let b = parseInt(color.slice(5, 7), 16);
r = Math.min(255, Math.floor(r * (1 + percent / 100)));
g = Math.min(255, Math.floor(g * (1 + percent / 100)));
b = Math.min(255, Math.floor(b * (1 + percent / 100)));
return `#${((1 << 24) + (r << 16) + (g << 8) + b).toString(16).slice(1)}`;
};
// This is the new function that calls the appropriate theme application
export const applyTheme = (theme: string, primary: string, secondary: string, accent: string, background: string, text: string) => {
switch (theme) {
case 'IOMARKET':
applyIOMarketTheme();
break;
case 'WHITE':
applyWhiteTheme();
break;
case 'BLACK':
applyBlackTheme();
break;
case 'CUSTOM':
applyCustomTheme();
break;
case 'BASIC-CUSTOM':
applyBasicCustomTheme(
primary,
secondary,
accent,
background,
text
);
break;
default:
applyIOMarketTheme();
break;
}
};