forked from utags/browser-extension-starter
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
e6e9030
commit e22b82f
Showing
6 changed files
with
226 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,156 @@ | ||
// ==UserScript== | ||
// @name Miniflux Extension | ||
// @name:zh-CN Miniflux Extension | ||
// @namespace https://github.com/utags/miniflux-extension | ||
// @homepage https://github.com/utags/miniflux-extension#readme | ||
// @supportURL https://github.com/utags/miniflux-extension/issues | ||
// @version 0.0.1 | ||
// @description An extension for Miniflux RSS reader | ||
// @description:zh-CN Miniflux RSS 阅读器扩展 | ||
// @icon https://miniflux.app/favicon.ico | ||
// @author Pipecraft | ||
// @license MIT | ||
// @match https://miniflux.pipecraft.net/* | ||
// @grant GM_addElement | ||
// @grant GM_addStyle | ||
// ==/UserScript== | ||
// | ||
;(() => { | ||
"use strict" | ||
var doc = document | ||
var $ = (element, selectors) => | ||
element && typeof element === "object" | ||
? element.querySelector(selectors) | ||
: doc.querySelector(element) | ||
var createElement = (tagName, attributes) => | ||
setAttributes(doc.createElement(tagName), attributes) | ||
var addEventListener = (element, type, listener, options) => { | ||
if (!element) { | ||
return | ||
} | ||
if (typeof type === "object") { | ||
for (const type1 in type) { | ||
if (Object.hasOwn(type, type1)) { | ||
element.addEventListener(type1, type[type1]) | ||
} | ||
} | ||
} else if (typeof type === "string" && typeof listener === "function") { | ||
element.addEventListener(type, listener, options) | ||
} | ||
} | ||
var setAttribute = (element, name, value) => | ||
element ? element.setAttribute(name, value) : void 0 | ||
var setAttributes = (element, attributes) => { | ||
if (element && attributes) { | ||
for (const name in attributes) { | ||
if (Object.hasOwn(attributes, name)) { | ||
const value = attributes[name] | ||
if (value === void 0) { | ||
continue | ||
} | ||
if (/^(value|textContent|innerText|innerHTML)$/.test(name)) { | ||
element[name] = value | ||
} else if (name === "style") { | ||
setStyle(element, value, true) | ||
} else if (/on\w+/.test(name)) { | ||
const type = name.slice(2) | ||
addEventListener(element, type, value) | ||
} else { | ||
setAttribute(element, name, value) | ||
} | ||
} | ||
} | ||
} | ||
return element | ||
} | ||
var setStyle = (element, values, overwrite) => { | ||
if (!element) { | ||
return | ||
} | ||
const style = element.style | ||
if (typeof values === "string") { | ||
style.cssText = overwrite ? values : style.cssText + ";" + values | ||
return | ||
} | ||
if (overwrite) { | ||
style.cssText = "" | ||
} | ||
for (const key in values) { | ||
if (Object.hasOwn(values, key)) { | ||
style[key] = values[key].replace("!important", "") | ||
} | ||
} | ||
} | ||
if (typeof Object.hasOwn !== "function") { | ||
Object.hasOwn = (instance, prop) => | ||
Object.prototype.hasOwnProperty.call(instance, prop) | ||
} | ||
var addElement = (parentNode, tagName, attributes) => { | ||
if (typeof parentNode === "string" || typeof tagName === "string") { | ||
const element = GM_addElement(parentNode, tagName, attributes) | ||
setAttributes(element, attributes) | ||
return element | ||
} | ||
setAttributes(tagName, attributes) | ||
parentNode.append(tagName) | ||
return tagName | ||
} | ||
var addStyle = (styleText) => GM_addStyle(styleText) | ||
var content_default = | ||
".miniflux_ext #left_section{position:fixed;top:0;left:0;padding:20px;overflow:auto;height:100%}" | ||
var config = { | ||
matches: ["https://miniflux.pipecraft.net/*"], | ||
} | ||
var storageKey = "extension.miniflux.cache" | ||
function getCategoriesFromCache() { | ||
const categoriesText = localStorage.getItem(storageKey) || "" | ||
return createElement("div", { | ||
class: "items", | ||
innerHTML: categoriesText, | ||
}) | ||
} | ||
async function updateCategories() { | ||
const response = await fetch("/categories") | ||
if (response.status === 200) { | ||
const text = await response.text() | ||
const div = createElement("div") | ||
div.innerHTML = text | ||
const categories = $(div, ".items") | ||
if (categories) { | ||
const categoriesText = localStorage.getItem(storageKey) || "" | ||
if (categoriesText !== categories.innerHTML) { | ||
localStorage.setItem(storageKey, categories.innerHTML) | ||
return true | ||
} | ||
} | ||
} | ||
return false | ||
} | ||
async function main() { | ||
if (!document.body || $(".miniflux_ext #left_section")) { | ||
return | ||
} | ||
addStyle(content_default) | ||
document.body.classList.add("miniflux_ext") | ||
const left = addElement(document.body, "section", { | ||
id: "left_section", | ||
innerHTML: `<section class="page-header"><h1>Categories</h1></section>`, | ||
}) | ||
let categories = getCategoriesFromCache() | ||
if (categories) { | ||
left.append(categories) | ||
} | ||
setTimeout(async () => { | ||
if (await updateCategories()) { | ||
console.log("updated") | ||
categories.remove() | ||
categories = getCategoriesFromCache() | ||
if (categories) { | ||
left.append(categories) | ||
} | ||
} | ||
}, 1e3) | ||
} | ||
main() | ||
addEventListener(document, "DOMContentLoaded", main) | ||
})() |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,24 @@ | ||
# Miniflux Extension | ||
|
||
An extension for Miniflux RSS reader. | ||
|
||
- After install this script, add miniflux site to "User matches" rules on the settings of this userscript | ||
|
||
data:image/s3,"s3://crabby-images/337e1/337e14b337c6caa9e89979b9d9f15b8afa015086" alt="screenshots" | ||
|
||
- Display categories on left section | ||
|
||
data:image/s3,"s3://crabby-images/2c50c/2c50c04a6f47cb8f6a1a66fde8e7a77201ccad0b" alt="screenshots" | ||
|
||
More information: [https://github.com/utags/miniflux-extension](https://github.com/utags/miniflux-extension) | ||
|
||
## License | ||
|
||
Copyright (c) 2023 [Pipecraft](https://www.pipecraft.net). Licensed under the [MIT License](https://github.com/utags/miniflux-extension/blob/main/LICENSE). | ||
|
||
## >\_ | ||
|
||
[data:image/s3,"s3://crabby-images/cd919/cd919d22975e123b1712d44a3390d6bbf92f774f" alt="Pipecraft"](https://www.pipecraft.net) | ||
[data:image/s3,"s3://crabby-images/f7ef3/f7ef3648dd42f7c5ca5ead5aea26d1387270484c" alt="UTags"](https://utags.pipecraft.net) | ||
[data:image/s3,"s3://crabby-images/5e194/5e1945cc97c9e4d2db1eb2322c2b6378285713d2" alt="DTO"](https://dto.pipecraft.net) | ||
[data:image/s3,"s3://crabby-images/d54fa/d54fa20460da05acd42721425a008f3309609b40" alt="BestXTools"](https://www.bestxtools.com) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,24 @@ | ||
# Miniflux Extension | ||
|
||
Miniflux RSS 阅读器扩展. | ||
|
||
- 安装脚本后,需要把 miniflux 网站的域名添加到 "User matches" 规则列表里 | ||
|
||
data:image/s3,"s3://crabby-images/337e1/337e14b337c6caa9e89979b9d9f15b8afa015086" alt="screenshots" | ||
|
||
- 功能 1: 分类列表显示在左边栏 | ||
|
||
data:image/s3,"s3://crabby-images/2c50c/2c50c04a6f47cb8f6a1a66fde8e7a77201ccad0b" alt="screenshots" | ||
|
||
More information: [https://github.com/utags/miniflux-extension](https://github.com/utags/miniflux-extension) | ||
|
||
## License | ||
|
||
Copyright (c) 2023 [Pipecraft](https://www.pipecraft.net). Licensed under the [MIT License](https://github.com/utags/miniflux-extension/blob/main/LICENSE). | ||
|
||
## >\_ | ||
|
||
[data:image/s3,"s3://crabby-images/cd919/cd919d22975e123b1712d44a3390d6bbf92f774f" alt="Pipecraft"](https://www.pipecraft.net) | ||
[data:image/s3,"s3://crabby-images/f7ef3/f7ef3648dd42f7c5ca5ead5aea26d1387270484c" alt="UTags"](https://utags.pipecraft.net) | ||
[data:image/s3,"s3://crabby-images/5e194/5e1945cc97c9e4d2db1eb2322c2b6378285713d2" alt="DTO"](https://dto.pipecraft.net) | ||
[data:image/s3,"s3://crabby-images/d54fa/d54fa20460da05acd42721425a008f3309609b40" alt="BestXTools"](https://www.bestxtools.com) |