@ema/js-base-library
Version:
This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 7.2.0.
439 lines • 28.5 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import * as tslib_1 from "tslib";
/**
* @record
*/
function IWebComponent() { }
if (false) {
/** @type {?} */
IWebComponent.prototype.attributeChangedCallback;
/** @type {?} */
IWebComponent.prototype.connectedCallback;
/** @type {?} */
IWebComponent.prototype.definePublicMethods;
/** @type {?} */
IWebComponent.prototype.init;
/** @type {?} */
IWebComponent.prototype.render;
/** @type {?} */
IWebComponent.prototype.template;
}
/*
base class for vanilla-js webcomponents
*/
var /*
base class for vanilla-js webcomponents
*/
BaseWebComponent = /** @class */ (function (_super) {
tslib_1.__extends(BaseWebComponent, _super);
function BaseWebComponent() {
var _this = _super.call(this) || this;
_this.data = {};
return _this;
}
/**
* @return {?}
*/
BaseWebComponent.prototype.init = /**
* @return {?}
*/
function () {
return tslib_1.__awaiter(this, void 0, void 0, function () { return tslib_1.__generator(this, function (_a) {
return [2 /*return*/];
}); });
};
/**
* @return {?}
*/
BaseWebComponent.prototype.render = /**
* @return {?}
*/
function () { };
/**
* @return {?}
*/
BaseWebComponent.prototype.definePublicMethods = /**
* @return {?}
*/
function () { };
/**
* @return {?}
*/
BaseWebComponent.prototype.remove = /**
* @return {?}
*/
function () { };
/**
* @param {?} name
* @param {?} oldVal
* @param {?} newVal
* @return {?}
*/
BaseWebComponent.prototype.attributeChangedCallback = /**
* @param {?} name
* @param {?} oldVal
* @param {?} newVal
* @return {?}
*/
function (name, oldVal, newVal) { };
/**
* @return {?}
*/
BaseWebComponent.prototype.connectedCallback = /**
* @return {?}
*/
function () {
var _this = this;
/** @type {?} */
var shadowRoot;
this.data = {};
if (!this.shadowRoot) {
shadowRoot = this.root = this.attachShadow({
mode: 'open'
});
}
else {
shadowRoot = this.root = this.shadowRoot;
}
this.el = shadowRoot.appendChild(this.template.content.cloneNode(true));
this.setState = this.setState.bind(this);
this.getState = this.getState.bind(this);
this.removeState = this.removeState.bind(this);
this.getData = this.getData.bind(this);
this.setData = this.setData.bind(this);
if (this.definePublicMethods) {
this.definePublicMethods();
}
if (this.init) {
this.init = this.init.bind(this);
}
if (this.dataJson) {
this.data = JSON.parse(this.dataJson);
}
if (this.init) {
this.init().then((/**
* @return {?}
*/
function () {
_this.preRender();
}));
}
else {
this.preRender();
}
};
Object.defineProperty(BaseWebComponent.prototype, "template", {
get: /**
* @return {?}
*/
function () {
if (this._template) {
return this._template;
}
this._template = document.createElement('template');
/** @type {?} */
var styles = document.createElement('style');
/** @type {?} */
var content = document.createElement('div');
/** @type {?} */
var imports = document.createElement('head');
imports.innerHTML = this.imports || "";
styles.innerHTML = this.styles || "";
content.innerHTML = this.htmlTemplate || "";
content.className = 'content';
this._template.content.appendChild(styles);
this._template.content.appendChild(imports);
this._template.content.appendChild(content);
return this._template;
},
enumerable: true,
configurable: true
});
/**
* @param {?} propName
* @param {?} getFn
* @param {?} setFn
* @return {?}
*/
BaseWebComponent.prototype.declareProp = /**
* @param {?} propName
* @param {?} getFn
* @param {?} setFn
* @return {?}
*/
function (propName, getFn, setFn) {
var _this = this;
/** @type {?} */
var obj = {};
// default getters / setters
if (!getFn) {
getFn = (/**
* @return {?}
*/
function () {
if (this.getAttribute(propName) !== null) {
return this.getAttribute(propName);
}
else {
return '';
}
});
}
if (!setFn) {
setFn = (/**
* @param {?} value
* @return {?}
*/
function (value) {
this.setAttribute(propName, value);
});
}
// current-state: getter / setter
if (propName === 'current-state') {
// getFn = () => {
// return this.getAttribute(propName);
// };
setFn = (/**
* @param {?} value
* @return {?}
*/
function (value) {
if (_this.isJson(value)) {
_this.setState(JSON.parse(value));
}
else {
_this.setState({ value: value });
}
// 2 way state
if (_this.sharedState) {
_this.setAttribute(propName, JSON.stringify(_this.state));
}
else {
_this.setAttribute(propName, value);
}
});
}
// current-state: getter / setter
if (propName === 'data-json') {
// getFn = () => {
// return this.getAttribute(propName);
// };
setFn = (/**
* @param {?} value
* @return {?}
*/
function (value) {
/** @type {?} */
var data = JSON.parse(value);
Object.keys(data).forEach((/**
* @param {?} k
* @return {?}
*/
function (k) {
_this.data[k] = data[k];
}));
_this.setAttribute(propName, value);
});
}
// obj[propName] = {get: getFn, set: setFn};
obj[this.kebabToLowerCamelCase(propName)] = { get: getFn, set: setFn };
Object.defineProperties(this, obj);
};
/**
* @param {?} eventName
* @param {?} detail
* @return {?}
*/
BaseWebComponent.prototype.dispatch = /**
* @param {?} eventName
* @param {?} detail
* @return {?}
*/
function (eventName, detail) {
this.dispatchEvent(new CustomEvent(eventName, { bubbles: true, detail: detail }));
};
// state management
// state management
/**
* @param {?} state
* @return {?}
*/
BaseWebComponent.prototype.setState =
// state management
/**
* @param {?} state
* @return {?}
*/
function (state) {
if (typeof state === 'string' && !this.isJson(state)) {
console.error('setState only accepts an object as argument');
return;
}
if (typeof state === 'string' && this.isJson(state)) {
state = JSON.parse(state);
}
this.state = tslib_1.__assign({}, this.state, state);
};
/**
* @param {?} key
* @return {?}
*/
BaseWebComponent.prototype.getState = /**
* @param {?} key
* @return {?}
*/
function (key) {
if (key && this.state[key]) {
return JSON.parse(JSON.stringify(this.state[key]));
}
else {
return JSON.parse(JSON.stringify(this.state));
}
};
/**
* @param {?} key
* @return {?}
*/
BaseWebComponent.prototype.removeState = /**
* @param {?} key
* @return {?}
*/
function (key) {
if (!key) {
this.state = {};
this.currentState = '{}';
this.preRender();
}
else {
delete this.state[key];
}
};
// data management
// data management
/**
* @param {?} object
* @param {?} extend
* @return {?}
*/
BaseWebComponent.prototype.setData =
// data management
/**
* @param {?} object
* @param {?} extend
* @return {?}
*/
function (object, extend) {
var _this = this;
if (extend) {
Object.keys(object).forEach((/**
* @param {?} k
* @param {?} i
* @return {?}
*/
function (k, i) {
_this.data[k] = object[k];
}));
}
else {
this.data = object;
}
this.preRender();
};
/**
* @return {?}
*/
BaseWebComponent.prototype.getData = /**
* @return {?}
*/
function () {
return this.data;
};
/**
* @return {?}
*/
BaseWebComponent.prototype.preRender = /**
* @return {?}
*/
function () {
if (this.root) {
this.root.querySelector('.content')['innerHTML'] = this.render();
}
};
// utils
// utils
/**
* @param {?} jsonString
* @return {?}
*/
BaseWebComponent.prototype.isJson =
// utils
/**
* @param {?} jsonString
* @return {?}
*/
function (jsonString) {
try {
/** @type {?} */
var o = JSON.parse(jsonString);
if (o && typeof o === "object") {
return o;
}
}
catch (e) { }
return false;
};
;
/**
* @param {?} str
* @return {?}
*/
BaseWebComponent.prototype.kebabToLowerCamelCase = /**
* @param {?} str
* @return {?}
*/
function (str) {
/** @type {?} */
var string = str.charAt(0).toLowerCase() + str.slice(1);
return string.replace(/(\-\w)/g, (/**
* @param {?} m
* @return {?}
*/
function (m) {
return m[1].toUpperCase();
}));
};
return BaseWebComponent;
}(HTMLElement));
/*
base class for vanilla-js webcomponents
*/
export { BaseWebComponent };
if (false) {
/** @type {?} */
BaseWebComponent.prototype.data;
/** @type {?} */
BaseWebComponent.prototype.el;
/** @type {?} */
BaseWebComponent.prototype.htmlTemplate;
/** @type {?} */
BaseWebComponent.prototype.imports;
/** @type {?} */
BaseWebComponent.prototype.root;
/** @type {?} */
BaseWebComponent.prototype.state;
/** @type {?} */
BaseWebComponent.prototype.sharedState;
/** @type {?} */
BaseWebComponent.prototype.dataJson;
/** @type {?} */
BaseWebComponent.prototype.currentState;
/** @type {?} */
BaseWebComponent.prototype.styles;
/** @type {?} */
BaseWebComponent.prototype._template;
/* Skipping unhandled member: ;*/
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-web-component.js","sourceRoot":"ng://@ema/js-base-library/","sources":["lib/base/base-web-component.ts"],"names":[],"mappings":"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","sourcesContent":["interface IWebComponent {\n    attributeChangedCallback;\n    connectedCallback;\n    definePublicMethods: any;\n    init;\n    render: any;\n    template;\n}\n\n/*\n    base class for vanilla-js webcomponents\n*/\nexport class BaseWebComponent extends HTMLElement implements IWebComponent {\n\n    data: any = {};\n    el: HTMLElement;\n    htmlTemplate;\n    imports: string;\n    root;\n    state;\n    sharedState;\n    dataJson;\n    currentState;\n    styles: string;\n    _template;\n\n    constructor() {\n        super()\n    }\n\n    async init() { }\n    render() { }\n    definePublicMethods() { }\n    remove() { }\n    attributeChangedCallback(name, oldVal, newVal) { }\n\n    connectedCallback() {\n        let shadowRoot;\n        this.data = {};\n        if(!this.shadowRoot) {\n            shadowRoot = this.root = this.attachShadow({\n                mode: 'open'\n            });\n        }else{\n            shadowRoot = this.root = this.shadowRoot;\n        }\n        this.el = shadowRoot.appendChild(this.template.content.cloneNode(true));\n        this.setState = this.setState.bind(this);\n        this.getState = this.getState.bind(this);\n        this.removeState = this.removeState.bind(this)\n        this.getData = this.getData.bind(this);\n        this.setData = this.setData.bind(this);\n        if(this.definePublicMethods) {\n            this.definePublicMethods();\n        }\n        if(this.init) {\n            this.init = this.init.bind(this);\n        }\n        if (this.dataJson) {\n            this.data = JSON.parse(this.dataJson);\n        }\n        if(this.init) {\n            this.init().then(() => {\n                this.preRender();\n            })\n        }else{\n            this.preRender()\n        }\n    }\n\n    get template() {\n        if (this._template) {\n            return this._template;\n        }\n        this._template = document.createElement('template');\n        let styles = document.createElement('style');\n        let content = document.createElement('div');\n        let imports = document.createElement('head');\n\n        imports.innerHTML = this.imports || ``;\n        styles.innerHTML = this.styles || ``;\n        content.innerHTML = this.htmlTemplate || ``;\n        content.className = 'content';\n\n        this._template.content.appendChild(styles);\n        this._template.content.appendChild(imports);\n        this._template.content.appendChild(content);\n\n        return this._template;\n    }\n\n    declareProp(propName, getFn, setFn) {\n        let obj = {};\n        // default getters / setters\n        if (!getFn) {\n            getFn = function () {\n                if (this.getAttribute(propName) !== null) {\n                    return this.getAttribute(propName);\n                } else {\n                    return '';\n                }\n            }\n        }\n        if (!setFn) {\n            setFn = function (value) {\n                this.setAttribute(propName, value);\n            }\n        }\n        // current-state: getter / setter\n        if (propName === 'current-state') {\n            // getFn = () => {\n            //     return this.getAttribute(propName);\n            // };\n            setFn = (value) => {\n                if(this.isJson(value)) {\n                    this.setState(JSON.parse(value))\n                }else{\n                    this.setState({value:value});\n                }\n                // 2 way state\n                if(this.sharedState) {\n                    this.setAttribute(propName,JSON.stringify(this.state))\n                }else{\n                    this.setAttribute(propName,value)\n                }\n            };\n        }\n        // current-state: getter / setter\n        if (propName === 'data-json') {\n            // getFn = () => {\n            //     return this.getAttribute(propName);\n            // };\n            setFn = (value) => {\n                let data = JSON.parse(value);\n                Object.keys(data).forEach((k) => {\n                    this.data[k] = data[k]\n                });\n                this.setAttribute(propName, value)\n            };\n        }\n        // obj[propName] = {get: getFn, set: setFn};\n        obj[this.kebabToLowerCamelCase(propName)] = {get: getFn, set: setFn};\n        Object.defineProperties(this, obj);\n    }\n\n    dispatch(eventName, detail) {\n        this.dispatchEvent(new CustomEvent(eventName, {bubbles: true, detail: detail}))\n    }\n\n    // state management\n    setState(state) {\n        if(typeof state === 'string' && !this.isJson(state)) {\n            console.error('setState only accepts an object as argument');\n            return;\n        }\n        if(typeof state === 'string' && this.isJson(state)) {\n            state = JSON.parse(state)\n        }\n        this.state = {...this.state, ...state};\n    }\n\n    getState(key) {\n        if(key && this.state[key]) {\n            return JSON.parse(JSON.stringify(this.state[key]));\n        }else{\n            return JSON.parse(JSON.stringify(this.state));\n        }\n    }\n\n    removeState(key) {\n        if(!key) {\n            this.state = {};\n            this.currentState = '{}';\n            this.preRender()\n        } else {\n            delete this.state[key]\n        }\n    }\n\n    // data management\n    setData(object, extend) {\n        if (extend) {\n            Object.keys(object).forEach((k, i) => {\n                this.data[k] = object[k];\n            });\n        } else {\n            this.data = object;\n        }\n        this.preRender();\n    }\n\n    getData() {\n        return this.data;\n    }\n\n    preRender() {\n        if (this.root) {\n            this.root.querySelector('.content')['innerHTML'] = this.render();\n        }\n    }\n\n    // utils\n    isJson(jsonString){\n        try {\n            let o = JSON.parse(jsonString);\n            if (o && typeof o === \"object\") { return o; }\n        }\n        catch (e) { }\n        return false;\n    };\n\n    kebabToLowerCamelCase(str) {\n        let string = str.charAt(0).toLowerCase() + str.slice(1);\n        return string.replace(/(\\-\\w)/g, function (m) {\n            return m[1].toUpperCase();\n        });\n    }\n\n}\n\n\n\n\n\n"]}