1
0
mirror of https://github.com/Tygs/0bin.git synced 2023-08-10 21:13:00 +03:00

Add toggle for reader mode

This commit is contained in:
ksamuel 2020-08-13 16:53:17 +02:00
parent 1939a6b89e
commit cda601a355
4 changed files with 40 additions and 5 deletions

View File

@ -9,7 +9,7 @@ PORT = "3255"
# Names/links to insert in the footer. # Names/links to insert in the footer.
# #
MENU = ( MENU = (
("Create paste", "/"), # First link will be highlighted ("Create paste", "/"),
("Github", "https://github.com/Tygs/0bin"), ("Github", "https://github.com/Tygs/0bin"),
("Faq", "/faq/"), # You probably want to keep this ("Faq", "/faq/"), # You probably want to keep this
# Any link with "mailto:" will be escaped to limit spam, but displayed # Any link with "mailto:" will be escaped to limit spam, but displayed

View File

@ -26,11 +26,13 @@ const app = new Vue({
downloadLink: {}, downloadLink: {},
displayBottomToolBar: false, displayBottomToolBar: false,
openPreviousPastesMenu: false, openPreviousPastesMenu: false,
readerMode: false,
isUploading: false, isUploading: false,
currentPaste: { currentPaste: {
ownerKey: '', ownerKey: '',
id: '', id: '',
type: '', type: '',
content: ''
}, },
newPaste: { newPaste: {
expiration: '1_day', expiration: '1_day',
@ -66,6 +68,28 @@ const app = new Vue({
}, },
methods: { methods: {
toggleReaderMode: function () {
if (!this.readerMode) {
this.messages = [];
this.currentPaste.content = zerobin.getPasteContent();
}
this.readerMode = !this.readerMode;
},
increaseFontSize: function (amount) {
let readableModeContent = document.getElementById('readable-paste-content')
let fontSize = window.getComputedStyle(readableModeContent, null).getPropertyValue('font-size');
amount = amount || 5;
readableModeContent.style.fontSize = (parseFloat(fontSize) + amount) + "px";
},
decreaseFontSize: function () {
this.increaseFontSize(-5);
},
formatEmail: (email) => { formatEmail: (email) => {
return "mailto:" + email.replace('__AT__', '@'); return "mailto:" + email.replace('__AT__', '@');
}, },

View File

@ -11,6 +11,7 @@
<link rel="icon" href="/static/img/favicon.ico" /> <link rel="icon" href="/static/img/favicon.ico" />
%if not settings.DEBUG: %if not settings.DEBUG:
<link href="/static/css/style.min.css?{{ VERSION }}" rel="stylesheet" /> <link href="/static/css/style.min.css?{{ VERSION }}" rel="stylesheet" />
%else: %else:
@ -26,7 +27,7 @@
<div id="app"> <div id="app">
<div class="topnav" @mouseleave="openPreviousPastesMenu =false"> <div :class="{'topnav': true, 'reader-mode': readerMode}" @mouseleave="openPreviousPastesMenu =false">
<a class="brand" href="/"><span>ø</span>bin<em>.net</em></a> <a class="brand" href="/"><span>ø</span>bin<em>.net</em></a>
<span class="tagline">"A client side encrypted PasteBin"<br><span>All pastes are AES256 encrypted, we cannot know <span class="tagline">"A client side encrypted PasteBin"<br><span>All pastes are AES256 encrypted, we cannot know
what you paste...</span> what you paste...</span>
@ -34,6 +35,14 @@
<nav> <nav>
<ul> <ul>
<li>
<a href="#" v-if="currentPaste.type === 'text'" @click.prevent="toggleReaderMode()">📖</a>
<span v-if="readerMode">
<a href="#" @click.prevent="increaseFontSize()">+</a>
<a href="#" @click.prevent="decreaseFontSize()">-</a>
🔍
</span>
</li>
<li class="submenu"><a href="#" @click.prevent="openPreviousPastesMenu = !openPreviousPastesMenu">Previous <li class="submenu"><a href="#" @click.prevent="openPreviousPastesMenu = !openPreviousPastesMenu">Previous
pastes v</a> pastes v</a>
<ul class="previous-pastes" id="topmenu" v-if="openPreviousPastesMenu"> <ul class="previous-pastes" id="topmenu" v-if="openPreviousPastesMenu">

View File

@ -54,12 +54,14 @@
<span id="expiration-tag">Expire {{ expiration }}</span> <span id="expiration-tag">Expire {{ expiration }}</span>
%end %end
<pre id="paste-content" class="prettyprint"> <pre id="paste-content" class="prettyprint" v-if="!readerMode">
<div class="paste-wrapper">
<code> <code>
{{ paste.content }} {{ paste.content }}
</code> </code>
</div> </pre>
<pre id="readable-paste-content" v-if="readerMode">
{% currentPaste.content %}
</pre> </pre>
<div class="d-flex justify-content-between down"> <div class="d-flex justify-content-between down">