diff options
| -rw-r--r-- | rt-liberation-viewer.el | 47 | 
1 files changed, 46 insertions, 1 deletions
| diff --git a/rt-liberation-viewer.el b/rt-liberation-viewer.el index c5a75c2..e07186d 100644 --- a/rt-liberation-viewer.el +++ b/rt-liberation-viewer.el @@ -171,6 +171,51 @@ ASSOC-BROWSER if non-nil should be a ticket browser."  	     section-point-list))        section-list))) +(defun rt-liber-viewer2-format-content (content) +  (with-temp-buffer +    (insert content) + +    ;; Convert the 9 leading whitespaces from RT's comment lines. +    (goto-char (point-min)) +    (insert "    ") +    (while (re-search-forward "^         " (point-max) t) +      (replace-match "    ")) + +    (fill-region (point-min) +		 (point-max)) + +    (buffer-substring (point-min) +		      (point-max)))) + +(defun rt-liber-viewer2-display-section (section) +  (let ((ticket-id (alist-get 'Ticket section)) +	(creator   (alist-get 'Creator section)) +	(date      (alist-get 'Created section)) +	(type	   (alist-get 'Type section)) +	(content   (alist-get 'Content section))) +    (insert +     (format "Ticket %s by %s on %s (-N- days ago) (%s)\n" +	     ticket-id +	     creator +	     date +	     type)) +    (cond ((or (string= type "Status") +	       (string= type "CustomField") +	       ;; (string= type "EmailRecord") +	       (string= type "Set")) +	   'nop-for-now) +	  (t (insert +	      (format "\n%s\n" +		      (rt-liber-viewer2-format-content content))))))) + +(defun rt-liber-viewer2-display-history (contents) +  (let ((section-list (rt-liber-viewer-parse-history contents))) +    (mapc +     (lambda (section) +       (rt-liber-viewer2-display-section section)) +     section-list))) + +;; Before release: move this back to the top  (defconst rt-liber-viewer2-font-lock-keywords    (let ((header-regexp (regexp-opt '("id: ")  				   t))) @@ -191,7 +236,7 @@ ASSOC-BROWSER if non-nil should be a ticket browser."      (with-current-buffer new-ticket-buffer        (let ((inhibit-read-only t))  	(erase-buffer) -	(insert "watch this space for further development") +	(rt-liber-viewer2-display-history contents)  	(goto-char (point-min))  	(rt-liber-viewer2-mode)  	(set | 
