summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorThanos Apollo <public@thanosapollo.org>2023-12-27 08:31:07 +0200
committerThanos Apollo <public@thanosapollo.org>2023-12-27 08:32:12 +0200
commit87399b02b5ec3b482f9650afcf3a5f864d8b9a58 (patch)
tree0ba41d7c110c5071107a1df2f25d453f77b68873
parent5a25c324919fc46bfd7353f53430eab0e2949552 (diff)
Add with-gnosis-buffer macro & updat display funcs
-rw-r--r--gnosis.el45
1 files changed, 21 insertions, 24 deletions
diff --git a/gnosis.el b/gnosis.el
index 4878680..6a65b3c 100644
--- a/gnosis.el
+++ b/gnosis.el
@@ -89,41 +89,38 @@ Example:
"From TABLE use where to delete VALUE."
(emacsql gnosis-db `[:delete :from ,table :where ,value]))
+(defmacro with-gnosis-buffer (&rest body)
+ "Execute BODY in gnosis buffer."
+ `(with-current-buffer (switch-to-buffer (get-buffer-create "*gnosis*"))
+ ,@body))
+
(defun gnosis-display--question (id)
"Display main row for note ID."
(let ((question (gnosis-get 'main 'notes `(= id ,id))))
- (with-current-buffer
- (switch-to-buffer
- (get-buffer-create "*gnosis*"))
+ (with-gnosis-buffer
(erase-buffer)
(fill-paragraph (insert (propertize question 'face 'gnosis-face-main))))))
-(defun gnosis-display--correct-answer-mcq (id user-choice)
- "Display correct answer & USER-CHOICE for MCQ note type with ID."
- (let* ((correct-answer (gnosis-get 'answer 'notes `(= id ,id)))
- (options (gnosis-get 'options 'notes `(= id ,id)))
- (answer (nth correct-answer options)))
- (with-current-buffer
- (switch-to-buffer
- (get-buffer-create "*gnosis*"))
- (insert (concat "\n\nCorrect answer: "
- (propertize answer 'face 'gnosis-face-correct-answer)
- "\nYour answer: "
- (propertize user-choice 'face 'gnosis-face-user-choice))))))
+(defun gnosis-display--cloze-sentence (sentence clozes)
+ "Display cloze sentence for SENTENCE with CLOZES."
+ (with-gnosis-buffer
+ (erase-buffer)
+ (fill-paragraph (insert
+ (gnosis-cloze-replace-words sentence clozes gnosis-cloze-char)))))
+
(defun gnosis-display--correct-answer-mcq (answer user-choice)
"Display correct ANSWER & USER-CHOICE for MCQ note."
- (with-current-buffer
- (switch-to-buffer
- (get-buffer-create "*gnosis*"))
- (insert (concat "\n\nCorrect answer: "
- (propertize answer 'face 'gnosis-face-correct-answer)
- "\nYour answer: "
- (propertize user-choice 'face 'gnosis-face-user-choice)))))
+ (with-gnosis-buffer
+ (insert (concat "\n\nCorrect answer: "
+ (propertize answer 'face 'gnosis-face-correct-answer)
+ "\nYour answer: "
+ (propertize user-choice 'face 'gnosis-face-user-choice)))))
(defun gnosis-display--extra (id)
"Display extra information for note ID."
(let ((extras (gnosis-get 'extra-notes 'extras `(= id ,id))))
- (with-current-buffer (switch-to-buffer (get-buffer-create "*gnosis*"))
+ (with-gnosis-buffer
+ (goto-char (point-max))
(insert (propertize "\n\n-----\n" 'face 'gnosis-face-seperator))
(fill-paragraph (insert (concat "\n" (propertize extras 'face 'gnosis-face-extra)))))))
@@ -133,7 +130,7 @@ Example:
(path-to-image (concat gnosis-images-dir "/" img))
(image (create-image path-to-image 'png nil :width 500 :height 300)))
(when img
- (with-current-buffer (switch-to-buffer (get-buffer-create "*gnosis*"))
+ (with-gnosis-buffer
(insert "\n\n")
(insert-image image)))))