From 4e3c6b5af5426de248bcf78780f54dd51e2c6957 Mon Sep 17 00:00:00 2001 From: overint Date: Sun, 22 Oct 2017 12:01:10 +1100 Subject: #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 -- cgit v1.2.3 From 162f468b1c54b1675b5a9e0ddedf8e9c7f1addb4 Mon Sep 17 00:00:00 2001 From: overint Date: Sun, 22 Oct 2017 12:01:49 +1100 Subject: #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 -- cgit v1.2.3 From 5a6f4ca3a54c987262df2d0df0f37fb0a1380d5b Mon Sep 17 00:00:00 2001 From: overint Date: Sun, 22 Oct 2017 12:05:13 +1100 Subject: #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(); }); -- cgit v1.2.3 From a44a3fb22519b6ef27ea7d3018d42609cfb384c4 Mon Sep 17 00:00:00 2001 From: overint Date: Sun, 22 Oct 2017 12:06:20 +1100 Subject: #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 }); -- cgit v1.2.3 From 8b979066a60c112eed6f879c0b0afee07bf0ca81 Mon Sep 17 00:00:00 2001 From: overint Date: Sun, 22 Oct 2017 13:01:15 +1100 Subject: #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 -- cgit v1.2.3 From 3a8ce1d0eca281a8f765612ded993e860792e220 Mon Sep 17 00:00:00 2001 From: Chaoyi Zha Date: Thu, 26 Oct 2017 16:28:13 -0400 Subject: 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; } -- cgit v1.2.3 From 90e24195ee37409b95556f69a3c1ff1b57685b24 Mon Sep 17 00:00:00 2001 From: Chaoyi Zha Date: Thu, 26 Oct 2017 16:30:41 -0400 Subject: 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
-- cgit v1.2.3 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: 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 -- cgit v1.2.3 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: 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: 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 -- cgit v1.2.3 From cc73a5e08daf4f21d4f3bf1e33105a542eea5b46 Mon Sep 17 00:00:00 2001 From: sanderr Date: Tue, 12 Dec 2017 20:41:08 +0000 Subject: 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; } -- cgit v1.2.3 From bbf3c2ec91cf074073858f1e7300ae0409dfe021 Mon Sep 17 00:00:00 2001 From: Chaoyi Zha Date: Thu, 14 Dec 2017 15:27:45 -0500 Subject: 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)) -- cgit v1.2.3 From 25094345d1ddf405837f25c7a3c114d228802898 Mon Sep 17 00:00:00 2001 From: Iuri de Silvio Date: Wed, 20 Dec 2017 20:14:51 -0200 Subject: 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; } } -- cgit v1.2.3 From 5b48ab31ca9ecddb491e18213acd27e226eec1e2 Mon Sep 17 00:00:00 2001 From: Iuri de Silvio Date: Wed, 20 Dec 2017 22:31:00 -0200 Subject: $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; } -- cgit v1.2.3 From 9e4ad61e2b962dbbe310cc8378146f27e2ab8064 Mon Sep 17 00:00:00 2001 From: Iuri de Silvio Date: Thu, 21 Dec 2017 08:44:24 -0200 Subject: create api quota index --- .../2017_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'); + }); + } +} -- cgit v1.2.3 From c16c477d0b1d0434e8b57c987fad7610bf45a1ec Mon Sep 17 00:00:00 2001 From: Chaoyi Zha Date: Wed, 10 Jan 2018 17:49:36 -0500 Subject: 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. -- cgit v1.2.3 From 992852138ef65e79309fe0e560c65cd634bd3e4e Mon Sep 17 00:00:00 2001 From: Chaoyi Zha Date: Wed, 10 Jan 2018 18:13:04 -0500 Subject: 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 -- cgit v1.2.3 From c62f51476f42387624f84da8e90d586b1d3a1a25 Mon Sep 17 00:00:00 2001 From: Chaoyi Zha Date: Wed, 10 Jan 2018 20:33:32 -0500 Subject: 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. -- cgit v1.2.3 From 58a69d9a5b9ea2bd16777384a53f6899746d2516 Mon Sep 17 00:00:00 2001 From: DT27 Date: Sun, 11 Feb 2018 15:39:59 +0800 Subject: 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'); } -- cgit v1.2.3 From b3f0fc62c3f4bfd48af9dc40a7707be7dcd9999f Mon Sep 17 00:00:00 2001 From: DT27 Date: Sun, 11 Feb 2018 18:23:42 +0800 Subject: 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 -- cgit v1.2.3 From 09724050c285fe63ef87f2ec50cf2cd0f1211ff6 Mon Sep 17 00:00:00 2001 From: Konstantin Zamyakin Date: Sun, 11 Feb 2018 22:46:29 +0300 Subject: 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 -- cgit v1.2.3 From c0ce7d4d6eeeac57c3dda926741fa006f2da7cb2 Mon Sep 17 00:00:00 2001 From: Chaoyi Zha Date: Sun, 11 Feb 2018 17:05:57 -0500 Subject: 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) { -- cgit v1.2.3 From a095966592ceae53243d9239326892b3a593edce Mon Sep 17 00:00:00 2001 From: Chaoyi Zha Date: Sun, 11 Feb 2018 17:25:26 -0500 Subject: 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 c70bc6e..d8ab877 100644 Binary files a/docs/logo.png and b/docs/logo.png differ 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 c70bc6e..3bd194d 100644 Binary files a/public/img/logo.png and b/public/img/logo.png differ -- cgit v1.2.3 From 62e484b2994bdef103abaeb2322bf820e474f714 Mon Sep 17 00:00:00 2001 From: DT27 Date: Mon, 12 Feb 2018 08:56:12 +0800 Subject: 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 -- cgit v1.2.3 From c6c50bc2cc5bb0aa5d8bf1706abf0218edeb612d Mon Sep 17 00:00:00 2001 From: DT27 Date: Mon, 12 Feb 2018 08:59:13 +0800 Subject: 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 -- cgit v1.2.3 From b80e422275530234ed9d4d767484a24567f91565 Mon Sep 17 00:00:00 2001 From: Chaoyi Zha Date: Thu, 15 Feb 2018 14:55:46 -0500 Subject: 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 -- cgit v1.2.3 From a243a87de8dfea92e07e6a5f7348c0e46be9b6fe Mon Sep 17 00:00:00 2001 From: Sam Ezeh Date: Tue, 20 Feb 2018 04:18:19 +0000 Subject: 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) { -- cgit v1.2.3 From e5dbcda2eab7eaa4ab603c304d8c3f838eeb4fbe Mon Sep 17 00:00:00 2001 From: Chaoyi Zha Date: Thu, 29 Mar 2018 00:01:38 -0400 Subject: 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

-
+
-- cgit v1.2.3 From 398b63a1902ef9d73151a1f3fb1dff973b98fffe Mon Sep 17 00:00:00 2001 From: Chaoyi Zha Date: Thu, 29 Mar 2018 00:04:11 -0400 Subject: 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; } -- cgit v1.2.3