UNPKG

@nova-ui/bits

Version:

SolarWinds Nova Framework

87 lines 24.2 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 { Component, Input } from "@angular/core"; import hljs from "highlight.js"; import javascript from "highlight.js/lib/languages/javascript"; import json from "highlight.js/lib/languages/json"; import less from "highlight.js/lib/languages/less"; import typescript from "highlight.js/lib/languages/typescript"; import xml from "highlight.js/lib/languages/xml"; import { CodeSandboxService } from "./code-sandbox.service"; import { SourcesService } from "../services/sources.service"; import * as i0 from "@angular/core"; import * as i1 from "../services/sources.service"; import * as i2 from "./code-sandbox.service"; import * as i3 from "@angular/common"; import * as i4 from "../../tabgroup/tab/tab.component"; import * as i5 from "../../tabgroup/tab-group/tab-group.component"; import * as i6 from "../../tooltip/tooltip.directive"; import * as i7 from "../../button/button.component"; import * as i8 from "../../image/image.component"; import * as i9 from "../copy-text/copy-text.component"; import * as i10 from "../example-code/example-code.component"; /** * @dynamic * @ignore */ export class ExampleWrapperComponent { constructor(sourcesService, codeSandboxService) { this.sourcesService = sourcesService; this.codeSandboxService = codeSandboxService; // Prefix of the example component's filenames this.filenamePrefix = ""; // Title to be displayed at the top of the example this.exampleTitle = ""; // Indicates whether the source code is being displayed this.showSource = false; hljs.registerLanguage("typescript", typescript); hljs.registerLanguage("javascript", javascript); hljs.registerLanguage("xml", xml); hljs.registerLanguage("json", json); hljs.registerLanguage("less", less); } getTooltip() { return this.showSource ? "Hide source code" : "Show source code"; } async openCodeSandboxExample() { await this.codeSandboxService.open(this.filenamePrefix, this.componentSources); } async ngOnInit() { this.componentSources = await this.sourcesService.getSourcesByFilenamePrefix(this.filenamePrefix) ?? []; } getExampleComponents(fileType) { return (this.componentSources?.find((component) => component.fileName.includes(this.filenamePrefix) && component.fileType === fileType)?.fileContent ?? ""); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ExampleWrapperComponent, deps: [{ token: i1.SourcesService }, { token: i2.CodeSandboxService }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: ExampleWrapperComponent, selector: "nui-example-wrapper", inputs: { filenamePrefix: "filenamePrefix", exampleTitle: "exampleTitle", showSource: "showSource" }, ngImport: i0, template: "<div class=\"nui-example-wrapper__container\">\n <div class=\"nui-example-wrapper__header\">\n <h4 class=\"nui-example-wrapper__title\">{{ exampleTitle }}</h4>\n <div>\n <button\n nui-button\n type=\"button\"\n displayStyle=\"action\"\n icon=\"{{\n showSource ? 'double-caret-up' : 'double-caret-down'\n }}\"\n title=\"Show source\"\n [nuiTooltip]=\"getTooltip()\"\n tooltipPlacement=\"bottom\"\n (click)=\"showSource = !showSource\"\n ></button>\n <button\n nui-button\n type=\"button\"\n displayStyle=\"action\"\n icon=\"external-link\"\n title=\"Open in CodeSandbox\"\n nuiTooltip=\"Open in Code Sandbox (only self-contained examples are opened properly)\"\n tooltipPlacement=\"bottom\"\n (click)=\"openCodeSandboxExample()\"\n ></button>\n </div>\n </div>\n <div *ngIf=\"showSource\" class=\"nui-example-wrapper__source\">\n <nui-tab-group>\n <nui-tab *ngIf=\"!!getExampleComponents('html')\" heading=\"HTML\">\n <div class=\"media-body\">\n <nui-copy-text\n fileContent=\"{{ getExampleComponents('html') }}\"\n ></nui-copy-text>\n <nui-example-code language=\"html\" [code]=\"getExampleComponents('html')\" />\n </div>\n </nui-tab>\n <nui-tab *ngIf=\"!!getExampleComponents('ts')\" heading=\"Typescript\">\n <nui-copy-text\n fileContent=\"{{ getExampleComponents('ts') }}\"\n ></nui-copy-text>\n <div class=\"media-body\">\n <nui-example-code language=\"typescript\" [code]=\"getExampleComponents('ts')\" />\n </div>\n </nui-tab>\n <nui-tab *ngIf=\"!!getExampleComponents('less')\" heading=\"Less\">\n <nui-copy-text\n fileContent=\"{{ getExampleComponents('less') }}\"\n ></nui-copy-text>\n <div class=\"media-body\">\n <nui-example-code\n *ngIf=\"!!getExampleComponents('less'); else noLess\"\n [code]=\"getExampleComponents('less')\"/>\n <ng-template #noLess>\n <nui-image image=\"no-data-to-show\"></nui-image>\n </ng-template>\n </div>\n </nui-tab>\n </nui-tab-group>\n </div>\n <div class=\"nui-example-wrapper__content\">\n <ng-content></ng-content>\n </div>\n</div>\n", styles: [".nui-example-wrapper__theme{display:inline-block}.nui-example-wrapper__content{background-color:var(--nui-color-bg-light,#fff)}.nui-example-wrapper__container{display:flex;flex-direction:column;border:1px solid;border-color:var(--nui-color-line-default,#d9d9d9);box-shadow:0 2px 2px #1111114d;margin-bottom:20px}.nui-example-wrapper__header{display:flex;flex-direction:row;background-color:var(--page-header-border-color,#d9d9d9);color:var(--nui-color-line-default,#d9d9d9);padding:5px 10px}.nui-example-wrapper__header button{outline:none}.nui-example-wrapper__title{flex-grow:1}.nui-example-wrapper__content{padding:20px}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.TabComponent, selector: "nui-tab", inputs: ["heading", "disabled", "templateRef", "active"], outputs: ["selected", "deselected"] }, { kind: "component", type: i5.TabGroupComponent, selector: "nui-tab-group", inputs: ["vertical"] }, { kind: "directive", type: i6.TooltipDirective, selector: "[nuiTooltip]", inputs: ["tooltipPlacement", "nuiTooltipDisabled", "nuiTooltipEllipsis", "nuiTooltip"], exportAs: ["nuiTooltip"] }, { kind: "component", type: i7.ButtonComponent, selector: "[nui-button]", inputs: ["displayStyle", "icon", "iconColor", "iconRight", "isBusy", "isEmpty", "ariaLabel", "isRepeat", "size"] }, { kind: "component", type: i8.ImageComponent, selector: "nui-image", inputs: ["image", "description", "float", "margin", "isWatermark", "width", "height", "autoFill"] }, { kind: "component", type: i9.CopyTextComponent, selector: "nui-copy-text", inputs: ["fileContent"] }, { kind: "component", type: i10.ExampleCodeComponent, selector: "nui-example-code", inputs: ["language", "code"] }] }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ExampleWrapperComponent, decorators: [{ type: Component, args: [{ selector: "nui-example-wrapper", template: "<div class=\"nui-example-wrapper__container\">\n <div class=\"nui-example-wrapper__header\">\n <h4 class=\"nui-example-wrapper__title\">{{ exampleTitle }}</h4>\n <div>\n <button\n nui-button\n type=\"button\"\n displayStyle=\"action\"\n icon=\"{{\n showSource ? 'double-caret-up' : 'double-caret-down'\n }}\"\n title=\"Show source\"\n [nuiTooltip]=\"getTooltip()\"\n tooltipPlacement=\"bottom\"\n (click)=\"showSource = !showSource\"\n ></button>\n <button\n nui-button\n type=\"button\"\n displayStyle=\"action\"\n icon=\"external-link\"\n title=\"Open in CodeSandbox\"\n nuiTooltip=\"Open in Code Sandbox (only self-contained examples are opened properly)\"\n tooltipPlacement=\"bottom\"\n (click)=\"openCodeSandboxExample()\"\n ></button>\n </div>\n </div>\n <div *ngIf=\"showSource\" class=\"nui-example-wrapper__source\">\n <nui-tab-group>\n <nui-tab *ngIf=\"!!getExampleComponents('html')\" heading=\"HTML\">\n <div class=\"media-body\">\n <nui-copy-text\n fileContent=\"{{ getExampleComponents('html') }}\"\n ></nui-copy-text>\n <nui-example-code language=\"html\" [code]=\"getExampleComponents('html')\" />\n </div>\n </nui-tab>\n <nui-tab *ngIf=\"!!getExampleComponents('ts')\" heading=\"Typescript\">\n <nui-copy-text\n fileContent=\"{{ getExampleComponents('ts') }}\"\n ></nui-copy-text>\n <div class=\"media-body\">\n <nui-example-code language=\"typescript\" [code]=\"getExampleComponents('ts')\" />\n </div>\n </nui-tab>\n <nui-tab *ngIf=\"!!getExampleComponents('less')\" heading=\"Less\">\n <nui-copy-text\n fileContent=\"{{ getExampleComponents('less') }}\"\n ></nui-copy-text>\n <div class=\"media-body\">\n <nui-example-code\n *ngIf=\"!!getExampleComponents('less'); else noLess\"\n [code]=\"getExampleComponents('less')\"/>\n <ng-template #noLess>\n <nui-image image=\"no-data-to-show\"></nui-image>\n </ng-template>\n </div>\n </nui-tab>\n </nui-tab-group>\n </div>\n <div class=\"nui-example-wrapper__content\">\n <ng-content></ng-content>\n </div>\n</div>\n", styles: [".nui-example-wrapper__theme{display:inline-block}.nui-example-wrapper__content{background-color:var(--nui-color-bg-light,#fff)}.nui-example-wrapper__container{display:flex;flex-direction:column;border:1px solid;border-color:var(--nui-color-line-default,#d9d9d9);box-shadow:0 2px 2px #1111114d;margin-bottom:20px}.nui-example-wrapper__header{display:flex;flex-direction:row;background-color:var(--page-header-border-color,#d9d9d9);color:var(--nui-color-line-default,#d9d9d9);padding:5px 10px}.nui-example-wrapper__header button{outline:none}.nui-example-wrapper__title{flex-grow:1}.nui-example-wrapper__content{padding:20px}\n"] }] }], ctorParameters: () => [{ type: i1.SourcesService }, { type: i2.CodeSandboxService }], propDecorators: { filenamePrefix: [{ type: Input }], exampleTitle: [{ type: Input }], showSource: [{ type: Input }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"example-wrapper.component.js","sourceRoot":"","sources":["../../../../../src/lib/docs/example-wrapper/example-wrapper.component.ts","../../../../../src/lib/docs/example-wrapper/example-wrapper.component.html"],"names":[],"mappings":"AAAA,yDAAyD;AACzD,EAAE;AACF,+EAA+E;AAC/E,4EAA4E;AAC5E,8EAA8E;AAC9E,+EAA+E;AAC/E,8EAA8E;AAC9E,4DAA4D;AAC5D,EAAE;AACF,6EAA6E;AAC7E,uDAAuD;AACvD,EAAE;AACF,6EAA6E;AAC7E,4EAA4E;AAC5E,+EAA+E;AAC/E,0EAA0E;AAC1E,iFAAiF;AACjF,6EAA6E;AAC7E,iBAAiB;AAEjB,OAAO,EAAE,SAAS,EAAE,KAAK,EAAU,MAAM,eAAe,CAAC;AACzD,OAAO,IAAI,MAAM,cAAc,CAAC;AAChC,OAAO,UAAU,MAAM,uCAAuC,CAAC;AAC/D,OAAO,IAAI,MAAM,iCAAiC,CAAC;AACnD,OAAO,IAAI,MAAM,iCAAiC,CAAC;AACnD,OAAO,UAAU,MAAM,uCAAuC,CAAC;AAC/D,OAAO,GAAG,MAAM,gCAAgC,CAAC;AAEjD,OAAO,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAC5D,OAAO,EAAgB,cAAc,EAAE,MAAM,6BAA6B,CAAC;;;;;;;;;;;;AAE3E;;;GAGG;AAMH,MAAM,OAAO,uBAAuB;IAYhC,YACY,cAA8B,EAC9B,kBAAsC;QADtC,mBAAc,GAAd,cAAc,CAAgB;QAC9B,uBAAkB,GAAlB,kBAAkB,CAAoB;QAblD,8CAA8C;QACrC,mBAAc,GAAW,EAAE,CAAC;QAErC,kDAAkD;QACzC,iBAAY,GAAW,EAAE,CAAC;QAEnC,uDAAuD;QAC9C,eAAU,GAAG,KAAK,CAAC;QAQxB,IAAI,CAAC,gBAAgB,CAAC,YAAY,EAAE,UAAU,CAAC,CAAC;QAChD,IAAI,CAAC,gBAAgB,CAAC,YAAY,EAAE,UAAU,CAAC,CAAC;QAChD,IAAI,CAAC,gBAAgB,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;QAClC,IAAI,CAAC,gBAAgB,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;QACpC,IAAI,CAAC,gBAAgB,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;IACxC,CAAC;IAEM,UAAU;QACb,OAAO,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,kBAAkB,CAAC;IACrE,CAAC;IAEM,KAAK,CAAC,sBAAsB;QAC/B,MAAM,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAC9B,IAAI,CAAC,cAAc,EACnB,IAAI,CAAC,gBAAgB,CACxB,CAAC;IACN,CAAC;IAEM,KAAK,CAAC,QAAQ;QACjB,IAAI,CAAC,gBAAgB;YACjB,MAAM,IAAI,CAAC,cAAc,CAAC,0BAA0B,CAChD,IAAI,CAAC,cAAc,CACtB,IAAI,EAAE,CAAC;IAChB,CAAC;IAEM,oBAAoB,CAAC,QAAgB;QACxC,OAAO,CACH,IAAI,CAAC,gBAAgB,EAAE,IAAI,CACvB,CAAC,SAAS,EAAE,EAAE,CACV,SAAS,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,cAAc,CAAC;YAChD,SAAS,CAAC,QAAQ,KAAK,QAAQ,CACtC,EAAE,WAAW,IAAI,EAAE,CACvB,CAAC;IACN,CAAC;+GAjDQ,uBAAuB;mGAAvB,uBAAuB,iKCxCpC,uxFAiEA;;4FDzBa,uBAAuB;kBALnC,SAAS;+BAEI,qBAAqB;oHAKtB,cAAc;sBAAtB,KAAK;gBAGG,YAAY;sBAApB,KAAK;gBAGG,UAAU;sBAAlB,KAAK","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 { Component, Input, OnInit } from \"@angular/core\";\nimport hljs from \"highlight.js\";\nimport javascript from \"highlight.js/lib/languages/javascript\";\nimport json from \"highlight.js/lib/languages/json\";\nimport less from \"highlight.js/lib/languages/less\";\nimport typescript from \"highlight.js/lib/languages/typescript\";\nimport xml from \"highlight.js/lib/languages/xml\";\n\nimport { CodeSandboxService } from \"./code-sandbox.service\";\nimport { FileMetadata, SourcesService } from \"../services/sources.service\";\n\n/**\n * @dynamic\n * @ignore\n */\n@Component({\n    templateUrl: \"./example-wrapper.component.html\",\n    selector: \"nui-example-wrapper\",\n    styleUrls: [\"./example-wrapper.component.less\"],\n})\nexport class ExampleWrapperComponent implements OnInit {\n    // Prefix of the example component's filenames\n    @Input() filenamePrefix: string = \"\";\n\n    // Title to be displayed at the top of the example\n    @Input() exampleTitle: string = \"\";\n\n    // Indicates whether the source code is being displayed\n    @Input() showSource = false;\n\n    public componentSources: FileMetadata[];\n\n    constructor(\n        private sourcesService: SourcesService,\n        private codeSandboxService: CodeSandboxService\n    ) {\n        hljs.registerLanguage(\"typescript\", typescript);\n        hljs.registerLanguage(\"javascript\", javascript);\n        hljs.registerLanguage(\"xml\", xml);\n        hljs.registerLanguage(\"json\", json);\n        hljs.registerLanguage(\"less\", less);\n    }\n\n    public getTooltip(): string {\n        return this.showSource ? \"Hide source code\" : \"Show source code\";\n    }\n\n    public async openCodeSandboxExample(): Promise<void> {\n        await this.codeSandboxService.open(\n            this.filenamePrefix,\n            this.componentSources\n        );\n    }\n\n    public async ngOnInit(): Promise<void> {\n        this.componentSources =\n            await this.sourcesService.getSourcesByFilenamePrefix(\n                this.filenamePrefix\n            ) ?? [];\n    }\n\n    public getExampleComponents(fileType: string): string {\n        return (\n            this.componentSources?.find(\n                (component) =>\n                    component.fileName.includes(this.filenamePrefix) &&\n                    component.fileType === fileType\n            )?.fileContent ?? \"\"\n        );\n    }\n}\n","<div class=\"nui-example-wrapper__container\">\n    <div class=\"nui-example-wrapper__header\">\n        <h4 class=\"nui-example-wrapper__title\">{{ exampleTitle }}</h4>\n        <div>\n            <button\n                nui-button\n                type=\"button\"\n                displayStyle=\"action\"\n                icon=\"{{\n                    showSource ? 'double-caret-up' : 'double-caret-down'\n                }}\"\n                title=\"Show source\"\n                [nuiTooltip]=\"getTooltip()\"\n                tooltipPlacement=\"bottom\"\n                (click)=\"showSource = !showSource\"\n            ></button>\n            <button\n                nui-button\n                type=\"button\"\n                displayStyle=\"action\"\n                icon=\"external-link\"\n                title=\"Open in CodeSandbox\"\n                nuiTooltip=\"Open in Code Sandbox (only self-contained examples are opened properly)\"\n                tooltipPlacement=\"bottom\"\n                (click)=\"openCodeSandboxExample()\"\n            ></button>\n        </div>\n    </div>\n    <div *ngIf=\"showSource\" class=\"nui-example-wrapper__source\">\n        <nui-tab-group>\n            <nui-tab *ngIf=\"!!getExampleComponents('html')\" heading=\"HTML\">\n                <div class=\"media-body\">\n                    <nui-copy-text\n                        fileContent=\"{{ getExampleComponents('html') }}\"\n                    ></nui-copy-text>\n                    <nui-example-code language=\"html\" [code]=\"getExampleComponents('html')\" />\n                </div>\n            </nui-tab>\n            <nui-tab *ngIf=\"!!getExampleComponents('ts')\" heading=\"Typescript\">\n                <nui-copy-text\n                    fileContent=\"{{ getExampleComponents('ts') }}\"\n                ></nui-copy-text>\n                <div class=\"media-body\">\n                    <nui-example-code language=\"typescript\" [code]=\"getExampleComponents('ts')\" />\n                </div>\n            </nui-tab>\n            <nui-tab *ngIf=\"!!getExampleComponents('less')\" heading=\"Less\">\n                <nui-copy-text\n                    fileContent=\"{{ getExampleComponents('less') }}\"\n                ></nui-copy-text>\n                <div class=\"media-body\">\n                    <nui-example-code\n                        *ngIf=\"!!getExampleComponents('less'); else noLess\"\n                        [code]=\"getExampleComponents('less')\"/>\n                    <ng-template #noLess>\n                        <nui-image image=\"no-data-to-show\"></nui-image>\n                    </ng-template>\n                </div>\n            </nui-tab>\n        </nui-tab-group>\n    </div>\n    <div class=\"nui-example-wrapper__content\">\n        <ng-content></ng-content>\n    </div>\n</div>\n"]}