From 729cd2a3c05f6f7440263ae3a143bc972a924b62 Mon Sep 17 00:00:00 2001 From: zakius Date: Fri, 15 Feb 2019 22:01:48 +0100 Subject: [PATCH 001/965] add .gitignore --- .gitignore | 3 +++ 1 file changed, 3 insertions(+) create mode 100644 .gitignore diff --git a/.gitignore b/.gitignore new file mode 100644 index 00000000..f981491c --- /dev/null +++ b/.gitignore @@ -0,0 +1,3 @@ +node_modules/* +docs/* +.idea/* \ No newline at end of file From 9187d45bc1c02f47c284643ba4c9eaf63c99be6f Mon Sep 17 00:00:00 2001 From: zakius Date: Fri, 15 Feb 2019 22:05:06 +0100 Subject: [PATCH 002/965] Support scroll-clicking article titles to open them in background tab --- scripts/app/mixins/selectable.js | 352 ++++++++++++++++--------------- 1 file changed, 177 insertions(+), 175 deletions(-) diff --git a/scripts/app/mixins/selectable.js b/scripts/app/mixins/selectable.js index 02b534c2..bd63b026 100644 --- a/scripts/app/mixins/selectable.js +++ b/scripts/app/mixins/selectable.js @@ -1,176 +1,178 @@ -define(['jquery'], function($) { - -return { - selectedItems: [], - selectPivot: null, - selectFlag: false, - restartSelection: function() { - if (this.selectedItems.length) { - this.selectedItems = []; - this.$el.find('.selected').removeClass('selected'); - this.$el.find('.last-selected').removeClass('last-selected'); - } - this.selectFirst(); - }, - selectFirst: function() { - var first = $('.' + this.itemClass + ':not(.invisible)').get(0); - if (first) this.select(first.view); - }, - selectNext: function(e) { - e = e || {}; - - var q = e.selectUnread ? '.unread:not(.invisible)' : '.' + this.itemClass + ':not(.invisible)'; - var next; - if (e.selectUnread && this.selectPivot) { - next = this.selectPivot.el.nextElementSibling; - } else { - next = this.$el.find('.last-selected'); - if (next.length) { - next = next.get(0).nextElementSibling; - } else { - next = this.el.firstElementChild; - } - } - while (next && !next.matchesSelector(q)) { - next = next.nextElementSibling; - } - - if (!next && !e.shiftKey && !e.ctrlKey && bg.settings.get('circularNavigation')) { - next = this.el.querySelector(q); - if (e.currentIsRemoved && next && this.$el.find('.last-selected').get(0) == next) { - next = []; - } - } - if (next && next.view) { - this.select(next.view, e, true); - if (!this.inView(next)) { - next.scrollIntoView(false); - } - } else if (e.currentIsRemoved) { - app.trigger('no-items:' + this.el.id); - } - - }, - selectPrev: function(e) { - e = e || {}; - var q = e.selectUnread ? '.unread:not(.invisible)' : '.' + this.itemClass + ':not(.invisible)'; - var prev; - if (e.selectUnread && this.selectPivot) { - prev = this.selectPivot.el.previousElementSibling; - } else { - prev = this.$el.find('.last-selected'); - if (prev.length) { - prev = prev.get(0).previousElementSibling; - } else { - prev = this.el.lastElementChild; - } - } - while (prev && !prev.matchesSelector(q)) { - prev = prev.previousElementSibling; - } - - if (!prev && !e.shiftKey && !e.ctrlKey && bg.settings.get('circularNavigation')) { - prev = this.$el.find(q + ':last').get(0); - if (e.currentIsRemoved && prev && this.$el.find('.last-selected').get(0) == prev) { - prev = []; - } - } - if (prev && prev.view) { - this.select(prev.view, e, true); - if (!this.inView(prev)) { - prev.scrollIntoView(true); - } - } else if (e.currentIsRemoved) { - app.trigger('no-items:' + this.el.id); - } - }, - select: function(view, e, forceSelect) { - e = e || {}; - var that = this; - if ( (e.shiftKey != true && e.ctrlKey != true) || (e.shiftKey && !this.selectPivot)) { - this.selectedItems = []; - this.selectPivot = view; - this.$el.find('.selected').removeClass('selected'); - - - if (!window || !window.frames) { - bg.logs.add({ message: 'Event duplication bug! Clearing events now...' }); - bg.console.log('Event duplication bug! Clearing events now...'); - bg.sources.trigger('clear-events', -1); - return; - } - - setTimeout(function() { - this.trigger('pick', view, e); - }.bind(this), 0); - - } else if (e.shiftKey && this.selectPivot) { - this.$el.find('.selected').removeClass('selected'); - this.selectedItems = [this.selectPivot]; - this.selectedItems[0].$el.addClass('selected'); - - if (this.selectedItems[0] != view) { - if (this.selectedItems[0].$el.index() < view.$el.index() ) { - this.selectedItems[0].$el.nextUntil(view.$el).not('.invisible,.date-group').each(function(i, el) { - $(el).addClass('selected'); - that.selectedItems.push(el.view); - }); - } else { - view.$el.nextUntil(this.selectedItems[0].$el).not('.invisible,.date-group').each(function(i, el) { - $(el).addClass('selected'); - that.selectedItems.push(el.view); - }); - } - - } - - if (forceSelect === true) { - setTimeout(function() { - this.trigger('pick', view, e); - }.bind(this), 0); - } - - } else if (e.ctrlKey && view.$el.hasClass('selected')) { - view.$el.removeClass('selected'); - view.$el.removeClass('last-selected'); - this.selectPivot = null; - this.selectedItems.splice(this.selectedItems.indexOf(view), 1); - return; - } else if (e.ctrlKey) { - this.selectPivot = view; - } - - this.$el.find('.last-selected').removeClass('last-selected'); - if (this.selectedItems[0] != view) { - this.selectedItems.push(view); - view.$el.addClass('selected'); - } - view.$el.addClass('last-selected'); - }, - inView: function(cel) { - var $cel = $(cel); - if ($cel.position().top - this.$el.offset().top < 0 || $cel.position().top + cel.offsetHeight >= this.el.offsetHeight) { - return false; - } - return true; - }, - handleSelectableMouseDown: function(e) { - //e.currentTarget.view.handleMouseDown(e); - var item = e.currentTarget.view; - if (this.selectedItems.length > 1 && item.$el.hasClass('selected') && !e.ctrlKey && !e.shiftKey) { - this.selectFlag = true; - return; - } - // used to be just { shiftKey: e.shiftKey, ctrlKey: e.ctrlKey } instead of 'e' - this.select(item, e); - }, - handleSelectableMouseUp: function(e) { - var item = e.currentTarget.view; - if (e.which == 1 && this.selectedItems.length > 1 && this.selectFlag) { - this.select(item, e); - this.selectFlag = false; - } - } - -}; +define(['jquery'], function($) { + +return { + selectedItems: [], + selectPivot: null, + selectFlag: false, + restartSelection: function() { + if (this.selectedItems.length) { + this.selectedItems = []; + this.$el.find('.selected').removeClass('selected'); + this.$el.find('.last-selected').removeClass('last-selected'); + } + this.selectFirst(); + }, + selectFirst: function() { + var first = $('.' + this.itemClass + ':not(.invisible)').get(0); + if (first) this.select(first.view); + }, + selectNext: function(e) { + e = e || {}; + + var q = e.selectUnread ? '.unread:not(.invisible)' : '.' + this.itemClass + ':not(.invisible)'; + var next; + if (e.selectUnread && this.selectPivot) { + next = this.selectPivot.el.nextElementSibling; + } else { + next = this.$el.find('.last-selected'); + if (next.length) { + next = next.get(0).nextElementSibling; + } else { + next = this.el.firstElementChild; + } + } + while (next && !next.matchesSelector(q)) { + next = next.nextElementSibling; + } + + if (!next && !e.shiftKey && !e.ctrlKey && bg.settings.get('circularNavigation')) { + next = this.el.querySelector(q); + if (e.currentIsRemoved && next && this.$el.find('.last-selected').get(0) == next) { + next = []; + } + } + if (next && next.view) { + this.select(next.view, e, true); + if (!this.inView(next)) { + next.scrollIntoView(false); + } + } else if (e.currentIsRemoved) { + app.trigger('no-items:' + this.el.id); + } + + }, + selectPrev: function(e) { + e = e || {}; + var q = e.selectUnread ? '.unread:not(.invisible)' : '.' + this.itemClass + ':not(.invisible)'; + var prev; + if (e.selectUnread && this.selectPivot) { + prev = this.selectPivot.el.previousElementSibling; + } else { + prev = this.$el.find('.last-selected'); + if (prev.length) { + prev = prev.get(0).previousElementSibling; + } else { + prev = this.el.lastElementChild; + } + } + while (prev && !prev.matchesSelector(q)) { + prev = prev.previousElementSibling; + } + + if (!prev && !e.shiftKey && !e.ctrlKey && bg.settings.get('circularNavigation')) { + prev = this.$el.find(q + ':last').get(0); + if (e.currentIsRemoved && prev && this.$el.find('.last-selected').get(0) == prev) { + prev = []; + } + } + if (prev && prev.view) { + this.select(prev.view, e, true); + if (!this.inView(prev)) { + prev.scrollIntoView(true); + } + } else if (e.currentIsRemoved) { + app.trigger('no-items:' + this.el.id); + } + }, + select: function(view, e, forceSelect) { + e = e || {}; + var that = this; + if ( (e.shiftKey != true && e.ctrlKey != true) || (e.shiftKey && !this.selectPivot)) { + this.selectedItems = []; + this.selectPivot = view; + this.$el.find('.selected').removeClass('selected'); + + + if (!window || !window.frames) { + bg.logs.add({ message: 'Event duplication bug! Clearing events now...' }); + bg.console.log('Event duplication bug! Clearing events now...'); + bg.sources.trigger('clear-events', -1); + return; + } + + setTimeout(function() { + this.trigger('pick', view, e); + }.bind(this), 0); + + } else if (e.shiftKey && this.selectPivot) { + this.$el.find('.selected').removeClass('selected'); + this.selectedItems = [this.selectPivot]; + this.selectedItems[0].$el.addClass('selected'); + + if (this.selectedItems[0] != view) { + if (this.selectedItems[0].$el.index() < view.$el.index() ) { + this.selectedItems[0].$el.nextUntil(view.$el).not('.invisible,.date-group').each(function(i, el) { + $(el).addClass('selected'); + that.selectedItems.push(el.view); + }); + } else { + view.$el.nextUntil(this.selectedItems[0].$el).not('.invisible,.date-group').each(function(i, el) { + $(el).addClass('selected'); + that.selectedItems.push(el.view); + }); + } + + } + + if (forceSelect === true) { + setTimeout(function() { + this.trigger('pick', view, e); + }.bind(this), 0); + } + + } else if (e.ctrlKey && view.$el.hasClass('selected')) { + view.$el.removeClass('selected'); + view.$el.removeClass('last-selected'); + this.selectPivot = null; + this.selectedItems.splice(this.selectedItems.indexOf(view), 1); + return; + } else if (e.ctrlKey) { + this.selectPivot = view; + } + + this.$el.find('.last-selected').removeClass('last-selected'); + if (this.selectedItems[0] != view) { + this.selectedItems.push(view); + view.$el.addClass('selected'); + } + view.$el.addClass('last-selected'); + }, + inView: function(cel) { + var $cel = $(cel); + if ($cel.position().top - this.$el.offset().top < 0 || $cel.position().top + cel.offsetHeight >= this.el.offsetHeight) { + return false; + } + return true; + }, + handleSelectableMouseDown: function(e) { + if(e.which === 2){ + return browser.tabs.create({url: e.currentTarget.view.model.attributes.url, active: false}); + } + var item = e.currentTarget.view; + if (this.selectedItems.length > 1 && item.$el.hasClass('selected') && !e.ctrlKey && !e.shiftKey) { + this.selectFlag = true; + return; + } + // used to be just { shiftKey: e.shiftKey, ctrlKey: e.ctrlKey } instead of 'e' + this.select(item, e); + }, + handleSelectableMouseUp: function(e) { + var item = e.currentTarget.view; + if (e.which == 1 && this.selectedItems.length > 1 && this.selectFlag) { + this.select(item, e); + this.selectFlag = false; + } + } + +}; }); \ No newline at end of file From d2c44a33f629caea04ca43951371585a1e942091 Mon Sep 17 00:00:00 2001 From: zakius Date: Fri, 15 Feb 2019 22:07:03 +0100 Subject: [PATCH 003/965] Update manifest.json --- manifest.json | 50 +++++++++++++++++++++++++++++++++++++------------- 1 file changed, 37 insertions(+), 13 deletions(-) diff --git a/manifest.json b/manifest.json index 14a2fa92..e80f2721 100644 --- a/manifest.json +++ b/manifest.json @@ -1,17 +1,34 @@ { "name": "Smart RSS", "developer": { - "name": "BS-Harou (Martin Kadlec)", - "url": "http://blog.martinkadlec.eu/" + "name": "zakius", + "url": "" }, - "description": "RSS Reader for Opera 15+!", + "description": "RSS Reader", "manifest_version": 2, "version": "2.0", "background": { "page": "index.html" }, - "web_accessible_resources": ["libs/jquery.min.js", "libs/underscore.min.js", "libs/backbone.min.js", "libs/backbone.indexDB.js", "images/icon16_v2.png"], - "permissions": ["https://*/*", "storage", "unlimitedStorage", "alarms", "tabs", "contextMenus", "http://*/*"], + "web_accessible_resources": [ + "libs/jquery.min.js", + "libs/underscore.min.js", + "libs/backbone.min.js", + "libs/backbone.indexDB.js", + "images/icon16_v2.png" + ], + "permissions": [ + "https://*/*", + "http://*/*", + "storage", + "unlimitedStorage", + "alarms", + "tabs", + "contextMenus", + "webRequest", + "webRequestBlocking", + "" + ], "content_security_policy": "script-src 'self' 'unsafe-eval' https://cdnjs.cloudflare.com/ajax/libs/mocha/ https://raw.github.com/chaijs/chai/master/; object-src 'unsafe-eval';", "browser_action": { "default_title": "Smart RSS", @@ -19,16 +36,18 @@ "19": "images/reload_anim_1.png" } }, - "options_page": "options.html", + "options_ui": { + "page": "options.html" + }, "icons": { "19": "images/icon19-arrow-orange.png", - "48": "images/48-inverted-round.png", - "64": "images/64-inverted-round.png", - "96": "images/96-inverted-round.png", - "128": "images/128-inverted-round.png" - }, - "commands": { - "_execute_browser_action": { + "48": "images/48-inverted-round.png", + "64": "images/64-inverted-round.png", + "96": "images/96-inverted-round.png", + "128": "images/128-inverted-round.png" + }, + "commands": { + "_execute_browser_action": { "suggested_key": { "windows": "Ctrl+Shift+R", "mac": "Command+Shift+R", @@ -36,5 +55,10 @@ "linux": "Ctrl+Shift+R" } } + }, + "applications": { + "gecko": { + "id": "smart-rss@mozilla.firefox" + } } } \ No newline at end of file From e11828d1d5913f6590608b58b744772b3db52f37 Mon Sep 17 00:00:00 2001 From: zakius Date: Fri, 15 Feb 2019 22:09:34 +0100 Subject: [PATCH 004/965] update --- scripts/main.js | 140 ++++++++++++++++++++++++------------------------ 1 file changed, 70 insertions(+), 70 deletions(-) diff --git a/scripts/main.js b/scripts/main.js index ad2b1d3f..8efce3b2 100644 --- a/scripts/main.js +++ b/scripts/main.js @@ -1,71 +1,71 @@ -require.config({ - - baseUrl: 'scripts/app', - waitSeconds: 0, - - paths: { - jquery: '../libs/jquery.min', - underscore: '../libs/underscore.min', - backbone: '../libs/backbone.min', - text: '../text', - domReady: '../domReady', - //mocha: '../../node_modules/mocha/mocha', - mocha: 'https://cdnjs.cloudflare.com/ajax/libs/mocha/1.12.1/mocha.min', - mochacss: 'https://cdnjs.cloudflare.com/ajax/libs/mocha/1.12.1/mocha.min.css?nojs', - chai: 'https://raw.github.com/chaijs/chai/master/chai' - }, - - shim: { - jquery: { - exports: '$' - }, - backbone: { - deps: ['underscore', 'jquery'], - exports: 'Backbone' - }, - underscore: { - exports: '_' - }, - mocha: { - exports: 'mocha' - } - } -}); - -var tabID = -1; - -chrome.runtime.getBackgroundPage(function(bg) { - /** - * Setup work, that has to be done before any dependencies get executed - */ - window.bg = bg; - - chrome.extension.sendMessage({ action: 'get-tab-id'}, function(response) { - if (response.action == 'response-tab-id') { - tabID = response.value; - } - }); - chrome.runtime.connect(); - - checkState(); -}); - -/** - * This is retarded solution. It is too late to think of something else. - * Broadcasting message from bgprocess might help. - */ -function checkState() { - if ('appStarted' in bg) { - init(); - } else { - setTimeout(checkState, 100); - } -} - -function init() { - bg.appStarted.always(function() { - requirejs(['app'], function(app) { - app.start(); - }); - }); +require.config({ + + baseUrl: 'scripts/app', + waitSeconds: 0, + + paths: { + jquery: '../libs/jquery.min', + underscore: '../libs/underscore.min', + backbone: '../libs/backbone.min', + text: '../text', + domReady: '../domReady', + //mocha: '../../node_modules/mocha/mocha', + mocha: 'https://cdnjs.cloudflare.com/ajax/libs/mocha/1.12.1/mocha.min', + mochacss: 'https://cdnjs.cloudflare.com/ajax/libs/mocha/1.12.1/mocha.min.css?nojs', + chai: 'https://raw.github.com/chaijs/chai/master/chai' + }, + + shim: { + jquery: { + exports: '$' + }, + backbone: { + deps: ['underscore', 'jquery'], + exports: 'Backbone' + }, + underscore: { + exports: '_' + }, + mocha: { + exports: 'mocha' + } + } +}); + +var tabID = -1; + +chrome.runtime.getBackgroundPage(function(bg) { + /** + * Setup work, that has to be done before any dependencies get executed + */ + window.bg = bg; + + chrome.runtime.sendMessage({ action: 'get-tab-id'}, function(response) { + if (response.action == 'response-tab-id') { + tabID = response.value; + } + }); + chrome.runtime.connect(); + + checkState(); +}); + +/** + * This is retarded solution. It is too late to think of something else. + * Broadcasting message from bgprocess might help. + */ +function checkState() { + if ('appStarted' in bg) { + init(); + } else { + setTimeout(checkState, 100); + } +} + +function init() { + bg.appStarted.always(function() { + requirejs(['app'], function(app) { + app.start(); + }); + }); } \ No newline at end of file From f30fee608ddd6a2b61668b3ceefbefc900989ee4 Mon Sep 17 00:00:00 2001 From: zakius Date: Fri, 15 Feb 2019 22:12:33 +0100 Subject: [PATCH 005/965] remove webkit prefixes (not needed anymore) --- styles/global.styl | 662 ++++++++++++++++++++++----------------------- 1 file changed, 331 insertions(+), 331 deletions(-) diff --git a/styles/global.styl b/styles/global.styl index 5c2473cb..a5f5a7f0 100644 --- a/styles/global.styl +++ b/styles/global.styl @@ -1,332 +1,332 @@ -@import nib - -vendor-prefixes = webkit official -flex-version = flex -support-for-ie = false - -* { - box-sizing: border-box; -} - -body.loading { - background: url('/images/tabloading.gif') no-repeat center center; -} - -body.loading * { - visibility: hidden; -} - -html, body { - height: 100%; - max-height: 100%; - width: 100%; - max-width: 100%; -} - -body { - margin: 0; - font-size: 100%; - font-family: sans-serif; -} - -.visible { - display: block !important; -} - -.invisible { - display: none !important; -} - -.hidden { - display: none !important; -} - -label { - font-family: sans-serif; - font-size: 0.75rem; - font-weight: bold; -} - - - -/** - * Toolbars & Toolbar Buttons - */ -.toolbar { - display: flex; - flex: 0 0 auto; - height: 32px; - background: #f2f2f2; - border-bottom: 1px solid #a6a6a6; - align-items: stretch; - justify-content: flex-start; - padding: 3px 6px; - user-select: none; - overflow: hidden; -} -.dynamic-space { - flex: 1 1 auto; - text-align: center; - margin-right: 3px; -} -.button { - flex: 0 0 28px; - overflow: hidden; - border-radius: 3px; - margin-right: 3px; - border: 1px solid transparent; - text-align: center; - line-height: 21px; - cursor: pointer; - /*transition: border-color 0.1s;*/ -} -.button:hover, .button:active { - border-color: #c4c4c4; -} -.button:active { - box-shadow: inset 0 1px 3px #bbb; -} - -[data-action="articles:undelete"] { - background: url('/images/delete_selected.png') no-repeat center center; - /*display: none;*/ -} - -#context-undelete { - display: none; -} - -input[type=search] { - max-width: 160px; - width: 160px; - /*margin-left: auto; - margin-right: 0;*/ - margin-top: 0px; - padding: 2px 5px; - margin-bottom: 0px; - font-size: 0.8rem; - border: 1px solid #a6a6a6; - border-radius: 5px; -} -input[type=search]:not(:focus):not(:valid) { - background: url('/images/search.png') no-repeat right center white; -} - - -/** - * Context Menus & Context Menu Items - */ - -.context-menu { - min-width: 150px; - max-width: 250px; - border: 1px solid rgb(160, 160, 160); - /*background: linear-gradient(to right, rgb(240, 240, 240) 27px, rgb(174, 207, 247) 27px, rgb(240, 240, 240) 28px);*/ - background: url('/images/context-border.png') repeat-y 27px top rgb(240, 240, 240); - position: absolute; - top: 300px; - left: 10px; - overflow: hidden; - z-index: 3; - padding: 2px; - box-shadow: 2px 2px 2px #999; - user-select: none; - cursor: default; - display: none; -} - -.context-menu-item { - font-size: 0.75rem; - font-family: sans-serif; - white-space: nowrap; - overflow: hidden; - text-overflow: ellipsis; - cursor: pointer; - padding: 4px 3px 4px 30px; - border: 1px solid transparent; -} - -.context-menu-item:hover { - border-radius: 3px; - border-color: rgb(174, 207, 247); -} - -/** - * Overlays - */ - -.overlay { - display: none; - width: 20rem; - min-height: 50px; - border: 1px solid rgb(160, 160, 160); - background: rgb(240, 240, 240); - position: absolute; - top: 30px; - right: 5px; - overflow: hidden; - z-index: 2; - padding: 5px; - border-radius: 5px; - box-shadow: 2px 2px 2px #999; -} - -.overlay label { - padding: 0.3rem 0 0.2rem 0; - display: block; -} - -.half-size { - width: 50% !important; - margin: 0; - box-sizing: border-box; -} - -/** - * Main regions - */ - -.regions { - display: flex; - flex: 1 1 auto; -} - -body > .regions { - min-height: 100%; - min-width: 100%; -} - -.regions.vertical { - flex-flow: column; -} - -.region { - min-width: 100px; - min-height: 180px; - border-right: 1px solid #a6a6a6; - display: flex; - flex-flow: column; - align-items: stretch; -} - -.vertical .region { - border-right: none; - border-bottom: 1px solid #a6a6a6; -} - -.thick-borders .region { - border-width: 5px; - - border-image: linear-gradient(to right, #767676 0%, #eee 20%, #f2f2f2 80%, #767676 100%) 0 100% 0 0/0 5px 0 0 stretch; -} - -.thick-borders .vertical .region { - border-image: linear-gradient(to bottom, #767676 0%, #eee 20%, #f2f2f2 80%, #767676 100%) 0 0 100% 0/0 0 5px 0 stretch; -} - -.region:last-child { - border: none !important; - border-image: none !important; -} - -#region-feeds { - flex: 0 0 300px; -} - -#region-articles { - flex: 0 0 400px; -} - -#region-content { - flex: 1 1 auto; -} - -.region:focus { - outline-width: 0; -} - -.resizer { - position: absolute; - left: 0; - top: 0; - user-select: none; -} - -#panel-toggle { - user-select: none; - display: none; - flex: 0 0 4px; - background: url('/images/toggle_left.png') no-repeat center center #d3daed; -} -#panel-toggle:not(.toggled) { - background-image: url('/images/toggle_right.png'); -} - -/** - * Report - */ -.report-overlay - position: fixed - top: 0 - left: 0 - width: 100% - height: 100% - background: rgba(0,0,0,0.5) - z-index: 10; - -.report-window - position: fixed - top: 50% - left: 50% - width: 30rem - height: 26rem - margin-top: -13rem - margin-left: -15rem - background: #fff - box-shadow: 0 0 6px black - padding: 1rem - - strong - text-transform: uppercase - font-size: 1.2rem - font-weight: normal - display: block - text-align: center - padding: 0.3rem 0 - border-bottom: 1px solid #ccc - - - label - display: inline-block - margin-top: 0.5rem - vertical-align: baseline - - - textarea, input[type=email], input[type=text] - width: 100% - resize: none - - input[type=checkbox] - vertical-align: bottom - - textarea - height: 11rem; - - .report-buttons, .report-message - margin-top: 1.5rem - text-align: center - font-size: 0.9rem; - - .report-buttons - line-height: 2rem - - input[type=submit], input[type=button] - padding: 0.3rem 1rem - -@media (max-height: 26rem) { - .report-window { top: 0 !important; margin-top: 0 !important; } -} - -@media (max-width: 30rem) { - .report-window { left: 0 !important; margin-left: 0 !important; } +@import nib + +vendor-prefixes = official +flex-version = flex +support-for-ie = false + +* { + box-sizing: border-box; +} + +body.loading { + background: url('/images/tabloading.gif') no-repeat center center; +} + +body.loading * { + visibility: hidden; +} + +html, body { + height: 100%; + max-height: 100%; + width: 100%; + max-width: 100%; +} + +body { + margin: 0; + font-size: 100%; + font-family: sans-serif; +} + +.visible { + display: block !important; +} + +.invisible { + display: none !important; +} + +.hidden { + display: none !important; +} + +label { + font-family: sans-serif; + font-size: 0.75rem; + font-weight: bold; +} + + + +/** + * Toolbars & Toolbar Buttons + */ +.toolbar { + display: flex; + flex: 0 0 auto; + height: 32px; + background: #f2f2f2; + border-bottom: 1px solid #a6a6a6; + align-items: stretch; + justify-content: flex-start; + padding: 3px 6px; + user-select: none; + overflow: hidden; +} +.dynamic-space { + flex: 1 1 auto; + text-align: center; + margin-right: 3px; +} +.button { + flex: 0 0 28px; + overflow: hidden; + border-radius: 3px; + margin-right: 3px; + border: 1px solid transparent; + text-align: center; + line-height: 21px; + cursor: pointer; + /*transition: border-color 0.1s;*/ +} +.button:hover, .button:active { + border-color: #c4c4c4; +} +.button:active { + box-shadow: inset 0 1px 3px #bbb; +} + +[data-action="articles:undelete"] { + background: url('/images/delete_selected.png') no-repeat center center; + /*display: none;*/ +} + +#context-undelete { + display: none; +} + +input[type=search] { + max-width: 160px; + width: 160px; + /*margin-left: auto; + margin-right: 0;*/ + margin-top: 0px; + padding: 2px 5px; + margin-bottom: 0px; + font-size: 0.8rem; + border: 1px solid #a6a6a6; + border-radius: 5px; +} +input[type=search]:not(:focus):not(:valid) { + background: url('/images/search.png') no-repeat right center white; +} + + +/** + * Context Menus & Context Menu Items + */ + +.context-menu { + min-width: 150px; + max-width: 250px; + border: 1px solid rgb(160, 160, 160); + /*background: linear-gradient(to right, rgb(240, 240, 240) 27px, rgb(174, 207, 247) 27px, rgb(240, 240, 240) 28px);*/ + background: url('/images/context-border.png') repeat-y 27px top rgb(240, 240, 240); + position: absolute; + top: 300px; + left: 10px; + overflow: hidden; + z-index: 3; + padding: 2px; + box-shadow: 2px 2px 2px #999; + user-select: none; + cursor: default; + display: none; +} + +.context-menu-item { + font-size: 0.75rem; + font-family: sans-serif; + white-space: nowrap; + overflow: hidden; + text-overflow: ellipsis; + cursor: pointer; + padding: 4px 3px 4px 30px; + border: 1px solid transparent; +} + +.context-menu-item:hover { + border-radius: 3px; + border-color: rgb(174, 207, 247); +} + +/** + * Overlays + */ + +.overlay { + display: none; + width: 20rem; + min-height: 50px; + border: 1px solid rgb(160, 160, 160); + background: rgb(240, 240, 240); + position: absolute; + top: 30px; + right: 5px; + overflow: hidden; + z-index: 2; + padding: 5px; + border-radius: 5px; + box-shadow: 2px 2px 2px #999; +} + +.overlay label { + padding: 0.3rem 0 0.2rem 0; + display: block; +} + +.half-size { + width: 50% !important; + margin: 0; + box-sizing: border-box; +} + +/** + * Main regions + */ + +.regions { + display: flex; + flex: 1 1 auto; +} + +body > .regions { + min-height: 100%; + min-width: 100%; +} + +.regions.vertical { + flex-flow: column; +} + +.region { + min-width: 100px; + min-height: 180px; + border-right: 1px solid #a6a6a6; + display: flex; + flex-flow: column; + align-items: stretch; +} + +.vertical .region { + border-right: none; + border-bottom: 1px solid #a6a6a6; +} + +.thick-borders .region { + border-width: 5px; + + border-image: linear-gradient(to right, #767676 0%, #eee 20%, #f2f2f2 80%, #767676 100%) 0 100% 0 0/0 5px 0 0 stretch; +} + +.thick-borders .vertical .region { + border-image: linear-gradient(to bottom, #767676 0%, #eee 20%, #f2f2f2 80%, #767676 100%) 0 0 100% 0/0 0 5px 0 stretch; +} + +.region:last-child { + border: none !important; + border-image: none !important; +} + +#region-feeds { + flex: 0 0 300px; +} + +#region-articles { + flex: 0 0 400px; +} + +#region-content { + flex: 1 1 auto; +} + +.region:focus { + outline-width: 0; +} + +.resizer { + position: absolute; + left: 0; + top: 0; + user-select: none; +} + +#panel-toggle { + user-select: none; + display: none; + flex: 0 0 4px; + background: url('/images/toggle_left.png') no-repeat center center #d3daed; +} +#panel-toggle:not(.toggled) { + background-image: url('/images/toggle_right.png'); +} + +/** + * Report + */ +.report-overlay + position: fixed + top: 0 + left: 0 + width: 100% + height: 100% + background: rgba(0,0,0,0.5) + z-index: 10; + +.report-window + position: fixed + top: 50% + left: 50% + width: 30rem + height: 26rem + margin-top: -13rem + margin-left: -15rem + background: #fff + box-shadow: 0 0 6px black + padding: 1rem + + strong + text-transform: uppercase + font-size: 1.2rem + font-weight: normal + display: block + text-align: center + padding: 0.3rem 0 + border-bottom: 1px solid #ccc + + + label + display: inline-block + margin-top: 0.5rem + vertical-align: baseline + + + textarea, input[type=email], input[type=text] + width: 100% + resize: none + + input[type=checkbox] + vertical-align: bottom + + textarea + height: 11rem; + + .report-buttons, .report-message + margin-top: 1.5rem + text-align: center + font-size: 0.9rem; + + .report-buttons + line-height: 2rem + + input[type=submit], input[type=button] + padding: 0.3rem 1rem + +@media (max-height: 26rem) { + .report-window { top: 0 !important; margin-top: 0 !important; } +} + +@media (max-width: 30rem) { + .report-window { left: 0 !important; margin-left: 0 !important; } } \ No newline at end of file From 2be17db19803e8589893fac897d3ec62e420c3d8 Mon Sep 17 00:00:00 2001 From: zakius Date: Fri, 15 Feb 2019 22:13:48 +0100 Subject: [PATCH 006/965] fix wrong scrolling behavior --- styles/global.styl | 5 +---- 1 file changed, 1 insertion(+), 4 deletions(-) diff --git a/styles/global.styl b/styles/global.styl index a5f5a7f0..07aa2857 100644 --- a/styles/global.styl +++ b/styles/global.styl @@ -189,12 +189,9 @@ input[type=search]:not(:focus):not(:valid) { .regions { display: flex; flex: 1 1 auto; + max-height: 100%; } -body > .regions { - min-height: 100%; - min-width: 100%; -} .regions.vertical { flex-flow: column; From f19f4b4323f07fcf820a9294827acc08c919ced0 Mon Sep 17 00:00:00 2001 From: zakius Date: Fri, 15 Feb 2019 22:16:58 +0100 Subject: [PATCH 007/965] remove compiled styles from repository --- .gitignore | 3 +- styles/main-compiled.css | 861 --------------------------------------- 2 files changed, 2 insertions(+), 862 deletions(-) delete mode 100644 styles/main-compiled.css diff --git a/.gitignore b/.gitignore index f981491c..3802d8d0 100644 --- a/.gitignore +++ b/.gitignore @@ -1,3 +1,4 @@ node_modules/* docs/* -.idea/* \ No newline at end of file +.idea/* +styles/main-compiled.css \ No newline at end of file diff --git a/styles/main-compiled.css b/styles/main-compiled.css deleted file mode 100644 index 89285266..00000000 --- a/styles/main-compiled.css +++ /dev/null @@ -1,861 +0,0 @@ -* { - -webkit-box-sizing: border-box; - box-sizing: border-box; -} -body.loading { - background: url("/images/tabloading.gif") no-repeat center center; -} -body.loading * { - visibility: hidden; -} -html, -body { - height: 100%; - max-height: 100%; - width: 100%; - max-width: 100%; -} -body { - margin: 0; - font-size: 100%; - font-family: sans-serif; -} -.visible { - display: block !important; -} -.invisible { - display: none !important; -} -.hidden { - display: none !important; -} -label { - font-family: sans-serif; - font-size: 0.75rem; - font-weight: bold; -} -/** - * Toolbars & Toolbar Buttons - */ -.toolbar { - display: -webkit-flex; - display: flex; - -webkit-flex: 0 0 auto; - flex: 0 0 auto; - height: 32px; - background: #f2f2f2; - border-bottom: 1px solid #a6a6a6; - -webkit-align-items: stretch; - align-items: stretch; - -webkit-justify-content: flex-start; - justify-content: flex-start; - padding: 3px 6px; - -webkit-user-select: none; - user-select: none; - overflow: hidden; -} -.dynamic-space { - -webkit-flex: 1 1 auto; - flex: 1 1 auto; - text-align: center; - margin-right: 3px; -} -.button { - -webkit-flex: 0 0 28px; - flex: 0 0 28px; - overflow: hidden; - -webkit-border-radius: 3px; - border-radius: 3px; - margin-right: 3px; - border: 1px solid transparent; - text-align: center; - line-height: 21px; - cursor: pointer; -/*transition: border-color 0.1s;*/ -} -.button:hover, -.button:active { - border-color: #c4c4c4; -} -.button:active { - -webkit-box-shadow: inset 0 1px 3px #bbb; - box-shadow: inset 0 1px 3px #bbb; -} -[data-action="articles:undelete"] { - background: url("/images/delete_selected.png") no-repeat center center; -/*display: none;*/ -} -#context-undelete { - display: none; -} -input[type=search] { - max-width: 160px; - width: 160px; -/*margin-left: auto; - margin-right: 0;*/ - margin-top: 0px; - padding: 2px 5px; - margin-bottom: 0px; - font-size: 0.8rem; - border: 1px solid #a6a6a6; - -webkit-border-radius: 5px; - border-radius: 5px; -} -input[type=search]:not(:focus):not(:valid) { - background: url("/images/search.png") no-repeat right center #fff; -} -/** - * Context Menus & Context Menu Items - */ -.context-menu { - min-width: 150px; - max-width: 250px; - border: 1px solid #a0a0a0; -/*background: linear-gradient(to right, rgb(240, 240, 240) 27px, rgb(174, 207, 247) 27px, rgb(240, 240, 240) 28px);*/ - background: url("/images/context-border.png") repeat-y 27px top #f0f0f0; - position: absolute; - top: 300px; - left: 10px; - overflow: hidden; - z-index: 3; - padding: 2px; - -webkit-box-shadow: 2px 2px 2px #999; - box-shadow: 2px 2px 2px #999; - -webkit-user-select: none; - user-select: none; - cursor: default; - display: none; -} -.context-menu-item { - font-size: 0.75rem; - font-family: sans-serif; - white-space: nowrap; - overflow: hidden; - text-overflow: ellipsis; - cursor: pointer; - padding: 4px 3px 4px 30px; - border: 1px solid transparent; -} -.context-menu-item:hover { - -webkit-border-radius: 3px; - border-radius: 3px; - border-color: #aecff7; -} -/** - * Overlays - */ -.overlay { - display: none; - width: 20rem; - min-height: 50px; - border: 1px solid #a0a0a0; - background: #f0f0f0; - position: absolute; - top: 30px; - right: 5px; - overflow: hidden; - z-index: 2; - padding: 5px; - -webkit-border-radius: 5px; - border-radius: 5px; - -webkit-box-shadow: 2px 2px 2px #999; - box-shadow: 2px 2px 2px #999; -} -.overlay label { - padding: 0.3rem 0 0.2rem 0; - display: block; -} -.half-size { - width: 50% !important; - margin: 0; - -webkit-box-sizing: border-box; - box-sizing: border-box; -} -/** - * Main regions - */ -.regions { - display: -webkit-flex; - display: flex; - -webkit-flex: 1 1 auto; - flex: 1 1 auto; -} -body > .regions { - min-height: 100%; - min-width: 100%; -} -.regions.vertical { - -webkit-flex-flow: column; - flex-flow: column; -} -.region { - min-width: 100px; - min-height: 180px; - border-right: 1px solid #a6a6a6; - display: -webkit-flex; - display: flex; - -webkit-flex-flow: column; - flex-flow: column; - -webkit-align-items: stretch; - align-items: stretch; -} -.vertical .region { - border-right: none; - border-bottom: 1px solid #a6a6a6; -} -.thick-borders .region { - border-width: 5px; - -webkit-border-image: -webkit-linear-gradient(left, #767676 0%, #eee 20%, #f2f2f2 80%, #767676 100%) 0 100% 0 0/0 5px 0 0 stretch; - border-image: linear-gradient(to right, #767676 0%, #eee 20%, #f2f2f2 80%, #767676 100%) 0 100% 0 0/0 5px 0 0 stretch; -} -.thick-borders .vertical .region { - -webkit-border-image: -webkit-linear-gradient(top, #767676 0%, #eee 20%, #f2f2f2 80%, #767676 100%) 0 0 100% 0/0 0 5px 0 stretch; - border-image: linear-gradient(to bottom, #767676 0%, #eee 20%, #f2f2f2 80%, #767676 100%) 0 0 100% 0/0 0 5px 0 stretch; -} -.region:last-child { - border: none !important; - -webkit-border-image: none !important; - border-image: none !important; -} -#region-feeds { - -webkit-flex: 0 0 300px; - flex: 0 0 300px; -} -#region-articles { - -webkit-flex: 0 0 400px; - flex: 0 0 400px; -} -#region-content { - -webkit-flex: 1 1 auto; - flex: 1 1 auto; -} -.region:focus { - outline-width: 0; -} -.resizer { - position: absolute; - left: 0; - top: 0; - -webkit-user-select: none; - user-select: none; -} -#panel-toggle { - -webkit-user-select: none; - user-select: none; - display: none; - -webkit-flex: 0 0 4px; - flex: 0 0 4px; - background: url("/images/toggle_left.png") no-repeat center center #d3daed; -} -#panel-toggle:not(.toggled) { - background-image: url("/images/toggle_right.png"); -} -/** - * Report - */ -.report-overlay { - position: fixed; - top: 0; - left: 0; - width: 100%; - height: 100%; - background: rgba(0,0,0,0.5); - z-index: 10; -} -.report-window { - position: fixed; - top: 50%; - left: 50%; - width: 30rem; - height: 26rem; - margin-top: -13rem; - margin-left: -15rem; - background: #fff; - -webkit-box-shadow: 0 0 6px #000; - box-shadow: 0 0 6px #000; - padding: 1rem; -} -.report-window strong { - text-transform: uppercase; - font-size: 1.2rem; - font-weight: normal; - display: block; - text-align: center; - padding: 0.3rem 0; - border-bottom: 1px solid #ccc; -} -.report-window label { - display: inline-block; - margin-top: 0.5rem; - vertical-align: baseline; -} -.report-window textarea, -.report-window input[type=email], -.report-window input[type=text] { - width: 100%; - resize: none; -} -.report-window input[type=checkbox] { - vertical-align: bottom; -} -.report-window textarea { - height: 11rem; -} -.report-window .report-buttons, -.report-window .report-message { - margin-top: 1.5rem; - text-align: center; - font-size: 0.9rem; -} -.report-window .report-buttons { - line-height: 2rem; -} -.report-window input[type=submit], -.report-window input[type=button] { - padding: 0.3rem 1rem; -} -@media (max-height: 26rem) { - .report-window { - top: 0 !important; - margin-top: 0 !important; - } -} -@media (max-width: 30rem) { - .report-window { - left: 0 !important; - margin-left: 0 !important; - } -} - -#toolbar { - -webkit-flex: 0 0 auto; - flex: 0 0 auto; -} -#feed-list { - -webkit-flex: 1 1; - flex: 1 1; -/*padding-top: 3px;*/ - -webkit-user-select: none; - user-select: none; - overflow-x: hidden; - overflow-y: auto; - display: -webkit-flex; - display: flex; - -webkit-flex-flow: column; - flex-flow: column; -} -.list-item { - -webkit-flex: 0 0 auto; - flex: 0 0 auto; - -webkit-align-items: center; - align-items: center; - width: 100%; - padding: 3px 5px 3px 15px; - display: -webkit-flex; - display: flex; - font-family: sans-serif; - font-size: 0.9rem; - cursor: pointer; -} -.selected { - background: #94c6f8; -} -/*.list-item:active { - background: rgb(51, 153, 255); -}*/ -.list-item:hover .source-title { - color: #285078; - text-decoration: underline; -} -.source-icon { - -webkit-flex: 0 0 16px; - flex: 0 0 16px; - height: 16px; -} -.source-title { - white-space: nowrap; - overflow: hidden; - text-overflow: ellipsis; - -webkit-flex: 1 1; - flex: 1 1; - padding: 0 5px; - line-height: 1.2; - font-size: 0.8rem; -} -.source-counter { - -webkit-flex: 0 0 auto; - flex: 0 0 auto; - padding: 0 5px; - background: #e1e1e1; - -webkit-border-radius: 3px; - border-radius: 3px; - height: 100%; - max-width: 50px; - overflow: hidden; -} -.source-counter:hover { - background: #d5d5d5; -} -.selected .source-counter:hover { - background: #e8e8e8; -} -.selected .source-counter { - color: #000 !important; -} -.folder { - padding-left: 1px !important; -} -.drag-over { - background: #e3e3ff; -} -.folder-arrow { - width: 14px; - height: 14px; - -webkit-flex: 0 0 14px; - flex: 0 0 14px; - background: url("/images/arrow-right.png") no-repeat center center; -} -.opened .folder-arrow { - background: url("/images/arrow-down.png") no-repeat center center; -} -.has-unread .source-title { - font-weight: bold; -} -[data-in-folder] { - padding-left: 30px; -} -#indicator { - display: none; - -webkit-flex: 0 0 1.75rem; - flex: 0 0 1.75rem; - line-height: 1.75rem; - width: 100%; - border-top: 1px solid #a6a6a6; - -webkit-flex-flow: row; - flex-flow: row; - -webkit-align-items: stretch; - align-items: stretch; - -webkit-user-select: none; - user-select: none; -} -#indicator-progress { - border-right: 1px solid #a6a6a6; - font-family: sans-serif; - overflow: hidden; - text-overflow: ellipsis; - white-space: nowrap; - background: -webkit-linear-gradient(left, #d1d1d1 0%, #eee 0%); - background: linear-gradient(to right, #d1d1d1 0%, #eee 0%); - -webkit-flex: 1 1 auto; - flex: 1 1 auto; - text-align: center; - font-size: 0.8rem; -} -#indicator.indicator-visible { - display: -webkit-flex; - display: flex; -} -#indicator-toolbar { - -webkit-flex: 0 0 2rem; - flex: 0 0 2rem; - padding: 0.1rem; - display: -webkit-flex; - display: flex; - -webkit-flex-flow: row; - flex-flow: row; - -webkit-align-items: stretch; - align-items: stretch; -} -#indicator-stop { - cursor: pointer; - background: url("../images/stop.png") no-repeat center center; - -webkit-border-radius: 3px; - border-radius: 3px; - width: 28px; - border: 1px solid transparent; -} -#indicator-stop:hover, -#indicator-stop:active { - border-color: #c4c4c4; -} -#indicator-stop:active { - -webkit-box-shadow: inset 0 1px 3px #bbb; - box-shadow: inset 0 1px 3px #bbb; -} -#properties { - padding: 10px; - background: #f2f2f2; - border-bottom: 1px solid #a6a6a6; - display: none; -} -#properties input, -#properties select { - width: 100%; - padding: 2px 5px; -} -#properties button { - width: 49%; - margin-top: 5px; - background: #fff; - border: 1px solid #a6a6a6; - -webkit-border-radius: 4px; - border-radius: 4px; - padding: 3px 0; - cursor: pointer; -} -#properties button:first-of-type { - margin-right: 2%; -} -#properties-advanced { - margin: 5px 0; - display: none; -} -#advanced-switch { - -webkit-user-select: none; - user-select: none; - margin: 5px 0; - font-weight: bold; - font-size: 0.75rem; - cursor: pointer; - padding-left: 16px; - font-family: sans-serif; - background: url("/images/right.png") no-repeat left 45%; -} -#advanced-switch:hover { - text-decoration: underline; -} -#advanced-switch.switched { - background: url("/images/down.png") no-repeat left 45%; -} - -#toolbar { - -webkit-flex: 0 0 auto; - flex: 0 0 auto; -} -#article-list { - -webkit-flex: 1 1 auto; - flex: 1 1 auto; - -webkit-user-select: none; - user-select: none; - overflow-x: hidden; - overflow-y: auto; - font-family: sans-serif; -} -.item { - width: 100%; - padding: 4px 5px 4px 5px; - cursor: pointer; - border-bottom: 1px solid #ccc; - display: -webkit-flex; - display: flex; - -webkit-flex-flow: row wrap; - flex-flow: row wrap; -} -.selected { - color: #f1f1f1 !important; - background: #39f; - border-bottom-color: #39f; - -webkit-font-smoothing: antialiased; -} -.region:not(.focused) .selected { - background: #94c6f7; - border-bottom-color: #ccc; -} -.last-selected { - outline: 1px dotted #808080; -} -.region:not(.focused) .last-selected { - outline: none; -} -.item:active *, -.selected * { - color: #f1f1f1 !important; -} -.unread { - font-weight: bold; -} -.unvisited { - color: #003bb3 !important; -} -.unvisited .item-author { - color: #003bb3 !important; -} -.item-title { - white-space: nowrap; - overflow: hidden; - text-overflow: ellipsis; - font-size: 0.8rem; - -webkit-flex: 1 1 100%; - flex: 1 1 100%; - padding-left: 1rem; -} -.item-author { - color: #664666; - padding-top: 0.2rem; - font-size: 0.75rem; - -webkit-flex: 1 1 10px; - flex: 1 1 10px; - white-space: nowrap; - min-width: 10px; - overflow: hidden; - text-overflow: ellipsis; -} -.item-pin { - width: 0.4rem; - height: 0.5rem; - margin-top: 0.46rem; - margin-right: 0.4rem; - margin-left: 0.2rem; - background-repeat: no-repeat; - background-image: url("../images/bullet_read.png"); - background-position: 50% 50%; - -webkit-background-size: 1rem; - background-size: 1rem; - -webkit-flex: 0 0 0.4rem; - flex: 0 0 0.4rem; -} -.unread:not(.unvisited) .item-pin:not(.pinned) { - background-image: url("../images/bullet_unread.png"); -} -.unvisited .item-pin:not(.pinned) { - background-image: url("../images/bullet_unseen.png"); -} -.pinned { - background-image: url("../images/bullet_pinned.png"); -} -.item-date { - color: #6d6d6d; - padding-top: 0.2rem; - font-size: 0.75rem; - -webkit-flex: 1 1 20px; - flex: 1 1 20px; - white-space: nowrap; - font-weight: normal; - text-align: right; -} -.date-group { - border-bottom: 1px solid #a6a6a6; - background: -webkit-linear-gradient(top, #fff 3px, #ececec); - background: linear-gradient(to bottom, #fff 3px, #ececec); - height: 22px; - line-height: 22px; - font-family: sans-serif; - font-size: 0.75rem; - text-align: center; - font-weight: bold; - -webkit-user-select: none; - user-select: none; -} -.unpluged { - display: none !important; -} -/** - * One line layout - */ -/*@media all and (min-width: 37rem) { - .lines-auto .item { - flex-wrap: nowrap; - justify-content: flex-end; - } - .lines-auto .item-title { - flex: 1 1 auto; - padding-right: 20px; - padding-left: 0; - font-size: 0.75rem; - } - .lines-auto .item-pin { - order: -1; - margin-top: 0.3rem; - } - .lines-auto .item-author, .lines-auto .item-date { - padding: 0; - } - .lines-auto .item-author { - flex: 0 0 12rem; - } - - .lines-auto .item-date { - flex: 0 0 auto; - padding-right: 5px; - } -}*/ -.lines-one-line .item { - -webkit-flex-wrap: nowrap; - flex-wrap: nowrap; - -webkit-justify-content: flex-end; - justify-content: flex-end; -} -.lines-one-line .item-title { - -webkit-flex: 1 1 auto; - flex: 1 1 auto; - padding-right: 20px; - padding-left: 0; - font-size: 0.75rem; -} -.lines-one-line .item-pin { - -webkit-order: -1; - order: -1; - margin-top: 0.3rem; -} -.lines-one-line .item-author, -.lines-one-line .item-date { - padding: 0; -} -.lines-one-line .item-author { - -webkit-flex: 0 0 12rem; - flex: 0 0 12rem; -} -.lines-one-line .item-date { - -webkit-flex: 0 0 auto; - flex: 0 0 auto; - padding-right: 5px; -} -@media all and (max-width: 42rem) { - .lines-one-line .item-author { - max-width: 10rem; - } -} -@media all and (max-width: 32rem) { - .lines-one-line .item-title { - -webkit-flex: 1 1 auto; - flex: 1 1 auto; - padding-right: 5px; - } - .lines-one-line .item-author { - display: none; - } - .lines-one-line .item-date { - -webkit-flex: 0 0 auto; - flex: 0 0 auto; - } -} -@media all and (max-width: 20rem) { - .lines-one-line .item-date { - display: none; - } -} - -header { - display: none; - padding: 25px 15px 15px 30px; - font-family: sans-serif; - border-bottom: 1px solid #c7cbd6; - -webkit-flex: 0 0 auto; - flex: 0 0 auto; - overflow: hidden; -} -.clear { - clear: both; -} -h1 { - margin: 0; - margin-bottom: 20px; - padding: 0; - color: #484848; - font-size: 1.5rem; - max-height: 6rem; - overflow: hidden; - text-overflow: ellipsis; -} -h1 a { - color: inherit; - font-size: inherit; - text-decoration: none; - font-weight: inherit; -} -#below-h1 { - display: -webkit-flex; - display: flex; - -webkit-flex-flow: row nowrap; - flex-flow: row nowrap; - width: 100%; -} -header p { - color: #b693ab; - font-size: 0.9rem; - margin: 0; - padding: 0; - white-space: nowrap; - overflow: hidden; - text-overflow: ellipsis; -} -header .author { - -webkit-flex: 1 1 auto; - flex: 1 1 auto; -} -header .date { - -webkit-flex: 0 1 200px; - flex: 0 1 200px; - text-align: right; -} -header .pin-button { - -webkit-flex: 0 0 25px; - flex: 0 0 25px; - height: 16px; - background: url("/images/mail_unpinned.png") no-repeat right center; - opacity: 0.8; - -webkit-transition: opacity 0.1s; - transition: opacity 0.1s; - cursor: pointer; -} -header .pin-button:hover { - opacity: 1; -} -header .pin-button.pinned { - background: url("/images/mail_pinned.png") no-repeat right center; -} -iframe { - height: 0; - display: none; - -webkit-flex: 1 1 auto; - flex: 1 1 auto; - width: 100%; -} -footer { - border-top: 2px solid #999; - padding: 5px 10px; - font-size: 0.75rem; - display: none; - max-height: 300px; - overflow-x: hidden; - overflow-y: auto; - background: #fff; -} -footer .log { - padding: 5px 0; -} -footer .log:not(:last-of-type) { - border-bottom: 1px solid #ccc; -} -footer #button-hide-log { - margin: 0; - padding: 0 4px; - border: 1px solid #a6a6a6; - cursor: pointer; -} -@media print { - header, - #toolbar { - display: none !important; - } -} -.overlay #config-layout { - padding: 5px; -} -.overlay #config-layout input[type=image] { - margin: 3px; -} -.overlay select { - width: 100%; -} -.overlay a { - display: block; - text-align: right; - margin: 3px; - margin-top: 8px; - padding-top: 8px; - font-size: 0.8rem; - font-family: sans-serif; - color: #000; - border-top: 1px solid #a6a6a6; -} From a57b2f81884e6257ed574e6dbd1c72b1ca33914c Mon Sep 17 00:00:00 2001 From: zakius Date: Fri, 15 Feb 2019 22:20:09 +0100 Subject: [PATCH 008/965] update package.json --- package.json | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/package.json b/package.json index 2b533bbe..3b6628cc 100644 --- a/package.json +++ b/package.json @@ -1,8 +1,8 @@ { "name": "smartrss", "version": "2.0.0", - "description": "RSS Reader for Opera 15+", - "homepage": "http://blog.martinkadlec.eu/post/501-smart-rss-final-v10", + "description": "RSS Reader", + "homepage": "", "dependencies": {}, "devDependencies": { "grunt": ">=0.4.1", @@ -18,12 +18,12 @@ }, "repository": { "type": "git", - "url": "git://github.com/BS-Harou/Smart-RSS.git" + "url": "git://github.com/zakius/Smart-RSS.git" }, - "author": "Martin Kadlec", - "license": "BSD-2-Clause", + "author": "zakius", + "license": "MIT", "bugs": { - "url": "https://github.com/BS-Harou/Smart-RSS/issues" + "url": "https://github.com/zakius/Smart-RSS/issues" }, "engine": "node >= 0.10.0" } From a5185f74d80362f5f530e0805c0d8095da15f6f6 Mon Sep 17 00:00:00 2001 From: zakius Date: Fri, 15 Feb 2019 22:28:47 +0100 Subject: [PATCH 009/965] update Gruntfile.js: support ES6 --- Gruntfile.js | 353 ++++++++++++++++++++++++++------------------------- 1 file changed, 177 insertions(+), 176 deletions(-) diff --git a/Gruntfile.js b/Gruntfile.js index b7296a21..ada282c5 100644 --- a/Gruntfile.js +++ b/Gruntfile.js @@ -1,177 +1,178 @@ -module.exports = function(grunt) { - - // Project configuration. - grunt.initConfig({ - pkg: grunt.file.readJSON('package.json'), - - - jshint: { - options: { - curly: false, // true: force { } - eqnull: true, // true: enable something == null - eqeqeq: false, // true: force === - immed: true, // true: immidiatly invocated fns has to be in () - newcap: true, // true: construcotr has to have firt letter uppercased - noarg: true, // true: no arguments.caller and arguments.callee - sub: true, // true: no warning about a['something'] if a.something can be used - undef: true, // true: can't use undeclared vars - browser: true, // true: set window object and other stuff as globals - devel: true, // true: set alert,confirm,console,... as globals - boss: true, // true: allow assigments in conditions and return statements - forin: true, // true: hasOwnProperty has to be in all for..in cycles - noempty: true, // true: no empty blocks - unused: true, // true: warn about unused vars - trailing: true, // true: no trailing whitespaces - supernew: true, // true: enable 'new Constructor' instead of 'new Constructor()' - onevar: false, // true: only one var per fn - funcscope: false, // false: no 'var' in blocks - maxdepth: 5, // max nesting depth - quotmark: 'single', // single: force ' - '-W041': true, // don't warn about something == false/true - '-W117': true, // don't warn about not defined vars until I refactorize bg.js - globals: { - app: true, - bg: true, - tabID: true, - chrome: false, - define: false, - require: false, - - /* browser globals not recognized by browser or devel options */ - requestAnimationFrame: true, - URL: true, - HTMLCollection: true - } - }, - all: ['scripts/app/**/*.js', 'scripts/bgprocess/**/*.js'] - }, - - requirejs: { - app: { - options: { - name: '../main', - baseUrl: 'scripts/app', - generateSourceMaps: true, - preserveLicenseComments: false, - optimize: 'uglify2', - waitSeconds: 0, - paths: { - jquery: '../libs/jquery.min', - underscore: '../libs/underscore.min', - backbone: '../libs/backbone.min', - text: '../text', - i18n: '../i18n', - domReady: '../domReady' - }, - shim: { - jquery: { - exports: '$' - }, - backbone: { - deps: ['underscore', 'jquery'], - exports: 'Backbone' - }, - underscore: { - exports: '_' - } - }, - excludeShallow: ['modules/Locale', 'jquery', 'underscore', 'backbone'], - out: 'scripts/main-compiled.js' - } - }, - bg: { - options: { - name: '../bgprocess', - baseUrl: 'scripts/bgprocess', - generateSourceMaps: true, - preserveLicenseComments: false, - optimize: 'uglify2', - waitSeconds: 0, - paths: { - jquery: '../libs/jquery.min', - underscore: '../libs/underscore.min', - backbone: '../libs/backbone.min', - text: '../text', - i18n: '../i18n', - md5: '../libs/md5', - domReady: '../domReady', - backboneDB: '../libs/backbone.indexDB' - }, - shim: { - jquery: { - exports: '$' - }, - backboneDB: { - deps: ['backbone'] - }, - backbone: { - deps: ['underscore', 'jquery'], - exports: 'Backbone' - }, - underscore: { - exports: '_' - }, - md5: { - exports: 'CryptoJS' - } - }, - excludeShallow: ['jquery', 'underscore', 'backbone', 'backboneDB'], - out: 'scripts/bgprocess-compiled.js' - } - } - }, - - stylus: { - compile: { - options: { - compress: false, - //imports: ['nib'] - }, - files: { - //'styles/options-compiled.css': 'options.styl', // 1:1 compile - 'styles/main-compiled.css': [ - 'styles/global.styl', - 'styles/feeds.styl', - 'styles/articles.styl', - 'styles/content.styl' - ] - } - } - }, - watch: { - scripts: { - files: ['styles/*.styl'], - tasks: ['stylus'], - options: { - spawn: false, - interrupt: true, - events: ['all'] - }, - }, - }, - yuidoc: { - compile: { - name: '<%= pkg.name %>', - description: '<%= pkg.description %>', - version: '<%= pkg.version %>', - url: '<%= pkg.homepage %>', - options: { - paths: ['scripts'], - /*themedir: 'path/to/custom/theme/',*/ - outdir: 'docs/' - } - } - } - }); - - - grunt.loadNpmTasks('grunt-contrib-jshint'); - grunt.loadNpmTasks('grunt-contrib-requirejs'); - grunt.loadNpmTasks('grunt-contrib-stylus'); - grunt.loadNpmTasks('grunt-contrib-watch'); - grunt.loadNpmTasks('grunt-contrib-yuidoc'); - - // Default task(s). - grunt.registerTask('default', ['jshint']); - grunt.registerTask('rjs', ['requirejs:app', 'requirejs:bg']); +module.exports = function(grunt) { + + // Project configuration. + grunt.initConfig({ + pkg: grunt.file.readJSON('package.json'), + + + jshint: { + options: { + curly: false, // true: force { } + eqnull: true, // true: enable something == null + eqeqeq: false, // true: force === + immed: true, // true: immidiatly invocated fns has to be in () + newcap: true, // true: construcotr has to have firt letter uppercased + noarg: true, // true: no arguments.caller and arguments.callee + sub: true, // true: no warning about a['something'] if a.something can be used + undef: true, // true: can't use undeclared vars + browser: true, // true: set window object and other stuff as globals + devel: true, // true: set alert,confirm,console,... as globals + boss: true, // true: allow assigments in conditions and return statements + forin: true, // true: hasOwnProperty has to be in all for..in cycles + noempty: true, // true: no empty blocks + unused: true, // true: warn about unused vars + trailing: true, // true: no trailing whitespaces + supernew: true, // true: enable 'new Constructor' instead of 'new Constructor()' + onevar: false, // true: only one var per fn + funcscope: false, // false: no 'var' in blocks + maxdepth: 5, // max nesting depth + quotmark: 'single', // single: force ' + '-W041': true, // don't warn about something == false/true + '-W117': true, // don't warn about not defined vars until I refactorize bg.js, + esversion: 6, + globals: { + app: true, + bg: true, + tabID: true, + chrome: false, + define: false, + require: false, + + /* browser globals not recognized by browser or devel options */ + requestAnimationFrame: true, + URL: true, + HTMLCollection: true + } + }, + all: ['scripts/app/**/*.js', 'scripts/bgprocess/**/*.js'] + }, + + requirejs: { + app: { + options: { + name: '../main', + baseUrl: 'scripts/app', + generateSourceMaps: true, + preserveLicenseComments: false, + optimize: 'uglify2', + waitSeconds: 0, + paths: { + jquery: '../libs/jquery.min', + underscore: '../libs/underscore.min', + backbone: '../libs/backbone.min', + text: '../text', + i18n: '../i18n', + domReady: '../domReady' + }, + shim: { + jquery: { + exports: '$' + }, + backbone: { + deps: ['underscore', 'jquery'], + exports: 'Backbone' + }, + underscore: { + exports: '_' + } + }, + excludeShallow: ['modules/Locale', 'jquery', 'underscore', 'backbone'], + out: 'scripts/main-compiled.js' + } + }, + bg: { + options: { + name: '../bgprocess', + baseUrl: 'scripts/bgprocess', + generateSourceMaps: true, + preserveLicenseComments: false, + optimize: 'uglify2', + waitSeconds: 0, + paths: { + jquery: '../libs/jquery.min', + underscore: '../libs/underscore.min', + backbone: '../libs/backbone.min', + text: '../text', + i18n: '../i18n', + md5: '../libs/md5', + domReady: '../domReady', + backboneDB: '../libs/backbone.indexDB' + }, + shim: { + jquery: { + exports: '$' + }, + backboneDB: { + deps: ['backbone'] + }, + backbone: { + deps: ['underscore', 'jquery'], + exports: 'Backbone' + }, + underscore: { + exports: '_' + }, + md5: { + exports: 'CryptoJS' + } + }, + excludeShallow: ['jquery', 'underscore', 'backbone', 'backboneDB'], + out: 'scripts/bgprocess-compiled.js' + } + } + }, + + stylus: { + compile: { + options: { + compress: false, + //imports: ['nib'] + }, + files: { + //'styles/options-compiled.css': 'options.styl', // 1:1 compile + 'styles/main-compiled.css': [ + 'styles/global.styl', + 'styles/feeds.styl', + 'styles/articles.styl', + 'styles/content.styl' + ] + } + } + }, + watch: { + scripts: { + files: ['styles/*.styl'], + tasks: ['stylus'], + options: { + spawn: false, + interrupt: true, + events: ['all'] + }, + }, + }, + yuidoc: { + compile: { + name: '<%= pkg.name %>', + description: '<%= pkg.description %>', + version: '<%= pkg.version %>', + url: '<%= pkg.homepage %>', + options: { + paths: ['scripts'], + /*themedir: 'path/to/custom/theme/',*/ + outdir: 'docs/' + } + } + } + }); + + + grunt.loadNpmTasks('grunt-contrib-jshint'); + grunt.loadNpmTasks('grunt-contrib-requirejs'); + grunt.loadNpmTasks('grunt-contrib-stylus'); + grunt.loadNpmTasks('grunt-contrib-watch'); + grunt.loadNpmTasks('grunt-contrib-yuidoc'); + + // Default task(s). + grunt.registerTask('default', ['jshint']); + grunt.registerTask('rjs', ['requirejs:app', 'requirejs:bg']); }; \ No newline at end of file From aab3490c86c5fcf8d4045bb4f2472cc8ce0be638 Mon Sep 17 00:00:00 2001 From: zakius Date: Fri, 15 Feb 2019 22:29:07 +0100 Subject: [PATCH 010/965] fix errors found by jshint --- scripts/app/staticdb/actions.js | 1445 ++++++++++++++++--------------- 1 file changed, 723 insertions(+), 722 deletions(-) diff --git a/scripts/app/staticdb/actions.js b/scripts/app/staticdb/actions.js index 26b59c54..e77f2b3e 100644 --- a/scripts/app/staticdb/actions.js +++ b/scripts/app/staticdb/actions.js @@ -1,723 +1,724 @@ -define(['jquery', 'underscore', 'helpers/stripTags', 'modules/Locale', 'controllers/comm'], function($, _, stripTags, Locale, comm) { - -return { - global: { - default: { - title: 'Unknown', - fn: function() { - alert('no action'); - } - }, - hideOverlays: { - title: 'Hide Overlays', - fn: function() { - comm.trigger('hide-overlays'); - } - }, - runTests: { - title: 'Run tests (dev dependencies needed)', - fn: function() { - require(['../runtests']); - } - }, - openOptions: { - title: 'Options', - icon: 'options.png', - fn: function() { - window.open('options.html'); - } - }, - report: { - title: 'Report a problem', - icon: 'report.png', - fn: function() { - app.report(); - } - } - }, - feeds: { - updateAll: { - icon: 'reload.png', - title: Locale.c.UPDATE_ALL, - fn: function() { - bg.loader.downloadAll(true); - } - }, - update: { - icon: 'reload.png', - title: Locale.c.UPDATE, - fn: function() { - var s = require('views/feedList').selectedItems; - if (s.length) { - bg.loader.download(_.pluck(s, 'model')); - } - } - }, - stopUpdate: { - icon: 'stop.png', - title: 'Stop updating feeds', - fn: function() { - bg.loader.abortDownloading(); - } - }, - mark: { - icon: 'read.png', - title: Locale.c.MARK_ALL_AS_READ, - fn: function() { - var s = require('views/feedList').getSelectedFeeds(); - if (!s.length) return; - - bg.items.forEach(function(item) { - if (item.get('unread') == true && s.indexOf(item.getSource()) >= 0) { - item.save({ - unread: false, - visited: true - }); - } - }); - - s.forEach(function(source) { - if (source.get('hasNew')) { - source.save({ hasNew: false }); - } - }); - - } - }, - refetch: { - title: 'Refetch', /****localization needed****/ - fn: function() { - var s = require('views/feedList').getSelectedFeeds(); - if (!s.length) return; - - s.forEach(function(source) { - bg.items.where({ sourceID: source.get('id') }).forEach(function(item) { - item.destroy(); - }); - }); - - app.actions.execute('feeds:update'); - - } - }, - delete: { - icon: 'delete.png', - title: Locale.c.DELETE, - fn: function() { - if (!confirm(Locale.c.REALLY_DELETE)) return; - - var feeds = require('views/feedList').getSelectedFeeds(); - var folders = require('views/feedList').getSelectedFolders(); - - feeds.forEach(function(feed) { - feed.destroy(); - }); - - folders.forEach(function(folder) { - folder.destroy(); - }); - } - }, - showProperties: { - icon: 'properties.png', - title: Locale.c.PROPERTIES, - fn: function() { - var properties = app.feeds.properties; - - var feedList = require('views/feedList'); - - var feeds = feedList.getSelectedFeeds(); - var folders = feedList.getSelectedFolders(); - - if (feedList.selectedItems.length == 1 && folders.length == 1) { - properties.show(folders[0]); - } else if (!folders.length && feeds.length == 1) { - properties.show(feeds[0]); - } else if (feeds.length > 0) { - properties.show(feeds); - } - - } - }, - addSource: { - icon: 'add.png', - title: Locale.c.ADD_RSS_SOURCE, - fn: function() { - var url = (prompt(Locale.c.RSS_FEED_URL) || '').trim(); - if (!url) return; - - var folderID = 0; - var list = require('views/feedList'); - if (list.selectedItems.length && list.selectedItems[0].$el.hasClass('folder')) { - var fid = list.selectedItems[0].model.get('id'); - // make sure source is not added to folder which is not in db - if (bg.folders.get(fid)) { - folderID = fid; - } - } - - url = app.fixURL(url); - var duplicate = bg.sources.findWhere({ url: url }); - - if (!duplicate) { - var newFeed = bg.sources.create({ - title: url, - url: url, - updateEvery: 180, - folderID: folderID - }, { wait: true }); - app.trigger('focus-feed', newFeed.get('id')); - } else { - app.trigger('focus-feed', duplicate.get('id')); - } - } - }, - addFolder: { - icon: 'add_folder.png', - title: Locale.c.NEW_FOLDER, - fn: function() { - var title = (prompt(Locale.c.FOLDER_NAME + ': ') || '').trim(); - if (!title) return; - - bg.folders.create({ - title: title - }, { wait: true }); - } - }, - focus: { - title: 'Focus feeds', - fn: function() { - app.setFocus('feeds'); - } - }, - selectNext: { - title: 'Select next', - fn: function(e) { - require('views/feedList').selectNext(e); - } - }, - selectPrevious: { - title: 'Select previous', - fn: function(e) { - require('views/feedList').selectPrev(e); - } - }, - closeFolders: { - title: 'Close folders', - fn: function(e) { - var folders = $('.folder.opened'); - if (!folders.length) return; - folders.each(function(i, folder) { - if (folder.view) { - folder.view.handleClickArrow(e); - } - }); - } - }, - openFolders: { - title: 'Open folders', - fn: function(e) { - var folders = $('.folder:not(.opened)'); - if (!folders.length) return; - folders.each(function(i, folder) { - if (folder.view) { - folder.view.handleClickArrow(e); - } - }); - } - }, - toggleFolder: { - title: 'Toggle folder', - fn: function(e) { - e = e || {}; - var cs = require('views/feedList').selectedItems; - if (cs.length && cs[0].$el.hasClass('folder')) { - cs[0].handleClickArrow(e); - } - } - }, - showArticles: { - title: 'Show articles', - fn: function(e) { - e = e || {}; - var t = e.target || {}; - var feedList = require('views/feedList'); - var feeds = feedList.getSelectedFeeds(); - var ids = _.pluck(feeds, 'id'); - var special = $('.special.selected').get(0); - if (special) special = special.view.model; - - app.trigger('select:' + feedList.el.id, { - action: 'new-select', - feeds: ids, - // _.extend is important, because otherwise it would be sent by reference - filter: special ? _.extend({}, special.get('filter')) : null, - name: special ? special.get('name') : null, - unreadOnly: !!e.altKey || t.className == 'source-counter' - }); - - - if (special && special.get('name') == 'all-feeds') { - bg.sources.forEach(function(source) { - if (source.get('hasNew')) { - source.save({ hasNew: false }); - } - }); - - } else if (ids.length) { - bg.sources.forEach(function(source) { - if (source.get('hasNew') && ids.indexOf(source.id) >= 0) { - source.save({ hasNew: false }); - } - }); - } - } - }, - showAndFocusArticles: { - title: 'Show and focus articles', - fn: function(e) { - e = e || {}; - var cs = require('views/feedList').selectedItems; - if (cs.length) { - app.actions.execute('feeds:showArticles', e); - app.actions.execute('articles:focus'); - } - } - } - }, - articles: { - mark: { - icon: 'read.png', - title: Locale.c.MARK_AS_READ, - fn: function() { - require('views/articleList').changeUnreadState(); - } - }, - update: { - icon: 'reload.png', - title: Locale.c.UPDATE, - fn: function() { - var list = require('views/articleList'); - if (list.currentData.feeds.length) { - list.currentData.feeds.forEach(function(id) { - bg.loader.downloadOne(bg.sources.get(id)); - }); - } else { - bg.loader.downloadAll(true); // true = force - } - } - }, - delete: { - icon: 'delete.png', - title: Locale.c.DELETE, - fn: function(e) { - var list = require('views/articleList'); - if (list.currentData.name == 'trash' || e.shiftKey) { - list.destroyBatch(list.selectedItems, list.removeItemCompletely); - } else { - list.destroyBatch(list.selectedItems, list.removeItem); - } - } - }, - undelete: { - icon: 'undelete.png', - title: Locale.c.UNDELETE, - fn: function() { - var articleList = require('views/articleList'); - if (!articleList.selectedItems || !articleList.selectedItems.length || articleList.currentData.name != 'trash') return; - articleList.destroyBatch(articleList.selectedItems, articleList.undeleteItem); - } - }, - selectNext: { - fn: function(e) { - require('views/articleList').selectNext(e); - } - }, - selectPrevious: { - fn: function(e) { - require('views/articleList').selectPrev(e); - } - }, - search: { - title: Locale.c.SEARCH_TIP, - fn: function(e) { - e = e || { currentTarget: $('input[type=search]').get(0) }; - var str = e.currentTarget.value || ''; - var list = require('views/articleList'); - if (str == '') { - $('.date-group').css('display', 'block'); - } else { - $('.date-group').css('display', 'none'); - } - - var searchInContent = false; - if (str[0] && str[0] == ':') { - str = str.replace(/^:/, '', str); - searchInContent = true; - } - var rg = new RegExp(RegExp.escape(str), 'i'); - list.views.some(function(view) { - if (!view.model) return true; - if (rg.test(view.model.get('title')) || rg.test(view.model.get('author')) || (searchInContent && rg.test(view.model.get('content')) )) { - view.$el.removeClass('invisible'); - } else { - view.$el.addClass('invisible'); - } - }); - - list.redraw(); - - list.restartSelection(); - } - }, - focusSearch: { - title: 'Focus Search', - fn: function() { - $('input[type=search]').focus(); - } - }, - focus: { - title: 'Focus Articles', - fn: function() { - app.setFocus('articles'); - } - }, - fullArticle: { - title: Locale.c.FULL_ARTICLE, - icon: 'full_article.png', - fn: function(e) { - var articleList = app.articles.articleList; - if (!articleList.selectedItems || !articleList.selectedItems.length) return; - if (articleList.selectedItems.length > 10 && bg.settings.get('askOnOpening')) { - if (!confirm('Do you really want to open ' + articleList.selectedItems.length + ' articles?')) { - return; - } - } - articleList.selectedItems.forEach(function(item) { - chrome.tabs.create({ url: stripTags(item.model.get('url')), active: !e.shiftKey }); - }); - } - }, - oneFullArticle: { - title: 'One full article', - fn: function(e) { - e = e || {}; - var articleList = app.articles.articleList; - var view; - if ('currentTarget' in e) { - view = e.currentTarget.view; - } else { - if (!articleList.selectedItems || !articleList.selectedItems.length) return; - view = articleList.selectedItems[0]; - } - if (view.model) { - chrome.tabs.create({ url: stripTags(view.model.get('url')), active: !e.shiftKey }); - } - } - }, - markAndNextUnread: { - title: Locale.c.MARK_AND_NEXT_UNREAD, - icon: 'find_next.png', - fn: function() { - require('views/articleList').changeUnreadState({ onlyToRead: true }); - require('views/articleList').selectNext({ selectUnread: true }); - } - }, - markAndPrevUnread: { - title: Locale.c.MARK_AND_PREV_UNREAD, - icon: 'find_previous.png', - fn: function() { - require('views/articleList').changeUnreadState({ onlyToRead: true }); - require('views/articleList').selectPrev({ selectUnread: true }); - } - }, - nextUnread: { - title: Locale.c.NEXT_UNREAD, - icon: 'forward.png', - fn: function() { - require('views/articleList').selectNext({ selectUnread: true }); - } - }, - prevUnread: { - title: Locale.c.PREV_UNREAD, - icon: 'back.png', - fn: function() { - require('views/articleList').selectPrev({ selectUnread: true }); - } - }, - markAllAsRead: { - title: Locale.c.MARK_ALL_AS_READ, - icon: 'read.png', - fn: function() { - var articleList = require('views/articleList'); - var f = articleList.currentData.feeds; - var filter = articleList.currentData.filter; - if (f.length) { - (filter ? bg.items.where(articleList.currentData.filter) : bg.items).forEach(function(item) { - if (item.get('unread') == true && f.indexOf(item.get('sourceID')) >= 0) { - item.save({ unread: false, visited: true }); - } - }); - } else if (articleList.currentData.name == 'all-feeds') { - if (confirm(Locale.c.MARK_ALL_QUESTION)) { - bg.items.forEach(function(item) { - if (item.get('unread') == true) { - item.save({ unread: false, visited: true }); - } - }); - } - } else if (articleList.currentData.filter) { - bg.items.where(articleList.specialFilter).forEach(function(item) { - item.save({ unread: false, visited: true }); - }); - } - } - }, - selectAll: { - title: 'Select All', - fn: function() { - var articleList = require('views/articleList'); - articleList.$el.find('.selected').removeClass('selected'); - articleList.selectedItems = []; - - articleList.$el.find('.item:not(.invisible)').each(function(i, item) { - item.view.$el.addClass('selected'); - articleList.selectedItems.push(item.view); - }); - - articleList.$el.find('.last-selected').removeClass('last-selected'); - articleList.$el.find('.item:not(.invisible):last').addClass('last-selected'); - } - }, - pin: { - title: Locale.c.PIN, - icon: 'pinsource_context.png', - fn: function() { - var articleList = require('views/articleList'); - if (!articleList.selectedItems || !articleList.selectedItems.length) return; - var val = !articleList.selectedItems[0].model.get('pinned'); - articleList.selectedItems.forEach(function(item) { - item.model.save({ pinned: val }); - }); - } - }, - spaceThrough: { - title: 'Space Through', - fn: function() { - var articleList = require('views/articleList'); - if (!articleList.selectedItems || !articleList.selectedItems.length) return; - app.trigger('space-pressed'); - } - }, - pageUp: { - title: 'Page up', - fn: function() { - var el = require('views/articleList').el; - el.scrollByPages(-1); - } - }, - pageDown: { - title: 'Page down', - fn: function() { - var el = require('views/articleList').el; - el.scrollByPages(1); - } - }, - scrollToBottom: { - title: 'Scroll to bottom', - fn: function() { - var el = require('views/articleList').el; - el.scrollTop = el.scrollHeight; - } - }, - scrollToTop: { - title: 'Scroll to top', - fn: function() { - var el = require('views/articleList').el; - el.scrollTop = 0; - } - }, - download: { - title: Locale.c.DOWNLOAD, - icon: 'save.png', - fn: function() { - var contentView = require('views/contentView'); - var articleList = require('views/articleList'); - if (!articleList.selectedItems.length) { - app.actions.execute('content:download'); - return; - } - var tpl = contentView.downloadTemplate; - - var list = {}; - list.articles = articleList.selectedItems.map(function(itemView) { - var attrs = Object.create(itemView.model.attributes); - attrs.date = contentView.getFormatedDate(attrs.date); - return attrs; - }); - - var blob = new Blob([ tpl(list) ], { type: 'text\/html' }); - var reader = new FileReader(); - reader.readAsDataURL(blob); - reader.onload = function() { - window.open(this.result.replace('data:text/html;', 'data:text/html;charset=utf-8;')); - }; - /*var url = URL.createObjectURL(blob); - window.open(url); - setTimeout(function() { - URL.revokeObjectURL(url); - }, 30000);*/ - } - } - }, - content: { - download: { - title: Locale.c.DOWNLOAD, - icon: 'save.png', - fn: function() { - var contentView = require('views/contentView'); - if (!contentView.model) return; - var tpl = contentView.downloadTemplate; - var attrs = Object.create(contentView.model.attributes); - attrs.date = contentView.getFormatedDate(attrs.date); - var list = { articles: [attrs] }; - var blob = new Blob([ tpl(list) ], { type: 'text\/html' }); - var reader = new FileReader(); - reader.readAsDataURL(blob); - reader.onload = function() { - window.open(this.result.replace('data:text/html;', 'data:text/html;charset=utf-8;')); - }; - /*var url = URL.createObjectURL(blob); - window.open(url); - setTimeout(function() { - URL.revokeObjectURL(url); - }, 30000);*/ - } - }, - print: { - title: Locale.c.PRINT, - icon: 'print.png', - fn: function() { - var contentView = require('views/contentView'); - if (!contentView.model) return; - window.print(); - } - }, - mark: { - title: Locale.c.MARK_AS_READ, - icon: 'read.png', - fn: function() { - var contentView = require('views/contentView'); - if (!contentView.model) return; - contentView.model.save({ - unread: !contentView.model.get('unread'), - visited: true - }); - } - }, - delete: { - title: Locale.c.DELETE, - icon: 'delete.png', - fn: function(e) { - var contentView = require('views/contentView'); - if (!contentView.model) return; - - askRmPinned = bg.settings.get('askRmPinned') - if (e.shiftKey) { - if (contentView.model.get('pinned') && askRmPinned && askRmPinned != 'none') { - var conf = confirm(Locale.c.PIN_QUESTION_A + contentView.model.escape('title') + Locale.c.PIN_QUESTION_B); - if (!conf) { - return; - } - } - - contentView.model.markAsDeleted(); - } else { - if (contentView.model.get('pinned') && askRmPinned == 'all') { - var conf = confirm(Locale.c.PIN_QUESTION_A + contentView.model.escape('title') + Locale.c.PIN_QUESTION_B); - if (!conf) { - return; - } - } - - contentView.model.save({ - trashed: true, - visited: true - }); - } - } - }, - showConfig: { - title: Locale.c.SETTINGS, - icon: 'config.png', - fn: function() { - app.content.overlay.show(); - } - }, - focus: { - title: 'Focus Article', - fn: function() { - app.setFocus('content'); - } - }, - focusSandbox: { - title: 'Focus Article', - fn: function() { - app.content.sandbox.el.focus(); - } - }, - scrollDown: { - title: 'Scroll down', - fn: function() { - var cw = $('iframe').get(0).contentWindow; - cw.scrollBy(0, 40); - } - }, - scrollUp: { - title: 'Scroll up', - fn: function() { - var cw = $('iframe').get(0).contentWindow; - cw.scrollBy(0, -40); - } - }, - spaceThrough: { - title: 'Space trough', - fn: function() { - require('views/contentView').handleSpace(); - } - }, - pageUp: { - title: 'Page up', - fn: function() { - var cw = $('iframe').get(0).contentWindow; - var d = $('iframe').get(0).contentWindow.document; - cw.scrollBy(0, -d.documentElement.clientHeight * 0.85); - } - }, - pageDown: { - title: 'Page down', - fn: function() { - var cw = $('iframe').get(0).contentWindow; - var d = $('iframe').get(0).contentWindow.document; - cw.scrollBy(0, d.documentElement.clientHeight * 0.85); - } - }, - scrollToBottom: { - title: 'Scroll to bottom', - fn: function() { - var cw = $('iframe').get(0).contentWindow; - var d = $('iframe').get(0).contentWindow.document; - cw.scrollTo(0, d.documentElement.offsetHeight); - } - }, - scrollToTop: { - title: 'Scroll to top', - fn: function() { - var cw = $('iframe').get(0).contentWindow; - cw.scrollTo(0, 0); - } - } - } - -}; // end actions object +define(['jquery', 'underscore', 'helpers/stripTags', 'modules/Locale', 'controllers/comm'], function($, _, stripTags, Locale, comm) { + +return { + global: { + default: { + title: 'Unknown', + fn: function() { + alert('no action'); + } + }, + hideOverlays: { + title: 'Hide Overlays', + fn: function() { + comm.trigger('hide-overlays'); + } + }, + runTests: { + title: 'Run tests (dev dependencies needed)', + fn: function() { + require(['../runtests']); + } + }, + openOptions: { + title: 'Options', + icon: 'options.png', + fn: function() { + window.open('options.html'); + } + }, + report: { + title: 'Report a problem', + icon: 'report.png', + fn: function() { + app.report(); + } + } + }, + feeds: { + updateAll: { + icon: 'reload.png', + title: Locale.c.UPDATE_ALL, + fn: function() { + bg.loader.downloadAll(true); + } + }, + update: { + icon: 'reload.png', + title: Locale.c.UPDATE, + fn: function() { + var s = require('views/feedList').selectedItems; + if (s.length) { + bg.loader.download(_.pluck(s, 'model')); + } + } + }, + stopUpdate: { + icon: 'stop.png', + title: 'Stop updating feeds', + fn: function() { + bg.loader.abortDownloading(); + } + }, + mark: { + icon: 'read.png', + title: Locale.c.MARK_ALL_AS_READ, + fn: function() { + var s = require('views/feedList').getSelectedFeeds(); + if (!s.length) return; + + bg.items.forEach(function(item) { + if (item.get('unread') == true && s.indexOf(item.getSource()) >= 0) { + item.save({ + unread: false, + visited: true + }); + } + }); + + s.forEach(function(source) { + if (source.get('hasNew')) { + source.save({ hasNew: false }); + } + }); + + } + }, + refetch: { + title: 'Refetch', /****localization needed****/ + fn: function() { + var s = require('views/feedList').getSelectedFeeds(); + if (!s.length) return; + + s.forEach(function(source) { + bg.items.where({ sourceID: source.get('id') }).forEach(function(item) { + item.destroy(); + }); + }); + + app.actions.execute('feeds:update'); + + } + }, + delete: { + icon: 'delete.png', + title: Locale.c.DELETE, + fn: function() { + if (!confirm(Locale.c.REALLY_DELETE)) return; + + var feeds = require('views/feedList').getSelectedFeeds(); + var folders = require('views/feedList').getSelectedFolders(); + + feeds.forEach(function(feed) { + feed.destroy(); + }); + + folders.forEach(function(folder) { + folder.destroy(); + }); + } + }, + showProperties: { + icon: 'properties.png', + title: Locale.c.PROPERTIES, + fn: function() { + var properties = app.feeds.properties; + + var feedList = require('views/feedList'); + + var feeds = feedList.getSelectedFeeds(); + var folders = feedList.getSelectedFolders(); + + if (feedList.selectedItems.length == 1 && folders.length == 1) { + properties.show(folders[0]); + } else if (!folders.length && feeds.length == 1) { + properties.show(feeds[0]); + } else if (feeds.length > 0) { + properties.show(feeds); + } + + } + }, + addSource: { + icon: 'add.png', + title: Locale.c.ADD_RSS_SOURCE, + fn: function() { + var url = (prompt(Locale.c.RSS_FEED_URL) || '').trim(); + if (!url) return; + + var folderID = 0; + var list = require('views/feedList'); + if (list.selectedItems.length && list.selectedItems[0].$el.hasClass('folder')) { + var fid = list.selectedItems[0].model.get('id'); + // make sure source is not added to folder which is not in db + if (bg.folders.get(fid)) { + folderID = fid; + } + } + + url = app.fixURL(url); + var duplicate = bg.sources.findWhere({ url: url }); + + if (!duplicate) { + var newFeed = bg.sources.create({ + title: url, + url: url, + updateEvery: 180, + folderID: folderID + }, { wait: true }); + app.trigger('focus-feed', newFeed.get('id')); + } else { + app.trigger('focus-feed', duplicate.get('id')); + } + } + }, + addFolder: { + icon: 'add_folder.png', + title: Locale.c.NEW_FOLDER, + fn: function() { + var title = (prompt(Locale.c.FOLDER_NAME + ': ') || '').trim(); + if (!title) return; + + bg.folders.create({ + title: title + }, { wait: true }); + } + }, + focus: { + title: 'Focus feeds', + fn: function() { + app.setFocus('feeds'); + } + }, + selectNext: { + title: 'Select next', + fn: function(e) { + require('views/feedList').selectNext(e); + } + }, + selectPrevious: { + title: 'Select previous', + fn: function(e) { + require('views/feedList').selectPrev(e); + } + }, + closeFolders: { + title: 'Close folders', + fn: function(e) { + var folders = $('.folder.opened'); + if (!folders.length) return; + folders.each(function(i, folder) { + if (folder.view) { + folder.view.handleClickArrow(e); + } + }); + } + }, + openFolders: { + title: 'Open folders', + fn: function(e) { + var folders = $('.folder:not(.opened)'); + if (!folders.length) return; + folders.each(function(i, folder) { + if (folder.view) { + folder.view.handleClickArrow(e); + } + }); + } + }, + toggleFolder: { + title: 'Toggle folder', + fn: function(e) { + e = e || {}; + var cs = require('views/feedList').selectedItems; + if (cs.length && cs[0].$el.hasClass('folder')) { + cs[0].handleClickArrow(e); + } + } + }, + showArticles: { + title: 'Show articles', + fn: function(e) { + e = e || {}; + var t = e.target || {}; + var feedList = require('views/feedList'); + var feeds = feedList.getSelectedFeeds(); + var ids = _.pluck(feeds, 'id'); + var special = $('.special.selected').get(0); + if (special) special = special.view.model; + + app.trigger('select:' + feedList.el.id, { + action: 'new-select', + feeds: ids, + // _.extend is important, because otherwise it would be sent by reference + filter: special ? _.extend({}, special.get('filter')) : null, + name: special ? special.get('name') : null, + unreadOnly: !!e.altKey || t.className == 'source-counter' + }); + + + if (special && special.get('name') == 'all-feeds') { + bg.sources.forEach(function(source) { + if (source.get('hasNew')) { + source.save({ hasNew: false }); + } + }); + + } else if (ids.length) { + bg.sources.forEach(function(source) { + if (source.get('hasNew') && ids.indexOf(source.id) >= 0) { + source.save({ hasNew: false }); + } + }); + } + } + }, + showAndFocusArticles: { + title: 'Show and focus articles', + fn: function(e) { + e = e || {}; + var cs = require('views/feedList').selectedItems; + if (cs.length) { + app.actions.execute('feeds:showArticles', e); + app.actions.execute('articles:focus'); + } + } + } + }, + articles: { + mark: { + icon: 'read.png', + title: Locale.c.MARK_AS_READ, + fn: function() { + require('views/articleList').changeUnreadState(); + } + }, + update: { + icon: 'reload.png', + title: Locale.c.UPDATE, + fn: function() { + var list = require('views/articleList'); + if (list.currentData.feeds.length) { + list.currentData.feeds.forEach(function(id) { + bg.loader.downloadOne(bg.sources.get(id)); + }); + } else { + bg.loader.downloadAll(true); // true = force + } + } + }, + delete: { + icon: 'delete.png', + title: Locale.c.DELETE, + fn: function(e) { + var list = require('views/articleList'); + if (list.currentData.name == 'trash' || e.shiftKey) { + list.destroyBatch(list.selectedItems, list.removeItemCompletely); + } else { + list.destroyBatch(list.selectedItems, list.removeItem); + } + } + }, + undelete: { + icon: 'undelete.png', + title: Locale.c.UNDELETE, + fn: function() { + var articleList = require('views/articleList'); + if (!articleList.selectedItems || !articleList.selectedItems.length || articleList.currentData.name != 'trash') return; + articleList.destroyBatch(articleList.selectedItems, articleList.undeleteItem); + } + }, + selectNext: { + fn: function(e) { + require('views/articleList').selectNext(e); + } + }, + selectPrevious: { + fn: function(e) { + require('views/articleList').selectPrev(e); + } + }, + search: { + title: Locale.c.SEARCH_TIP, + fn: function(e) { + e = e || { currentTarget: $('input[type=search]').get(0) }; + var str = e.currentTarget.value || ''; + var list = require('views/articleList'); + if (str == '') { + $('.date-group').css('display', 'block'); + } else { + $('.date-group').css('display', 'none'); + } + + var searchInContent = false; + if (str[0] && str[0] == ':') { + str = str.replace(/^:/, '', str); + searchInContent = true; + } + var rg = new RegExp(RegExp.escape(str), 'i'); + list.views.some(function(view) { + if (!view.model) return true; + if (rg.test(view.model.get('title')) || rg.test(view.model.get('author')) || (searchInContent && rg.test(view.model.get('content')) )) { + view.$el.removeClass('invisible'); + } else { + view.$el.addClass('invisible'); + } + }); + + list.redraw(); + + list.restartSelection(); + } + }, + focusSearch: { + title: 'Focus Search', + fn: function() { + $('input[type=search]').focus(); + } + }, + focus: { + title: 'Focus Articles', + fn: function() { + app.setFocus('articles'); + } + }, + fullArticle: { + title: Locale.c.FULL_ARTICLE, + icon: 'full_article.png', + fn: function(e) { + var articleList = app.articles.articleList; + if (!articleList.selectedItems || !articleList.selectedItems.length) return; + if (articleList.selectedItems.length > 10 && bg.settings.get('askOnOpening')) { + if (!confirm('Do you really want to open ' + articleList.selectedItems.length + ' articles?')) { + return; + } + } + articleList.selectedItems.forEach(function(item) { + chrome.tabs.create({ url: stripTags(item.model.get('url')), active: !e.shiftKey }); + }); + } + }, + oneFullArticle: { + title: 'One full article', + fn: function(e) { + e = e || {}; + var articleList = app.articles.articleList; + var view; + if ('currentTarget' in e) { + view = e.currentTarget.view; + } else { + if (!articleList.selectedItems || !articleList.selectedItems.length) return; + view = articleList.selectedItems[0]; + } + if (view.model) { + chrome.tabs.create({ url: stripTags(view.model.get('url')), active: !e.shiftKey }); + } + } + }, + markAndNextUnread: { + title: Locale.c.MARK_AND_NEXT_UNREAD, + icon: 'find_next.png', + fn: function() { + require('views/articleList').changeUnreadState({ onlyToRead: true }); + require('views/articleList').selectNext({ selectUnread: true }); + } + }, + markAndPrevUnread: { + title: Locale.c.MARK_AND_PREV_UNREAD, + icon: 'find_previous.png', + fn: function() { + require('views/articleList').changeUnreadState({ onlyToRead: true }); + require('views/articleList').selectPrev({ selectUnread: true }); + } + }, + nextUnread: { + title: Locale.c.NEXT_UNREAD, + icon: 'forward.png', + fn: function() { + require('views/articleList').selectNext({ selectUnread: true }); + } + }, + prevUnread: { + title: Locale.c.PREV_UNREAD, + icon: 'back.png', + fn: function() { + require('views/articleList').selectPrev({ selectUnread: true }); + } + }, + markAllAsRead: { + title: Locale.c.MARK_ALL_AS_READ, + icon: 'read.png', + fn: function() { + var articleList = require('views/articleList'); + var f = articleList.currentData.feeds; + var filter = articleList.currentData.filter; + if (f.length) { + (filter ? bg.items.where(articleList.currentData.filter) : bg.items).forEach(function(item) { + if (item.get('unread') == true && f.indexOf(item.get('sourceID')) >= 0) { + item.save({ unread: false, visited: true }); + } + }); + } else if (articleList.currentData.name == 'all-feeds') { + if (confirm(Locale.c.MARK_ALL_QUESTION)) { + bg.items.forEach(function(item) { + if (item.get('unread') == true) { + item.save({ unread: false, visited: true }); + } + }); + } + } else if (articleList.currentData.filter) { + bg.items.where(articleList.specialFilter).forEach(function(item) { + item.save({ unread: false, visited: true }); + }); + } + } + }, + selectAll: { + title: 'Select All', + fn: function() { + var articleList = require('views/articleList'); + articleList.$el.find('.selected').removeClass('selected'); + articleList.selectedItems = []; + + articleList.$el.find('.item:not(.invisible)').each(function(i, item) { + item.view.$el.addClass('selected'); + articleList.selectedItems.push(item.view); + }); + + articleList.$el.find('.last-selected').removeClass('last-selected'); + articleList.$el.find('.item:not(.invisible):last').addClass('last-selected'); + } + }, + pin: { + title: Locale.c.PIN, + icon: 'pinsource_context.png', + fn: function() { + var articleList = require('views/articleList'); + if (!articleList.selectedItems || !articleList.selectedItems.length) return; + var val = !articleList.selectedItems[0].model.get('pinned'); + articleList.selectedItems.forEach(function(item) { + item.model.save({ pinned: val }); + }); + } + }, + spaceThrough: { + title: 'Space Through', + fn: function() { + var articleList = require('views/articleList'); + if (!articleList.selectedItems || !articleList.selectedItems.length) return; + app.trigger('space-pressed'); + } + }, + pageUp: { + title: 'Page up', + fn: function() { + var el = require('views/articleList').el; + el.scrollByPages(-1); + } + }, + pageDown: { + title: 'Page down', + fn: function() { + var el = require('views/articleList').el; + el.scrollByPages(1); + } + }, + scrollToBottom: { + title: 'Scroll to bottom', + fn: function() { + var el = require('views/articleList').el; + el.scrollTop = el.scrollHeight; + } + }, + scrollToTop: { + title: 'Scroll to top', + fn: function() { + var el = require('views/articleList').el; + el.scrollTop = 0; + } + }, + download: { + title: Locale.c.DOWNLOAD, + icon: 'save.png', + fn: function() { + var contentView = require('views/contentView'); + var articleList = require('views/articleList'); + if (!articleList.selectedItems.length) { + app.actions.execute('content:download'); + return; + } + var tpl = contentView.downloadTemplate; + + var list = {}; + list.articles = articleList.selectedItems.map(function(itemView) { + var attrs = Object.create(itemView.model.attributes); + attrs.date = contentView.getFormatedDate(attrs.date); + return attrs; + }); + + var blob = new Blob([ tpl(list) ], { type: 'text\/html' }); + var reader = new FileReader(); + reader.readAsDataURL(blob); + reader.onload = function() { + window.open(this.result.replace('data:text/html;', 'data:text/html;charset=utf-8;')); + }; + /*var url = URL.createObjectURL(blob); + window.open(url); + setTimeout(function() { + URL.revokeObjectURL(url); + }, 30000);*/ + } + } + }, + content: { + download: { + title: Locale.c.DOWNLOAD, + icon: 'save.png', + fn: function() { + var contentView = require('views/contentView'); + if (!contentView.model) return; + var tpl = contentView.downloadTemplate; + var attrs = Object.create(contentView.model.attributes); + attrs.date = contentView.getFormatedDate(attrs.date); + var list = { articles: [attrs] }; + var blob = new Blob([ tpl(list) ], { type: 'text\/html' }); + var reader = new FileReader(); + reader.readAsDataURL(blob); + reader.onload = function() { + window.open(this.result.replace('data:text/html;', 'data:text/html;charset=utf-8;')); + }; + /*var url = URL.createObjectURL(blob); + window.open(url); + setTimeout(function() { + URL.revokeObjectURL(url); + }, 30000);*/ + } + }, + print: { + title: Locale.c.PRINT, + icon: 'print.png', + fn: function() { + var contentView = require('views/contentView'); + if (!contentView.model) return; + window.print(); + } + }, + mark: { + title: Locale.c.MARK_AS_READ, + icon: 'read.png', + fn: function() { + var contentView = require('views/contentView'); + if (!contentView.model) return; + contentView.model.save({ + unread: !contentView.model.get('unread'), + visited: true + }); + } + }, + delete: { + title: Locale.c.DELETE, + icon: 'delete.png', + fn: function(e) { + var contentView = require('views/contentView'); + if (!contentView.model) return; + + askRmPinned = bg.settings.get('askRmPinned'); + + if (e.shiftKey) { + if (contentView.model.get('pinned') && askRmPinned && askRmPinned != 'none') { + let conf = confirm(Locale.c.PIN_QUESTION_A + contentView.model.escape('title') + Locale.c.PIN_QUESTION_B); + if (!conf) { + return; + } + } + + contentView.model.markAsDeleted(); + } else { + if (contentView.model.get('pinned') && askRmPinned == 'all') { + let conf = confirm(Locale.c.PIN_QUESTION_A + contentView.model.escape('title') + Locale.c.PIN_QUESTION_B); + if (!conf) { + return; + } + } + + contentView.model.save({ + trashed: true, + visited: true + }); + } + } + }, + showConfig: { + title: Locale.c.SETTINGS, + icon: 'config.png', + fn: function() { + app.content.overlay.show(); + } + }, + focus: { + title: 'Focus Article', + fn: function() { + app.setFocus('content'); + } + }, + focusSandbox: { + title: 'Focus Article', + fn: function() { + app.content.sandbox.el.focus(); + } + }, + scrollDown: { + title: 'Scroll down', + fn: function() { + var cw = $('iframe').get(0).contentWindow; + cw.scrollBy(0, 40); + } + }, + scrollUp: { + title: 'Scroll up', + fn: function() { + var cw = $('iframe').get(0).contentWindow; + cw.scrollBy(0, -40); + } + }, + spaceThrough: { + title: 'Space trough', + fn: function() { + require('views/contentView').handleSpace(); + } + }, + pageUp: { + title: 'Page up', + fn: function() { + var cw = $('iframe').get(0).contentWindow; + var d = $('iframe').get(0).contentWindow.document; + cw.scrollBy(0, -d.documentElement.clientHeight * 0.85); + } + }, + pageDown: { + title: 'Page down', + fn: function() { + var cw = $('iframe').get(0).contentWindow; + var d = $('iframe').get(0).contentWindow.document; + cw.scrollBy(0, d.documentElement.clientHeight * 0.85); + } + }, + scrollToBottom: { + title: 'Scroll to bottom', + fn: function() { + var cw = $('iframe').get(0).contentWindow; + var d = $('iframe').get(0).contentWindow.document; + cw.scrollTo(0, d.documentElement.offsetHeight); + } + }, + scrollToTop: { + title: 'Scroll to top', + fn: function() { + var cw = $('iframe').get(0).contentWindow; + cw.scrollTo(0, 0); + } + } + } + +}; // end actions object }); // end define function \ No newline at end of file From 339f2225e2778148246d1a79bd93e3c4989a00da Mon Sep 17 00:00:00 2001 From: zakius Date: Fri, 15 Feb 2019 22:29:52 +0100 Subject: [PATCH 011/965] fix errors found by jshint --- scripts/app/views/articleList.js | 1640 +++++++++++++++--------------- 1 file changed, 820 insertions(+), 820 deletions(-) diff --git a/scripts/app/views/articleList.js b/scripts/app/views/articleList.js index b023b694..24b82d2d 100644 --- a/scripts/app/views/articleList.js +++ b/scripts/app/views/articleList.js @@ -1,821 +1,821 @@ -/** - * @module App - * @submodule views/articleList - */ -define([ - 'backbone', 'underscore', 'jquery', 'collections/Groups', 'models/Group', 'views/GroupView', - 'views/ItemView', 'mixins/selectable', 'modules/Locale' -], -function (BB, _, $, Groups, Group, GroupView, ItemView, selectable, Locale) { - - function isScrolledIntoView(elem) { - if (!screen) { - bg.sources.trigger('clear-events', -1); - return false; - } - - var docViewTop = 0; - var docViewBottom = screen.height; - - var rect = elem.getBoundingClientRect(); - var elemTop = rect.top; - var elemBottom = elemTop + rect.height; - - return (elemBottom >= docViewTop) && (elemTop <= docViewBottom); - /* && (elemBottom <= docViewBottom) && (elemTop >= docViewTop) ;*/ - } - - var groups = new Groups(); - - - /** - * List of articles - * @class ArticleListView - * @constructor - * @extends Backbone.View - */ - var ArticleListView = BB.View.extend({ - /** - * Height of one article item (changes with layout and rems) - * @property _itemHeight - * @default 0 - * @type Number - */ - _itemHeight: 0, - - /** - * Tag name of article list element - * @property tagName - * @default 'div' - * @type String - */ - tagName: 'div', - - /** - * ID of article list - * @property id - * @default 'article-list' - * @type String - */ - id: 'article-list', - - /** - * Class of article views - * @property itemClass - * @default 'item' - * @type string - */ - itemClass: 'item', - - /** - * Unordered list of all article views - * @property views - * @default [] - * @type Array - */ - views: [], - - /** - * Order list of yet rendered article views - * @property viewsToRender - * @default [] - * @type Array - */ - viewsToRender: [], - - - /** - * Data received from feedList about current selection (feed ids, name of special, filter, unreadOnly) - * @property currentData - * @default { feeds: [], name: 'all-feeds', filter: { trashed: false}, unreadOnly: false } - * @type Object - */ - currentData: { - feeds: [], - name: 'all-feeds', - filter: { trashed: false }, - unreadOnly: false - }, - - /** - * Flag to prevent focusing more items in one tick - * @property noFocus - * @default false - * @type Boolean - */ - noFocus: false, - - /** - * All article views - unattached views - * @property reuseIndex - * @default 0 - * @type Integer - */ - reuseIndex: 0, - - events: { - 'dragstart .item': 'handleDragStart', - 'mousedown .item': 'handleMouseDown', - 'mouseup .item': 'handleMouseUp', - 'dblclick .item': 'handleItemDblClick', - 'mousedown .item-pin,.item-pinned': 'handleClickPin', - }, - - /** - * Opens articles url in new tab - * @method handleItemDblClick - * @triggered on double click on article - */ - handleItemDblClick: function() { - app.actions.execute('articles:oneFullArticle'); - }, - - /** - * Selects article - * @method handleMouseDown - * @triggered on mouse down on article - * @param event {MouseEvent} - */ - handleMouseDown: function(e) { - this.handleSelectableMouseDown(e); - }, - - /** - * Changes pin state - * @method handleClickPin - * @triggered on click on pin button - * @param event {MouseEvent} - */ - handleClickPin: function(e) { - e.currentTarget.parentNode.view.handleClickPin(e); - }, - - /** - * Calls neccesary slect methods - * @method handleMouseUp - * @triggered on mouse up on article - * @param event {MouseEvent} - */ - handleMouseUp: function(e) { - e.currentTarget.view.handleMouseUp(e); - this.handleSelectableMouseUp(e); - }, - - /** - * Called when new instance is created - * @method initialize - */ - initialize: function() { - - this.$el.addClass('lines-' + bg.settings.get('lines')); - bg.items.on('reset', this.addItems, this); - bg.items.on('add', this.addItem, this); - bg.items.on('sort', this.handleSort, this); - bg.items.on('render-screen', this.handleRenderScreen, this); - bg.settings.on('change:lines', this.handleChangeLines, this); - bg.settings.on('change:layout', this.handleChangeLayout, this); - bg.sources.on('destroy', this.handleSourcesDestroy, this); - bg.sources.on('clear-events', this.handleClearEvents, this); - - groups.on('add', this.addGroup, this); - - this.on('attach', this.handleAttached, this); - this.on('pick', this.handlePick, this); - - - this.$el.on('scroll', this.handleScroll.bind(this)); - - }, - - /** - * Sends msg to show selected article - * @method handlePick - * @triggered when one article is selected - * @param view {views/ItemView} - */ - handlePick: function(view) { - if (!view.model.collection) { - // This shouldn't usually happen - // It might happen when source is deleted and created in the same tick - return; - } - - app.trigger('select:' + this.el.id, { action: 'new-select', value: view.model.id }); - - if (view.model.get('unread') && bg.settings.get('readOnVisit')) { - view.model.save({ - visited: true, - unread: false - }); - } else if (!view.model.get('visited')) { - view.model.save('visited', true); - } - }, - - /** - * Sets comm event listeners - * @method handleAttached - * @triggered when article list is attached to DOM - */ - handleAttached: function() { - - app.on('select:feed-list', function(data) { - this.el.scrollTop = 0; - this.unreadOnly = data.unreadOnly; - - if (data.action == 'new-select') { - this.handleNewSelected(data); - } - }, this); - - app.on('give-me-next', function() { - if (this.selectedItems[0] && this.selectedItems[0].model.get('unread') == true) { - this.selectedItems[0].model.save({ unread: false }); - } - this.selectNext({ selectUnread: true }); - }, this); - - if (bg.sourceToFocus) { - setTimeout(function() { - app.trigger('focus-feed', bg.sourceToFocus); - bg.sourceToFocus = null; - }, 0); - } else { - this.loadAllFeeds(); - } - }, - - /** - * Loads all untrashed feeds - * @method loadAllFeeds - * @chainable - */ - loadAllFeeds: function() { - var that = this; - setTimeout(function() { - app.trigger('select-all-feeds'); - - var unread = bg.items.where({ trashed: false, unread: true }); - if (unread.length) { - that.addItems(unread); - } else { - that.addItems(bg.items.where({ trashed: false })); - } - }, 0); - - return this; - }, - - /** - * Renders unrendered articles in view by calling handleScroll - * @method handleRenderScreen - * @triggered when new items arr added or when source is destroyed - */ - handleRenderScreen: function() { - this.redraw(); - if ($('input[type=search]').val()) { - app.actions.execute('articles:search'); - } - }, - - /** - * Calls redraw when user scrolls in list - * @method handleScroll - * @triggered when list is scrolled (and is called from many other places) - */ - handleScroll: function() { - this.redraw(); - }, - - /** - * Renders unrendered articles in view - * @method redraw - */ - redraw: function() { - var start = -1; - var count = 0; - for (var i=0,j=this.viewsToRender.length; i= 0 && count % 10 != 0) || isScrolledIntoView(this.viewsToRender[i].el)) { - this.viewsToRender[i].render(); - count++; - if (start == -1) start = i; - } else if (start >= 0) { - break; - } - } - - - if (start >= 0 && count > 0) { - this.viewsToRender.splice(start, count); - } - }, - - /** - * Unbinds all listeners to bg process - * @method handleClearEvents - * @triggered when tab is closed/refershed - * @param id {Integer} id of the closed tab - */ - handleClearEvents: function(id) { - if (window == null || id == tabID) { - bg.items.off('reset', this.addItems, this); - bg.items.off('add', this.addItem, this); - bg.items.off('sort', this.handleSort, this); - bg.items.off('render-screen', this.handleRenderScreen, this); - bg.settings.off('change:lines', this.handleChangeLines, this); - bg.settings.off('change:layout', this.handleChangeLayout, this); - - bg.sources.off('destroy', this.handleSourcesDestroy, this); - - bg.sources.off('clear-events', this.handleClearEvents, this); - } - }, - - /** - * Sets new article item height and rerenders list - * @method handleChangeLayout - * @triggered when layout setting is changed - */ - handleChangeLayout: function() { - var that = this; - requestAnimationFrame(function() { - that.setItemHeight(); - that.handleScroll(); - }); - }, - - /** - * Clears searchbox and sorts the list - * @method handleSort - * @triggered when sort setting is changed - */ - handleSort: function() { - $('#input-search').val(''); - - this.handleNewSelected(this.currentData); - - }, - - /** - * Adds or removes neccesary one-line/twoline classes for given lines settings - * @method handleChangeLines - * @triggered when lines setting is changed - * @param settings {Settings} bg.Settings - */ - handleChangeLines: function(settings) { - this.$el.removeClass('lines-auto'); - this.$el.removeClass('lines-one-line'); - this.$el.removeClass('lines-two-lines'); - // this.$el.removeClass('lines-' + settings.previous('lines')); // does not work for some reason - this.$el.addClass('lines-' + settings.get('lines')); - }, - - /** - * Stores ids of dragged items - * @method handleDragStart - * @triggered on drag start - * @param event {DragEvent} - */ - handleDragStart: function(e) { - var ids = this.selectedItems.map(function(view) { - return view.model.id; - }); - - e.originalEvent.dataTransfer.setData('text/plain', JSON.stringify(ids)); - }, - - /** - * Selects new item when the last selected is deleted - * @method selectAfterDelete - * @param view {views/ItemView} - */ - selectAfterDelete: function(view) { - if (view == this.selectedItems[0]) { - var last = this.$el.find('.item:not(.invisible):last').get(0); - if (last && view == last.view) { - this.selectPrev({ currentIsRemoved: true }); - } else { - this.selectNext({ currentIsRemoved: true }); - } - } else { - // if first item is the last item to be deleted, selecting it will trigger error - rAF to get around it - requestAnimationFrame(function() { - this.selectFirst(); - }.bind(this)); - } - }, - - /** - * Tests whether newly fetched item should be added to current list. - * (If the item's feed is selected) - * @method inCurrentData - * @return Boolean - * @param item {Item} bg.Item - */ - inCurrentData: function(item) { - var f = this.currentData.feeds; - if (!f.length) { - if (!this.currentData.filter) { - return true; - } else if (item.query(this.currentData.filter)) { - return true; - } - } else if (f.indexOf(item.get('sourceID')) >= 0) { - return true; - } - - return false; - }, - - /** - * Adds new article item to the list - * @method addItem - * @param item {Item} bg.Item - * @param noManualSort {Boolean} true when adding items in a batch in right order - */ - addItem: function(item, noManualSort) { - - //Don't add newly fetched items to middle column, when they shouldn't be - if (noManualSort !== true && !this.inCurrentData(item)) { - return false; - } - - - - var after = null; - if (noManualSort !== true) { - $.makeArray($('#article-list .item, #article-list .date-group')).some(function(itemEl) { - if (bg.items.comparator(itemEl.view.model, item) === 1) { - after = itemEl; - return true; - } - }); - } - - var view; - - if (!after) { - if (this.reuseIndex >= this.views.length) { - view = new ItemView({ model: item }, this); - if (!this._itemHeight) { - view.render(); - } else { - view.$el.css('height', this._itemHeight + 'px'); - view.prerender(); - } - this.$el.append(view.$el); - this.views.push(view); - } else { - view = this.views[this.reuseIndex]; - view.swapModel(item); - } - - if (!this.selectedItems.length) this.select(view); - } else { - view = new ItemView({ model: item }, this); - view.render().$el.insertBefore($(after)); - - // weee, this is definitelly not working 100% right :D or is it? - var indexElement = after.view instanceof ItemView ? after : after.nextElementSibling; - var index = indexElement ? this.views.indexOf(indexElement.view) : -1; - if (index == -1) index = this.reuseIndex; - - this.views.splice(index, 0, view); - } - - if (!this._itemHeight) { - this._itemHeight = view.el.getBoundingClientRect().height; - } - - - if (!bg.settings.get('disableDateGroups') && bg.settings.get('sortBy') == 'date') { - var group = Group.getGroup(item.get('date')); - if (!groups.findWhere({ title: group.title })) { - groups.add(new Group(group), { before: view.el }); - } - } - - this.reuseIndex++; - }, - - /** - * Adds new date group to the list - * @method addGroup - * @param model {models/Group} group create by groups.create - * @param col {collections/Groups} - * @param opt {Object} options { before: insertBeforeItem } - */ - addGroup: function(model, col, opt) { - var before = opt.before; - var view = new GroupView({ model: model }, groups); - - - view.render().$el.insertBefore(before); - }, - - /** - * Gets the height of one article items and stores it. - * @method setItemHeight - */ - setItemHeight: function() { - var firstItem = this.$el.find('.item:not(.invisible):first'); - if (firstItem.length) { - this._itemHeight = firstItem.get(0).getBoundingClientRect().height; - } - }, - - /** - * Removes everything from lists and adds new collectino of articles - * @method setItemHeight - * @param items {Backbone.Collection} bg.Items - */ - addItems: function(items) { - - groups.reset(); - - - /** - * Select removal - */ - this.selectedItems = []; - this.viewsToRender = []; - this.$el.find('.selected').removeClass('.selected'); - this.$el.find('.last-selected').removeClass('.last-selected'); - this.selectPivot = null; - /* --- */ - - //var st = Date.now(); - - this.setItemHeight(); - - this.reuseIndex = 0; - - - - items.forEach(function(item) { - this.addItem(item, true); - }, this); - - for (var i=this.reuseIndex, j = this.views.length; i < j; i++) { - if (!this.views[i].model) break; - this.views[i].unplugModel(); - } - - this.redraw(); - - if ($('input[type=search]').val()) { - app.actions.execute('articles:search'); - } - - //alert(Date.now() - st); - - }, - - /** - * Called every time when new feed is selected and before it is rendered - * @method clearOnSelect - */ - clearOnSelect: function() { - // Smart RSS used to reset search on feed select change. It instead keeps the fitler now. - //$('input[type=search]').val(''); - - // if prev selected was trash, hide undelete buttons - if (this.currentData.name == 'trash') { - /*$('[data-action="articles:update"]').css('display', 'block'); - $('[data-action="articles:undelete"]').css('display', 'none');*/ - app.articles.toolbar.showItems('articles:update'); - app.articles.toolbar.hideItems('articles:undelete'); - $('#context-undelete').css('display', 'none'); - } - - this.currentData = { - feeds: [], - name: 'all-feeds', - filter: { trashed: false }, - unreadOnly: false - }; - - }, - - /** - * Called every time when new feed is selected. Gets the right data from store. - * @method handleNewSelected - * @param data {Object} data object received from feed list - */ - handleNewSelected: function(data) { - this.clearOnSelect(); - this.currentData = data; - - var searchIn = null; - if (data.filter) { - searchIn = bg.items.where(data.filter); - } else { - searchIn = bg.items.where({ trashed: false }); - } - - // if newly selected is trash - if (this.currentData.name == 'trash') { - app.articles.toolbar.hideItems('articles:update').showItems('articles:undelete'); - $('#context-undelete').css('display', 'block'); - } - - var items = searchIn.filter(function(item) { - if (!item.get('unread') && this.unreadOnly) return false; - return data.name || data.feeds.indexOf(item.get('sourceID')) >= 0; - }, this); - - this.addItems( items ); - }, - - - /** - * If current feed is removed, select all feeds - * @triggered when any source is destroyed - * @method handleSourcesDestroy - * @param source {Source} Destroyed source - */ - handleSourcesDestroy: function(source) { - - var that = this; - var d = this.currentData; - var index = d.feeds.indexOf(source.id); - - if (index >= 0) { - d.feeds.splice(index, 1); - } - - if (!d.feeds.length && !d.filter) { - - this.clearOnSelect(); - - if (document.querySelector('.item')) { - this.once('items-destroyed', function() { - that.loadAllFeeds(); - }, this); - } else { - this.loadAllFeeds(); - } - } - - }, - - /** - * Moves item from trash back to its original source - * @method undeleteItem - * @param view {views/ItemView} Undeleted article view - */ - undeleteItem: function(view) { - view.model.save({ - 'trashed': false - }); - this.destroyItem(view); - }, - - /** - * Moves item to trash - * @method removeItem - * @param view {views/ItemView} Removed article view - */ - removeItem: function(view) { - askRmPinned = bg.settings.get('askRmPinned') - if (view.model.get('pinned') && askRmPinned == 'all') { - var conf = confirm(Locale.c.PIN_QUESTION_A + view.model.escape('title') + Locale.c.PIN_QUESTION_B); - if (!conf) { - return; - } - } - view.model.save({ trashed: true, visited: true }); - //this.destroyItem(view); - }, - - /** - * Removes item from both source and trash leaving only info it has been already fetched and deleted - * @method removeItemCompletely - * @param view {views/ItemView} Removed article view - */ - removeItemCompletely: function(view) { - askRmPinned = bg.settings.get('askRmPinned') - if (view.model.get('pinned') && askRmPinned && askRmPinned != 'none') { - var conf = confirm(Locale.c.PIN_QUESTION_A + view.model.escape('title') + Locale.c.PIN_QUESTION_B); - if (!conf) { - return; - } - } - view.model.markAsDeleted(); - //this.destroyItem(view); - }, - - /** - * Calls undeleteItem/removeItem/removeItemCompletely in a batch for several items - * @method destroyBatch - * @param arr {Array} List of views - * @param fn {Function} Function to be called on each view - */ - destroyBatch: function(arr, fn) { - for (var i=0, j=arr.length; i= 0) this.selectedItems.splice(io, 1); - io = this.views.indexOf(view); - if (io >= 0) this.views.splice(io, 1); - io = this.viewsToRender.indexOf(view); - if (io >= 0) this.viewsToRender.splice(io, 1); - - this.reuseIndex--; - if (this.reuseIndex < 0) { - this.reuseIndex = 0; - console.log('reuse index under zero'); - } - }, - - /** - * Toggles unread state of selected items (with onlyToRead option) - * @method changeUnreadState - * @param opt {Object} Options { onlyToRead: bool } - */ - changeUnreadState: function(opt) { - opt = opt || {}; - var val = this.selectedItems.length && !opt.onlyToRead ? !this.selectedItems[0].model.get('unread') : false; - this.selectedItems.forEach(function(item) { - if (!opt.onlyToRead || item.model.get('unread') == true) { - item.model.save({ unread: val, visited: true }); - } - - }, this); - } - }); - - ArticleListView = ArticleListView.extend(selectable); - - return new ArticleListView(); +/** + * @module App + * @submodule views/articleList + */ +define([ + 'backbone', 'underscore', 'jquery', 'collections/Groups', 'models/Group', 'views/GroupView', + 'views/ItemView', 'mixins/selectable', 'modules/Locale' +], +function (BB, _, $, Groups, Group, GroupView, ItemView, selectable, Locale) { + + function isScrolledIntoView(elem) { + if (!screen) { + bg.sources.trigger('clear-events', -1); + return false; + } + + var docViewTop = 0; + var docViewBottom = screen.height; + + var rect = elem.getBoundingClientRect(); + var elemTop = rect.top; + var elemBottom = elemTop + rect.height; + + return (elemBottom >= docViewTop) && (elemTop <= docViewBottom); + /* && (elemBottom <= docViewBottom) && (elemTop >= docViewTop) ;*/ + } + + var groups = new Groups(); + + + /** + * List of articles + * @class ArticleListView + * @constructor + * @extends Backbone.View + */ + var ArticleListView = BB.View.extend({ + /** + * Height of one article item (changes with layout and rems) + * @property _itemHeight + * @default 0 + * @type Number + */ + _itemHeight: 0, + + /** + * Tag name of article list element + * @property tagName + * @default 'div' + * @type String + */ + tagName: 'div', + + /** + * ID of article list + * @property id + * @default 'article-list' + * @type String + */ + id: 'article-list', + + /** + * Class of article views + * @property itemClass + * @default 'item' + * @type string + */ + itemClass: 'item', + + /** + * Unordered list of all article views + * @property views + * @default [] + * @type Array + */ + views: [], + + /** + * Order list of yet rendered article views + * @property viewsToRender + * @default [] + * @type Array + */ + viewsToRender: [], + + + /** + * Data received from feedList about current selection (feed ids, name of special, filter, unreadOnly) + * @property currentData + * @default { feeds: [], name: 'all-feeds', filter: { trashed: false}, unreadOnly: false } + * @type Object + */ + currentData: { + feeds: [], + name: 'all-feeds', + filter: { trashed: false }, + unreadOnly: false + }, + + /** + * Flag to prevent focusing more items in one tick + * @property noFocus + * @default false + * @type Boolean + */ + noFocus: false, + + /** + * All article views - unattached views + * @property reuseIndex + * @default 0 + * @type Integer + */ + reuseIndex: 0, + + events: { + 'dragstart .item': 'handleDragStart', + 'mousedown .item': 'handleMouseDown', + 'mouseup .item': 'handleMouseUp', + 'dblclick .item': 'handleItemDblClick', + 'mousedown .item-pin,.item-pinned': 'handleClickPin', + }, + + /** + * Opens articles url in new tab + * @method handleItemDblClick + * @triggered on double click on article + */ + handleItemDblClick: function() { + app.actions.execute('articles:oneFullArticle'); + }, + + /** + * Selects article + * @method handleMouseDown + * @triggered on mouse down on article + * @param event {MouseEvent} + */ + handleMouseDown: function(e) { + this.handleSelectableMouseDown(e); + }, + + /** + * Changes pin state + * @method handleClickPin + * @triggered on click on pin button + * @param event {MouseEvent} + */ + handleClickPin: function(e) { + e.currentTarget.parentNode.view.handleClickPin(e); + }, + + /** + * Calls neccesary slect methods + * @method handleMouseUp + * @triggered on mouse up on article + * @param event {MouseEvent} + */ + handleMouseUp: function(e) { + e.currentTarget.view.handleMouseUp(e); + this.handleSelectableMouseUp(e); + }, + + /** + * Called when new instance is created + * @method initialize + */ + initialize: function() { + + this.$el.addClass('lines-' + bg.settings.get('lines')); + bg.items.on('reset', this.addItems, this); + bg.items.on('add', this.addItem, this); + bg.items.on('sort', this.handleSort, this); + bg.items.on('render-screen', this.handleRenderScreen, this); + bg.settings.on('change:lines', this.handleChangeLines, this); + bg.settings.on('change:layout', this.handleChangeLayout, this); + bg.sources.on('destroy', this.handleSourcesDestroy, this); + bg.sources.on('clear-events', this.handleClearEvents, this); + + groups.on('add', this.addGroup, this); + + this.on('attach', this.handleAttached, this); + this.on('pick', this.handlePick, this); + + + this.$el.on('scroll', this.handleScroll.bind(this)); + + }, + + /** + * Sends msg to show selected article + * @method handlePick + * @triggered when one article is selected + * @param view {views/ItemView} + */ + handlePick: function(view) { + if (!view.model.collection) { + // This shouldn't usually happen + // It might happen when source is deleted and created in the same tick + return; + } + + app.trigger('select:' + this.el.id, { action: 'new-select', value: view.model.id }); + + if (view.model.get('unread') && bg.settings.get('readOnVisit')) { + view.model.save({ + visited: true, + unread: false + }); + } else if (!view.model.get('visited')) { + view.model.save('visited', true); + } + }, + + /** + * Sets comm event listeners + * @method handleAttached + * @triggered when article list is attached to DOM + */ + handleAttached: function() { + + app.on('select:feed-list', function(data) { + this.el.scrollTop = 0; + this.unreadOnly = data.unreadOnly; + + if (data.action == 'new-select') { + this.handleNewSelected(data); + } + }, this); + + app.on('give-me-next', function() { + if (this.selectedItems[0] && this.selectedItems[0].model.get('unread') == true) { + this.selectedItems[0].model.save({ unread: false }); + } + this.selectNext({ selectUnread: true }); + }, this); + + if (bg.sourceToFocus) { + setTimeout(function() { + app.trigger('focus-feed', bg.sourceToFocus); + bg.sourceToFocus = null; + }, 0); + } else { + this.loadAllFeeds(); + } + }, + + /** + * Loads all untrashed feeds + * @method loadAllFeeds + * @chainable + */ + loadAllFeeds: function() { + var that = this; + setTimeout(function() { + app.trigger('select-all-feeds'); + + var unread = bg.items.where({ trashed: false, unread: true }); + if (unread.length) { + that.addItems(unread); + } else { + that.addItems(bg.items.where({ trashed: false })); + } + }, 0); + + return this; + }, + + /** + * Renders unrendered articles in view by calling handleScroll + * @method handleRenderScreen + * @triggered when new items arr added or when source is destroyed + */ + handleRenderScreen: function() { + this.redraw(); + if ($('input[type=search]').val()) { + app.actions.execute('articles:search'); + } + }, + + /** + * Calls redraw when user scrolls in list + * @method handleScroll + * @triggered when list is scrolled (and is called from many other places) + */ + handleScroll: function() { + this.redraw(); + }, + + /** + * Renders unrendered articles in view + * @method redraw + */ + redraw: function() { + var start = -1; + var count = 0; + for (var i=0,j=this.viewsToRender.length; i= 0 && count % 10 != 0) || isScrolledIntoView(this.viewsToRender[i].el)) { + this.viewsToRender[i].render(); + count++; + if (start == -1) start = i; + } else if (start >= 0) { + break; + } + } + + + if (start >= 0 && count > 0) { + this.viewsToRender.splice(start, count); + } + }, + + /** + * Unbinds all listeners to bg process + * @method handleClearEvents + * @triggered when tab is closed/refershed + * @param id {Integer} id of the closed tab + */ + handleClearEvents: function(id) { + if (window == null || id == tabID) { + bg.items.off('reset', this.addItems, this); + bg.items.off('add', this.addItem, this); + bg.items.off('sort', this.handleSort, this); + bg.items.off('render-screen', this.handleRenderScreen, this); + bg.settings.off('change:lines', this.handleChangeLines, this); + bg.settings.off('change:layout', this.handleChangeLayout, this); + + bg.sources.off('destroy', this.handleSourcesDestroy, this); + + bg.sources.off('clear-events', this.handleClearEvents, this); + } + }, + + /** + * Sets new article item height and rerenders list + * @method handleChangeLayout + * @triggered when layout setting is changed + */ + handleChangeLayout: function() { + var that = this; + requestAnimationFrame(function() { + that.setItemHeight(); + that.handleScroll(); + }); + }, + + /** + * Clears searchbox and sorts the list + * @method handleSort + * @triggered when sort setting is changed + */ + handleSort: function() { + $('#input-search').val(''); + + this.handleNewSelected(this.currentData); + + }, + + /** + * Adds or removes neccesary one-line/twoline classes for given lines settings + * @method handleChangeLines + * @triggered when lines setting is changed + * @param settings {Settings} bg.Settings + */ + handleChangeLines: function(settings) { + this.$el.removeClass('lines-auto'); + this.$el.removeClass('lines-one-line'); + this.$el.removeClass('lines-two-lines'); + // this.$el.removeClass('lines-' + settings.previous('lines')); // does not work for some reason + this.$el.addClass('lines-' + settings.get('lines')); + }, + + /** + * Stores ids of dragged items + * @method handleDragStart + * @triggered on drag start + * @param event {DragEvent} + */ + handleDragStart: function(e) { + var ids = this.selectedItems.map(function(view) { + return view.model.id; + }); + + e.originalEvent.dataTransfer.setData('text/plain', JSON.stringify(ids)); + }, + + /** + * Selects new item when the last selected is deleted + * @method selectAfterDelete + * @param view {views/ItemView} + */ + selectAfterDelete: function(view) { + if (view == this.selectedItems[0]) { + var last = this.$el.find('.item:not(.invisible):last').get(0); + if (last && view == last.view) { + this.selectPrev({ currentIsRemoved: true }); + } else { + this.selectNext({ currentIsRemoved: true }); + } + } else { + // if first item is the last item to be deleted, selecting it will trigger error - rAF to get around it + requestAnimationFrame(function() { + this.selectFirst(); + }.bind(this)); + } + }, + + /** + * Tests whether newly fetched item should be added to current list. + * (If the item's feed is selected) + * @method inCurrentData + * @return Boolean + * @param item {Item} bg.Item + */ + inCurrentData: function(item) { + var f = this.currentData.feeds; + if (!f.length) { + if (!this.currentData.filter) { + return true; + } else if (item.query(this.currentData.filter)) { + return true; + } + } else if (f.indexOf(item.get('sourceID')) >= 0) { + return true; + } + + return false; + }, + + /** + * Adds new article item to the list + * @method addItem + * @param item {Item} bg.Item + * @param noManualSort {Boolean} true when adding items in a batch in right order + */ + addItem: function(item, noManualSort) { + + //Don't add newly fetched items to middle column, when they shouldn't be + if (noManualSort !== true && !this.inCurrentData(item)) { + return false; + } + + + + var after = null; + if (noManualSort !== true) { + $.makeArray($('#article-list .item, #article-list .date-group')).some(function(itemEl) { + if (bg.items.comparator(itemEl.view.model, item) === 1) { + after = itemEl; + return true; + } + }); + } + + var view; + + if (!after) { + if (this.reuseIndex >= this.views.length) { + view = new ItemView({ model: item }, this); + if (!this._itemHeight) { + view.render(); + } else { + view.$el.css('height', this._itemHeight + 'px'); + view.prerender(); + } + this.$el.append(view.$el); + this.views.push(view); + } else { + view = this.views[this.reuseIndex]; + view.swapModel(item); + } + + if (!this.selectedItems.length) this.select(view); + } else { + view = new ItemView({ model: item }, this); + view.render().$el.insertBefore($(after)); + + // weee, this is definitelly not working 100% right :D or is it? + var indexElement = after.view instanceof ItemView ? after : after.nextElementSibling; + var index = indexElement ? this.views.indexOf(indexElement.view) : -1; + if (index == -1) index = this.reuseIndex; + + this.views.splice(index, 0, view); + } + + if (!this._itemHeight) { + this._itemHeight = view.el.getBoundingClientRect().height; + } + + + if (!bg.settings.get('disableDateGroups') && bg.settings.get('sortBy') == 'date') { + var group = Group.getGroup(item.get('date')); + if (!groups.findWhere({ title: group.title })) { + groups.add(new Group(group), { before: view.el }); + } + } + + this.reuseIndex++; + }, + + /** + * Adds new date group to the list + * @method addGroup + * @param model {models/Group} group create by groups.create + * @param col {collections/Groups} + * @param opt {Object} options { before: insertBeforeItem } + */ + addGroup: function(model, col, opt) { + var before = opt.before; + var view = new GroupView({ model: model }, groups); + + + view.render().$el.insertBefore(before); + }, + + /** + * Gets the height of one article items and stores it. + * @method setItemHeight + */ + setItemHeight: function() { + var firstItem = this.$el.find('.item:not(.invisible):first'); + if (firstItem.length) { + this._itemHeight = firstItem.get(0).getBoundingClientRect().height; + } + }, + + /** + * Removes everything from lists and adds new collectino of articles + * @method setItemHeight + * @param items {Backbone.Collection} bg.Items + */ + addItems: function(items) { + + groups.reset(); + + + /** + * Select removal + */ + this.selectedItems = []; + this.viewsToRender = []; + this.$el.find('.selected').removeClass('.selected'); + this.$el.find('.last-selected').removeClass('.last-selected'); + this.selectPivot = null; + /* --- */ + + //var st = Date.now(); + + this.setItemHeight(); + + this.reuseIndex = 0; + + + + items.forEach(function(item) { + this.addItem(item, true); + }, this); + + for (var i=this.reuseIndex, j = this.views.length; i < j; i++) { + if (!this.views[i].model) break; + this.views[i].unplugModel(); + } + + this.redraw(); + + if ($('input[type=search]').val()) { + app.actions.execute('articles:search'); + } + + //alert(Date.now() - st); + + }, + + /** + * Called every time when new feed is selected and before it is rendered + * @method clearOnSelect + */ + clearOnSelect: function() { + // Smart RSS used to reset search on feed select change. It instead keeps the fitler now. + //$('input[type=search]').val(''); + + // if prev selected was trash, hide undelete buttons + if (this.currentData.name == 'trash') { + /*$('[data-action="articles:update"]').css('display', 'block'); + $('[data-action="articles:undelete"]').css('display', 'none');*/ + app.articles.toolbar.showItems('articles:update'); + app.articles.toolbar.hideItems('articles:undelete'); + $('#context-undelete').css('display', 'none'); + } + + this.currentData = { + feeds: [], + name: 'all-feeds', + filter: { trashed: false }, + unreadOnly: false + }; + + }, + + /** + * Called every time when new feed is selected. Gets the right data from store. + * @method handleNewSelected + * @param data {Object} data object received from feed list + */ + handleNewSelected: function(data) { + this.clearOnSelect(); + this.currentData = data; + + var searchIn = null; + if (data.filter) { + searchIn = bg.items.where(data.filter); + } else { + searchIn = bg.items.where({ trashed: false }); + } + + // if newly selected is trash + if (this.currentData.name == 'trash') { + app.articles.toolbar.hideItems('articles:update').showItems('articles:undelete'); + $('#context-undelete').css('display', 'block'); + } + + var items = searchIn.filter(function(item) { + if (!item.get('unread') && this.unreadOnly) return false; + return data.name || data.feeds.indexOf(item.get('sourceID')) >= 0; + }, this); + + this.addItems( items ); + }, + + + /** + * If current feed is removed, select all feeds + * @triggered when any source is destroyed + * @method handleSourcesDestroy + * @param source {Source} Destroyed source + */ + handleSourcesDestroy: function(source) { + + var that = this; + var d = this.currentData; + var index = d.feeds.indexOf(source.id); + + if (index >= 0) { + d.feeds.splice(index, 1); + } + + if (!d.feeds.length && !d.filter) { + + this.clearOnSelect(); + + if (document.querySelector('.item')) { + this.once('items-destroyed', function() { + that.loadAllFeeds(); + }, this); + } else { + this.loadAllFeeds(); + } + } + + }, + + /** + * Moves item from trash back to its original source + * @method undeleteItem + * @param view {views/ItemView} Undeleted article view + */ + undeleteItem: function(view) { + view.model.save({ + 'trashed': false + }); + this.destroyItem(view); + }, + + /** + * Moves item to trash + * @method removeItem + * @param view {views/ItemView} Removed article view + */ + removeItem: function(view) { + askRmPinned = bg.settings.get('askRmPinned'); + if (view.model.get('pinned') && askRmPinned == 'all') { + var conf = confirm(Locale.c.PIN_QUESTION_A + view.model.escape('title') + Locale.c.PIN_QUESTION_B); + if (!conf) { + return; + } + } + view.model.save({ trashed: true, visited: true }); + //this.destroyItem(view); + }, + + /** + * Removes item from both source and trash leaving only info it has been already fetched and deleted + * @method removeItemCompletely + * @param view {views/ItemView} Removed article view + */ + removeItemCompletely: function(view) { + askRmPinned = bg.settings.get('askRmPinned'); + if (view.model.get('pinned') && askRmPinned && askRmPinned != 'none') { + var conf = confirm(Locale.c.PIN_QUESTION_A + view.model.escape('title') + Locale.c.PIN_QUESTION_B); + if (!conf) { + return; + } + } + view.model.markAsDeleted(); + //this.destroyItem(view); + }, + + /** + * Calls undeleteItem/removeItem/removeItemCompletely in a batch for several items + * @method destroyBatch + * @param arr {Array} List of views + * @param fn {Function} Function to be called on each view + */ + destroyBatch: function(arr, fn) { + for (var i=0, j=arr.length; i= 0) this.selectedItems.splice(io, 1); + io = this.views.indexOf(view); + if (io >= 0) this.views.splice(io, 1); + io = this.viewsToRender.indexOf(view); + if (io >= 0) this.viewsToRender.splice(io, 1); + + this.reuseIndex--; + if (this.reuseIndex < 0) { + this.reuseIndex = 0; + console.log('reuse index under zero'); + } + }, + + /** + * Toggles unread state of selected items (with onlyToRead option) + * @method changeUnreadState + * @param opt {Object} Options { onlyToRead: bool } + */ + changeUnreadState: function(opt) { + opt = opt || {}; + var val = this.selectedItems.length && !opt.onlyToRead ? !this.selectedItems[0].model.get('unread') : false; + this.selectedItems.forEach(function(item) { + if (!opt.onlyToRead || item.model.get('unread') == true) { + item.model.save({ unread: val, visited: true }); + } + + }, this); + } + }); + + ArticleListView = ArticleListView.extend(selectable); + + return new ArticleListView(); }); \ No newline at end of file From 1f0eee47962b9f20c475a3c2a2a6002828f693ef Mon Sep 17 00:00:00 2001 From: zakius Date: Fri, 15 Feb 2019 22:33:24 +0100 Subject: [PATCH 012/965] update Gruntfile.js: make sure no future reserved keywords are used --- Gruntfile.js | 1 + 1 file changed, 1 insertion(+) diff --git a/Gruntfile.js b/Gruntfile.js index ada282c5..0bc349b2 100644 --- a/Gruntfile.js +++ b/Gruntfile.js @@ -30,6 +30,7 @@ module.exports = function(grunt) { '-W041': true, // don't warn about something == false/true '-W117': true, // don't warn about not defined vars until I refactorize bg.js, esversion: 6, + futurehostile: true, globals: { app: true, bg: true, From 1006f245732ee76c165f128279660e9faaa1ef6a Mon Sep 17 00:00:00 2001 From: zakius Date: Fri, 15 Feb 2019 23:09:01 +0100 Subject: [PATCH 013/965] update require.js --- Gruntfile.js | 4 ++-- scripts/libs/require.js | 41 +++++------------------------------------ 2 files changed, 7 insertions(+), 38 deletions(-) diff --git a/Gruntfile.js b/Gruntfile.js index 0bc349b2..c96ea18d 100644 --- a/Gruntfile.js +++ b/Gruntfile.js @@ -55,7 +55,7 @@ module.exports = function(grunt) { baseUrl: 'scripts/app', generateSourceMaps: true, preserveLicenseComments: false, - optimize: 'uglify2', + optimize: 'none', waitSeconds: 0, paths: { jquery: '../libs/jquery.min', @@ -87,7 +87,7 @@ module.exports = function(grunt) { baseUrl: 'scripts/bgprocess', generateSourceMaps: true, preserveLicenseComments: false, - optimize: 'uglify2', + optimize: 'none', waitSeconds: 0, paths: { jquery: '../libs/jquery.min', diff --git a/scripts/libs/require.js b/scripts/libs/require.js index 7ff409d9..a4203f0d 100644 --- a/scripts/libs/require.js +++ b/scripts/libs/require.js @@ -1,36 +1,5 @@ -/* - RequireJS 2.1.8 Copyright (c) 2010-2012, The Dojo Foundation All Rights Reserved. - Available via the MIT or new BSD license. - see: http://github.com/jrburke/requirejs for details -*/ -var requirejs,require,define; -(function(Z){function H(b){return"[object Function]"===L.call(b)}function I(b){return"[object Array]"===L.call(b)}function y(b,c){if(b){var d;for(d=0;dthis.depCount&&!this.defined){if(H(m)){if(this.events.error&&this.map.isDefine||j.onError!==aa)try{e=i.execCb(c,m,b,e)}catch(d){a=d}else e=i.execCb(c,m,b,e);this.map.isDefine&&((b=this.module)&&void 0!==b.exports&&b.exports!== -this.exports?e=b.exports:void 0===e&&this.usingExports&&(e=this.exports));if(a)return a.requireMap=this.map,a.requireModules=this.map.isDefine?[this.map.id]:null,a.requireType=this.map.isDefine?"define":"require",v(this.error=a)}else e=m;this.exports=e;if(this.map.isDefine&&!this.ignore&&(r[c]=e,j.onResourceLoad))j.onResourceLoad(i,this.map,this.depMaps);x(c);this.defined=!0}this.defining=!1;this.defined&&!this.defineEmitted&&(this.defineEmitted=!0,this.emit("defined",this.exports),this.defineEmitComplete= -!0)}}else this.fetch()}},callPlugin:function(){var a=this.map,b=a.id,d=n(a.prefix);this.depMaps.push(d);t(d,"defined",u(this,function(e){var m,d;d=this.map.name;var g=this.map.parentMap?this.map.parentMap.name:null,h=i.makeRequire(a.parentMap,{enableBuildCallback:!0});if(this.map.unnormalized){if(e.normalize&&(d=e.normalize(d,function(a){return c(a,g,!0)})||""),e=n(a.prefix+"!"+d,this.map.parentMap),t(e,"defined",u(this,function(a){this.init([],function(){return a},null,{enabled:!0,ignore:!0})})), -d=l(p,e.id)){this.depMaps.push(e);if(this.events.error)d.on("error",u(this,function(a){this.emit("error",a)}));d.enable()}}else m=u(this,function(a){this.init([],function(){return a},null,{enabled:!0})}),m.error=u(this,function(a){this.inited=!0;this.error=a;a.requireModules=[b];F(p,function(a){0===a.map.id.indexOf(b+"_unnormalized")&&x(a.map.id)});v(a)}),m.fromText=u(this,function(e,c){var d=a.name,g=n(d),B=O;c&&(e=c);B&&(O=!1);q(g);s(k.config,b)&&(k.config[d]=k.config[b]);try{j.exec(e)}catch(ca){return v(A("fromtexteval", -"fromText eval for "+b+" failed: "+ca,ca,[b]))}B&&(O=!0);this.depMaps.push(g);i.completeLoad(d);h([d],m)}),e.load(a.name,h,m,k)}));i.enable(d,this);this.pluginMaps[d.id]=d},enable:function(){T[this.map.id]=this;this.enabling=this.enabled=!0;y(this.depMaps,u(this,function(a,b){var c,e;if("string"===typeof a){a=n(a,this.map.isDefine?this.map:this.map.parentMap,!1,!this.skipMap);this.depMaps[b]=a;if(c=l(N,a.id)){this.depExports[b]=c(this);return}this.depCount+=1;t(a,"defined",u(this,function(a){this.defineDep(b, -a);this.check()}));this.errback&&t(a,"error",u(this,this.errback))}c=a.id;e=p[c];!s(N,c)&&(e&&!e.enabled)&&i.enable(a,this)}));F(this.pluginMaps,u(this,function(a){var b=l(p,a.id);b&&!b.enabled&&i.enable(a,this)}));this.enabling=!1;this.check()},on:function(a,b){var c=this.events[a];c||(c=this.events[a]=[]);c.push(b)},emit:function(a,b){y(this.events[a],function(a){a(b)});"error"===a&&delete this.events[a]}};i={config:k,contextName:b,registry:p,defined:r,urlFetched:S,defQueue:G,Module:X,makeModuleMap:n, -nextTick:j.nextTick,onError:v,configure:function(a){a.baseUrl&&"/"!==a.baseUrl.charAt(a.baseUrl.length-1)&&(a.baseUrl+="/");var b=k.pkgs,c=k.shim,e={paths:!0,config:!0,map:!0};F(a,function(a,b){e[b]?"map"===b?(k.map||(k.map={}),Q(k[b],a,!0,!0)):Q(k[b],a,!0):k[b]=a});a.shim&&(F(a.shim,function(a,b){I(a)&&(a={deps:a});if((a.exports||a.init)&&!a.exportsFn)a.exportsFn=i.makeShimExports(a);c[b]=a}),k.shim=c);a.packages&&(y(a.packages,function(a){a="string"===typeof a?{name:a}:a;b[a.name]={name:a.name, -location:a.location||a.name,main:(a.main||"main").replace(ja,"").replace(ea,"")}}),k.pkgs=b);F(p,function(a,b){!a.inited&&!a.map.unnormalized&&(a.map=n(b))});if(a.deps||a.callback)i.require(a.deps||[],a.callback)},makeShimExports:function(a){return function(){var b;a.init&&(b=a.init.apply(Z,arguments));return b||a.exports&&ba(a.exports)}},makeRequire:function(a,f){function d(e,c,h){var g,k;f.enableBuildCallback&&(c&&H(c))&&(c.__requireJsBuild=!0);if("string"===typeof e){if(H(c))return v(A("requireargs", -"Invalid require call"),h);if(a&&s(N,e))return N[e](p[a.id]);if(j.get)return j.get(i,e,a,d);g=n(e,a,!1,!0);g=g.id;return!s(r,g)?v(A("notloaded",'Module name "'+g+'" has not been loaded yet for context: '+b+(a?"":". Use require([])"))):r[g]}K();i.nextTick(function(){K();k=q(n(null,a));k.skipMap=f.skipMap;k.init(e,c,h,{enabled:!0});C()});return d}f=f||{};Q(d,{isBrowser:z,toUrl:function(b){var d,f=b.lastIndexOf("."),g=b.split("/")[0];if(-1!==f&&(!("."===g||".."===g)||1h.attachEvent.toString().indexOf("[native code"))&&!W?(O=!0,h.attachEvent("onreadystatechange",b.onScriptLoad)):(h.addEventListener("load",b.onScriptLoad,!1),h.addEventListener("error", -b.onScriptError,!1)),h.src=d,K=h,C?x.insertBefore(h,C):x.appendChild(h),K=null,h;if(da)try{importScripts(d),b.completeLoad(c)}catch(l){b.onError(A("importscripts","importScripts failed for "+c+" at "+d,l,[c]))}};z&&M(document.getElementsByTagName("script"),function(b){x||(x=b.parentNode);if(J=b.getAttribute("data-main"))return q=J,t.baseUrl||(D=q.split("/"),q=D.pop(),fa=D.length?D.join("/")+"/":"./",t.baseUrl=fa),q=q.replace(ea,""),j.jsExtRegExp.test(q)&&(q=J),t.deps=t.deps?t.deps.concat(q):[q],!0}); -define=function(b,c,d){var h,j;"string"!==typeof b&&(d=c,c=b,b=null);I(c)||(d=c,c=null);!c&&H(d)&&(c=[],d.length&&(d.toString().replace(la,"").replace(ma,function(b,d){c.push(d)}),c=(1===d.length?["require"]:["require","exports","module"]).concat(c)));if(O){if(!(h=K))P&&"interactive"===P.readyState||M(document.getElementsByTagName("script"),function(b){if("interactive"===b.readyState)return P=b}),h=P;h&&(b||(b=h.getAttribute("data-requiremodule")),j=E[h.getAttribute("data-requirecontext")])}(j?j.defQueue: -R).push([b,c,d])};define.amd={jQuery:!0};j.exec=function(b){return eval(b)};j(t)}})(this); +/** vim: et:ts=4:sw=4:sts=4 + * @license RequireJS 2.3.6 Copyright jQuery Foundation and other contributors. + * Released under MIT license, https://github.com/requirejs/requirejs/blob/master/LICENSE + */ +var requirejs,require,define;!function(global,setTimeout){var req,s,head,baseElement,dataMain,src,interactiveScript,currentlyAddingScript,mainScript,subPath,version="2.3.6",commentRegExp=/\/\*[\s\S]*?\*\/|([^:"'=]|^)\/\/.*$/gm,cjsRequireRegExp=/[^.]\s*require\s*\(\s*["']([^'"\s]+)["']\s*\)/g,jsSuffixRegExp=/\.js$/,currDirRegExp=/^\.\//,op=Object.prototype,ostring=op.toString,hasOwn=op.hasOwnProperty,isBrowser=!("undefined"==typeof window||"undefined"==typeof navigator||!window.document),isWebWorker=!isBrowser&&"undefined"!=typeof importScripts,readyRegExp=isBrowser&&"PLAYSTATION 3"===navigator.platform?/^complete$/:/^(complete|loaded)$/,defContextName="_",isOpera="undefined"!=typeof opera&&"[object Opera]"===opera.toString(),contexts={},cfg={},globalDefQueue=[],useInteractive=!1;function commentReplace(e,t){return t||""}function isFunction(e){return"[object Function]"===ostring.call(e)}function isArray(e){return"[object Array]"===ostring.call(e)}function each(e,t){var i;if(e)for(i=0;i Date: Fri, 15 Feb 2019 23:09:35 +0100 Subject: [PATCH 014/965] update .gitignore --- .gitignore | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/.gitignore b/.gitignore index 3802d8d0..cb491dee 100644 --- a/.gitignore +++ b/.gitignore @@ -1,4 +1,6 @@ node_modules/* docs/* .idea/* -styles/main-compiled.css \ No newline at end of file +styles/main-compiled.css +scripts/main-compiled.* +scripts/bgprocess-compiled.* \ No newline at end of file From 713405d23e4afdc00a51decc814f22d20f9ae1ec Mon Sep 17 00:00:00 2001 From: zakius Date: Fri, 15 Feb 2019 23:13:43 +0100 Subject: [PATCH 015/965] update jQuery --- scripts/libs/jquery.min.js | 8 ++------ 1 file changed, 2 insertions(+), 6 deletions(-) diff --git a/scripts/libs/jquery.min.js b/scripts/libs/jquery.min.js index 2be209dd..4d9b3a25 100644 --- a/scripts/libs/jquery.min.js +++ b/scripts/libs/jquery.min.js @@ -1,6 +1,2 @@ -/*! jQuery v2.0.3 | (c) 2005, 2013 jQuery Foundation, Inc. | jquery.org/license -//@ sourceMappingURL=jquery-2.0.3.min.map -*/ -(function(e,undefined){var t,n,r=typeof undefined,i=e.location,o=e.document,s=o.documentElement,a=e.jQuery,u=e.$,l={},c=[],p="2.0.3",f=c.concat,h=c.push,d=c.slice,g=c.indexOf,m=l.toString,y=l.hasOwnProperty,v=p.trim,x=function(e,n){return new x.fn.init(e,n,t)},b=/[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/.source,w=/\S+/g,T=/^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]*))$/,C=/^<(\w+)\s*\/?>(?:<\/\1>|)$/,k=/^-ms-/,N=/-([\da-z])/gi,E=function(e,t){return t.toUpperCase()},S=function(){o.removeEventListener("DOMContentLoaded",S,!1),e.removeEventListener("load",S,!1),x.ready()};x.fn=x.prototype={jquery:p,constructor:x,init:function(e,t,n){var r,i;if(!e)return this;if("string"==typeof e){if(r="<"===e.charAt(0)&&">"===e.charAt(e.length-1)&&e.length>=3?[null,e,null]:T.exec(e),!r||!r[1]&&t)return!t||t.jquery?(t||n).find(e):this.constructor(t).find(e);if(r[1]){if(t=t instanceof x?t[0]:t,x.merge(this,x.parseHTML(r[1],t&&t.nodeType?t.ownerDocument||t:o,!0)),C.test(r[1])&&x.isPlainObject(t))for(r in t)x.isFunction(this[r])?this[r](t[r]):this.attr(r,t[r]);return this}return i=o.getElementById(r[2]),i&&i.parentNode&&(this.length=1,this[0]=i),this.context=o,this.selector=e,this}return e.nodeType?(this.context=this[0]=e,this.length=1,this):x.isFunction(e)?n.ready(e):(e.selector!==undefined&&(this.selector=e.selector,this.context=e.context),x.makeArray(e,this))},selector:"",length:0,toArray:function(){return d.call(this)},get:function(e){return null==e?this.toArray():0>e?this[this.length+e]:this[e]},pushStack:function(e){var t=x.merge(this.constructor(),e);return t.prevObject=this,t.context=this.context,t},each:function(e,t){return x.each(this,e,t)},ready:function(e){return x.ready.promise().done(e),this},slice:function(){return this.pushStack(d.apply(this,arguments))},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},eq:function(e){var t=this.length,n=+e+(0>e?t:0);return this.pushStack(n>=0&&t>n?[this[n]]:[])},map:function(e){return this.pushStack(x.map(this,function(t,n){return e.call(t,n,t)}))},end:function(){return this.prevObject||this.constructor(null)},push:h,sort:[].sort,splice:[].splice},x.fn.init.prototype=x.fn,x.extend=x.fn.extend=function(){var e,t,n,r,i,o,s=arguments[0]||{},a=1,u=arguments.length,l=!1;for("boolean"==typeof s&&(l=s,s=arguments[1]||{},a=2),"object"==typeof s||x.isFunction(s)||(s={}),u===a&&(s=this,--a);u>a;a++)if(null!=(e=arguments[a]))for(t in e)n=s[t],r=e[t],s!==r&&(l&&r&&(x.isPlainObject(r)||(i=x.isArray(r)))?(i?(i=!1,o=n&&x.isArray(n)?n:[]):o=n&&x.isPlainObject(n)?n:{},s[t]=x.extend(l,o,r)):r!==undefined&&(s[t]=r));return s},x.extend({expando:"jQuery"+(p+Math.random()).replace(/\D/g,""),noConflict:function(t){return e.$===x&&(e.$=u),t&&e.jQuery===x&&(e.jQuery=a),x},isReady:!1,readyWait:1,holdReady:function(e){e?x.readyWait++:x.ready(!0)},ready:function(e){(e===!0?--x.readyWait:x.isReady)||(x.isReady=!0,e!==!0&&--x.readyWait>0||(n.resolveWith(o,[x]),x.fn.trigger&&x(o).trigger("ready").off("ready")))},isFunction:function(e){return"function"===x.type(e)},isArray:Array.isArray,isWindow:function(e){return null!=e&&e===e.window},isNumeric:function(e){return!isNaN(parseFloat(e))&&isFinite(e)},type:function(e){return null==e?e+"":"object"==typeof e||"function"==typeof e?l[m.call(e)]||"object":typeof e},isPlainObject:function(e){if("object"!==x.type(e)||e.nodeType||x.isWindow(e))return!1;try{if(e.constructor&&!y.call(e.constructor.prototype,"isPrototypeOf"))return!1}catch(t){return!1}return!0},isEmptyObject:function(e){var t;for(t in e)return!1;return!0},error:function(e){throw Error(e)},parseHTML:function(e,t,n){if(!e||"string"!=typeof e)return null;"boolean"==typeof t&&(n=t,t=!1),t=t||o;var r=C.exec(e),i=!n&&[];return r?[t.createElement(r[1])]:(r=x.buildFragment([e],t,i),i&&x(i).remove(),x.merge([],r.childNodes))},parseJSON:JSON.parse,parseXML:function(e){var t,n;if(!e||"string"!=typeof e)return null;try{n=new DOMParser,t=n.parseFromString(e,"text/xml")}catch(r){t=undefined}return(!t||t.getElementsByTagName("parsererror").length)&&x.error("Invalid XML: "+e),t},noop:function(){},globalEval:function(e){var t,n=eval;e=x.trim(e),e&&(1===e.indexOf("use strict")?(t=o.createElement("script"),t.text=e,o.head.appendChild(t).parentNode.removeChild(t)):n(e))},camelCase:function(e){return e.replace(k,"ms-").replace(N,E)},nodeName:function(e,t){return e.nodeName&&e.nodeName.toLowerCase()===t.toLowerCase()},each:function(e,t,n){var r,i=0,o=e.length,s=j(e);if(n){if(s){for(;o>i;i++)if(r=t.apply(e[i],n),r===!1)break}else for(i in e)if(r=t.apply(e[i],n),r===!1)break}else if(s){for(;o>i;i++)if(r=t.call(e[i],i,e[i]),r===!1)break}else for(i in e)if(r=t.call(e[i],i,e[i]),r===!1)break;return e},trim:function(e){return null==e?"":v.call(e)},makeArray:function(e,t){var n=t||[];return null!=e&&(j(Object(e))?x.merge(n,"string"==typeof e?[e]:e):h.call(n,e)),n},inArray:function(e,t,n){return null==t?-1:g.call(t,e,n)},merge:function(e,t){var n=t.length,r=e.length,i=0;if("number"==typeof n)for(;n>i;i++)e[r++]=t[i];else while(t[i]!==undefined)e[r++]=t[i++];return e.length=r,e},grep:function(e,t,n){var r,i=[],o=0,s=e.length;for(n=!!n;s>o;o++)r=!!t(e[o],o),n!==r&&i.push(e[o]);return i},map:function(e,t,n){var r,i=0,o=e.length,s=j(e),a=[];if(s)for(;o>i;i++)r=t(e[i],i,n),null!=r&&(a[a.length]=r);else for(i in e)r=t(e[i],i,n),null!=r&&(a[a.length]=r);return f.apply([],a)},guid:1,proxy:function(e,t){var n,r,i;return"string"==typeof t&&(n=e[t],t=e,e=n),x.isFunction(e)?(r=d.call(arguments,2),i=function(){return e.apply(t||this,r.concat(d.call(arguments)))},i.guid=e.guid=e.guid||x.guid++,i):undefined},access:function(e,t,n,r,i,o,s){var a=0,u=e.length,l=null==n;if("object"===x.type(n)){i=!0;for(a in n)x.access(e,t,a,n[a],!0,o,s)}else if(r!==undefined&&(i=!0,x.isFunction(r)||(s=!0),l&&(s?(t.call(e,r),t=null):(l=t,t=function(e,t,n){return l.call(x(e),n)})),t))for(;u>a;a++)t(e[a],n,s?r:r.call(e[a],a,t(e[a],n)));return i?e:l?t.call(e):u?t(e[0],n):o},now:Date.now,swap:function(e,t,n,r){var i,o,s={};for(o in t)s[o]=e.style[o],e.style[o]=t[o];i=n.apply(e,r||[]);for(o in t)e.style[o]=s[o];return i}}),x.ready.promise=function(t){return n||(n=x.Deferred(),"complete"===o.readyState?setTimeout(x.ready):(o.addEventListener("DOMContentLoaded",S,!1),e.addEventListener("load",S,!1))),n.promise(t)},x.each("Boolean Number String Function Array Date RegExp Object Error".split(" "),function(e,t){l["[object "+t+"]"]=t.toLowerCase()});function j(e){var t=e.length,n=x.type(e);return x.isWindow(e)?!1:1===e.nodeType&&t?!0:"array"===n||"function"!==n&&(0===t||"number"==typeof t&&t>0&&t-1 in e)}t=x(o),function(e,undefined){var t,n,r,i,o,s,a,u,l,c,p,f,h,d,g,m,y,v="sizzle"+-new Date,b=e.document,w=0,T=0,C=st(),k=st(),N=st(),E=!1,S=function(e,t){return e===t?(E=!0,0):0},j=typeof undefined,D=1<<31,A={}.hasOwnProperty,L=[],q=L.pop,H=L.push,O=L.push,F=L.slice,P=L.indexOf||function(e){var t=0,n=this.length;for(;n>t;t++)if(this[t]===e)return t;return-1},R="checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped",M="[\\x20\\t\\r\\n\\f]",W="(?:\\\\.|[\\w-]|[^\\x00-\\xa0])+",$=W.replace("w","w#"),B="\\["+M+"*("+W+")"+M+"*(?:([*^$|!~]?=)"+M+"*(?:(['\"])((?:\\\\.|[^\\\\])*?)\\3|("+$+")|)|)"+M+"*\\]",I=":("+W+")(?:\\(((['\"])((?:\\\\.|[^\\\\])*?)\\3|((?:\\\\.|[^\\\\()[\\]]|"+B.replace(3,8)+")*)|.*)\\)|)",z=RegExp("^"+M+"+|((?:^|[^\\\\])(?:\\\\.)*)"+M+"+$","g"),_=RegExp("^"+M+"*,"+M+"*"),X=RegExp("^"+M+"*([>+~]|"+M+")"+M+"*"),U=RegExp(M+"*[+~]"),Y=RegExp("="+M+"*([^\\]'\"]*)"+M+"*\\]","g"),V=RegExp(I),G=RegExp("^"+$+"$"),J={ID:RegExp("^#("+W+")"),CLASS:RegExp("^\\.("+W+")"),TAG:RegExp("^("+W.replace("w","w*")+")"),ATTR:RegExp("^"+B),PSEUDO:RegExp("^"+I),CHILD:RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\("+M+"*(even|odd|(([+-]|)(\\d*)n|)"+M+"*(?:([+-]|)"+M+"*(\\d+)|))"+M+"*\\)|)","i"),bool:RegExp("^(?:"+R+")$","i"),needsContext:RegExp("^"+M+"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\("+M+"*((?:-\\d)?\\d*)"+M+"*\\)|)(?=[^-]|$)","i")},Q=/^[^{]+\{\s*\[native \w/,K=/^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,Z=/^(?:input|select|textarea|button)$/i,et=/^h\d$/i,tt=/'|\\/g,nt=RegExp("\\\\([\\da-f]{1,6}"+M+"?|("+M+")|.)","ig"),rt=function(e,t,n){var r="0x"+t-65536;return r!==r||n?t:0>r?String.fromCharCode(r+65536):String.fromCharCode(55296|r>>10,56320|1023&r)};try{O.apply(L=F.call(b.childNodes),b.childNodes),L[b.childNodes.length].nodeType}catch(it){O={apply:L.length?function(e,t){H.apply(e,F.call(t))}:function(e,t){var n=e.length,r=0;while(e[n++]=t[r++]);e.length=n-1}}}function ot(e,t,r,i){var o,s,a,u,l,f,g,m,x,w;if((t?t.ownerDocument||t:b)!==p&&c(t),t=t||p,r=r||[],!e||"string"!=typeof e)return r;if(1!==(u=t.nodeType)&&9!==u)return[];if(h&&!i){if(o=K.exec(e))if(a=o[1]){if(9===u){if(s=t.getElementById(a),!s||!s.parentNode)return r;if(s.id===a)return r.push(s),r}else if(t.ownerDocument&&(s=t.ownerDocument.getElementById(a))&&y(t,s)&&s.id===a)return r.push(s),r}else{if(o[2])return O.apply(r,t.getElementsByTagName(e)),r;if((a=o[3])&&n.getElementsByClassName&&t.getElementsByClassName)return O.apply(r,t.getElementsByClassName(a)),r}if(n.qsa&&(!d||!d.test(e))){if(m=g=v,x=t,w=9===u&&e,1===u&&"object"!==t.nodeName.toLowerCase()){f=gt(e),(g=t.getAttribute("id"))?m=g.replace(tt,"\\$&"):t.setAttribute("id",m),m="[id='"+m+"'] ",l=f.length;while(l--)f[l]=m+mt(f[l]);x=U.test(e)&&t.parentNode||t,w=f.join(",")}if(w)try{return O.apply(r,x.querySelectorAll(w)),r}catch(T){}finally{g||t.removeAttribute("id")}}}return kt(e.replace(z,"$1"),t,r,i)}function st(){var e=[];function t(n,r){return e.push(n+=" ")>i.cacheLength&&delete t[e.shift()],t[n]=r}return t}function at(e){return e[v]=!0,e}function ut(e){var t=p.createElement("div");try{return!!e(t)}catch(n){return!1}finally{t.parentNode&&t.parentNode.removeChild(t),t=null}}function lt(e,t){var n=e.split("|"),r=e.length;while(r--)i.attrHandle[n[r]]=t}function ct(e,t){var n=t&&e,r=n&&1===e.nodeType&&1===t.nodeType&&(~t.sourceIndex||D)-(~e.sourceIndex||D);if(r)return r;if(n)while(n=n.nextSibling)if(n===t)return-1;return e?1:-1}function pt(e){return function(t){var n=t.nodeName.toLowerCase();return"input"===n&&t.type===e}}function ft(e){return function(t){var n=t.nodeName.toLowerCase();return("input"===n||"button"===n)&&t.type===e}}function ht(e){return at(function(t){return t=+t,at(function(n,r){var i,o=e([],n.length,t),s=o.length;while(s--)n[i=o[s]]&&(n[i]=!(r[i]=n[i]))})})}s=ot.isXML=function(e){var t=e&&(e.ownerDocument||e).documentElement;return t?"HTML"!==t.nodeName:!1},n=ot.support={},c=ot.setDocument=function(e){var t=e?e.ownerDocument||e:b,r=t.defaultView;return t!==p&&9===t.nodeType&&t.documentElement?(p=t,f=t.documentElement,h=!s(t),r&&r.attachEvent&&r!==r.top&&r.attachEvent("onbeforeunload",function(){c()}),n.attributes=ut(function(e){return e.className="i",!e.getAttribute("className")}),n.getElementsByTagName=ut(function(e){return e.appendChild(t.createComment("")),!e.getElementsByTagName("*").length}),n.getElementsByClassName=ut(function(e){return e.innerHTML="
",e.firstChild.className="i",2===e.getElementsByClassName("i").length}),n.getById=ut(function(e){return f.appendChild(e).id=v,!t.getElementsByName||!t.getElementsByName(v).length}),n.getById?(i.find.ID=function(e,t){if(typeof t.getElementById!==j&&h){var n=t.getElementById(e);return n&&n.parentNode?[n]:[]}},i.filter.ID=function(e){var t=e.replace(nt,rt);return function(e){return e.getAttribute("id")===t}}):(delete i.find.ID,i.filter.ID=function(e){var t=e.replace(nt,rt);return function(e){var n=typeof e.getAttributeNode!==j&&e.getAttributeNode("id");return n&&n.value===t}}),i.find.TAG=n.getElementsByTagName?function(e,t){return typeof t.getElementsByTagName!==j?t.getElementsByTagName(e):undefined}:function(e,t){var n,r=[],i=0,o=t.getElementsByTagName(e);if("*"===e){while(n=o[i++])1===n.nodeType&&r.push(n);return r}return o},i.find.CLASS=n.getElementsByClassName&&function(e,t){return typeof t.getElementsByClassName!==j&&h?t.getElementsByClassName(e):undefined},g=[],d=[],(n.qsa=Q.test(t.querySelectorAll))&&(ut(function(e){e.innerHTML="",e.querySelectorAll("[selected]").length||d.push("\\["+M+"*(?:value|"+R+")"),e.querySelectorAll(":checked").length||d.push(":checked")}),ut(function(e){var n=t.createElement("input");n.setAttribute("type","hidden"),e.appendChild(n).setAttribute("t",""),e.querySelectorAll("[t^='']").length&&d.push("[*^$]="+M+"*(?:''|\"\")"),e.querySelectorAll(":enabled").length||d.push(":enabled",":disabled"),e.querySelectorAll("*,:x"),d.push(",.*:")})),(n.matchesSelector=Q.test(m=f.webkitMatchesSelector||f.mozMatchesSelector||f.oMatchesSelector||f.msMatchesSelector))&&ut(function(e){n.disconnectedMatch=m.call(e,"div"),m.call(e,"[s!='']:x"),g.push("!=",I)}),d=d.length&&RegExp(d.join("|")),g=g.length&&RegExp(g.join("|")),y=Q.test(f.contains)||f.compareDocumentPosition?function(e,t){var n=9===e.nodeType?e.documentElement:e,r=t&&t.parentNode;return e===r||!(!r||1!==r.nodeType||!(n.contains?n.contains(r):e.compareDocumentPosition&&16&e.compareDocumentPosition(r)))}:function(e,t){if(t)while(t=t.parentNode)if(t===e)return!0;return!1},S=f.compareDocumentPosition?function(e,r){if(e===r)return E=!0,0;var i=r.compareDocumentPosition&&e.compareDocumentPosition&&e.compareDocumentPosition(r);return i?1&i||!n.sortDetached&&r.compareDocumentPosition(e)===i?e===t||y(b,e)?-1:r===t||y(b,r)?1:l?P.call(l,e)-P.call(l,r):0:4&i?-1:1:e.compareDocumentPosition?-1:1}:function(e,n){var r,i=0,o=e.parentNode,s=n.parentNode,a=[e],u=[n];if(e===n)return E=!0,0;if(!o||!s)return e===t?-1:n===t?1:o?-1:s?1:l?P.call(l,e)-P.call(l,n):0;if(o===s)return ct(e,n);r=e;while(r=r.parentNode)a.unshift(r);r=n;while(r=r.parentNode)u.unshift(r);while(a[i]===u[i])i++;return i?ct(a[i],u[i]):a[i]===b?-1:u[i]===b?1:0},t):p},ot.matches=function(e,t){return ot(e,null,null,t)},ot.matchesSelector=function(e,t){if((e.ownerDocument||e)!==p&&c(e),t=t.replace(Y,"='$1']"),!(!n.matchesSelector||!h||g&&g.test(t)||d&&d.test(t)))try{var r=m.call(e,t);if(r||n.disconnectedMatch||e.document&&11!==e.document.nodeType)return r}catch(i){}return ot(t,p,null,[e]).length>0},ot.contains=function(e,t){return(e.ownerDocument||e)!==p&&c(e),y(e,t)},ot.attr=function(e,t){(e.ownerDocument||e)!==p&&c(e);var r=i.attrHandle[t.toLowerCase()],o=r&&A.call(i.attrHandle,t.toLowerCase())?r(e,t,!h):undefined;return o===undefined?n.attributes||!h?e.getAttribute(t):(o=e.getAttributeNode(t))&&o.specified?o.value:null:o},ot.error=function(e){throw Error("Syntax error, unrecognized expression: "+e)},ot.uniqueSort=function(e){var t,r=[],i=0,o=0;if(E=!n.detectDuplicates,l=!n.sortStable&&e.slice(0),e.sort(S),E){while(t=e[o++])t===e[o]&&(i=r.push(o));while(i--)e.splice(r[i],1)}return e},o=ot.getText=function(e){var t,n="",r=0,i=e.nodeType;if(i){if(1===i||9===i||11===i){if("string"==typeof e.textContent)return e.textContent;for(e=e.firstChild;e;e=e.nextSibling)n+=o(e)}else if(3===i||4===i)return e.nodeValue}else for(;t=e[r];r++)n+=o(t);return n},i=ot.selectors={cacheLength:50,createPseudo:at,match:J,attrHandle:{},find:{},relative:{">":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"~":{dir:"previousSibling"}},preFilter:{ATTR:function(e){return e[1]=e[1].replace(nt,rt),e[3]=(e[4]||e[5]||"").replace(nt,rt),"~="===e[2]&&(e[3]=" "+e[3]+" "),e.slice(0,4)},CHILD:function(e){return e[1]=e[1].toLowerCase(),"nth"===e[1].slice(0,3)?(e[3]||ot.error(e[0]),e[4]=+(e[4]?e[5]+(e[6]||1):2*("even"===e[3]||"odd"===e[3])),e[5]=+(e[7]+e[8]||"odd"===e[3])):e[3]&&ot.error(e[0]),e},PSEUDO:function(e){var t,n=!e[5]&&e[2];return J.CHILD.test(e[0])?null:(e[3]&&e[4]!==undefined?e[2]=e[4]:n&&V.test(n)&&(t=gt(n,!0))&&(t=n.indexOf(")",n.length-t)-n.length)&&(e[0]=e[0].slice(0,t),e[2]=n.slice(0,t)),e.slice(0,3))}},filter:{TAG:function(e){var t=e.replace(nt,rt).toLowerCase();return"*"===e?function(){return!0}:function(e){return e.nodeName&&e.nodeName.toLowerCase()===t}},CLASS:function(e){var t=C[e+" "];return t||(t=RegExp("(^|"+M+")"+e+"("+M+"|$)"))&&C(e,function(e){return t.test("string"==typeof e.className&&e.className||typeof e.getAttribute!==j&&e.getAttribute("class")||"")})},ATTR:function(e,t,n){return function(r){var i=ot.attr(r,e);return null==i?"!="===t:t?(i+="","="===t?i===n:"!="===t?i!==n:"^="===t?n&&0===i.indexOf(n):"*="===t?n&&i.indexOf(n)>-1:"$="===t?n&&i.slice(-n.length)===n:"~="===t?(" "+i+" ").indexOf(n)>-1:"|="===t?i===n||i.slice(0,n.length+1)===n+"-":!1):!0}},CHILD:function(e,t,n,r,i){var o="nth"!==e.slice(0,3),s="last"!==e.slice(-4),a="of-type"===t;return 1===r&&0===i?function(e){return!!e.parentNode}:function(t,n,u){var l,c,p,f,h,d,g=o!==s?"nextSibling":"previousSibling",m=t.parentNode,y=a&&t.nodeName.toLowerCase(),x=!u&&!a;if(m){if(o){while(g){p=t;while(p=p[g])if(a?p.nodeName.toLowerCase()===y:1===p.nodeType)return!1;d=g="only"===e&&!d&&"nextSibling"}return!0}if(d=[s?m.firstChild:m.lastChild],s&&x){c=m[v]||(m[v]={}),l=c[e]||[],h=l[0]===w&&l[1],f=l[0]===w&&l[2],p=h&&m.childNodes[h];while(p=++h&&p&&p[g]||(f=h=0)||d.pop())if(1===p.nodeType&&++f&&p===t){c[e]=[w,h,f];break}}else if(x&&(l=(t[v]||(t[v]={}))[e])&&l[0]===w)f=l[1];else while(p=++h&&p&&p[g]||(f=h=0)||d.pop())if((a?p.nodeName.toLowerCase()===y:1===p.nodeType)&&++f&&(x&&((p[v]||(p[v]={}))[e]=[w,f]),p===t))break;return f-=i,f===r||0===f%r&&f/r>=0}}},PSEUDO:function(e,t){var n,r=i.pseudos[e]||i.setFilters[e.toLowerCase()]||ot.error("unsupported pseudo: "+e);return r[v]?r(t):r.length>1?(n=[e,e,"",t],i.setFilters.hasOwnProperty(e.toLowerCase())?at(function(e,n){var i,o=r(e,t),s=o.length;while(s--)i=P.call(e,o[s]),e[i]=!(n[i]=o[s])}):function(e){return r(e,0,n)}):r}},pseudos:{not:at(function(e){var t=[],n=[],r=a(e.replace(z,"$1"));return r[v]?at(function(e,t,n,i){var o,s=r(e,null,i,[]),a=e.length;while(a--)(o=s[a])&&(e[a]=!(t[a]=o))}):function(e,i,o){return t[0]=e,r(t,null,o,n),!n.pop()}}),has:at(function(e){return function(t){return ot(e,t).length>0}}),contains:at(function(e){return function(t){return(t.textContent||t.innerText||o(t)).indexOf(e)>-1}}),lang:at(function(e){return G.test(e||"")||ot.error("unsupported lang: "+e),e=e.replace(nt,rt).toLowerCase(),function(t){var n;do if(n=h?t.lang:t.getAttribute("xml:lang")||t.getAttribute("lang"))return n=n.toLowerCase(),n===e||0===n.indexOf(e+"-");while((t=t.parentNode)&&1===t.nodeType);return!1}}),target:function(t){var n=e.location&&e.location.hash;return n&&n.slice(1)===t.id},root:function(e){return e===f},focus:function(e){return e===p.activeElement&&(!p.hasFocus||p.hasFocus())&&!!(e.type||e.href||~e.tabIndex)},enabled:function(e){return e.disabled===!1},disabled:function(e){return e.disabled===!0},checked:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&!!e.checked||"option"===t&&!!e.selected},selected:function(e){return e.parentNode&&e.parentNode.selectedIndex,e.selected===!0},empty:function(e){for(e=e.firstChild;e;e=e.nextSibling)if(e.nodeName>"@"||3===e.nodeType||4===e.nodeType)return!1;return!0},parent:function(e){return!i.pseudos.empty(e)},header:function(e){return et.test(e.nodeName)},input:function(e){return Z.test(e.nodeName)},button:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&"button"===e.type||"button"===t},text:function(e){var t;return"input"===e.nodeName.toLowerCase()&&"text"===e.type&&(null==(t=e.getAttribute("type"))||t.toLowerCase()===e.type)},first:ht(function(){return[0]}),last:ht(function(e,t){return[t-1]}),eq:ht(function(e,t,n){return[0>n?n+t:n]}),even:ht(function(e,t){var n=0;for(;t>n;n+=2)e.push(n);return e}),odd:ht(function(e,t){var n=1;for(;t>n;n+=2)e.push(n);return e}),lt:ht(function(e,t,n){var r=0>n?n+t:n;for(;--r>=0;)e.push(r);return e}),gt:ht(function(e,t,n){var r=0>n?n+t:n;for(;t>++r;)e.push(r);return e})}},i.pseudos.nth=i.pseudos.eq;for(t in{radio:!0,checkbox:!0,file:!0,password:!0,image:!0})i.pseudos[t]=pt(t);for(t in{submit:!0,reset:!0})i.pseudos[t]=ft(t);function dt(){}dt.prototype=i.filters=i.pseudos,i.setFilters=new dt;function gt(e,t){var n,r,o,s,a,u,l,c=k[e+" "];if(c)return t?0:c.slice(0);a=e,u=[],l=i.preFilter;while(a){(!n||(r=_.exec(a)))&&(r&&(a=a.slice(r[0].length)||a),u.push(o=[])),n=!1,(r=X.exec(a))&&(n=r.shift(),o.push({value:n,type:r[0].replace(z," ")}),a=a.slice(n.length));for(s in i.filter)!(r=J[s].exec(a))||l[s]&&!(r=l[s](r))||(n=r.shift(),o.push({value:n,type:s,matches:r}),a=a.slice(n.length));if(!n)break}return t?a.length:a?ot.error(e):k(e,u).slice(0)}function mt(e){var t=0,n=e.length,r="";for(;n>t;t++)r+=e[t].value;return r}function yt(e,t,n){var i=t.dir,o=n&&"parentNode"===i,s=T++;return t.first?function(t,n,r){while(t=t[i])if(1===t.nodeType||o)return e(t,n,r)}:function(t,n,a){var u,l,c,p=w+" "+s;if(a){while(t=t[i])if((1===t.nodeType||o)&&e(t,n,a))return!0}else while(t=t[i])if(1===t.nodeType||o)if(c=t[v]||(t[v]={}),(l=c[i])&&l[0]===p){if((u=l[1])===!0||u===r)return u===!0}else if(l=c[i]=[p],l[1]=e(t,n,a)||r,l[1]===!0)return!0}}function vt(e){return e.length>1?function(t,n,r){var i=e.length;while(i--)if(!e[i](t,n,r))return!1;return!0}:e[0]}function xt(e,t,n,r,i){var o,s=[],a=0,u=e.length,l=null!=t;for(;u>a;a++)(o=e[a])&&(!n||n(o,r,i))&&(s.push(o),l&&t.push(a));return s}function bt(e,t,n,r,i,o){return r&&!r[v]&&(r=bt(r)),i&&!i[v]&&(i=bt(i,o)),at(function(o,s,a,u){var l,c,p,f=[],h=[],d=s.length,g=o||Ct(t||"*",a.nodeType?[a]:a,[]),m=!e||!o&&t?g:xt(g,f,e,a,u),y=n?i||(o?e:d||r)?[]:s:m;if(n&&n(m,y,a,u),r){l=xt(y,h),r(l,[],a,u),c=l.length;while(c--)(p=l[c])&&(y[h[c]]=!(m[h[c]]=p))}if(o){if(i||e){if(i){l=[],c=y.length;while(c--)(p=y[c])&&l.push(m[c]=p);i(null,y=[],l,u)}c=y.length;while(c--)(p=y[c])&&(l=i?P.call(o,p):f[c])>-1&&(o[l]=!(s[l]=p))}}else y=xt(y===s?y.splice(d,y.length):y),i?i(null,s,y,u):O.apply(s,y)})}function wt(e){var t,n,r,o=e.length,s=i.relative[e[0].type],a=s||i.relative[" "],l=s?1:0,c=yt(function(e){return e===t},a,!0),p=yt(function(e){return P.call(t,e)>-1},a,!0),f=[function(e,n,r){return!s&&(r||n!==u)||((t=n).nodeType?c(e,n,r):p(e,n,r))}];for(;o>l;l++)if(n=i.relative[e[l].type])f=[yt(vt(f),n)];else{if(n=i.filter[e[l].type].apply(null,e[l].matches),n[v]){for(r=++l;o>r;r++)if(i.relative[e[r].type])break;return bt(l>1&&vt(f),l>1&&mt(e.slice(0,l-1).concat({value:" "===e[l-2].type?"*":""})).replace(z,"$1"),n,r>l&&wt(e.slice(l,r)),o>r&&wt(e=e.slice(r)),o>r&&mt(e))}f.push(n)}return vt(f)}function Tt(e,t){var n=0,o=t.length>0,s=e.length>0,a=function(a,l,c,f,h){var d,g,m,y=[],v=0,x="0",b=a&&[],T=null!=h,C=u,k=a||s&&i.find.TAG("*",h&&l.parentNode||l),N=w+=null==C?1:Math.random()||.1;for(T&&(u=l!==p&&l,r=n);null!=(d=k[x]);x++){if(s&&d){g=0;while(m=e[g++])if(m(d,l,c)){f.push(d);break}T&&(w=N,r=++n)}o&&((d=!m&&d)&&v--,a&&b.push(d))}if(v+=x,o&&x!==v){g=0;while(m=t[g++])m(b,y,l,c);if(a){if(v>0)while(x--)b[x]||y[x]||(y[x]=q.call(f));y=xt(y)}O.apply(f,y),T&&!a&&y.length>0&&v+t.length>1&&ot.uniqueSort(f)}return T&&(w=N,u=C),b};return o?at(a):a}a=ot.compile=function(e,t){var n,r=[],i=[],o=N[e+" "];if(!o){t||(t=gt(e)),n=t.length;while(n--)o=wt(t[n]),o[v]?r.push(o):i.push(o);o=N(e,Tt(i,r))}return o};function Ct(e,t,n){var r=0,i=t.length;for(;i>r;r++)ot(e,t[r],n);return n}function kt(e,t,r,o){var s,u,l,c,p,f=gt(e);if(!o&&1===f.length){if(u=f[0]=f[0].slice(0),u.length>2&&"ID"===(l=u[0]).type&&n.getById&&9===t.nodeType&&h&&i.relative[u[1].type]){if(t=(i.find.ID(l.matches[0].replace(nt,rt),t)||[])[0],!t)return r;e=e.slice(u.shift().value.length)}s=J.needsContext.test(e)?0:u.length;while(s--){if(l=u[s],i.relative[c=l.type])break;if((p=i.find[c])&&(o=p(l.matches[0].replace(nt,rt),U.test(u[0].type)&&t.parentNode||t))){if(u.splice(s,1),e=o.length&&mt(u),!e)return O.apply(r,o),r;break}}}return a(e,f)(o,t,!h,r,U.test(e)),r}n.sortStable=v.split("").sort(S).join("")===v,n.detectDuplicates=E,c(),n.sortDetached=ut(function(e){return 1&e.compareDocumentPosition(p.createElement("div"))}),ut(function(e){return e.innerHTML="","#"===e.firstChild.getAttribute("href")})||lt("type|href|height|width",function(e,t,n){return n?undefined:e.getAttribute(t,"type"===t.toLowerCase()?1:2)}),n.attributes&&ut(function(e){return e.innerHTML="",e.firstChild.setAttribute("value",""),""===e.firstChild.getAttribute("value")})||lt("value",function(e,t,n){return n||"input"!==e.nodeName.toLowerCase()?undefined:e.defaultValue}),ut(function(e){return null==e.getAttribute("disabled")})||lt(R,function(e,t,n){var r;return n?undefined:(r=e.getAttributeNode(t))&&r.specified?r.value:e[t]===!0?t.toLowerCase():null}),x.find=ot,x.expr=ot.selectors,x.expr[":"]=x.expr.pseudos,x.unique=ot.uniqueSort,x.text=ot.getText,x.isXMLDoc=ot.isXML,x.contains=ot.contains}(e);var D={};function A(e){var t=D[e]={};return x.each(e.match(w)||[],function(e,n){t[n]=!0}),t}x.Callbacks=function(e){e="string"==typeof e?D[e]||A(e):x.extend({},e);var t,n,r,i,o,s,a=[],u=!e.once&&[],l=function(p){for(t=e.memory&&p,n=!0,s=i||0,i=0,o=a.length,r=!0;a&&o>s;s++)if(a[s].apply(p[0],p[1])===!1&&e.stopOnFalse){t=!1;break}r=!1,a&&(u?u.length&&l(u.shift()):t?a=[]:c.disable())},c={add:function(){if(a){var n=a.length;(function s(t){x.each(t,function(t,n){var r=x.type(n);"function"===r?e.unique&&c.has(n)||a.push(n):n&&n.length&&"string"!==r&&s(n)})})(arguments),r?o=a.length:t&&(i=n,l(t))}return this},remove:function(){return a&&x.each(arguments,function(e,t){var n;while((n=x.inArray(t,a,n))>-1)a.splice(n,1),r&&(o>=n&&o--,s>=n&&s--)}),this},has:function(e){return e?x.inArray(e,a)>-1:!(!a||!a.length)},empty:function(){return a=[],o=0,this},disable:function(){return a=u=t=undefined,this},disabled:function(){return!a},lock:function(){return u=undefined,t||c.disable(),this},locked:function(){return!u},fireWith:function(e,t){return!a||n&&!u||(t=t||[],t=[e,t.slice?t.slice():t],r?u.push(t):l(t)),this},fire:function(){return c.fireWith(this,arguments),this},fired:function(){return!!n}};return c},x.extend({Deferred:function(e){var t=[["resolve","done",x.Callbacks("once memory"),"resolved"],["reject","fail",x.Callbacks("once memory"),"rejected"],["notify","progress",x.Callbacks("memory")]],n="pending",r={state:function(){return n},always:function(){return i.done(arguments).fail(arguments),this},then:function(){var e=arguments;return x.Deferred(function(n){x.each(t,function(t,o){var s=o[0],a=x.isFunction(e[t])&&e[t];i[o[1]](function(){var e=a&&a.apply(this,arguments);e&&x.isFunction(e.promise)?e.promise().done(n.resolve).fail(n.reject).progress(n.notify):n[s+"With"](this===r?n.promise():this,a?[e]:arguments)})}),e=null}).promise()},promise:function(e){return null!=e?x.extend(e,r):r}},i={};return r.pipe=r.then,x.each(t,function(e,o){var s=o[2],a=o[3];r[o[1]]=s.add,a&&s.add(function(){n=a},t[1^e][2].disable,t[2][2].lock),i[o[0]]=function(){return i[o[0]+"With"](this===i?r:this,arguments),this},i[o[0]+"With"]=s.fireWith}),r.promise(i),e&&e.call(i,i),i},when:function(e){var t=0,n=d.call(arguments),r=n.length,i=1!==r||e&&x.isFunction(e.promise)?r:0,o=1===i?e:x.Deferred(),s=function(e,t,n){return function(r){t[e]=this,n[e]=arguments.length>1?d.call(arguments):r,n===a?o.notifyWith(t,n):--i||o.resolveWith(t,n)}},a,u,l;if(r>1)for(a=Array(r),u=Array(r),l=Array(r);r>t;t++)n[t]&&x.isFunction(n[t].promise)?n[t].promise().done(s(t,l,n)).fail(o.reject).progress(s(t,u,a)):--i;return i||o.resolveWith(l,n),o.promise()}}),x.support=function(t){var n=o.createElement("input"),r=o.createDocumentFragment(),i=o.createElement("div"),s=o.createElement("select"),a=s.appendChild(o.createElement("option"));return n.type?(n.type="checkbox",t.checkOn=""!==n.value,t.optSelected=a.selected,t.reliableMarginRight=!0,t.boxSizingReliable=!0,t.pixelPosition=!1,n.checked=!0,t.noCloneChecked=n.cloneNode(!0).checked,s.disabled=!0,t.optDisabled=!a.disabled,n=o.createElement("input"),n.value="t",n.type="radio",t.radioValue="t"===n.value,n.setAttribute("checked","t"),n.setAttribute("name","t"),r.appendChild(n),t.checkClone=r.cloneNode(!0).cloneNode(!0).lastChild.checked,t.focusinBubbles="onfocusin"in e,i.style.backgroundClip="content-box",i.cloneNode(!0).style.backgroundClip="",t.clearCloneStyle="content-box"===i.style.backgroundClip,x(function(){var n,r,s="padding:0;margin:0;border:0;display:block;-webkit-box-sizing:content-box;-moz-box-sizing:content-box;box-sizing:content-box",a=o.getElementsByTagName("body")[0];a&&(n=o.createElement("div"),n.style.cssText="border:0;width:0;height:0;position:absolute;top:0;left:-9999px;margin-top:1px",a.appendChild(n).appendChild(i),i.innerHTML="",i.style.cssText="-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;padding:1px;border:1px;display:block;width:4px;margin-top:1%;position:absolute;top:1%",x.swap(a,null!=a.style.zoom?{zoom:1}:{},function(){t.boxSizing=4===i.offsetWidth}),e.getComputedStyle&&(t.pixelPosition="1%"!==(e.getComputedStyle(i,null)||{}).top,t.boxSizingReliable="4px"===(e.getComputedStyle(i,null)||{width:"4px"}).width,r=i.appendChild(o.createElement("div")),r.style.cssText=i.style.cssText=s,r.style.marginRight=r.style.width="0",i.style.width="1px",t.reliableMarginRight=!parseFloat((e.getComputedStyle(r,null)||{}).marginRight)),a.removeChild(n))}),t):t}({});var L,q,H=/(?:\{[\s\S]*\}|\[[\s\S]*\])$/,O=/([A-Z])/g;function F(){Object.defineProperty(this.cache={},0,{get:function(){return{}}}),this.expando=x.expando+Math.random()}F.uid=1,F.accepts=function(e){return e.nodeType?1===e.nodeType||9===e.nodeType:!0},F.prototype={key:function(e){if(!F.accepts(e))return 0;var t={},n=e[this.expando];if(!n){n=F.uid++;try{t[this.expando]={value:n},Object.defineProperties(e,t)}catch(r){t[this.expando]=n,x.extend(e,t)}}return this.cache[n]||(this.cache[n]={}),n},set:function(e,t,n){var r,i=this.key(e),o=this.cache[i];if("string"==typeof t)o[t]=n;else if(x.isEmptyObject(o))x.extend(this.cache[i],t);else for(r in t)o[r]=t[r];return o},get:function(e,t){var n=this.cache[this.key(e)];return t===undefined?n:n[t]},access:function(e,t,n){var r;return t===undefined||t&&"string"==typeof t&&n===undefined?(r=this.get(e,t),r!==undefined?r:this.get(e,x.camelCase(t))):(this.set(e,t,n),n!==undefined?n:t)},remove:function(e,t){var n,r,i,o=this.key(e),s=this.cache[o];if(t===undefined)this.cache[o]={};else{x.isArray(t)?r=t.concat(t.map(x.camelCase)):(i=x.camelCase(t),t in s?r=[t,i]:(r=i,r=r in s?[r]:r.match(w)||[])),n=r.length;while(n--)delete s[r[n]]}},hasData:function(e){return!x.isEmptyObject(this.cache[e[this.expando]]||{})},discard:function(e){e[this.expando]&&delete this.cache[e[this.expando]]}},L=new F,q=new F,x.extend({acceptData:F.accepts,hasData:function(e){return L.hasData(e)||q.hasData(e)},data:function(e,t,n){return L.access(e,t,n)},removeData:function(e,t){L.remove(e,t)},_data:function(e,t,n){return q.access(e,t,n)},_removeData:function(e,t){q.remove(e,t)}}),x.fn.extend({data:function(e,t){var n,r,i=this[0],o=0,s=null;if(e===undefined){if(this.length&&(s=L.get(i),1===i.nodeType&&!q.get(i,"hasDataAttrs"))){for(n=i.attributes;n.length>o;o++)r=n[o].name,0===r.indexOf("data-")&&(r=x.camelCase(r.slice(5)),P(i,r,s[r]));q.set(i,"hasDataAttrs",!0)}return s}return"object"==typeof e?this.each(function(){L.set(this,e)}):x.access(this,function(t){var n,r=x.camelCase(e);if(i&&t===undefined){if(n=L.get(i,e),n!==undefined)return n;if(n=L.get(i,r),n!==undefined)return n;if(n=P(i,r,undefined),n!==undefined)return n}else this.each(function(){var n=L.get(this,r);L.set(this,r,t),-1!==e.indexOf("-")&&n!==undefined&&L.set(this,e,t)})},null,t,arguments.length>1,null,!0)},removeData:function(e){return this.each(function(){L.remove(this,e)})}});function P(e,t,n){var r;if(n===undefined&&1===e.nodeType)if(r="data-"+t.replace(O,"-$1").toLowerCase(),n=e.getAttribute(r),"string"==typeof n){try{n="true"===n?!0:"false"===n?!1:"null"===n?null:+n+""===n?+n:H.test(n)?JSON.parse(n):n}catch(i){}L.set(e,t,n)}else n=undefined;return n}x.extend({queue:function(e,t,n){var r;return e?(t=(t||"fx")+"queue",r=q.get(e,t),n&&(!r||x.isArray(n)?r=q.access(e,t,x.makeArray(n)):r.push(n)),r||[]):undefined},dequeue:function(e,t){t=t||"fx";var n=x.queue(e,t),r=n.length,i=n.shift(),o=x._queueHooks(e,t),s=function(){x.dequeue(e,t) -};"inprogress"===i&&(i=n.shift(),r--),i&&("fx"===t&&n.unshift("inprogress"),delete o.stop,i.call(e,s,o)),!r&&o&&o.empty.fire()},_queueHooks:function(e,t){var n=t+"queueHooks";return q.get(e,n)||q.access(e,n,{empty:x.Callbacks("once memory").add(function(){q.remove(e,[t+"queue",n])})})}}),x.fn.extend({queue:function(e,t){var n=2;return"string"!=typeof e&&(t=e,e="fx",n--),n>arguments.length?x.queue(this[0],e):t===undefined?this:this.each(function(){var n=x.queue(this,e,t);x._queueHooks(this,e),"fx"===e&&"inprogress"!==n[0]&&x.dequeue(this,e)})},dequeue:function(e){return this.each(function(){x.dequeue(this,e)})},delay:function(e,t){return e=x.fx?x.fx.speeds[e]||e:e,t=t||"fx",this.queue(t,function(t,n){var r=setTimeout(t,e);n.stop=function(){clearTimeout(r)}})},clearQueue:function(e){return this.queue(e||"fx",[])},promise:function(e,t){var n,r=1,i=x.Deferred(),o=this,s=this.length,a=function(){--r||i.resolveWith(o,[o])};"string"!=typeof e&&(t=e,e=undefined),e=e||"fx";while(s--)n=q.get(o[s],e+"queueHooks"),n&&n.empty&&(r++,n.empty.add(a));return a(),i.promise(t)}});var R,M,W=/[\t\r\n\f]/g,$=/\r/g,B=/^(?:input|select|textarea|button)$/i;x.fn.extend({attr:function(e,t){return x.access(this,x.attr,e,t,arguments.length>1)},removeAttr:function(e){return this.each(function(){x.removeAttr(this,e)})},prop:function(e,t){return x.access(this,x.prop,e,t,arguments.length>1)},removeProp:function(e){return this.each(function(){delete this[x.propFix[e]||e]})},addClass:function(e){var t,n,r,i,o,s=0,a=this.length,u="string"==typeof e&&e;if(x.isFunction(e))return this.each(function(t){x(this).addClass(e.call(this,t,this.className))});if(u)for(t=(e||"").match(w)||[];a>s;s++)if(n=this[s],r=1===n.nodeType&&(n.className?(" "+n.className+" ").replace(W," "):" ")){o=0;while(i=t[o++])0>r.indexOf(" "+i+" ")&&(r+=i+" ");n.className=x.trim(r)}return this},removeClass:function(e){var t,n,r,i,o,s=0,a=this.length,u=0===arguments.length||"string"==typeof e&&e;if(x.isFunction(e))return this.each(function(t){x(this).removeClass(e.call(this,t,this.className))});if(u)for(t=(e||"").match(w)||[];a>s;s++)if(n=this[s],r=1===n.nodeType&&(n.className?(" "+n.className+" ").replace(W," "):"")){o=0;while(i=t[o++])while(r.indexOf(" "+i+" ")>=0)r=r.replace(" "+i+" "," ");n.className=e?x.trim(r):""}return this},toggleClass:function(e,t){var n=typeof e;return"boolean"==typeof t&&"string"===n?t?this.addClass(e):this.removeClass(e):x.isFunction(e)?this.each(function(n){x(this).toggleClass(e.call(this,n,this.className,t),t)}):this.each(function(){if("string"===n){var t,i=0,o=x(this),s=e.match(w)||[];while(t=s[i++])o.hasClass(t)?o.removeClass(t):o.addClass(t)}else(n===r||"boolean"===n)&&(this.className&&q.set(this,"__className__",this.className),this.className=this.className||e===!1?"":q.get(this,"__className__")||"")})},hasClass:function(e){var t=" "+e+" ",n=0,r=this.length;for(;r>n;n++)if(1===this[n].nodeType&&(" "+this[n].className+" ").replace(W," ").indexOf(t)>=0)return!0;return!1},val:function(e){var t,n,r,i=this[0];{if(arguments.length)return r=x.isFunction(e),this.each(function(n){var i;1===this.nodeType&&(i=r?e.call(this,n,x(this).val()):e,null==i?i="":"number"==typeof i?i+="":x.isArray(i)&&(i=x.map(i,function(e){return null==e?"":e+""})),t=x.valHooks[this.type]||x.valHooks[this.nodeName.toLowerCase()],t&&"set"in t&&t.set(this,i,"value")!==undefined||(this.value=i))});if(i)return t=x.valHooks[i.type]||x.valHooks[i.nodeName.toLowerCase()],t&&"get"in t&&(n=t.get(i,"value"))!==undefined?n:(n=i.value,"string"==typeof n?n.replace($,""):null==n?"":n)}}}),x.extend({valHooks:{option:{get:function(e){var t=e.attributes.value;return!t||t.specified?e.value:e.text}},select:{get:function(e){var t,n,r=e.options,i=e.selectedIndex,o="select-one"===e.type||0>i,s=o?null:[],a=o?i+1:r.length,u=0>i?a:o?i:0;for(;a>u;u++)if(n=r[u],!(!n.selected&&u!==i||(x.support.optDisabled?n.disabled:null!==n.getAttribute("disabled"))||n.parentNode.disabled&&x.nodeName(n.parentNode,"optgroup"))){if(t=x(n).val(),o)return t;s.push(t)}return s},set:function(e,t){var n,r,i=e.options,o=x.makeArray(t),s=i.length;while(s--)r=i[s],(r.selected=x.inArray(x(r).val(),o)>=0)&&(n=!0);return n||(e.selectedIndex=-1),o}}},attr:function(e,t,n){var i,o,s=e.nodeType;if(e&&3!==s&&8!==s&&2!==s)return typeof e.getAttribute===r?x.prop(e,t,n):(1===s&&x.isXMLDoc(e)||(t=t.toLowerCase(),i=x.attrHooks[t]||(x.expr.match.bool.test(t)?M:R)),n===undefined?i&&"get"in i&&null!==(o=i.get(e,t))?o:(o=x.find.attr(e,t),null==o?undefined:o):null!==n?i&&"set"in i&&(o=i.set(e,n,t))!==undefined?o:(e.setAttribute(t,n+""),n):(x.removeAttr(e,t),undefined))},removeAttr:function(e,t){var n,r,i=0,o=t&&t.match(w);if(o&&1===e.nodeType)while(n=o[i++])r=x.propFix[n]||n,x.expr.match.bool.test(n)&&(e[r]=!1),e.removeAttribute(n)},attrHooks:{type:{set:function(e,t){if(!x.support.radioValue&&"radio"===t&&x.nodeName(e,"input")){var n=e.value;return e.setAttribute("type",t),n&&(e.value=n),t}}}},propFix:{"for":"htmlFor","class":"className"},prop:function(e,t,n){var r,i,o,s=e.nodeType;if(e&&3!==s&&8!==s&&2!==s)return o=1!==s||!x.isXMLDoc(e),o&&(t=x.propFix[t]||t,i=x.propHooks[t]),n!==undefined?i&&"set"in i&&(r=i.set(e,n,t))!==undefined?r:e[t]=n:i&&"get"in i&&null!==(r=i.get(e,t))?r:e[t]},propHooks:{tabIndex:{get:function(e){return e.hasAttribute("tabindex")||B.test(e.nodeName)||e.href?e.tabIndex:-1}}}}),M={set:function(e,t,n){return t===!1?x.removeAttr(e,n):e.setAttribute(n,n),n}},x.each(x.expr.match.bool.source.match(/\w+/g),function(e,t){var n=x.expr.attrHandle[t]||x.find.attr;x.expr.attrHandle[t]=function(e,t,r){var i=x.expr.attrHandle[t],o=r?undefined:(x.expr.attrHandle[t]=undefined)!=n(e,t,r)?t.toLowerCase():null;return x.expr.attrHandle[t]=i,o}}),x.support.optSelected||(x.propHooks.selected={get:function(e){var t=e.parentNode;return t&&t.parentNode&&t.parentNode.selectedIndex,null}}),x.each(["tabIndex","readOnly","maxLength","cellSpacing","cellPadding","rowSpan","colSpan","useMap","frameBorder","contentEditable"],function(){x.propFix[this.toLowerCase()]=this}),x.each(["radio","checkbox"],function(){x.valHooks[this]={set:function(e,t){return x.isArray(t)?e.checked=x.inArray(x(e).val(),t)>=0:undefined}},x.support.checkOn||(x.valHooks[this].get=function(e){return null===e.getAttribute("value")?"on":e.value})});var I=/^key/,z=/^(?:mouse|contextmenu)|click/,_=/^(?:focusinfocus|focusoutblur)$/,X=/^([^.]*)(?:\.(.+)|)$/;function U(){return!0}function Y(){return!1}function V(){try{return o.activeElement}catch(e){}}x.event={global:{},add:function(e,t,n,i,o){var s,a,u,l,c,p,f,h,d,g,m,y=q.get(e);if(y){n.handler&&(s=n,n=s.handler,o=s.selector),n.guid||(n.guid=x.guid++),(l=y.events)||(l=y.events={}),(a=y.handle)||(a=y.handle=function(e){return typeof x===r||e&&x.event.triggered===e.type?undefined:x.event.dispatch.apply(a.elem,arguments)},a.elem=e),t=(t||"").match(w)||[""],c=t.length;while(c--)u=X.exec(t[c])||[],d=m=u[1],g=(u[2]||"").split(".").sort(),d&&(f=x.event.special[d]||{},d=(o?f.delegateType:f.bindType)||d,f=x.event.special[d]||{},p=x.extend({type:d,origType:m,data:i,handler:n,guid:n.guid,selector:o,needsContext:o&&x.expr.match.needsContext.test(o),namespace:g.join(".")},s),(h=l[d])||(h=l[d]=[],h.delegateCount=0,f.setup&&f.setup.call(e,i,g,a)!==!1||e.addEventListener&&e.addEventListener(d,a,!1)),f.add&&(f.add.call(e,p),p.handler.guid||(p.handler.guid=n.guid)),o?h.splice(h.delegateCount++,0,p):h.push(p),x.event.global[d]=!0);e=null}},remove:function(e,t,n,r,i){var o,s,a,u,l,c,p,f,h,d,g,m=q.hasData(e)&&q.get(e);if(m&&(u=m.events)){t=(t||"").match(w)||[""],l=t.length;while(l--)if(a=X.exec(t[l])||[],h=g=a[1],d=(a[2]||"").split(".").sort(),h){p=x.event.special[h]||{},h=(r?p.delegateType:p.bindType)||h,f=u[h]||[],a=a[2]&&RegExp("(^|\\.)"+d.join("\\.(?:.*\\.|)")+"(\\.|$)"),s=o=f.length;while(o--)c=f[o],!i&&g!==c.origType||n&&n.guid!==c.guid||a&&!a.test(c.namespace)||r&&r!==c.selector&&("**"!==r||!c.selector)||(f.splice(o,1),c.selector&&f.delegateCount--,p.remove&&p.remove.call(e,c));s&&!f.length&&(p.teardown&&p.teardown.call(e,d,m.handle)!==!1||x.removeEvent(e,h,m.handle),delete u[h])}else for(h in u)x.event.remove(e,h+t[l],n,r,!0);x.isEmptyObject(u)&&(delete m.handle,q.remove(e,"events"))}},trigger:function(t,n,r,i){var s,a,u,l,c,p,f,h=[r||o],d=y.call(t,"type")?t.type:t,g=y.call(t,"namespace")?t.namespace.split("."):[];if(a=u=r=r||o,3!==r.nodeType&&8!==r.nodeType&&!_.test(d+x.event.triggered)&&(d.indexOf(".")>=0&&(g=d.split("."),d=g.shift(),g.sort()),c=0>d.indexOf(":")&&"on"+d,t=t[x.expando]?t:new x.Event(d,"object"==typeof t&&t),t.isTrigger=i?2:3,t.namespace=g.join("."),t.namespace_re=t.namespace?RegExp("(^|\\.)"+g.join("\\.(?:.*\\.|)")+"(\\.|$)"):null,t.result=undefined,t.target||(t.target=r),n=null==n?[t]:x.makeArray(n,[t]),f=x.event.special[d]||{},i||!f.trigger||f.trigger.apply(r,n)!==!1)){if(!i&&!f.noBubble&&!x.isWindow(r)){for(l=f.delegateType||d,_.test(l+d)||(a=a.parentNode);a;a=a.parentNode)h.push(a),u=a;u===(r.ownerDocument||o)&&h.push(u.defaultView||u.parentWindow||e)}s=0;while((a=h[s++])&&!t.isPropagationStopped())t.type=s>1?l:f.bindType||d,p=(q.get(a,"events")||{})[t.type]&&q.get(a,"handle"),p&&p.apply(a,n),p=c&&a[c],p&&x.acceptData(a)&&p.apply&&p.apply(a,n)===!1&&t.preventDefault();return t.type=d,i||t.isDefaultPrevented()||f._default&&f._default.apply(h.pop(),n)!==!1||!x.acceptData(r)||c&&x.isFunction(r[d])&&!x.isWindow(r)&&(u=r[c],u&&(r[c]=null),x.event.triggered=d,r[d](),x.event.triggered=undefined,u&&(r[c]=u)),t.result}},dispatch:function(e){e=x.event.fix(e);var t,n,r,i,o,s=[],a=d.call(arguments),u=(q.get(this,"events")||{})[e.type]||[],l=x.event.special[e.type]||{};if(a[0]=e,e.delegateTarget=this,!l.preDispatch||l.preDispatch.call(this,e)!==!1){s=x.event.handlers.call(this,e,u),t=0;while((i=s[t++])&&!e.isPropagationStopped()){e.currentTarget=i.elem,n=0;while((o=i.handlers[n++])&&!e.isImmediatePropagationStopped())(!e.namespace_re||e.namespace_re.test(o.namespace))&&(e.handleObj=o,e.data=o.data,r=((x.event.special[o.origType]||{}).handle||o.handler).apply(i.elem,a),r!==undefined&&(e.result=r)===!1&&(e.preventDefault(),e.stopPropagation()))}return l.postDispatch&&l.postDispatch.call(this,e),e.result}},handlers:function(e,t){var n,r,i,o,s=[],a=t.delegateCount,u=e.target;if(a&&u.nodeType&&(!e.button||"click"!==e.type))for(;u!==this;u=u.parentNode||this)if(u.disabled!==!0||"click"!==e.type){for(r=[],n=0;a>n;n++)o=t[n],i=o.selector+" ",r[i]===undefined&&(r[i]=o.needsContext?x(i,this).index(u)>=0:x.find(i,this,null,[u]).length),r[i]&&r.push(o);r.length&&s.push({elem:u,handlers:r})}return t.length>a&&s.push({elem:this,handlers:t.slice(a)}),s},props:"altKey bubbles cancelable ctrlKey currentTarget eventPhase metaKey relatedTarget shiftKey target timeStamp view which".split(" "),fixHooks:{},keyHooks:{props:"char charCode key keyCode".split(" "),filter:function(e,t){return null==e.which&&(e.which=null!=t.charCode?t.charCode:t.keyCode),e}},mouseHooks:{props:"button buttons clientX clientY offsetX offsetY pageX pageY screenX screenY toElement".split(" "),filter:function(e,t){var n,r,i,s=t.button;return null==e.pageX&&null!=t.clientX&&(n=e.target.ownerDocument||o,r=n.documentElement,i=n.body,e.pageX=t.clientX+(r&&r.scrollLeft||i&&i.scrollLeft||0)-(r&&r.clientLeft||i&&i.clientLeft||0),e.pageY=t.clientY+(r&&r.scrollTop||i&&i.scrollTop||0)-(r&&r.clientTop||i&&i.clientTop||0)),e.which||s===undefined||(e.which=1&s?1:2&s?3:4&s?2:0),e}},fix:function(e){if(e[x.expando])return e;var t,n,r,i=e.type,s=e,a=this.fixHooks[i];a||(this.fixHooks[i]=a=z.test(i)?this.mouseHooks:I.test(i)?this.keyHooks:{}),r=a.props?this.props.concat(a.props):this.props,e=new x.Event(s),t=r.length;while(t--)n=r[t],e[n]=s[n];return e.target||(e.target=o),3===e.target.nodeType&&(e.target=e.target.parentNode),a.filter?a.filter(e,s):e},special:{load:{noBubble:!0},focus:{trigger:function(){return this!==V()&&this.focus?(this.focus(),!1):undefined},delegateType:"focusin"},blur:{trigger:function(){return this===V()&&this.blur?(this.blur(),!1):undefined},delegateType:"focusout"},click:{trigger:function(){return"checkbox"===this.type&&this.click&&x.nodeName(this,"input")?(this.click(),!1):undefined},_default:function(e){return x.nodeName(e.target,"a")}},beforeunload:{postDispatch:function(e){e.result!==undefined&&(e.originalEvent.returnValue=e.result)}}},simulate:function(e,t,n,r){var i=x.extend(new x.Event,n,{type:e,isSimulated:!0,originalEvent:{}});r?x.event.trigger(i,null,t):x.event.dispatch.call(t,i),i.isDefaultPrevented()&&n.preventDefault()}},x.removeEvent=function(e,t,n){e.removeEventListener&&e.removeEventListener(t,n,!1)},x.Event=function(e,t){return this instanceof x.Event?(e&&e.type?(this.originalEvent=e,this.type=e.type,this.isDefaultPrevented=e.defaultPrevented||e.getPreventDefault&&e.getPreventDefault()?U:Y):this.type=e,t&&x.extend(this,t),this.timeStamp=e&&e.timeStamp||x.now(),this[x.expando]=!0,undefined):new x.Event(e,t)},x.Event.prototype={isDefaultPrevented:Y,isPropagationStopped:Y,isImmediatePropagationStopped:Y,preventDefault:function(){var e=this.originalEvent;this.isDefaultPrevented=U,e&&e.preventDefault&&e.preventDefault()},stopPropagation:function(){var e=this.originalEvent;this.isPropagationStopped=U,e&&e.stopPropagation&&e.stopPropagation()},stopImmediatePropagation:function(){this.isImmediatePropagationStopped=U,this.stopPropagation()}},x.each({mouseenter:"mouseover",mouseleave:"mouseout"},function(e,t){x.event.special[e]={delegateType:t,bindType:t,handle:function(e){var n,r=this,i=e.relatedTarget,o=e.handleObj;return(!i||i!==r&&!x.contains(r,i))&&(e.type=o.origType,n=o.handler.apply(this,arguments),e.type=t),n}}}),x.support.focusinBubbles||x.each({focus:"focusin",blur:"focusout"},function(e,t){var n=0,r=function(e){x.event.simulate(t,e.target,x.event.fix(e),!0)};x.event.special[t]={setup:function(){0===n++&&o.addEventListener(e,r,!0)},teardown:function(){0===--n&&o.removeEventListener(e,r,!0)}}}),x.fn.extend({on:function(e,t,n,r,i){var o,s;if("object"==typeof e){"string"!=typeof t&&(n=n||t,t=undefined);for(s in e)this.on(s,t,n,e[s],i);return this}if(null==n&&null==r?(r=t,n=t=undefined):null==r&&("string"==typeof t?(r=n,n=undefined):(r=n,n=t,t=undefined)),r===!1)r=Y;else if(!r)return this;return 1===i&&(o=r,r=function(e){return x().off(e),o.apply(this,arguments)},r.guid=o.guid||(o.guid=x.guid++)),this.each(function(){x.event.add(this,e,r,n,t)})},one:function(e,t,n,r){return this.on(e,t,n,r,1)},off:function(e,t,n){var r,i;if(e&&e.preventDefault&&e.handleObj)return r=e.handleObj,x(e.delegateTarget).off(r.namespace?r.origType+"."+r.namespace:r.origType,r.selector,r.handler),this;if("object"==typeof e){for(i in e)this.off(i,t,e[i]);return this}return(t===!1||"function"==typeof t)&&(n=t,t=undefined),n===!1&&(n=Y),this.each(function(){x.event.remove(this,e,n,t)})},trigger:function(e,t){return this.each(function(){x.event.trigger(e,t,this)})},triggerHandler:function(e,t){var n=this[0];return n?x.event.trigger(e,t,n,!0):undefined}});var G=/^.[^:#\[\.,]*$/,J=/^(?:parents|prev(?:Until|All))/,Q=x.expr.match.needsContext,K={children:!0,contents:!0,next:!0,prev:!0};x.fn.extend({find:function(e){var t,n=[],r=this,i=r.length;if("string"!=typeof e)return this.pushStack(x(e).filter(function(){for(t=0;i>t;t++)if(x.contains(r[t],this))return!0}));for(t=0;i>t;t++)x.find(e,r[t],n);return n=this.pushStack(i>1?x.unique(n):n),n.selector=this.selector?this.selector+" "+e:e,n},has:function(e){var t=x(e,this),n=t.length;return this.filter(function(){var e=0;for(;n>e;e++)if(x.contains(this,t[e]))return!0})},not:function(e){return this.pushStack(et(this,e||[],!0))},filter:function(e){return this.pushStack(et(this,e||[],!1))},is:function(e){return!!et(this,"string"==typeof e&&Q.test(e)?x(e):e||[],!1).length},closest:function(e,t){var n,r=0,i=this.length,o=[],s=Q.test(e)||"string"!=typeof e?x(e,t||this.context):0;for(;i>r;r++)for(n=this[r];n&&n!==t;n=n.parentNode)if(11>n.nodeType&&(s?s.index(n)>-1:1===n.nodeType&&x.find.matchesSelector(n,e))){n=o.push(n);break}return this.pushStack(o.length>1?x.unique(o):o)},index:function(e){return e?"string"==typeof e?g.call(x(e),this[0]):g.call(this,e.jquery?e[0]:e):this[0]&&this[0].parentNode?this.first().prevAll().length:-1},add:function(e,t){var n="string"==typeof e?x(e,t):x.makeArray(e&&e.nodeType?[e]:e),r=x.merge(this.get(),n);return this.pushStack(x.unique(r))},addBack:function(e){return this.add(null==e?this.prevObject:this.prevObject.filter(e))}});function Z(e,t){while((e=e[t])&&1!==e.nodeType);return e}x.each({parent:function(e){var t=e.parentNode;return t&&11!==t.nodeType?t:null},parents:function(e){return x.dir(e,"parentNode")},parentsUntil:function(e,t,n){return x.dir(e,"parentNode",n)},next:function(e){return Z(e,"nextSibling")},prev:function(e){return Z(e,"previousSibling")},nextAll:function(e){return x.dir(e,"nextSibling")},prevAll:function(e){return x.dir(e,"previousSibling")},nextUntil:function(e,t,n){return x.dir(e,"nextSibling",n)},prevUntil:function(e,t,n){return x.dir(e,"previousSibling",n)},siblings:function(e){return x.sibling((e.parentNode||{}).firstChild,e)},children:function(e){return x.sibling(e.firstChild)},contents:function(e){return e.contentDocument||x.merge([],e.childNodes)}},function(e,t){x.fn[e]=function(n,r){var i=x.map(this,t,n);return"Until"!==e.slice(-5)&&(r=n),r&&"string"==typeof r&&(i=x.filter(r,i)),this.length>1&&(K[e]||x.unique(i),J.test(e)&&i.reverse()),this.pushStack(i)}}),x.extend({filter:function(e,t,n){var r=t[0];return n&&(e=":not("+e+")"),1===t.length&&1===r.nodeType?x.find.matchesSelector(r,e)?[r]:[]:x.find.matches(e,x.grep(t,function(e){return 1===e.nodeType}))},dir:function(e,t,n){var r=[],i=n!==undefined;while((e=e[t])&&9!==e.nodeType)if(1===e.nodeType){if(i&&x(e).is(n))break;r.push(e)}return r},sibling:function(e,t){var n=[];for(;e;e=e.nextSibling)1===e.nodeType&&e!==t&&n.push(e);return n}});function et(e,t,n){if(x.isFunction(t))return x.grep(e,function(e,r){return!!t.call(e,r,e)!==n});if(t.nodeType)return x.grep(e,function(e){return e===t!==n});if("string"==typeof t){if(G.test(t))return x.filter(t,e,n);t=x.filter(t,e)}return x.grep(e,function(e){return g.call(t,e)>=0!==n})}var tt=/<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\w:]+)[^>]*)\/>/gi,nt=/<([\w:]+)/,rt=/<|&#?\w+;/,it=/<(?:script|style|link)/i,ot=/^(?:checkbox|radio)$/i,st=/checked\s*(?:[^=]|=\s*.checked.)/i,at=/^$|\/(?:java|ecma)script/i,ut=/^true\/(.*)/,lt=/^\s*\s*$/g,ct={option:[1,""],thead:[1,"","
"],col:[2,"","
"],tr:[2,"","
"],td:[3,"","
"],_default:[0,"",""]};ct.optgroup=ct.option,ct.tbody=ct.tfoot=ct.colgroup=ct.caption=ct.thead,ct.th=ct.td,x.fn.extend({text:function(e){return x.access(this,function(e){return e===undefined?x.text(this):this.empty().append((this[0]&&this[0].ownerDocument||o).createTextNode(e))},null,e,arguments.length)},append:function(){return this.domManip(arguments,function(e){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var t=pt(this,e);t.appendChild(e)}})},prepend:function(){return this.domManip(arguments,function(e){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var t=pt(this,e);t.insertBefore(e,t.firstChild)}})},before:function(){return this.domManip(arguments,function(e){this.parentNode&&this.parentNode.insertBefore(e,this)})},after:function(){return this.domManip(arguments,function(e){this.parentNode&&this.parentNode.insertBefore(e,this.nextSibling)})},remove:function(e,t){var n,r=e?x.filter(e,this):this,i=0;for(;null!=(n=r[i]);i++)t||1!==n.nodeType||x.cleanData(mt(n)),n.parentNode&&(t&&x.contains(n.ownerDocument,n)&&dt(mt(n,"script")),n.parentNode.removeChild(n));return this},empty:function(){var e,t=0;for(;null!=(e=this[t]);t++)1===e.nodeType&&(x.cleanData(mt(e,!1)),e.textContent="");return this},clone:function(e,t){return e=null==e?!1:e,t=null==t?e:t,this.map(function(){return x.clone(this,e,t)})},html:function(e){return x.access(this,function(e){var t=this[0]||{},n=0,r=this.length;if(e===undefined&&1===t.nodeType)return t.innerHTML;if("string"==typeof e&&!it.test(e)&&!ct[(nt.exec(e)||["",""])[1].toLowerCase()]){e=e.replace(tt,"<$1>");try{for(;r>n;n++)t=this[n]||{},1===t.nodeType&&(x.cleanData(mt(t,!1)),t.innerHTML=e);t=0}catch(i){}}t&&this.empty().append(e)},null,e,arguments.length)},replaceWith:function(){var e=x.map(this,function(e){return[e.nextSibling,e.parentNode]}),t=0;return this.domManip(arguments,function(n){var r=e[t++],i=e[t++];i&&(r&&r.parentNode!==i&&(r=this.nextSibling),x(this).remove(),i.insertBefore(n,r))},!0),t?this:this.remove()},detach:function(e){return this.remove(e,!0)},domManip:function(e,t,n){e=f.apply([],e);var r,i,o,s,a,u,l=0,c=this.length,p=this,h=c-1,d=e[0],g=x.isFunction(d);if(g||!(1>=c||"string"!=typeof d||x.support.checkClone)&&st.test(d))return this.each(function(r){var i=p.eq(r);g&&(e[0]=d.call(this,r,i.html())),i.domManip(e,t,n)});if(c&&(r=x.buildFragment(e,this[0].ownerDocument,!1,!n&&this),i=r.firstChild,1===r.childNodes.length&&(r=i),i)){for(o=x.map(mt(r,"script"),ft),s=o.length;c>l;l++)a=r,l!==h&&(a=x.clone(a,!0,!0),s&&x.merge(o,mt(a,"script"))),t.call(this[l],a,l);if(s)for(u=o[o.length-1].ownerDocument,x.map(o,ht),l=0;s>l;l++)a=o[l],at.test(a.type||"")&&!q.access(a,"globalEval")&&x.contains(u,a)&&(a.src?x._evalUrl(a.src):x.globalEval(a.textContent.replace(lt,"")))}return this}}),x.each({appendTo:"append",prependTo:"prepend",insertBefore:"before",insertAfter:"after",replaceAll:"replaceWith"},function(e,t){x.fn[e]=function(e){var n,r=[],i=x(e),o=i.length-1,s=0;for(;o>=s;s++)n=s===o?this:this.clone(!0),x(i[s])[t](n),h.apply(r,n.get());return this.pushStack(r)}}),x.extend({clone:function(e,t,n){var r,i,o,s,a=e.cloneNode(!0),u=x.contains(e.ownerDocument,e);if(!(x.support.noCloneChecked||1!==e.nodeType&&11!==e.nodeType||x.isXMLDoc(e)))for(s=mt(a),o=mt(e),r=0,i=o.length;i>r;r++)yt(o[r],s[r]);if(t)if(n)for(o=o||mt(e),s=s||mt(a),r=0,i=o.length;i>r;r++)gt(o[r],s[r]);else gt(e,a);return s=mt(a,"script"),s.length>0&&dt(s,!u&&mt(e,"script")),a},buildFragment:function(e,t,n,r){var i,o,s,a,u,l,c=0,p=e.length,f=t.createDocumentFragment(),h=[];for(;p>c;c++)if(i=e[c],i||0===i)if("object"===x.type(i))x.merge(h,i.nodeType?[i]:i);else if(rt.test(i)){o=o||f.appendChild(t.createElement("div")),s=(nt.exec(i)||["",""])[1].toLowerCase(),a=ct[s]||ct._default,o.innerHTML=a[1]+i.replace(tt,"<$1>")+a[2],l=a[0];while(l--)o=o.lastChild;x.merge(h,o.childNodes),o=f.firstChild,o.textContent=""}else h.push(t.createTextNode(i));f.textContent="",c=0;while(i=h[c++])if((!r||-1===x.inArray(i,r))&&(u=x.contains(i.ownerDocument,i),o=mt(f.appendChild(i),"script"),u&&dt(o),n)){l=0;while(i=o[l++])at.test(i.type||"")&&n.push(i)}return f},cleanData:function(e){var t,n,r,i,o,s,a=x.event.special,u=0;for(;(n=e[u])!==undefined;u++){if(F.accepts(n)&&(o=n[q.expando],o&&(t=q.cache[o]))){if(r=Object.keys(t.events||{}),r.length)for(s=0;(i=r[s])!==undefined;s++)a[i]?x.event.remove(n,i):x.removeEvent(n,i,t.handle);q.cache[o]&&delete q.cache[o]}delete L.cache[n[L.expando]]}},_evalUrl:function(e){return x.ajax({url:e,type:"GET",dataType:"script",async:!1,global:!1,"throws":!0})}});function pt(e,t){return x.nodeName(e,"table")&&x.nodeName(1===t.nodeType?t:t.firstChild,"tr")?e.getElementsByTagName("tbody")[0]||e.appendChild(e.ownerDocument.createElement("tbody")):e}function ft(e){return e.type=(null!==e.getAttribute("type"))+"/"+e.type,e}function ht(e){var t=ut.exec(e.type);return t?e.type=t[1]:e.removeAttribute("type"),e}function dt(e,t){var n=e.length,r=0;for(;n>r;r++)q.set(e[r],"globalEval",!t||q.get(t[r],"globalEval"))}function gt(e,t){var n,r,i,o,s,a,u,l;if(1===t.nodeType){if(q.hasData(e)&&(o=q.access(e),s=q.set(t,o),l=o.events)){delete s.handle,s.events={};for(i in l)for(n=0,r=l[i].length;r>n;n++)x.event.add(t,i,l[i][n])}L.hasData(e)&&(a=L.access(e),u=x.extend({},a),L.set(t,u))}}function mt(e,t){var n=e.getElementsByTagName?e.getElementsByTagName(t||"*"):e.querySelectorAll?e.querySelectorAll(t||"*"):[];return t===undefined||t&&x.nodeName(e,t)?x.merge([e],n):n}function yt(e,t){var n=t.nodeName.toLowerCase();"input"===n&&ot.test(e.type)?t.checked=e.checked:("input"===n||"textarea"===n)&&(t.defaultValue=e.defaultValue)}x.fn.extend({wrapAll:function(e){var t;return x.isFunction(e)?this.each(function(t){x(this).wrapAll(e.call(this,t))}):(this[0]&&(t=x(e,this[0].ownerDocument).eq(0).clone(!0),this[0].parentNode&&t.insertBefore(this[0]),t.map(function(){var e=this;while(e.firstElementChild)e=e.firstElementChild;return e}).append(this)),this)},wrapInner:function(e){return x.isFunction(e)?this.each(function(t){x(this).wrapInner(e.call(this,t))}):this.each(function(){var t=x(this),n=t.contents();n.length?n.wrapAll(e):t.append(e)})},wrap:function(e){var t=x.isFunction(e);return this.each(function(n){x(this).wrapAll(t?e.call(this,n):e)})},unwrap:function(){return this.parent().each(function(){x.nodeName(this,"body")||x(this).replaceWith(this.childNodes)}).end()}});var vt,xt,bt=/^(none|table(?!-c[ea]).+)/,wt=/^margin/,Tt=RegExp("^("+b+")(.*)$","i"),Ct=RegExp("^("+b+")(?!px)[a-z%]+$","i"),kt=RegExp("^([+-])=("+b+")","i"),Nt={BODY:"block"},Et={position:"absolute",visibility:"hidden",display:"block"},St={letterSpacing:0,fontWeight:400},jt=["Top","Right","Bottom","Left"],Dt=["Webkit","O","Moz","ms"];function At(e,t){if(t in e)return t;var n=t.charAt(0).toUpperCase()+t.slice(1),r=t,i=Dt.length;while(i--)if(t=Dt[i]+n,t in e)return t;return r}function Lt(e,t){return e=t||e,"none"===x.css(e,"display")||!x.contains(e.ownerDocument,e)}function qt(t){return e.getComputedStyle(t,null)}function Ht(e,t){var n,r,i,o=[],s=0,a=e.length;for(;a>s;s++)r=e[s],r.style&&(o[s]=q.get(r,"olddisplay"),n=r.style.display,t?(o[s]||"none"!==n||(r.style.display=""),""===r.style.display&&Lt(r)&&(o[s]=q.access(r,"olddisplay",Rt(r.nodeName)))):o[s]||(i=Lt(r),(n&&"none"!==n||!i)&&q.set(r,"olddisplay",i?n:x.css(r,"display"))));for(s=0;a>s;s++)r=e[s],r.style&&(t&&"none"!==r.style.display&&""!==r.style.display||(r.style.display=t?o[s]||"":"none"));return e}x.fn.extend({css:function(e,t){return x.access(this,function(e,t,n){var r,i,o={},s=0;if(x.isArray(t)){for(r=qt(e),i=t.length;i>s;s++)o[t[s]]=x.css(e,t[s],!1,r);return o}return n!==undefined?x.style(e,t,n):x.css(e,t)},e,t,arguments.length>1)},show:function(){return Ht(this,!0)},hide:function(){return Ht(this)},toggle:function(e){return"boolean"==typeof e?e?this.show():this.hide():this.each(function(){Lt(this)?x(this).show():x(this).hide()})}}),x.extend({cssHooks:{opacity:{get:function(e,t){if(t){var n=vt(e,"opacity");return""===n?"1":n}}}},cssNumber:{columnCount:!0,fillOpacity:!0,fontWeight:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,widows:!0,zIndex:!0,zoom:!0},cssProps:{"float":"cssFloat"},style:function(e,t,n,r){if(e&&3!==e.nodeType&&8!==e.nodeType&&e.style){var i,o,s,a=x.camelCase(t),u=e.style;return t=x.cssProps[a]||(x.cssProps[a]=At(u,a)),s=x.cssHooks[t]||x.cssHooks[a],n===undefined?s&&"get"in s&&(i=s.get(e,!1,r))!==undefined?i:u[t]:(o=typeof n,"string"===o&&(i=kt.exec(n))&&(n=(i[1]+1)*i[2]+parseFloat(x.css(e,t)),o="number"),null==n||"number"===o&&isNaN(n)||("number"!==o||x.cssNumber[a]||(n+="px"),x.support.clearCloneStyle||""!==n||0!==t.indexOf("background")||(u[t]="inherit"),s&&"set"in s&&(n=s.set(e,n,r))===undefined||(u[t]=n)),undefined)}},css:function(e,t,n,r){var i,o,s,a=x.camelCase(t);return t=x.cssProps[a]||(x.cssProps[a]=At(e.style,a)),s=x.cssHooks[t]||x.cssHooks[a],s&&"get"in s&&(i=s.get(e,!0,n)),i===undefined&&(i=vt(e,t,r)),"normal"===i&&t in St&&(i=St[t]),""===n||n?(o=parseFloat(i),n===!0||x.isNumeric(o)?o||0:i):i}}),vt=function(e,t,n){var r,i,o,s=n||qt(e),a=s?s.getPropertyValue(t)||s[t]:undefined,u=e.style;return s&&(""!==a||x.contains(e.ownerDocument,e)||(a=x.style(e,t)),Ct.test(a)&&wt.test(t)&&(r=u.width,i=u.minWidth,o=u.maxWidth,u.minWidth=u.maxWidth=u.width=a,a=s.width,u.width=r,u.minWidth=i,u.maxWidth=o)),a};function Ot(e,t,n){var r=Tt.exec(t);return r?Math.max(0,r[1]-(n||0))+(r[2]||"px"):t}function Ft(e,t,n,r,i){var o=n===(r?"border":"content")?4:"width"===t?1:0,s=0;for(;4>o;o+=2)"margin"===n&&(s+=x.css(e,n+jt[o],!0,i)),r?("content"===n&&(s-=x.css(e,"padding"+jt[o],!0,i)),"margin"!==n&&(s-=x.css(e,"border"+jt[o]+"Width",!0,i))):(s+=x.css(e,"padding"+jt[o],!0,i),"padding"!==n&&(s+=x.css(e,"border"+jt[o]+"Width",!0,i)));return s}function Pt(e,t,n){var r=!0,i="width"===t?e.offsetWidth:e.offsetHeight,o=qt(e),s=x.support.boxSizing&&"border-box"===x.css(e,"boxSizing",!1,o);if(0>=i||null==i){if(i=vt(e,t,o),(0>i||null==i)&&(i=e.style[t]),Ct.test(i))return i;r=s&&(x.support.boxSizingReliable||i===e.style[t]),i=parseFloat(i)||0}return i+Ft(e,t,n||(s?"border":"content"),r,o)+"px"}function Rt(e){var t=o,n=Nt[e];return n||(n=Mt(e,t),"none"!==n&&n||(xt=(xt||x("'); + } else { + aY.append(bi.content); + } + a7.find('img').on('error', aG); + a7.find('div.entry-title a.entry-link').click(aa); + a7.find('div.entry-nptitle > a').click(aa); + if (L.isTextRTL(bi.content, true, 100)) { + aY.addClass('rtl-layout'); + } + if (bi.starred == 1) { + a7.find('span#topstar-' + bi.id).addClass('starred'); + a7.find('span#star-' + bi.id).addClass('starred'); + } + if (bi.unread == 1) { + a7.addClass('unread'); + } + if (a6.firstload == true && a6.activelink == undefined && a7.hasClass('entry')) { + a7.addClass('active'); + a6.activelink = true; + } + try { + a7.find('div.tags').tagselector({ + tags: bi.tags, + autocomplete: bj, + eventAdd: aL(bj), + eventRemove: e, + eventSelect: aI + }); + } catch (a5) { + console.log('Error: cannot initialize tag selector for entry ' + bi.id); + } + a7.click(F); + if (a6.action != 'preview') { + a7.find('span.star').click(k); + bh = a7.find('> div.entry-body > div.itemlinks'); + bh.find('input.unreadbox').click(g); + bh.find('a.delete-entry').click(C); + bh.find('a.share').click(aE(bi)); + a7.find('div.entry-title span.delete-entry-upper').click(function () { + $(this).parent().parent().parent().parent().parent().parent().find('div.itemlinks > a.delete-entry').click(); + }); + a7.find('div.entry-title span.readtoggle-entry-upper').click(function () { + var bn = $(this).parent().parent().parent().parent().parent().parent(); + ar(parseInt(bn.attr('data-id'), 10)); + }); + a7.find('div.entry-header > div.fromline > img.fromlinefavicon').click(function () { + var bn = $(this); + aC(parseInt(bn.attr('data-feedid'), 10)); + }); + } + if (c == feedbro.Engine.VIEWMODE_NEWS || c == feedbro.Engine.VIEWMODE_NEWSLINEMODE) { + a7.find('div.entry-newspaper-section').click(function (bp) { + var bq = $(this); + var bo = bq.parent(); + if ($(bp.target).is('a')) { + return; + } + ay(bo.find('div.entry-body > blockquote:first')); + bo.removeClass('entry-newspaper'); + bq.css('display', 'none'); + $('div.active').removeClass('active'); + bo.addClass('active'); + var bn = $('div#feed'); + bn.scrollTop(bn.scrollTop() + parseInt(bo.offset().top, 10) - parseInt($('div#toolbar').outerHeight(), 10) - 1); + }); + } + try { + ba = bi.enclosures; + if (ba != undefined && Array.isArray(ba) && ba.length > 0) { + for (bc = 0; bc < ba.length; bc++) { + a4 = ba[bc]; + if (a4 == undefined) { + continue; + } + if (a4.url != undefined) { + a4.url = aO(a4.url); + } + if (a4.type != undefined) { + a4.type = aO(a4.type); + } + if (a4.length != undefined) { + a4.length = aO(a4.length); + } + aY.append(j.createTag(bi.id + '-' + bc, a4)); + } + } + } catch (bb) { + console.log('Error: could not initialize enclosure for entry: ' + bi.id); + } + $('div#feed').append(a7); + if (R.getMathJaxEnabled()) { + try { + if (n.shouldRender(bi.title) || n.shouldRender(bi.content)) { + n.render('blogentrypost-' + bi.id); + } + } catch (bb) { + console.log('Could not render MathJax: ', bb); + } + } + if (a6.action != 'preview' && bi.unread == 1 && a8 != 3) { + aP.once('trigger-' + bi.id, h); + } + } + + function ar(a4) { + var a2 = $('div#blogentrypost-' + a4); + try { + var aZ = a2.find('span.readtoggle-entry-upper > img'); + var a3 = aZ.attr('src') == 'images/icon-read.png'; + var a1 = a2.find('div.itemlinks > span.keepunread > input.unreadbox'); + var a5 = parseInt(a1.attr('id').substring(7), 10); + K().markUnread(a5, a3 ? 1 : 0); + var aY = $('div#titles > div.activetitle'); + if (aY.length > 0) { + if (a3) { + aY.addClass('unread'); + } else { + aY.removeClass('unread'); + } + } + if (a3) { + a2.addClass('unread'); + aZ.attr('src', 'images/icon-unread.png'); + a1.prop('checked', true); + } else { + a2.removeClass('unread'); + aZ.attr('src', 'images/icon-read.png'); + a1.prop('checked', false); + } + } catch (a0) { + console.log(a0); + } + } + + function l(aY) { + if (c == feedbro.Engine.VIEWMODE_NEWS || c == feedbro.Engine.VIEWMODE_NEWSLINEMODE || c == feedbro.Engine.VIEWMODE_HEADLINES) { + if (aY.content) { + aY.content = aY.content.replace(L.getRegexp('<(img|iframe|audio|video|embed)([^>]*)src=([^>]*)', 'gi'), function (a2, a1, a0, aZ) { + var a3 = '<' + a1 + a0 + 'data-lazysingle=' + aZ; + a3 = a3.replace(/srcset=/g, 'data-lazymulti='); + return a3; + }); + } + } + } + + function ay(aY) { + aY.find('[data-lazysingle],[data-lazymulti]').each(function (a0, a1) { + var aZ; + aZ = a1.getAttribute('data-lazymulti'); + if (aZ != undefined && aZ != '') { + a1.setAttribute('srcset', aZ); + } + aZ = a1.getAttribute('data-lazysingle'); + if (aZ != undefined && aZ != '') { + a1.setAttribute('src', aZ); + } + }); + } + + function au(a2, aZ, aY, a1) { + var a0 = ''; + a0 += '
'; + if (a1.action != 'preview') { + a0 += '
'; + if (c == feedbro.Engine.VIEWMODE_HEADLINES) { + a0 += '
'; + } else { + a0 += '
'; + } + a0 += '' + aO(L.stripTags(a2.title)) + ' '; + if (a2.points != undefined) { + a0 += '(' + a2.points + ')'; + } + a0 += '
'; + a0 += '
'; + a0 += ' '; + a0 += ''; + a0 += ''; + a0 += '
'; + } else { + a0 += '' + aO(L.stripTags(a2.title)) + ' '; + } + a0 += '
'; + a0 += '
'; + if (R.getFaviconOnFromline()) { + a0 += ''; + } + a0 += Locale.i18n('article_fromline_from', true) + '
'; + a0 += aO(L.stripTags(a2.feed.title)) + '
'; + if (a2.author != undefined && a2.author != '') { + a0 += ' ' + Locale.i18n('article_fromline_by', true) + ' '; + } + a0 += '
# ' + aZ + '.
'; + return a0; + } + + function aA(aZ, aY) { + if (aZ != undefined && aY != undefined) { + return aZ.format(aY) + ' (' + L.timeAgo(aZ) + ') '; + } else { + return ''; + } + } + + function w(aY) { + return L.isTextRTL(aY, true, 100); + } + + function aq(a0, aY) { + var aZ = c; + c = a0; + $('div.mode').removeClass('active-mode'); + $('div#feed').attr('data-viewmode', (c + 1)); + if (a0 == 0) { + $('div#normalview').addClass('active-mode'); + Z(false); + aR(); + } else { + if (a0 == 1) { + $('div#headlineview').addClass('active-mode'); + Z(false); + aR(); + } else { + if (a0 == 2) { + $('div#3cola').addClass('active-mode'); + Z(true); + } else { + if (a0 == 3) { + Z(false); + $('div#newsview').addClass('active-mode'); + } else { + if (a0 == 4) { + Z(false); + $('div#newslinemode').addClass('active-mode'); + } else { + if (a0 == 5) { + $('div#3colaiframe').addClass('active-mode'); + Z(true); + } + } + } + } + } + } + if ((aZ == feedbro.Engine.VIEWMODE_OPERA || aZ == feedbro.Engine.VIEWMODE_OPERA_IFRAME || aZ == feedbro.Engine.VIEWMODE_NEWS) && (a0 == feedbro.Engine.VIEWMODE_HEADLINES || a0 == feedbro.Engine.VIEWMODE_FULL)) { + aH(); + } else { + if ((a0 == feedbro.Engine.VIEWMODE_OPERA || a0 == feedbro.Engine.VIEWMODE_OPERA_IFRAME) && (aZ == feedbro.Engine.VIEWMODE_HEADLINES || aZ == feedbro.Engine.VIEWMODE_FULL || aZ == feedbro.Engine.VIEWMODE_NEWS || aZ == feedbro.Engine.VIEWMODE_NEWSLINEMODE)) { + aH(); + } else { + if (a0 == feedbro.Engine.VIEWMODE_NEWS && aZ != feedbro.Engine.VIEWMODE_NEWS) { + aH(); + } else { + if (a0 == feedbro.Engine.VIEWMODE_NEWSLINEMODE && aZ != feedbro.Engine.VIEWMODE_NEWSLINEMODE) { + aH(); + } else { + if ((a0 == 0 || a0 == 1) && (aZ != 0 && aZ != 1)) { + aH(); + } else { + if (a0 == feedbro.Engine.VIEWMODE_FULL && aZ == feedbro.Engine.VIEWMODE_HEADLINES) { + $('blockquote.entry-blockquote').each(function (a1, a2) { + ay($(a2)); + }); + } + } + } + } + } + } + if (aY != true) { + K().getSettings().setViewMode(c); + K().saveSettings(); + } + } + + function ak() { + var aY = !$('input#onlyunread').prop('checked'); + aw(aY); + K().getSettings().setOnlyUnread(aY); + K().saveSettings(); + } + + function aw(aY) { + if (aY == true) { + $('div#unreadtoggle').addClass('active-mode'); + $('input#onlyunread').prop('checked', true); + } else { + $('div#unreadtoggle').removeClass('active-mode'); + $('input#onlyunread').prop('checked', false); + } + } + + aB.addStandardTag = function (aZ) { + var aY = $('div#feed > div.entry.active > div.entry-body > div.itemlinks > div.tags'); + if (aY.length == 0) { + aY = $('div#feed > div.entry > div.entry-body > div.itemlinks > div.tags'); + } + if (aY.length == 0) { + return; + } + aY.mouseenter(); + aY.find('input').val(aZ); + aY.find('button.tagadd').click(); + aY.mouseleave(); + }; + aB.activateAddTag = function () { + var aY = $('div#feed > div.entry.active > div.entry-body > div.itemlinks > div.tags'); + if (aY.length == 0) { + aY = $('div#feed > div.entry > div.entry-body > div.itemlinks > div.tags'); + } + if (aY.length == 0) { + return; + } + if (!aY.is(':visible')) { + return; + } + aY.mouseenter(); + aY.find('input').focus(); + }; + + function Y(a3, aZ) { + var a0 = 800; + var aY = 830; + var a2 = Math.round((screen.width / 2) - (a0 / 2)); + var a1 = Math.round((screen.height / 2) - (aY / 2)); + chrome.windows.create({url: chrome.runtime.getURL(aZ), type: 'popup', width: a0, height: aY, top: a1, left: a2}); + } +}; +feedbro.Engine.VIEWMODE_FULL = 0; +feedbro.Engine.VIEWMODE_HEADLINES = 1; +feedbro.Engine.VIEWMODE_OPERA = 2; +feedbro.Engine.VIEWMODE_NEWS = 3; +feedbro.Engine.VIEWMODE_NEWSLINEMODE = 4; +feedbro.Engine.VIEWMODE_OPERA_IFRAME = 5; +var feedbro = feedbro || {}; +feedbro.FaPlugin = function () { + this._strings = new feedbro.Strings(); +}; +feedbro.FaPlugin.prototype.canParse = function (a) { + return a && a.indexOf(atob('ZmFjZWJvb2suY29tLw==')) != -1; +}; +feedbro.FaPlugin.prototype.parse = function (e, c, a, f) { + var b = this; + var d = new XMLHttpRequest(); + d.onreadystatechange = function (j) { + if (d.readyState == 4) { + if (d.status == 200) { + var i = d.responseText; + var g = ''; + try { + g = b.toRSS(i, e.url); + } catch (h) { + console.log('Failed to parse: ' + e.url); + } + if (c) { + c(e.url, d, g, a, f, true); + } + } else { + c(e.url, d, '', a, f, true); + } + d.onreadystatechange = null; + d.onerror = null; + d.abort = null; + d = null; + } + }; + d.open('GET', e.url, true); + d.send(); +}; +feedbro.FaPlugin.prototype.toRSS = function (j, a) { + var d; + d = {stag: [''], etag: ''}; + this._strings.findNext(j, d); + var g = d.match; + var p = []; + var m = '\n\n\n'; + m += ' <![CDATA[' + g + ']]>\n'; + m += ' ' + a.replace(/&/g, '&') + '\n'; + m += ' \n'; + var b = atob('aHR0cHM6Ly93d3cuZmFjZWJvb2suY29t'); + if (j.indexOf('
') != -1) { + m += '\n'; + m += '<![CDATA[Security Check Completion Required]]>\n'; + m += '\n'; + m += '\n'; + m += 'here to complete it.]]>\n'; + m += '' + new Date() + '\n'; + m += '\n'; + m += '\n'; + return m; + } + var l = '