dda-masto-embed/src/main/dda/masto_embed/app.cljs

129 lines
4.1 KiB
Text
Raw Normal View History

2020-04-25 11:42:54 +00:00
; Licensed to the Apache Software Foundation (ASF) under one
; or more contributor license agreements. See the NOTICE file
; distributed with this work for additional information
; regarding copyright ownership. The ASF licenses this file
; to you under the Apache License, Version 2.0 (the
; "License"); you may not use this file except in compliance
; with the License. You may obtain a copy of the License at
;
; http://www.apache.org/licenses/LICENSE-2.0
;
; Unless required by applicable law or agreed to in writing, software
; distributed under the License is distributed on an "AS IS" BASIS,
; WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
; See the License for the specific language governing permissions and
; limitations under the License.
(ns dda.masto-embed.app
2020-04-24 15:22:51 +00:00
(:require
2020-06-19 09:05:45 +00:00
[cljs.core.async :refer [go close! put! take! timeout chan <! >!]]
[cljs.core.async.interop :refer-macros [<p!]]
2020-07-08 18:35:01 +00:00
[hiccups.runtime :refer [render-html]]
[dda.masto-embed.api :as api]
[dda.masto-embed.infra :as infra]
[dda.masto-embed.render-bootstrap :as rb]
))
2020-04-24 16:22:41 +00:00
2020-04-25 12:26:33 +00:00
(def masto-embed "masto-embed")
2022-02-24 13:08:43 +00:00
(defn element-from-document-by-name [name]
2020-04-26 16:35:09 +00:00
(-> js/document
(.getElementById masto-embed)
2022-02-24 13:08:43 +00:00
(.getAttribute name)))
(defn host-url-from-document []
(element-from-document-by-name "host_url"))
2020-06-19 09:05:45 +00:00
2020-06-19 15:26:34 +00:00
(defn account-name-from-document []
2022-02-24 13:08:43 +00:00
(element-from-document-by-name "account_name"))
2020-04-26 16:35:09 +00:00
(defn account-id-from-document []
2022-02-24 13:08:43 +00:00
(element-from-document-by-name "account_id"))
2020-04-24 16:22:41 +00:00
(defn replies-to-from-document []
(element-from-document-by-name "replies_to"))
(defn filter-favorited-from-document []
(element-from-document-by-name "filter_favorited"))
2020-04-24 16:41:40 +00:00
(defn render-to-document
[input]
(-> js/document
2020-04-25 12:26:33 +00:00
(.getElementById masto-embed)
2020-04-24 16:41:40 +00:00
(.-innerHTML)
(set! input)))
2020-06-19 09:05:45 +00:00
(defn find-account-id [host-url account-name]
2020-06-19 15:26:34 +00:00
(let [out (chan)]
2020-06-19 09:05:45 +00:00
(go
2020-06-19 15:26:34 +00:00
(>! out
(->>
(<p! (api/get-directory host-url))
2020-06-23 18:09:00 +00:00
api/mastojs->edn
2020-06-19 15:26:34 +00:00
(filter #(= account-name (:acct %)))
2020-06-24 17:59:02 +00:00
(infra/debug)
2020-06-19 15:26:34 +00:00
(map :id)
2020-06-19 15:28:32 +00:00
first)))
2020-06-19 09:05:45 +00:00
out))
(defn favorited-replies? [host-url account-name reply-id]
(let [out (chan)]
(go
(>! out
(->>
(<p! (api/get-favorited-by host-url reply-id))
api/mastojs->edn
(filter #(= account-name (:acct %)))
(empty?)
(not))))
out))
(defn favorited? [host-url account-name replies]
(let [out (chan)]
(go
(>! out
(loop [loc-replies replies
result []]
(if (empty? loc-replies)
result
(recur (rest loc-replies)
(conj result (<! (favorited-replies? host-url account-name (first loc-replies)))))))))
out))
(defn account-mode [host-url account-name]
2020-06-19 09:05:45 +00:00
(go
(let [account-id (or
2020-06-19 09:05:45 +00:00
(account-id-from-document)
2020-06-19 15:26:34 +00:00
(<! (find-account-id host-url account-name)))
2020-06-23 18:09:00 +00:00
statuus (->
(<p! (api/get-account-statuses host-url account-id))
api/mastojs->edn)]
(->> statuus
(take 4)
(rb/masto->html)
(render-html)
(render-to-document)))))
(defn replies-mode [host-url account-name post-id filter-favorited]
(go
2022-03-11 08:50:01 +00:00
(let [replies (->
(<p! (api/get-replies host-url post-id))
api/mastojs->edn)
favorited (<! (favorited? host-url account-name (map :id (:descendants replies))))
combined (map (fn [s f] {:status s :favorited f}) (:descendants replies) favorited)]
(->> combined
(filter #(infra/debug (or (not filter-favorited) (:favorited %))))
(map :status)
(infra/debug)
(rb/masto->html)
(render-html)
(render-to-document)))))
(defn init []
(let [host-url (host-url-from-document)
account-name (account-name-from-document)
replies-to (replies-to-from-document)
2022-03-11 08:50:01 +00:00
filter-favorited (filter-favorited-from-document)]
(if (nil? replies-to)
(account-mode host-url account-name)
(replies-mode host-url account-name replies-to filter-favorited))
))