Compare commits

..

No commits in common. "4a8026ec723a31acec1cecad46e136450646ea08" and "953342c280e0407ade9112abac66859ee100638f" have entirely different histories.

6 changed files with 40 additions and 55 deletions

View File

@ -19,21 +19,18 @@ def main():
args = parser.parse_args() args = parser.parse_args()
config = read_config() config = read_config()
# If no config file exists and user does not go into "config mode"
if config is None and args.config is False: if config is None and args.config is False:
sys.exit("No Config available. please run: 'python project.py --config' to set it up") sys.exit("No Config available. please run: 'python project.py --config' to set it up")
# add config
elif args.config is True: elif args.config is True:
config = configure() config = configure()
write_config(config) write_config(config)
# change ui mode
elif args.m: elif args.m:
config = handle_change_mode(args) config = handle_change_mode(args)
write_config(config) write_config(config)
# start terminal ui
elif config["mode"] == "terminal": elif config["mode"] == "terminal":
handle_terminal(args) handle_terminal(args)
# start customtkinter ui
elif config["mode"] == "gui": elif config["mode"] == "gui":
# start gui # start gui
try: try:
@ -73,13 +70,9 @@ def read_config():
with open(CONFIG_FILE, "r") as f: with open(CONFIG_FILE, "r") as f:
return json.load(f) return json.load(f)
def write_config(config: dict): def write_config(config: dict):
try: with open(CONFIG_FILE, "w") as config_file:
with open(CONFIG_FILE, "w") as config_file: json.dump(config, config_file, indent=4)
json.dump(config, config_file, indent=4)
except FileNotFoundError:
sys.exit(ERROR_CORRPUTED_CONFIG)
def handle_change_mode(args): def handle_change_mode(args):
config = read_config() config = read_config()
@ -95,7 +88,7 @@ def handle_change_mode(args):
def handle_terminal(args): def handle_terminal(args):
config = read_config() config = read_config()
# if a prompt exists
if args.p: if args.p:
try: try:
bot = TerminalBot(args.p, args.f, **config["ollamaConfig"]) bot = TerminalBot(args.p, args.f, **config["ollamaConfig"])

View File

@ -4,7 +4,6 @@ class OllamaChatBot:
def __init__(self, base_url, model, headers): def __init__(self, base_url, model, headers):
self.base_url = base_url self.base_url = base_url
self.model = model self.model = model
# check if header exists
if self.is_empty(headers): if self.is_empty(headers):
self.headers = "" self.headers = ""
else: else:
@ -23,11 +22,12 @@ class OllamaChatBot:
headers = self.headers headers = self.headers
) )
def is_empty(self, dictionary: dict) -> bool: def is_empty(self, dictionary):
return len(dictionary) == 1 and list(dictionary.keys())[0] == '' and list(dictionary.values())[0] == '' return len(dictionary) == 1 and list(dictionary.keys())[0] == '' and list(dictionary.values())[0] == ''
def get_request(self, prompt: str) -> str:
def get_request(self, prompt):
messanges = [] messanges = []
self.messanges.append(prompt) self.messanges.append(prompt)
if len(self.messanges) > 5: if len(self.messanges) > 5:

View File

@ -24,7 +24,7 @@ class ChatGUI(CTk.CTk):
self.create_widgets() self.create_widgets()
self.start_message_processing_thread() self.start_message_processing_thread()
def get_response_from_ollama(self, prompt: str, context: str): def get_response_from_ollama(self, prompt, context):
try: try:
if context != "": if context != "":
if self.context != context: if self.context != context:
@ -52,7 +52,7 @@ class ChatGUI(CTk.CTk):
self.entry_bar.delete(0, CTk.END) # Clear input field after sending self.entry_bar.delete(0, CTk.END) # Clear input field after sending
Thread(target=lambda q, arg1, arg2: q.put(self.get_response_from_ollama(arg1, arg2)), args=(self.message_queue, message, context)).start() Thread(target=lambda q, arg1, arg2: q.put(self.get_response_from_ollama(arg1, arg2)), args=(self.message_queue, message, context)).start()
def show_reply(self, message: str): def show_reply(self, message):
bot_reply = Reply(master=self.messages_frame,reply_type = "Fabelous-AI-Bot", message=message) bot_reply = Reply(master=self.messages_frame,reply_type = "Fabelous-AI-Bot", message=message)
self.history.append(bot_reply) self.history.append(bot_reply)
bot_reply.pack(anchor="w", padx=5, pady=2) bot_reply.pack(anchor="w", padx=5, pady=2)
@ -115,7 +115,7 @@ class ChatGUI(CTk.CTk):
self.history = [] self.history = []
self.bot.messanges = [] self.bot.messanges = []
self.rag.init_ollama() self.rag.init_ollama()
self.file_entry.delete(0, "end")
def start_message_processing_thread(self): def start_message_processing_thread(self):

View File

