Parcourir la source

enhance: hide logbook by default

Tienson Qin il y a 4 ans
Parent
commit
dd9a90b4ad

+ 1 - 1
package.json

@@ -75,7 +75,7 @@
         "ignore": "^5.1.8",
         "is-svg": "4.2.2",
         "jszip": "^3.5.0",
-        "mldoc": "1.0.4",
+        "mldoc": "1.0.5",
         "path": "^0.12.7",
         "pixi-graph-fork": "^0.1.6",
         "posthog-js": "^1.10.2",

+ 1 - 0
resources/css/common.css

@@ -1015,6 +1015,7 @@ hr {
 .fade-link {
   opacity: 0.6;
   transition: 0.3s;
+  color: var(--ls-primary-text-color);
 }
 
 a.fade-link:hover {

+ 174 - 161
src/main/frontend/components/block.cljs

@@ -1852,9 +1852,20 @@
             (when (and summary
                        (not= summary "0m")
                        (not (string/blank? summary)))
-              [:div.text-sm.time-spent.ml-1 {:style {:padding-top 3}}
-               [:a.opacity-30.hover:opacity-100
-                summary]])))
+              (ui/tippy {:html        (fn []
+                                        (when-let [logbook (drawer/get-logbook body)]
+                                          (let [clocks (->> (last logbook)
+                                                            (remove string/blank?))]
+                                            [:div.p-4
+                                             [:div.font-bold.mb-2 "LOGBOOK:"]
+                                             [:ul
+                                              (for [clock clocks]
+                                                [:li clock])]])))
+                         :interactive true
+                         :delay       [1000, 100]}
+               [:div.text-sm.time-spent.ml-1 {:style {:padding-top 3}}
+                [:a.fade-link
+                 summary]]))))
 
         (let [block-refs-count (count (:block/_refs (db/entity (:db/id block))))]
           (when (and block-refs-count (> block-refs-count 0))
@@ -2345,7 +2356,7 @@
                                                                     (not table?)))
                               true)]])
 
