npm.io
2.1.1 • Published 2d ago

@nativescript/canvas-polyfill

Licence
Apache-2.0
Version
2.1.1
Deps
6
Size
686 kB
Vulns
0
Weekly
1.4K

@nativescript/canvas-polyfill

Browser polyfill for NativeScript

Installation

npm i @nativescript/canvas-polyfill

Usage

Import the library into your JavaScript file:

import '@nativescript/canvas-polyfill';

Implements

DOM

DOM is provided with very low support, these are used for libs like pixi.js that validate type.

class Node
class Element
class Document
class HTMLImageElement
class Image
class ImageBitmap
class HTMLVideoElement
class Video
class HTMLCanvasElement
class Canvas
Image, HTMLImageElement, ImageBitmap

Image has support for loading callbacks, however the loaded uri must be passed to the src already.

const image = new Image();
image.src = '';
image.onload = () => {
  const { src, width, height } = image;
};
image.addEventListener('loading', () => {});
image.addEventListener('error', () => {});
Document
const element = document.createElement('div');
const fakeContext = element.getContext('');
Element
All sizes return the window size:
element.clientWidth;
element.clientHeight;
element.innerWidth;
element.innerHeight;
element.offsetWidth;
element.offsetHeight;
Empty attributes that prevent libraries from crashing
element.tagName;
element.addEventListener;
element.removeEventListener;
element.setAttributeNS;
element.createElementNS;
Node
node.ownerDocument;
node.className;
node.appendChild;
node.insertBefore;
node.removeChild;
node.setAttributeNS;
node.getBoundingClientRect;

Debug flags

For debugging base64 image transformations toggle:

global.__debug_browser_polyfill_image = true;

By default global.__debug_browser_polyfill_image is false.

License

Apache License Version 2.0, January 2004

Keywords