@nova-ui/bits
Version:
SolarWinds Nova Framework
92 lines • 14.4 kB
JavaScript
// © 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"]}