https://github.com/data7expressions/json-light
Json Light
https://github.com/data7expressions/json-light
Last synced: about 1 year ago
JSON representation
Json Light
- Host: GitHub
- URL: https://github.com/data7expressions/json-light
- Owner: data7expressions
- License: mit
- Created: 2023-04-05T17:26:51.000Z (about 3 years ago)
- Default Branch: main
- Last Pushed: 2024-03-11T18:53:40.000Z (over 2 years ago)
- Last Synced: 2024-03-17T10:47:49.757Z (about 2 years ago)
- Language: TypeScript
- Size: 1.4 MB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
# Json Light
>Json Light is a json compressor, generating a new simplified json file from a type definition.
>
>The type can be written by us or generated by the library itself.
>
>Json Light extracts the property tags from a json object and stores the values in an array.
>
## Features
- Compress json generating a new valid json
- Allows to get type from json data
- In the event that you do not want to pass the type to the compress function, it will be generated from the data and stored within the resulting json, allowing it to be later decompressed without the need to pass the type
- CLI
## Methods
### .type(data:any)
get type from json data
- Params:
- data : json data
### .compress(data:any, type?:string)
get a compressed json
- Params:
- data : json data
- type : type (optional)
- mapping : replace names of properties for key and save mapping (optional)
### .decompress(data:any, type?:string)
decompress a previously compressed json getting the original json
- Params:
- data : json data
- type : type (optional)
## Quick start
```typescript
import { JsonLight } from 'json-light'
const data = {
name: 'Spain',
region: 'Europe',
phoneCode: '34',
timezones: [
{ name: 'Madrid', offset: 1, pos: { lat: 40.4165, log: -3.70256 } },
{ name: 'Ceuta', offset: 1, pos: { lat: 35.8883, log: -5.3162 } },
{ name: 'Canary', offset: 0, pos: { lat: 28.1248, log: -15.43 } }
]
}
```
Get Type:
```typescript
const type = JsonLight.type(data)
console.log(type)
```
Output:
```txt
{ name:string,
region:string,
phoneCode:string,
timezones:[
{name:string,
offset:integer,
pos:{lat:decimal,log:decimal}
}
]
}
```
Compress:
```typescript
const compressed = JsonLight.compress(data, { type , mapping: true })
console.log(JSON.stringify(compressed, null, 2))
```
Output:
```javascript
{
"0": [
{
"1": [
40.4165,
-3.70256
],
"_": [
"Madrid",
1
]
},
{
"1": [
35.8883,
-5.3162
],
"_": [
"Ceuta",
1
]
},
{
"1": [
28.1248,
-15.43
],
"_": [
"Canary",
0
]
}
],
"_": [
"Spain",
"Europe",
"34"
],
"__map": {
"0": "timezones",
"1": "pos"
}
}
```
Decompress:
```typescript
const decompressed = JsonLight.decompress(compressed, { type })
console.log(JSON.stringify(decompressed, null, 2))
```
Output:
```javascript
{
"name": "Spain",
"region": "Europe",
"phoneCode": "34",
"timezones": [
{
"name": "Madrid",
"offset": 1,
"pos": {
"lat": 40.4165,
"log": -3.70256
}
},
{
"name": "Ceuta",
"offset": 1,
"pos": {
"lat": 35.8883,
"log": -5.3162
}
},
{
"name": "Canary",
"offset": 0,
"pos": {
"lat": 28.1248,
"log": -15.43
}
}
]
}
```
## CLI
Install
```sh
npm install -g json-light
```
Version:
```sh
json-light version
```
Type:
```sh
json-light type -i source.json
```
Compress:
```sh
json-light compress -i source.json -o compressed.json -s '{name:string,region:string,phoneCode:string,timezones:[{name:string,offset:integer,pos:{lat:decimal,log:decimal}}]}'
```
Decompress:
```sh
json-light decompress -i compressed.json -o original.json -s '{name:string,region:string,phoneCode:string,timezones:[{name:string,offset:integer,pos:{lat:decimal,log:decimal}}]}'
```
## CLI examples
these examples are based on the files found in the git repository
### Type
```sh
json-light type -i ./src/dev/sources/countries.json
json-light type -i ./src/dev/sources/northwind.json
```
Output:
```javascript
[{name:string,iso3:string,iso2:string,numeric_code:string,phone_code:string,capital:string,currency:string,currency_symbol:string,tld:string,native:string,region:string,subregion:string,timezones:[{zoneName:string,gmtOffset:integer,gmtOffsetName:string,abbreviation:string,tzName:string}],translations:{kr:string,br:string,pt:string,nl:string,hr:string,fa:string,de:string,es:string,fr:string,ja:string,it:string,cn:string},latitude:string,longitude:string,emoji:string,emojiU:string,states:[{id:integer,name:string,state_code:string,latitude:string,longitude:string,type:string}]}]
{entities:[{entity:string,rows:[{id:any,name:string,description:string,contact:string,phone:string,address:string,city:string,region:string,postalCode:string,country:string,lastName:string,firstName:string,title:string,titleOfCourtesy:string,birthDate:string,hireDate:string,reportsToId:integer,homepage:string,supplierId:integer,categoryId:integer,quantity:string,price:decimal,inStock:integer,onOrder:integer,reorderLevel:integer,discontinued:boolean,customerId:string,employeeId:integer,orderDate:string,requiredDate:string,shippedDate:string,shipViaId:integer,freight:decimal,details:[{orderId:integer,productId:integer,unitPrice:decimal,quantity:integer,discount:integer}]}]}]}
```
### Compress
```sh
json-light compress -i ./src/dev/sources/countries.json -o ./src/dev/results/countries.json -m
json-light compress -i ./src/dev/sources/northwind.json -o ./src/dev/results/northwind.json -m
```
### Decompress
```sh
json-light decompress -i ./src/dev/results/countries.json -o ./src/dev/results/countries_original.json
json-light decompress -i ./src/dev/results/northwind.json -o ./src/dev/results/northwind_original.json
```
### Results
```sh
[4.0K] .
├── [4.0K] results
│ ├── [427K] countries.json
│ ├── [712K] countries_original.json
│ ├── [ 43M] customers.json
│ ├── [ 79M] customers_original.json
│ ├── [328K] northwind.json
│ └── [464K] northwind_original.json
└── [4.0K] sources
├── [949K] countries.json
├── [154M] customers.json
└── [893K] northwind.json
```