Lot of stuff and fixed Edge not accepting #RRGGBBAA notation issue latest
This commit is contained in:
		
							parent
							
								
									fa8dd4b653
								
							
						
					
					
						commit
						73e45df3fc
					
				
					 29 changed files with 2948 additions and 2906 deletions
				
			
		
							
								
								
									
										3
									
								
								.vs/ProjectSettings.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								.vs/ProjectSettings.json
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,3 @@ | ||||||
|  | { | ||||||
|  |   "CurrentProjectSetting": null | ||||||
|  | } | ||||||
							
								
								
									
										14
									
								
								.vs/VSWorkspaceState.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								.vs/VSWorkspaceState.json
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,14 @@ | ||||||
|  | { | ||||||
|  |   "ExpandedNodes": [ | ||||||
|  |     "", | ||||||
|  |     "\\amd", | ||||||
|  |     "\\classes", | ||||||
|  |     "\\db", | ||||||
|  |     "\\lang", | ||||||
|  |     "\\lang\\en", | ||||||
|  |     "\\lang\\nl", | ||||||
|  |     "\\pix" | ||||||
|  |   ], | ||||||
|  |   "SelectedNode": "\\db\\access.php", | ||||||
|  |   "PreviewInSolutionExplorer": false | ||||||
|  | } | ||||||
							
								
								
									
										
											BIN
										
									
								
								.vs/block_gradelevel/v15/.suo
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								.vs/block_gradelevel/v15/.suo
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								.vs/slnx.sqlite
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								.vs/slnx.sqlite
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										2
									
								
								amd/build/renderbadge.min.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								amd/build/renderbadge.min.js
									
									
									
									
										vendored
									
									
								
							|  | @ -1 +1 @@ | ||||||
