Files
gobsidian/web/templates/note.html
2025-08-26 20:55:08 +01:00

105 lines
3.6 KiB
HTML

{{define "note"}}
{{template "base" .}}
{{end}}
{{define "note_content"}}
<div class="max-w-4xl mx-auto p-6">
<!-- Note Header -->
<div class="mb-6">
<div class="flex items-center justify-between mb-4">
<h1 class="text-3xl font-bold text-white">{{.title}}</h1>
<div class="flex items-center space-x-3">
{{if .Authenticated}}
<a href="{{url (print "/editor/edit/" .note_path)}}" class="btn-primary">
<i class="fas fa-edit mr-2"></i>Edit
</a>
{{end}}
<a href="{{url (print "/download/" .note_path)}}" class="btn-secondary">
<i class="fas fa-download mr-2"></i>Download
</a>
{{if .Authenticated}}
<button class="btn-danger delete-note-btn" data-path="{{.note_path}}">
<i class="fas fa-trash mr-2"></i>Delete
</button>
{{end}}
</div>
</div>
{{if .folder_path}}
<p class="text-gray-400">
<i class="fas fa-folder mr-2"></i>
<a href="{{url (print "/folder/" .folder_path)}}" class="text-blue-400 hover:text-blue-300">{{.folder_path}}</a>
</p>
{{end}}
</div>
<!-- Note Content | safeHTML -->
<div class="bg-gray-800 rounded-lg p-6">
<div class="prose prose-dark max-w-none">
{{.content | safeHTML}}
</div>
</div>
</div>
<!-- Delete Confirmation Modal -->
<div id="delete-modal" class="modal-overlay hidden">
<div class="modal-content">
<h3 class="text-lg font-medium text-white mb-4">Confirm Delete</h3>
<p class="text-gray-300 mb-6">Are you sure you want to delete this note? This action cannot be undone.</p>
<div class="flex justify-end space-x-3">
<button id="cancel-delete" class="btn-secondary">Cancel</button>
<button id="confirm-delete" class="btn-danger">Delete</button>
</div>
</div>
</div>
{{end}}
{{define "note_scripts"}}
<script>
document.addEventListener('DOMContentLoaded', function() {
const deleteBtn = document.querySelector('.delete-note-btn');
const modal = document.getElementById('delete-modal');
const cancelBtn = document.getElementById('cancel-delete');
const confirmBtn = document.getElementById('confirm-delete');
if (deleteBtn) {
deleteBtn.addEventListener('click', function() {
modal.classList.remove('hidden');
});
}
if (cancelBtn) {
cancelBtn.addEventListener('click', function() {
modal.classList.add('hidden');
});
}
if (confirmBtn) {
confirmBtn.addEventListener('click', function() {
const path = deleteBtn.dataset.path;
const m = document.cookie.match(/(?:^|; )csrf_token=([^;]+)/);
const csrf = m && m[1] ? decodeURIComponent(m[1]) : '';
fetch(window.prefix(`/editor/delete/${path}`), {
method: 'DELETE',
headers: csrf ? { 'X-CSRF-Token': csrf } : {}
})
.then(response => {
if (response.ok) {
window.location.href = window.prefix('/');
} else {
alert('Error deleting note');
}
})
.catch(error => {
console.error('Error:', error);
alert('Error deleting note');
});
});
}
// Re-highlight code blocks that might have been added dynamically
hljs.highlightAll();
});
</script>
{{end}}