From 3d10bfc3c76c502ba5f5f1ae5512bef7cc5a2da0 Mon Sep 17 00:00:00 2001 From: Maroxy Date: Sun, 17 Oct 2021 22:28:26 +0200 Subject: [PATCH] Remove namespace and export default interface --- src/ts/GIJSON.d.ts | 124 +++++++++++++++++++++---------------------- src/ts/Genshinlib.ts | 4 +- 2 files changed, 63 insertions(+), 65 deletions(-) diff --git a/src/ts/GIJSON.d.ts b/src/ts/GIJSON.d.ts index 61d3af3..04ec4f0 100644 --- a/src/ts/GIJSON.d.ts +++ b/src/ts/GIJSON.d.ts @@ -1,73 +1,69 @@ -declare module GIJSON { +interface VoicePack { + language: string; + name: string; + path: string; + size: string; + md5: string; +} - interface VoicePack { - language: string; - name: string; - path: string; - size: string; - md5: string; - } +interface Latest { + name: string; + version: string; + path: string; + size: string; + md5: string; + entry: string; + voice_packs: VoicePack[]; + decompressed_path: string; + segments: any[]; +} - interface Latest { - name: string; - version: string; - path: string; - size: string; - md5: string; - entry: string; - voice_packs: VoicePack[]; - decompressed_path: string; - segments: any[]; - } +interface Diff { + name: string; + version: string; + path: string; + size: string; + md5: string; + is_recommended_update: boolean; + voice_packs: VoicePack[]; +} - interface Diff { - name: string; - version: string; - path: string; - size: string; - md5: string; - is_recommended_update: boolean; - voice_packs: VoicePack[]; - } +interface Game { + latest: Latest; + diffs: Diff[]; +} - interface Game { - latest: Latest; - diffs: Diff[]; - } +interface Plugins { + name: string; + version: string; + path: string; + size: string; + md5: string; + entry: string; +} - interface Plugins { - name: string; - version: string; - path: string; - size: string; - md5: string; - entry: string; - } +interface Plugin { + plugins: Plugins[]; + version: string; +} - interface Plugin { - plugins: Plugins[]; - version: string; - } +interface DeprecatedPackage { + name: string; + md5: string; +} - interface DeprecatedPackage { - name: string; - md5: string; - } - - interface Data { - game: Game; - plugin: Plugin; - web_url: string; - force_update?: any; - pre_download_game?: any; - deprecated_packages: DeprecatedPackage[]; - sdk?: any; - } - - export interface Type { - retcode: number; - message: string; - data: Data; - } +interface Data { + game: Game; + plugin: Plugin; + web_url: string; + force_update?: any; + pre_download_game?: any; + deprecated_packages: DeprecatedPackage[]; + sdk?: any; +} +export default interface GIJSON { + retcode: number; + message: string; + data: Data; } \ No newline at end of file diff --git a/src/ts/Genshinlib.ts b/src/ts/Genshinlib.ts index f6c0a98..47f33ac 100644 --- a/src/ts/Genshinlib.ts +++ b/src/ts/Genshinlib.ts @@ -1,3 +1,5 @@ +import GIJSON from "./GIJSON"; + const https = require('https'); const fs = require('fs'); const path = require('path'); @@ -74,7 +76,7 @@ export class Genshinlib response.on('data', (chunk: any) => data += chunk); response.on('end', () => { - let jsondata: GIJSON.Type = JSON.parse(data); + let jsondata: GIJSON = JSON.parse(data); return jsondata.message === 'OK' ? resolve(jsondata.data) : reject(null); });