json-to-table-com
Version:
A JSON-to-Table Converter Package for Converting JSON Data into Tabular Format for Enhanced Visualization
132 lines • 24.3 kB
JavaScript
// Author : Kavindu Yasintha Silva
// Import the core angular services.
import { ChangeDetectionStrategy, Input } from "@angular/core";
import { Component } from "@angular/core";
import * as i0 from "@angular/core";
import * as i1 from "@angular/common";
export class JsonToTableComponent {
// I initialize the json tree component.
constructor(changeDetectorRef) {
this.changeDetectorRef = changeDetectorRef;
this.collapsedEntries = Object.create(null);
this.entryCount = 0;
this.isCollapsed = false;
this.value = "";
this.valueType = this.calculateType(this.value);
// this.changeDetectorRef.detectChanges()
}
// ---
// PUBLIC METHODS.
// ---
// I calculate the Type for the given value.
calculateType(target) {
if (target === null) {
return ("Null");
}
if (typeof (target) === "string") {
return ("String");
}
if (typeof (target) === "number") {
return ("Number");
}
if (typeof (target) === "boolean") {
return ("Boolean");
}
if (Array.isArray(target)) {
return ("Array");
}
return ("Object");
}
// I get called when the input bindings have been updated.
ngOnChanges() {
this.entryCount = 0;
this.isCollapsed = false;
this.valueType = this.calculateType(this.value);
this.clearCollapsedEntries();
if (this.valueType === "Object") {
this.entryCount = Object.keys(this.value).length;
}
else if (this.valueType === "Array") {
this.entryCount = this.value.length;
}
}
// I attempt to parse the current String value as a JSON payload.
// --
// NOTE: This overrides the passed-in state at this point in the JSON Tree.
parseString(event) {
if (!event.metaKey) {
return;
}
try {
this.value = JSON.parse(this.value);
this.ngOnChanges();
console.group("String Parsing");
console.log("The value was successfully parsed as JSON.");
console.log(this.value);
console.groupEnd();
}
catch (error) {
console.group("String Parsing");
console.warn("The value could not be parsed as JSON.");
console.error(error);
console.log(this.value);
console.groupEnd();
}
}
// I toggle the expansion of the given value.
toggle(index) {
// Top-level toggle.
if (index === undefined) {
this.isCollapsed = !this.isCollapsed;
// If we're collapsing the top-level value, then reset any settings for the
// sub-entry visibility.
if (this.isCollapsed) {
this.clearCollapsedEntries();
}
// Sub-entry toggle.
}
else {
this.collapsedEntries[index] = !this.collapsedEntries[index];
}
}
// ---
// PRIVATE METHODS.
// ---
// I clear the collapsed entries index.
clearCollapsedEntries() {
for (var key in this.collapsedEntries) {
delete (this.collapsedEntries[key]);
}
}
ngAfterViewInit() {
}
updateData(apiResponse) {
this.collapsedEntries = Object.create(null);
this.entryCount = 0;
this.isCollapsed = false;
this.value = apiResponse;
console.log(this.value);
this.valueType = this.calculateType(this.value);
// this.changeDetectorRef.detectChanges()
}
assertStringKey(key) {
return key;
}
ngOnInit() {
}
}
JsonToTableComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: JsonToTableComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
JsonToTableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: JsonToTableComponent, selector: "AutoJsonComponent", inputs: { value: "value" }, usesOnChanges: true, ngImport: i0, template: "<div\n class=\"payload\"\n [ngSwitch]=\"valueType\">\n\n <ng-template ngSwitchCase=\"Null\">\n\n <ng-template [ngIf]=\"( ! isCollapsed )\">\n <div class=\"value is-null\">\n null\n </div>\n </ng-template>\n </ng-template>\n\n <ng-template ngSwitchCase=\"String\">\n\n <ng-template [ngIf]=\"( ! isCollapsed )\">\n <div class=\"value is-string\">\n <a (click)=\"parseString( $event )\">\n {{ value }}\n </a>\n </div>\n </ng-template>\n </ng-template>\n\n <ng-template ngSwitchCase=\"Number\">\n\n <ng-template [ngIf]=\"( ! isCollapsed )\">\n <div class=\"value is-number\">\n {{ value }}\n </div>\n </ng-template>\n </ng-template>\n\n <ng-template ngSwitchCase=\"Boolean\">\n\n <ng-template [ngIf]=\"( ! isCollapsed )\">\n <div class=\"value is-boolean\">\n {{ value }}\n </div>\n </ng-template>\n </ng-template>\n\n <ng-template ngSwitchCase=\"Array\">\n <div\n (click)=\"toggle()\"\n class=\"header is-array\"\n [class.is-collapsed]=\"isCollapsed\">\n <div class=\"type\">\n Array\n </div>\n <div class=\"entry-count\">\n Entries: {{ entryCount }}\n </div>\n </div>\n <ng-template [ngIf]=\"( ! isCollapsed )\">\n <ng-template ngFor let-subvalue let-index=\"index\" [ngForOf]=\"value\">\n <div\n (click)=\"toggle( index )\"\n class=\"label is-array\"\n [class.is-collapsed]=\"collapsedEntries[ index ]\">\n {{ index }}\n </div>\n <ng-template [ngIf]=\"( ! collapsedEntries[ index ] )\">\n <div class=\"value is-array\">\n <AutoJsonComponent [value]=\"subvalue\"></AutoJsonComponent>\n </div>\n </ng-template>\n </ng-template>\n </ng-template>\n </ng-template>\n\n <ng-template ngSwitchCase=\"Object\">\n\n <ng-template [ngIf]=\"!isCollapsed\">\n <ng-template ngFor let-subvalue [ngForOf]=\"value | keyvalue\">\n <div\n (click)=\"toggle(assertStringKey(subvalue.key))\"\n class=\"label is-object\"\n [class.is-collapsed]=\"collapsedEntries[assertStringKey(subvalue.key)]\">\n {{ subvalue.key }}\n </div>\n <ng-template [ngIf]=\"!collapsedEntries[assertStringKey(subvalue.key)]\">\n <div class=\"value is-object\">\n <AutoJsonComponent [value]=\"subvalue.value\"></AutoJsonComponent>\n </div>\n </ng-template>\n </ng-template>\n </ng-template>\n </ng-template>\n\n\n</div>\n", styles: [":host{display:block}.payload{display:inline-grid;grid-gap:0px;grid-template-columns:min-content;border:1px solid #dddddd;width:100%}.header{border:1px solid #dddddd;border-radius:3px;background-color:#dd0330;cursor:pointer;grid-column:1 / span 2;padding:6px}.header.is-null{background-color:#dd0330;border-color:#ddd}.header.is-string{background-color:#dd0330;border-color:#dd0330}.header.is-number{background-color:#df5e73;border-color:#df5e73}.header.is-boolean{background-color:#df5e73;border-color:#df5e73}.header.is-array{background-color:#e58494;border-color:#e58494}.header.is-object{background-color:#cc4c5c;border-color:#cc4c5c}.header.is-collapsed{background-color:#cc2c44;border-color:#cc2c44}.entry-count{margin-top:4px}.label{background-color:#ddd;border:1px solid #dddddd;border-radius:3px;cursor:pointer;grid-column:1 / span 1;padding:4px}.label.is-null{background-color:#ddd;border-color:#ccc}.label.is-string{background-color:#ffc900;border-color:#f3b700}.label.is-number{background-color:#ffc900;border-color:#f3b700}.label.is-boolean{background-color:#ffc900;border-color:#f3b700}.label.is-array{background-color:#df5e73;border-color:#df5e73;color:#fff}.label.is-object{background-color:#fff;border-color:#ddd}.value{background-color:#f0f0f0;border:1px solid #dddddd;border-radius:3px;grid-column:2 / span 1;padding:4px}.value.is-null{background-color:#f2f2f2;border-color:#ddd}.value.is-string{background-color:#f2f2f2;border-color:#ddd}.value.is-number{background-color:#f2f2f2;border-color:#ddd}.value.is-boolean{background-color:#f2f2f2;border-color:#ddd}.value.is-array{background-color:#f2f2f2;border-color:#ddd}.value.is-object{background-color:#fff;border-color:#ddd}.value.is-string a{width:475px;word-wrap:break-word;display:inline-block}\n"], components: [{ type: JsonToTableComponent, selector: "AutoJsonComponent", inputs: ["value"] }], directives: [{ type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "keyvalue": i1.KeyValuePipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: JsonToTableComponent, decorators: [{
type: Component,
args: [{
selector: "AutoJsonComponent",
inputs: ["value"],
changeDetection: ChangeDetectionStrategy.OnPush,
styleUrls: ["./json-to-table.component.css"],
templateUrl: "./json-to-table.component.html"
}]
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { value: [{
type: Input
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"json-to-table.component.js","sourceRoot":"","sources":["../../../../projects/json-to-table/src/lib/json-to-table.component.ts","../../../../projects/json-to-table/src/lib/json-to-table.component.html"],"names":[],"mappings":"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","sourcesContent":["\n// Author : Kavindu Yasintha Silva\n\n// Import the core angular services.\nimport {AfterViewInit, ChangeDetectionStrategy, ChangeDetectorRef, Input, OnInit} from \"@angular/core\";\nimport { Component } from \"@angular/core\";\n\n\n// ----------------------------------------------------------------------------------- //\n// ----------------------------------------------------------------------------------- //\n\n// CAUTION: The value bound this component is ASSUMED to be the result of a JSON.parse()\n// call. As such, it does NOT SUPPORT the full set of JavaScript data-types. Instead, it\n// only supports those that can be encoded in a JSON payload.\ntype ValueType =\n  | \"Null\"\n  | \"String\"\n  | \"Number\"\n  | \"Boolean\"\n  | \"Array\"\n  | \"Object\"\n  ;\n\ninterface CollapsedEntries {\n  [ key: string ]: boolean;\n}\n\n@Component({\n  selector: \"AutoJsonComponent\",\n  inputs: [ \"value\" ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  styleUrls: [ \"./json-to-table.component.css\" ],\n  templateUrl: \"./json-to-table.component.html\"\n})\nexport class JsonToTableComponent implements OnInit,AfterViewInit {\n\n  public collapsedEntries: CollapsedEntries;\n  public entryCount: number;\n  public isCollapsed: boolean;\n  @Input() value: any;\n  public valueType: ValueType;\n\n  // I initialize the json tree component.\n  constructor(private changeDetectorRef: ChangeDetectorRef) {\n    this.collapsedEntries = Object.create( null );\n    this.entryCount = 0;\n    this.isCollapsed = false;\n    this.value =  \"\"\n    this.valueType = this.calculateType( this.value );\n    // this.changeDetectorRef.detectChanges()\n  }\n\n\n  // ---\n  // PUBLIC METHODS.\n  // ---\n\n  // I calculate the Type for the given value.\n  public calculateType( target: any ) : ValueType {\n\n    if ( target === null ) {\n\n      return( \"Null\" );\n\n    }\n\n    if ( typeof( target ) === \"string\" ) {\n\n      return( \"String\" );\n\n    }\n\n    if ( typeof( target ) === \"number\" ) {\n\n      return( \"Number\" );\n\n    }\n\n    if ( typeof( target ) === \"boolean\" ) {\n\n      return( \"Boolean\" );\n\n    }\n\n    if ( Array.isArray( target ) ) {\n\n      return( \"Array\" );\n\n    }\n\n    return( \"Object\" );\n\n  }\n\n\n  // I get called when the input bindings have been updated.\n  public ngOnChanges() : void {\n\n    this.entryCount = 0;\n    this.isCollapsed = false;\n    this.valueType = this.calculateType( this.value );\n    this.clearCollapsedEntries();\n\n    if ( this.valueType === \"Object\" ) {\n\n      this.entryCount = Object.keys( this.value ).length;\n\n    } else if ( this.valueType === \"Array\" ) {\n\n      this.entryCount = this.value.length;\n\n    }\n\n  }\n\n\n  // I attempt to parse the current String value as a JSON payload.\n  // --\n  // NOTE: This overrides the passed-in state at this point in the JSON Tree.\n  public parseString( event: any ) : void {\n\n\n    if ( ! event.metaKey ) {\n\n      return;\n\n    }\n\n\n\n    try {\n\n      this.value = JSON.parse( this.value );\n      this.ngOnChanges();\n\n      console.group( \"String Parsing\" );\n      console.log( \"The value was successfully parsed as JSON.\" );\n      console.log( this.value );\n      console.groupEnd();\n\n    } catch ( error ) {\n\n      console.group( \"String Parsing\" );\n      console.warn( \"The value could not be parsed as JSON.\" );\n      console.error( error );\n      console.log( this.value );\n      console.groupEnd();\n\n    }\n\n  }\n\n\n  // I toggle the expansion of the given value.\n  public toggle( index?: string | number ) : void {\n\n    // Top-level toggle.\n    if ( index === undefined ) {\n\n      this.isCollapsed = ! this.isCollapsed;\n\n      // If we're collapsing the top-level value, then reset any settings for the\n      // sub-entry visibility.\n      if ( this.isCollapsed ) {\n\n        this.clearCollapsedEntries();\n\n      }\n\n      // Sub-entry toggle.\n    } else {\n\n      this.collapsedEntries[ index ] = ! this.collapsedEntries[ index ];\n\n    }\n\n  }\n\n  // ---\n  // PRIVATE METHODS.\n  // ---\n\n  // I clear the collapsed entries index.\n  private clearCollapsedEntries() : void {\n\n    for ( var key in this.collapsedEntries ) {\n\n      delete( this.collapsedEntries[ key ] );\n\n    }\n\n  }\n\n  ngAfterViewInit(): void {\n  }\n\n  updateData(apiResponse:any):void{\n    this.collapsedEntries = Object.create( null );\n    this.entryCount = 0;\n    this.isCollapsed = false;\n    this.value =  apiResponse\n    console.log(this.value );\n    this.valueType = this.calculateType( this.value );\n    // this.changeDetectorRef.detectChanges()\n\n  }\n  assertStringKey(key: unknown): string {\n    return key as string;\n  }\n\n  ngOnInit(): void {\n\n  }\n\n}\n","<div\n  class=\"payload\"\n  [ngSwitch]=\"valueType\">\n\n  <ng-template ngSwitchCase=\"Null\">\n\n    <ng-template [ngIf]=\"( ! isCollapsed )\">\n      <div class=\"value is-null\">\n        null\n      </div>\n    </ng-template>\n  </ng-template>\n\n  <ng-template ngSwitchCase=\"String\">\n\n    <ng-template [ngIf]=\"( ! isCollapsed )\">\n      <div class=\"value is-string\">\n        <a (click)=\"parseString( $event )\">\n          {{ value }}\n        </a>\n      </div>\n    </ng-template>\n  </ng-template>\n\n  <ng-template ngSwitchCase=\"Number\">\n\n    <ng-template [ngIf]=\"( ! isCollapsed )\">\n      <div class=\"value is-number\">\n        {{ value }}\n      </div>\n    </ng-template>\n  </ng-template>\n\n  <ng-template ngSwitchCase=\"Boolean\">\n\n    <ng-template [ngIf]=\"( ! isCollapsed )\">\n      <div class=\"value is-boolean\">\n        {{ value }}\n      </div>\n    </ng-template>\n  </ng-template>\n\n  <ng-template ngSwitchCase=\"Array\">\n    <div\n      (click)=\"toggle()\"\n      class=\"header is-array\"\n      [class.is-collapsed]=\"isCollapsed\">\n      <div class=\"type\">\n        Array\n      </div>\n      <div class=\"entry-count\">\n        Entries: {{ entryCount }}\n      </div>\n    </div>\n    <ng-template [ngIf]=\"( ! isCollapsed )\">\n      <ng-template ngFor let-subvalue let-index=\"index\" [ngForOf]=\"value\">\n        <div\n          (click)=\"toggle( index )\"\n          class=\"label is-array\"\n          [class.is-collapsed]=\"collapsedEntries[ index ]\">\n          {{ index }}\n        </div>\n        <ng-template [ngIf]=\"( ! collapsedEntries[ index ] )\">\n          <div class=\"value is-array\">\n            <AutoJsonComponent [value]=\"subvalue\"></AutoJsonComponent>\n          </div>\n        </ng-template>\n      </ng-template>\n    </ng-template>\n  </ng-template>\n\n  <ng-template ngSwitchCase=\"Object\">\n\n    <ng-template [ngIf]=\"!isCollapsed\">\n      <ng-template ngFor let-subvalue [ngForOf]=\"value | keyvalue\">\n        <div\n          (click)=\"toggle(assertStringKey(subvalue.key))\"\n          class=\"label is-object\"\n          [class.is-collapsed]=\"collapsedEntries[assertStringKey(subvalue.key)]\">\n          {{ subvalue.key }}\n        </div>\n        <ng-template [ngIf]=\"!collapsedEntries[assertStringKey(subvalue.key)]\">\n          <div class=\"value is-object\">\n            <AutoJsonComponent [value]=\"subvalue.value\"></AutoJsonComponent>\n          </div>\n        </ng-template>\n      </ng-template>\n    </ng-template>\n  </ng-template>\n\n\n</div>\n"]}