@ -7,6 +7,7 @@ class Reply(tk.Frame):
def __init__(self, master, message,reply_type, font_size=12, background="#252525", text_color="white"): def __init__(self, master, message,reply_type, font_size=12, background="#252525", text_color="white"):
super().__init__(master) super().__init__(master)
# Define style configurations
self.font = ("Helvetica", font_size) self.font = ("Helvetica", font_size)
self.background = background self.background = background
self.text_color = text_color self.text_color = text_color
@ -15,7 +16,7 @@ class Reply(tk.Frame):
self.message = self.extract_code(message) self.message = self.extract_code(message)
self.reply_scope = [] self.reply_scope = []
# change background of message # Adjust the overall background of the ttk.Notebook
self.configure(background=self.background) self.configure(background=self.background)
@ -27,7 +28,6 @@ class Reply(tk.Frame):
row_index = 1 # Track the current grid row for widgets row_index = 1 # Track the current grid row for widgets
for part in self.message: for part in self.message:
# part is a code block
if part.startswith(CODE_PREFIX): if part.startswith(CODE_PREFIX):
part = part[len(CODE_PREFIX):] part = part[len(CODE_PREFIX):]
code = tk.Text(master=self, width=50, font=self.font, code = tk.Text(master=self, width=50, font=self.font,
@ -48,31 +48,22 @@ class Reply(tk.Frame):
row_index += 1 row_index += 1
def extract_code(self, input_string: str, replacement=CODE_PREFIX) -> list: def extract_code(self, input_string, replacement=CODE_PREFIX):
# Split the input string on the ``` delimiter split_parts = re.split(r'(```)', input_string)
split_parts = re.split(r'(```)', input_string) # Include the delimiter in the results output_array = []
previously_delimiter = False
# Initialize an empty list to store the output array for part in split_parts:
output_array = [] if part == "```":
previously_delimiter = True
continue
# Track whether the previous part was a ``` delimiter if previously_delimiter:
previously_delimiter = False part = re.sub(r'^\b\w+\b', replacement, part, count=1)
previously_delimiter = False
if part.strip():
output_array.append(part)
for part in split_parts: return output_array
# Check if the current part is a ``` delimiter
if part == "```":
previously_delimiter = True # Set flag if a delimiter is found
continue # Skip adding the delimiter to the output
# If the previous part was a delimiter, replace the first word with the specified string
if previously_delimiter:
part = re.sub(r'^\b\w+\b', replacement, part, count=1) # Replace the programming Language
previously_delimiter = False # Reset the flag
# Only add non-empty parts to the output array
if part.strip():
output_array.append(part)
return output_array

View File

@ -20,7 +20,7 @@ class Rag:
self.base_url_llm = base_url_llm self.base_url_llm = base_url_llm
self.base_url_embed = base_url_embed self.base_url_embed = base_url_embed
# check if header exists
if self.is_empty(base_header): if self.is_empty(base_header):
self.base_header = "" self.base_header = ""
else: else:
@ -38,7 +38,7 @@ class Rag:
headers = self.base_header headers = self.base_header
) )
def get_file(self, file_path: str): def get_file(self, file_path):
# Check if the file path starts with 'https://' # Check if the file path starts with 'https://'
if file_path.startswith('https://'): if file_path.startswith('https://'):
try: try:
@ -73,10 +73,12 @@ class Rag:
return True return True
def is_empty(self, dictionary: dict) -> bool: def is_empty(self, dictionary):
return len(dictionary) == 1 and list(dictionary.keys())[0] == '' and list(dictionary.values())[0] == '' return len(dictionary) == 1 and list(dictionary.keys())[0] == '' and list(dictionary.values())[0] == ''
def receive_data(self, file_path: str):
def receive_data(self, file_path):
try: try:
if self.get_file(file_path): if self.get_file(file_path):
text_splitter = RecursiveCharacterTextSplitter(chunk_size=250, chunk_overlap=0) text_splitter = RecursiveCharacterTextSplitter(chunk_size=250, chunk_overlap=0)
@ -87,11 +89,10 @@ class Rag:
return (True, f"'{file_path}' unsupported, read documentation for more information") return (True, f"'{file_path}' unsupported, read documentation for more information")
except (ValueError, AttributeError) as e: except (ValueError, AttributeError) as e:
return (True, f"An unexpected Error occuried: {e}") return (True, f"An unexpected Error occuried: {e}")
def get_request(self, prompt):
def get_request(self, prompt: str) -> str:
qachain=RetrievalQA.from_chain_type(self.chat_ollama, retriever=self.retriever) qachain=RetrievalQA.from_chain_type(self.chat_ollama, retriever=self.retriever)
try: try:
return qachain.invoke({"query": prompt})["result"] return qachain.invoke({"query": prompt})["result"]
except ValueError as e: except ValueError as e:
return f"An unexpected Error occuried: {e}" return (True, f"An unexpected Error occuried: {e}")

View File

@ -70,7 +70,7 @@ class TerminalBot:
else: else:
print(colored(message + "\n", "white")) print(colored(message + "\n", "white"))
def extract_code(self, input_string, replacement=CODE_PREFIX) -> list: def extract_code(self, input_string, replacement=CODE_PREFIX):
# Split the input string on the ``` delimiter # Split the input string on the ``` delimiter
split_parts = re.split(r'(```)', input_string) # Include the delimiter in the results split_parts = re.split(r'(```)', input_string) # Include the delimiter in the results
@ -89,7 +89,7 @@ class TerminalBot:
# If the previous part was a delimiter, replace the first word with the specified string # If the previous part was a delimiter, replace the first word with the specified string
if previously_delimiter: if previously_delimiter:
part = re.sub(r'^\b\w+\b', replacement, part, count=1) # Replace the programming Language part = re.sub(r'^\b\w+\b', replacement, part, count=1) # Replace the first word
previously_delimiter = False # Reset the flag previously_delimiter = False # Reset the flag
# Only add non-empty parts to the output array # Only add non-empty parts to the output array