Coder Social home page Coder Social logo

maaxgr / ang-jsoneditor Goto Github PK

View Code? Open in Web Editor NEW

This project forked from mariohmol/ang-jsoneditor

12.0 2.0 16.0 1.21 MB

Jsoneditor for Angular 11, 12, 13 and 14

License: MIT License

TypeScript 83.65% JavaScript 8.98% HTML 6.96% SCSS 0.40%
jsoneditor angular typescript javascript

ang-jsoneditor's Introduction

Angular Json Editor

About this repository

This is a fork of mariohmol's ang-jsoneditor with support for Angular 11, 12, 13 and 14. This repository will probably become stale, when the original will be actively maintained again.

About the project

Angular wrapper for jsoneditor). A library with that you can view and edit json content interactively.

Demo Image

Installation

1. Install "jsoneditor"

The wrapped library is not packaged in this library.
You have to install it via npm i [email protected]

2. Install this wrapper library

To install this library with npm, run one of the command below:

Compatibility Command Stability
Angular 11 npm install @maaxgr/ang-jsoneditor@11 Stable
Angular 12 npm install @maaxgr/ang-jsoneditor@12 Stable
Angular 13 npm install @maaxgr/ang-jsoneditor@13 Stable
Angular 14 npm install @maaxgr/ang-jsoneditor@14 Stable

WARNING: Although versions are marked as stable, there can be still bugs because this project isn't heavily integrated in a lot of production projects

Usage

Minimal Example

First import Module in module.ts:

// For Angular 11 + 12 
import { NgJsonEditorModule } from '@maaxgr/ang-jsoneditor'
// Starting Angular 13
import { AngJsoneditorModule } from '@maaxgr/ang-jsoneditor'

@NgModule({
  declarations: [
    AppComponent
  ],
  imports: [
    ....,
    // For Angular 11 + 12 
    NgJsonEditorModule,
    // Starting Angular 13
    AngJsoneditorModule,
  ],
  providers: [],
  bootstrap: [AppComponent]
})
export class AppModule { }

Then setup your component models as below:

import {Component} from '@angular/core';
import {JsonEditorOptions} from "@maaxgr/ang-jsoneditor";

@Component({
  selector: 'app-root',
  template: '<json-editor [options]="editorOptions" [data]="initialData" (change)="showJson($event)"></json-editor>' +
    '<div>{{ visibleData | json }}</div>'
})
export class AppComponent {

  public editorOptions: JsonEditorOptions;
  public initialData: any;
  public visibleData: any;

  constructor() {
    this.editorOptions = new JsonEditorOptions()
    this.editorOptions.modes = ['code', 'text', 'tree', 'view'];

    this.initialData = {"products":[{"name":"car","product":[{"name":"honda","model":[{"id":"civic","name":"civic"},{"id":"accord","name":"accord"},{"id":"crv","name":"crv"},{"id":"pilot","name":"pilot"},{"id":"odyssey","name":"odyssey"}]}]}]}
    this.visibleData = this.initialData;
  }

  showJson(d: Event) {
    this.visibleData = d;
  }

}

Add Style to style.scss:

@import "~jsoneditor/dist/jsoneditor.min.css";

Access Component

For deeper configuration, add this to component.ts:

@ViewChild(JsonEditorComponent, { static: false }) editor!: JsonEditorComponent;

Forms

Build it integrated with ReactiveForms:

this.form = this.fb.group({
  myinput: [this.data]
});
<form [formGroup]="form" (submit)="submit()">
    <json-editor [options]="editorOptions2" formControlName="myinput">
    </json-editor>
</form>

Extra Features

Besides all the configuration options from the original jsoneditor, Angular Json Editor supports one additional option:

=> expandAll: to automatically expand all nodes upon json loaded with the data input.

Troubleshoot

If you have issue with the height of the component, you can try one of those solutions:

When you import CSS:

@import "~jsoneditor/dist/jsoneditor.min.css";
textarea.jsoneditor-text{min-height:350px;}

Or Customizing the CSS:

:host ::ng-deep json-editor,
:host ::ng-deep json-editor .jsoneditor,
:host ::ng-deep json-editor > div,
:host ::ng-deep json-editor jsoneditor-outer {
  height: 500px;
}

Or as a inner style in component:

<json-editor class="col-md-12" #editorExample style="min-height: 300px;" [options]="editorOptionsData" [data]="dataStructure"></json-editor>

For code view you can change the height using this example:

.ace_editor.ace-jsoneditor {
  min-height: 500px;
}

Use debug mode to see in your console the data and options passed to jsoneditor. Copy this and paste in your issue when reporting bugs.

<json-editor [debug]="true" [options]="editorOptionsData" [data]="dataStructure"></json-editor>

JSONOptions missing params

If you find youself trying to use an custom option that is not mapped here, you can do:

let editorOptions: JsonEditorOptions = new JsonEditorOptions(); (<any>this.editorOptions).templates = [{menu options objects as in json editor documentation}]

See the issue

Internet Explorer

If you want to support IE, please follow this guide:

Multiple editors

