@nativescript/canvas-polyfill 2.0.0-beta.9 → 2.0.0-rc.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (202) hide show
  1. package/DOM/CharacterData.d.ts +5 -2
  2. package/DOM/CharacterData.js +9 -2
  3. package/DOM/CharacterData.js.map +1 -1
  4. package/DOM/DOMPointReadOnly.d.ts +27 -0
  5. package/DOM/DOMPointReadOnly.js +43 -0
  6. package/DOM/DOMPointReadOnly.js.map +1 -0
  7. package/DOM/Document.d.ts +26 -11
  8. package/DOM/Document.js +249 -41
  9. package/DOM/Document.js.map +1 -1
  10. package/DOM/Element.d.ts +58 -21
  11. package/DOM/Element.js +414 -19
  12. package/DOM/Element.js.map +1 -1
  13. package/DOM/EventTarget.d.ts +7 -0
  14. package/DOM/EventTarget.js +54 -0
  15. package/DOM/EventTarget.js.map +1 -0
  16. package/DOM/HTMLCanvasElement.d.ts +23 -12
  17. package/DOM/HTMLCanvasElement.js +54 -27
  18. package/DOM/HTMLCanvasElement.js.map +1 -1
  19. package/DOM/HTMLCollection.d.ts +4 -0
  20. package/DOM/HTMLCollection.js +10 -0
  21. package/DOM/HTMLCollection.js.map +1 -0
  22. package/DOM/HTMLDivElement.d.ts +6 -0
  23. package/DOM/HTMLDivElement.js +27 -0
  24. package/DOM/HTMLDivElement.js.map +1 -0
  25. package/DOM/HTMLElement.d.ts +26 -0
  26. package/DOM/HTMLElement.js +57 -0
  27. package/DOM/HTMLElement.js.map +1 -0
  28. package/DOM/HTMLImageElement.d.ts +18 -5
  29. package/DOM/HTMLImageElement.js +248 -73
  30. package/DOM/HTMLImageElement.js.map +1 -1
  31. package/DOM/HTMLUnknownElement.d.ts +4 -0
  32. package/DOM/HTMLUnknownElement.js +7 -0
  33. package/DOM/HTMLUnknownElement.js.map +1 -0
  34. package/DOM/HTMLVideoElement.d.ts +3 -4
  35. package/DOM/HTMLVideoElement.js +15 -7
  36. package/DOM/HTMLVideoElement.js.map +1 -1
  37. package/DOM/Node.d.ts +20 -28
  38. package/DOM/Node.js +39 -123
  39. package/DOM/Node.js.map +1 -1
  40. package/DOM/Text.d.ts +2 -0
  41. package/DOM/Text.js +2 -0
  42. package/DOM/Text.js.map +1 -1
  43. package/DOM/XMLDocument.d.ts +6 -10
  44. package/DOM/XMLDocument.js +23 -23
  45. package/DOM/XMLDocument.js.map +1 -1
  46. package/DOM/svg/SVGAnimatedEnumeration.d.ts +4 -0
  47. package/DOM/svg/SVGAnimatedEnumeration.js +7 -0
  48. package/DOM/svg/SVGAnimatedEnumeration.js.map +1 -0
  49. package/DOM/svg/SVGAnimatedLength.d.ts +42 -0
  50. package/DOM/svg/SVGAnimatedLength.js +360 -0
  51. package/DOM/svg/SVGAnimatedLength.js.map +1 -0
  52. package/DOM/svg/SVGAnimatedNumber.d.ts +9 -0
  53. package/DOM/svg/SVGAnimatedNumber.js +49 -0
  54. package/DOM/svg/SVGAnimatedNumber.js.map +1 -0
  55. package/DOM/svg/SVGAnimatedPreserveAspectRatio.d.ts +34 -0
  56. package/DOM/svg/SVGAnimatedPreserveAspectRatio.js +69 -0
  57. package/DOM/svg/SVGAnimatedPreserveAspectRatio.js.map +1 -0
  58. package/DOM/svg/SVGAnimatedRect.d.ts +10 -0
  59. package/DOM/svg/SVGAnimatedRect.js +39 -0
  60. package/DOM/svg/SVGAnimatedRect.js.map +1 -0
  61. package/DOM/svg/SVGAnimatedString.d.ts +9 -0
  62. package/DOM/svg/SVGAnimatedString.js +21 -0
  63. package/DOM/svg/SVGAnimatedString.js.map +1 -0
  64. package/DOM/svg/SVGAnimatedTransformList.d.ts +10 -0
  65. package/DOM/svg/SVGAnimatedTransformList.js +16 -0
  66. package/DOM/svg/SVGAnimatedTransformList.js.map +1 -0
  67. package/DOM/svg/SVGCircleElement.d.ts +9 -11
  68. package/DOM/svg/SVGCircleElement.js +14 -31
  69. package/DOM/svg/SVGCircleElement.js.map +1 -1
  70. package/DOM/svg/SVGElement.d.ts +12 -12
  71. package/DOM/svg/SVGElement.js +58 -43
  72. package/DOM/svg/SVGElement.js.map +1 -1
  73. package/DOM/svg/SVGEllipseElement.d.ts +13 -0
  74. package/DOM/svg/SVGEllipseElement.js +26 -0
  75. package/DOM/svg/SVGEllipseElement.js.map +1 -0
  76. package/DOM/svg/SVGGGElement.d.ts +2 -11
  77. package/DOM/svg/SVGGGElement.js +4 -34
  78. package/DOM/svg/SVGGGElement.js.map +1 -1
  79. package/DOM/svg/SVGGeometryElement.d.ts +3 -0
  80. package/DOM/svg/SVGGeometryElement.js +4 -0
  81. package/DOM/svg/SVGGeometryElement.js.map +1 -0
  82. package/DOM/svg/SVGGradientElement.d.ts +7 -0
  83. package/DOM/svg/SVGGradientElement.js +12 -0
  84. package/DOM/svg/SVGGradientElement.js.map +1 -0
  85. package/DOM/svg/SVGGraphicsElement.d.ts +6 -0
  86. package/DOM/svg/SVGGraphicsElement.js +12 -0
  87. package/DOM/svg/SVGGraphicsElement.js.map +1 -0
  88. package/DOM/svg/SVGImageElement.d.ts +17 -0
  89. package/DOM/svg/SVGImageElement.js +42 -0
  90. package/DOM/svg/SVGImageElement.js.map +1 -0
  91. package/DOM/svg/SVGLineElement.d.ts +13 -0
  92. package/DOM/svg/SVGLineElement.js +26 -0
  93. package/DOM/svg/SVGLineElement.js.map +1 -0
  94. package/DOM/svg/SVGLinearGradientElement.d.ts +13 -0
  95. package/DOM/svg/SVGLinearGradientElement.js +26 -0
  96. package/DOM/svg/SVGLinearGradientElement.js.map +1 -0
  97. package/DOM/svg/SVGMarkerElement.d.ts +17 -0
  98. package/DOM/svg/SVGMarkerElement.js +31 -0
  99. package/DOM/svg/SVGMarkerElement.js.map +1 -0
  100. package/DOM/svg/SVGMaskElement.d.ts +4 -0
  101. package/DOM/svg/SVGMaskElement.js +8 -0
  102. package/DOM/svg/SVGMaskElement.js.map +1 -0
  103. package/DOM/svg/SVGMatrix.d.ts +23 -0
  104. package/DOM/svg/SVGMatrix.js +76 -0
  105. package/DOM/svg/SVGMatrix.js.map +1 -0
  106. package/DOM/svg/SVGPathElement.d.ts +2 -11
  107. package/DOM/svg/SVGPathElement.js +4 -34
  108. package/DOM/svg/SVGPathElement.js.map +1 -1
  109. package/DOM/svg/SVGPolygonElement.d.ts +9 -0
  110. package/DOM/svg/SVGPolygonElement.js +23 -0
  111. package/DOM/svg/SVGPolygonElement.js.map +1 -0
  112. package/DOM/svg/SVGPolylineElement.d.ts +9 -0
  113. package/DOM/svg/SVGPolylineElement.js +23 -0
  114. package/DOM/svg/SVGPolylineElement.js.map +1 -0
  115. package/DOM/svg/SVGRadialGradientElement.d.ts +17 -0
  116. package/DOM/svg/SVGRadialGradientElement.js +34 -0
  117. package/DOM/svg/SVGRadialGradientElement.js.map +1 -0
  118. package/DOM/svg/SVGRectElement.d.ts +15 -11
  119. package/DOM/svg/SVGRectElement.js +22 -27
  120. package/DOM/svg/SVGRectElement.js.map +1 -1
  121. package/DOM/svg/SVGSVGElement.d.ts +29 -0
  122. package/DOM/svg/SVGSVGElement.js +76 -0
  123. package/DOM/svg/SVGSVGElement.js.map +1 -0
  124. package/DOM/svg/SVGStopElement.d.ts +7 -0
  125. package/DOM/svg/SVGStopElement.js +14 -0
  126. package/DOM/svg/SVGStopElement.js.map +1 -0
  127. package/DOM/svg/SVGTextContentElement.d.ts +3 -0
  128. package/DOM/svg/SVGTextContentElement.js +4 -0
  129. package/DOM/svg/SVGTextContentElement.js.map +1 -0
  130. package/DOM/svg/SVGTextElement.d.ts +4 -0
  131. package/DOM/svg/SVGTextElement.js +9 -0
  132. package/DOM/svg/SVGTextElement.js.map +1 -0
  133. package/DOM/svg/SVGTextPositioningElement.d.ts +3 -0
  134. package/DOM/svg/SVGTextPositioningElement.js +4 -0
  135. package/DOM/svg/SVGTextPositioningElement.js.map +1 -0
  136. package/DOM/svg/SVGTransform.d.ts +33 -0
  137. package/DOM/svg/SVGTransform.js +97 -0
  138. package/DOM/svg/SVGTransform.js.map +1 -0
  139. package/DOM/svg/SVGUnits.d.ts +52 -0
  140. package/DOM/svg/SVGUnits.js +154 -0
  141. package/DOM/svg/SVGUnits.js.map +1 -0
  142. package/DOM/svg/SVGUseElement.d.ts +16 -0
  143. package/DOM/svg/SVGUseElement.js +35 -0
  144. package/DOM/svg/SVGUseElement.js.map +1 -0
  145. package/DOM/svg/index.d.ts +25 -2
  146. package/DOM/svg/index.js +25 -2
  147. package/DOM/svg/index.js.map +1 -1
  148. package/MutationObserver.d.ts +0 -1
  149. package/MutationObserver.js.map +1 -1
  150. package/async/file/file.android.d.ts +1 -1
  151. package/async/file/file.android.js +9 -7
  152. package/async/file/file.android.js.map +1 -1
  153. package/async/file/file.ios.d.ts +1 -1
  154. package/async/file/file.ios.js +9 -10
  155. package/async/file/file.ios.js.map +1 -1
  156. package/async/http/http-request-common.d.ts +1 -1
  157. package/async/http/http-request-common.js.map +1 -1
  158. package/async/http/http.android.d.ts +1 -1
  159. package/async/http/http.android.js +58 -55
  160. package/async/http/http.android.js.map +1 -1
  161. package/async/http/http.ios.d.ts +1 -1
  162. package/async/http/http.ios.js +41 -60
  163. package/async/http/http.ios.js.map +1 -1
  164. package/async/xhr/TNSXMLHttpRequest.d.ts +2 -2
  165. package/async/xhr/TNSXMLHttpRequest.js +93 -90
  166. package/async/xhr/TNSXMLHttpRequest.js.map +1 -1
  167. package/index.d.ts +2 -0
  168. package/index.js +22 -16
  169. package/index.js.map +1 -1
  170. package/localStorage.js +0 -2
  171. package/localStorage.js.map +1 -1
  172. package/navigator.d.ts +12 -0
  173. package/navigator.js +19 -0
  174. package/navigator.js.map +1 -0
  175. package/package.json +7 -5
  176. package/performance.js.map +1 -1
  177. package/platforms/android/async-release.aar +0 -0
  178. package/platforms/android/canvas_polyfill.aar +0 -0
  179. package/platforms/android/include.gradle +5 -6
  180. package/process.js +1 -0
  181. package/process.js.map +1 -1
  182. package/resize.js.map +1 -1
  183. package/url-search.js +0 -1
  184. package/url-search.js.map +1 -1
  185. package/urlBlobPatch.d.ts +1 -0
  186. package/urlBlobPatch.js +123 -0
  187. package/urlBlobPatch.js.map +1 -0
  188. package/utils.d.ts +1 -0
  189. package/utils.js +339 -0
  190. package/utils.js.map +1 -0
  191. package/window.d.ts +4 -4
  192. package/window.js +101 -18
  193. package/window.js.map +1 -1
  194. package/workerPatch.d.ts +3 -0
  195. package/workerPatch.js +13 -0
  196. package/workerPatch.js.map +1 -0
  197. package/URL.android.d.ts +0 -46
  198. package/URL.android.js +0 -432
  199. package/URL.android.js.map +0 -1
  200. package/URL.ios.d.ts +0 -51
  201. package/URL.ios.js +0 -649
  202. package/URL.ios.js.map +0 -1
