59 lines
2.5 KiB
HTML
59 lines
2.5 KiB
HTML
<div class="grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-6">
|
|
{% for folder in folders %}
|
|
<div class="card bg-base-100 shadow-xl border border-base-300">
|
|
<div class="card-body">
|
|
<div class="flex justify-between items-start mb-2">
|
|
<h3 class="text-xl font-bold">{{ folder.name }}</h3>
|
|
<div class="flex space-x-2">
|
|
<button class="btn btn-sm btn-outline"
|
|
hx-get="/api/folders/{{ folder.id }}/edit"
|
|
hx-target="#modal-holder"
|
|
hx-swap="innerHTML"
|
|
hx-trigger="click">
|
|
<i class="fas fa-edit"></i>
|
|
</button>
|
|
<button class="btn btn-sm btn-outline btn-error"
|
|
hx-delete="/api/folders/{{ folder.id }}"
|
|
hx-target="#folders-list"
|
|
hx-swap="innerHTML"
|
|
hx-confirm="Are you sure you want to delete this folder?">
|
|
<i class="fas fa-trash"></i>
|
|
</button>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="bg-base-200 rounded-box p-4 mb-4">
|
|
<p class="text-base-content/80">{{ folder.rule_text }}</p>
|
|
</div>
|
|
|
|
<div class="flex justify-between items-center mt-2">
|
|
{% if folder.priority == 1 %}
|
|
<span class="badge badge-error">High Priority</span>
|
|
{% elif folder.priority == -1 %}
|
|
<span class="badge badge-info">Low Priority</span>
|
|
{% else %}
|
|
<span class="badge badge-primary">Normal Priority</span>
|
|
{% endif %}
|
|
<span class="text-xs badge badge-secondary">0 emails</span>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
{% else %}
|
|
<div class="col-span-full text-center py-12 bg-base-100 rounded-box shadow-lg">
|
|
<div class="text-5xl mb-4 text-primary">
|
|
<i class="fas fa-folder-open"></i>
|
|
</div>
|
|
<h3 class="text-2xl font-bold mb-2">No folders yet</h3>
|
|
<p class="mb-6 text-base-content/70">Add your first folder to get started organizing your emails.</p>
|
|
<button class="btn btn-primary btn-lg"
|
|
hx-get="/api/folders/new"
|
|
hx-target="#modal-holder"
|
|
hx-swap="innerHTML"
|
|
hx-trigger="click">
|
|
<i class="fas fa-plus mr-2"></i>
|
|
Create Folder
|
|
</button>
|
|
</div>
|
|
{% endfor %}
|
|
</div>
|