import NoteContextAwareWidget from "../note_context_aware_widget.js"; import dialogService from "../dialog.js"; import server from "../../services/server.js"; import toastService from "../../services/toast.js"; const TPL = `
`; export default class RelationMapButtons extends NoteContextAwareWidget { doRender() { super.doRender(); this.$widget = $(TPL); this.$createChildNote = this.$widget.find(".relation-map-create-child-note"); this.$zoomInButton = this.$widget.find(".relation-map-zoom-in"); this.$zoomOutButton = this.$widget.find(".relation-map-zoom-out"); this.$resetPanZoomButton = this.$widget.find(".relation-map-reset-pan-zoom"); this.$createChildNote.on('click', async () => { const title = await dialogService.prompt({ message: "Enter title of new note", defaultValue: "new note" }); if (!title.trim()) { return; } const {note} = await server.post(`notes/${this.noteId}/children?target=into`, { title, content: '', type: 'text' }); toastService.showMessage("Click on canvas to place new note"); this.clipboard = { noteId: note.noteId, title }; }); this.$resetPanZoomButton.on('click', () => { // reset to initial pan & zoom state this.pzInstance.zoomTo(0, 0, 1 / this.getZoom()); this.pzInstance.moveTo(0, 0); }); this.$zoomInButton.on('click', () => this.pzInstance.zoomTo(0, 0, 1.2)); this.$zoomOutButton.on('click', () => this.pzInstance.zoomTo(0, 0, 0.8)); } }