To use multiple jsoneditors in your view you cannot use the same editor options.

You should have something like:

<div *ngFor="let prd of data.products" class="w-100-p p-24" >
  <json-editor [options]="makeOptions()" [data]="prd" (change)="showJson($event)"></json-editor>
</div>
makeOptions = () => {
  return new JsonEditorOptions();
}

Demo

Demo component files are included in Git Project under projects/demo.
An explanation how to start the demo is in the Local Development-Guide

Collaborate

See Local Development

License

MIT

ang-jsoneditor's People

Contributors

17radix avatar angular-cli avatar deanist avatar hc-satoshiwatanabe avatar intellix avatar jabiinfante avatar jeffreymercado avatar maaxgr avatar manishit56 avatar mariohmol avatar michael-spengler avatar osmanraifgunes avatar rr-hornback avatar schobster avatar snyk-bot avatar vamcs avatar vrockai avatar zahnrodolfo avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar

ang-jsoneditor's Issues

Warning: Option "onChangeJSON" is not applicable to modes "text" and "code".

The object includes a property for onChangeJSON and whether it's set or not, a console warning is triggered if the modes array includes "text" or "code". I'm not using onChangeJSON so it's kind of bizarre to be getting that warning.

Option "onChangeJSON" is not applicable to modes "text" and "code". Use "onChangeText" or "onChange" instead.

Support for Angular 13

Hello,

I am currently starting a new project and decided to work with the latest Angular (13 at this moment) and my next steps will require me to make a JSON editor ... or use one

I saw your repo fork and I also see that for Angular 13 support but it says "Work in Progress" and there is no npm command for Angular 13.

So I tried running using Angular 12 with npm install @maaxgr/ang-jsoneditor@12 and the output was the one below and in the end my ng serve just hangs

$ ng serve
⠙ Generating browser application bundles (phase: setup)...(node:39691) UnhandledPromiseRejectionWarning: Error: The target entry-point "@maaxgr/ang-jsoneditor" has missing dependencies:
 - jsoneditor

    at TargetedEntryPointFinder.findEntryPoints (file://{path-to-angular-project}/test-json-editor/node_modules/@angular/compiler-cli/bundles/ngcc/index.js:4616:13)
    at file://{path-to-angular-project}/test-json-editor/node_modules/@angular/compiler-cli/bundles/ngcc/index.js:5008:33
    at SingleProcessExecutorSync.doExecute (file://{path-to-angular-project}/test-json-editor/node_modules/@angular/compiler-cli/bundles/ngcc/index.js:14633:23)
    at file://{path-to-angular-project}/test-json-editor/node_modules/@angular/compiler-cli/bundles/ngcc/index.js:14654:35
    at SyncLocker.lock (file://{path-to-angular-project}/test-json-editor/node_modules/@angular/compiler-cli/bundles/ngcc/index.js:14884:14)
    at SingleProcessExecutorSync.execute (file://{path-to-angular-project}/test-json-editor/node_modules/@angular/compiler-cli/bundles/ngcc/index.js:14654:19)
    at mainNgcc (file://{path-to-angular-project}/test-json-editor/node_modules/@angular/compiler-cli/bundles/ngcc/index.js:15985:19)
    at Module.process2 (file://{path-to-angular-project}/test-json-editor/node_modules/@angular/compiler-cli/bundles/ngcc/index.js:16050:10)
    at NgccProcessor.processModule ({path-to-angular-project}/test-json-editor/node_modules/@ngtools/webpack/src/ngcc_processor.js:182:27)
    at {path-to-angular-project}/test-json-editor/node_modules/@ngtools/webpack/src/ivy/host.js:146:18
(Use `node --trace-warnings ...` to show where the warning was created)
(node:39691) UnhandledPromiseRejectionWarning: Unhandled promise rejection. This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). To terminate the node process on unhandled promise rejection, use the CLI flag `--unhandled-rejections=strict` (see https://nodejs.org/api/cli.html#cli_unhandled_rejections_mode). (rejection id: 1)
(node:39691) [DEP0018] DeprecationWarning: Unhandled promise rejections are deprecated. In the future, promise rejections that are not handled will terminate the Node.js process with a non-zero exit code.
⠇ Generating browser application bundles (phase: setup)...

Do you have any plans on making a stable npm package for Angular 13?
You also say in the repo description

This is a fork of mariohmol's ang-jsoneditor with support for Angular 11, 12 and 13.

Do you have any tips on how to get it to work on Angular 13?

Thanks a lot

how to use onCreateMenu to filter the menus?

I want to delete some menus when operating, but when i use onCreateMenu function,It has no any parameter but the ordinary liberary has parameter,How can I use it?

In ordinary liberary : this.editorOptions.onCreateMenu = (items, node) => { items.filter()... }

but now:

image

Can anyone help to use onCreateMenu to filter the menus? Thanks!

unknown this.editor referencing.

image
it seems this.editor is undefined and being reference here again with
image

Is there i away to fix this one?
Is not causing any functionality issues so far, but i just want to make the console cleaner.

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.