forked from emacs-slack/emacs-slack
-
Notifications
You must be signed in to change notification settings - Fork 0
/
slack-message-faces.el
135 lines (106 loc) · 4.1 KB
/
slack-message-faces.el
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
;;; slack-message-faces.el --- -*- lexical-binding: t; -*-
;; Copyright (C) 2020 南優也
;; Author: 南優也 <[email protected]>
;; Keywords:
;; This program is free software; you can redistribute it and/or modify
;; it under the terms of the GNU General Public License as published by
;; the Free Software Foundation, either version 3 of the License, or
;; (at your option) any later version.
;; This program is distributed in the hope that it will be useful,
;; but WITHOUT ANY WARRANTY; without even the implied warranty of
;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
;; GNU General Public License for more details.
;; You should have received a copy of the GNU General Public License
;; along with this program. If not, see <https://www.gnu.org/licenses/>.
;;; Commentary:
;;
;;; Code:
(require 'color)
(defface slack-profile-image-face
'((t ()))
"Face used to profile image."
:group 'slack)
(defface slack-message-output-text
'((t (:weight normal)))
"Face used to text message."
:group 'slack)
(defface slack-message-output-header
'((t (:foreground "#FFA000"
:weight bold
:height 1.0
:underline t)))
"Face used to text message."
:group 'slack)
(defface slack-message-output-reaction
'((t (:box (:line-width 1 :style released-button))))
"Face used to reactions."
:group 'slack)
(defface slack-message-output-reaction-pressed
'((t (:background "cyan" :box (:line-width 1 :style released-button))))
"Face used to reactions pressed by user."
:group 'slack)
(defface slack-message-deleted-face
'((t (:strike-through t)))
"Face used to deleted message."
:group 'slack)
(defface slack-attachment-header
'((t (:inherit slack-message-output-header)))
"Face used to shared message header."
:group 'slack)
(defface slack-attachment-footer
'((t (:height 0.8)))
"Face used to shared message footer."
:group 'slack)
(defface slack-attachment-pad
'((t (:weight ultra-bold)))
"Face used to shared message pad."
:group 'slack)
(defface slack-attachment-field-title
'((t (:weight bold :height 1.0)))
"Face used to attachment field title."
:group 'slack)
(defface slack-channel-button-face
'((t (:underline t :foreground "cyan")))
"Face used to channel button."
:group 'slack)
(defface slack-message-mention-face
'((t (:background "#073642" :foreground "#2aa198")))
"Face used to mention."
:group 'slack)
(defface slack-message-mention-me-face
'((t (:background "#073642" :foreground "#b58900")))
"Face used to mention."
:group 'slack)
(defface slack-message-mention-keyword-face
'((t (:background "#073642" :foreground "#859900")))
"Face used to @here, @channel, @everyone mention."
:group 'slack)
(defface slack-preview-face
(let* ((default-bg (or (face-background 'default) "unspecified-bg"))
(light-bg (if (equal default-bg "unspecified-bg")
"unspecified-bg"
(color-darken-name default-bg 3)))
(dark-bg (if (equal default-bg "unspecified-bg")
"unspecified-bg"
(color-lighten-name default-bg 3))))
`((default :inherit (fixed-pitch shadow) :slant normal :weight normal)
(((type graphic) (class color) (background dark)) (:background ,dark-bg))
(((type graphic) (class color) (background light)) (:background ,light-bg))))
"Used preview text and code blocks"
:group 'slack)
(defun slack-message-put-header-property (header)
(if header
(propertize header 'face 'slack-message-output-header)))
(defun slack-message-put-text-property (text)
(if text
(propertize text 'face 'slack-message-output-text)))
(defun slack-message-put-deleted-property (text)
(if text
(propertize text 'face 'slack-message-deleted-face)))
(defun slack-put-preview-overlay (start end)
(let ((overlay (make-overlay start end)))
(overlay-put overlay 'face 'slack-preview-face)))
(defalias 'slack-put-email-body-overlay 'slack-put-preview-overlay)
(defalias 'slack-put-code-block-overlay 'slack-put-preview-overlay)
(provide 'slack-message-faces)
;;; slack-message-faces.el ends here