diff --git a/css/html_instruct_style.css b/css/html_instruct_style.css
index 5a439304f7..130c353a7c 100644
--- a/css/html_instruct_style.css
+++ b/css/html_instruct_style.css
@@ -2,8 +2,12 @@
background: var(--block-background-fill);
padding: 24px 19px;
padding-right: 19px !important;
+ padding-top: 0px;
border: 1px solid var(--block-border-color);
- border-radius: 8px;
+}
+
+.chat > .messages {
+ padding-top: 28px !important;
}
.message {
@@ -15,6 +19,10 @@
line-height: 24px;
}
+.message:first-child {
+ padding-top: 0;
+}
+
.username {
display: none;
}
diff --git a/css/main.css b/css/main.css
index 33feb179bd..fa706ba955 100644
--- a/css/main.css
+++ b/css/main.css
@@ -91,16 +91,19 @@ div.svelte-15lo0d8 > *, div.svelte-15lo0d8 > .form > * {
.header_bar {
background-color: #f7f7f7;
- margin-bottom: 19px;
+ box-shadow: 0 2px 3px rgba(22 22 22 / 35%);
+ margin-bottom: 0px;
overflow-x: scroll;
margin-left: calc(-1 * var(--size-4));
margin-right: calc(-1 * var(--size-4));
display: block !important;
text-wrap: nowrap;
+ z-index: 90;
}
.dark .header_bar {
border: none !important;
+ box-shadow: 0 3px 4px rgba(20 20 20 / 60%);
background-color: #8080802b;
}
@@ -299,6 +302,10 @@ div.svelte-362y77>*, div.svelte-362y77>.form>* {
width: 100%;
}
+#chat-tab {
+ padding-top: 0px;
+}
+
#chat-tab button#Generate, #chat-tab button#stop {
width: 89.3438px !important;
}
@@ -318,14 +325,6 @@ div.svelte-362y77>*, div.svelte-362y77>.form>* {
padding-left: 0;
padding-right: 0;
}
-
- .chat-parent {
- height: calc(100dvh - 179px) !important;
- }
-
- .old-ui .chat-parent {
- height: calc(100dvh - 310px) !important;
- }
}
.chat {
@@ -339,24 +338,31 @@ div.svelte-362y77>*, div.svelte-362y77>.form>* {
flex-direction: column;
word-break: break-word;
overflow-wrap: anywhere;
+ border-top: none;
+ border-radius: 0 0 0 8px;
}
.chat-parent {
- height: calc(100dvh - 181px);
+ height: calc(100dvh - 98px - var(--header-height) - var(--input-delta));
overflow: auto !important;
+ border-radius: 0 !important;
+ margin-bottom: var(--input-delta) !important;
}
.old-ui .chat-parent {
- height: calc(100dvh - 270px);
+ height: calc(100dvh - 192px - var(--header-height) - var(--input-delta));
+ margin-bottom: var(--input-delta) !important;
}
.chat-parent.bigchat {
- height: calc(100dvh - 181px) !important;
+ height: calc(100dvh - 98px - var(--header-height) - var(--input-delta)) !important;
+ margin-bottom: var(--input-delta) !important;
}
.chat > .messages {
display: flex;
flex-direction: column;
+ padding-top: 25px;
}
.chat .message:last-child {
@@ -624,11 +630,11 @@ div.svelte-362y77>*, div.svelte-362y77>.form>* {
}
#chat-col {
- padding-bottom: 115px;
+ padding-bottom: 100px;
}
.old-ui #chat-col, #chat-col.bigchat {
- padding-bottom: 95px !important;
+ padding-bottom: 80px !important;
}
.old-ui #chat-buttons #clear-history-confirm {
diff --git a/js/main.js b/js/main.js
index 9f10915d83..0828dee45b 100644
--- a/js/main.js
+++ b/js/main.js
@@ -16,16 +16,20 @@ document.querySelector(".header_bar").addEventListener("click", function(event)
// Check if one of the generation tabs is visible
if (chat_visible || notebook_visible || default_visible) {
- extensions.style.display = "flex";
+ extensions && (extensions.style.display = "flex");
+
if (chat_visible) {
- extensions.style.maxWidth = "880px";
- extensions.style.padding = "0px";
+ this.style.marginBottom = "0px";
+ extensions && (extensions.style.maxWidth = "880px");
+ extensions && (extensions.style.padding = "0px");
} else {
- extensions.style.maxWidth = "none";
- extensions.style.padding = "15px";
+ this.style.marginBottom = "19px";
+ extensions && (extensions.style.maxWidth = "none");
+ extensions && (extensions.style.padding = "15px");
}
} else {
- extensions.style.display = "none";
+ this.style.marginBottom = "19px";
+ extensions && (extensions.style.display = "none");
}
}
});
@@ -123,7 +127,7 @@ targetElement.addEventListener("scroll", function() {
// Create a MutationObserver instance
const observer = new MutationObserver(function(mutations) {
mutations.forEach(function(mutation) {
- updateChatHeight();
+ updateCssProperties();
if(!isScrolled) {
targetElement.scrollTop = targetElement.scrollHeight;
@@ -326,14 +330,32 @@ function toggleBigPicture() {
}
//------------------------------------------------
-// Define the --chat-height global CSS variable to
-// the height of the chat parent
+// Define global CSS properties for resizing and
+// positioning certain elements
//------------------------------------------------
-function updateChatHeight() {
- const chatContainer = document.getElementById('chat').parentNode.parentNode.parentNode;
- const newChatHeight = `${chatContainer.clientHeight}px`;
+let currentChatInputHeight = 0;
+function updateCssProperties() {
+ // Set the height of the chat area
+ const chatContainer = document.getElementById('chat').parentNode.parentNode.parentNode;
+ const chatInputHeight = document.querySelector('#chat-input textarea').clientHeight;
+ const newChatHeight = `${chatContainer.clientHeight - chatInputHeight + 40}px`;
document.documentElement.style.setProperty('--chat-height', newChatHeight);
+ document.documentElement.style.setProperty('--input-delta', `${chatInputHeight - 40}px`);
+
+ // Set the position offset of the chat input box
+ const header = document.querySelector('.header_bar');
+ const headerHeight = `${header.clientHeight}px`;
+ document.documentElement.style.setProperty('--header-height', headerHeight);
+
+ // Offset the scroll position of the chat area
+ if (chatInputHeight !== currentChatInputHeight) {
+ chatContainer.scrollTop += chatInputHeight > currentChatInputHeight ? chatInputHeight : -chatInputHeight;
+ currentChatInputHeight = chatInputHeight;
+ }
}
-window.addEventListener('resize', updateChatHeight);
+new ResizeObserver(updateCssProperties)
+ .observe(document.querySelector('#chat-input textarea'));
+
+window.addEventListener('resize', updateCssProperties);
diff --git a/js/show_controls.js b/js/show_controls.js
index 0ba1ecde75..cdd6efc40b 100644
--- a/js/show_controls.js
+++ b/js/show_controls.js
@@ -10,6 +10,7 @@ function toggle_controls(value) {
chatParent.classList.remove("bigchat");
document.getElementById("chat-input-row").classList.remove("bigchat");
document.getElementById("chat-col").classList.remove("bigchat");
+ document.getElementById("chat-tab").style.paddingBottom = "";
let gallery_element = document.getElementById('gallery-extension');
if (gallery_element) {
@@ -24,5 +25,6 @@ function toggle_controls(value) {
chatParent.classList.add("bigchat");
document.getElementById("chat-input-row").classList.add("bigchat");
document.getElementById("chat-col").classList.add("bigchat");
+ document.getElementById("chat-tab").style.paddingBottom = "0px";
}
}