From 4e3c6b5af5426de248bcf78780f54dd51e2c6957 Mon Sep 17 00:00:00 2001 From: overint Date: Sun, 22 Oct 2017 12:01:10 +1100 Subject: [PATCH 01/29] #347 Add QR code library --- public/js/qrcode.min.js | 1 + 1 file changed, 1 insertion(+) create mode 100644 public/js/qrcode.min.js diff --git a/public/js/qrcode.min.js b/public/js/qrcode.min.js new file mode 100644 index 0000000..993e88f --- /dev/null +++ b/public/js/qrcode.min.js @@ -0,0 +1 @@ +var QRCode;!function(){function a(a){this.mode=c.MODE_8BIT_BYTE,this.data=a,this.parsedData=[];for(var b=[],d=0,e=this.data.length;e>d;d++){var f=this.data.charCodeAt(d);f>65536?(b[0]=240|(1835008&f)>>>18,b[1]=128|(258048&f)>>>12,b[2]=128|(4032&f)>>>6,b[3]=128|63&f):f>2048?(b[0]=224|(61440&f)>>>12,b[1]=128|(4032&f)>>>6,b[2]=128|63&f):f>128?(b[0]=192|(1984&f)>>>6,b[1]=128|63&f):b[0]=f,this.parsedData=this.parsedData.concat(b)}this.parsedData.length!=this.data.length&&(this.parsedData.unshift(191),this.parsedData.unshift(187),this.parsedData.unshift(239))}function b(a,b){this.typeNumber=a,this.errorCorrectLevel=b,this.modules=null,this.moduleCount=0,this.dataCache=null,this.dataList=[]}function i(a,b){if(void 0==a.length)throw new Error(a.length+"/"+b);for(var c=0;c=f;f++){var h=0;switch(b){case d.L:h=l[f][0];break;case d.M:h=l[f][1];break;case d.Q:h=l[f][2];break;case d.H:h=l[f][3]}if(h>=e)break;c++}if(c>l.length)throw new Error("Too long data");return c}function s(a){var b=encodeURI(a).toString().replace(/\%[0-9a-fA-F]{2}/g,"a");return b.length+(b.length!=a?3:0)}a.prototype={getLength:function(){return this.parsedData.length},write:function(a){for(var b=0,c=this.parsedData.length;c>b;b++)a.put(this.parsedData[b],8)}},b.prototype={addData:function(b){var c=new a(b);this.dataList.push(c),this.dataCache=null},isDark:function(a,b){if(0>a||this.moduleCount<=a||0>b||this.moduleCount<=b)throw new Error(a+","+b);return this.modules[a][b]},getModuleCount:function(){return this.moduleCount},make:function(){this.makeImpl(!1,this.getBestMaskPattern())},makeImpl:function(a,c){this.moduleCount=4*this.typeNumber+17,this.modules=new Array(this.moduleCount);for(var d=0;d=7&&this.setupTypeNumber(a),null==this.dataCache&&(this.dataCache=b.createData(this.typeNumber,this.errorCorrectLevel,this.dataList)),this.mapData(this.dataCache,c)},setupPositionProbePattern:function(a,b){for(var c=-1;7>=c;c++)if(!(-1>=a+c||this.moduleCount<=a+c))for(var d=-1;7>=d;d++)-1>=b+d||this.moduleCount<=b+d||(this.modules[a+c][b+d]=c>=0&&6>=c&&(0==d||6==d)||d>=0&&6>=d&&(0==c||6==c)||c>=2&&4>=c&&d>=2&&4>=d?!0:!1)},getBestMaskPattern:function(){for(var a=0,b=0,c=0;8>c;c++){this.makeImpl(!0,c);var d=f.getLostPoint(this);(0==c||a>d)&&(a=d,b=c)}return b},createMovieClip:function(a,b,c){var d=a.createEmptyMovieClip(b,c),e=1;this.make();for(var f=0;f=g;g++)for(var h=-2;2>=h;h++)this.modules[d+g][e+h]=-2==g||2==g||-2==h||2==h||0==g&&0==h?!0:!1}},setupTypeNumber:function(a){for(var b=f.getBCHTypeNumber(this.typeNumber),c=0;18>c;c++){var d=!a&&1==(1&b>>c);this.modules[Math.floor(c/3)][c%3+this.moduleCount-8-3]=d}for(var c=0;18>c;c++){var d=!a&&1==(1&b>>c);this.modules[c%3+this.moduleCount-8-3][Math.floor(c/3)]=d}},setupTypeInfo:function(a,b){for(var c=this.errorCorrectLevel<<3|b,d=f.getBCHTypeInfo(c),e=0;15>e;e++){var g=!a&&1==(1&d>>e);6>e?this.modules[e][8]=g:8>e?this.modules[e+1][8]=g:this.modules[this.moduleCount-15+e][8]=g}for(var e=0;15>e;e++){var g=!a&&1==(1&d>>e);8>e?this.modules[8][this.moduleCount-e-1]=g:9>e?this.modules[8][15-e-1+1]=g:this.modules[8][15-e-1]=g}this.modules[this.moduleCount-8][8]=!a},mapData:function(a,b){for(var c=-1,d=this.moduleCount-1,e=7,g=0,h=this.moduleCount-1;h>0;h-=2)for(6==h&&h--;;){for(var i=0;2>i;i++)if(null==this.modules[d][h-i]){var j=!1;g>>e));var k=f.getMask(b,d,h-i);k&&(j=!j),this.modules[d][h-i]=j,e--,-1==e&&(g++,e=7)}if(d+=c,0>d||this.moduleCount<=d){d-=c,c=-c;break}}}},b.PAD0=236,b.PAD1=17,b.createData=function(a,c,d){for(var e=j.getRSBlocks(a,c),g=new k,h=0;h8*l)throw new Error("code length overflow. ("+g.getLengthInBits()+">"+8*l+")");for(g.getLengthInBits()+4<=8*l&&g.put(0,4);0!=g.getLengthInBits()%8;)g.putBit(!1);for(;;){if(g.getLengthInBits()>=8*l)break;if(g.put(b.PAD0,8),g.getLengthInBits()>=8*l)break;g.put(b.PAD1,8)}return b.createBytes(g,e)},b.createBytes=function(a,b){for(var c=0,d=0,e=0,g=new Array(b.length),h=new Array(b.length),j=0;j=0?p.get(q):0}}for(var r=0,m=0;mm;m++)for(var j=0;jm;m++)for(var j=0;j=0;)b^=f.G15<=0;)b^=f.G18<>>=1;return b},getPatternPosition:function(a){return f.PATTERN_POSITION_TABLE[a-1]},getMask:function(a,b,c){switch(a){case e.PATTERN000:return 0==(b+c)%2;case e.PATTERN001:return 0==b%2;case e.PATTERN010:return 0==c%3;case e.PATTERN011:return 0==(b+c)%3;case e.PATTERN100:return 0==(Math.floor(b/2)+Math.floor(c/3))%2;case e.PATTERN101:return 0==b*c%2+b*c%3;case e.PATTERN110:return 0==(b*c%2+b*c%3)%2;case e.PATTERN111:return 0==(b*c%3+(b+c)%2)%2;default:throw new Error("bad maskPattern:"+a)}},getErrorCorrectPolynomial:function(a){for(var b=new i([1],0),c=0;a>c;c++)b=b.multiply(new i([1,g.gexp(c)],0));return b},getLengthInBits:function(a,b){if(b>=1&&10>b)switch(a){case c.MODE_NUMBER:return 10;case c.MODE_ALPHA_NUM:return 9;case c.MODE_8BIT_BYTE:return 8;case c.MODE_KANJI:return 8;default:throw new Error("mode:"+a)}else if(27>b)switch(a){case c.MODE_NUMBER:return 12;case c.MODE_ALPHA_NUM:return 11;case c.MODE_8BIT_BYTE:return 16;case c.MODE_KANJI:return 10;default:throw new Error("mode:"+a)}else{if(!(41>b))throw new Error("type:"+b);switch(a){case c.MODE_NUMBER:return 14;case c.MODE_ALPHA_NUM:return 13;case c.MODE_8BIT_BYTE:return 16;case c.MODE_KANJI:return 12;default:throw new Error("mode:"+a)}}},getLostPoint:function(a){for(var b=a.getModuleCount(),c=0,d=0;b>d;d++)for(var e=0;b>e;e++){for(var f=0,g=a.isDark(d,e),h=-1;1>=h;h++)if(!(0>d+h||d+h>=b))for(var i=-1;1>=i;i++)0>e+i||e+i>=b||(0!=h||0!=i)&&g==a.isDark(d+h,e+i)&&f++;f>5&&(c+=3+f-5)}for(var d=0;b-1>d;d++)for(var e=0;b-1>e;e++){var j=0;a.isDark(d,e)&&j++,a.isDark(d+1,e)&&j++,a.isDark(d,e+1)&&j++,a.isDark(d+1,e+1)&&j++,(0==j||4==j)&&(c+=3)}for(var d=0;b>d;d++)for(var e=0;b-6>e;e++)a.isDark(d,e)&&!a.isDark(d,e+1)&&a.isDark(d,e+2)&&a.isDark(d,e+3)&&a.isDark(d,e+4)&&!a.isDark(d,e+5)&&a.isDark(d,e+6)&&(c+=40);for(var e=0;b>e;e++)for(var d=0;b-6>d;d++)a.isDark(d,e)&&!a.isDark(d+1,e)&&a.isDark(d+2,e)&&a.isDark(d+3,e)&&a.isDark(d+4,e)&&!a.isDark(d+5,e)&&a.isDark(d+6,e)&&(c+=40);for(var k=0,e=0;b>e;e++)for(var d=0;b>d;d++)a.isDark(d,e)&&k++;var l=Math.abs(100*k/b/b-50)/5;return c+=10*l}},g={glog:function(a){if(1>a)throw new Error("glog("+a+")");return g.LOG_TABLE[a]},gexp:function(a){for(;0>a;)a+=255;for(;a>=256;)a-=255;return g.EXP_TABLE[a]},EXP_TABLE:new Array(256),LOG_TABLE:new Array(256)},h=0;8>h;h++)g.EXP_TABLE[h]=1<h;h++)g.EXP_TABLE[h]=g.EXP_TABLE[h-4]^g.EXP_TABLE[h-5]^g.EXP_TABLE[h-6]^g.EXP_TABLE[h-8];for(var h=0;255>h;h++)g.LOG_TABLE[g.EXP_TABLE[h]]=h;i.prototype={get:function(a){return this.num[a]},getLength:function(){return this.num.length},multiply:function(a){for(var b=new Array(this.getLength()+a.getLength()-1),c=0;cf;f++)for(var g=c[3*f+0],h=c[3*f+1],i=c[3*f+2],k=0;g>k;k++)e.push(new j(h,i));return e},j.getRsBlockTable=function(a,b){switch(b){case d.L:return j.RS_BLOCK_TABLE[4*(a-1)+0];case d.M:return j.RS_BLOCK_TABLE[4*(a-1)+1];case d.Q:return j.RS_BLOCK_TABLE[4*(a-1)+2];case d.H:return j.RS_BLOCK_TABLE[4*(a-1)+3];default:return void 0}},k.prototype={get:function(a){var b=Math.floor(a/8);return 1==(1&this.buffer[b]>>>7-a%8)},put:function(a,b){for(var c=0;b>c;c++)this.putBit(1==(1&a>>>b-c-1))},getLengthInBits:function(){return this.length},putBit:function(a){var b=Math.floor(this.length/8);this.buffer.length<=b&&this.buffer.push(0),a&&(this.buffer[b]|=128>>>this.length%8),this.length++}};var l=[[17,14,11,7],[32,26,20,14],[53,42,32,24],[78,62,46,34],[106,84,60,44],[134,106,74,58],[154,122,86,64],[192,152,108,84],[230,180,130,98],[271,213,151,119],[321,251,177,137],[367,287,203,155],[425,331,241,177],[458,362,258,194],[520,412,292,220],[586,450,322,250],[644,504,364,280],[718,560,394,310],[792,624,442,338],[858,666,482,382],[929,711,509,403],[1003,779,565,439],[1091,857,611,461],[1171,911,661,511],[1273,997,715,535],[1367,1059,751,593],[1465,1125,805,625],[1528,1190,868,658],[1628,1264,908,698],[1732,1370,982,742],[1840,1452,1030,790],[1952,1538,1112,842],[2068,1628,1168,898],[2188,1722,1228,958],[2303,1809,1283,983],[2431,1911,1351,1051],[2563,1989,1423,1093],[2699,2099,1499,1139],[2809,2213,1579,1219],[2953,2331,1663,1273]],o=function(){var a=function(a,b){this._el=a,this._htOption=b};return a.prototype.draw=function(a){function g(a,b){var c=document.createElementNS("http://www.w3.org/2000/svg",a);for(var d in b)b.hasOwnProperty(d)&&c.setAttribute(d,b[d]);return c}var b=this._htOption,c=this._el,d=a.getModuleCount();Math.floor(b.width/d),Math.floor(b.height/d),this.clear();var h=g("svg",{viewBox:"0 0 "+String(d)+" "+String(d),width:"100%",height:"100%",fill:b.colorLight});h.setAttributeNS("http://www.w3.org/2000/xmlns/","xmlns:xlink","http://www.w3.org/1999/xlink"),c.appendChild(h),h.appendChild(g("rect",{fill:b.colorDark,width:"1",height:"1",id:"template"}));for(var i=0;d>i;i++)for(var j=0;d>j;j++)if(a.isDark(i,j)){var k=g("use",{x:String(i),y:String(j)});k.setAttributeNS("http://www.w3.org/1999/xlink","href","#template"),h.appendChild(k)}},a.prototype.clear=function(){for(;this._el.hasChildNodes();)this._el.removeChild(this._el.lastChild)},a}(),p="svg"===document.documentElement.tagName.toLowerCase(),q=p?o:m()?function(){function a(){this._elImage.src=this._elCanvas.toDataURL("image/png"),this._elImage.style.display="block",this._elCanvas.style.display="none"}function d(a,b){var c=this;if(c._fFail=b,c._fSuccess=a,null===c._bSupportDataURI){var d=document.createElement("img"),e=function(){c._bSupportDataURI=!1,c._fFail&&_fFail.call(c)},f=function(){c._bSupportDataURI=!0,c._fSuccess&&c._fSuccess.call(c)};return d.onabort=e,d.onerror=e,d.onload=f,d.src="data:image/gif;base64,iVBORw0KGgoAAAANSUhEUgAAAAUAAAAFCAYAAACNbyblAAAAHElEQVQI12P4//8/w38GIAXDIBKE0DHxgljNBAAO9TXL0Y4OHwAAAABJRU5ErkJggg==",void 0}c._bSupportDataURI===!0&&c._fSuccess?c._fSuccess.call(c):c._bSupportDataURI===!1&&c._fFail&&c._fFail.call(c)}if(this._android&&this._android<=2.1){var b=1/window.devicePixelRatio,c=CanvasRenderingContext2D.prototype.drawImage;CanvasRenderingContext2D.prototype.drawImage=function(a,d,e,f,g,h,i,j){if("nodeName"in a&&/img/i.test(a.nodeName))for(var l=arguments.length-1;l>=1;l--)arguments[l]=arguments[l]*b;else"undefined"==typeof j&&(arguments[1]*=b,arguments[2]*=b,arguments[3]*=b,arguments[4]*=b);c.apply(this,arguments)}}var e=function(a,b){this._bIsPainted=!1,this._android=n(),this._htOption=b,this._elCanvas=document.createElement("canvas"),this._elCanvas.width=b.width,this._elCanvas.height=b.height,a.appendChild(this._elCanvas),this._el=a,this._oContext=this._elCanvas.getContext("2d"),this._bIsPainted=!1,this._elImage=document.createElement("img"),this._elImage.style.display="none",this._el.appendChild(this._elImage),this._bSupportDataURI=null};return e.prototype.draw=function(a){var b=this._elImage,c=this._oContext,d=this._htOption,e=a.getModuleCount(),f=d.width/e,g=d.height/e,h=Math.round(f),i=Math.round(g);b.style.display="none",this.clear();for(var j=0;e>j;j++)for(var k=0;e>k;k++){var l=a.isDark(j,k),m=k*f,n=j*g;c.strokeStyle=l?d.colorDark:d.colorLight,c.lineWidth=1,c.fillStyle=l?d.colorDark:d.colorLight,c.fillRect(m,n,f,g),c.strokeRect(Math.floor(m)+.5,Math.floor(n)+.5,h,i),c.strokeRect(Math.ceil(m)-.5,Math.ceil(n)-.5,h,i)}this._bIsPainted=!0},e.prototype.makeImage=function(){this._bIsPainted&&d.call(this,a)},e.prototype.isPainted=function(){return this._bIsPainted},e.prototype.clear=function(){this._oContext.clearRect(0,0,this._elCanvas.width,this._elCanvas.height),this._bIsPainted=!1},e.prototype.round=function(a){return a?Math.floor(1e3*a)/1e3:a},e}():function(){var a=function(a,b){this._el=a,this._htOption=b};return a.prototype.draw=function(a){for(var b=this._htOption,c=this._el,d=a.getModuleCount(),e=Math.floor(b.width/d),f=Math.floor(b.height/d),g=[''],h=0;d>h;h++){g.push("");for(var i=0;d>i;i++)g.push('');g.push("")}g.push("
"),c.innerHTML=g.join("");var j=c.childNodes[0],k=(b.width-j.offsetWidth)/2,l=(b.height-j.offsetHeight)/2;k>0&&l>0&&(j.style.margin=l+"px "+k+"px")},a.prototype.clear=function(){this._el.innerHTML=""},a}();QRCode=function(a,b){if(this._htOption={width:256,height:256,typeNumber:4,colorDark:"#000000",colorLight:"#ffffff",correctLevel:d.H},"string"==typeof b&&(b={text:b}),b)for(var c in b)this._htOption[c]=b[c];"string"==typeof a&&(a=document.getElementById(a)),this._android=n(),this._el=a,this._oQRCode=null,this._oDrawing=new q(this._el,this._htOption),this._htOption.text&&this.makeCode(this._htOption.text)},QRCode.prototype.makeCode=function(a){this._oQRCode=new b(r(a,this._htOption.correctLevel),this._htOption.correctLevel),this._oQRCode.addData(a),this._oQRCode.make(),this._el.title=a,this._oDrawing.draw(this._oQRCode),this.makeImage()},QRCode.prototype.makeImage=function(){"function"==typeof this._oDrawing.makeImage&&(!this._android||this._android>=3)&&this._oDrawing.makeImage()},QRCode.prototype.clear=function(){this._oDrawing.clear()},QRCode.CorrectLevel=d}(); \ No newline at end of file From 162f468b1c54b1675b5a9e0ddedf8e9c7f1addb4 Mon Sep 17 00:00:00 2001 From: overint Date: Sun, 22 Oct 2017 12:01:49 +1100 Subject: [PATCH 02/29] #347 Add button to generate QR code --- public/css/shorten_result.css | 11 +++++++++++ public/js/shorten_result.js | 12 ++++++++++++ resources/views/shorten_result.blade.php | 6 ++++++ 3 files changed, 29 insertions(+) diff --git a/public/css/shorten_result.css b/public/css/shorten_result.css index a8e89b8..39db788 100644 --- a/public/css/shorten_result.css +++ b/public/css/shorten_result.css @@ -12,3 +12,14 @@ .content-div { text-align: center; } + +.qrCodeContainer { + display: none; + width: 300px; + height: 300px; + padding: 10px; + margin: 20px auto 0 auto; + background-color: white; + border: 1px #b7b7b7 solid; + border-radius: 7px; +} diff --git a/public/js/shorten_result.js b/public/js/shorten_result.js index 5c6f4a3..02cda0d 100644 --- a/public/js/shorten_result.js +++ b/public/js/shorten_result.js @@ -9,6 +9,18 @@ $('.result-box').change(function () { $(this).val(original_link); }); + +$('#generateQRCode').click(function () { + var container = $('.qrCodeContainer'); + container.empty(); + new QRCode(container.get(0), { + text: $('.result-box').val(), + width: 280, + height: 280 + }); + container.show(); +}); + $(function () { original_link = $('.result-box').val(); select_text(); diff --git a/resources/views/shorten_result.blade.php b/resources/views/shorten_result.blade.php index fcbbb8f..1f65d32 100644 --- a/resources/views/shorten_result.blade.php +++ b/resources/views/shorten_result.blade.php @@ -7,9 +7,15 @@ @section('content')

