diff options
| author | marty hiatt <martianhiatus@disroot.org> | 2024-11-02 11:25:35 +0100 | 
|---|---|---|
| committer | marty hiatt <martianhiatus@disroot.org> | 2024-11-02 15:25:42 +0100 | 
| commit | 7af46336f2dd2ed17b3aba7b0c58b029b49767cc (patch) | |
| tree | 3f2f1b8cc6956dafbb09615e8c8f65342b88ee67 | |
| parent | ee25cb9b026a40c320570c09635a476509d81d67 (diff) | |
add read less button to unfolded long posts (read more). FIX #614
| -rw-r--r-- | lisp/mastodon-tl.el | 30 | 
1 files changed, 22 insertions, 8 deletions
| diff --git a/lisp/mastodon-tl.el b/lisp/mastodon-tl.el index 3e1d49f..87fd710 100644 --- a/lisp/mastodon-tl.el +++ b/lisp/mastodon-tl.el @@ -1143,7 +1143,8 @@ the toot)."  LINK-TYPE is the type of link to produce."    (let ((help-text (cond ((eq link-type 'content-warning)                            "Toggle hidden text") -                         ((eq link-type 'read-more) +                         ((or (eq link-type 'read-more) +                              (eq link-type 'read-less))                            "Toggle full post")                           (t                            (error "Unknown link type %s" link-type))))) @@ -1187,6 +1188,8 @@ Used for hitting RET on a given link."                          (error "Unable to find account"))))))))            ((eq link-type 'read-more)             (mastodon-tl--unfold-post)) +          ((eq link-type 'read-less) +           (mastodon-tl--fold-post))            (t             (error "Unknown link type %s" link-type))))) @@ -1653,7 +1656,8 @@ Runs `mastodon-tl--render-text' and fetches poll or media."      (string= reply-to-id prev-id)))  (defun mastodon-tl--insert-status -    (toot body &optional detailed-p thread domain unfolded no-byline) +    (toot body &optional detailed-p thread domain unfolded no-byline +          cw-expanded)    "Display the content and byline of timeline element TOOT.  BODY will form the section of the toot above the byline.  DETAILED-P means display more detailed info. For now @@ -1669,7 +1673,10 @@ NO-BYLINE means just insert toot body, used for folding."           ;; (type (alist-get 'type toot))           (toot-foldable            (and mastodon-tl--fold-toots-at-length -               (length> body mastodon-tl--fold-toots-at-length)))) +               (length> body mastodon-tl--fold-toots-at-length))) +         (cw-p (not +                (string-empty-p +                 (alist-get 'spoiler_text toot)))))      (insert       (propertize ;; body + byline:        (concat @@ -1690,7 +1697,14 @@ NO-BYLINE means just insert toot body, used for folding."                 (propertize body                             'line-prefix bar                             'wrap-prefix bar) -             body))) +             body)) +         (if (and toot-foldable unfolded cw-expanded) +             (propertize (mastodon-search--format-heading +                          (mastodon-tl--make-link "READ LESS" 'read-less) +                          nil :no-newline) +                         'mastodon-content-warning-body cw-p +                         'invisible (not cw-expanded)) +           ""))          'toot-body t) ;; includes newlines etc. for folding         ;; byline:         "\n" @@ -1751,7 +1765,7 @@ title, and context."      (mastodon-tl--filter-by-context context filters-no-context)))  (defun mastodon-tl--toot (toot &optional detailed-p thread domain -                               unfolded no-byline no-cw) +                               unfolded no-byline cw-expanded)    "Format TOOT and insert it into the buffer.  DETAILED-P means display more detailed info. For now  this just means displaying toot client. @@ -1761,7 +1775,7 @@ UNFOLDED is a boolean meaning whether to unfold or fold item if foldable.  NO-BYLINE means just insert toot body, used for folding.  NO-CW means treat content warnings as unfolded."    (let* ((mastodon-tl--expand-content-warnings -          (or no-cw mastodon-tl--expand-content-warnings)) +          (or cw-expanded mastodon-tl--expand-content-warnings))           (filtered (mastodon-tl--field 'filtered toot))           (filters (when filtered                      (mastodon-tl--current-filters filtered))) @@ -1775,7 +1789,7 @@ NO-CW means treat content warnings as unfolded."      (unless (and filtered (assoc "hide" filters)) ;; no insert        (mastodon-tl--insert-status         toot (mastodon-tl--clean-tabs-and-nl spoiler-or-content) -       detailed-p thread domain unfolded no-byline)))) +       detailed-p thread domain unfolded no-byline cw-expanded))))  (defun mastodon-tl--timeline (toots &optional thread domain no-byline)    "Display each toot in TOOTS. @@ -1853,7 +1867,7 @@ FOLD means to fold it instead."          (delete-char 1) ;; prevent newlines accumulating          ;; insert toot body:          (mastodon-tl--toot toot nil nil nil (not fold) :no-byline -                           (unless cw-invis :no-cw)) ;; respect CW state +                           (unless cw-invis :cw-expanded)) ;; respect CW state          ;; set toot-folded prop on entire toot (not just body):          (let ((toot-range ;; post fold action range:                 (mastodon-tl--find-property-range 'item-json | 
