-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathreader.html
120 lines (93 loc) · 2.79 KB
/
reader.html
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
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Coach Mate</title>
<link rel='stylesheet' href="../node_modules/bulma/css/bulma.css">
<link rel='stylesheet' href="../node_modules/font-awesome/css/font-awesome.min.css">
<link rel='stylesheet' href="main.css">
<style media="screen">
html, body, webview {
height: 100%
}
</style>
</head>
<body>
<section id="loader" class="hero is-fullheight has-text centered">
<div class="hero-body">
<div class="container">
<div class="busy">
<h1 class="title">
<span class="icon-is-large">
<i class="fa fa-circle-o-notch fa-spin fa-fw"></i>
</span>
</h1>
</div>
<div class="failed is-hidden">
<h1 class="title">Failed to Load</h1>
<h2 class="subtitle">Please check your Network Connection</h2>
</div>
</div>
</div>
</section>
<a id="keep" class="is-hidden">
<div class="block">
<span class="tag is-large is-info">
<span class="icon">
<i class="fa fa-check fa-inverse"></i>
</span> Keep it!
</span>
</div>
</a>
<a id="delete" class="is-hidden">
<div class="block">
<span class="tag is-large is-info">
<span class="icon">
<i class="fa fa-check fa-inverse"></i>
</span> Delete it!
</span>
</div>
</a>
<webview src="about:blank"></webview>
<script>
// jQuery
$ = require('jquery')
const queryString = require('query-string')
//Parse query string
const queryParams = queryString.parse(location.search)
//Get item index
let itemIndex = queryParams.itemIndex
//Get query string 'url'
let url = decodeURIComponent(queryParams.url)
// Load remote content once webview is ready
$('webview').one('dom-ready', (e) => {
//Load item content url into webview
e.currentTarget.loadURL(url)
}).one('did-finish-load', () => {
// Hide loader to reveal webview
$('#loader').fadeOut(100)
//Show mark read button
$('#keep').removeClass('is-hidden')
$('#delete').removeClass('is-hidden')
// Handle failed load
}).on('did-fail-load', () => {
$('#keep').addClass('is-hidden')
$('#delete').addClass('is-hidden')
$('#loader .busy').addClass('is-hidden')
$('#loader').fadeIn(100)
$('#loader .failed').removeClass('is-hidden')
})
// Handle mark-read click (delete)
$('#keep').click(() => {
// Parent window
window.close()
})
// Handle mark-read click (keep)
$('#delete').click(() => {
// Parent window
window.opener.eval(`deleteItem(${itemIndex})`)
window.close()
})
</script>
</body>
</html>