mirror of
https://github.com/sissbruecker/linkding.git
synced 2025-08-14 05:59:29 +02:00
Implement bookmark import form
This commit is contained in:
@@ -1,2 +1,3 @@
|
||||
from .bookmarks import *
|
||||
from .api import *
|
||||
from .bookmarks import *
|
||||
from .settings import *
|
||||
|
@@ -5,7 +5,7 @@ from bookmarks.services.website_loader import load_website_metadata
|
||||
|
||||
|
||||
@login_required
|
||||
def website_metadata(request):
|
||||
def api_website_metadata(request):
|
||||
url = request.GET.get('url')
|
||||
metadata = load_website_metadata(url)
|
||||
return JsonResponse(metadata.to_dict())
|
||||
|
@@ -12,7 +12,7 @@ _default_page_size = 30
|
||||
|
||||
|
||||
@login_required
|
||||
def index(request):
|
||||
def bookmarks_index(request):
|
||||
page = request.GET.get('page')
|
||||
query_string = request.GET.get('q')
|
||||
query_set = queries.query_bookmarks(request.user, query_string)
|
||||
@@ -34,7 +34,7 @@ def index(request):
|
||||
|
||||
|
||||
@login_required
|
||||
def new(request):
|
||||
def bookmarks_new(request):
|
||||
if request.method == 'POST':
|
||||
form = BookmarkForm(request.POST)
|
||||
if form.is_valid():
|
||||
@@ -48,7 +48,7 @@ def new(request):
|
||||
|
||||
|
||||
@login_required
|
||||
def edit(request, bookmark_id: int):
|
||||
def bookmarks_edit(request, bookmark_id: int):
|
||||
bookmark = Bookmark.objects.get(pk=bookmark_id)
|
||||
if request.method == 'POST':
|
||||
form = BookmarkForm(request.POST, instance=bookmark)
|
||||
@@ -63,7 +63,7 @@ def edit(request, bookmark_id: int):
|
||||
|
||||
|
||||
@login_required
|
||||
def remove(request, bookmark_id: int):
|
||||
def bookmarks_remove(request, bookmark_id: int):
|
||||
bookmark = Bookmark.objects.get(pk=bookmark_id)
|
||||
bookmark.delete()
|
||||
return HttpResponseRedirect(reverse('bookmarks:index'))
|
||||
|
35
bookmarks/views/settings.py
Normal file
35
bookmarks/views/settings.py
Normal file
@@ -0,0 +1,35 @@
|
||||
from django.contrib import messages
|
||||
from django.contrib.auth.decorators import login_required
|
||||
from django.http import HttpResponseRedirect
|
||||
from django.shortcuts import render
|
||||
from django.urls import reverse
|
||||
|
||||
from services.importer import import_netscape_html
|
||||
|
||||
|
||||
@login_required
|
||||
def settings_index(request):
|
||||
import_message = _find_message_with_tag(messages.get_messages(request), 'bookmark_import')
|
||||
return render(request, 'settings/index.html', {
|
||||
'import_message': import_message
|
||||
})
|
||||
|
||||
|
||||
@login_required
|
||||
def settings_bookmark_import(request):
|
||||
try:
|
||||
import_file = request.FILES.get('import_file')
|
||||
content = import_file.read()
|
||||
import_netscape_html(content, request.user)
|
||||
messages.success(request, 'Bookmarks were successfully imported.', 'bookmark_import')
|
||||
except():
|
||||
messages.error(request, 'An error occurred during bookmark import.', 'bookmark_import')
|
||||
pass
|
||||
|
||||
return HttpResponseRedirect(reverse('bookmarks:settings_index'))
|
||||
|
||||
|
||||
def _find_message_with_tag(messages, tag):
|
||||
for message in messages:
|
||||
if message.extra_tags == tag:
|
||||
return message
|
Reference in New Issue
Block a user