Q : org
아젠다 뷰 에서 디바이더 라인을 배치 할 수 있습니까?
내가해야 할 일이 많을 때 내 의제 버퍼가 약간 바쁠 수 있습니다. 이 혼잡함은 나를 놀라게하기 때문에 내 의제를 보지 못하게하는 비생산적인 효과가 있습니다. 시각적으로 덜 까다로울 수있는 방법을 찾고 있습니다.
내가 원하는 것은 다음과 같은 의제 항목 사이에 구분선 (예 : 대시 선)을 넣을 수 있다는 것입니다.
- 오늘 마감일이 있습니다
- 마감일이 지났습니다 (X 일이 지남).
- 예정된 마감일이 있습니다 (X 일로 인해).
의제보기에서 분배기 라인을 배치 할 수 있습니까? 그렇다면 어떻게해야합니까?
답변
org-agenda-block-separator
의제에서 블록 사이의 구분 기호입니다. 이것이 문자열이면 줄 바꿈이 추가 된 구분 기호로 사용됩니다. 문자 인 경우 창 너비를 채우기 위해 반복됩니다. nil이면 구분 기호가 비활성화됩니다. 여기서
org-agenda-custom-commands
현재 블록과 이전 블록 사이의 구분 기호를 다룹니다.
org-agenda-compact-blocks
non-nil은 블록 아젠다를보다 간결하게 만듭니다. 이는 일정 범위 이름 및 주 번호 또는 구분선과 같은 줄을 생략하여 전체적으로 수행됩니다.
답변
아젠다보기에서 여러 개의 사용자 정의 명령을 연결하여 자체 검색이 가능한 여러 블록을 가질 수 있습니다.
(setq org-agenda-custom-commands
'(("D" "Deadlines"
((tags-todo "DEADLINE=\"<today>\""
((org-agenda-overriding-header "Due Today"))
)
(tags-todo "DEADLINE<\"<today>\""
((org-agenda-overriding-header "You're Late")))
(tags-todo "+DEADLINE<\"<+5d>\"+DEADLINE>\"<today>\""
((org-agenda-overriding-header "Better get on it")))
))))
끝에 모든 블록에 적용 할 옵션 목록을 배치 할 수도 있습니다.
이 단점은 각 블록이 개별적으로 계산되므로 단일 안건으로 생성하는 데 3 배가 걸린다는 것입니다
답변
다음은에 의해 생성되는 항목의 텍스트 속성을 검사하고 org-agenda-list
특정 기준에 따라 문자열을 수정하는 방법의 예입니다 . 이 예제에서는 text 속성 값을 가져 ts-date
와서 현재 날짜와 비교합니다 OLD:
. 기한이 지난 경우에는 ; 현재 인 경우을 추가 CURRENT:
하고 미래인 경우을 추가 FUTURE:
합니다. 원래 포스터는이 예제를 사용자 정의하여 선택한 위치에 새 줄 및 / 또는 구분선을 추가 할 수 있습니다. 사용자 정의는 org-agenda-sorting-strategy
등 의 원본 포스터에서 선택한 정렬 기준에 따라 달라질 수 있습니다 .
이 예에서 함수 org-agenda-finalize-entries
는 ;; BEGIN modification
및 레이블이 지정된 섹션 사이의 하단 근처에서 수정되었습니다 ;; END modification
.
(require 'org-agenda)
(defun org-agenda-finalize-entries (list &optional type)
"Sort, limit and concatenate the LIST of agenda items.
The optional argument TYPE tells the agenda type."
(let ((max-effort (cond ((listp org-agenda-max-effort)
(cdr (assoc type org-agenda-max-effort)))
(t org-agenda-max-effort)))
(max-todo (cond ((listp org-agenda-max-todos)
(cdr (assoc type org-agenda-max-todos)))
(t org-agenda-max-todos)))
(max-tags (cond ((listp org-agenda-max-tags)
(cdr (assoc type org-agenda-max-tags)))
(t org-agenda-max-tags)))
(max-entries (cond ((listp org-agenda-max-entries)
(cdr (assoc type org-agenda-max-entries)))
(t org-agenda-max-entries))) l)
(when org-agenda-before-sorting-filter-function
(setq list
(delq nil
(mapcar
org-agenda-before-sorting-filter-function list))))
(setq list (mapcar 'org-agenda-highlight-todo list)
list (mapcar 'identity (sort list 'org-entries-lessp)))
(when max-effort
(setq list (org-agenda-limit-entries
list 'effort-minutes max-effort 'identity)))
(when max-todo
(setq list (org-agenda-limit-entries list 'todo-state max-todo)))
(when max-tags
(setq list (org-agenda-limit-entries list 'tags max-tags)))
(when max-entries
(setq list (org-agenda-limit-entries list 'org-hd-marker max-entries)))
;; BEGIN modification
(setq list
(mapcar
(lambda (string)
(let* (
(current-date (time-to-days (current-time)))
(ts-date (get-text-property 0 'ts-date string)) )
(if ts-date
(cond
((< ts-date current-date)
(message "The task dated %s is overdue." ts-date)
;; The new value of `string' is returned/thrown as a result.
(replace-regexp-in-string "^" "OLD: " string))
((= ts-date current-date)
(message "The task dated %s is due today." ts-date)
;; The new value of `string' is returned/thrown as a result.
(replace-regexp-in-string "^" "CURRENT: " string))
((> ts-date current-date)
(message "The task dated %s is not due yet." ts-date)
;; The new value of `string' is returned/thrown as a result.
(replace-regexp-in-string "^" "FUTURE: " string)))
string)))
list))
;; END modification
(mapconcat 'identity list "\n")))