UNPKG

reactronic-dom

Version:

Reactronic DOM - Transactional Reactive Front-End Development Framework

39 lines (38 loc) 1.82 kB
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; var __metadata = (this && this.__metadata) || function (k, v) { if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); }; import { ToggleRef, transaction } from 'reactronic'; import { objectHasMember } from '../../core/Utils'; import { Sensor } from './Sensor'; export class WindowSensor extends Sensor { constructor() { super(...arguments); this.activeData = undefined; this.previousActiveData = undefined; } setActiveWindow(window, debugHint = '') { if (window !== this.activeData) { const activeData = this.activeData; if (activeData && objectHasMember(activeData, 'popupToggle')) { const popupToggle = activeData.popupToggle; if (popupToggle instanceof ToggleRef) { popupToggle.value = popupToggle.valueOff; } } this.previousActiveData = activeData; this.activeData = window; } } } __decorate([ transaction, __metadata("design:type", Function), __metadata("design:paramtypes", [Object, String]), __metadata("design:returntype", void 0) ], WindowSensor.prototype, "setActiveWindow", null);