UNPKG

18.7 kBJavaScriptView Raw
1'use strict';
2
3Object.defineProperty(exports, "__esModule", {
4 value: true
5});
6exports.Context = undefined;
7
8var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
9
10var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; };
11
12var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
13
14var _events = require('events');
15
16var _defined = require('defined');
17
18var _defined2 = _interopRequireDefault(_defined);
19
20var _document = require('global/document');
21
22var _document2 = _interopRequireDefault(_document);
23
24var _window = require('global/window');
25
26var _window2 = _interopRequireDefault(_window);
27
28var _domEvents = require('dom-events');
29
30var _domEvents2 = _interopRequireDefault(_domEvents);
31
32var _regl = require('@littlstar/regl');
33
34var _regl2 = _interopRequireDefault(_regl);
35
36function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
37
38function _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }
39
40function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
41
42function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; }
43
44function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }
45
46var Context = exports.Context = function (_EventEmitter) {
47 _inherits(Context, _EventEmitter);
48
49 function Context() {
50 var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
51 var createRegl = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : _regl2.default;
52
53 _classCallCheck(this, Context);
54
55 var _this = _possibleConstructorReturn(this, (Context.__proto__ || Object.getPrototypeOf(Context)).call(this));
56
57 _this.setMaxListeners(Infinity);
58 _this._hasFocus = false;
59 _this._isDestroyed = false;
60
61 // coalesce regl options if given as `.gl`
62 opts.regl = (0, _defined2.default)(opts.regl, opts.gl || {});
63 if (opts.gl && opts.gl.context) {
64 opts.regl.gl = opts.gl.context;
65 delete opts.gl.context;
66 }
67
68 // derive container element
69 if (opts.canvas && 'object' == _typeof(opts.canvas)) {
70 opts.regl.canvas = opts.canvas;
71 } else if (opts.element && 'CANVAS' == opts.element.nodeName) {
72 opts.regl.canvas = opts.element;
73 } else if (opts.element && opts.element.nodeName) {
74 opts.regl.container = opts.element;
75 } else if ('string' == typeof opts.element) {
76 opts.regl.container = opts.element;
77 }
78
79 // call regl initializer
80 createRegl(_extends({
81 pixelRatio: opts.pixelRatio || _window2.default.devicePixelRatio || 1,
82 profile: Boolean(opts.profile)
83 }, opts.regl, {
84 attributes: _extends({}, opts.regl.attributes || {}),
85 extensions: [].concat(_toConsumableArray(opts.regl.extensions || [])),
86 optionalExtensions: ['ANGLE_instanced_arrays'].concat(_toConsumableArray(opts.regl.optionalExtensions || [])),
87
88 onDone: function onDone(err, regl) {
89 if (err) {
90 return _this.emit('error', err);
91 }
92 _this._regl = regl;
93 _this._isDestroyed = false;
94 if (regl._gl && regl._gl.canvas) {
95 _this._domElement = _this._regl._gl.canvas;
96 } else {
97 _this._domElement = null;
98 }
99 }
100 }));
101
102 if (null != _this._domElement && 'undefind' != typeof _window2.default && 'undefind' != typeof _document2.default) {
103 var bind = function bind(t, e, f) {
104 _domEvents2.default.on(t, e, f);
105 _this.once('beforedestroy', function () {
106 return _domEvents2.default.off(t, e, f);
107 });
108 };
109 // context focus event handlers
110 var onblur = function onblur() {
111 _this.blur();
112 };
113 var onfocus = function onfocus() {
114 _this.focus();
115 };
116 var onwindowblur = function onwindowblur() {
117 _this.blur();
118 };
119 var onmousedown = function onmousedown(e) {
120 if (e.target == _this._domElement) {
121 _this.focus();
122 } else {
123 _this.blur();
124 }
125 };
126 bind(_this._domElement, 'blur', onblur);
127 bind(_this._domElement, 'focus', onfocus);
128 bind(_window2.default, 'blur', onwindowblur);
129 bind(_document2.default, 'mousedown', onmousedown);
130 bind(_document2.default, 'touchstart', onmousedown);
131 }
132 return _this;
133 }
134
135 _createClass(Context, [{
136 key: 'focus',
137 value: function focus() {
138 this._hasFocus = true;
139 this.emit('focus');
140 return this;
141 }
142 }, {
143 key: 'blur',
144 value: function blur() {
145 this._hasFocus = false;
146 this.emit('blur');
147 return this;
148 }
149 }, {
150 key: 'destroy',
151 value: function destroy() {
152 this.emit('beforedestroy');
153 if (this._regl && 'function' == typeof this._regl.destroy) {
154 this._regl.destroy();
155 }
156
157 if (this._domElement && this._domElement.parentElement) {
158 this._domElement.parentElement.removeChild(this._domElement);
159 }
160
161 delete this._regl;
162 delete this._domElement;
163 this._hasFocus = false;
164 this.emit('destroy');
165 return this;
166 }
167 }, {
168 key: 'refresh',
169 value: function refresh() {
170 if (this.regl && 'function' == typeof this.regl._refresh) {
171 this.regl._refresh();
172 }
173 return this;
174 }
175 }, {
176 key: 'flush',
177 value: function flush() {
178 if (this.gl) {
179 this.gl.flush();
180 }
181 return this;
182 }
183 }, {
184 key: 'poll',
185 value: function poll() {
186 if (this.regl) {
187 if (this.regl && 'function' == typeof this.regl.poll) {
188 this.regl.poll();
189 }
190 }
191 }
192 }, {
193 key: 'isDestroyed',
194 get: function get() {
195 return Boolean(this._isDestroyed);
196 }
197 }, {
198 key: 'domElement',
199 get: function get() {
200 return this._domElement || null;
201 }
202 }, {
203 key: 'hasFocus',
204 get: function get() {
205 return Boolean(this._hasFocus);
206 }
207 }, {
208 key: 'regl',
209 get: function get() {
210 return this._regl || null;
211 }
212 }, {
213 key: 'gl',
214 get: function get() {
215 return this._regl ? this._regl._gl || null : null;
216 }
217 }]);
218
219 return Context;
220}(_events.EventEmitter);
221//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/core/context.js"],"names":["Context","opts","createRegl","setMaxListeners","Infinity","_hasFocus","_isDestroyed","regl","gl","context","canvas","element","nodeName","container","pixelRatio","devicePixelRatio","profile","Boolean","attributes","extensions","optionalExtensions","onDone","err","emit","_regl","_gl","_domElement","bind","t","e","f","on","once","off","onblur","blur","onfocus","focus","onwindowblur","onmousedown","target","destroy","parentElement","removeChild","_refresh","flush","poll"],"mappings":"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","file":"context.js","sourcesContent":["import { EventEmitter } from 'events'\nimport coalesce from 'defined'\nimport document from 'global/document'\nimport window from 'global/window'\nimport events from 'dom-events'\nimport regl from '@littlstar/regl'\n\nexport class Context extends EventEmitter {\n  constructor(opts = {}, createRegl = regl) {\n    super()\n    this.setMaxListeners(Infinity)\n    this._hasFocus = false\n    this._isDestroyed = false\n\n    // coalesce regl options if given as `.gl`\n    opts.regl = coalesce(opts.regl, opts.gl || {})\n    if (opts.gl && opts.gl.context) {\n      opts.regl.gl = opts.gl.context\n      delete opts.gl.context\n    }\n\n    // derive container element\n    if (opts.canvas && 'object' == typeof opts.canvas) {\n      opts.regl.canvas = opts.canvas\n    } else if (opts.element && 'CANVAS' == opts.element.nodeName) {\n      opts.regl.canvas = opts.element\n    } else if (opts.element && opts.element.nodeName) {\n      opts.regl.container = opts.element\n    } else if ('string' == typeof opts.element) {\n      opts.regl.container = opts.element\n    }\n\n    // call regl initializer\n    createRegl({\n      pixelRatio: opts.pixelRatio || window.devicePixelRatio || 1,\n      profile: Boolean(opts.profile),\n      ...opts.regl,\n      attributes: { ...(opts.regl.attributes || {}) },\n      extensions: [ ...(opts.regl.extensions || []) ],\n      optionalExtensions: [\n        'ANGLE_instanced_arrays',\n        ...(opts.regl.optionalExtensions || [])\n      ],\n\n      onDone: (err, regl) => {\n        if (err) { return this.emit('error', err) }\n        this._regl = regl\n        this._isDestroyed = false\n        if (regl._gl && regl._gl.canvas) {\n          this._domElement = this._regl._gl.canvas\n        } else {\n          this._domElement = null\n        }\n      }\n    })\n\n    if (\n      null != this._domElement &&\n      'undefind' != typeof window &&\n      'undefind' != typeof document\n    ) {\n      const bind = (t, e, f) => {\n        events.on(t, e, f)\n        this.once('beforedestroy', () => events.off(t, e, f))\n      }\n      // context focus event handlers\n      const onblur = () => { this.blur() }\n      const onfocus = () => { this.focus() }\n      const onwindowblur = () => { this.blur() }\n      const onmousedown = (e) => {\n        if (e.target == this._domElement) { this.focus() }\n        else { this.blur() }\n      }\n      bind(this._domElement, 'blur', onblur)\n      bind(this._domElement, 'focus', onfocus)\n      bind(window, 'blur', onwindowblur)\n      bind(document, 'mousedown', onmousedown)\n      bind(document, 'touchstart', onmousedown)\n    }\n  }\n\n  get isDestroyed() { return Boolean(this._isDestroyed) }\n  get domElement() { return this._domElement || null }\n  get hasFocus() { return Boolean(this._hasFocus) }\n  get regl() { return this._regl || null }\n  get gl() { return this._regl ? this._regl._gl || null : null }\n\n  focus() {\n    this._hasFocus = true\n    this.emit('focus')\n    return this\n  }\n\n  blur() {\n    this._hasFocus = false\n    this.emit('blur')\n    return this\n  }\n\n  destroy() {\n    this.emit('beforedestroy')\n    if (this._regl && 'function' == typeof this._regl.destroy) {\n      this._regl.destroy()\n    }\n\n    if (this._domElement && this._domElement.parentElement) {\n      this._domElement.parentElement.removeChild(this._domElement)\n    }\n\n    delete this._regl\n    delete this._domElement\n    this._hasFocus = false\n    this.emit('destroy')\n    return this\n  }\n\n  refresh() {\n    if (this.regl && 'function' == typeof this.regl._refresh) {\n      this.regl._refresh()\n    }\n    return this\n  }\n\n  flush() {\n    if (this.gl) {\n      this.gl.flush()\n    }\n    return this\n  }\n\n  poll() {\n    if (this.regl) {\n      if (this.regl && 'function' == typeof this.regl.poll) {\n        this.regl.poll()\n      }\n    }\n  }\n}\n"]}
\No newline at end of file