Compare commits

..

No commits in common. "de55f4a4dee9b26f25416056c3589d4b42c54811" and "7964405502509b68a4882f95ac3cd9313f91cd1a" have entirely different histories.

12 changed files with 24 additions and 78 deletions

View file

@ -11,7 +11,8 @@ browser and detect feed URLs in web pages.
``` ```
git clone https://git.platypush.tech/blacklight/rss-viewer-browser-extension git clone https://git.platypush.tech/blacklight/rss-viewer-browser-extension
cd rss-viewer-browser-extension cd rss-viewer-browser-extension
./build.sh npm install
npm run build
``` ```
A file named `dist.crx` will be generated - just drop it into your browser's extensions. A file named `dist.crx` will be generated - just drop it into your browser's extensions.

View file

@ -1,6 +0,0 @@
#!/bin/sh
npm install
npm run build
zip -r dist dist
mv dist.zip dist.crx

8
package-lock.json generated
View file

@ -1,12 +1,12 @@
{ {
"name": "rss-viewer-browser-ext", "name": "sample-project",
"version": "0.1.1", "version": "1.0.0",
"lockfileVersion": 2, "lockfileVersion": 2,
"requires": true, "requires": true,
"packages": { "packages": {
"": { "": {
"name": "rss-viewer-browser-ext", "name": "sample-project",
"version": "0.1.1", "version": "1.0.0",
"dependencies": { "dependencies": {
"dotenv": "^16.0.0", "dotenv": "^16.0.0",
"node-sass": "^8.0.0", "node-sass": "^8.0.0",

View file

@ -1,6 +1,6 @@
{ {
"name": "rss-viewer-browser-ext", "name": "rss-viewer-browser-ext",
"version": "0.1.1", "version": "0.1.0",
"type": "module", "type": "module",
"scripts": { "scripts": {
"build": "rollup -c", "build": "rollup -c",

View file

@ -136,7 +136,10 @@ const getFeedRoot = () => {
return root return root
} }
const renderFeed = () => { browser.runtime.onMessage.addListener(async (message: {type: Object}) => {
if (message.type !== 'renderFeed')
return
const xmlDoc = getFeedRoot() const xmlDoc = getFeedRoot()
if (!xmlDoc) if (!xmlDoc)
// Not an RSS feed // Not an RSS feed
@ -148,33 +151,4 @@ const renderFeed = () => {
browser.storage.local.set(parseFeed(channel)) browser.storage.local.set(parseFeed(channel))
window.location.href = browser.runtime.getURL('viewer/index.html') window.location.href = browser.runtime.getURL('viewer/index.html')
}
const extractFeedUrl = () => {
const links = Array.from(document.getElementsByTagName('link'))
.filter((link) =>
link.getAttribute('rel') === 'alternate' &&
link.getAttribute('type') === 'application/rss+xml'
)
if (!links.length)
return
let link = links[0].getAttribute('href') || ''
if (link.length && !link.match(/^https?:\/\//)) {
let port = window.location.port
if (port.length)
port = `:${port}`
link = `${window.location.protocol}//${window.location.hostname}${port}${link}`
}
return link.length ? link : null
}
browser.runtime.onMessage.addListener(async (message: {type: Object}) => {
if (message.type === 'renderFeed')
return renderFeed()
if (message.type === 'extractFeedUrl')
return extractFeedUrl()
}) })

View file

@ -1,7 +1,7 @@
{ {
"name": "RSS Viewer", "name": "RSS Viewer",
"description": "An easy way to render RSS feeds directly in your browser", "description": "An easy way to render RSS feeds directly in your browser",
"version": "0.1.1", "version": "0.1.0",
"manifest_version": 3, "manifest_version": 3,
"action": { "action": {
"default_icon": { "default_icon": {

View file

@ -1,34 +1,14 @@
<template> <template>
<div class="popup"> <div class="popup">
<div v-if="feedUrl"> Nothing interesting here
<a :href="feedUrl" target="_blank">Found a feed URL</a>
</div>
<div v-else>
No feed URLs found on this page
</div>
</div> </div>
</template> </template>
<script> <script lang="ts">
import browser from 'webextension-polyfill';
export default { export default {
name: 'Popup', name: 'Popup',
data() {
return {
feedUrl: null,
}
},
async mounted() {
const [tab] = await chrome.tabs.query({ active: true, currentWindow: true })
this.feedUrl = await browser.tabs.sendMessage(tab.id, {type: 'extractFeedUrl'})
},
} }
</script> </script>
<style scoped> <style scoped>
.popup {
padding: 1em;
}
</style> </style>

View file

@ -2,7 +2,7 @@
<html> <html>
<head> <head>
<meta charset="UTF-8"> <meta charset="UTF-8">
<title>RSS Viewer Popup</title> <title>Popup</title>
</head> </head>
<body style="min-width: 200px;"> <body style="min-width: 200px;">
<div id="app"></div> <div id="app"></div>

View file

@ -1,5 +1,6 @@
import { createApp } from "vue"; import { createApp } from "vue";
//import { createPinia } from "pinia";
import App from "./Popup.vue"; import App from "./Popup.vue";
const app = createApp(App) const app = createApp(App) //.use(createPinia());
app.mount('#app') app.mount('#app')

View file

@ -18,8 +18,7 @@
<main> <main>
<div class="item" v-for="item, i in (feed.items || [])" :key="i"> <div class="item" v-for="item, i in (feed.items || [])" :key="i">
<div class="header" :class="{expanded: expandedItems[i]}" <div class="header" @click="expandedItems[i] = !expandedItems[i]">
@click="expandedItems[i] = !expandedItems[i]">
<h2 v-if="item.title?.length"> <h2 v-if="item.title?.length">
<a :href="item.url" target="_blank" v-text="item.title" /> <a :href="item.url" target="_blank" v-text="item.title" />
</h2> </h2>
@ -125,10 +124,6 @@ main {
padding: 0.5em; padding: 0.5em;
border-radius: 1em; border-radius: 1em;
&.expanded {
border-radius: 1em 1em 0 0;
}
&:hover { &:hover {
background: #cff7cf; background: #cff7cf;
} }

View file

@ -1,5 +1,6 @@
import { createApp } from "vue"; import { createApp } from "vue";
//import { createPinia } from "pinia";
import App from "./App.vue"; import App from "./App.vue";
const app = createApp(App) const app = createApp(App) // .use(createPinia());
app.mount('#app') app.mount('#app')