UNPKG

@nova-ui/bits

Version:

SolarWinds Nova Framework

92 lines 14.4 kB
// © 2022 SolarWinds Worldwide, LLC. All rights reserved. // // Permission is hereby granted, free of charge, to any person obtaining a copy // of this software and associated documentation files (the "Software"), to // deal in the Software without restriction, including without limitation the // rights to use, copy, modify, merge, publish, distribute, sublicense, and/or // sell copies of the Software, and to permit persons to whom the Software is // furnished to do so, subject to the following conditions: // // The above copyright notice and this permission notice shall be included in // all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN // THE SOFTWARE. import { DOCUMENT } from "@angular/common"; import { Inject, Injectable, Optional } from "@angular/core"; import { compressToBase64 } from "lz-string"; import { createAngularApp } from "./code-sandbox-files"; import { DEMO_PATH_TOKEN } from "../../../constants/path.constants"; import * as i0 from "@angular/core"; /** @dynamic */ export class CodeSandboxService { constructor(document, config) { this.document = document; this.config = config; } async open(prefix, sources) { async function mainVersion(packageName) { // only fetch tiny-tarball const res = await fetch("https://registry.npmjs.org/" + packageName, { headers: new Headers({ Accept: "application/vnd.npm.install-v1+json; q=1.0, application/json; q=0.8, */*", }), }); const json = await res.json(); return json["dist-tags"].latest; } const form = this.document.createElement("form"); const latestNovaVersion = await mainVersion("@nova-ui/bits"); const packageLib = sources.find((source) => source.fileName === "package.json")?.fileContent ?? ""; const files = createAngularApp(prefix, this.config.context, sources, packageLib.default, packageLib.default, latestNovaVersion); // TODO fix modification of less files // const modifySources = (source: string) => // Handle non-existent less references that are just killing plunker // source.replace(/^.*@import \(reference\).*$/gm, "/* NUI LESS VARIABLES ARE NOT SUPPORTED YET */"); // TODO add support for translations // form.append(this.formInput("translations", "ts", translations)); form.style.display = "none"; form.setAttribute("method", "POST"); form.setAttribute("action", "https://codesandbox.io/api/v1/sandboxes/define"); form.setAttribute("target", "_blank"); const parameters = this.compress(files); this.addHiddenInput(form, "parameters", parameters); this.document.body.appendChild(form); form.submit(); document.body.removeChild(form); } addHiddenInput(form, name, value) { const input = document.createElement("input"); input.type = "hidden"; input.name = name; input.value = value; form.appendChild(input); } compress(object) { return compressToBase64(JSON.stringify(object)) .replace(/\+/g, "-") // Convert '+' to '-' .replace(/\//g, "_") // Convert '/' to '_' .replace(/=+$/, ""); // Remove ending '=' } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CodeSandboxService, deps: [{ token: DOCUMENT }, { token: DEMO_PATH_TOKEN, optional: true }], target: i0.ɵɵFactoryTarget.Injectable }); } static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CodeSandboxService, providedIn: "root" }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CodeSandboxService, decorators: [{ type: Injectable, args: [{ providedIn: "root", }] }], ctorParameters: () => [{ type: Document, decorators: [{ type: Inject, args: [DOCUMENT] }] }, { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [DEMO_PATH_TOKEN] }] }] }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"code-sandbox.service.js","sourceRoot":"","sources":["../../../../../src/lib/docs/example-wrapper/code-sandbox.service.ts"],"names":[],"mappings":"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","sourcesContent":["// © 2022 SolarWinds Worldwide, LLC. All rights reserved.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n//  of this software and associated documentation files (the \"Software\"), to\n//  deal in the Software without restriction, including without limitation the\n//  rights to use, copy, modify, merge, publish, distribute, sublicense, and/or\n//  sell copies of the Software, and to permit persons to whom the Software is\n//  furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n//  all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n//  IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n//  FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n//  AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n//  LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n//  OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n//  THE SOFTWARE.\n\nimport { DOCUMENT } from \"@angular/common\";\nimport { Inject, Injectable, Optional } from \"@angular/core\";\nimport { compressToBase64 } from \"lz-string\";\n\nimport { createAngularApp } from \"./code-sandbox-files\";\nimport { DEMO_PATH_TOKEN } from \"../../../constants/path.constants\";\nimport {FileMetadata} from \"../services/sources.service\";\n\n/** @dynamic */\n@Injectable({\n    providedIn: \"root\",\n})\nexport class CodeSandboxService {\n    constructor(\n        @Inject(DOCUMENT) private document: Document,\n        @Optional() @Inject(DEMO_PATH_TOKEN) private config: any\n    ) {}\n\n    async open(prefix: string, sources: any): Promise<void> {\n        async function mainVersion(packageName: string) {\n            // only fetch tiny-tarball\n            const res = await fetch(\n                \"https://registry.npmjs.org/\" + packageName,\n                {\n                    headers: new Headers({\n                        Accept: \"application/vnd.npm.install-v1+json; q=1.0, application/json; q=0.8, */*\",\n                    }),\n                }\n            );\n            const json = await res.json();\n            return json[\"dist-tags\"].latest;\n        }\n\n        const form: HTMLFormElement = this.document.createElement(\"form\");\n\n        const latestNovaVersion = await mainVersion(\"@nova-ui/bits\");\n\n        const packageLib = sources.find(\n            (source: FileMetadata) => source.fileName === \"package.json\"\n        )?.fileContent ?? \"\";\n\n        const files = createAngularApp(\n            prefix,\n            this.config.context,\n            sources,\n            packageLib.default,\n            packageLib.default,\n            latestNovaVersion\n        );\n        // TODO fix modification of less files\n        // const modifySources = (source: string) => // Handle non-existent less references that are just killing plunker\n        //     source.replace(/^.*@import \\(reference\\).*$/gm, \"/* NUI LESS VARIABLES ARE NOT SUPPORTED YET */\");\n\n        // TODO add support for translations\n        // form.append(this.formInput(\"translations\", \"ts\", translations));\n\n        form.style.display = \"none\";\n        form.setAttribute(\"method\", \"POST\");\n        form.setAttribute(\n            \"action\",\n            \"https://codesandbox.io/api/v1/sandboxes/define\"\n        );\n        form.setAttribute(\"target\", \"_blank\");\n\n        const parameters = this.compress(files);\n        this.addHiddenInput(form, \"parameters\", parameters);\n\n        this.document.body.appendChild(form);\n        form.submit();\n        document.body.removeChild(form);\n    }\n\n    addHiddenInput(form: HTMLFormElement, name: string, value: any): void {\n        const input = document.createElement(\"input\");\n        input.type = \"hidden\";\n        input.name = name;\n        input.value = value;\n        form.appendChild(input);\n    }\n\n    compress(object: Record<string, object>): string {\n        return compressToBase64(JSON.stringify(object))\n            .replace(/\\+/g, \"-\") // Convert '+' to '-'\n            .replace(/\\//g, \"_\") // Convert '/' to '_'\n            .replace(/=+$/, \"\"); // Remove ending '='\n    }\n}\n"]}