angular-canvas
Advanced tools
Comparing version 0.0.6 to 0.0.7
@@ -471,3 +471,2 @@ (function (global, factory) { | ||
DefaultDomRenderer2.prototype.createText = function (value) { | ||
console.log(value); | ||
return document.createTextNode(value); | ||
@@ -907,3 +906,3 @@ }; | ||
if (node.setValue) { | ||
node.setValue && node.setValue(value); | ||
node.setValue(value); | ||
} | ||
@@ -910,0 +909,0 @@ else { |
@@ -15,3 +15,3 @@ !function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("@angular/core"),require("@angular/common"),require("@angular/platform-browser")):"function"==typeof define&&define.amd?define("angular-canvas",["exports","@angular/core","@angular/common","@angular/platform-browser"],e):e((t=t||self)["angular-canvas"]={},t.ng.core,t.ng.common,t.ng.platformBrowser)}(this,(function(t,e,n,o){"use strict"; | ||
PERFORMANCE OF THIS SOFTWARE. | ||
***************************************************************************** */var r=function(t,e){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(t,e){t.__proto__=e}||function(t,e){for(var n in e)Object.prototype.hasOwnProperty.call(e,n)&&(t[n]=e[n])})(t,e)};function i(t,e){function n(){this.constructor=t}r(t,e),t.prototype=null===e?Object.create(e):(n.prototype=e.prototype,new n)}Object.create;function s(t,e){var n="function"==typeof Symbol&&t[Symbol.iterator];if(!n)return t;var o,r,i=n.call(t),s=[];try{for(;(void 0===e||e-- >0)&&!(o=i.next()).done;)s.push(o.value)}catch(t){r={error:t}}finally{try{o&&!o.done&&(n=i.return)&&n.call(i)}finally{if(r)throw r.error}}return s}Object.create;function a(t){return Array.from(t.values()).filter((function(t){return t&&!!t.draw}))}var p=function(){function t(t){var e=this;this.ngZone=t,this.componentSet=new Set,this.componentsDrawings=[],this.element=document.createElement("canvas"),this.element.style.position="absolute",this.context=this.element.getContext("2d"),this.ngZone.runOutsideAngular((function(){window.requestAnimationFrame((function(t){return e.draw(t)}))}))}return Object.defineProperty(t.prototype,"parent",{get:function(){return this._parent},set:function(t){var e=this;this.resizeObserver=new ResizeObserver((function(t){var n=s(t,1)[0];e.element.width=n.contentRect.width,e.element.height=n.contentRect.height,e.drawAll(!1)})),this.resizeObserver.observe(t)},enumerable:!1,configurable:!0}),t.prototype.addClass=function(t){this.element.setAttribute("class",t)},t.prototype.appendChild=function(t){this.componentSet.add(t),this.componentsDrawings=a(this.componentSet)},t.prototype.removeChild=function(t){this.componentSet.delete(t),this.componentsDrawings=a(this.componentSet)},t.prototype.insertBefore=function(t,e){this.componentSet.add(t),this.componentsDrawings=a(this.componentSet)},t.prototype.removeAttribute=function(t,e){},t.prototype.removeClass=function(t){},t.prototype.removeStyle=function(t,e){},t.prototype.setNgAttribute=function(t,e,n){this.element.setAttribute(t,e)},t.prototype.setNgProperty=function(t,e){},t.prototype.setStyle=function(t,e,n){},t.prototype.setValue=function(t){},t.prototype.drawAll=function(t){var e=this;this.ngZone.runOutsideAngular((function(){e.requestId&&window.cancelAnimationFrame(e.requestId),e.requestId=window.requestAnimationFrame((function(n){return e.draw(n,t)}))}))},t.prototype.draw=function(t,e){var n=this;void 0===e&&(e=!0);var o=this.context;e&&o.clearRect(0,0,this.element.width,this.element.height);for(var r=!1,i=0;i<this.componentsDrawings.length;i++)this.componentsDrawings[i].draw(o,t),r=r||this.componentsDrawings[i].needDraw;r&&(this.requestId&&window.cancelAnimationFrame(this.requestId),this.requestId=window.requestAnimationFrame((function(t){return n.draw(t)})))},t}();p.nodeName="canvas";var u={svg:"http://www.w3.org/2000/svg",xhtml:"http://www.w3.org/1999/xhtml",xlink:"http://www.w3.org/1999/xlink",xml:"http://www.w3.org/XML/1998/namespace",xmlns:"http://www.w3.org/2000/xmlns/"},c=/%COMP%/g,l="_nghost-%COMP%",d="_ngcontent-%COMP%";function h(t){return d.replace(c,t)}function y(t){return l.replace(c,t)}function f(t,e,n){for(var o=0;o<e.length;o++){var r=e[o];Array.isArray(r)?f(t,r,n):(r=r.replace(c,t),n.push(r))}return n}var m=window.ngDevMode,v=void 0===m||!!m;function w(t){return function(e){if("__ngUnwrap__"===e)return t;!1===t(e)&&(e.preventDefault(),e.returnValue=!1)}}var g=function(){function t(t){this.eventManager=t,this.data=Object.create(null)}return t.prototype.destroy=function(){},t.prototype.createElement=function(t,e){return e?document.createElementNS(u[e]||e,t):document.createElement(t)},t.prototype.createComment=function(t){return document.createComment(t)},t.prototype.createText=function(t){return console.log(t),document.createTextNode(t)},t.prototype.appendChild=function(t,e){t.appendChild(e)},t.prototype.insertBefore=function(t,e,n){t&&t.insertBefore(e,n)},t.prototype.removeChild=function(t,e){t&&t.removeChild(e)},t.prototype.selectRootElement=function(t,e){var n="string"==typeof t?document.querySelector(t):t;if(!n)throw new Error('The selector "'+t+'" did not match any elements');return e||(n.textContent=""),n},t.prototype.parentNode=function(t){return t.parentNode},t.prototype.nextSibling=function(t){return t.nextSibling},t.prototype.setAttribute=function(t,e,n,o){if(o){e=o+":"+e;var r=u[o];r?t.setAttributeNS(r,e,n):t.setAttribute(e,n)}else t.setAttribute(e,n)},t.prototype.removeAttribute=function(t,e,n){if(n){var o=u[n];o?t.removeAttributeNS(o,e):t.removeAttribute(n+":"+e)}else t.removeAttribute(e)},t.prototype.addClass=function(t,e){t.classList.add(e)},t.prototype.removeClass=function(t,e){t.classList.remove(e)},t.prototype.setStyle=function(t,n,o,r){r&e.RendererStyleFlags2.DashCase?t.style.setProperty(n,o,r&e.RendererStyleFlags2.Important?"important":""):t.style[n]=o},t.prototype.removeStyle=function(t,n,o){o&e.RendererStyleFlags2.DashCase?t.style.removeProperty(n):t.style[n]=""},t.prototype.setProperty=function(t,e,n){v&&C(e,"property"),t[e]=n},t.prototype.setValue=function(t,e){t.nodeValue=e},t.prototype.listen=function(t,e,n){return v&&C(e,"listener"),"string"==typeof t?this.eventManager.addGlobalEventListener(t,e,w(n)):this.eventManager.addEventListener(t,e,w(n))},t}(),S="@".charCodeAt(0);function C(t,e){if(t.charCodeAt(0)===S)throw new Error("Found the synthetic "+e+" "+t+'. Please include either "BrowserAnimationsModule" or "NoopAnimationsModule" in your application.')}var A=function(t){function e(e,n,o,r){var i=t.call(this,e)||this;i.component=o;var s=f(r+"-"+o.id,o.styles,[]);return n.addStyles(s),i.contentAttr=h(r+"-"+o.id),i.hostAttr=y(r+"-"+o.id),i}return i(e,t),e.prototype.applyToHost=function(e){t.prototype.setAttribute.call(this,e,this.hostAttr,"")},e.prototype.createElement=function(e,n){var o=t.prototype.createElement.call(this,e,n);return t.prototype.setAttribute.call(this,o,this.contentAttr,""),o},e}(g),b=function(t){function n(n,o,r,i){var s=t.call(this,n)||this;s.sharedStylesHost=o,s.hostEl=r,s.component=i,i.encapsulation===e.ViewEncapsulation.ShadowDom?s.shadowRoot=r.attachShadow({mode:"open"}):s.shadowRoot=r.createShadowRoot(),s.sharedStylesHost.addHost(s.shadowRoot);for(var a=f(i.id,i.styles,[]),p=0;p<a.length;p++){var u=document.createElement("style");u.textContent=a[p],s.shadowRoot.appendChild(u)}return s}return i(n,t),n.prototype.nodeOrShadowRoot=function(t){return t===this.hostEl?this.shadowRoot:t},n.prototype.destroy=function(){this.sharedStylesHost.removeHost(this.shadowRoot)},n.prototype.appendChild=function(e,n){return t.prototype.appendChild.call(this,this.nodeOrShadowRoot(e),n)},n.prototype.insertBefore=function(e,n,o){return t.prototype.insertBefore.call(this,this.nodeOrShadowRoot(e),n,o)},n.prototype.removeChild=function(e,n){return t.prototype.removeChild.call(this,this.nodeOrShadowRoot(e),n)},n.prototype.parentNode=function(e){return this.nodeOrShadowRoot(t.prototype.parentNode.call(this,this.nodeOrShadowRoot(e)))},n}(g),R={};function E(){return R.canvasRendererMetadataArgsStorage||(R.canvasRendererMetadataArgsStorage=new M),R.canvasRendererMetadataArgsStorage}var M=function(){this.elements=new Map},x=function(){function t(t,e,n,o){this.eventManager=t,this.sharedStylesHost=e,this.appId=n,this.ngZone=o,this.rendererByCompId=new Map,this.defaultRenderer=new g(t)}return t.prototype.end=function(){},t.prototype.createRenderer=function(t,n){if(!t||!n)return this.defaultRenderer;if(n.type&&n.type.isCanvasComponent)return(o=this.rendererByCompId.get(n.id))||(o=new O(this.eventManager,this.sharedStylesHost,n,this.appId,this.ngZone),this.rendererByCompId.set(n.id,o)),o.applyToHost(t),o;switch(n.encapsulation){case e.ViewEncapsulation.Emulated:var o;return(o=this.rendererByCompId.get(n.id))||(o=new A(this.eventManager,this.sharedStylesHost,n,this.appId),this.rendererByCompId.set(n.id,o)),o.applyToHost(t),o;case e.ViewEncapsulation.Native:case e.ViewEncapsulation.ShadowDom:return new b(this.eventManager,this.sharedStylesHost,t,n);default:if(!this.rendererByCompId.has(n.id)){var r=f(n.id,n.styles,[]);this.sharedStylesHost.addStyles(r),this.rendererByCompId.set(n.id,this.defaultRenderer)}return this.defaultRenderer}},t}();x.decorators=[{type:e.Injectable}],x.ctorParameters=function(){return[{type:o.EventManager},{type:o.ɵDomSharedStylesHost},{type:String},{type:e.NgZone}]};var O=function(){function t(t,e,n,o,r){this.component=n,this.ngZone=r,this.canvasElements=E().elements;var i=f(o+"-"+n.id,n.styles,[]);e.addStyles(i),this.contentAttr=h(o+"-"+n.id),this.hostAttr=y(o+"-"+n.id)}return t.prototype.applyToHost=function(t){this.setAttribute(t,this.hostAttr,"")},t.prototype.createElement=function(t,e){var n=this.canvasElements.get(t);if(n)return new n;if("canvas"===t){var o=new p(this.ngZone);return o.element.setAttribute(this.contentAttr,""),o}var r=void 0;return r=e?document.createElementNS(u[e]||e,t):document.createElement(t),this.setAttribute(r,this.contentAttr,""),r},t.prototype.createText=function(t){return document.createTextNode(t)},t.prototype.selectRootElement=function(t,e){var n="string"==typeof t?document.querySelector(t):t;if(!n)throw new Error('The selector "'+t+'" did not match any elements');return e||(n.textContent=""),n},t.prototype.addClass=function(t,e){t.classList?t.classList.add(e):t.addClass(e)},t.prototype.removeClass=function(t,e){t.classList?t.classList.add(e):t.removeClass(e)},t.prototype.appendChild=function(t,e){e&&(e.parent=t,e instanceof p?t.appendChild(e.element):t.appendChild(e))},t.prototype.removeChild=function(t,e){e.destroy&&e.destroy(),t&&t.removeChild(e)},t.prototype.createComment=function(t){return document.createComment(t)},t.prototype.destroy=function(){},t.prototype.insertBefore=function(t,e,n){t&&t.insertBefore&&(e.parent=t,t.insertBefore(e,n))},t.prototype.listen=function(t,e,n){var o=function(e){return n.call(t,e)};return t.addEventListener(e,o),function(){return t.removeEventListener(e,o)}},t.prototype.nextSibling=function(t){return{previous:t,next:t.nextSibling}},t.prototype.parentNode=function(t){return t.parent?t.parent:t},t.prototype.removeAttribute=function(t,e,n){if(n){var o=u[n];o?t.removeAttributeNS(o,e):t.removeAttribute(n+":"+e)}else t.removeAttribute(e)},t.prototype.removeStyle=function(t,e,n){t.removeStyle(e,n)},t.prototype.setAttribute=function(t,e,n,o){if(o){e=o+":"+e;var r=u[o];r?t.setAttributeNS(r,e,n):t.setAttribute(e,n)}else t.setAttribute(e,n)},t.prototype.setProperty=function(t,e,n){t.setNgProperty(e,n)},t.prototype.setStyle=function(t,n,o,r){t.style?r&e.RendererStyleFlags2.DashCase?t.style.setProperty(n,o,r&e.RendererStyleFlags2.Important?"important":""):t.style[n]=o:t.setStyle(n,o,r)},t.prototype.setValue=function(t,e){t.setValue?t.setValue&&t.setValue(e):t.nodeValue=e},t}(),N=function(){function t(){}return t.forRoot=function(e){return{ngModule:t}},t}();N.decorators=[{type:e.NgModule,args:[{imports:[n.CommonModule],providers:[{provide:e.RendererFactory2,useClass:x,deps:[o.EventManager,o.ɵDomSharedStylesHost,e.APP_ID,e.NgZone]}],schemas:[e.NO_ERRORS_SCHEMA]}]}],t.CanvasComponent=function(t){t.isCanvasComponent=!0},t.CanvasDomModule=N,t.CanvasDomRendererFactory=x,t.CanvasElement=function(t){return function(e){E().elements.set(t.selector,e)}},t.CanvasRenderer=O,t.MetadataArgsStorage=M,t.NgCanvas=p,t.getMetadataArgsStorage=E,Object.defineProperty(t,"__esModule",{value:!0})})); | ||
***************************************************************************** */var r=function(t,e){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(t,e){t.__proto__=e}||function(t,e){for(var n in e)Object.prototype.hasOwnProperty.call(e,n)&&(t[n]=e[n])})(t,e)};function i(t,e){function n(){this.constructor=t}r(t,e),t.prototype=null===e?Object.create(e):(n.prototype=e.prototype,new n)}Object.create;function s(t,e){var n="function"==typeof Symbol&&t[Symbol.iterator];if(!n)return t;var o,r,i=n.call(t),s=[];try{for(;(void 0===e||e-- >0)&&!(o=i.next()).done;)s.push(o.value)}catch(t){r={error:t}}finally{try{o&&!o.done&&(n=i.return)&&n.call(i)}finally{if(r)throw r.error}}return s}Object.create;function a(t){return Array.from(t.values()).filter((function(t){return t&&!!t.draw}))}var p=function(){function t(t){var e=this;this.ngZone=t,this.componentSet=new Set,this.componentsDrawings=[],this.element=document.createElement("canvas"),this.element.style.position="absolute",this.context=this.element.getContext("2d"),this.ngZone.runOutsideAngular((function(){window.requestAnimationFrame((function(t){return e.draw(t)}))}))}return Object.defineProperty(t.prototype,"parent",{get:function(){return this._parent},set:function(t){var e=this;this.resizeObserver=new ResizeObserver((function(t){var n=s(t,1)[0];e.element.width=n.contentRect.width,e.element.height=n.contentRect.height,e.drawAll(!1)})),this.resizeObserver.observe(t)},enumerable:!1,configurable:!0}),t.prototype.addClass=function(t){this.element.setAttribute("class",t)},t.prototype.appendChild=function(t){this.componentSet.add(t),this.componentsDrawings=a(this.componentSet)},t.prototype.removeChild=function(t){this.componentSet.delete(t),this.componentsDrawings=a(this.componentSet)},t.prototype.insertBefore=function(t,e){this.componentSet.add(t),this.componentsDrawings=a(this.componentSet)},t.prototype.removeAttribute=function(t,e){},t.prototype.removeClass=function(t){},t.prototype.removeStyle=function(t,e){},t.prototype.setNgAttribute=function(t,e,n){this.element.setAttribute(t,e)},t.prototype.setNgProperty=function(t,e){},t.prototype.setStyle=function(t,e,n){},t.prototype.setValue=function(t){},t.prototype.drawAll=function(t){var e=this;this.ngZone.runOutsideAngular((function(){e.requestId&&window.cancelAnimationFrame(e.requestId),e.requestId=window.requestAnimationFrame((function(n){return e.draw(n,t)}))}))},t.prototype.draw=function(t,e){var n=this;void 0===e&&(e=!0);var o=this.context;e&&o.clearRect(0,0,this.element.width,this.element.height);for(var r=!1,i=0;i<this.componentsDrawings.length;i++)this.componentsDrawings[i].draw(o,t),r=r||this.componentsDrawings[i].needDraw;r&&(this.requestId&&window.cancelAnimationFrame(this.requestId),this.requestId=window.requestAnimationFrame((function(t){return n.draw(t)})))},t}();p.nodeName="canvas";var u={svg:"http://www.w3.org/2000/svg",xhtml:"http://www.w3.org/1999/xhtml",xlink:"http://www.w3.org/1999/xlink",xml:"http://www.w3.org/XML/1998/namespace",xmlns:"http://www.w3.org/2000/xmlns/"},c=/%COMP%/g,l="_nghost-%COMP%",d="_ngcontent-%COMP%";function h(t){return d.replace(c,t)}function y(t){return l.replace(c,t)}function f(t,e,n){for(var o=0;o<e.length;o++){var r=e[o];Array.isArray(r)?f(t,r,n):(r=r.replace(c,t),n.push(r))}return n}var m=window.ngDevMode,v=void 0===m||!!m;function w(t){return function(e){if("__ngUnwrap__"===e)return t;!1===t(e)&&(e.preventDefault(),e.returnValue=!1)}}var g=function(){function t(t){this.eventManager=t,this.data=Object.create(null)}return t.prototype.destroy=function(){},t.prototype.createElement=function(t,e){return e?document.createElementNS(u[e]||e,t):document.createElement(t)},t.prototype.createComment=function(t){return document.createComment(t)},t.prototype.createText=function(t){return document.createTextNode(t)},t.prototype.appendChild=function(t,e){t.appendChild(e)},t.prototype.insertBefore=function(t,e,n){t&&t.insertBefore(e,n)},t.prototype.removeChild=function(t,e){t&&t.removeChild(e)},t.prototype.selectRootElement=function(t,e){var n="string"==typeof t?document.querySelector(t):t;if(!n)throw new Error('The selector "'+t+'" did not match any elements');return e||(n.textContent=""),n},t.prototype.parentNode=function(t){return t.parentNode},t.prototype.nextSibling=function(t){return t.nextSibling},t.prototype.setAttribute=function(t,e,n,o){if(o){e=o+":"+e;var r=u[o];r?t.setAttributeNS(r,e,n):t.setAttribute(e,n)}else t.setAttribute(e,n)},t.prototype.removeAttribute=function(t,e,n){if(n){var o=u[n];o?t.removeAttributeNS(o,e):t.removeAttribute(n+":"+e)}else t.removeAttribute(e)},t.prototype.addClass=function(t,e){t.classList.add(e)},t.prototype.removeClass=function(t,e){t.classList.remove(e)},t.prototype.setStyle=function(t,n,o,r){r&e.RendererStyleFlags2.DashCase?t.style.setProperty(n,o,r&e.RendererStyleFlags2.Important?"important":""):t.style[n]=o},t.prototype.removeStyle=function(t,n,o){o&e.RendererStyleFlags2.DashCase?t.style.removeProperty(n):t.style[n]=""},t.prototype.setProperty=function(t,e,n){v&&C(e,"property"),t[e]=n},t.prototype.setValue=function(t,e){t.nodeValue=e},t.prototype.listen=function(t,e,n){return v&&C(e,"listener"),"string"==typeof t?this.eventManager.addGlobalEventListener(t,e,w(n)):this.eventManager.addEventListener(t,e,w(n))},t}(),S="@".charCodeAt(0);function C(t,e){if(t.charCodeAt(0)===S)throw new Error("Found the synthetic "+e+" "+t+'. Please include either "BrowserAnimationsModule" or "NoopAnimationsModule" in your application.')}var A=function(t){function e(e,n,o,r){var i=t.call(this,e)||this;i.component=o;var s=f(r+"-"+o.id,o.styles,[]);return n.addStyles(s),i.contentAttr=h(r+"-"+o.id),i.hostAttr=y(r+"-"+o.id),i}return i(e,t),e.prototype.applyToHost=function(e){t.prototype.setAttribute.call(this,e,this.hostAttr,"")},e.prototype.createElement=function(e,n){var o=t.prototype.createElement.call(this,e,n);return t.prototype.setAttribute.call(this,o,this.contentAttr,""),o},e}(g),b=function(t){function n(n,o,r,i){var s=t.call(this,n)||this;s.sharedStylesHost=o,s.hostEl=r,s.component=i,i.encapsulation===e.ViewEncapsulation.ShadowDom?s.shadowRoot=r.attachShadow({mode:"open"}):s.shadowRoot=r.createShadowRoot(),s.sharedStylesHost.addHost(s.shadowRoot);for(var a=f(i.id,i.styles,[]),p=0;p<a.length;p++){var u=document.createElement("style");u.textContent=a[p],s.shadowRoot.appendChild(u)}return s}return i(n,t),n.prototype.nodeOrShadowRoot=function(t){return t===this.hostEl?this.shadowRoot:t},n.prototype.destroy=function(){this.sharedStylesHost.removeHost(this.shadowRoot)},n.prototype.appendChild=function(e,n){return t.prototype.appendChild.call(this,this.nodeOrShadowRoot(e),n)},n.prototype.insertBefore=function(e,n,o){return t.prototype.insertBefore.call(this,this.nodeOrShadowRoot(e),n,o)},n.prototype.removeChild=function(e,n){return t.prototype.removeChild.call(this,this.nodeOrShadowRoot(e),n)},n.prototype.parentNode=function(e){return this.nodeOrShadowRoot(t.prototype.parentNode.call(this,this.nodeOrShadowRoot(e)))},n}(g),R={};function E(){return R.canvasRendererMetadataArgsStorage||(R.canvasRendererMetadataArgsStorage=new M),R.canvasRendererMetadataArgsStorage}var M=function(){this.elements=new Map},x=function(){function t(t,e,n,o){this.eventManager=t,this.sharedStylesHost=e,this.appId=n,this.ngZone=o,this.rendererByCompId=new Map,this.defaultRenderer=new g(t)}return t.prototype.end=function(){},t.prototype.createRenderer=function(t,n){if(!t||!n)return this.defaultRenderer;if(n.type&&n.type.isCanvasComponent)return(o=this.rendererByCompId.get(n.id))||(o=new O(this.eventManager,this.sharedStylesHost,n,this.appId,this.ngZone),this.rendererByCompId.set(n.id,o)),o.applyToHost(t),o;switch(n.encapsulation){case e.ViewEncapsulation.Emulated:var o;return(o=this.rendererByCompId.get(n.id))||(o=new A(this.eventManager,this.sharedStylesHost,n,this.appId),this.rendererByCompId.set(n.id,o)),o.applyToHost(t),o;case e.ViewEncapsulation.Native:case e.ViewEncapsulation.ShadowDom:return new b(this.eventManager,this.sharedStylesHost,t,n);default:if(!this.rendererByCompId.has(n.id)){var r=f(n.id,n.styles,[]);this.sharedStylesHost.addStyles(r),this.rendererByCompId.set(n.id,this.defaultRenderer)}return this.defaultRenderer}},t}();x.decorators=[{type:e.Injectable}],x.ctorParameters=function(){return[{type:o.EventManager},{type:o.ɵDomSharedStylesHost},{type:String},{type:e.NgZone}]};var O=function(){function t(t,e,n,o,r){this.component=n,this.ngZone=r,this.canvasElements=E().elements;var i=f(o+"-"+n.id,n.styles,[]);e.addStyles(i),this.contentAttr=h(o+"-"+n.id),this.hostAttr=y(o+"-"+n.id)}return t.prototype.applyToHost=function(t){this.setAttribute(t,this.hostAttr,"")},t.prototype.createElement=function(t,e){var n=this.canvasElements.get(t);if(n)return new n;if("canvas"===t){var o=new p(this.ngZone);return o.element.setAttribute(this.contentAttr,""),o}var r=void 0;return r=e?document.createElementNS(u[e]||e,t):document.createElement(t),this.setAttribute(r,this.contentAttr,""),r},t.prototype.createText=function(t){return document.createTextNode(t)},t.prototype.selectRootElement=function(t,e){var n="string"==typeof t?document.querySelector(t):t;if(!n)throw new Error('The selector "'+t+'" did not match any elements');return e||(n.textContent=""),n},t.prototype.addClass=function(t,e){t.classList?t.classList.add(e):t.addClass(e)},t.prototype.removeClass=function(t,e){t.classList?t.classList.add(e):t.removeClass(e)},t.prototype.appendChild=function(t,e){e&&(e.parent=t,e instanceof p?t.appendChild(e.element):t.appendChild(e))},t.prototype.removeChild=function(t,e){e.destroy&&e.destroy(),t&&t.removeChild(e)},t.prototype.createComment=function(t){return document.createComment(t)},t.prototype.destroy=function(){},t.prototype.insertBefore=function(t,e,n){t&&t.insertBefore&&(e.parent=t,t.insertBefore(e,n))},t.prototype.listen=function(t,e,n){var o=function(e){return n.call(t,e)};return t.addEventListener(e,o),function(){return t.removeEventListener(e,o)}},t.prototype.nextSibling=function(t){return{previous:t,next:t.nextSibling}},t.prototype.parentNode=function(t){return t.parent?t.parent:t},t.prototype.removeAttribute=function(t,e,n){if(n){var o=u[n];o?t.removeAttributeNS(o,e):t.removeAttribute(n+":"+e)}else t.removeAttribute(e)},t.prototype.removeStyle=function(t,e,n){t.removeStyle(e,n)},t.prototype.setAttribute=function(t,e,n,o){if(o){e=o+":"+e;var r=u[o];r?t.setAttributeNS(r,e,n):t.setAttribute(e,n)}else t.setAttribute(e,n)},t.prototype.setProperty=function(t,e,n){t.setNgProperty(e,n)},t.prototype.setStyle=function(t,n,o,r){t.style?r&e.RendererStyleFlags2.DashCase?t.style.setProperty(n,o,r&e.RendererStyleFlags2.Important?"important":""):t.style[n]=o:t.setStyle(n,o,r)},t.prototype.setValue=function(t,e){t.setValue?t.setValue(e):t.nodeValue=e},t}(),N=function(){function t(){}return t.forRoot=function(e){return{ngModule:t}},t}();N.decorators=[{type:e.NgModule,args:[{imports:[n.CommonModule],providers:[{provide:e.RendererFactory2,useClass:x,deps:[o.EventManager,o.ɵDomSharedStylesHost,e.APP_ID,e.NgZone]}],schemas:[e.NO_ERRORS_SCHEMA]}]}],t.CanvasComponent=function(t){t.isCanvasComponent=!0},t.CanvasDomModule=N,t.CanvasDomRendererFactory=x,t.CanvasElement=function(t){return function(e){E().elements.set(t.selector,e)}},t.CanvasRenderer=O,t.MetadataArgsStorage=M,t.NgCanvas=p,t.getMetadataArgsStorage=E,Object.defineProperty(t,"__esModule",{value:!0})})); | ||
//# sourceMappingURL=angular-canvas.umd.min.js.map |
@@ -239,3 +239,3 @@ import { Injectable, NgZone, RendererStyleFlags2, ViewEncapsulation, } from '@angular/core'; | ||
if (node.setValue) { | ||
node.setValue && node.setValue(value); | ||
node.setValue(value); | ||
} | ||
@@ -247,2 +247,2 @@ else { | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"canvas-dom-renderer.js","sourceRoot":"/Users/irustm/dev/github/angular-canvas/projects/angular-canvas-lib/src/","sources":["lib/canvas-dom-renderer.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Injectable,\n  NgZone,\n  Renderer2,\n  RendererFactory2,\n  RendererStyleFlags2,\n  RendererType2,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { NgCanvasElement } from './components/ng-canvas-element';\nimport { NgCanvas } from './components/ng-canvas';\nimport { EventManager } from '@angular/platform-browser';\nimport { ɵDomSharedStylesHost as DomSharedStylesHost } from '@angular/platform-browser';\nimport {\n  DefaultDomRenderer2,\n  EmulatedEncapsulationDomRenderer2,\n  ShadowDomRenderer,\n} from './default-dom-renderer';\nimport {\n  flattenStyles,\n  NAMESPACE_URIS,\n  shimContentAttribute,\n  shimHostAttribute,\n} from './renderer-utils';\nimport { getMetadataArgsStorage } from './metadata/metadata-storage';\n\n@Injectable()\nexport class CanvasDomRendererFactory implements RendererFactory2 {\n  private rendererByCompId = new Map<string, Renderer2>();\n  private defaultRenderer: Renderer2;\n\n  constructor(\n    private readonly eventManager: EventManager,\n    private readonly sharedStylesHost: DomSharedStylesHost,\n    private readonly appId: string,\n    private readonly ngZone: NgZone\n  ) {\n    this.defaultRenderer = new DefaultDomRenderer2(eventManager);\n  }\n\n  end() {}\n\n  createRenderer(element: any, type: RendererType2 | null): Renderer2 {\n    if (!element || !type) {\n      return this.defaultRenderer;\n    }\n\n    // @ts-ignore\n    if (type['type'] && type['type'].isCanvasComponent) {\n      let renderer = this.rendererByCompId.get(type.id);\n\n      if (!renderer) {\n        renderer = new CanvasRenderer(\n          this.eventManager,\n          this.sharedStylesHost,\n          type,\n          this.appId,\n          this.ngZone\n        );\n        this.rendererByCompId.set(type.id, renderer);\n      }\n      (renderer as CanvasRenderer).applyToHost(element);\n      return renderer;\n    }\n\n    switch (type.encapsulation) {\n      case ViewEncapsulation.Emulated: {\n        let renderer = this.rendererByCompId.get(type.id);\n        if (!renderer) {\n          renderer = new EmulatedEncapsulationDomRenderer2(\n            this.eventManager,\n            this.sharedStylesHost,\n            type,\n            this.appId\n          );\n          this.rendererByCompId.set(type.id, renderer);\n        }\n        (renderer as EmulatedEncapsulationDomRenderer2).applyToHost(element);\n        return renderer;\n      }\n      case ViewEncapsulation.Native:\n      case ViewEncapsulation.ShadowDom:\n        return new ShadowDomRenderer(\n          this.eventManager,\n          this.sharedStylesHost,\n          element,\n          type\n        );\n\n      default: {\n        if (!this.rendererByCompId.has(type.id)) {\n          const styles = flattenStyles(type.id, type.styles, []);\n          this.sharedStylesHost.addStyles(styles);\n          this.rendererByCompId.set(type.id, this.defaultRenderer);\n        }\n        return this.defaultRenderer;\n      }\n    }\n  }\n}\n\nexport class CanvasRenderer implements Renderer2 {\n  private contentAttr: string;\n  private hostAttr: string;\n  private readonly canvasElements = getMetadataArgsStorage().elements;\n\n  readonly data: { [p: string]: any };\n  destroyNode: ((node: any) => void) | null;\n\n  constructor(\n    eventManager: EventManager,\n    sharedStylesHost: DomSharedStylesHost,\n    private component: RendererType2,\n    appId: string,\n    private ngZone: NgZone\n  ) {\n    const styles = flattenStyles(\n      appId + '-' + component.id,\n      component.styles,\n      []\n    );\n    sharedStylesHost.addStyles(styles);\n\n    this.contentAttr = shimContentAttribute(appId + '-' + component.id);\n    this.hostAttr = shimHostAttribute(appId + '-' + component.id);\n  }\n\n  // tslint:disable-next-line:typedef\n  applyToHost(element: any) {\n    this.setAttribute(element, this.hostAttr, '');\n  }\n\n  createElement(name: string, namespace?: string | null): any {\n    const Component = this.canvasElements.get(name);\n\n    if (Component) {\n      return new Component();\n    } else if (name === 'canvas') {\n      const canvas = new NgCanvas(this.ngZone);\n      canvas.element.setAttribute(this.contentAttr, '');\n      return canvas;\n    } else {\n      let element;\n      if (namespace) {\n        // In cases where Ivy (not ViewEngine) is giving us the actual namespace, the look up by key\n        // will result in undefined, so we just return the namespace here.\n        element = document.createElementNS(\n          NAMESPACE_URIS[namespace] || namespace,\n          name\n        );\n      } else {\n        element = document.createElement(name);\n      }\n\n      this.setAttribute(element, this.contentAttr, '');\n      return element;\n    }\n  }\n\n  createText(value: string): any {\n    return document.createTextNode(value);\n  }\n\n  selectRootElement(selectorOrNode: any, preserveContent?: boolean): any {\n    const el: any =\n      typeof selectorOrNode === 'string'\n        ? document.querySelector(selectorOrNode)\n        : selectorOrNode;\n    if (!el) {\n      throw new Error(\n        `The selector \"${selectorOrNode}\" did not match any elements`\n      );\n    }\n    if (!preserveContent) {\n      el.textContent = '';\n    }\n    return el;\n  }\n\n  addClass(el: NgCanvasElement, name: string): void {\n    if (el.classList) {\n      el.classList.add(name);\n    } else {\n      el.addClass(name);\n    }\n  }\n\n  removeClass(el: NgCanvasElement, name: string): void {\n    if (el.classList) {\n      el.classList.add(name);\n    } else {\n      el.removeClass(name);\n    }\n  }\n\n  appendChild(parent: NgCanvasElement, newChild: NgCanvasElement): void {\n    // parent.appendChild(newChild);\n    if (!newChild) {\n      return;\n    }\n    newChild.parent = parent as any;\n\n    if (newChild instanceof NgCanvas) {\n      parent.appendChild((newChild as NgCanvas).element);\n    } else {\n      parent.appendChild(newChild);\n    }\n  }\n\n  removeChild(parent: NgCanvasElement, oldChild): void {\n    // tslint:disable-next-line:no-unused-expression\n    oldChild.destroy && oldChild.destroy();\n    if (parent) {\n      parent.removeChild(oldChild);\n    }\n  }\n\n  createComment(value: string): any {\n    return document.createComment(value);\n  }\n\n  destroy(): void {}\n\n  insertBefore(parent: NgCanvasElement, newChild: any, refChild: any): void {\n    if (parent && parent.insertBefore) {\n      newChild.parent = parent;\n      parent.insertBefore(newChild, refChild);\n    }\n  }\n\n  listen(\n    target: any,\n    eventName: string,\n    callback: (event: any) => boolean | void\n  ): () => void {\n    const callbackFunc = (e: any) => callback.call(target, e);\n\n    target.addEventListener(eventName, callbackFunc);\n\n    return () => target.removeEventListener(eventName, callbackFunc);\n  }\n\n  // tslint:disable-next-line:typedef\n  nextSibling(node: any) {\n    return {\n      previous: node,\n      next: node.nextSibling,\n    };\n  }\n\n  parentNode(node: any): any {\n    return node.parent ? node.parent : node;\n  }\n\n  removeAttribute(\n    el: NgCanvasElement,\n    name: string,\n    namespace?: string | null\n  ): void {\n    if (namespace) {\n      // TODO(FW-811): Ivy may cause issues here because it's passing around\n      // full URIs for namespaces, therefore this lookup will fail.\n      const namespaceUri = NAMESPACE_URIS[namespace];\n      if (namespaceUri) {\n        el.removeAttributeNS(namespaceUri, name);\n      } else {\n        // TODO(FW-811): Since ivy is passing around full URIs for namespaces\n        // this could result in properties like `http://www.w3.org/2000/svg:cx=\"123\"`,\n        // which is wrong.\n        el.removeAttribute(`${namespace}:${name}`);\n      }\n    } else {\n      el.removeAttribute(name);\n    }\n  }\n\n  removeStyle(\n    el: NgCanvasElement,\n    style: string,\n    flags?: RendererStyleFlags2\n  ): void {\n    el.removeStyle(style, flags);\n  }\n\n  setAttribute(\n    el: NgCanvasElement,\n    name: string,\n    value: string,\n    namespace?: string | null\n  ): void {\n    if (namespace) {\n      name = namespace + ':' + name;\n      // TODO(FW-811): Ivy may cause issues here because it's passing around\n      // full URIs for namespaces, therefore this lookup will fail.\n      const namespaceUri = NAMESPACE_URIS[namespace];\n      if (namespaceUri) {\n        el.setAttributeNS(namespaceUri, name, value);\n      } else {\n        el.setAttribute(name, value);\n      }\n    } else {\n      el.setAttribute(name, value);\n    }\n  }\n\n  setProperty(el: NgCanvasElement, name: string, value: any): void {\n    el.setNgProperty(name, value);\n  }\n\n  setStyle(\n    el: NgCanvasElement,\n    style: string,\n    value: any,\n    flags?: RendererStyleFlags2\n  ): void {\n    if (el.style) {\n      // tslint:disable-next-line:no-bitwise\n      if (flags & RendererStyleFlags2.DashCase) {\n        el.style.setProperty(\n          // tslint:disable-next-line:no-bitwise\n          style,\n          value,\n          !!(flags & RendererStyleFlags2.Important) ? 'important' : ''\n        );\n      } else {\n        el.style[style] = value;\n      }\n    } else {\n      el.setStyle(style, value, flags);\n    }\n  }\n\n  setValue(node: any, value: string): void {\n    if (node.setValue) {\n      node.setValue && node.setValue(value);\n    } else {\n      node.nodeValue = value;\n    }\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"canvas-dom-renderer.js","sourceRoot":"/Users/irustm/dev/github/angular-canvas/projects/angular-canvas-lib/src/","sources":["lib/canvas-dom-renderer.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Injectable,\n  NgZone,\n  Renderer2,\n  RendererFactory2,\n  RendererStyleFlags2,\n  RendererType2,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { NgCanvasElement } from './components/ng-canvas-element';\nimport { NgCanvas } from './components/ng-canvas';\nimport { EventManager } from '@angular/platform-browser';\nimport { ɵDomSharedStylesHost as DomSharedStylesHost } from '@angular/platform-browser';\nimport {\n  DefaultDomRenderer2,\n  EmulatedEncapsulationDomRenderer2,\n  ShadowDomRenderer,\n} from './default-dom-renderer';\nimport {\n  flattenStyles,\n  NAMESPACE_URIS,\n  shimContentAttribute,\n  shimHostAttribute,\n} from './renderer-utils';\nimport { getMetadataArgsStorage } from './metadata/metadata-storage';\n\n@Injectable()\nexport class CanvasDomRendererFactory implements RendererFactory2 {\n  private rendererByCompId = new Map<string, Renderer2>();\n  private defaultRenderer: Renderer2;\n\n  constructor(\n    private readonly eventManager: EventManager,\n    private readonly sharedStylesHost: DomSharedStylesHost,\n    private readonly appId: string,\n    private readonly ngZone: NgZone\n  ) {\n    this.defaultRenderer = new DefaultDomRenderer2(eventManager);\n  }\n\n  end() {}\n\n  createRenderer(element: any, type: RendererType2 | null): Renderer2 {\n    if (!element || !type) {\n      return this.defaultRenderer;\n    }\n\n    // @ts-ignore\n    if (type['type'] && type['type'].isCanvasComponent) {\n      let renderer = this.rendererByCompId.get(type.id);\n\n      if (!renderer) {\n        renderer = new CanvasRenderer(\n          this.eventManager,\n          this.sharedStylesHost,\n          type,\n          this.appId,\n          this.ngZone\n        );\n        this.rendererByCompId.set(type.id, renderer);\n      }\n      (renderer as CanvasRenderer).applyToHost(element);\n      return renderer;\n    }\n\n    switch (type.encapsulation) {\n      case ViewEncapsulation.Emulated: {\n        let renderer = this.rendererByCompId.get(type.id);\n        if (!renderer) {\n          renderer = new EmulatedEncapsulationDomRenderer2(\n            this.eventManager,\n            this.sharedStylesHost,\n            type,\n            this.appId\n          );\n          this.rendererByCompId.set(type.id, renderer);\n        }\n        (renderer as EmulatedEncapsulationDomRenderer2).applyToHost(element);\n        return renderer;\n      }\n      case ViewEncapsulation.Native:\n      case ViewEncapsulation.ShadowDom:\n        return new ShadowDomRenderer(\n          this.eventManager,\n          this.sharedStylesHost,\n          element,\n          type\n        );\n\n      default: {\n        if (!this.rendererByCompId.has(type.id)) {\n          const styles = flattenStyles(type.id, type.styles, []);\n          this.sharedStylesHost.addStyles(styles);\n          this.rendererByCompId.set(type.id, this.defaultRenderer);\n        }\n        return this.defaultRenderer;\n      }\n    }\n  }\n}\n\nexport class CanvasRenderer implements Renderer2 {\n  private contentAttr: string;\n  private hostAttr: string;\n  private readonly canvasElements = getMetadataArgsStorage().elements;\n\n  readonly data: { [p: string]: any };\n  destroyNode: ((node: any) => void) | null;\n\n  constructor(\n    eventManager: EventManager,\n    sharedStylesHost: DomSharedStylesHost,\n    private component: RendererType2,\n    appId: string,\n    private ngZone: NgZone\n  ) {\n    const styles = flattenStyles(\n      appId + '-' + component.id,\n      component.styles,\n      []\n    );\n    sharedStylesHost.addStyles(styles);\n\n    this.contentAttr = shimContentAttribute(appId + '-' + component.id);\n    this.hostAttr = shimHostAttribute(appId + '-' + component.id);\n  }\n\n  // tslint:disable-next-line:typedef\n  applyToHost(element: any) {\n    this.setAttribute(element, this.hostAttr, '');\n  }\n\n  createElement(name: string, namespace?: string | null): any {\n    const Component = this.canvasElements.get(name);\n\n    if (Component) {\n      return new Component();\n    } else if (name === 'canvas') {\n      const canvas = new NgCanvas(this.ngZone);\n      canvas.element.setAttribute(this.contentAttr, '');\n      return canvas;\n    } else {\n      let element;\n      if (namespace) {\n        // In cases where Ivy (not ViewEngine) is giving us the actual namespace, the look up by key\n        // will result in undefined, so we just return the namespace here.\n        element = document.createElementNS(\n          NAMESPACE_URIS[namespace] || namespace,\n          name\n        );\n      } else {\n        element = document.createElement(name);\n      }\n\n      this.setAttribute(element, this.contentAttr, '');\n      return element;\n    }\n  }\n\n  createText(value: string): any {\n    return document.createTextNode(value);\n  }\n\n  selectRootElement(selectorOrNode: any, preserveContent?: boolean): any {\n    const el: any =\n      typeof selectorOrNode === 'string'\n        ? document.querySelector(selectorOrNode)\n        : selectorOrNode;\n    if (!el) {\n      throw new Error(\n        `The selector \"${selectorOrNode}\" did not match any elements`\n      );\n    }\n    if (!preserveContent) {\n      el.textContent = '';\n    }\n    return el;\n  }\n\n  addClass(el: NgCanvasElement, name: string): void {\n    if (el.classList) {\n      el.classList.add(name);\n    } else {\n      el.addClass(name);\n    }\n  }\n\n  removeClass(el: NgCanvasElement, name: string): void {\n    if (el.classList) {\n      el.classList.add(name);\n    } else {\n      el.removeClass(name);\n    }\n  }\n\n  appendChild(parent: NgCanvasElement, newChild: NgCanvasElement): void {\n    // parent.appendChild(newChild);\n    if (!newChild) {\n      return;\n    }\n    newChild.parent = parent as any;\n\n    if (newChild instanceof NgCanvas) {\n      parent.appendChild((newChild as NgCanvas).element);\n    } else {\n      parent.appendChild(newChild);\n    }\n  }\n\n  removeChild(parent: NgCanvasElement, oldChild): void {\n    // tslint:disable-next-line:no-unused-expression\n    oldChild.destroy && oldChild.destroy();\n    if (parent) {\n      parent.removeChild(oldChild);\n    }\n  }\n\n  createComment(value: string): any {\n    return document.createComment(value);\n  }\n\n  destroy(): void {}\n\n  insertBefore(parent: NgCanvasElement, newChild: any, refChild: any): void {\n    if (parent && parent.insertBefore) {\n      newChild.parent = parent;\n      parent.insertBefore(newChild, refChild);\n    }\n  }\n\n  listen(\n    target: any,\n    eventName: string,\n    callback: (event: any) => boolean | void\n  ): () => void {\n    const callbackFunc = (e: any) => callback.call(target, e);\n\n    target.addEventListener(eventName, callbackFunc);\n\n    return () => target.removeEventListener(eventName, callbackFunc);\n  }\n\n  // tslint:disable-next-line:typedef\n  nextSibling(node: any) {\n    return {\n      previous: node,\n      next: node.nextSibling,\n    };\n  }\n\n  parentNode(node: any): any {\n    return node.parent ? node.parent : node;\n  }\n\n  removeAttribute(\n    el: NgCanvasElement,\n    name: string,\n    namespace?: string | null\n  ): void {\n    if (namespace) {\n      // TODO(FW-811): Ivy may cause issues here because it's passing around\n      // full URIs for namespaces, therefore this lookup will fail.\n      const namespaceUri = NAMESPACE_URIS[namespace];\n      if (namespaceUri) {\n        el.removeAttributeNS(namespaceUri, name);\n      } else {\n        // TODO(FW-811): Since ivy is passing around full URIs for namespaces\n        // this could result in properties like `http://www.w3.org/2000/svg:cx=\"123\"`,\n        // which is wrong.\n        el.removeAttribute(`${namespace}:${name}`);\n      }\n    } else {\n      el.removeAttribute(name);\n    }\n  }\n\n  removeStyle(\n    el: NgCanvasElement,\n    style: string,\n    flags?: RendererStyleFlags2\n  ): void {\n    el.removeStyle(style, flags);\n  }\n\n  setAttribute(\n    el: NgCanvasElement,\n    name: string,\n    value: string,\n    namespace?: string | null\n  ): void {\n    if (namespace) {\n      name = namespace + ':' + name;\n      // TODO(FW-811): Ivy may cause issues here because it's passing around\n      // full URIs for namespaces, therefore this lookup will fail.\n      const namespaceUri = NAMESPACE_URIS[namespace];\n      if (namespaceUri) {\n        el.setAttributeNS(namespaceUri, name, value);\n      } else {\n        el.setAttribute(name, value);\n      }\n    } else {\n      el.setAttribute(name, value);\n    }\n  }\n\n  setProperty(el: NgCanvasElement, name: string, value: any): void {\n    el.setNgProperty(name, value);\n  }\n\n  setStyle(\n    el: NgCanvasElement,\n    style: string,\n    value: any,\n    flags?: RendererStyleFlags2\n  ): void {\n    if (el.style) {\n      // tslint:disable-next-line:no-bitwise\n      if (flags & RendererStyleFlags2.DashCase) {\n        el.style.setProperty(\n          // tslint:disable-next-line:no-bitwise\n          style,\n          value,\n          !!(flags & RendererStyleFlags2.Important) ? 'important' : ''\n        );\n      } else {\n        el.style[style] = value;\n      }\n    } else {\n      el.setStyle(style, value, flags);\n    }\n  }\n\n  setValue(node: any, value: string): void {\n    if (node.setValue) {\n      node.setValue(value);\n    } else {\n      node.nodeValue = value;\n    }\n  }\n}\n"]} |
@@ -46,3 +46,2 @@ import { RendererStyleFlags2, ViewEncapsulation, } from '@angular/core'; | ||
createText(value) { | ||
console.log(value); | ||
return document.createTextNode(value); | ||
@@ -229,2 +228,2 @@ } | ||
export { ɵ0 }; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"default-dom-renderer.js","sourceRoot":"/Users/irustm/dev/github/angular-canvas/projects/angular-canvas-lib/src/","sources":["lib/default-dom-renderer.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Renderer2,\n  RendererStyleFlags2,\n  RendererType2,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {\n  EventManager,\n  ɵDomSharedStylesHost as DomSharedStylesHost,\n} from '@angular/platform-browser';\nimport {\n  flattenStyles,\n  NAMESPACE_URIS,\n  shimContentAttribute,\n  shimHostAttribute,\n} from './renderer-utils';\n\nconst ngDevMode = (window as any).ngDevMode;\nconst NG_DEV_MODE: boolean = typeof ngDevMode === 'undefined' || !!ngDevMode;\n\n// tslint:disable-next-line:typedef\nfunction decoratePreventDefault(eventHandler) {\n  // `DebugNode.triggerEventHandler` needs to know if the listener was created with\n  // decoratePreventDefault or is a listener added outside the Angular context so it can handle the\n  // two differently. In the first case, the special '__ngUnwrap__' token is passed to the unwrap\n  // the listener (see below).\n  return (event: any) => {\n    // Ivy uses '__ngUnwrap__' as a special token that allows us to unwrap the function\n    // so that it can be invoked programmatically by `DebugNode.triggerEventHandler`. The debug_node\n    // can inspect the listener toString contents for the existence of this special token. Because\n    // the token is a string literal, it is ensured to not be modified by compiled code.\n    if (event === '__ngUnwrap__') {\n      return eventHandler;\n    }\n\n    const allowDefaultBehavior = eventHandler(event);\n    if (allowDefaultBehavior === false) {\n      // TODO(tbosch): move preventDefault into event plugins...\n      event.preventDefault();\n      event.returnValue = false;\n    }\n\n    return undefined;\n  };\n}\n\nexport class DefaultDomRenderer2 implements Renderer2 {\n  constructor(private eventManager: EventManager) {}\n\n  data: { [key: string]: any } = Object.create(null);\n\n  destroyNode: null;\n\n  destroy(): void {}\n\n  createElement(name: string, namespace?: string): any {\n    if (namespace) {\n      // In cases where Ivy (not ViewEngine) is giving us the actual namespace, the look up by key\n      // will result in undefined, so we just return the namespace here.\n      return document.createElementNS(\n        NAMESPACE_URIS[namespace] || namespace,\n        name\n      );\n    }\n\n    return document.createElement(name);\n  }\n\n  createComment(value: string): any {\n    return document.createComment(value);\n  }\n\n  createText(value: string): any {\n    console.log(value);\n    return document.createTextNode(value);\n  }\n\n  appendChild(parent: any, newChild: any): void {\n    parent.appendChild(newChild);\n  }\n\n  insertBefore(parent: any, newChild: any, refChild: any): void {\n    if (parent) {\n      parent.insertBefore(newChild, refChild);\n    }\n  }\n\n  removeChild(parent: any, oldChild: any): void {\n    if (parent) {\n      parent.removeChild(oldChild);\n    }\n  }\n\n  selectRootElement(\n    selectorOrNode: string | any,\n    preserveContent?: boolean\n  ): any {\n    let el: any =\n      typeof selectorOrNode === 'string'\n        ? document.querySelector(selectorOrNode)\n        : selectorOrNode;\n    if (!el) {\n      throw new Error(\n        `The selector \"${selectorOrNode}\" did not match any elements`\n      );\n    }\n    if (!preserveContent) {\n      el.textContent = '';\n    }\n    return el;\n  }\n\n  parentNode(node: any): any {\n    return node.parentNode;\n  }\n\n  nextSibling(node: any): any {\n    return node.nextSibling;\n  }\n\n  setAttribute(el: any, name: string, value: string, namespace?: string): void {\n    if (namespace) {\n      name = namespace + ':' + name;\n      // TODO(FW-811): Ivy may cause issues here because it's passing around\n      // full URIs for namespaces, therefore this lookup will fail.\n      const namespaceUri = NAMESPACE_URIS[namespace];\n      if (namespaceUri) {\n        el.setAttributeNS(namespaceUri, name, value);\n      } else {\n        el.setAttribute(name, value);\n      }\n    } else {\n      el.setAttribute(name, value);\n    }\n  }\n\n  removeAttribute(el: any, name: string, namespace?: string): void {\n    if (namespace) {\n      // TODO(FW-811): Ivy may cause issues here because it's passing around\n      // full URIs for namespaces, therefore this lookup will fail.\n      const namespaceUri = NAMESPACE_URIS[namespace];\n      if (namespaceUri) {\n        el.removeAttributeNS(namespaceUri, name);\n      } else {\n        // TODO(FW-811): Since ivy is passing around full URIs for namespaces\n        // this could result in properties like `http://www.w3.org/2000/svg:cx=\"123\"`,\n        // which is wrong.\n        el.removeAttribute(`${namespace}:${name}`);\n      }\n    } else {\n      el.removeAttribute(name);\n    }\n  }\n\n  addClass(el: any, name: string): void {\n    el.classList.add(name);\n  }\n\n  removeClass(el: any, name: string): void {\n    el.classList.remove(name);\n  }\n\n  setStyle(\n    el: any,\n    style: string,\n    value: any,\n    flags: RendererStyleFlags2\n  ): void {\n    // tslint:disable-next-line:no-bitwise\n    if (flags & RendererStyleFlags2.DashCase) {\n      el.style.setProperty(\n        // tslint:disable-next-line:no-bitwise\n        style,\n        value,\n        !!(flags & RendererStyleFlags2.Important) ? 'important' : ''\n      );\n    } else {\n      el.style[style] = value;\n    }\n  }\n\n  removeStyle(el: any, style: string, flags: RendererStyleFlags2): void {\n    // tslint:disable-next-line:no-bitwise\n    if (flags & RendererStyleFlags2.DashCase) {\n      el.style.removeProperty(style);\n    } else {\n      // IE requires '' instead of null\n      // see https://github.com/angular/angular/issues/7916\n      el.style[style] = '';\n    }\n  }\n\n  setProperty(el: any, name: string, value: any): void {\n    // tslint:disable-next-line:no-unused-expression\n    NG_DEV_MODE && checkNoSyntheticProp(name, 'property');\n    el[name] = value;\n  }\n\n  setValue(node: any, value: string): void {\n    node.nodeValue = value;\n  }\n\n  listen(\n    target: 'window' | 'document' | 'body' | any,\n    event: string,\n    callback: (event: any) => boolean\n  ): () => void {\n    // tslint:disable-next-line:no-unused-expression\n    NG_DEV_MODE && checkNoSyntheticProp(event, 'listener');\n    if (typeof target === 'string') {\n      return <() => void>(\n        this.eventManager.addGlobalEventListener(\n          target,\n          event,\n          decoratePreventDefault(callback)\n        )\n      );\n    }\n    return (<() => void>(\n      this.eventManager.addEventListener(\n        target,\n        event,\n        decoratePreventDefault(callback)\n      )\n    )) as () => void;\n  }\n}\n\nconst AT_CHARCODE = (() => '@'.charCodeAt(0))();\n\n// tslint:disable-next-line:typedef\nfunction checkNoSyntheticProp(name: string, nameKind: string) {\n  if (name.charCodeAt(0) === AT_CHARCODE) {\n    throw new Error(\n      `Found the synthetic ${nameKind} ${name}. Please include either \"BrowserAnimationsModule\" or \"NoopAnimationsModule\" in your application.`\n    );\n  }\n}\n\nexport class EmulatedEncapsulationDomRenderer2 extends DefaultDomRenderer2 {\n  private contentAttr: string;\n  private hostAttr: string;\n\n  constructor(\n    eventManager: EventManager,\n    sharedStylesHost: DomSharedStylesHost,\n    private component: RendererType2,\n    appId: string\n  ) {\n    super(eventManager);\n    const styles = flattenStyles(\n      appId + '-' + component.id,\n      component.styles,\n      []\n    );\n    sharedStylesHost.addStyles(styles);\n\n    this.contentAttr = shimContentAttribute(appId + '-' + component.id);\n    this.hostAttr = shimHostAttribute(appId + '-' + component.id);\n  }\n\n  // tslint:disable-next-line:typedef\n  applyToHost(element: any) {\n    super.setAttribute(element, this.hostAttr, '');\n  }\n\n  createElement(parent: any, name: string): Element {\n    const el = super.createElement(parent, name);\n    super.setAttribute(el, this.contentAttr, '');\n    return el;\n  }\n}\n\nexport class ShadowDomRenderer extends DefaultDomRenderer2 {\n  private shadowRoot: any;\n\n  constructor(\n    eventManager: EventManager,\n    private sharedStylesHost: DomSharedStylesHost,\n    private hostEl: any,\n    private component: RendererType2\n  ) {\n    super(eventManager);\n    if (component.encapsulation === ViewEncapsulation.ShadowDom) {\n      this.shadowRoot = (hostEl as any).attachShadow({ mode: 'open' });\n    } else {\n      this.shadowRoot = (hostEl as any).createShadowRoot();\n    }\n    this.sharedStylesHost.addHost(this.shadowRoot);\n    const styles = flattenStyles(component.id, component.styles, []);\n    for (let i = 0; i < styles.length; i++) {\n      const styleEl = document.createElement('style');\n      styleEl.textContent = styles[i];\n      this.shadowRoot.appendChild(styleEl);\n    }\n  }\n\n  private nodeOrShadowRoot(node: any): any {\n    return node === this.hostEl ? this.shadowRoot : node;\n  }\n\n  destroy() {\n    this.sharedStylesHost.removeHost(this.shadowRoot);\n  }\n\n  appendChild(parent: any, newChild: any): void {\n    return super.appendChild(this.nodeOrShadowRoot(parent), newChild);\n  }\n\n  insertBefore(parent: any, newChild: any, refChild: any): void {\n    return super.insertBefore(\n      this.nodeOrShadowRoot(parent),\n      newChild,\n      refChild\n    );\n  }\n\n  removeChild(parent: any, oldChild: any): void {\n    return super.removeChild(this.nodeOrShadowRoot(parent), oldChild);\n  }\n\n  parentNode(node: any): any {\n    return this.nodeOrShadowRoot(super.parentNode(this.nodeOrShadowRoot(node)));\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"default-dom-renderer.js","sourceRoot":"/Users/irustm/dev/github/angular-canvas/projects/angular-canvas-lib/src/","sources":["lib/default-dom-renderer.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Renderer2,\n  RendererStyleFlags2,\n  RendererType2,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {\n  EventManager,\n  ɵDomSharedStylesHost as DomSharedStylesHost,\n} from '@angular/platform-browser';\nimport {\n  flattenStyles,\n  NAMESPACE_URIS,\n  shimContentAttribute,\n  shimHostAttribute,\n} from './renderer-utils';\n\nconst ngDevMode = (window as any).ngDevMode;\nconst NG_DEV_MODE: boolean = typeof ngDevMode === 'undefined' || !!ngDevMode;\n\n// tslint:disable-next-line:typedef\nfunction decoratePreventDefault(eventHandler) {\n  // `DebugNode.triggerEventHandler` needs to know if the listener was created with\n  // decoratePreventDefault or is a listener added outside the Angular context so it can handle the\n  // two differently. In the first case, the special '__ngUnwrap__' token is passed to the unwrap\n  // the listener (see below).\n  return (event: any) => {\n    // Ivy uses '__ngUnwrap__' as a special token that allows us to unwrap the function\n    // so that it can be invoked programmatically by `DebugNode.triggerEventHandler`. The debug_node\n    // can inspect the listener toString contents for the existence of this special token. Because\n    // the token is a string literal, it is ensured to not be modified by compiled code.\n    if (event === '__ngUnwrap__') {\n      return eventHandler;\n    }\n\n    const allowDefaultBehavior = eventHandler(event);\n    if (allowDefaultBehavior === false) {\n      // TODO(tbosch): move preventDefault into event plugins...\n      event.preventDefault();\n      event.returnValue = false;\n    }\n\n    return undefined;\n  };\n}\n\nexport class DefaultDomRenderer2 implements Renderer2 {\n  constructor(private eventManager: EventManager) {}\n\n  data: { [key: string]: any } = Object.create(null);\n\n  destroyNode: null;\n\n  destroy(): void {}\n\n  createElement(name: string, namespace?: string): any {\n    if (namespace) {\n      // In cases where Ivy (not ViewEngine) is giving us the actual namespace, the look up by key\n      // will result in undefined, so we just return the namespace here.\n      return document.createElementNS(\n        NAMESPACE_URIS[namespace] || namespace,\n        name\n      );\n    }\n\n    return document.createElement(name);\n  }\n\n  createComment(value: string): any {\n    return document.createComment(value);\n  }\n\n  createText(value: string): any {\n    return document.createTextNode(value);\n  }\n\n  appendChild(parent: any, newChild: any): void {\n    parent.appendChild(newChild);\n  }\n\n  insertBefore(parent: any, newChild: any, refChild: any): void {\n    if (parent) {\n      parent.insertBefore(newChild, refChild);\n    }\n  }\n\n  removeChild(parent: any, oldChild: any): void {\n    if (parent) {\n      parent.removeChild(oldChild);\n    }\n  }\n\n  selectRootElement(\n    selectorOrNode: string | any,\n    preserveContent?: boolean\n  ): any {\n    let el: any =\n      typeof selectorOrNode === 'string'\n        ? document.querySelector(selectorOrNode)\n        : selectorOrNode;\n    if (!el) {\n      throw new Error(\n        `The selector \"${selectorOrNode}\" did not match any elements`\n      );\n    }\n    if (!preserveContent) {\n      el.textContent = '';\n    }\n    return el;\n  }\n\n  parentNode(node: any): any {\n    return node.parentNode;\n  }\n\n  nextSibling(node: any): any {\n    return node.nextSibling;\n  }\n\n  setAttribute(el: any, name: string, value: string, namespace?: string): void {\n    if (namespace) {\n      name = namespace + ':' + name;\n      // TODO(FW-811): Ivy may cause issues here because it's passing around\n      // full URIs for namespaces, therefore this lookup will fail.\n      const namespaceUri = NAMESPACE_URIS[namespace];\n      if (namespaceUri) {\n        el.setAttributeNS(namespaceUri, name, value);\n      } else {\n        el.setAttribute(name, value);\n      }\n    } else {\n      el.setAttribute(name, value);\n    }\n  }\n\n  removeAttribute(el: any, name: string, namespace?: string): void {\n    if (namespace) {\n      // TODO(FW-811): Ivy may cause issues here because it's passing around\n      // full URIs for namespaces, therefore this lookup will fail.\n      const namespaceUri = NAMESPACE_URIS[namespace];\n      if (namespaceUri) {\n        el.removeAttributeNS(namespaceUri, name);\n      } else {\n        // TODO(FW-811): Since ivy is passing around full URIs for namespaces\n        // this could result in properties like `http://www.w3.org/2000/svg:cx=\"123\"`,\n        // which is wrong.\n        el.removeAttribute(`${namespace}:${name}`);\n      }\n    } else {\n      el.removeAttribute(name);\n    }\n  }\n\n  addClass(el: any, name: string): void {\n    el.classList.add(name);\n  }\n\n  removeClass(el: any, name: string): void {\n    el.classList.remove(name);\n  }\n\n  setStyle(\n    el: any,\n    style: string,\n    value: any,\n    flags: RendererStyleFlags2\n  ): void {\n    // tslint:disable-next-line:no-bitwise\n    if (flags & RendererStyleFlags2.DashCase) {\n      el.style.setProperty(\n        // tslint:disable-next-line:no-bitwise\n        style,\n        value,\n        !!(flags & RendererStyleFlags2.Important) ? 'important' : ''\n      );\n    } else {\n      el.style[style] = value;\n    }\n  }\n\n  removeStyle(el: any, style: string, flags: RendererStyleFlags2): void {\n    // tslint:disable-next-line:no-bitwise\n    if (flags & RendererStyleFlags2.DashCase) {\n      el.style.removeProperty(style);\n    } else {\n      // IE requires '' instead of null\n      // see https://github.com/angular/angular/issues/7916\n      el.style[style] = '';\n    }\n  }\n\n  setProperty(el: any, name: string, value: any): void {\n    // tslint:disable-next-line:no-unused-expression\n    NG_DEV_MODE && checkNoSyntheticProp(name, 'property');\n    el[name] = value;\n  }\n\n  setValue(node: any, value: string): void {\n    node.nodeValue = value;\n  }\n\n  listen(\n    target: 'window' | 'document' | 'body' | any,\n    event: string,\n    callback: (event: any) => boolean\n  ): () => void {\n    // tslint:disable-next-line:no-unused-expression\n    NG_DEV_MODE && checkNoSyntheticProp(event, 'listener');\n    if (typeof target === 'string') {\n      return <() => void>(\n        this.eventManager.addGlobalEventListener(\n          target,\n          event,\n          decoratePreventDefault(callback)\n        )\n      );\n    }\n    return (<() => void>(\n      this.eventManager.addEventListener(\n        target,\n        event,\n        decoratePreventDefault(callback)\n      )\n    )) as () => void;\n  }\n}\n\nconst AT_CHARCODE = (() => '@'.charCodeAt(0))();\n\n// tslint:disable-next-line:typedef\nfunction checkNoSyntheticProp(name: string, nameKind: string) {\n  if (name.charCodeAt(0) === AT_CHARCODE) {\n    throw new Error(\n      `Found the synthetic ${nameKind} ${name}. Please include either \"BrowserAnimationsModule\" or \"NoopAnimationsModule\" in your application.`\n    );\n  }\n}\n\nexport class EmulatedEncapsulationDomRenderer2 extends DefaultDomRenderer2 {\n  private contentAttr: string;\n  private hostAttr: string;\n\n  constructor(\n    eventManager: EventManager,\n    sharedStylesHost: DomSharedStylesHost,\n    private component: RendererType2,\n    appId: string\n  ) {\n    super(eventManager);\n    const styles = flattenStyles(\n      appId + '-' + component.id,\n      component.styles,\n      []\n    );\n    sharedStylesHost.addStyles(styles);\n\n    this.contentAttr = shimContentAttribute(appId + '-' + component.id);\n    this.hostAttr = shimHostAttribute(appId + '-' + component.id);\n  }\n\n  // tslint:disable-next-line:typedef\n  applyToHost(element: any) {\n    super.setAttribute(element, this.hostAttr, '');\n  }\n\n  createElement(parent: any, name: string): Element {\n    const el = super.createElement(parent, name);\n    super.setAttribute(el, this.contentAttr, '');\n    return el;\n  }\n}\n\nexport class ShadowDomRenderer extends DefaultDomRenderer2 {\n  private shadowRoot: any;\n\n  constructor(\n    eventManager: EventManager,\n    private sharedStylesHost: DomSharedStylesHost,\n    private hostEl: any,\n    private component: RendererType2\n  ) {\n    super(eventManager);\n    if (component.encapsulation === ViewEncapsulation.ShadowDom) {\n      this.shadowRoot = (hostEl as any).attachShadow({ mode: 'open' });\n    } else {\n      this.shadowRoot = (hostEl as any).createShadowRoot();\n    }\n    this.sharedStylesHost.addHost(this.shadowRoot);\n    const styles = flattenStyles(component.id, component.styles, []);\n    for (let i = 0; i < styles.length; i++) {\n      const styleEl = document.createElement('style');\n      styleEl.textContent = styles[i];\n      this.shadowRoot.appendChild(styleEl);\n    }\n  }\n\n  private nodeOrShadowRoot(node: any): any {\n    return node === this.hostEl ? this.shadowRoot : node;\n  }\n\n  destroy() {\n    this.sharedStylesHost.removeHost(this.shadowRoot);\n  }\n\n  appendChild(parent: any, newChild: any): void {\n    return super.appendChild(this.nodeOrShadowRoot(parent), newChild);\n  }\n\n  insertBefore(parent: any, newChild: any, refChild: any): void {\n    return super.insertBefore(\n      this.nodeOrShadowRoot(parent),\n      newChild,\n      refChild\n    );\n  }\n\n  removeChild(parent: any, oldChild: any): void {\n    return super.removeChild(this.nodeOrShadowRoot(parent), oldChild);\n  }\n\n  parentNode(node: any): any {\n    return this.nodeOrShadowRoot(super.parentNode(this.nodeOrShadowRoot(node)));\n  }\n}\n"]} |
@@ -157,3 +157,2 @@ import { RendererStyleFlags2, ViewEncapsulation, Injectable, NgZone, NgModule, RendererFactory2, APP_ID, NO_ERRORS_SCHEMA } from '@angular/core'; | ||
createText(value) { | ||
console.log(value); | ||
return document.createTextNode(value); | ||
@@ -584,3 +583,3 @@ } | ||
if (node.setValue) { | ||
node.setValue && node.setValue(value); | ||
node.setValue(value); | ||
} | ||
@@ -587,0 +586,0 @@ else { |
{ | ||
"name": "angular-canvas", | ||
"version": "0.0.6", | ||
"version": "0.0.7", | ||
"description": "Angular canvas renderer", | ||
@@ -5,0 +5,0 @@ "repository": { |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
350557
2469