-               [:a.mx-2.opacity-60.hover:opacity-100.block
+               [:a.mx-2.block.fade-link
                 {:on-click (fn []
                              (let [all-keys (query-table/get-keys result page-list?)]
                                (state/pub-event! [:modal/set-query-properties current-block all-keys])))}
@@ -2455,164 +2466,166 @@
                    :markdown)]
     (try
       (match item
-             ["Drawer" name lines]
-             [:div.flex.flex-col
-              [:div.text-sm.mt-1.flex.flex-row
-               [:div.drawer {:data-drawer-name name}
-                (ui/foldable
-                 [:div.opacity-50.font-medium
-                  (util/format ":%s:" (string/upper-case name))]
-                 [:div (apply str lines)
-                  [:div.opacity-50.font-medium {:style {:width 95}}
-                   ":END:"]]
-                 {:default-collapsed? true
-                  :title-trigger? true})]]]
-
-             ["Properties" m]
-             [:div.properties
-              (for [[k v] (dissoc m :roam_alias :roam_tags)]
-                (when (and (not (and (= k :macros) (empty? v))) ; empty macros
-                           (not (= k :title))
-                           (not (= k :filters)))
-                  [:div.property
-                   [:span.font-medium.mr-1 (str (name k) ": ")]
-                   (if (coll? v)
-                     (let [vals (for [item v]
-                                  (if (coll? v)
-                                    (let [config (if (= k :alias)
-                                                   (assoc config :block/alias? true))]
-                                      (page-cp config {:block/name item}))
-                                    (inline-text format item)))]
-                       (interpose [:span ", "] vals))
-                     (inline-text format v))]))]
-
-             ["Paragraph" l]
-             ;; TODO: speedup
-             (if (util/safe-re-find #"\"Export_Snippet\" \"embed\"" (str l))
-               (->elem :div (map-inline config l))
-               (->elem :div.is-paragraph (map-inline config l)))
-
-             ["Horizontal_Rule"]
-             (when-not (:slide? config)
-               [:hr])
-             ["Heading" h]
-             (block-container config h)
-             ["List" l]
-             (let [lists (divide-lists l)]
-               (if (= 1 (count lists))
-                 (let [l (first lists)]
-                   (->elem
-                    (list-element l)
-                    (map #(list-item config %) l)))
-                 [:div.list-group
-                  (for [l lists]
-                    (->elem
-                     (list-element l)
-                     (map #(list-item config %) l)))]))
-             ["Table" t]
-             (table config t)
-             ["Math" s]
-             (if html-export?
-               (latex/html-export s true true)
-               (latex/latex (str (dc/squuid)) s true true))
-             ["Example" l]
-             [:pre.pre-wrap-white-space
-              (join-lines l)]
-             ["Quote" l]
-             (->elem
-              :blockquote
-              (markup-elements-cp config l))
-             ["Raw_Html" content]
-             (when (not html-export?)
-               [:div.raw_html {:dangerouslySetInnerHTML
-                               {:__html content}}])
-             ["Export" "html" options content]
-             (when (not html-export?)
-               [:div.export_html {:dangerouslySetInnerHTML
-                                  {:__html content}}])
-             ["Hiccup" content]
-             (ui/catch-error
-              [:div.warning {:title "Invalid hiccup"}
-               content]
-              (-> (safe-read-string content)
-                  (security/remove-javascript-links-in-href)))
-
-             ["Export" "latex" options content]
-             (if html-export?
-               (latex/html-export content true false)
-               (latex/latex (str (dc/squuid)) content true false))
-
-             ["Custom" "query" _options result content]
-             (try
-               (let [query (reader/read-string content)]
-                 (custom-query config query))
-               (catch js/Error e
-                 (println "read-string error:")
-                 (js/console.error e)
-                 [:div.warning {:title "Invalid query"}
-                  content]))
-
-             ["Custom" "note" options result content]
-             (admonition config "note" options result)
-
-             ["Custom" "tip" options result content]
-             (admonition config "tip" options result)
-
-             ["Custom" "important" options result content]
-             (admonition config "important" options result)
-
-             ["Custom" "caution" options result content]
-             (admonition config "caution" options result)
-
-             ["Custom" "warning" options result content]
-             (admonition config "warning" options result)
-
-             ["Custom" "pinned" options result content]
-             (admonition config "pinned" options result)
-
-             ["Custom" "center" options l content]
-             (->elem
-              :div.text-center
-              (markup-elements-cp config l))
+        ["Drawer" name lines]
 
-             ["Custom" name options l content]
-             (->elem
-              :div
-              {:class name}
-              (markup-elements-cp config l))
-
-             ["Latex_Fragment" l]
-             [:p.latex-fragment
-              (inline config ["Latex_Fragment" l])]
-
-             ["Latex_Environment" name option content]
-             (let [content (latex-environment-content name option content)]
-               (if html-export?
-                 (latex/html-export content true true)
-                 (latex/latex (str (dc/squuid)) content true true)))
-
-             ["Displayed_Math" content]
-             (if html-export?
-               (latex/html-export content true true)
-               (latex/latex (str (dc/squuid)) content true true))
-
-             ["Footnote_Definition" name definition]
-             (let [id (util/url-encode name)]
-               [:div.footdef
-                [:div.footpara
-                 (conj
-                  (markup-element-cp config ["Paragraph" definition])
-                  [:a.ml-1 {:id (str "fn." id)
-                            :style {:font-size 14}
-                            :class "footnum"
-                            :on-click #(route-handler/jump-to-anchor! (str "fnr." id))}
-                   [:sup.fn (str name "↩︎")]])]])
-
-             ["Src" options]
-             (src-cp config options html-export?)
-
-             :else
-             "")
+        (when (not= name "logbook")
+          [:div.flex.flex-col
+           [:div.text-sm.mt-1.flex.flex-row
+            [:div.drawer {:data-drawer-name name}
+             (ui/foldable
+              [:div.opacity-50.font-medium
+               (util/format ":%s:" (string/upper-case name))]
+              [:div (apply str lines)
+               [:div.opacity-50.font-medium {:style {:width 95}}
+                ":END:"]]
+              {:default-collapsed? true
+               :title-trigger? true})]]])
+
+        ["Properties" m]
+        [:div.properties
+         (for [[k v] (dissoc m :roam_alias :roam_tags)]
+           (when (and (not (and (= k :macros) (empty? v))) ; empty macros
+                      (not (= k :title))
+                      (not (= k :filters)))
+             [:div.property
+              [:span.font-medium.mr-1 (str (name k) ": ")]
+              (if (coll? v)
+                (let [vals (for [item v]
+                             (if (coll? v)
+                               (let [config (if (= k :alias)
+                                              (assoc config :block/alias? true))]
+                                 (page-cp config {:block/name item}))
+                               (inline-text format item)))]
+                  (interpose [:span ", "] vals))
+                (inline-text format v))]))]
+
+        ["Paragraph" l]
+        ;; TODO: speedup
+        (if (util/safe-re-find #"\"Export_Snippet\" \"embed\"" (str l))
+          (->elem :div (map-inline config l))
+          (->elem :div.is-paragraph (map-inline config l)))
+
+        ["Horizontal_Rule"]
+        (when-not (:slide? config)
+          [:hr])
+        ["Heading" h]
+        (block-container config h)
+        ["List" l]
+        (let [lists (divide-lists l)]
+          (if (= 1 (count lists))
+            (let [l (first lists)]
+              (->elem
+               (list-element l)
+               (map #(list-item config %) l)))
+            [:div.list-group
+             (for [l lists]
+               (->elem
+                (list-element l)
+                (map #(list-item config %) l)))]))
+        ["Table" t]
+        (table config t)
+        ["Math" s]
+        (if html-export?
+          (latex/html-export s true true)
+          (latex/latex (str (dc/squuid)) s true true))
+        ["Example" l]
+        [:pre.pre-wrap-white-space
+         (join-lines l)]
+        ["Quote" l]
+        (->elem
+         :blockquote
+         (markup-elements-cp config l))
+        ["Raw_Html" content]
+        (when (not html-export?)
+          [:div.raw_html {:dangerouslySetInnerHTML
+                          {:__html content}}])
+        ["Export" "html" options content]
+        (when (not html-export?)
+          [:div.export_html {:dangerouslySetInnerHTML
+                             {:__html content}}])
+        ["Hiccup" content]
+        (ui/catch-error
+         [:div.warning {:title "Invalid hiccup"}
+          content]
+         (-> (safe-read-string content)
+             (security/remove-javascript-links-in-href)))
+
+        ["Export" "latex" options content]
+        (if html-export?
+          (latex/html-export content true false)
+          (latex/latex (str (dc/squuid)) content true false))
+
+        ["Custom" "query" _options result content]
+        (try
+          (let [query (reader/read-string content)]
+            (custom-query config query))
+          (catch js/Error e
+            (println "read-string error:")
+            (js/console.error e)
+            [:div.warning {:title "Invalid query"}
+             content]))
+
+        ["Custom" "note" options result content]
+        (admonition config "note" options result)
+
+        ["Custom" "tip" options result content]
+        (admonition config "tip" options result)
+
+        ["Custom" "important" options result content]
+        (admonition config "important" options result)
+
+        ["Custom" "caution" options result content]
+        (admonition config "caution" options result)
+
+        ["Custom" "warning" options result content]
+        (admonition config "warning" options result)
+
+        ["Custom" "pinned" options result content]
+        (admonition config "pinned" options result)
+
+        ["Custom" "center" options l content]
+        (->elem
+         :div.text-center
+         (markup-elements-cp config l))
+
+        ["Custom" name options l content]
+        (->elem
+         :div
+         {:class name}
+         (markup-elements-cp config l))
+
+        ["Latex_Fragment" l]
+        [:p.latex-fragment
+         (inline config ["Latex_Fragment" l])]
+
+        ["Latex_Environment" name option content]
+        (let [content (latex-environment-content name option content)]
+          (if html-export?
+            (latex/html-export content true true)
+            (latex/latex (str (dc/squuid)) content true true)))
+
+        ["Displayed_Math" content]
+        (if html-export?
+          (latex/html-export content true true)
+          (latex/latex (str (dc/squuid)) content true true))
+
+        ["Footnote_Definition" name definition]
+        (let [id (util/url-encode name)]
+          [:div.footdef
+           [:div.footpara
+            (conj
+             (markup-element-cp config ["Paragraph" definition])
+             [:a.ml-1 {:id (str "fn." id)
+                       :style {:font-size 14}
+                       :class "footnum"
+                       :on-click #(route-handler/jump-to-anchor! (str "fnr." id))}
+              [:sup.fn (str name "↩︎")]])]])
+
+        ["Src" options]
+        (src-cp config options html-export?)
+
+        :else
+        "")
       (catch js/Error e
         (println "Convert to html failed, error: " e)
         ""))))

+ 9 - 0
src/main/frontend/components/block.css

@@ -515,3 +515,12 @@ span.cloze-revealed {
 .page-property-key {
   color: var(--ls-secondary-text-color);
 }
+
+.block-parents a {
+  color: var(--ls-primary-text-color);
+  opacity: 0.8;
+}
+
+.block-parents a:hover {
+  opacity: 1;
+}

+ 21 - 16
src/main/frontend/util/clock.cljs

@@ -31,22 +31,27 @@
 
 (defn clock-out
   [format content]
-  (if-let [clock-in-log (last (last (drawer/get-drawer-ast format content "logbook")))]
-    (when (string/starts-with? clock-in-log "CLOCK:")
-      (let [clock-start (subs clock-in-log 8 (- (count clock-in-log) 1))
-            clock-end (date/get-date-time-string-3)
-            clock-span (minutes->hours:minutes
-                        (t/in-minutes
-                         (t/interval
-                          (tf/parse date/custom-formatter-3 clock-start)
-                          (tf/parse date/custom-formatter-3 clock-end))))
-            clock-out-log (util/format "CLOCK: [%s]--[%s] =>  %s"
-                                       clock-start clock-end clock-span)]
-        (string/replace
-         content
-         (str clock-in-log "\n")
-         (str clock-out-log "\n"))))
-    content))
+  (try
+    (or
+     (when-let [clock-in-log (last (last (drawer/get-drawer-ast format content "logbook")))]
+       (let [clock-in-log (string/trim clock-in-log)]
+         (when (string/starts-with? clock-in-log "CLOCK:")
+           (let [clock-start (subs clock-in-log 8 (- (count clock-in-log) 1))
+                 clock-end (date/get-date-time-string-3)
+                 clock-span (minutes->hours:minutes
+                             (t/in-minutes
+                              (t/interval
+                               (tf/parse date/custom-formatter-3 clock-start)
+                               (tf/parse date/custom-formatter-3 clock-end))))
+                 clock-out-log (util/format "CLOCK: [%s]--[%s] =>  %s"
+                                            clock-start clock-end clock-span)]
+             (string/replace
+              content
+              (str clock-in-log "\n")
+              (str clock-out-log "\n"))))))
+     content)
+    (catch js/Error e
+      content)))
 
 (defn clock-summary
   [body string?]

+ 1 - 1
src/main/frontend/util/drawer.cljs

@@ -117,7 +117,7 @@
   (let [body (:block/body block)
         logbook (get-logbook body)]
     (if logbook
-      (let [clocks (last logbook)
+      (let [clocks (map string/trim (last logbook))
             logbook (->> (concat [":LOGBOOK:"] clocks [":END:"])
                          (remove string/blank?)
                          (string/join "\n"))

+ 4 - 4
yarn.lock

@@ -6173,10 +6173,10 @@ mkdirp@^0.5.0, mkdirp@^0.5.4, mkdirp@~0.5.1:
   dependencies:
     minimist "^1.2.5"
 
[email protected].3:
-  version "1.0.3"
-  resolved "https://registry.yarnpkg.com/mldoc/-/mldoc-1.0.3.tgz#070fbe1757c9913dda5fda633b6cf756ad58b8be"
-  integrity sha512-CAzsCN9kxQGWgNO3oE7zHTzf/T1G9nS7+DeBpKlOE1TKDKG1fhfYLnwKePfKP6YQK95vFOyf/5CdK8ml8P1cxg==
[email protected].5:
+  version "1.0.5"
+  resolved "https://registry.yarnpkg.com/mldoc/-/mldoc-1.0.5.tgz#2f36ee21ae50c0ac73ca7eeb6e1f38ec34f422d3"
+  integrity sha512-OUkySx+GokdIRFkMFtwUUX0+THB5WYeK54xaZ1bTv8rDbN4v30WnOCjJxBcPCaWioff+CWoxQnChiJaodpIn8g==
   dependencies:
     yargs "^12.0.2"