uses document border, easier to grab

This commit is contained in:
Santiago Lema 2025-05-10 01:19:14 -03:00
parent 38e8c87118
commit 2df9419ce2
6 changed files with 72 additions and 51 deletions

View file

@ -5,6 +5,7 @@
#include "MainWindow.h"
static int progressAnim = 0;
static int progressColor = 0;
static bool progressColorUp = false;
@ -17,6 +18,7 @@ static bool progressColorUp = false;
#include <Menu.h>
#include <MenuBar.h>
#include <MimeType.h>
#include <Resources.h>
#include <ScrollView.h>
#include <StringView.h>
#include <TranslationUtils.h>
@ -25,7 +27,10 @@ static bool progressColorUp = false;
#include <MessageRunner.h>
#include <View.h>
#include <Path.h>
#include "Conversation.h"
#include <FindDirectory.h>
#undef B_TRANSLATION_CONTEXT
#define B_TRANSLATION_CONTEXT "Window"
@ -106,9 +111,23 @@ MainWindow::MainWindow()
_answerView->SetFlags(_answerView->Flags() | B_FULL_UPDATE_ON_RESIZE);
_answerScrollView->SetFlags(_answerView->Flags() | B_FULL_UPDATE_ON_RESIZE);
/*
BView *imageView = new BView("icon_view", B_WILL_DRAW | B_FOLLOW_NONE);
imageView->SetViewColor(ui_color(B_PANEL_BACKGROUND_COLOR));
BBitmap* oneImage = BTranslationUtils::GetBitmap('RAWT', 77, NULL);
imageView->SetViewColor(ui_color(B_CONTROL_BORDER_COLOR));
if (oneImage) {
imageView->SetViewBitmap(oneImage,B_FOLLOW_LEFT_TOP, B_TILE_BITMAP);
printf("Image loaded!\n");
}
else {
printf("Image NOT loaded!\n");
}
*/
// BView *imageView = new BView("icon_view", B_WILL_DRAW | B_FOLLOW_NONE);
// imageView->SetViewColor(ui_color(B_PANEL_BACKGROUND_COLOR));
BStringView *headerQuestion =
new BStringView("questionLabel", "Your question: ");
@ -119,67 +138,62 @@ rgb_color colorQuestion = {100, 100,150, 255};
//high color = txt
headerQuestion->SetHighColor(colorQuestion);
headerAnswer->SetHighColor(colorQuestion);
headerAnswer->SetHighColor(colorQuestion);
BLayoutBuilder::Group<>(this, B_VERTICAL, 0)
BLayoutBuilder::Group<>(this, B_VERTICAL, 0)
.AddGlue(0.1)
.Add(headerQuestion)
.AddGroup(B_HORIZONTAL, 0, 1)
.Add(_inputField)
.AddGlue(0.01)
// .Add(imageView)
.AddGlue(0.1)
.Add(headerQuestion)
.AddGroup(B_HORIZONTAL, 0, 1)
.Add(_inputField)
.AddGlue(0.01)
.AddGroup(B_VERTICAL, B_USE_DEFAULT_SPACING, 0)
. AddGroup(B_HORIZONTAL, 0)
.Add(_infoConversation).AddGlue(0.1)
.End()
. AddGroup(B_HORIZONTAL, 0)
.Add(_modelField).AddGlue(0.1)
.End()
. AddGroup(B_HORIZONTAL, 0)
.Add(_sendButton).AddGlue(0.1)
.End()
.End()
.End()
.AddGroup(B_VERTICAL, B_USE_DEFAULT_SPACING, 0)
.AddGlue(0.1)
.Add(headerAnswer)
.AddGroup(B_VERTICAL, B_USE_DEFAULT_SPACING, 1.0)
.AddGroup(B_HORIZONTAL, 0)
.Add(_infoConversation)
.AddGlue(0.1)
.End()
.AddGroup(B_HORIZONTAL, 0)
.Add(_modelField)
.AddGlue(0.1)
.End()
.AddGroup(B_HORIZONTAL, 0)
.Add(_sendButton)
.AddGlue(0.1)
.End()
.Add(_answerScrollView, 1)
.Add(_progress,0.1)
.Add(_infoView,0.1)
.End()
.SetInsets(6,6, 6, 6)
.End()
.End()
.End();
.AddGlue(0.1)
.Add(headerAnswer)
.AddGroup(B_VERTICAL, B_USE_DEFAULT_SPACING, 1.0)
// Loop Just to animate progress in Bar
BMessageRunner *runner = new BMessageRunner(this, // target BHandler
new BMessage(kPulse),
100000 // interval in μs (0ms)
.Add(_answerScrollView, 1)
.Add(_progress, 0.1)
.Add(_infoView, 0.1)
.End()
.SetInsets(6, 6, 6, 6)
.End();
// Loop Just to animate progress in Bar
BMessageRunner *runner = new BMessageRunner(this, // target BHandler
new BMessage(kPulse),
100000 // interval in μs (0ms)
);
);
updateHistoryInfo();
updateHistoryInfo();
PostMessage(kCheckKey);
PostMessage(kCheckKey);
}
void MainWindow::checkValidKey() {
if (!_conversation->validKey) {