UNPKG

@rxdi/ui-kit

Version:

UI Components for building graphql-server website

141 lines 5.88 kB
"use strict"; 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); }; var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } return new (P || (P = Promise))(function (resolve, reject) { function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } step((generator = generator.apply(thisArg, _arguments || [])).next()); }); }; Object.defineProperty(exports, "__esModule", { value: true }); exports.MonadComponent = void 0; const lit_html_1 = require("@rxdi/lit-html"); const shades_1 = require("shades"); const rxjs_1 = require("rxjs"); const operators_1 = require("rxjs/operators"); /** * @customElement rx-monad */ let MonadComponent = class MonadComponent extends lit_html_1.LitElement { OnUpdateFirst() { return __awaiter(this, void 0, void 0, function* () { const nodes = this.shadowRoot.querySelector('slot').assignedNodes(); const renderComponent = this.findNode(nodes, 'rx-render'); const fetchComponent = this.findNode(nodes, 'rx-fetch'); const stateComponent = this.findNode(nodes, 'rx-state'); const styleComponent = this.findNode(nodes, 'rx-style'); const settingsComponent = this.findNode(nodes, 'rx-settings'); const lensComponent = this.findNode(nodes, 'rx-lens'); let fetch; let state = yield stateComponent.value; if (lensComponent.match) { state = this.get(state, lensComponent.match); } else if (lensComponent.get) { lensComponent.get = lensComponent.get.map(a => a === 'all' ? shades_1.all : a); if ((0, rxjs_1.isObservable)(state)) { state = state.pipe((0, operators_1.map)(s => { const expectedState = shades_1.get(...lensComponent.get)(s); if (!expectedState) { return s; } return expectedState; })); } else { state = shades_1.get(...lensComponent.get)(state); } if (lensComponent.ray) { state = lensComponent.ray(state); } } else if (lensComponent.ray) { if ((0, rxjs_1.isObservable)(state)) { state = state.pipe((0, operators_1.map)(s => lensComponent.ray(s))); } else { state = lensComponent.ray(state); } } if (fetchComponent.query) { fetch = this.trim(fetchComponent.query, 'query'); } if (fetchComponent.subscribe) { fetch = this.trim(fetchComponent.subscribe, 'subscription'); } if (fetchComponent.mutate) { fetch = this.trim(fetchComponent.mutate, 'mutation'); } this.options = { settings: settingsComponent.value, state, fetch, style: styleComponent.value, render: renderComponent.state }; }); } trim(query = '', type) { if (query.includes(type)) { return query; } const trimmedQuery = query.trim().replace(/\s/g, ''); return `${type} ${trimmedQuery}`; } modState(args, state) { return new Promise((resolve, reject) => { try { (0, shades_1.mod)(args[0], args[1], args[2], args[3], args[4])(resolve)(state); } catch (e) { reject(e); } }); } findNode(nodes, localName) { const node = nodes.find(n => n && n.nextSibling && n.nextSibling.localName === localName); if (node) { return node.nextSibling; } return { value: null }; } get(obj = {}, path = '', defaultValue) { return (path .replace(/\[(.+?)\]/g, '.$1') .split('.') .reduce((o, key) => o[key], obj) || defaultValue); } }; __decorate([ (0, lit_html_1.property)({ type: Object }), __metadata("design:type", Object) ], MonadComponent.prototype, "options", void 0); MonadComponent = __decorate([ (0, lit_html_1.Component)({ selector: 'rx-monad', template() { return (0, lit_html_1.html) ` <slot></slot> ${this.options ? (0, lit_html_1.html) ` <rx-graph .options=${this.options}></rx-graph> ` : ''} `; } }) ], MonadComponent); exports.MonadComponent = MonadComponent; //# sourceMappingURL=monad.component.js.map