implement document view page
Run Tests / Run Tests (push) Successful in 44s
Details
Run Tests / Run Tests (push) Successful in 44s
Details
This commit is contained in:
parent
f7db98d91e
commit
9476c49139
|
@ -5,10 +5,9 @@ services:
|
||||||
- 5672:5672
|
- 5672:5672
|
||||||
- 15672:15672
|
- 15672:15672
|
||||||
|
|
||||||
|
|
||||||
vllm:
|
vllm:
|
||||||
image: vllm/vllm-openai:latest
|
image: vllm/vllm-openai:latest
|
||||||
command: "--model Qwen/Qwen2-VL-2B-Instruct-GPTQ-Int4 --quantization gptq"
|
command: "--model Qwen/Qwen2-VL-2B-Instruct-GPTQ-Int4 --quantization gptq "
|
||||||
volumes:
|
volumes:
|
||||||
- ~/.cache/huggingface:/root/.cache/huggingface
|
- ~/.cache/huggingface:/root/.cache/huggingface
|
||||||
ports:
|
ports:
|
||||||
|
|
|
@ -149,6 +149,7 @@ CELERY_BROKER_URL = "amqp://guest:guest@localhost/"
|
||||||
|
|
||||||
|
|
||||||
OPENAI_API_BASE = os.getenv("OPENAI_API_BASE")
|
OPENAI_API_BASE = os.getenv("OPENAI_API_BASE")
|
||||||
#OPENAI_API_KEY = os.getenv("OPENAI_API_KEY")
|
OPENAI_API_KEY = os.getenv("OPENAI_API_KEY")
|
||||||
OPENAI_API_KEY = "test"
|
#OPENAI_API_KEY = "test"
|
||||||
OPENAI_MODEL = os.getenv("OPENAI_MODEL", "openai/gpt-4o")
|
OPENAI_MODEL = os.getenv("OPENAI_MODEL", "openai/gpt-4o")
|
||||||
|
#OPENAI_MODEL="ollama/llama3.2-vision"
|
||||||
|
|
|
@ -0,0 +1,18 @@
|
||||||
|
# Generated by Django 4.2.16 on 2024-12-15 06:34
|
||||||
|
|
||||||
|
from django.db import migrations, models
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('webui', '0005_imagememo_error_message'),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='imagememo',
|
||||||
|
name='model_name',
|
||||||
|
field=models.CharField(max_length=255, null=True),
|
||||||
|
),
|
||||||
|
]
|
|
@ -3,6 +3,7 @@ from django.contrib.auth.base_user import BaseUserManager
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
|
||||||
from uuid import uuid4
|
from uuid import uuid4
|
||||||
|
from email.header import Charset
|
||||||
|
|
||||||
|
|
||||||
class UserManager(BaseUserManager):
|
class UserManager(BaseUserManager):
|
||||||
|
@ -58,6 +59,8 @@ class ImageMemo(models.Model):
|
||||||
|
|
||||||
author = models.ForeignKey("User", on_delete=models.CASCADE, related_name="memos")
|
author = models.ForeignKey("User", on_delete=models.CASCADE, related_name="memos")
|
||||||
|
|
||||||
|
model_name = models.CharField(max_length=255, null=True)
|
||||||
|
|
||||||
created_at = models.DateTimeField(auto_now_add=True)
|
created_at = models.DateTimeField(auto_now_add=True)
|
||||||
updated_at = models.DateTimeField(
|
updated_at = models.DateTimeField(
|
||||||
auto_now=True,
|
auto_now=True,
|
||||||
|
|
|
@ -16,6 +16,12 @@ If any words or letters are unclear, denote them with a '?<word>?'.
|
||||||
|
|
||||||
For example if you were not sure whether a word is blow or blew you would transcribe it as '?blow?'
|
For example if you were not sure whether a word is blow or blew you would transcribe it as '?blow?'
|
||||||
|
|
||||||
|
If a text is underlined followed by a newline that indicates that it is a header. Use markdown H2 to denote it as such.
|
||||||
|
|
||||||
|
Make sure to add 2 newlines newlines between sections.
|
||||||
|
|
||||||
|
Anything that looks visually like a bullet point should be treated as such. This includes lines starting with hyphens. Replace bullet point indicators with * in the interpretted text.
|
||||||
|
|
||||||
Please include whitespace and formatting for headings too.
|
Please include whitespace and formatting for headings too.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
|
|
@ -23,17 +23,23 @@
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td class="font-medium pr-4">Created:</td>
|
<td class="font-medium pr-4">Created:</td>
|
||||||
<td class="text-gray-600">{{ document.created_at|date:"d/m/Y H:i" }}</td>
|
<td class="text-gray-600">
|
||||||
|
{{ document.created_at|date:"d/m/Y H:i:s" }}
|
||||||
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td class="font-medium pr-4">Updated:</td>
|
<td class="font-medium pr-4">Updated:</td>
|
||||||
<td class="text-gray-600">{{ document.updated_at|date:"d/m/Y H:i" }}</td>
|
<td class="text-gray-600">
|
||||||
|
{{ document.updated_at|date:"d/m/Y H:i:s" }}
|
||||||
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
</table>
|
</table>
|
||||||
</div>
|
</div>
|
||||||
<div class="prose max-w-full">
|
<div class="prose max-w-full">
|
||||||
<div class="flex justify-between items-center mb-3">
|
<div class="flex justify-between items-center mb-3">
|
||||||
<h3 class="text-xl font-semibold text-gray-800">Content:</h3>
|
<h3 class="text-xl font-semibold text-gray-800">
|
||||||
|
Content:
|
||||||
|
</h3>
|
||||||
<button
|
<button
|
||||||
id="copyButton"
|
id="copyButton"
|
||||||
class="bg-gray-200 text-gray-700 px-3 py-1 rounded-md hover:bg-gray-300 transition duration-300 flex items-center text-sm"
|
class="bg-gray-200 text-gray-700 px-3 py-1 rounded-md hover:bg-gray-300 transition duration-300 flex items-center text-sm"
|
||||||
|
@ -55,10 +61,15 @@
|
||||||
Copy to Clipboard
|
Copy to Clipboard
|
||||||
</button>
|
</button>
|
||||||
</div>
|
</div>
|
||||||
<div id="markdown-rendered" class="bg-gray-50 p-4 rounded-md">
|
<div
|
||||||
{{ document.content|markdown }}
|
id="markdown-rendered"
|
||||||
|
class="bg-gray-50 p-4 rounded-md"
|
||||||
|
>
|
||||||
|
{{ markup|safe }}
|
||||||
|
</div>
|
||||||
|
<div id="markdown-content" class="hidden">
|
||||||
|
{{ document.content}}
|
||||||
</div>
|
</div>
|
||||||
<div id="markdown-content" class="hidden">{{ document.content}}</div>
|
|
||||||
</div>
|
</div>
|
||||||
<div class="mt-8 flex space-x-4">
|
<div class="mt-8 flex space-x-4">
|
||||||
<a
|
<a
|
||||||
|
@ -149,7 +160,9 @@
|
||||||
<script>
|
<script>
|
||||||
document.addEventListener("DOMContentLoaded", (event) => {
|
document.addEventListener("DOMContentLoaded", (event) => {
|
||||||
// Syntax highlighting
|
// Syntax highlighting
|
||||||
document.querySelectorAll("#markdown-content pre code").forEach((block) => {
|
document
|
||||||
|
.querySelectorAll("#markdown-content pre code")
|
||||||
|
.forEach((block) => {
|
||||||
hljs.highlightElement(block);
|
hljs.highlightElement(block);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -168,8 +181,14 @@
|
||||||
setTimeout(() => {
|
setTimeout(() => {
|
||||||
copyButton.innerHTML =
|
copyButton.innerHTML =
|
||||||
'<svg class="w-4 h-4 mr-2" fill="none" stroke="currentColor" viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg"><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M8 16H6a2 2 0 01-2-2V6a2 2 0 012-2h8a2 2 0 012 2v2m-6 12h8a2 2 0 002-2v-8a2 2 0 00-2-2h-8a2 2 0 00-2 2v8a2 2 0 002 2z"></path></svg>Copy to Clipboard';
|
'<svg class="w-4 h-4 mr-2" fill="none" stroke="currentColor" viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg"><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M8 16H6a2 2 0 01-2-2V6a2 2 0 012-2h8a2 2 0 012 2v2m-6 12h8a2 2 0 002-2v-8a2 2 0 00-2-2h-8a2 2 0 00-2 2v8a2 2 0 002 2z"></path></svg>Copy to Clipboard';
|
||||||
copyButton.classList.remove("bg-green-500", "text-white");
|
copyButton.classList.remove(
|
||||||
copyButton.classList.add("bg-gray-200", "text-gray-700");
|
"bg-green-500",
|
||||||
|
"text-white",
|
||||||
|
);
|
||||||
|
copyButton.classList.add(
|
||||||
|
"bg-gray-200",
|
||||||
|
"text-gray-700",
|
||||||
|
);
|
||||||
}, 2000);
|
}, 2000);
|
||||||
})
|
})
|
||||||
.catch((err) => {
|
.catch((err) => {
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
import logging
|
import logging
|
||||||
import os
|
import os
|
||||||
|
import markdown
|
||||||
|
|
||||||
from django.contrib import messages
|
from django.contrib import messages
|
||||||
from django.shortcuts import redirect, render
|
from django.shortcuts import redirect, render
|
||||||
|
@ -61,13 +62,15 @@ def view_document(request: HttpRequest, pk: str):
|
||||||
# find document with given ID (pk path param) and current user id
|
# find document with given ID (pk path param) and current user id
|
||||||
document = ImageMemo.objects.filter(id=pk, author__id=request.user.id).first()
|
document = ImageMemo.objects.filter(id=pk, author__id=request.user.id).first()
|
||||||
|
|
||||||
|
doc_markup = markdown.markdown(document.content)
|
||||||
|
|
||||||
if not document:
|
if not document:
|
||||||
logger.debug(f"No memo found for user={request.user.id} and memo_id={pk}")
|
logger.debug(f"No memo found for user={request.user.id} and memo_id={pk}")
|
||||||
return HttpResponse(content="Document not found", status=404)
|
return HttpResponse(content="Document not found", status=404)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
return render(request, "document.html", context={"document": document})
|
return render(request, "document.html", context={"document": document, "markup": doc_markup})
|
||||||
|
|
||||||
|
|
||||||
@login_required
|
@login_required
|
||||||
|
|
|
@ -11,6 +11,7 @@ dependencies = [
|
||||||
"django>=4.2.16",
|
"django>=4.2.16",
|
||||||
"litellm>=1.54.1",
|
"litellm>=1.54.1",
|
||||||
"loguru>=0.7.3",
|
"loguru>=0.7.3",
|
||||||
|
"markdown>=3.7",
|
||||||
"pillow>=11.0.0",
|
"pillow>=11.0.0",
|
||||||
"pytest-django>=4.9.0",
|
"pytest-django>=4.9.0",
|
||||||
"pytest-loguru>=0.4.0",
|
"pytest-loguru>=0.4.0",
|
||||||
|
|
2
uv.lock
2
uv.lock
|
@ -1002,6 +1002,7 @@ dependencies = [
|
||||||
{ name = "django-markdownify" },
|
{ name = "django-markdownify" },
|
||||||
{ name = "litellm" },
|
{ name = "litellm" },
|
||||||
{ name = "loguru" },
|
{ name = "loguru" },
|
||||||
|
{ name = "markdown" },
|
||||||
{ name = "pillow" },
|
{ name = "pillow" },
|
||||||
{ name = "pytest" },
|
{ name = "pytest" },
|
||||||
{ name = "pytest-django" },
|
{ name = "pytest-django" },
|
||||||
|
@ -1018,6 +1019,7 @@ requires-dist = [
|
||||||
{ name = "django-markdownify", specifier = ">=0.9.5" },
|
{ name = "django-markdownify", specifier = ">=0.9.5" },
|
||||||
{ name = "litellm", specifier = ">=1.54.1" },
|
{ name = "litellm", specifier = ">=1.54.1" },
|
||||||
{ name = "loguru", specifier = ">=0.7.3" },
|
{ name = "loguru", specifier = ">=0.7.3" },
|
||||||
|
{ name = "markdown", specifier = ">=3.7" },
|
||||||
{ name = "pillow", specifier = ">=11.0.0" },
|
{ name = "pillow", specifier = ">=11.0.0" },
|
||||||
{ name = "pytest", specifier = ">=8.3.4" },
|
{ name = "pytest", specifier = ">=8.3.4" },
|
||||||
{ name = "pytest-django", specifier = ">=4.9.0" },
|
{ name = "pytest-django", specifier = ">=4.9.0" },
|
||||||
|
|
Loading…
Reference in New Issue