UNPKG

@dunite/au-react-wrapper

Version:
145 lines (144 loc) 7.03 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; }; import * as React from 'react'; import * as ReactDom from 'react-dom'; import { inlineView, LogManager } from 'aurelia-framework'; import { ReactStateWrapper } from './ReactStateWrapper'; // Den här filen har endast "ReactStateWrapper" som unik referens /* * @deprecated Use AuReactWrapper instead */ var AuReactStateWrapper = /** @class */ (function () { function AuReactStateWrapper(element) { this.element = element; this.log = LogManager.getLogger('reacthost'); // this.log.info('DuReactWrapperBaseClass constructor'); this.inneridAurelia = 'du' + Math.round(Math.random() * 10000000000000000); } AuReactStateWrapper.prototype.createState = function (reactprops) { var reactpropNames = Object.getOwnPropertyNames(reactprops); var a = {}; var _loop_1 = function (i) { var renderPropName = reactpropNames[i]; if (typeof reactprops[renderPropName] === 'function') { //this.log.debug(`React template: typeof reactprops[${renderPropName}] is function`); //this.log.debug(`Aurelia object: typeof this[${renderPropName}] is ${typeof this[renderPropName] }`); if (typeof this_1[renderPropName] === 'function') { //this.log.debug('bound function, go aurelia'); a[renderPropName] = this_1[renderPropName].bind(this_1.parent); } else { //this.log.debug('function is not bound, check for default implementation on React template'); var funcNames = ['defaultOnChangeEvent', 'defaultActionEvent', 'onlyAureliaBound']; if (!funcNames.includes(reactprops[renderPropName].name)) { //this.log.debug('React template has default implementation, call it.'); that = this_1; a[renderPropName] = function () { var argLength = arguments.length; reactprops[renderPropName](that, argLength >= 1 ? arguments[0] : undefined, argLength >= 2 ? arguments[1] : undefined, argLength >= 3 ? arguments[2] : undefined, argLength >= 4 ? arguments[3] : undefined); }; } // else // { // this.log.debug('React template has empty implementation, do nothing.'); // } } } else { this_1.log.debug("React template: typeof reactprops[" + renderPropName + "] is NOT function"); if (typeof this_1[renderPropName] !== 'undefined') { // this.log.debug('Aurelia object property ' + renderPropName + ' has value ' + this[renderPropName]); a[renderPropName] = this_1[renderPropName]; } // else // { // this.log.debug('Aurelia object property ' + renderPropName + ' has NO value ' ); // } } }; var this_1 = this, that; for (var i = 0; i < reactpropNames.length; i++) { _loop_1(i); } return a; }; AuReactStateWrapper.prototype.isHidden = function () { return this.hiddenIsHidden ? this[this.hiddenName] : !this[this.hiddenName]; }; AuReactStateWrapper.prototype.bind = function (bindingContext) { //this.log.debug('DuPanel bind'); if (bindingContext !== null) { this.parent = bindingContext; } }; AuReactStateWrapper.prototype.unbind = function () { this.log.debug('DuReactWrapperBaseClass unbind '); ReactDom.unmountComponentAtNode(this.element); }; AuReactStateWrapper.prototype.propertyChanged = function (name, newValue) { // this.log.debug('propertyChanged'); // this.log.debug(name); // this.log.debug(newValue); var obj = {}; obj[name] = newValue; if (name == this.hiddenName) { if (this.hiddenIsHidden ? newValue : !newValue) { this.moveBack(); } } this.reactComponent.setState(obj); this[name] = newValue; }; AuReactStateWrapper.prototype.moveBack = function () { //this.log.debug('Move back'); var auelement = document.getElementById(this.inneridAurelia); var oldParent = document.getElementById(this.reactComponent.inneridReact); if (oldParent == null || auelement == null) { return; } while (oldParent.childNodes.length > 0) { auelement.appendChild(oldParent.childNodes[0]); } }; // reactComponentWillUnmount() // { // this.log.debug('DuReactWrapperBaseClass componentWillUnmount'); // } // reactComponentDidMount() // { // this.log.debug('DuReactWrapperBaseClass reactComponentDidMount'); // } AuReactStateWrapper.prototype.renderReact = function (reactClass, a) { this.log.debug('DuReactWrapperBaseClass renderReact'); //ReactDom.unmountComponentAtNode(this.element); this.container = this.element.querySelector('.au-react-root'); if (this.container != null) { this.container.remove(); } this.container = document.createElement('span'); this.container.setAttribute('class', 'au-react-root'); this.element.appendChild(this.container); a.aureliaHost = this; a.reactClass = reactClass; // reactElement is the DOM element; var reactElement = React.createElement(ReactStateWrapper, a); // reactComponent is THE React Component var reactComponent = ReactDom.render(reactElement, this.container // , () => // { // this.log.debug('DuReactWrapperBaseClass React callback render complete'); // } ); this.reactComponent = reactComponent; this.log.debug('DuReactWrapperBaseClass renderReact complete'); }; AuReactStateWrapper = __decorate([ inlineView('<template><span id.bind="inneridAurelia" show.bind="!hidden"><slot></slot></span></template>') ], AuReactStateWrapper); return AuReactStateWrapper; }()); export { AuReactStateWrapper };