summaryrefslogtreecommitdiff
path: root/src/gizmo/wasp-bannerads.el
blob: e950d8743b2e78c504afdf07fe7242982314b83d (plain)
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
;;; wasp-bannerads --- Advertising and merchandising for elite finance -*- lexical-binding: t; -*-
;;; Commentary:
;;; Code:

(require 'dash)
(require 's)
(require 'f)
(require 'ht)
(require 'wasp-utils)
(require 'wasp-chat)
(require 'wasp-model)

(defvar w/banner-ad-block nil)

(defcustom w/banner-ad-buffer "*wasp-banner-ad*"
  "Name of buffer used to display banner ad."
  :type '(string)
  :group 'wasp)

(define-derived-mode w/banner-ad-mode special-mode "banner ad"
  "Major mode for displaying banner ads."
  :group 'w
  (setq-local cursor-type nil))

(defun w/banner-ad-get-buffer ()
  "Return the banner ad buffer."
  (unless (get-buffer w/banner-ad-buffer)
    (with-current-buffer (get-buffer-create w/banner-ad-buffer)
      (w/banner-ad-mode)))
  (get-buffer w/banner-ad-buffer))

(defvar w/banner-ad-position-jitter 0)
(defun w/banner-ad-update ()
  "Render the banner ad buffer."
  (with-current-buffer (w/banner-ad-get-buffer)
    (setq-local cursor-type nil)
    (let* ((inhibit-read-only t))
      (erase-buffer)
      (if w/banner-ad-block
        (w/write "This advertisement was blocked by your adblocker")
        (let* ((paths (f-files (w/asset "bannerads")))
                (path (w/pick-random paths))
                (img
                  (create-image path nil nil
                    :max-width 555 :max-height 175
                    :animate-position (+ (point-min) w/banner-ad-position-jitter))))
          (setf w/banner-ad-position-jitter (% (+ w/banner-ad-position-jitter 1) (length "bannerad")))
          (image-animate img nil t)
          (w/write (propertize "bannerad" 'display img)))))))
(add-hook 'w/gizmo-update-hook #'w/banner-ad-update)

(defun w/banner-ad-block ()
  "Toggle adblock."
  (setq w/banner-ad-block t)
  (w/banner-ad-update)
  (w/overlay-toggle-set "adblock")
  (run-with-timer 10 nil
    (lambda ()
      (setq w/banner-ad-block nil)
      (w/overlay-toggle-unset "adblock")
      (w/banner-ad-update)))
  nil)

(provide 'wasp-bannerads)
;;; wasp-bannerads.el ends here