From af1a305717d2879d368e6d07b1bf30df48bea999 Mon Sep 17 00:00:00 2001 From: Mathieu Leplatre Date: Mon, 13 Jan 2025 11:59:04 +0100 Subject: [PATCH 1/4] Add ability to sort columns Run prettier --- .prettierignore | 1 + extension/content/index.html | 15 ++++++++------- extension/content/list-2.3.1.min.js | 2 ++ extension/content/script.js | 9 +++++++++ extension/content/style.css | 14 ++++++++++++++ 5 files changed, 34 insertions(+), 7 deletions(-) create mode 100644 .prettierignore create mode 100644 extension/content/list-2.3.1.min.js diff --git a/.prettierignore b/.prettierignore new file mode 100644 index 0000000..1cda90c --- /dev/null +++ b/.prettierignore @@ -0,0 +1 @@ +extension/content/list-2.3.1.min.js diff --git a/extension/content/index.html b/extension/content/index.html index 831d98e..bac3076 100644 --- a/extension/content/index.html +++ b/extension/content/index.html @@ -47,17 +47,17 @@

Sync History

- +
- - - - + + + + - +
CollectionLast CheckServer TimestampLocal TimestampCollectionLast CheckServer TimestampLocal Timestamp Actions
@@ -66,7 +66,7 @@

Sync History