| define(["jquery","core/str","core/ajax","block_gradelevel/debugger"],function(e,t,i,l){let r=l("renderbadge");r.enable();let a={init:function(){r.info("Setting up badge renderers"),e("figure.levelbadge").each(function(){a.setup_badge(this,!0)})},setup_badge:function(t,i){let l=e(t),n=e(t).data("badge-props");if(r.info("Setting up skill badge on ",t,n),n&&i)r.info("  skill badge was already configured. Skipping process...");else{n=a.fetchProperties(t);let i=e("<canvas height= '"+n.height+"' width = '"+n.width+"'/>");e("canvas",t).remove(),l.append(i),a.render(i[0],n),l.data("badge-props",n)}},render:function(e,t){let i=e.getContext("2d"),l={base:t.color,light:a.shadeBlendConvert(.6,t.color),dark:a.shadeBlendConvert(.3,t.color),lightPoint:a.shadeBlendConvert(.8,t.color),reflection:{lightest:"#ffffff51",darkest:"#ffffff20"},radialGradient:{x0:.75,y0:.25,r0:.05,x1:.6,y1:.4,r1:.4},levelText:"white"},n={size:Math.min(t.height,t.width),borderWidth:.05,reflection:{angle:-20,offset:.125},levelText:{x:.5,y:.9,size:.2,font:"Open Sans, Arial, helvetica, sans-serif"},icon:{x:.5,y:.47,scale:.7}};r.info("  Config",n),r.info("  Colors",l),r.info("  Props",t);let s=i.createRadialGradient(n.size*l.radialGradient.x0,n.size*l.radialGradient.y0,n.size*l.radialGradient.r0,n.size*l.radialGradient.x1,n.size*l.radialGradient.y1,n.size*l.radialGradient.r1);s.addColorStop(0,l.lightPoint),s.addColorStop(1,l.base),i.beginPath(),i.fillStyle=s,i.arc(.5*n.size,.5*n.size,n.size/2,0,2*Math.PI),i.fill();let o=Math.asin(n.reflection.offset),d=n.reflection.angle/360*2*Math.PI,h=i.createLinearGradient((.5-n.reflection.offset*Math.sin(d))/2*n.size,(.5+n.reflection.offset*Math.cos(d))/2*n.size,Math.sin(d)/2*n.size,Math.cos(d)/2*n.size);h.addColorStop(0,l.reflection.lightest),h.addColorStop(1,l.reflection.darkest),i.beginPath(),i.fillStyle=h,i.arc(.5*n.size,.5*n.size,n.size/2,0+o+d,Math.PI-o+d),i.fill();let f=n.size*n.borderWidth;if(i.beginPath(),i.strokeStyle=l.light,i.lineWidth=f,i.arc(.5*n.size,.5*n.size,n.size/2-f/2,0,2*Math.PI),i.stroke(),i.beginPath(),i.strokeStyle=l.dark,i.lineWidth=f,i.arc(.5*n.size,.5*n.size,n.size/2-f/2,0-Math.PI/2,2*t.progress*Math.PI-Math.PI/2),i.stroke(),t.level&&(i.font=n.size*n.levelText.size+"px "+n.levelText.font,i.fillStyle=l.levelText,i.textAlign="center",i.fillText(""+t.level,n.size*n.levelText.x,n.size*n.levelText.y)),t.image){let e=new Image;e.onload=function(){let e={x:0,y:0,w:n.size*n.icon.scale,h:n.size*n.icon.scale};this.width>this.height?e.h*=this.height/this.width:e.w*=this.width/this.height,e.x=n.size*n.icon.x-e.w/2,e.y=n.size*n.icon.y-e.h/2,i.drawImage(this,e.x,e.y,e.w,e.h)},e.src=t.image}},fetchProperties:function(t){let i=e(t),l=i.find("img"),r=null;return l.length>0&&(r=l.attr("src")),{progress:i.attr("data-progress"),width:i.attr("data-width"),height:i.attr("data-height"),color:"#"+i.attr("data-color"),level:i.attr("data-level"),image:r}},shadeBlendConvert:function(e,t,i){if("number"!=typeof e||e<-1||e>1||"string"!=typeof t||"r"!=t[0]&&"#"!=t[0]||i&&"string"!=typeof i)return null;this.sbcRip||(this.sbcRip=(e=>{let t=e.length,i={};if(t>9){if((e=e.split(",")).length<3||e.length>4)return null;i[0]=l(e[0].split("(")[1]),i[1]=l(e[1]),i[2]=l(e[2]),i[3]=e[3]?parseFloat(e[3]):-1}else{if(8==t||6==t||t<4)return null;t<6&&(e="#"+e[1]+e[1]+e[2]+e[2]+e[3]+e[3]+(t>4?e[4]+""+e[4]:"")),e=l(e.slice(1),16),i[0]=e>>16&255,i[1]=e>>8&255,i[2]=255&e,i[3]=-1,9!=t&&5!=t||(i[3]=r(i[2]/255*1e4)/1e4,i[2]=i[1],i[1]=i[0],i[0]=e>>24&255)}return i}));var l=parseInt,r=Math.round,a=t.length>9,n=(a="string"==typeof i?i.length>9||"c"==i&&!a:a,e<0),s=(e=n?-1*e:e,i=i&&"c"!=i?i:n?"#000000":"#FFFFFF",this.sbcRip(t)),o=this.sbcRip(i);return s&&o?a?"rgb"+(s[3]>-1||o[3]>-1?"a(":"(")+r((o[0]-s[0])*e+s[0])+","+r((o[1]-s[1])*e+s[1])+","+r((o[2]-s[2])*e+s[2])+(s[3]<0&&o[3]<0?")":","+(s[3]>-1&&o[3]>-1?r(1e4*((o[3]-s[3])*e+s[3]))/1e4:o[3]<0?s[3]:o[3])+")"):"#"+(4294967296+16777216*r((o[0]-s[0])*e+s[0])+65536*r((o[1]-s[1])*e+s[1])+256*r((o[2]-s[2])*e+s[2])+(s[3]>-1&&o[3]>-1?r(255*((o[3]-s[3])*e+s[3])):o[3]>-1?r(255*o[3]):s[3]>-1?r(255*s[3]):255)).toString(16).slice(1,s[3]>-1||o[3]>-1?void 0:-2):null}};return a}); | define(["jquery","core/str","core/ajax","block_gradelevel/debugger"],function(e,t,i,r){let l=r("renderbadge");function n(e){if(/^#([A-Fa-f0-9]{3})$/.test(e)){let t=e.substring(1).split(""),i="0x"+[t[0],t[0],t[1],t[1],t[2],t[2]].join("");return"rgb("+[i>>16&255,i>>8&255,255&i].join(",")+")"}if(/^#([A-Fa-f0-9]{6})$/.test(e)){let t="0x"+e.substring(1).split("").join("");return"rgb("+[t>>16&255,t>>8&255,255&t].join(",")+")"}if(/^#([A-Fa-f0-9]{8})$/.test(e)){let t=e.substring(1).split(""),i="0x"+[t[0],t[1],t[2],t[3],t[4],t[5]].join(""),r="0x"+[t[6],t[7]].join("");return"rgba("+[i>>16&255,i>>8&255,255&i].join(",")+","+r/255+")"}throw Error("Invalid hex code: "+e)}l.enable();let a={init:function(){l.info("Setting up badge renderers"),e("figure.levelbadge").each(function(){a.setup_badge(this,!0)})},setup_badge:function(t,i){let r=e(t),n=e(t).data("badge-props");if(l.info("Setting up skill badge on ",t,n),n&&i)l.info("  skill badge was already configured. Skipping process...");else{n=a.fetchProperties(t);let i=e("<canvas height= '"+n.height+"' width = '"+n.width+"'/>");e("canvas",t).remove(),r.append(i),a.render(i[0],n),r.data("badge-props",n)}},render:function(e,t){let i=e.getContext("2d"),r={base:t.color,light:a.shadeBlendConvert(.6,t.color),dark:a.shadeBlendConvert(.3,t.color),lightPoint:a.shadeBlendConvert(.8,t.color),reflection:{lightest:"#ffffff51",darkest:"#ffffff20"},radialGradient:{x0:.75,y0:.25,r0:.05,x1:.6,y1:.4,r1:.4},levelText:"white"},s={size:Math.min(t.height,t.width),borderWidth:.05,reflection:{angle:-20,offset:.125},levelText:{x:.5,y:.9,size:.2,font:"Open Sans, Arial, helvetica, sans-serif"},icon:{x:.5,y:.47,scale:.7}};l.info("  Config",s),l.info("  Colors",r),l.info("  Props",t);let o=i.createRadialGradient(s.size*r.radialGradient.x0,s.size*r.radialGradient.y0,s.size*r.radialGradient.r0,s.size*r.radialGradient.x1,s.size*r.radialGradient.y1,s.size*r.radialGradient.r1);o.addColorStop(0,n(r.lightPoint)),o.addColorStop(1,n(r.base)),i.beginPath(),i.fillStyle=o,i.arc(.5*s.size,.5*s.size,s.size/2,0,2*Math.PI),i.fill();let d=Math.asin(s.reflection.offset),h=s.reflection.angle/360*2*Math.PI;l.info("rflAngleRad:",h);let f=i.createLinearGradient((.5-s.reflection.offset*Math.sin(h))/2*s.size,(.5+s.reflection.offset*Math.cos(h))/2*s.size,Math.sin(h)/2*s.size,Math.cos(h)/2*s.size);l.info("rflGradient",f),f.addColorStop(0,n(r.reflection.lightest)),f.addColorStop(1,n(r.reflection.darkest)),i.beginPath(),i.fillStyle=f,i.arc(.5*s.size,.5*s.size,s.size/2,0+d+h,Math.PI-d+h),i.fill(),l.info("Starting with border");let g=s.size*s.borderWidth;if(i.beginPath(),i.strokeStyle=r.light,i.lineWidth=g,i.arc(.5*s.size,.5*s.size,s.size/2-g/2,0,2*Math.PI),i.stroke(),i.beginPath(),i.strokeStyle=r.dark,i.lineWidth=g,i.arc(.5*s.size,.5*s.size,s.size/2-g/2,0-Math.PI/2,2*t.progress*Math.PI-Math.PI/2),i.stroke(),t.level&&(i.font=s.size*s.levelText.size+"px "+s.levelText.font,i.fillStyle=r.levelText,i.textAlign="center",i.fillText(""+t.level,s.size*s.levelText.x,s.size*s.levelText.y)),t.image){let e=new Image;e.onload=function(){let e={x:0,y:0,w:s.size*s.icon.scale,h:s.size*s.icon.scale};this.width>this.height?e.h*=this.height/this.width:e.w*=this.width/this.height,e.x=s.size*s.icon.x-e.w/2,e.y=s.size*s.icon.y-e.h/2,i.drawImage(this,e.x,e.y,e.w,e.h)},e.src=t.image}},fetchProperties:function(t){let i=e(t),r=i.find("img"),l=null;return r.length>0&&(l=r.attr("src")),{progress:i.attr("data-progress"),width:i.attr("data-width"),height:i.attr("data-height"),color:"#"+i.attr("data-color"),level:i.attr("data-level"),image:l}},shadeBlendConvert:function(e,t,i){if("number"!=typeof e||e<-1||e>1||"string"!=typeof t||"r"!=t[0]&&"#"!=t[0]||i&&"string"!=typeof i)return null;this.sbcRip||(this.sbcRip=(e=>{let t=e.length,i={};if(t>9){if((e=e.split(",")).length<3||e.length>4)return null;i[0]=r(e[0].split("(")[1]),i[1]=r(e[1]),i[2]=r(e[2]),i[3]=e[3]?parseFloat(e[3]):-1}else{if(8==t||6==t||t<4)return null;t<6&&(e="#"+e[1]+e[1]+e[2]+e[2]+e[3]+e[3]+(t>4?e[4]+""+e[4]:"")),e=r(e.slice(1),16),i[0]=e>>16&255,i[1]=e>>8&255,i[2]=255&e,i[3]=-1,9!=t&&5!=t||(i[3]=l(i[2]/255*1e4)/1e4,i[2]=i[1],i[1]=i[0],i[0]=e>>24&255)}return i}));var r=parseInt,l=Math.round,n=t.length>9,a=(n="string"==typeof i?i.length>9||"c"==i&&!n:n,e<0),s=(e=a?-1*e:e,i=i&&"c"!=i?i:a?"#000000":"#FFFFFF",this.sbcRip(t)),o=this.sbcRip(i);return s&&o?n?"rgb"+(s[3]>-1||o[3]>-1?"a(":"(")+l((o[0]-s[0])*e+s[0])+","+l((o[1]-s[1])*e+s[1])+","+l((o[2]-s[2])*e+s[2])+(s[3]<0&&o[3]<0?")":","+(s[3]>-1&&o[3]>-1?l(1e4*((o[3]-s[3])*e+s[3]))/1e4:o[3]<0?s[3]:o[3])+")"):"#"+(4294967296+16777216*l((o[0]-s[0])*e+s[0])+65536*l((o[1]-s[1])*e+s[1])+256*l((o[2]-s[2])*e+s[2])+(s[3]>-1&&o[3]>-1?l(255*((o[3]-s[3])*e+s[3])):o[3]>-1?l(255*o[3]):s[3]>-1?l(255*s[3]):255)).toString(16).slice(1,s[3]>-1||o[3]>-1?void 0:-2):null}};return a}); | ||||||
|  | @ -7,6 +7,29 @@ define(['jquery', 'core/str', 'core/ajax','block_gradelevel/debugger' ], functio | ||||||
|     let debug = Debugger("renderbadge"); |     let debug = Debugger("renderbadge"); | ||||||
|     debug.enable(); |     debug.enable(); | ||||||
| 
 | 
 | ||||||
|  |     // function is used to overcome Edge's non-support of CSS4 hex rgba notation (@nov 2018) 
 | ||||||
|  |     /* eslint-disable no-bitwise*/ | ||||||
|  |     function hexToRgbA(hex){ | ||||||
|  |         /*eslint no-bitwise: "off"*/ | ||||||
|  |         if(/^#([A-Fa-f0-9]{3})$/.test(hex)){ | ||||||
|  |             let h= hex.substring(1).split(''); | ||||||
|  |             let c= '0x'+[h[0], h[0], h[1], h[1], h[2], h[2]].join(''); | ||||||
|  |             return 'rgb('+[(c>>16)&255, (c>>8)&255, c&255].join(',')+')'; | ||||||
|  |         } | ||||||
|  |         if(/^#([A-Fa-f0-9]{6})$/.test(hex)){ | ||||||
|  |             let h= hex.substring(1).split(''); | ||||||
|  |             let c= '0x'+h.join(''); | ||||||
|  |             return 'rgb('+[(c>>16)&255, (c>>8)&255, c&255].join(',')+')'; | ||||||
|  |         } | ||||||
|  |         if(/^#([A-Fa-f0-9]{8})$/.test(hex)){ | ||||||
|  |             let h= hex.substring(1).split(''); | ||||||
|  |             let c = '0x' + [h[0],h[1],h[2],h[3],h[4],h[5],].join(''); | ||||||
|  |             let a= '0x' + [h[6],h[7],].join(''); | ||||||
|  |             return 'rgba('+[(c>>16)&255, (c>>8)&255, c&255].join(',')+','+a/255.0+')'; | ||||||
|  |         } | ||||||
|  |         throw Error('Invalid hex code: ' + hex); | ||||||
|  |     } | ||||||
|  |     /* eslint-enable no-bitwise */ | ||||||
|     let self = { |     let self = { | ||||||
|         init: function init() { |         init: function init() { | ||||||
|             debug.info("Setting up badge renderers"); |             debug.info("Setting up badge renderers"); | ||||||
|  | @ -90,8 +113,8 @@ define(['jquery', 'core/str', 'core/ajax','block_gradelevel/debugger' ], functio | ||||||
|                 config.size * colors.radialGradient.y1, |                 config.size * colors.radialGradient.y1, | ||||||
|                 (config.size ) * colors.radialGradient.r1 |                 (config.size ) * colors.radialGradient.r1 | ||||||
|             ); |             ); | ||||||
|             baseGradient.addColorStop(0, colors.lightPoint); |             baseGradient.addColorStop(0, hexToRgbA(colors.lightPoint)); | ||||||
|             baseGradient.addColorStop(1, colors.base); |             baseGradient.addColorStop(1, hexToRgbA(colors.base)); | ||||||
|             ctx.beginPath(); |             ctx.beginPath(); | ||||||
|             ctx.fillStyle = baseGradient; |             ctx.fillStyle = baseGradient; | ||||||
|             ctx.arc(0.5 * config.size, 0.5 * config.size, config.size / 2, 0, 2 * Math.PI); |             ctx.arc(0.5 * config.size, 0.5 * config.size, config.size / 2, 0, 2 * Math.PI); | ||||||
|  | @ -102,21 +125,23 @@ define(['jquery', 'core/str', 'core/ajax','block_gradelevel/debugger' ], functio | ||||||
|             let rflOffset = Math.asin(config.reflection.offset); |             let rflOffset = Math.asin(config.reflection.offset); | ||||||
|             let rflAngleRad = (config.reflection.angle / 360.0) * 2 * Math.PI; |             let rflAngleRad = (config.reflection.angle / 360.0) * 2 * Math.PI; | ||||||
| 
 | 
 | ||||||
|  |             debug.info("rflAngleRad:",rflAngleRad); | ||||||
|             let rflGradient = ctx.createLinearGradient( |             let rflGradient = ctx.createLinearGradient( | ||||||
|                 (0.5 - config.reflection.offset * Math.sin(rflAngleRad))/2 * config.size, |                 (0.5 - config.reflection.offset * Math.sin(rflAngleRad))/2 * config.size, | ||||||
|                 (0.5 + config.reflection.offset * Math.cos(rflAngleRad))/2 * config.size, |                 (0.5 + config.reflection.offset * Math.cos(rflAngleRad))/2 * config.size, | ||||||
|                 Math.sin(rflAngleRad)/2 * config.size, |                 Math.sin(rflAngleRad)/2 * config.size, | ||||||
|                 Math.cos(rflAngleRad)/2 * config.size |                 Math.cos(rflAngleRad)/2 * config.size | ||||||
|             ); |             ); | ||||||
|             rflGradient.addColorStop(0, colors.reflection.lightest); |             debug.info("rflGradient",rflGradient); | ||||||
|             rflGradient.addColorStop(1, colors.reflection.darkest); |             rflGradient.addColorStop(0, hexToRgbA(colors.reflection.lightest)); | ||||||
|  |             rflGradient.addColorStop(1, hexToRgbA(colors.reflection.darkest)); | ||||||
|             ctx.beginPath(); |             ctx.beginPath(); | ||||||
|             ctx.fillStyle = rflGradient; |             ctx.fillStyle = rflGradient; | ||||||
|             ctx.arc(0.5 * config.size, 0.5 * config.size, config.size / 2, |             ctx.arc(0.5 * config.size, 0.5 * config.size, config.size / 2, | ||||||
|                 0 + rflOffset + rflAngleRad, |                 0 + rflOffset + rflAngleRad, | ||||||
|                 Math.PI - rflOffset + rflAngleRad); |                 Math.PI - rflOffset + rflAngleRad); | ||||||
|             ctx.fill(); |             ctx.fill(); | ||||||
| 
 |             debug.info("Starting with border"); | ||||||
|             // draw empty border
 |             // draw empty border
 | ||||||
|             let strokeWidth = config.size * config.borderWidth; |             let strokeWidth = config.size * config.borderWidth; | ||||||
|             ctx.beginPath(); |             ctx.beginPath(); | ||||||
|  |  | ||||||
|  | @ -1,4 +1,4 @@ | ||||||
| <?php | <?php | ||||||
| $plugin->component = 'block_gradelevel';  // Recommended since 2.0.2 (MDL-26035). Required since 3.0 (MDL-48494)
 | $plugin->component = 'block_gradelevel';  // Recommended since 2.0.2 (MDL-26035). Required since 3.0 (MDL-48494)
 | ||||||
| $plugin->version = 2018092402;  // YYYYMMDDHH (year, month, day, 24-hr time)
 | $plugin->version = 2018112400;  // YYYYMMDDHH (year, month, day, iteration)
 | ||||||
| $plugin->requires = 2018050800; // YYYYMMDDHH (This is the release version for Moodle 3.5)
 | $plugin->requires = 2018050800; // YYYYMMDDHH (This is the release version for Moodle 3.5)
 | ||||||
		Loading…
	
		Reference in a new issue
	
	 user
						user