reactronic-dom
Version:
Reactronic DOM - Transactional Reactive Front-End Development Framework
39 lines (38 loc) • 1.82 kB
JavaScript
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);