mirror of
https://github.com/sissbruecker/linkding.git
synced 2025-08-25 03:16:56 +02:00
Implement archive view (#46)
This commit is contained in:
34
bookmarks/templates/bookmarks/archive.html
Normal file
34
bookmarks/templates/bookmarks/archive.html
Normal file
@@ -0,0 +1,34 @@
|
|||||||
|
{% extends "bookmarks/layout.html" %}
|
||||||
|
{% load static %}
|
||||||
|
{% load shared %}
|
||||||
|
{% load bookmarks %}
|
||||||
|
|
||||||
|
{% block content %}
|
||||||
|
<div class="bookmarks-page columns">
|
||||||
|
|
||||||
|
{# Bookmark list #}
|
||||||
|
<section class="content-area column col-8 col-md-12">
|
||||||
|
<div class="content-area-header">
|
||||||
|
<h2>Archived bookmarks</h2>
|
||||||
|
<div class="spacer"></div>
|
||||||
|
{% include 'bookmarks/search.html' %}
|
||||||
|
</div>
|
||||||
|
|
||||||
|
{% if empty %}
|
||||||
|
{% include 'bookmarks/empty_bookmarks.html' %}
|
||||||
|
{% else %}
|
||||||
|
{% bookmark_list bookmarks return_url %}
|
||||||
|
{% endif %}
|
||||||
|
</section>
|
||||||
|
|
||||||
|
{# Tag list #}
|
||||||
|
<section class="content-area column col-4 hide-md">
|
||||||
|
<div class="content-area-header">
|
||||||
|
<h2>Tags</h2>
|
||||||
|
</div>
|
||||||
|
{% tag_cloud tags %}
|
||||||
|
</section>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<script src="{% static "bundle.js" %}"></script>
|
||||||
|
{% endblock %}
|
@@ -11,17 +11,7 @@
|
|||||||
<div class="content-area-header">
|
<div class="content-area-header">
|
||||||
<h2>Bookmarks</h2>
|
<h2>Bookmarks</h2>
|
||||||
<div class="spacer"></div>
|
<div class="spacer"></div>
|
||||||
<div class="search">
|
{% include 'bookmarks/search.html' %}
|
||||||
<form action="{% url 'bookmarks:index' %}" method="get" role="search">
|
|
||||||
<div class="input-group">
|
|
||||||
<span id="search-input-wrap">
|
|
||||||
<input type="search" class="form-input" name="q" placeholder="Search for words or #tags"
|
|
||||||
value="{{ query }}">
|
|
||||||
</span>
|
|
||||||
<input type="submit" value="Search" class="btn input-group-btn">
|
|
||||||
</div>
|
|
||||||
</form>
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
{% if empty %}
|
{% if empty %}
|
||||||
@@ -40,24 +30,5 @@
|
|||||||
</section>
|
</section>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
{# Replace search input with auto-complete component #}
|
|
||||||
<script src="{% static "bundle.js" %}"></script>
|
<script src="{% static "bundle.js" %}"></script>
|
||||||
<script type="application/javascript">
|
|
||||||
const currentTagsString = '{{ tags_string }}';
|
|
||||||
const currentTags = currentTagsString.split(' ');
|
|
||||||
const apiClient = new linkding.ApiClient('{% url 'bookmarks:api-root' %}')
|
|
||||||
const wrapper = document.getElementById('search-input-wrap')
|
|
||||||
const newWrapper = document.createElement('div')
|
|
||||||
new linkding.SearchAutoComplete({
|
|
||||||
target: newWrapper,
|
|
||||||
props: {
|
|
||||||
name: 'q',
|
|
||||||
placeholder: 'Search for words or #tags',
|
|
||||||
value: '{{ query }}',
|
|
||||||
tags: currentTags,
|
|
||||||
apiClient
|
|
||||||
}
|
|
||||||
})
|
|
||||||
wrapper.parentElement.replaceChild(newWrapper, wrapper)
|
|
||||||
</script>
|
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
|
@@ -1,6 +1,7 @@
|
|||||||
{# Basic menu list #}
|
{# Basic menu list #}
|
||||||
<div class="hide-md">
|
<div class="hide-md">
|
||||||
<a href="{% url 'bookmarks:new' %}" class="btn btn-primary mr-2">Add bookmark</a>
|
<a href="{% url 'bookmarks:new' %}" class="btn btn-primary mr-2">Add bookmark</a>
|
||||||
|
<a href="{% url 'bookmarks:archived' %}" class="btn btn-link">Archive</a>
|
||||||
<a href="{% url 'bookmarks:bookmarklet' %}" class="btn btn-link">Bookmarklet</a>
|
<a href="{% url 'bookmarks:bookmarklet' %}" class="btn btn-link">Bookmarklet</a>
|
||||||
<a href="{% url 'bookmarks:settings.index' %}" class="btn btn-link">Settings</a>
|
<a href="{% url 'bookmarks:settings.index' %}" class="btn btn-link">Settings</a>
|
||||||
<a href="{% url 'logout' %}" class="btn btn-link">Logout</a>
|
<a href="{% url 'logout' %}" class="btn btn-link">Logout</a>
|
||||||
@@ -16,6 +17,9 @@
|
|||||||
</a>
|
</a>
|
||||||
<!-- menu component -->
|
<!-- menu component -->
|
||||||
<ul class="menu">
|
<ul class="menu">
|
||||||
|
<li>
|
||||||
|
<a href="{% url 'bookmarks:archived' %}" class="btn btn-link">Archive</a>
|
||||||
|
</li>
|
||||||
<li>
|
<li>
|
||||||
<a href="{% url 'bookmarks:bookmarklet' %}" class="btn btn-link">Bookmarklet</a>
|
<a href="{% url 'bookmarks:bookmarklet' %}" class="btn btn-link">Bookmarklet</a>
|
||||||
</li>
|
</li>
|
||||||
|
33
bookmarks/templates/bookmarks/search.html
Normal file
33
bookmarks/templates/bookmarks/search.html
Normal file
@@ -0,0 +1,33 @@
|
|||||||
|
<div class="search">
|
||||||
|
<form action="" method="get" role="search">
|
||||||
|
<div class="input-group">
|
||||||
|
<span id="search-input-wrap">
|
||||||
|
<input type="search" class="form-input" name="q" placeholder="Search for words or #tags"
|
||||||
|
value="{{ query }}">
|
||||||
|
</span>
|
||||||
|
<input type="submit" value="Search" class="btn input-group-btn">
|
||||||
|
</div>
|
||||||
|
</form>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
{# Replace search input with auto-complete component #}
|
||||||
|
<script type="application/javascript">
|
||||||
|
window.addEventListener("load", function() {
|
||||||
|
const currentTagsString = '{{ tags_string }}';
|
||||||
|
const currentTags = currentTagsString.split(' ');
|
||||||
|
const apiClient = new linkding.ApiClient('{% url 'bookmarks:api-root' %}')
|
||||||
|
const wrapper = document.getElementById('search-input-wrap')
|
||||||
|
const newWrapper = document.createElement('div')
|
||||||
|
new linkding.SearchAutoComplete({
|
||||||
|
target: newWrapper,
|
||||||
|
props: {
|
||||||
|
name: 'q',
|
||||||
|
placeholder: 'Search for words or #tags',
|
||||||
|
value: '{{ query }}',
|
||||||
|
tags: currentTags,
|
||||||
|
apiClient
|
||||||
|
}
|
||||||
|
})
|
||||||
|
wrapper.parentElement.replaceChild(newWrapper, wrapper)
|
||||||
|
});
|
||||||
|
</script>
|
@@ -11,6 +11,7 @@ urlpatterns = [
|
|||||||
url(r'^$', RedirectView.as_view(pattern_name='bookmarks:index', permanent=False)),
|
url(r'^$', RedirectView.as_view(pattern_name='bookmarks:index', permanent=False)),
|
||||||
# Bookmarks
|
# Bookmarks
|
||||||
path('bookmarks', views.bookmarks.index, name='index'),
|
path('bookmarks', views.bookmarks.index, name='index'),
|
||||||
|
path('bookmarks/archived', views.bookmarks.archived, name='archived'),
|
||||||
path('bookmarks/new', views.bookmarks.new, name='new'),
|
path('bookmarks/new', views.bookmarks.new, name='new'),
|
||||||
path('bookmarks/close', views.bookmarks.close, name='close'),
|
path('bookmarks/close', views.bookmarks.close, name='close'),
|
||||||
path('bookmarks/<int:bookmark_id>/edit', views.bookmarks.edit, name='edit'),
|
path('bookmarks/<int:bookmark_id>/edit', views.bookmarks.edit, name='edit'),
|
||||||
|
@@ -16,22 +16,38 @@ _default_page_size = 30
|
|||||||
|
|
||||||
@login_required
|
@login_required
|
||||||
def index(request):
|
def index(request):
|
||||||
page = request.GET.get('page')
|
|
||||||
query_string = request.GET.get('q')
|
query_string = request.GET.get('q')
|
||||||
query_set = queries.query_bookmarks(request.user, query_string)
|
query_set = queries.query_bookmarks(request.user, query_string)
|
||||||
|
base_url = reverse('bookmarks:index')
|
||||||
|
context = get_bookmark_view_context(request, query_set, base_url)
|
||||||
|
return render(request, 'bookmarks/index.html', context)
|
||||||
|
|
||||||
|
|
||||||
|
@login_required
|
||||||
|
def archived(request):
|
||||||
|
query_string = request.GET.get('q')
|
||||||
|
query_set = queries.query_archived_bookmarks(request.user, query_string)
|
||||||
|
base_url = reverse('bookmarks:archived')
|
||||||
|
context = get_bookmark_view_context(request, query_set, base_url)
|
||||||
|
return render(request, 'bookmarks/archive.html', context)
|
||||||
|
|
||||||
|
|
||||||
|
def get_bookmark_view_context(request, query_set, base_url):
|
||||||
|
page = request.GET.get('page')
|
||||||
|
query_string = request.GET.get('q')
|
||||||
paginator = Paginator(query_set, _default_page_size)
|
paginator = Paginator(query_set, _default_page_size)
|
||||||
bookmarks = paginator.get_page(page)
|
bookmarks = paginator.get_page(page)
|
||||||
tags = queries.query_tags(request.user, query_string)
|
tags = queries.query_tags(request.user, query_string)
|
||||||
tag_names = [tag.name for tag in tags]
|
tag_names = [tag.name for tag in tags]
|
||||||
tags_string = build_tag_string(tag_names, ' ')
|
tags_string = build_tag_string(tag_names, ' ')
|
||||||
return_url = generate_index_return_url(page, query_string)
|
return_url = generate_return_url(base_url, page, query_string)
|
||||||
|
|
||||||
if request.GET.get('tag'):
|
if request.GET.get('tag'):
|
||||||
mod = request.GET.copy()
|
mod = request.GET.copy()
|
||||||
mod.pop('tag')
|
mod.pop('tag')
|
||||||
request.GET = mod
|
request.GET = mod
|
||||||
|
|
||||||
context = {
|
return {
|
||||||
'bookmarks': bookmarks,
|
'bookmarks': bookmarks,
|
||||||
'tags': tags,
|
'tags': tags,
|
||||||
'tags_string': tags_string,
|
'tags_string': tags_string,
|
||||||
@@ -39,16 +55,14 @@ def index(request):
|
|||||||
'empty': paginator.count == 0,
|
'empty': paginator.count == 0,
|
||||||
'return_url': return_url
|
'return_url': return_url
|
||||||
}
|
}
|
||||||
return render(request, 'bookmarks/index.html', context)
|
|
||||||
|
|
||||||
|
|
||||||
def generate_index_return_url(page, query_string):
|
def generate_return_url(base_url, page, query_string):
|
||||||
url_query = {}
|
url_query = {}
|
||||||
if query_string is not None:
|
if query_string is not None:
|
||||||
url_query['q'] = query_string
|
url_query['q'] = query_string
|
||||||
if page is not None:
|
if page is not None:
|
||||||
url_query['page'] = page
|
url_query['page'] = page
|
||||||
base_url = reverse('bookmarks:index')
|
|
||||||
url_params = urllib.parse.urlencode(url_query)
|
url_params = urllib.parse.urlencode(url_query)
|
||||||
return_url = base_url if url_params == '' else base_url + '?' + url_params
|
return_url = base_url if url_params == '' else base_url + '?' + url_params
|
||||||
return urllib.parse.quote_plus(return_url)
|
return urllib.parse.quote_plus(return_url)
|
||||||
@@ -140,7 +154,7 @@ def unarchive(request, bookmark_id: int):
|
|||||||
bookmark = Bookmark.objects.get(pk=bookmark_id)
|
bookmark = Bookmark.objects.get(pk=bookmark_id)
|
||||||
unarchive_bookmark(bookmark)
|
unarchive_bookmark(bookmark)
|
||||||
return_url = request.GET.get('return_url')
|
return_url = request.GET.get('return_url')
|
||||||
return_url = return_url if return_url else reverse('bookmarks:index')
|
return_url = return_url if return_url else reverse('bookmarks:archived')
|
||||||
return HttpResponseRedirect(return_url)
|
return HttpResponseRedirect(return_url)
|
||||||
|
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user