Shortened URL

+ Shorten another + +
+ @endsection + @section('js') + @endsection From 5a6f4ca3a54c987262df2d0df0f37fb0a1380d5b Mon Sep 17 00:00:00 2001 From: overint Date: Sun, 22 Oct 2017 12:05:13 +1100 Subject: [PATCH 03/29] #347 Add alt tag to qr code image --- public/js/shorten_result.js | 1 + 1 file changed, 1 insertion(+) diff --git a/public/js/shorten_result.js b/public/js/shorten_result.js index 02cda0d..d9914b0 100644 --- a/public/js/shorten_result.js +++ b/public/js/shorten_result.js @@ -18,6 +18,7 @@ $('#generateQRCode').click(function () { width: 280, height: 280 }); + container.find('img').attr('alt', original_link); container.show(); }); From a44a3fb22519b6ef27ea7d3018d42609cfb384c4 Mon Sep 17 00:00:00 2001 From: overint Date: Sun, 22 Oct 2017 12:06:20 +1100 Subject: [PATCH 04/29] #347 Generate QR code from var instead of getting from the DOM. --- public/js/shorten_result.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/public/js/shorten_result.js b/public/js/shorten_result.js index d9914b0..402919e 100644 --- a/public/js/shorten_result.js +++ b/public/js/shorten_result.js @@ -14,7 +14,7 @@ $('#generateQRCode').click(function () { var container = $('.qrCodeContainer'); container.empty(); new QRCode(container.get(0), { - text: $('.result-box').val(), + text: original_link, width: 280, height: 280 }); From 8b979066a60c112eed6f879c0b0afee07bf0ca81 Mon Sep 17 00:00:00 2001 From: overint Date: Sun, 22 Oct 2017 13:01:15 +1100 Subject: [PATCH 05/29] #347 Update selector names --- public/css/shorten_result.css | 2 +- public/js/shorten_result.js | 4 ++-- resources/views/shorten_result.blade.php | 4 ++-- 3 files changed, 5 insertions(+), 5 deletions(-) diff --git a/public/css/shorten_result.css b/public/css/shorten_result.css index 39db788..71f8255 100644 --- a/public/css/shorten_result.css +++ b/public/css/shorten_result.css @@ -13,7 +13,7 @@ text-align: center; } -.qrCodeContainer { +.qr-code-container { display: none; width: 300px; height: 300px; diff --git a/public/js/shorten_result.js b/public/js/shorten_result.js index 402919e..e497843 100644 --- a/public/js/shorten_result.js +++ b/public/js/shorten_result.js @@ -10,8 +10,8 @@ $('.result-box').change(function () { }); -$('#generateQRCode').click(function () { - var container = $('.qrCodeContainer'); +$('#generate-qr-code').click(function () { + var container = $('.qr-code-container'); container.empty(); new QRCode(container.get(0), { text: original_link, diff --git a/resources/views/shorten_result.blade.php b/resources/views/shorten_result.blade.php index 1f65d32..4098acd 100644 --- a/resources/views/shorten_result.blade.php +++ b/resources/views/shorten_result.blade.php @@ -7,10 +7,10 @@ @section('content')