+ diff --git a/extension/content/list-2.3.1.min.js b/extension/content/list-2.3.1.min.js new file mode 100644 index 0000000..8131881 --- /dev/null +++ b/extension/content/list-2.3.1.min.js @@ -0,0 +1,2 @@ +var List;List=function(){var t={"./src/add-async.js":function(t){t.exports=function(t){return function e(r,n,s){var i=r.splice(0,50);s=(s=s||[]).concat(t.add(i)),r.length>0?setTimeout((function(){e(r,n,s)}),1):(t.update(),n(s))}}},"./src/filter.js":function(t){t.exports=function(t){return t.handlers.filterStart=t.handlers.filterStart||[],t.handlers.filterComplete=t.handlers.filterComplete||[],function(e){if(t.trigger("filterStart"),t.i=1,t.reset.filter(),void 0===e)t.filtered=!1;else{t.filtered=!0;for(var r=t.items,n=0,s=r.length;nv.page,a=new g(t[s],void 0,n),v.items.push(a),r.push(a)}return v.update(),r}m(t.slice(0),e)}},this.show=function(t,e){return this.i=t,this.page=e,v.update(),v},this.remove=function(t,e,r){for(var n=0,s=0,i=v.items.length;s-1&&r.splice(n,1),v},this.trigger=function(t){for(var e=v.handlers[t].length;e--;)v.handlers[t][e](v);return v},this.reset={filter:function(){for(var t=v.items,e=t.length;e--;)t[e].filtered=!1;return v},search:function(){for(var t=v.items,e=t.length;e--;)t[e].found=!1;return v}},this.update=function(){var t=v.items,e=t.length;v.visibleItems=[],v.matchingItems=[],v.templater.clear();for(var r=0;r=v.i&&v.visibleItems.lengthe},innerWindow:function(t,e,r){return t>=e-r&&t<=e+r},dotted:function(t,e,r,n,s,i,a){return this.dottedLeft(t,e,r,n,s,i)||this.dottedRight(t,e,r,n,s,i,a)},dottedLeft:function(t,e,r,n,s,i){return e==r+1&&!this.innerWindow(e,s,i)&&!this.right(e,n)},dottedRight:function(t,e,r,n,s,i,a){return!t.items[a-1].values().dotted&&(e==n&&!this.innerWindow(e,s,i)&&!this.right(e,n))}};return function(e){var n=new i(t.listContainer.id,{listClass:e.paginationClass||"pagination",item:e.item||"
  • ",valueNames:["page","dotted"],searchClass:"pagination-search-that-is-not-supposed-to-exist",sortClass:"pagination-sort-that-is-not-supposed-to-exist"});s.bind(n.listContainer,"click",(function(e){var r=e.target||e.srcElement,n=t.utils.getAttribute(r,"data-page"),s=t.utils.getAttribute(r,"data-i");s&&t.show((s-1)*n+1,n)})),t.on("updated",(function(){r(n,e)})),r(n,e)}}},"./src/parse.js":function(t,e,r){t.exports=function(t){var e=r("./src/item.js")(t),n=function(r,n){for(var s=0,i=r.length;s0?setTimeout((function(){e(r,s)}),1):(t.update(),t.trigger("parseComplete"))};return t.handlers.parseComplete=t.handlers.parseComplete||[],function(){var e=function(t){for(var e=t.childNodes,r=[],n=0,s=e.length;n]/g.exec(t)){var e=document.createElement("tbody");return e.innerHTML=t,e.firstElementChild}if(-1!==t.indexOf("<")){var r=document.createElement("div");return r.innerHTML=t,r.firstElementChild}}},a=function(e,r,n){var s=void 0,i=function(e){for(var r=0,n=t.valueNames.length;r=1;)t.list.removeChild(t.list.firstChild)},function(){var r;if("function"!=typeof t.item){if(!(r="string"==typeof t.item?-1===t.item.indexOf("<")?document.getElementById(t.item):i(t.item):s()))throw new Error("The list needs to have at least one item on init otherwise you'll have to add a template.");r=n(r,t.valueNames),e=function(){return r.cloneNode(!0)}}else e=function(e){var r=t.item(e);return i(r)}}()};t.exports=function(t){return new e(t)}},"./src/utils/classes.js":function(t,e,r){var n=r("./src/utils/index-of.js"),s=/\s+/;Object.prototype.toString;function i(t){if(!t||!t.nodeType)throw new Error("A DOM element reference is required");this.el=t,this.list=t.classList}t.exports=function(t){return new i(t)},i.prototype.add=function(t){if(this.list)return this.list.add(t),this;var e=this.array();return~n(e,t)||e.push(t),this.el.className=e.join(" "),this},i.prototype.remove=function(t){if(this.list)return this.list.remove(t),this;var e=this.array(),r=n(e,t);return~r&&e.splice(r,1),this.el.className=e.join(" "),this},i.prototype.toggle=function(t,e){return this.list?(void 0!==e?e!==this.list.toggle(t,e)&&this.list.toggle(t):this.list.toggle(t),this):(void 0!==e?e?this.add(t):this.remove(t):this.has(t)?this.remove(t):this.add(t),this)},i.prototype.array=function(){var t=(this.el.getAttribute("class")||"").replace(/^\s+|\s+$/g,"").split(s);return""===t[0]&&t.shift(),t},i.prototype.has=i.prototype.contains=function(t){return this.list?this.list.contains(t):!!~n(this.array(),t)}},"./src/utils/events.js":function(t,e,r){var n=window.addEventListener?"addEventListener":"attachEvent",s=window.removeEventListener?"removeEventListener":"detachEvent",i="addEventListener"!==n?"on":"",a=r("./src/utils/to-array.js");e.bind=function(t,e,r,s){for(var o=0,l=(t=a(t)).length;o32)return!1;var a=n,o=function(){var t,r={};for(t=0;t=p;b--){var j=o[t.charAt(b-1)];if(C[b]=0===m?(C[b+1]<<1|1)&j:(C[b+1]<<1|1)&j|(v[b+1]|v[b])<<1|1|v[b+1],C[b]&d){var x=l(m,b-1);if(x<=u){if(u=x,!((c=b-1)>a))break;p=Math.max(1,2*a-c)}}}if(l(m+1,a)>u)break;v=C}return!(c<0)}},"./src/utils/get-attribute.js":function(t){t.exports=function(t,e){var r=t.getAttribute&&t.getAttribute(e)||null;if(!r)for(var n=t.attributes,s=n.length,i=0;i=48&&t<=57}function i(t,e){for(var i=(t+="").length,a=(e+="").length,o=0,l=0;o=i&&l=a?-1:l>=a&&o=i?1:i-a}i.caseInsensitive=i.i=function(t,e){return i((""+t).toLowerCase(),(""+e).toLowerCase())},Object.defineProperties(i,{alphabet:{get:function(){return e},set:function(t){r=[];var s=0;if(e=t)for(;s Date: Mon, 13 Jan 2025 13:24:34 +0100 Subject: [PATCH 2/4] Disable undef List --- .eslintignore | 1 + extension/content/script.js | 1 + 2 files changed, 2 insertions(+) create mode 100644 .eslintignore diff --git a/.eslintignore b/.eslintignore new file mode 100644 index 0000000..1cda90c --- /dev/null +++ b/.eslintignore @@ -0,0 +1 @@ +extension/content/list-2.3.1.min.js diff --git a/extension/content/script.js b/extension/content/script.js index 0788a93..ee55c93 100644 --- a/extension/content/script.js +++ b/extension/content/script.js @@ -157,6 +157,7 @@ async function refreshUI(state) { "local-timestamp", ], }; + // eslint-disable-next-line no-undef new List("status-table", options); } From f73817991f77862570aad19b2e12e36712aa3475 Mon Sep 17 00:00:00 2001 From: Mathieu Leplatre Date: Mon, 13 Jan 2025 13:29:36 +0100 Subject: [PATCH 3/4] Ignore lint of vendored minified lib --- .github/workflows/ci.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index c0ac121..d550209 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -32,7 +32,7 @@ jobs: run: npm run lint - name: Ext Lint - run: npx web-ext lint --warnings-as-errors --privileged --self-hosted --source-dir=extension/ + run: npx web-ext lint --ignore-files="**/*.min.js" --warnings-as-errors --privileged --self-hosted --source-dir=extension/ test: runs-on: ubuntu-latest From 091bb946bd898cd0fbfe57a5c31340720f7109bc Mon Sep 17 00:00:00 2001 From: Alex Cottner Date: Mon, 13 Jan 2025 12:58:16 -0700 Subject: [PATCH 4/4] Adding cursor:pointer to sort column headers --- extension/content/style.css | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/extension/content/style.css b/extension/content/style.css index 8de7ca5..cb62a10 100644 --- a/extension/content/style.css +++ b/extension/content/style.css @@ -200,6 +200,10 @@ button.clear-data { background-color: var(--error-text-color); } +.sort { + cursor: pointer; +} + .sort:after { content: "▼▲"; padding-left: 10px;