-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathclient.js
104 lines (82 loc) · 3.06 KB
/
client.js
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
const { ipcMain } = require('electron');
const Parser = require('rss-parser');
const Store = require('electron-store');
const store = new Store();
document.addEventListener('DOMContentLoaded', (event) => {
document.querySelector('#add-blog').addEventListener('click', () => {
document.querySelector('#main-screen').classList.add('hidden');
document.querySelector('#form').classList.remove('hidden');
});
document.querySelector('#back').addEventListener('click', () => {
document.querySelector('#main-screen').classList.remove('hidden');
document.querySelector('#form').classList.add('hidden');
});
document.querySelector('form').addEventListener('submit', () => {
store.set('feeds', [
...(store.get('feeds') || []),
document.querySelector('#feedurl').value,
]);
});
const rerender = (posts) => {
document.querySelector('tbody').innerHTML = '';
posts
.sort((a, b) => new Date(b.date) - new Date(a.date))
.map((value, index) => {
const link = document.createElement('a');
link.setAttribute('href', value.link);
link.value = value.title;
const div1 = document.createElement('div');
div1.setAttribute(
'class',
'text-sm leading-5 font-medium text-gray-900 underline'
);
div1.appendChild(link);
const div2 = document.createElement('div');
div2.setAttribute('class', 'text-sm leading-5 text-gray-500');
div2.innerText = value.title;
const divWrapper1 = document.createElement('div');
divWrapper1.setAttribute('class', 'ml-4');
divWrapper1.appendChild(div1);
divWrapper1.appendChild(div2);
const divWrapper2 = document.createElement('div');
divWrapper2.setAttribute('class', 'flex items-center');
divWrapper2.appendChild(divWrapper1);
const td_1 = document.createElement('td');
td_1.appendChild(divWrapper2);
const div1_2 = document.createElement('div');
div1_2.setAttribute('class', 'text-sm leading-5 text-gray-900');
div1_2.innerText = new Date(value.date).toDateString();
const td_2 = document.createElement('td');
td_2.setAttribute(
'class',
'px-6 py-4 whitespace-no-wrap border-b border-gray-200'
);
td_2.appendChild(div1_2);
const tr = document.createElement('tr');
tr.appendChild(td_1);
tr.appendChild(td_2);
const item = document.createDocumentFragment();
item.appendChild(tr);
document.querySelector('tbody').appendChild(item);
})
}
const getPosts = async () => {
const posts = [];
const parser = new Parser();
for (const feed of store.get('feeds')) {
const data = await parser.parseURL(feed);
data.items.slice(0, 10).forEach((item) => {
posts.push({
title: item.title,
link: item.link,
date: item.isoDate,
name: feed.name,
});
});
}
return posts;
}
getPosts().then((posts) => {
rerender(posts);
});
});