Merge branch 'release/0.2.2'

This commit is contained in:
Book Pauk
2019-02-17 14:59:14 +07:00
8 changed files with 76 additions and 50 deletions

View File

@@ -6,7 +6,7 @@ const api = axios.create({
class Misc { class Misc {
async loadConfig() { async loadConfig() {
const response = await api.post('/config', {params: ['name', 'version', 'mode', 'maxUploadFileSize']}); const response = await api.post('/config', {params: ['name', 'version', 'mode', 'maxUploadFileSize', 'branch']});
return response.data; return response.data;
} }
} }

View File

@@ -210,7 +210,7 @@ class App extends Vue {
} }
//yandex-метрика для omnireader //yandex-метрика для omnireader
if (this.mode == 'omnireader' && !this.yaMetricsDone) { if (this.config.branch == 'production' && this.mode == 'omnireader' && !this.yaMetricsDone) {
(function(m,e,t,r,i,k,a){m[i]=m[i]||function(){(m[i].a=m[i].a||[]).push(arguments)}; (function(m,e,t,r,i,k,a){m[i]=m[i]||function(){(m[i].a=m[i].a||[]).push(arguments)};
m[i].l=1*new Date();k=e.createElement(t),a=e.getElementsByTagName(t)[0],k.async=1,k.src=r,a.parentNode.insertBefore(k,a)}) m[i].l=1*new Date();k=e.createElement(t),a=e.getElementsByTagName(t)[0],k.async=1,k.src=r,a.parentNode.insertBefore(k,a)})
(window, document, "script", "https://mc.yandex.ru/metrika/tag.js", "ym");// eslint-disable-line no-unexpected-multiline (window, document, "script", "https://mc.yandex.ru/metrika/tag.js", "ym");// eslint-disable-line no-unexpected-multiline

View File

@@ -126,8 +126,10 @@ class HistoryPage extends Vue {
updateTableData() { updateTableData() {
let result = []; let result = [];
for (let bookKey in bookManager.recent) { const sorted = bookManager.getSortedRecent();
const book = bookManager.recent[bookKey]; const len = (sorted.length < 100 ? sorted.length : 100);
for (let i = 0; i < len; i++) {
const book = sorted[i];
let d = new Date(); let d = new Date();
d.setTime(book.touchTime); d.setTime(book.touchTime);
const t = formatDate(d).split(' '); const t = formatDate(d).split(' ');

View File

@@ -569,7 +569,7 @@ class TextPage extends Vue {
} }
if (this.book && this.bookPos > 0 && this.bookPos >= this.parsed.textLength) { if (this.book && this.bookPos > 0 && this.bookPos >= this.parsed.textLength) {
this.doEnd(); this.doEnd(true);
return; return;
} }
@@ -591,7 +591,7 @@ class TextPage extends Vue {
this.debouncedDrawStatusBar(); this.debouncedDrawStatusBar();
if (this.book && this.linesDown && this.linesDown.length < this.pageLineCount) { if (this.book && this.linesDown && this.linesDown.length < this.pageLineCount) {
this.doEnd(); this.doEnd(true);
return; return;
} }
} }
@@ -822,7 +822,7 @@ class TextPage extends Vue {
this.bookPos = 0; this.bookPos = 0;
} }
doEnd() { doEnd(noAni) {
if (this.parsed.para.length && this.pageLineCount > 0) { if (this.parsed.para.length && this.pageLineCount > 0) {
let i = this.parsed.para.length - 1; let i = this.parsed.para.length - 1;
let lastPos = this.parsed.para[i].offset + this.parsed.para[i].length - 1; let lastPos = this.parsed.para[i].offset + this.parsed.para[i].length - 1;
@@ -830,7 +830,8 @@ class TextPage extends Vue {
if (lines) { if (lines) {
i = this.pageLineCount - 1; i = this.pageLineCount - 1;
i = (i > lines.length - 1 ? lines.length - 1 : i); i = (i > lines.length - 1 ? lines.length - 1 : i);
this.currentAnimation = this.pageChangeAnimation; if (!noAni)
this.currentAnimation = this.pageChangeAnimation;
this.pageChangeDirectionDown = true; this.pageChangeDirectionDown = true;
this.bookPos = lines[i].begin; this.bookPos = lines[i].begin;
} }

View File

@@ -22,7 +22,8 @@ class BookManager {
this.settings = settings; this.settings = settings;
this.books = {}; this.books = {};
this.recent = {}; this.recent = {};
this.recentChanged = true; this.recentChanged1 = true;
this.recentChanged2 = true;
let len = await bmMetaStore.length(); let len = await bmMetaStore.length();
for (let i = 0; i < len; i++) { for (let i = 0; i < len; i++) {
@@ -170,7 +171,8 @@ class BookManager {
await bmRecentStore.setItem(result.key, result); await bmRecentStore.setItem(result.key, result);
await this.cleanRecentBooks(); await this.cleanRecentBooks();
this.recentChanged = true; this.recentChanged1 = true;
this.recentChanged2 = true;
return result; return result;
} }
@@ -186,14 +188,15 @@ class BookManager {
await bmRecentStore.removeItem(value.key); await bmRecentStore.removeItem(value.key);
delete this.recent[value.key]; delete this.recent[value.key];
this.recentChanged = true; this.recentChanged1 = true;
this.recentChanged2 = true;
} }
async cleanRecentBooks() { async cleanRecentBooks() {
if (!this.recent) if (!this.recent)
await this.init(); await this.init();
if (Object.keys(this.recent).length > 100) { if (Object.keys(this.recent).length > 1000) {
let min = Date.now(); let min = Date.now();
let found = null; let found = null;
for (let key in this.recent) { for (let key in this.recent) {
@@ -212,7 +215,7 @@ class BookManager {
} }
mostRecentBook() { mostRecentBook() {
if (!this.recentChanged && this.mostRecentCached) { if (!this.recentChanged1 && this.mostRecentCached) {
return this.mostRecentCached; return this.mostRecentCached;
} }
@@ -226,10 +229,25 @@ class BookManager {
} }
} }
this.mostRecentCached = result; this.mostRecentCached = result;
this.recentChanged = false; this.recentChanged1 = false;
return result; return result;
} }
getSortedRecent() {
if (!this.recentChanged2 && this.sortedRecentCached) {
return this.sortedRecentCached;
}
let result = Object.values(this.recent);
result.sort((a, b) => b.touchTime - a.touchTime);
this.sortedRecentCached = result;
this.recentChanged2 = false;
return result;
}
} }
export default new BookManager(); export default new BookManager();

View File

@@ -1,6 +1,6 @@
{ {
"name": "Liberama", "name": "Liberama",
"version": "0.2.1", "version": "0.2.2",
"engines": { "engines": {
"node": ">=10.0.0" "node": ">=10.0.0"
}, },

View File

@@ -43,7 +43,7 @@ class BookConverter {
else { else {
//может это чистый текст? //может это чистый текст?
if (textUtils.checkIfText(data)) { if (textUtils.checkIfText(data)) {
await fs.writeFile(outputFile, this.convertHtml(data)); await fs.writeFile(outputFile, this.convertHtml(data, true));
return; return;
} }
@@ -167,7 +167,7 @@ class BookConverter {
titleInfo['book-title'] = title; titleInfo['book-title'] = title;
//подозрение на чистый текст, надо разбить на параграфы //подозрение на чистый текст, надо разбить на параграфы
if ((isText || pars.length < buf.length/2000) && spaceCounter.length) { if (isText || pars.length < buf.length/2000) {
let total = 0; let total = 0;
for (let i = 0; i < spaceCounter.length; i++) { for (let i = 0; i < spaceCounter.length; i++) {
total += (spaceCounter[i] ? spaceCounter[i] : 0); total += (spaceCounter[i] ? spaceCounter[i] : 0);
@@ -176,41 +176,37 @@ class BookConverter {
let i = spaceCounter.length - 1; let i = spaceCounter.length - 1;
while (i > 0 && (!spaceCounter[i] || spaceCounter[i] < total)) i--; while (i > 0 && (!spaceCounter[i] || spaceCounter[i] < total)) i--;
const parIndent = i; const parIndent = (i > 0 ? i : 0);
if (parIndent > 0) {//нашли отступ параграфа
let newPars = []; let newPars = [];
const newPar = () => { const newPar = () => {
newPars.push({_n: 'p', _t: ''}); newPars.push({_n: 'p', _t: ''});
}; };
const growPar = (text) => { const growPar = (text) => {
const l = newPars.length; const l = newPars.length;
if (l) { if (l) {
newPars[l - 1]._t += text; newPars[l - 1]._t += text;
}
} }
for (const par of pars) {
newPar();
const lines = par._t.split('\n');
for (const line of lines) {
const sp = line.split(' ');
let l = 0;
while (l < sp.length && sp[l].trim() == '') {
l++;
}
if (l >= parIndent)
newPar();
growPar(line.trim() + ' ');
}
}
body.section._a[0] = newPars;
} else {
body.section._a[0] = pars;
} }
for (const par of pars) {
newPar();
const lines = par._t.split('\n');
for (const line of lines) {
const sp = line.split(' ');
let l = 0;
while (l < sp.length && sp[l].trim() == '') {
l++;
}
if (l >= parIndent)
newPar();
growPar(line.trim() + ' ');
}
}
body.section._a[0] = newPars;
} else { } else {
body.section._a[0] = pars; body.section._a[0] = pars;
} }

View File

@@ -70,13 +70,22 @@ function getEncoding(buf) {
function checkIfText(buf) { function checkIfText(buf) {
let spaceCount = 0; let spaceCount = 0;
let crCount = 0;
let lfCount = 0;
for (let i = 0; i < buf.length; i++) { for (let i = 0; i < buf.length; i++) {
if (buf[i] == 32) if (buf[i] == 32)
spaceCount++; spaceCount++;
if (buf[i] == 13)
crCount++;
if (buf[i] == 10)
lfCount++;
} }
const freq = spaceCount/(buf.length + 1);
return (freq > 0.1); const spaceFreq = spaceCount/(buf.length + 1);
const crFreq = crCount/(buf.length + 1);
const lfFreq = lfCount/(buf.length + 1);
return (spaceFreq > 0.1 || crFreq > 0.03 || lfFreq > 0.03);
} }
module.exports = { module.exports = {