@@ -1,51 +1,78 @@
1
1
  import { Canvas } from '@nativescript/canvas';
2
- import { Element } from './Element';
3
- export class HTMLCanvasElement extends Element {
4
- constructor() {
2
+ import { HTMLElement } from './HTMLElement';
3
+ import setValue from 'set-value';
4
+ import { DOMParser } from '@xmldom/xmldom';
5
+ export class HTMLCanvasElement extends HTMLElement {
6
+ constructor(canvas) {
5
7
  super('canvas');
6
- let canvas = undefined;
7
- if (arguments.length > 1) {
8
- canvas = arguments[1];
8
+ this._htmlCanvas = true;
9
+ if (arguments.length > 0) {
10
+ canvas = arguments[0];
9
11
  }
10
12
  if (canvas instanceof Canvas) {
11
- this._canvas = canvas;
13
+ this.nativeElement = canvas;
12
14
  }
13
15
  else {
14
- this._canvas = Canvas.createCustomView(true);
16
+ this.nativeElement = Canvas.createCustomView();
15
17
  }
18
+ if (!this.nativeElement.__domElement) {
19
+ this.nativeElement.__domElement = new DOMParser().parseFromString('<canvas></canvas>', 'text/html').documentElement;
20
+ }
21
+ if (this.nativeElement && '__target' in this.nativeElement) {
22
+ this.nativeElement.__target = this;
23
+ }
24
+ }
25
+ static [Symbol.hasInstance](obj) {
26
+ return obj?._htmlCanvas || obj instanceof Canvas;
27
+ }
28
+ get _canvas() {
29
+ return this.nativeElement;
30
+ }
31
+ get innerWidth() {
32
+ return this.clientWidth;
33
+ }
34
+ get innerHeight() {
35
+ return this.clientHeight;
36
+ }
37
+ get clientWidth() {
38
+ return this.nativeElement['clientWidth'];
39
+ }
40
+ get clientHeight() {
41
+ return this.nativeElement['clientHeight'];
16
42
  }
17
43
  set width(value) {
18
- // if (global.isIOS) {
19
- // this._canvas.width = value / Screen.mainScreen.scale;
20
- // } else {
21
- // this._canvas.width = value;
22
- // }
23
- this._canvas.width = value;
44
+ setValue(this.nativeElement, 'width', value);
24
45
  }
25
46
  get width() {
26
- return this._canvas.width;
47
+ return this.nativeElement['width'];
27
48
  }
28
49
  set height(value) {
29
- // if (global.isIOS) {
30
- // this._canvas.height = value / Screen.mainScreen.scale;
31
- // } else {
32
- // this._canvas.height = value;
33
- // }
34
- this._canvas.height = value;
50
+ setValue(this.nativeElement, 'height', value);
35
51
  }
36
52
  get height() {
37
- return this._canvas.height;
53
+ return this.nativeElement['height'];
38
54
  }
39
- toDataURL(type, encoderOptions) {
40
- return this._canvas.toDataURL(type, encoderOptions);
55
+ toDataURL(type, encoderOptions = 0.92) {
56
+ const nativeElement = this.nativeElement;
57
+ if (nativeElement) {
58
+ return nativeElement.toDataURL?.(type, encoderOptions);
59
+ }
60
+ return 'data:,';
41
61
  }
42
62
  getContext(contextType, contextOptions) {
43
- return this._canvas.getContext(contextType, contextOptions);
63
+ const nativeElement = this.nativeElement;
64
+ if (nativeElement) {
65
+ return nativeElement.getContext(contextType, contextOptions);
66
+ }
67
+ return null;
44
68
  }
45
69
  setPointerCapture(id) { }
46
70
  releasePointerCapture(id) { }
47
- getBoundingClientRect() {
48
- return this._canvas.getBoundingClientRect();
71
+ getRootNode() {
72
+ return this;
49
73
  }
50
74
  }
75
+ Canvas.prototype.toHTMLCanvas = function () {
76
+ return new HTMLCanvasElement(this);
77
+ };
51
78
  //# sourceMappingURL=HTMLCanvasElement.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"HTMLCanvasElement.js","sourceRoot":"","sources":["../../../../packages/canvas-polyfill/DOM/HTMLCanvasElement.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,sBAAsB,CAAC;AAE9C,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAEpC,MAAM,OAAO,iBAAkB,SAAQ,OAAO;IAC7C;QACC,KAAK,CAAC,QAAQ,CAAC,CAAC;QAChB,IAAI,MAAM,GAAG,SAAS,CAAC;QACvB,IAAI,SAAS,CAAC,MAAM,GAAG,CAAC,EAAE;YACzB,MAAM,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC;SACtB;QAED,IAAI,MAAM,YAAY,MAAM,EAAE;YAC7B,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC;SACtB;aAAM;YACN,IAAI,CAAC,OAAO,GAAI,MAAc,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC;SACtD;IACF,CAAC;IAED,IAAI,KAAK,CAAC,KAAK;QACd,sBAAsB;QACtB,yDAAyD;QACzD,WAAW;QACX,+BAA+B;QAC/B,IAAI;QACJ,IAAI,CAAC,OAAO,CAAC,KAAK,GAAG,KAAK,CAAC;IAC5B,CAAC;IAED,IAAI,KAAK;QACR,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC;IAC3B,CAAC;IAED,IAAI,MAAM,CAAC,KAAK;QACf,sBAAsB;QACtB,0DAA0D;QAC1D,WAAW;QACX,gCAAgC;QAChC,IAAI;QACJ,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,KAAK,CAAC;IAC7B,CAAC;IAED,IAAI,MAAM;QACT,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC;IAC5B,CAAC;IAED,SAAS,CAAC,IAAI,EAAE,cAAc;QAC7B,OAAO,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,IAAI,EAAE,cAAc,CAAC,CAAC;IACrD,CAAC;IAED,UAAU,CAAC,WAAW,EAAE,cAAc;QACrC,OAAO,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,WAAW,EAAE,cAAc,CAAC,CAAC;IAC7D,CAAC;IAED,iBAAiB,CAAC,EAAE,IAAG,CAAC;IAExB,qBAAqB,CAAC,EAAE,IAAG,CAAC;IAE5B,qBAAqB;QACpB,OAAO,IAAI,CAAC,OAAO,CAAC,qBAAqB,EAAE,CAAC;IAC7C,CAAC;CACD"}
1
+ {"version":3,"file":"HTMLCanvasElement.js","sourceRoot":"","sources":["../../../../packages/canvas-polyfill/DOM/HTMLCanvasElement.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,4 @@
1
+ export declare class HTMLCollection extends Array {
2
+ item(index: number): any;
3
+ namedItem(nameOrId: string): any;
4
+ }
@@ -0,0 +1,10 @@
1
+ export class HTMLCollection extends Array {
2
+ item(index) {
3
+ return this[index];
4
+ }
5
+ namedItem(nameOrId) {
6
+ // todo
7
+ return null;
8
+ }
9
+ }
10
+ //# sourceMappingURL=HTMLCollection.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"HTMLCollection.js","sourceRoot":"","sources":["../../../../packages/canvas-polyfill/DOM/HTMLCollection.ts"],"names":[],"mappings":"AAAA,MAAM,OAAO,cAAe,SAAQ,KAAK;IACxC,IAAI,CAAC,KAAa;QACjB,OAAO,IAAI,CAAC,KAAK,CAAC,CAAC;IACpB,CAAC;IAED,SAAS,CAAC,QAAgB;QACzB,OAAO;QACP,OAAO,IAAI,CAAC;IACb,CAAC;CACD"}
@@ -0,0 +1,6 @@
1
+ import { HTMLElement } from './HTMLElement';
2
+ export declare class HTMLDivElement extends HTMLElement {
3
+ constructor();
4
+ get innerHTML(): any;
5
+ set innerHTML(value: any);
6
+ }
@@ -0,0 +1,27 @@
1
+ import { HTMLElement } from './HTMLElement';
2
+ import { StackLayout } from '@nativescript/core';
3
+ export class HTMLDivElement extends HTMLElement {
4
+ constructor() {
5
+ super('div');
6
+ const div = arguments[0];
7
+ // using StackLayout for now
8
+ if (!(div instanceof StackLayout)) {
9
+ this.nativeElement = new StackLayout();
10
+ }
11
+ else {
12
+ this.nativeElement = arguments[0];
13
+ }
14
+ if (!this.nativeElement.__domElement) {
15
+ this.nativeElement.__domElement = new DOMParser().parseFromString('<div></div>', 'text/html').documentElement;
16
+ }
17
+ }
18
+ get innerHTML() {
19
+ return this.nativeElement?.__domElement?.children[1]?.children[0]?.innerHTML;
20
+ }
21
+ set innerHTML(value) {
22
+ if (typeof value === 'string') {
23
+ this.nativeElement.__domElement = new DOMParser().parseFromString(`<div>${value}</div>`, 'text/html').documentElement;
24
+ }
25
+ }
26
+ }
27
+ //# sourceMappingURL=HTMLDivElement.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"HTMLDivElement.js","sourceRoot":"","sources":["../../../../packages/canvas-polyfill/DOM/HTMLDivElement.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAEjD,MAAM,OAAO,cAAe,SAAQ,WAAW;IAC9C;QACC,KAAK,CAAC,KAAK,CAAC,CAAC;QACb,MAAM,GAAG,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC;QAEzB,4BAA4B;QAC5B,IAAI,CAAC,CAAC,GAAG,YAAY,WAAW,CAAC,EAAE,CAAC;YACnC,IAAI,CAAC,aAAa,GAAG,IAAI,WAAW,EAAE,CAAC;QACxC,CAAC;aAAM,CAAC;YACP,IAAI,CAAC,aAAa,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC;QACnC,CAAC;QAED,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,YAAY,EAAE,CAAC;YACtC,IAAI,CAAC,aAAa,CAAC,YAAY,GAAG,IAAI,SAAS,EAAE,CAAC,eAAe,CAAC,aAAa,EAAE,WAAW,CAAC,CAAC,eAAwB,CAAC;QACxH,CAAC;IACF,CAAC;IAED,IAAI,SAAS;QACZ,OAAa,IAAI,CAAC,aAAc,EAAE,YAAY,EAAE,QAAQ,CAAC,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC,CAAC,EAAE,SAAS,CAAC;IACrF,CAAC;IAED,IAAI,SAAS,CAAC,KAAK;QAClB,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;YAC/B,IAAI,CAAC,aAAa,CAAC,YAAY,GAAG,IAAI,SAAS,EAAE,CAAC,eAAe,CAAC,QAAQ,KAAK,QAAQ,EAAE,WAAW,CAAC,CAAC,eAAwB,CAAC;QAChI,CAAC;IACF,CAAC;CACD"}
@@ -0,0 +1,26 @@
1
+ import { Element } from './Element';
2
+ import { ViewBase } from '@nativescript/core';
3
+ export declare class Style {
4
+ private _values;
5
+ nativeElement: WeakRef<ViewBase>;
6
+ constructor();
7
+ private _nativeElement;
8
+ get width(): any;
9
+ set width(value: any);
10
+ get height(): any;
11
+ set height(value: any);
12
+ }
13
+ export declare class HTMLElement extends Element {
14
+ private _style;
15
+ constructor(tagName?: string);
16
+ get style(): Style | import("@nativescript/core").Style;
17
+ set nativeElement(value: import("@nativescript/core").View & {
18
+ __domElement?: Element;
19
+ isConnected?: boolean;
20
+ });
21
+ get nativeElement(): import("@nativescript/core").View & {
22
+ __domElement?: Element;
23
+ isConnected?: boolean;
24
+ };
25
+ get isConnected(): boolean;
26
+ }
@@ -0,0 +1,57 @@
1
+ import { Element } from './Element';
2
+ export class Style {
3
+ constructor() {
4
+ this._values = new Map();
5
+ }
6
+ _nativeElement() {
7
+ if (__ANDROID__) {
8
+ return this.nativeElement?.get?.();
9
+ }
10
+ if (__IOS__) {
11
+ return this.nativeElement?.deref?.();
12
+ }
13
+ return undefined;
14
+ }
15
+ get width() {
16
+ return this._values.get('width');
17
+ }
18
+ set width(value) {
19
+ this._values.set('width', value);
20
+ }
21
+ get height() {
22
+ return this._values.get('height');
23
+ }
24
+ set height(value) {
25
+ this._values.set('height', value);
26
+ }
27
+ }
28
+ export class HTMLElement extends Element {
29
+ constructor(tagName = '') {
30
+ super(tagName ?? '');
31
+ this._style = new Style();
32
+ }
33
+ get style() {
34
+ if (this._nativeElement) {
35
+ return this._nativeElement.style;
36
+ }
37
+ return this._style;
38
+ }
39
+ set nativeElement(value) {
40
+ this._nativeElement = value;
41
+ if (value) {
42
+ this._emitter = new WeakRef(value);
43
+ this._style.nativeElement = new WeakRef(value);
44
+ }
45
+ else {
46
+ this._emitter = value;
47
+ this._style.nativeElement = value;
48
+ }
49
+ }
50
+ get nativeElement() {
51
+ return this._nativeElement;
52
+ }
53
+ get isConnected() {
54
+ return this.nativeElement?.isConnected ?? !!this.nativeElement?.parent ?? false;
55
+ }
56
+ }
57
+ //# sourceMappingURL=HTMLElement.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"HTMLElement.js","sourceRoot":"","sources":["../../../../packages/canvas-polyfill/DOM/HTMLElement.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAIpC,MAAM,OAAO,KAAK;IAIjB;QACC,IAAI,CAAC,OAAO,GAAG,IAAI,GAAG,EAAE,CAAC;IAC1B,CAAC;IAEO,cAAc;QACrB,IAAI,WAAW,EAAE,CAAC;YACjB,OAAO,IAAI,CAAC,aAAa,EAAE,GAAG,EAAE,EAAE,CAAC;QACpC,CAAC;QACD,IAAI,OAAO,EAAE,CAAC;YACb,OAAO,IAAI,CAAC,aAAa,EAAE,KAAK,EAAE,EAAE,CAAC;QACtC,CAAC;QACD,OAAO,SAAS,CAAC;IAClB,CAAC;IAED,IAAI,KAAK;QACR,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;IAClC,CAAC;IACD,IAAI,KAAK,CAAC,KAAK;QACd,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;IAClC,CAAC;IAED,IAAI,MAAM;QACT,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;IACnC,CAAC;IACD,IAAI,MAAM,CAAC,KAAK;QACf,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;IACnC,CAAC;CACD;AAED,MAAM,OAAO,WAAY,SAAQ,OAAO;IAGvC,YAAY,UAAkB,EAAE;QAC/B,KAAK,CAAC,OAAO,IAAI,EAAE,CAAC,CAAC;QACrB,IAAI,CAAC,MAAM,GAAG,IAAI,KAAK,EAAE,CAAC;IAC3B,CAAC;IAED,IAAI,KAAK;QACR,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;YACzB,OAAO,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC;QAClC,CAAC;QACD,OAAO,IAAI,CAAC,MAAM,CAAC;IACpB,CAAC;IAED,IAAI,aAAa,CAAC,KAAK;QACtB,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;QAC5B,IAAI,KAAK,EAAE,CAAC;YACX,IAAI,CAAC,QAAQ,GAAG,IAAI,OAAO,CAAC,KAAK,CAAC,CAAC;YACnC,IAAI,CAAC,MAAM,CAAC,aAAa,GAAG,IAAI,OAAO,CAAC,KAAK,CAAC,CAAC;QAChD,CAAC;aAAM,CAAC;YACP,IAAI,CAAC,QAAQ,GAAG,KAAc,CAAC;YAC/B,IAAI,CAAC,MAAM,CAAC,aAAa,GAAG,KAAc,CAAC;QAC5C,CAAC;IACF,CAAC;IAED,IAAI,aAAa;QAChB,OAAO,IAAI,CAAC,cAAc,CAAC;IAC5B,CAAC;IAED,IAAI,WAAW;QACd,OAAO,IAAI,CAAC,aAAa,EAAE,WAAW,IAAI,CAAC,CAAC,IAAI,CAAC,aAAa,EAAE,MAAM,IAAI,KAAK,CAAC;IACjF,CAAC;CACD"}
@@ -1,19 +1,32 @@
1
- import { Element } from './Element';
2
- export declare class HTMLImageElement extends Element {
1
+ import { ImageAsset } from '@nativescript/canvas';
2
+ import { HTMLElement } from './HTMLElement';
3
+ export declare class HTMLImageElement extends HTMLElement {
3
4
  private localUri;
4
5
  private _onload;
6
+ private _onerror;
5
7
  private _complete;
6
8
  private _base64;
7
- _asset: any;
8
- _imageSource: any;
9
+ width: number;
10
+ height: number;
11
+ _asset: ImageAsset;
12
+ _svg: any;
9
13
  __id: any;
10
14
  decoding: string;
15
+ private _loading;
16
+ private _decodingQueue;
11
17
  get src(): any;
18
+ get naturalWidth(): number;
19
+ get naturalHeight(): number;
12
20
  set src(value: any);
13
21
  get onload(): any;
14
22
  set onload(value: any);
23
+ get onerror(): any;
24
+ set onerror(value: any);
15
25
  get complete(): any;
16
26
  set complete(value: any);
27
+ private _dispatchDecode;
28
+ decode(): Promise<void>;
29
+ static _fromSvg(svg: any): HTMLImageElement;
17
30
  constructor(props?: any);
18
- _load(): void;
31
+ _load(): Promise<void>;
19
32
  }