Shortened URL

- +Generate QR Code Shorten another -
+
@endsection From 3a8ce1d0eca281a8f765612ded993e860792e220 Mon Sep 17 00:00:00 2001 From: Chaoyi Zha Date: Thu, 26 Oct 2017 16:28:13 -0400 Subject: [PATCH 06/29] Remove CSS clutter, fix centering --- public/css/shorten_result.css | 12 +++++------- 1 file changed, 5 insertions(+), 7 deletions(-) diff --git a/public/css/shorten_result.css b/public/css/shorten_result.css index 71f8255..46adf07 100644 --- a/public/css/shorten_result.css +++ b/public/css/shorten_result.css @@ -15,11 +15,9 @@ .qr-code-container { display: none; - width: 300px; - height: 300px; - padding: 10px; - margin: 20px auto 0 auto; - background-color: white; - border: 1px #b7b7b7 solid; - border-radius: 7px; + margin-top: 2em; +} + +.qr-code-container img { + display: inline !important; } From 90e24195ee37409b95556f69a3c1ff1b57685b24 Mon Sep 17 00:00:00 2001 From: Chaoyi Zha Date: Thu, 26 Oct 2017 16:30:41 -0400 Subject: [PATCH 07/29] Change button class to be more general --- public/css/shorten_result.css | 2 +- resources/views/shorten_result.blade.php | 4 ++-- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/public/css/shorten_result.css b/public/css/shorten_result.css index 46adf07..c672654 100644 --- a/public/css/shorten_result.css +++ b/public/css/shorten_result.css @@ -5,7 +5,7 @@ } -.back-btn { +.btn { margin-top: 30px; } diff --git a/resources/views/shorten_result.blade.php b/resources/views/shorten_result.blade.php index 4098acd..ae16c32 100644 --- a/resources/views/shorten_result.blade.php +++ b/resources/views/shorten_result.blade.php @@ -7,8 +7,8 @@ @section('content')

Shortened URL

-Generate QR Code -Shorten another +Generate QR Code +Shorten another
From f047e315135d9ede27c41574867d34b93e0359af Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Anh=20Tu=E1=BA=A5n?= Date: Sat, 28 Oct 2017 14:01:58 +0700 Subject: [PATCH 08/29] Merge disable/delete column to Control --- app/Http/Controllers/AdminPaginationController.php | 10 ++++++++-- public/js/AdminCtrl.js | 13 +++++-------- resources/views/snippets/link_table.blade.php | 3 +-- 3 files changed, 14 insertions(+), 12 deletions(-) diff --git a/app/Http/Controllers/AdminPaginationController.php b/app/Http/Controllers/AdminPaginationController.php index 01297ab..2cb51b4 100644 --- a/app/Http/Controllers/AdminPaginationController.php +++ b/app/Http/Controllers/AdminPaginationController.php @@ -1,4 +1,5 @@ '; } + public function renderControlLinkCell($link){ + return '
+ ' . $this->renderToggleLinkActiveCell($link) . $this->renderDeleteLinkCell($link) . ' +
'; + } + /* DataTables bindings */ public function paginateAdminUsers(Request $request) { @@ -143,8 +150,7 @@ class AdminPaginationController extends Controller { $admin_links = Link::select(['short_url', 'long_url', 'clicks', 'created_at', 'creator', 'is_disabled']); return Datatables::of($admin_links) - ->addColumn('disable', [$this, 'renderToggleLinkActiveCell']) - ->addColumn('delete', [$this, 'renderDeleteLinkCell']) + ->addColumn('control', [$this, 'renderControlLinkCell']) ->editColumn('clicks', [$this, 'renderClicksCell']) ->editColumn('long_url', [$this, 'renderLongUrlCell']) ->escapeColumns(['short_url', 'creator']) diff --git a/public/js/AdminCtrl.js b/public/js/AdminCtrl.js index 586fb96..2fbbd2c 100644 --- a/public/js/AdminCtrl.js +++ b/public/js/AdminCtrl.js @@ -152,15 +152,12 @@ polr.controller('AdminCtrl', function($scope, $compile, $timeout) { "ajax": BASE_API_PATH + 'admin/get_admin_links', "columns": [ - {className: 'wrap-text', data: 'short_url', name: 'short_url'}, + {className: 'wrap-text', data: 'short_url', name: 'short_url', width: '10%'}, {className: 'wrap-text', data: 'long_url', name: 'long_url'}, - {data: 'clicks', name: 'clicks'}, - {data: 'created_at', name: 'created_at'}, - {data: 'creator', name: 'creator'}, - - {data: 'disable', name: 'disable', orderable: false, searchable: false}, - {data: 'delete', name: 'delete', orderable: false, searchable: false} - + {data: 'clicks', name: 'clicks', width: '10%'}, + {data: 'created_at', name: 'created_at', width: '18%'}, + {data: 'creator', name: 'creator', width: '20%'}, + {data: 'control', name: 'control', orderable: false, searchable: false, width: '15%'}, ] }, datatables_config)); } diff --git a/resources/views/snippets/link_table.blade.php b/resources/views/snippets/link_table.blade.php index 554d9a2..a8a2e5a 100644 --- a/resources/views/snippets/link_table.blade.php +++ b/resources/views/snippets/link_table.blade.php @@ -8,8 +8,7 @@ @if ($table_id == "admin_links_table") {{-- Show action buttons only if admin view --}} Creator - Disable - Delete + Control @endif From 357d134818e7e82fd70ea13bd21e0c8929170654 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Anh=20Tu=E1=BA=A5n?= Date: Sat, 28 Oct 2017 15:43:37 +0700 Subject: [PATCH 09/29] Remove enter on top --- app/Http/Controllers/AdminPaginationController.php | 1 - 1 file changed, 1 deletion(-) diff --git a/app/Http/Controllers/AdminPaginationController.php b/app/Http/Controllers/AdminPaginationController.php index 2cb51b4..79a5818 100644 --- a/app/Http/Controllers/AdminPaginationController.php +++ b/app/Http/Controllers/AdminPaginationController.php @@ -1,5 +1,4 @@ Date: Mon, 4 Dec 2017 00:03:36 +0100 Subject: [PATCH 10/29] Add `mypolr` to "unofficial libraries" I've added my project `mypolr` to the list of unofficial libraries, but not sure if the formatting, wording, or description is on par with what you're looking for. I also discovered this Ruby project while searching for "Polr" on GitHub, but I haven't checked it out: https://github.com/SeniorMedia/polr-ruby It does, however, seem to be stable. --- docs/developer-guide/libraries.md | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/docs/developer-guide/libraries.md b/docs/developer-guide/libraries.md index b2ef6a7..f9bcc26 100644 --- a/docs/developer-guide/libraries.md +++ b/docs/developer-guide/libraries.md @@ -9,5 +9,10 @@ that you take a look at the [API documentation](api/) to integrate Polr into you - there are no official libraries for Polr 2.0 yet. ### Unofficial libraries -- there are no unofficial libraries for Polr 2.0 yet. +- [mypolr][mypolr_gh] is a Python 3 package for interacting with the Polr 2.0 API. ([User Guide and documentation][mypolr_docs]) + +- there seems to be only one unofficial libraries for Polr 2.0 yet. - perhaps you'd like to write one? Send a PR to add your library to this page. + +[mypolr_gh]: https://github.com/fauskanger/mypolr +[mypolr_docs]: https://mypolr.readthedocs.io From cc73a5e08daf4f21d4f3bf1e33105a542eea5b46 Mon Sep 17 00:00:00 2001 From: sanderr Date: Tue, 12 Dec 2017 20:41:08 +0000 Subject: [PATCH 11/29] Makes the int-value for api-rate limit field visible Closes #400 --- public/css/admin.css | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/public/css/admin.css b/public/css/admin.css index 2c9b51f..4342132 100644 --- a/public/css/admin.css +++ b/public/css/admin.css @@ -37,7 +37,7 @@ input.api-quota { display: inline; width: 9em; font-size: .85em; - height: .85em; + height: auto; padding-left: 0.8em; } From bbf3c2ec91cf074073858f1e7300ae0409dfe021 Mon Sep 17 00:00:00 2001 From: Chaoyi Zha Date: Thu, 14 Dec 2017 15:27:45 -0500 Subject: [PATCH 12/29] Layout changes --- docs/developer-guide/libraries.md | 14 +++----------- 1 file changed, 3 insertions(+), 11 deletions(-) diff --git a/docs/developer-guide/libraries.md b/docs/developer-guide/libraries.md index f9bcc26..8dfcb68 100644 --- a/docs/developer-guide/libraries.md +++ b/docs/developer-guide/libraries.md @@ -5,14 +5,6 @@ To interact with Polr's API, you may opt to use a library or write your own inte As not all languages and frameworks are currently supported by a library, it is encouraged that you take a look at the [API documentation](api/) to integrate Polr into your application. -### Official Libraries -- there are no official libraries for Polr 2.0 yet. - -### Unofficial libraries -- [mypolr][mypolr_gh] is a Python 3 package for interacting with the Polr 2.0 API. ([User Guide and documentation][mypolr_docs]) - -- there seems to be only one unofficial libraries for Polr 2.0 yet. -- perhaps you'd like to write one? Send a PR to add your library to this page. - -[mypolr_gh]: https://github.com/fauskanger/mypolr -[mypolr_docs]: https://mypolr.readthedocs.io +## Unofficial libraries +### Python +- [mypolr](https://github.com/fauskanger/mypolr) is a Python 3 package for interacting with the Polr 2.0 API. ([Documentation](https://mypolr.readthedocs.io)) From 25094345d1ddf405837f25c7a3c114d228802898 Mon Sep 17 00:00:00 2001 From: Iuri de Silvio Date: Wed, 20 Dec 2017 20:14:51 -0200 Subject: [PATCH 13/29] Avoid link counting for unlimited quota --- app/Helpers/ApiHelper.php | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/app/Helpers/ApiHelper.php b/app/Helpers/ApiHelper.php index 5f629f8..cc5e91b 100644 --- a/app/Helpers/ApiHelper.php +++ b/app/Helpers/ApiHelper.php @@ -23,11 +23,15 @@ class ApiHelper { $api_quota = env('SETTING_ANON_API_QUOTA') ?: 5; } + if ($api_quota == -1) { + return false; + } + $links_last_minute = Link::where('is_api', 1) ->where('creator', $username) ->where('created_at', '>=', $last_minute) ->count(); - return ($api_quota > -1 && $links_last_minute >= $api_quota); + return $links_last_minute >= $api_quota; } } From 5b48ab31ca9ecddb491e18213acd27e226eec1e2 Mon Sep 17 00:00:00 2001 From: Iuri de Silvio Date: Wed, 20 Dec 2017 22:31:00 -0200 Subject: [PATCH 14/29] $api_quota < 0 instead of -1 --- app/Helpers/ApiHelper.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/app/Helpers/ApiHelper.php b/app/Helpers/ApiHelper.php index cc5e91b..6c751fe 100644 --- a/app/Helpers/ApiHelper.php +++ b/app/Helpers/ApiHelper.php @@ -23,7 +23,7 @@ class ApiHelper { $api_quota = env('SETTING_ANON_API_QUOTA') ?: 5; } - if ($api_quota == -1) { + if ($api_quota < 0) { return false; } From 9e4ad61e2b962dbbe310cc8378146f27e2ab8064 Mon Sep 17 00:00:00 2001 From: Iuri de Silvio Date: Thu, 21 Dec 2017 08:44:24 -0200 Subject: [PATCH 15/29] create api quota index --- ...17_12_21_095425_create_api_quota_index.php | 36 +++++++++++++++++++ 1 file changed, 36 insertions(+) create mode 100644 database/migrations/2017_12_21_095425_create_api_quota_index.php diff --git a/database/migrations/2017_12_21_095425_create_api_quota_index.php b/database/migrations/2017_12_21_095425_create_api_quota_index.php new file mode 100644 index 0000000..471ec41 --- /dev/null +++ b/database/migrations/2017_12_21_095425_create_api_quota_index.php @@ -0,0 +1,36 @@ +index( + ['created_at', 'creator', 'is_api'], + 'api_quota_index' + ); + }); + } + + /** + * Reverse the migrations. + * + * @return void + */ + public function down() + { + Schema::table('links', function (Blueprint $table) + { + $table->dropIndex('api_quota_index'); + }); + } +} From c16c477d0b1d0434e8b57c987fad7610bf45a1ec Mon Sep 17 00:00:00 2001 From: Chaoyi Zha Date: Wed, 10 Jan 2018 17:49:36 -0500 Subject: [PATCH 16/29] Add new logo --- README.md | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/README.md b/README.md index 97a950f..3662aa2 100644 --- a/README.md +++ b/README.md @@ -1,4 +1,5 @@ -# [![Logo](http://i.imgur.com/aOtrJNz.png)](https://polrproject.org) +Polr Logo + :aerial_tramway: A modern, minimalist, and lightweight URL shortener. From 992852138ef65e79309fe0e560c65cd634bd3e4e Mon Sep 17 00:00:00 2001 From: Chaoyi Zha Date: Wed, 10 Jan 2018 18:13:04 -0500 Subject: [PATCH 17/29] Updates to README --- README.md | 14 ++++++++++---- 1 file changed, 10 insertions(+), 4 deletions(-) diff --git a/README.md b/README.md index 3662aa2..14b5ec6 100644 --- a/README.md +++ b/README.md @@ -5,7 +5,7 @@ [![GitHub license](https://img.shields.io/badge/license-GPLv2%2B-blue.svg)]() [![GitHub release](https://img.shields.io/github/release/cydrobolt/polr.svg)](https://github.com/cydrobolt/polr/releases) -[![Builds status](https://travis-ci.org/cydrobolt/polr.svg)](https://travis-ci.org/cydrobolt/polr) +[![Builds status](https://travis-ci.org/cydrobolt/polr.svg)](https://travis-ci.org/cydrobolt/polr) [![Docs](https://img.shields.io/badge/docs-latest-brightgreen.svg?style=flat)](http://polr.readthedocs.org/en/latest/) @@ -17,7 +17,7 @@ Polr is an intrepid, self-hostable open-source link shortening web application w Polr is written in PHP and Lumen, using MySQL as its primary database. - - To get started with Polr on your server, check out the [installation guide](http://docs.polrproject.org/en/latest/user-guide/installation/). You can clone this repository, or download a [release](https://github.com/cydrobolt/polr/releases). + - To get started with Polr on your server, check out the [installation guide](http://docs.polrproject.org/en/latest/user-guide/installation/). You can clone this repository, or download a [release](https://github.com/cydrobolt/polr/releases). - To get started with the Polr API, check out the [API guide](http://docs.polrproject.org/en/latest/developer-guide/api/). @@ -45,11 +45,17 @@ There are breaking changes between 2.x and 1.x; it is not yet possible to automa * Safari - [Polr.safariextension](https://github.com/cleverdevil/Polr.safariextension) -#### Sponsors +#### Libraries + +* Python - [mypolr](https://github.com/fauskanger/mypolr) + +#### Acknowledgements We would like to thank Oregon State University's Open Source Lab for providing resources for our infrastructure. The Polr website and demo are hosted on their infrastructure. +Thank you to [lastspark](https://thenounproject.com/lastspark/) for providing our logo's icon. + #### Versioning Polr uses [Semantic Versioning](http://semver.org/) @@ -58,7 +64,7 @@ Polr uses [Semantic Versioning](http://semver.org/) #### License - Copyright (C) 2013-2017 Chaoyi Zha + Copyright (C) 2013-2018 Chaoyi Zha This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License From c62f51476f42387624f84da8e90d586b1d3a1a25 Mon Sep 17 00:00:00 2001 From: Chaoyi Zha Date: Wed, 10 Jan 2018 20:33:32 -0500 Subject: [PATCH 18/29] Update logo link --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index 14b5ec6..0f38b41 100644 --- a/README.md +++ b/README.md @@ -1,4 +1,4 @@ -Polr Logo +Polr Logo :aerial_tramway: A modern, minimalist, and lightweight URL shortener. From 58a69d9a5b9ea2bd16777384a53f6899746d2516 Mon Sep 17 00:00:00 2001 From: DT27 Date: Sun, 11 Feb 2018 15:39:59 +0800 Subject: [PATCH 19/29] Remove role form session when user logout. --- app/Http/Controllers/UserController.php | 1 + 1 file changed, 1 insertion(+) diff --git a/app/Http/Controllers/UserController.php b/app/Http/Controllers/UserController.php index 7cdf545..62e8c27 100644 --- a/app/Http/Controllers/UserController.php +++ b/app/Http/Controllers/UserController.php @@ -30,6 +30,7 @@ class UserController extends Controller { public function performLogoutUser(Request $request) { $request->session()->forget('username'); + $request->session()->forget('role'); return redirect()->route('index'); } From b3f0fc62c3f4bfd48af9dc40a7707be7dcd9999f Mon Sep 17 00:00:00 2001 From: DT27 Date: Sun, 11 Feb 2018 18:23:42 +0800 Subject: [PATCH 20/29] Add "Copy to clipboard" button in shorten result page. --- public/css/shorten_result.css | 11 +++++++++++ public/img/clippy.svg | 1 + public/js/clipboard.min.js | 7 +++++++ public/js/shorten_result.js | 20 ++++++++++++++++++++ resources/views/shorten_result.blade.php | 7 ++++++- 5 files changed, 45 insertions(+), 1 deletion(-) create mode 100644 public/img/clippy.svg create mode 100644 public/js/clipboard.min.js diff --git a/public/css/shorten_result.css b/public/css/shorten_result.css index c672654..cbe9574 100644 --- a/public/css/shorten_result.css +++ b/public/css/shorten_result.css @@ -21,3 +21,14 @@ .qr-code-container img { display: inline !important; } + +.input-group { + width: 50%; + margin: 0 auto; +} +.input-group-addon { + padding:0px 10px; + cursor: pointer; +} + +.tooltipped{position:relative}.tooltipped:after{position:absolute;z-index:1000000;display:none;padding:5px 8px;font:normal normal 11px/1.5 Helvetica,arial,nimbussansl,liberationsans,freesans,clean,sans-serif,segoe ui emoji,segoe ui symbol;color:#fff;text-align:center;text-decoration:none;text-shadow:none;text-transform:none;letter-spacing:normal;word-wrap:break-word;white-space:pre;pointer-events:none;content:attr(aria-label);background:rgba(0,0,0,.8);border-radius:3px;-webkit-font-smoothing:subpixel-antialiased}.tooltipped:before{position:absolute;z-index:1000001;display:none;width:0;height:0;color:rgba(0,0,0,.8);pointer-events:none;content:"";border:5px solid transparent}.tooltipped:hover:before,.tooltipped:hover:after,.tooltipped:active:before,.tooltipped:active:after,.tooltipped:focus:before,.tooltipped:focus:after{display:inline-block;text-decoration:none}.tooltipped-multiline:hover:after,.tooltipped-multiline:active:after,.tooltipped-multiline:focus:after{display:table-cell}.tooltipped-s:after,.tooltipped-se:after,.tooltipped-sw:after{top:100%;right:50%;margin-top:5px}.tooltipped-s:before,.tooltipped-se:before,.tooltipped-sw:before{top:auto;right:50%;bottom:-5px;margin-right:-5px;border-bottom-color:rgba(0,0,0,.8)}.tooltipped-se:after{right:auto;left:50%;margin-left:-15px}.tooltipped-sw:after{margin-right:-15px}.tooltipped-n:after,.tooltipped-ne:after,.tooltipped-nw:after{right:50%;bottom:100%;margin-bottom:5px}.tooltipped-n:before,.tooltipped-ne:before,.tooltipped-nw:before{top:-5px;right:50%;bottom:auto;margin-right:-5px;border-top-color:rgba(0,0,0,.8)}.tooltipped-ne:after{right:auto;left:50%;margin-left:-15px}.tooltipped-nw:after{margin-right:-15px}.tooltipped-s:after,.tooltipped-n:after{-webkit-transform:translateX(50%);-ms-transform:translateX(50%);transform:translateX(50%)}.tooltipped-w:after{right:100%;bottom:50%;margin-right:5px;-webkit-transform:translateY(50%);-ms-transform:translateY(50%);transform:translateY(50%)}.tooltipped-w:before{top:50%;bottom:50%;left:-5px;margin-top:-5px;border-left-color:rgba(0,0,0,.8)}.tooltipped-e:after{bottom:50%;left:100%;margin-left:5px;-webkit-transform:translateY(50%);-ms-transform:translateY(50%);transform:translateY(50%)}.tooltipped-e:before{top:50%;right:-5px;bottom:50%;margin-top:-5px;border-right-color:rgba(0,0,0,.8)}.tooltipped-multiline:after{width:-webkit-max-content;width:-moz-max-content;width:max-content;max-width:250px;word-break:break-word;word-wrap:normal;white-space:pre-line;border-collapse:separate}.tooltipped-multiline.tooltipped-s:after,.tooltipped-multiline.tooltipped-n:after{right:auto;left:50%;-webkit-transform:translateX(-50%);-ms-transform:translateX(-50%);transform:translateX(-50%)}.tooltipped-multiline.tooltipped-w:after,.tooltipped-multiline.tooltipped-e:after{right:100%}@media screen and (min-width:0\0){.tooltipped-multiline:after{width:250px}}.tooltipped-sticky:before,.tooltipped-sticky:after{display:inline-block}.tooltipped-sticky.tooltipped-multiline:after{display:table-cell}.fullscreen-overlay-enabled.dark-theme .tooltipped:after{color:#000;background:rgba(255,255,255,.8)}.fullscreen-overlay-enabled.dark-theme .tooltipped .tooltipped-s:before,.fullscreen-overlay-enabled.dark-theme .tooltipped .tooltipped-se:before,.fullscreen-overlay-enabled.dark-theme .tooltipped .tooltipped-sw:before{border-bottom-color:rgba(255,255,255,.8)}.fullscreen-overlay-enabled.dark-theme .tooltipped.tooltipped-n:before,.fullscreen-overlay-enabled.dark-theme .tooltipped.tooltipped-ne:before,.fullscreen-overlay-enabled.dark-theme .tooltipped.tooltipped-nw:before{border-top-color:rgba(255,255,255,.8)}.fullscreen-overlay-enabled.dark-theme .tooltipped.tooltipped-e:before{border-right-color:rgba(255,255,255,.8)}.fullscreen-overlay-enabled.dark-theme .tooltipped.tooltipped-w:before{border-left-color:rgba(255,255,255,.8)} \ No newline at end of file diff --git a/public/img/clippy.svg b/public/img/clippy.svg new file mode 100644 index 0000000..d506c70 --- /dev/null +++ b/public/img/clippy.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/public/js/clipboard.min.js b/public/js/clipboard.min.js new file mode 100644 index 0000000..90fd15b --- /dev/null +++ b/public/js/clipboard.min.js @@ -0,0 +1,7 @@ +/*! + * clipboard.js v1.7.1 + * https://zenorocha.github.io/clipboard.js + * + * Licensed MIT © Zeno Rocha + */ +!function(t){if("object"==typeof exports&&"undefined"!=typeof module)module.exports=t();else if("function"==typeof define&&define.amd)define([],t);else{var e;e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:this,e.Clipboard=t()}}(function(){var t,e,n;return function t(e,n,o){function i(a,c){if(!n[a]){if(!e[a]){var l="function"==typeof require&&require;if(!c&&l)return l(a,!0);if(r)return r(a,!0);var s=new Error("Cannot find module '"+a+"'");throw s.code="MODULE_NOT_FOUND",s}var u=n[a]={exports:{}};e[a][0].call(u.exports,function(t){var n=e[a][1][t];return i(n||t)},u,u.exports,t,e,n,o)}return n[a].exports}for(var r="function"==typeof require&&require,a=0;a0&&void 0!==arguments[0]?arguments[0]:{};this.action=e.action,this.container=e.container,this.emitter=e.emitter,this.target=e.target,this.text=e.text,this.trigger=e.trigger,this.selectedText=""}},{key:"initSelection",value:function t(){this.text?this.selectFake():this.target&&this.selectTarget()}},{key:"selectFake",value:function t(){var e=this,n="rtl"==document.documentElement.getAttribute("dir");this.removeFake(),this.fakeHandlerCallback=function(){return e.removeFake()},this.fakeHandler=this.container.addEventListener("click",this.fakeHandlerCallback)||!0,this.fakeElem=document.createElement("textarea"),this.fakeElem.style.fontSize="12pt",this.fakeElem.style.border="0",this.fakeElem.style.padding="0",this.fakeElem.style.margin="0",this.fakeElem.style.position="absolute",this.fakeElem.style[n?"right":"left"]="-9999px";var o=window.pageYOffset||document.documentElement.scrollTop;this.fakeElem.style.top=o+"px",this.fakeElem.setAttribute("readonly",""),this.fakeElem.value=this.text,this.container.appendChild(this.fakeElem),this.selectedText=(0,i.default)(this.fakeElem),this.copyText()}},{key:"removeFake",value:function t(){this.fakeHandler&&(this.container.removeEventListener("click",this.fakeHandlerCallback),this.fakeHandler=null,this.fakeHandlerCallback=null),this.fakeElem&&(this.container.removeChild(this.fakeElem),this.fakeElem=null)}},{key:"selectTarget",value:function t(){this.selectedText=(0,i.default)(this.target),this.copyText()}},{key:"copyText",value:function t(){var e=void 0;try{e=document.execCommand(this.action)}catch(t){e=!1}this.handleResult(e)}},{key:"handleResult",value:function t(e){this.emitter.emit(e?"success":"error",{action:this.action,text:this.selectedText,trigger:this.trigger,clearSelection:this.clearSelection.bind(this)})}},{key:"clearSelection",value:function t(){this.trigger&&this.trigger.focus(),window.getSelection().removeAllRanges()}},{key:"destroy",value:function t(){this.removeFake()}},{key:"action",set:function t(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"copy";if(this._action=e,"copy"!==this._action&&"cut"!==this._action)throw new Error('Invalid "action" value, use either "copy" or "cut"')},get:function t(){return this._action}},{key:"target",set:function t(e){if(void 0!==e){if(!e||"object"!==(void 0===e?"undefined":r(e))||1!==e.nodeType)throw new Error('Invalid "target" value, use a valid Element');if("copy"===this.action&&e.hasAttribute("disabled"))throw new Error('Invalid "target" attribute. Please use "readonly" instead of "disabled" attribute');if("cut"===this.action&&(e.hasAttribute("readonly")||e.hasAttribute("disabled")))throw new Error('Invalid "target" attribute. You can\'t cut text from elements with "readonly" or "disabled" attributes');this._target=e}},get:function t(){return this._target}}]),t}();t.exports=c})},{select:5}],8:[function(e,n,o){!function(i,r){if("function"==typeof t&&t.amd)t(["module","./clipboard-action","tiny-emitter","good-listener"],r);else if(void 0!==o)r(n,e("./clipboard-action"),e("tiny-emitter"),e("good-listener"));else{var a={exports:{}};r(a,i.clipboardAction,i.tinyEmitter,i.goodListener),i.clipboard=a.exports}}(this,function(t,e,n,o){"use strict";function i(t){return t&&t.__esModule?t:{default:t}}function r(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function a(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function c(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}function l(t,e){var n="data-clipboard-"+t;if(e.hasAttribute(n))return e.getAttribute(n)}var s=i(e),u=i(n),f=i(o),d="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t},h=function(){function t(t,e){for(var n=0;n0&&void 0!==arguments[0]?arguments[0]:{};this.action="function"==typeof e.action?e.action:this.defaultAction,this.target="function"==typeof e.target?e.target:this.defaultTarget,this.text="function"==typeof e.text?e.text:this.defaultText,this.container="object"===d(e.container)?e.container:document.body}},{key:"listenClick",value:function t(e){var n=this;this.listener=(0,f.default)(e,"click",function(t){return n.onClick(t)})}},{key:"onClick",value:function t(e){var n=e.delegateTarget||e.currentTarget;this.clipboardAction&&(this.clipboardAction=null),this.clipboardAction=new s.default({action:this.action(n),target:this.target(n),text:this.text(n),container:this.container,trigger:n,emitter:this})}},{key:"defaultAction",value:function t(e){return l("action",e)}},{key:"defaultTarget",value:function t(e){var n=l("target",e);if(n)return document.querySelector(n)}},{key:"defaultText",value:function t(e){return l("text",e)}},{key:"destroy",value:function t(){this.listener.destroy(),this.clipboardAction&&(this.clipboardAction.destroy(),this.clipboardAction=null)}}],[{key:"isSupported",value:function t(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:["copy","cut"],n="string"==typeof e?[e]:e,o=!!document.queryCommandSupported;return n.forEach(function(t){o=o&&!!document.queryCommandSupported(t)}),o}}]),e}(u.default);t.exports=p})},{"./clipboard-action":7,"good-listener":4,"tiny-emitter":6}]},{},[8])(8)}); \ No newline at end of file diff --git a/public/js/shorten_result.js b/public/js/shorten_result.js index e497843..3406544 100644 --- a/public/js/shorten_result.js +++ b/public/js/shorten_result.js @@ -22,6 +22,26 @@ $('#generate-qr-code').click(function () { container.show(); }); + +var clipboardDemos = new Clipboard('[data-clipboard-demo]'); +clipboardDemos.on('success', function(e) { + e.clearSelection(); + showTooltip(e.trigger, 'Copied!'); +}); +var btns = document.querySelectorAll('.input-group-addon'); +for (var i = 0; i < btns.length; i++) { + btns[i].addEventListener('mouseleave', clearTooltip); + btns[i].addEventListener('blur', clearTooltip); +} +function clearTooltip(e) { + e.currentTarget.setAttribute('class', 'input-group-addon'); + e.currentTarget.removeAttribute('aria-label'); +} +function showTooltip(elem, msg) { + elem.setAttribute('class', 'input-group-addon tooltipped tooltipped-s'); + elem.setAttribute('aria-label', msg); +} + $(function () { original_link = $('.result-box').val(); select_text(); diff --git a/resources/views/shorten_result.blade.php b/resources/views/shorten_result.blade.php index ae16c32..1a7905a 100644 --- a/resources/views/shorten_result.blade.php +++ b/resources/views/shorten_result.blade.php @@ -6,7 +6,10 @@ @section('content')

Shortened URL

- +
+ +
Copy to clipboard
+
Generate QR Code Shorten another @@ -17,5 +20,7 @@ @section('js') + + @endsection From 09724050c285fe63ef87f2ec50cf2cd0f1211ff6 Mon Sep 17 00:00:00 2001 From: Konstantin Zamyakin Date: Sun, 11 Feb 2018 22:46:29 +0300 Subject: [PATCH 21/29] return 404 http status for missing links --- app/Exceptions/Handler.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/app/Exceptions/Handler.php b/app/Exceptions/Handler.php index 2afb883..e1b16ba 100644 --- a/app/Exceptions/Handler.php +++ b/app/Exceptions/Handler.php @@ -51,7 +51,7 @@ class Handler extends ExceptionHandler { return redirect()->to(env('SETTING_INDEX_REDIRECT')); } // Otherwise, show a nice error page - return view('errors.404'); + return response(view('errors.404'), 404); } if ($e instanceof HttpException) { // Handle HTTP exceptions thrown by public-facing controllers From c0ce7d4d6eeeac57c3dda926741fa006f2da7cb2 Mon Sep 17 00:00:00 2001 From: Chaoyi Zha Date: Sun, 11 Feb 2018 17:05:57 -0500 Subject: [PATCH 22/29] Use proper HTTP response code for pretty 500 page; reduce line length --- app/Exceptions/Handler.php | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/app/Exceptions/Handler.php b/app/Exceptions/Handler.php index e1b16ba..4229462 100644 --- a/app/Exceptions/Handler.php +++ b/app/Exceptions/Handler.php @@ -60,11 +60,15 @@ class Handler extends ExceptionHandler { if ($status_code == 500) { // Render a nice error page for 500s - return view('errors.500'); + return response(view('errors.500'), 500); } else { // If not 500, render generic page - return response(view('errors.generic', ['status_code' => $status_code, 'status_message' => $status_message]), $status_code); + return response( + view('errors.generic', [ + 'status_code' => $status_code, + 'status_message' => $status_message + ]), $status_code); } } if ($e instanceof ApiException) { From a095966592ceae53243d9239326892b3a593edce Mon Sep 17 00:00:00 2001 From: Chaoyi Zha Date: Sun, 11 Feb 2018 17:25:26 -0500 Subject: [PATCH 23/29] Update docs logo; update logo in about page; update well CSS to better wrap new logo --- docs/logo.png | Bin 4889 -> 9390 bytes public/css/about.css | 4 ++-- public/img/logo.png | Bin 4889 -> 10024 bytes 3 files changed, 2 insertions(+), 2 deletions(-) diff --git a/docs/logo.png b/docs/logo.png index c70bc6e930f67f8841fe37582fc80d6a4639e577..d8ab877a63a13de39de8cbda5c9565f6b6b7e911 100644 GIT binary patch literal 9390 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 literal 4889 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 R=zkk3JuPF+x+jiN{{t-*T>St5 diff --git a/public/css/about.css b/public/css/about.css index 669c674..07f1517 100644 --- a/public/css/about.css +++ b/public/css/about.css @@ -17,11 +17,11 @@ } .logo-img { - width: 18em; + width: 17em; } .logo-well { - width: 19em; + width: 20.5em; -webkit-animation: colorpulse 20s infinite; animation: colorpulse 20s infinite; diff --git a/public/img/logo.png b/public/img/logo.png index c70bc6e930f67f8841fe37582fc80d6a4639e577..3bd194df271370c6685ed2bc3c418987b636bbf0 100644 GIT binary patch literal 10024 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 R=zkk3JuPF+x+jiN{{t-*T>St5 From 62e484b2994bdef103abaeb2322bf820e474f714 Mon Sep 17 00:00:00 2001 From: DT27 Date: Mon, 12 Feb 2018 08:56:12 +0800 Subject: [PATCH 24/29] Use Bootstrap tooltips. --- public/css/shorten_result.css | 2 -- public/js/shorten_result.js | 24 ++++++++---------------- resources/views/shorten_result.blade.php | 9 +++++---- 3 files changed, 13 insertions(+), 22 deletions(-) diff --git a/public/css/shorten_result.css b/public/css/shorten_result.css index cbe9574..5871b22 100644 --- a/public/css/shorten_result.css +++ b/public/css/shorten_result.css @@ -30,5 +30,3 @@ padding:0px 10px; cursor: pointer; } - -.tooltipped{position:relative}.tooltipped:after{position:absolute;z-index:1000000;display:none;padding:5px 8px;font:normal normal 11px/1.5 Helvetica,arial,nimbussansl,liberationsans,freesans,clean,sans-serif,segoe ui emoji,segoe ui symbol;color:#fff;text-align:center;text-decoration:none;text-shadow:none;text-transform:none;letter-spacing:normal;word-wrap:break-word;white-space:pre;pointer-events:none;content:attr(aria-label);background:rgba(0,0,0,.8);border-radius:3px;-webkit-font-smoothing:subpixel-antialiased}.tooltipped:before{position:absolute;z-index:1000001;display:none;width:0;height:0;color:rgba(0,0,0,.8);pointer-events:none;content:"";border:5px solid transparent}.tooltipped:hover:before,.tooltipped:hover:after,.tooltipped:active:before,.tooltipped:active:after,.tooltipped:focus:before,.tooltipped:focus:after{display:inline-block;text-decoration:none}.tooltipped-multiline:hover:after,.tooltipped-multiline:active:after,.tooltipped-multiline:focus:after{display:table-cell}.tooltipped-s:after,.tooltipped-se:after,.tooltipped-sw:after{top:100%;right:50%;margin-top:5px}.tooltipped-s:before,.tooltipped-se:before,.tooltipped-sw:before{top:auto;right:50%;bottom:-5px;margin-right:-5px;border-bottom-color:rgba(0,0,0,.8)}.tooltipped-se:after{right:auto;left:50%;margin-left:-15px}.tooltipped-sw:after{margin-right:-15px}.tooltipped-n:after,.tooltipped-ne:after,.tooltipped-nw:after{right:50%;bottom:100%;margin-bottom:5px}.tooltipped-n:before,.tooltipped-ne:before,.tooltipped-nw:before{top:-5px;right:50%;bottom:auto;margin-right:-5px;border-top-color:rgba(0,0,0,.8)}.tooltipped-ne:after{right:auto;left:50%;margin-left:-15px}.tooltipped-nw:after{margin-right:-15px}.tooltipped-s:after,.tooltipped-n:after{-webkit-transform:translateX(50%);-ms-transform:translateX(50%);transform:translateX(50%)}.tooltipped-w:after{right:100%;bottom:50%;margin-right:5px;-webkit-transform:translateY(50%);-ms-transform:translateY(50%);transform:translateY(50%)}.tooltipped-w:before{top:50%;bottom:50%;left:-5px;margin-top:-5px;border-left-color:rgba(0,0,0,.8)}.tooltipped-e:after{bottom:50%;left:100%;margin-left:5px;-webkit-transform:translateY(50%);-ms-transform:translateY(50%);transform:translateY(50%)}.tooltipped-e:before{top:50%;right:-5px;bottom:50%;margin-top:-5px;border-right-color:rgba(0,0,0,.8)}.tooltipped-multiline:after{width:-webkit-max-content;width:-moz-max-content;width:max-content;max-width:250px;word-break:break-word;word-wrap:normal;white-space:pre-line;border-collapse:separate}.tooltipped-multiline.tooltipped-s:after,.tooltipped-multiline.tooltipped-n:after{right:auto;left:50%;-webkit-transform:translateX(-50%);-ms-transform:translateX(-50%);transform:translateX(-50%)}.tooltipped-multiline.tooltipped-w:after,.tooltipped-multiline.tooltipped-e:after{right:100%}@media screen and (min-width:0\0){.tooltipped-multiline:after{width:250px}}.tooltipped-sticky:before,.tooltipped-sticky:after{display:inline-block}.tooltipped-sticky.tooltipped-multiline:after{display:table-cell}.fullscreen-overlay-enabled.dark-theme .tooltipped:after{color:#000;background:rgba(255,255,255,.8)}.fullscreen-overlay-enabled.dark-theme .tooltipped .tooltipped-s:before,.fullscreen-overlay-enabled.dark-theme .tooltipped .tooltipped-se:before,.fullscreen-overlay-enabled.dark-theme .tooltipped .tooltipped-sw:before{border-bottom-color:rgba(255,255,255,.8)}.fullscreen-overlay-enabled.dark-theme .tooltipped.tooltipped-n:before,.fullscreen-overlay-enabled.dark-theme .tooltipped.tooltipped-ne:before,.fullscreen-overlay-enabled.dark-theme .tooltipped.tooltipped-nw:before{border-top-color:rgba(255,255,255,.8)}.fullscreen-overlay-enabled.dark-theme .tooltipped.tooltipped-e:before{border-right-color:rgba(255,255,255,.8)}.fullscreen-overlay-enabled.dark-theme .tooltipped.tooltipped-w:before{border-left-color:rgba(255,255,255,.8)} \ No newline at end of file diff --git a/public/js/shorten_result.js b/public/js/shorten_result.js index 3406544..1c7f32f 100644 --- a/public/js/shorten_result.js +++ b/public/js/shorten_result.js @@ -23,24 +23,16 @@ $('#generate-qr-code').click(function () { }); -var clipboardDemos = new Clipboard('[data-clipboard-demo]'); -clipboardDemos.on('success', function(e) { +var clipboard = new Clipboard('[data-clipboard]'); +clipboard.on('success', function(e) { e.clearSelection(); - showTooltip(e.trigger, 'Copied!'); + $('[data-clipboard]').tooltip('show'); +}); +$('[data-clipboard]').on('blur',function () { + $(this).tooltip('destroy') +}).on('mouseleave',function () { + $(this).tooltip('destroy') }); -var btns = document.querySelectorAll('.input-group-addon'); -for (var i = 0; i < btns.length; i++) { - btns[i].addEventListener('mouseleave', clearTooltip); - btns[i].addEventListener('blur', clearTooltip); -} -function clearTooltip(e) { - e.currentTarget.setAttribute('class', 'input-group-addon'); - e.currentTarget.removeAttribute('aria-label'); -} -function showTooltip(elem, msg) { - elem.setAttribute('class', 'input-group-addon tooltipped tooltipped-s'); - elem.setAttribute('aria-label', msg); -} $(function () { original_link = $('.result-box').val(); diff --git a/resources/views/shorten_result.blade.php b/resources/views/shorten_result.blade.php index 1a7905a..f1df3cf 100644 --- a/resources/views/shorten_result.blade.php +++ b/resources/views/shorten_result.blade.php @@ -7,8 +7,10 @@ @section('content')

Shortened URL

- -
Copy to clipboard
+ +
+ +
Generate QR Code Shorten another @@ -20,7 +22,6 @@ @section('js') - - + @endsection From c6c50bc2cc5bb0aa5d8bf1706abf0218edeb612d Mon Sep 17 00:00:00 2001 From: DT27 Date: Mon, 12 Feb 2018 08:59:13 +0800 Subject: [PATCH 25/29] no message --- public/img/clippy.svg | 1 - 1 file changed, 1 deletion(-) delete mode 100644 public/img/clippy.svg diff --git a/public/img/clippy.svg b/public/img/clippy.svg deleted file mode 100644 index d506c70..0000000 --- a/public/img/clippy.svg +++ /dev/null @@ -1 +0,0 @@ - \ No newline at end of file From b80e422275530234ed9d4d767484a24567f91565 Mon Sep 17 00:00:00 2001 From: Chaoyi Zha Date: Thu, 15 Feb 2018 14:55:46 -0500 Subject: [PATCH 26/29] Update ISSUE_TEMPLATE.md --- .github/ISSUE_TEMPLATE.md | 1 + 1 file changed, 1 insertion(+) diff --git a/.github/ISSUE_TEMPLATE.md b/.github/ISSUE_TEMPLATE.md index 6348fa0..609fc18 100644 --- a/.github/ISSUE_TEMPLATE.md +++ b/.github/ISSUE_TEMPLATE.md @@ -1,4 +1,5 @@ + ## Expected Behavior From a243a87de8dfea92e07e6a5f7348c0e46be9b6fe Mon Sep 17 00:00:00 2001 From: Sam Ezeh Date: Tue, 20 Feb 2018 04:18:19 +0000 Subject: [PATCH 27/29] Sanitised URLs (#420) Escape special characters in long URLs in DataTables --- app/Http/Controllers/AdminPaginationController.php | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/app/Http/Controllers/AdminPaginationController.php b/app/Http/Controllers/AdminPaginationController.php index 01297ab..827ed39 100644 --- a/app/Http/Controllers/AdminPaginationController.php +++ b/app/Http/Controllers/AdminPaginationController.php @@ -17,8 +17,8 @@ class AdminPaginationController extends Controller { /* Cell rendering functions */ public function renderLongUrlCell($link) { - return '' . str_limit($link->long_url, 50) . ' - '; + return '' . e(str_limit($link->long_url, 50)) . ' + '; } public function renderClicksCell($link) { From e5dbcda2eab7eaa4ab603c304d8c3f838eeb4fbe Mon Sep 17 00:00:00 2001 From: Chaoyi Zha Date: Thu, 29 Mar 2018 00:01:38 -0400 Subject: [PATCH 28/29] Small changes to code style --- public/js/shorten_result.js | 11 ++++++----- resources/views/shorten_result.blade.php | 2 +- 2 files changed, 7 insertions(+), 6 deletions(-) diff --git a/public/js/shorten_result.js b/public/js/shorten_result.js index 1c7f32f..f05812c 100644 --- a/public/js/shorten_result.js +++ b/public/js/shorten_result.js @@ -23,15 +23,16 @@ $('#generate-qr-code').click(function () { }); -var clipboard = new Clipboard('[data-clipboard]'); +var clipboard = new Clipboard('#clipboard-copy'); clipboard.on('success', function(e) { e.clearSelection(); - $('[data-clipboard]').tooltip('show'); + $('#clipboard-copy').tooltip('show'); }); -$('[data-clipboard]').on('blur',function () { - $(this).tooltip('destroy') + +$('#clipboard-copy').on('blur',function () { + $(this).tooltip('destroy'); }).on('mouseleave',function () { - $(this).tooltip('destroy') + $(this).tooltip('destroy'); }); $(function () { diff --git a/resources/views/shorten_result.blade.php b/resources/views/shorten_result.blade.php index f1df3cf..e4975ec 100644 --- a/resources/views/shorten_result.blade.php +++ b/resources/views/shorten_result.blade.php @@ -8,7 +8,7 @@

Shortened URL

-
+
From 398b63a1902ef9d73151a1f3fb1dff973b98fffe Mon Sep 17 00:00:00 2001 From: Chaoyi Zha Date: Thu, 29 Mar 2018 00:04:11 -0400 Subject: [PATCH 29/29] Style; change width --- public/css/shorten_result.css | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/public/css/shorten_result.css b/public/css/shorten_result.css index 5871b22..42482a1 100644 --- a/public/css/shorten_result.css +++ b/public/css/shorten_result.css @@ -23,10 +23,11 @@ } .input-group { - width: 50%; + width: 40vw; margin: 0 auto; } + .input-group-addon { - padding:0px 10px; + padding: 0px 10px; cursor: pointer; }