translationLanguages.jsonl
Schema
_key
(required): enum
Enum values:ru
,fr
,en
,zh
,de
,ko
,ja
,es
name
(required): enum
Enum values:Russian
,French
,English
,Chinese
,German
,Korean
,Japanese
,Spanish
Code snippets
// <auto-generated />
//
// To parse this JSON data, add NuGet 'Newtonsoft.Json' then do:
//
// using QuickType;
//
// var translationLanguage = TranslationLanguage.FromJson(jsonString);
namespace QuickType
{
using System;
using System.Collections.Generic;
using System.Globalization;
using Newtonsoft.Json;
using Newtonsoft.Json.Converters;
public partial class TranslationLanguage
{
[JsonProperty("_key")]
public Key Key { get; set; }
[JsonProperty("name")]
public Name Name { get; set; }
}
public enum Key { De, En, Es, Fr, Ja, Ko, Ru, Zh };
public enum Name { Chinese, English, French, German, Japanese, Korean, Russian, Spanish };
public partial class TranslationLanguage
{
public static TranslationLanguage FromJson(string json) => JsonConvert.DeserializeObject<TranslationLanguage>(json, QuickType.Converter.Settings);
}
public static class Serialize
{
public static string ToJson(this TranslationLanguage self) => JsonConvert.SerializeObject(self, QuickType.Converter.Settings);
}
internal static class Converter
{
public static readonly JsonSerializerSettings Settings = new JsonSerializerSettings
{
MetadataPropertyHandling = MetadataPropertyHandling.Ignore,
DateParseHandling = DateParseHandling.None,
Converters =
{
KeyConverter.Singleton,
NameConverter.Singleton,
new IsoDateTimeConverter { DateTimeStyles = DateTimeStyles.AssumeUniversal }
},
};
}
internal class KeyConverter : JsonConverter
{
public override bool CanConvert(Type t) => t == typeof(Key) || t == typeof(Key?);
public override object ReadJson(JsonReader reader, Type t, object existingValue, JsonSerializer serializer)
{
if (reader.TokenType == JsonToken.Null) return null;
var value = serializer.Deserialize<string>(reader);
switch (value)
{
case "de":
return Key.De;
case "en":
return Key.En;
case "es":
return Key.Es;
case "fr":
return Key.Fr;
case "ja":
return Key.Ja;
case "ko":
return Key.Ko;
case "ru":
return Key.Ru;
case "zh":
return Key.Zh;
}
throw new Exception("Cannot unmarshal type Key");
}
public override void WriteJson(JsonWriter writer, object untypedValue, JsonSerializer serializer)
{
if (untypedValue == null)
{
serializer.Serialize(writer, null);
return;
}
var value = (Key)untypedValue;
switch (value)
{
case Key.De:
serializer.Serialize(writer, "de");
return;
case Key.En:
serializer.Serialize(writer, "en");
return;
case Key.Es:
serializer.Serialize(writer, "es");
return;
case Key.Fr:
serializer.Serialize(writer, "fr");
return;
case Key.Ja:
serializer.Serialize(writer, "ja");
return;
case Key.Ko:
serializer.Serialize(writer, "ko");
return;
case Key.Ru:
serializer.Serialize(writer, "ru");
return;
case Key.Zh:
serializer.Serialize(writer, "zh");
return;
}
throw new Exception("Cannot marshal type Key");
}
public static readonly KeyConverter Singleton = new KeyConverter();
}
internal class NameConverter : JsonConverter
{
public override bool CanConvert(Type t) => t == typeof(Name) || t == typeof(Name?);
public override object ReadJson(JsonReader reader, Type t, object existingValue, JsonSerializer serializer)
{
if (reader.TokenType == JsonToken.Null) return null;
var value = serializer.Deserialize<string>(reader);
switch (value)
{
case "Chinese":
return Name.Chinese;
case "English":
return Name.English;
case "French":
return Name.French;
case "German":
return Name.German;
case "Japanese":
return Name.Japanese;
case "Korean":
return Name.Korean;
case "Russian":
return Name.Russian;
case "Spanish":
return Name.Spanish;
}
throw new Exception("Cannot unmarshal type Name");
}
public override void WriteJson(JsonWriter writer, object untypedValue, JsonSerializer serializer)
{
if (untypedValue == null)
{
serializer.Serialize(writer, null);
return;
}
var value = (Name)untypedValue;
switch (value)
{
case Name.Chinese:
serializer.Serialize(writer, "Chinese");
return;
case Name.English:
serializer.Serialize(writer, "English");
return;
case Name.French:
serializer.Serialize(writer, "French");
return;
case Name.German:
serializer.Serialize(writer, "German");
return;
case Name.Japanese:
serializer.Serialize(writer, "Japanese");
return;
case Name.Korean:
serializer.Serialize(writer, "Korean");
return;
case Name.Russian:
serializer.Serialize(writer, "Russian");
return;
case Name.Spanish:
serializer.Serialize(writer, "Spanish");
return;
}
throw new Exception("Cannot marshal type Name");
}
public static readonly NameConverter Singleton = new NameConverter();
}
}
// Code generated from JSON Schema using quicktype. DO NOT EDIT.
// To parse and unparse this JSON data, add this code to your project and do:
//
// translationLanguage, err := UnmarshalTranslationLanguage(bytes)
// bytes, err = translationLanguage.Marshal()
package model
import "encoding/json"
func UnmarshalTranslationLanguage(data []byte) (TranslationLanguage, error) {
var r TranslationLanguage
err := json.Unmarshal(data, &r)
return r, err
}
func (r *TranslationLanguage) Marshal() ([]byte, error) {
return json.Marshal(r)
}
type TranslationLanguage struct {
Key Key `json:"_key"`
Name Name `json:"name"`
}
type Key string
const (
De Key = "de"
En Key = "en"
Es Key = "es"
Fr Key = "fr"
Ja Key = "ja"
Ko Key = "ko"
Ru Key = "ru"
Zh Key = "zh"
)
type Name string
const (
Chinese Name = "Chinese"
English Name = "English"
French Name = "French"
German Name = "German"
Japanese Name = "Japanese"
Korean Name = "Korean"
Russian Name = "Russian"
Spanish Name = "Spanish"
)
{
"$schema": "https://json-schema.org/draft/2020-12/schema",
"type": "object",
"properties": {
"_key": {
"type": "string",
"enum": [
"ru",
"fr",
"en",
"zh",
"de",
"ko",
"ja",
"es"
]
},
"name": {
"type": "string",
"enum": [
"Russian",
"French",
"English",
"Chinese",
"German",
"Korean",
"Japanese",
"Spanish"
]
}
},
"required": [
"_key",
"name"
]
}
// To parse the JSON, install kotlin's serialization plugin and do:
//
// val json = Json { allowStructuredMapKeys = true }
// val translationLanguage = json.parse(TranslationLanguage.serializer(), jsonString)
package model
import kotlinx.serialization.*
import kotlinx.serialization.json.*
import kotlinx.serialization.descriptors.*
import kotlinx.serialization.encoding.*
@Serializable
data class TranslationLanguage (
@SerialName("_key")
val key: Key,
val name: Name
)
@Serializable
enum class Key(val value: String) {
@SerialName("de") De("de"),
@SerialName("en") En("en"),
@SerialName("es") Es("es"),
@SerialName("fr") Fr("fr"),
@SerialName("ja") Ja("ja"),
@SerialName("ko") Ko("ko"),
@SerialName("ru") Ru("ru"),
@SerialName("zh") Zh("zh");
}
@Serializable
enum class Name(val value: String) {
@SerialName("Chinese") Chinese("Chinese"),
@SerialName("English") English("English"),
@SerialName("French") French("French"),
@SerialName("German") German("German"),
@SerialName("Japanese") Japanese("Japanese"),
@SerialName("Korean") Korean("Korean"),
@SerialName("Russian") Russian("Russian"),
@SerialName("Spanish") Spanish("Spanish");
}
<?php
// This is a autogenerated file:TranslationLanguage
class TranslationLanguage {
private Key $key; // json:_key Required
private Name $name; // json:name Required
/**
* @param Key $key
* @param Name $name
*/
public function __construct(Key $key, Name $name) {
$this->key = $key;
$this->name = $name;
}
/**
* @param string $value
* @throws Exception
* @return Key
*/
public static function fromKey(string $value): Key {
return Key::from($value); /*enum*/
}
/**
* @throws Exception
* @return string
*/
public function toKey(): string {
if (TranslationLanguage::validateKey($this->key)) {
return Key::to($this->key); /*enum*/
}
throw new Exception('never get to this TranslationLanguage::key');
}
/**
* @param Key
* @return bool
* @throws Exception
*/
public static function validateKey(Key $value): bool {
Key::to($value);
return true;
}
/**
* @throws Exception
* @return Key
*/
public function getKey(): Key {
if (TranslationLanguage::validateKey($this->key)) {
return $this->key;
}
throw new Exception('never get to getKey TranslationLanguage::key');
}
/**
* @return Key
*/
public static function sampleKey(): Key {
return Key::sample(); /*enum*/
}
/**
* @param string $value
* @throws Exception
* @return Name
*/
public static function fromName(string $value): Name {
return Name::from($value); /*enum*/
}
/**
* @throws Exception
* @return string
*/
public function toName(): string {
if (TranslationLanguage::validateName($this->name)) {
return Name::to($this->name); /*enum*/
}
throw new Exception('never get to this TranslationLanguage::name');
}
/**
* @param Name
* @return bool
* @throws Exception
*/
public static function validateName(Name $value): bool {
Name::to($value);
return true;
}
/**
* @throws Exception
* @return Name
*/
public function getName(): Name {
if (TranslationLanguage::validateName($this->name)) {
return $this->name;
}
throw new Exception('never get to getName TranslationLanguage::name');
}
/**
* @return Name
*/
public static function sampleName(): Name {
return Name::sample(); /*enum*/
}
/**
* @throws Exception
* @return bool
*/
public function validate(): bool {
return TranslationLanguage::validateKey($this->key)
|| TranslationLanguage::validateName($this->name);
}
/**
* @return stdClass
* @throws Exception
*/
public function to(): stdClass {
$out = new stdClass();
$out->{'_key'} = $this->toKey();
$out->{'name'} = $this->toName();
return $out;
}
/**
* @param stdClass $obj
* @return TranslationLanguage
* @throws Exception
*/
public static function from(stdClass $obj): TranslationLanguage {
return new TranslationLanguage(
TranslationLanguage::fromKey($obj->{'_key'})
,TranslationLanguage::fromName($obj->{'name'})
);
}
/**
* @return TranslationLanguage
*/
public static function sample(): TranslationLanguage {
return new TranslationLanguage(
TranslationLanguage::sampleKey()
,TranslationLanguage::sampleName()
);
}
}
// This is a autogenerated file:Key
class Key {
public static Key $DE;
public static Key $EN;
public static Key $ES;
public static Key $FR;
public static Key $JA;
public static Key $KO;
public static Key $RU;
public static Key $ZH;
public static function init() {
Key::$DE = new Key('de');
Key::$EN = new Key('en');
Key::$ES = new Key('es');
Key::$FR = new Key('fr');
Key::$JA = new Key('ja');
Key::$KO = new Key('ko');
Key::$RU = new Key('ru');
Key::$ZH = new Key('zh');
}
private string $enum;
public function __construct(string $enum) {
$this->enum = $enum;
}
/**
* @param Key
* @return string
* @throws Exception
*/
public static function to(Key $obj): string {
switch ($obj->enum) {
case Key::$DE->enum: return 'de';
case Key::$EN->enum: return 'en';
case Key::$ES->enum: return 'es';
case Key::$FR->enum: return 'fr';
case Key::$JA->enum: return 'ja';
case Key::$KO->enum: return 'ko';
case Key::$RU->enum: return 'ru';
case Key::$ZH->enum: return 'zh';
}
throw new Exception('the give value is not an enum-value.');
}
/**
* @param mixed
* @return Key
* @throws Exception
*/
public static function from($obj): Key {
switch ($obj) {
case 'de': return Key::$DE;
case 'en': return Key::$EN;
case 'es': return Key::$ES;
case 'fr': return Key::$FR;
case 'ja': return Key::$JA;
case 'ko': return Key::$KO;
case 'ru': return Key::$RU;
case 'zh': return Key::$ZH;
}
throw new Exception("Cannot deserialize Key");
}
/**
* @return Key
*/
public static function sample(): Key {
return Key::$DE;
}
}
Key::init();
// This is a autogenerated file:Name
class Name {
public static Name $CHINESE;
public static Name $ENGLISH;
public static Name $FRENCH;
public static Name $GERMAN;
public static Name $JAPANESE;
public static Name $KOREAN;
public static Name $RUSSIAN;
public static Name $SPANISH;
public static function init() {
Name::$CHINESE = new Name('Chinese');
Name::$ENGLISH = new Name('English');
Name::$FRENCH = new Name('French');
Name::$GERMAN = new Name('German');
Name::$JAPANESE = new Name('Japanese');
Name::$KOREAN = new Name('Korean');
Name::$RUSSIAN = new Name('Russian');
Name::$SPANISH = new Name('Spanish');
}
private string $enum;
public function __construct(string $enum) {
$this->enum = $enum;
}
/**
* @param Name
* @return string
* @throws Exception
*/
public static function to(Name $obj): string {
switch ($obj->enum) {
case Name::$CHINESE->enum: return 'Chinese';
case Name::$ENGLISH->enum: return 'English';
case Name::$FRENCH->enum: return 'French';
case Name::$GERMAN->enum: return 'German';
case Name::$JAPANESE->enum: return 'Japanese';
case Name::$KOREAN->enum: return 'Korean';
case Name::$RUSSIAN->enum: return 'Russian';
case Name::$SPANISH->enum: return 'Spanish';
}
throw new Exception('the give value is not an enum-value.');
}
/**
* @param mixed
* @return Name
* @throws Exception
*/
public static function from($obj): Name {
switch ($obj) {
case 'Chinese': return Name::$CHINESE;
case 'English': return Name::$ENGLISH;
case 'French': return Name::$FRENCH;
case 'German': return Name::$GERMAN;
case 'Japanese': return Name::$JAPANESE;
case 'Korean': return Name::$KOREAN;
case 'Russian': return Name::$RUSSIAN;
case 'Spanish': return Name::$SPANISH;
}
throw new Exception("Cannot deserialize Name");
}
/**
* @return Name
*/
public static function sample(): Name {
return Name::$CHINESE;
}
}
Name::init();
from enum import Enum
from typing import Any, TypeVar, Type, cast
T = TypeVar("T")
EnumT = TypeVar("EnumT", bound=Enum)
def to_enum(c: Type[EnumT], x: Any) -> EnumT:
assert isinstance(x, c)
return x.value
def to_class(c: Type[T], x: Any) -> dict:
assert isinstance(x, c)
return cast(Any, x).to_dict()
class Key(Enum):
DE = "de"
EN = "en"
ES = "es"
FR = "fr"
JA = "ja"
KO = "ko"
RU = "ru"
ZH = "zh"
class Name(Enum):
CHINESE = "Chinese"
ENGLISH = "English"
FRENCH = "French"
GERMAN = "German"
JAPANESE = "Japanese"
KOREAN = "Korean"
RUSSIAN = "Russian"
SPANISH = "Spanish"
class TranslationLanguage:
key: Key
name: Name
def __init__(self, key: Key, name: Name) -> None:
self.key = key
self.name = name
@staticmethod
def from_dict(obj: Any) -> 'TranslationLanguage':
assert isinstance(obj, dict)
key = Key(obj.get("_key"))
name = Name(obj.get("name"))
return TranslationLanguage(key, name)
def to_dict(self) -> dict:
result: dict = {}
result["_key"] = to_enum(Key, self.key)
result["name"] = to_enum(Name, self.name)
return result
def translation_language_from_dict(s: Any) -> TranslationLanguage:
return TranslationLanguage.from_dict(s)
def translation_language_to_dict(x: TranslationLanguage) -> Any:
return to_class(TranslationLanguage, x)
// To parse this data:
//
// import { Convert, TranslationLanguage } from "./file";
//
// const translationLanguage = Convert.toTranslationLanguage(json);
//
// These functions will throw an error if the JSON doesn't
// match the expected interface, even if the JSON is valid.
export interface TranslationLanguage {
_key: Key;
name: Name;
[property: string]: any;
}
export enum Key {
De = "de",
En = "en",
Es = "es",
Fr = "fr",
Ja = "ja",
Ko = "ko",
Ru = "ru",
Zh = "zh",
}
export enum Name {
Chinese = "Chinese",
English = "English",
French = "French",
German = "German",
Japanese = "Japanese",
Korean = "Korean",
Russian = "Russian",
Spanish = "Spanish",
}
// Converts JSON strings to/from your types
// and asserts the results of JSON.parse at runtime
export class Convert {
public static toTranslationLanguage(json: string): TranslationLanguage {
return cast(JSON.parse(json), r("TranslationLanguage"));
}
public static translationLanguageToJson(value: TranslationLanguage): string {
return JSON.stringify(uncast(value, r("TranslationLanguage")), null, 2);
}
}
function invalidValue(typ: any, val: any, key: any, parent: any = ''): never {
const prettyTyp = prettyTypeName(typ);
const parentText = parent ? ` on ${parent}` : '';
const keyText = key ? ` for key "${key}"` : '';
throw Error(`Invalid value${keyText}${parentText}. Expected ${prettyTyp} but got ${JSON.stringify(val)}`);
}
function prettyTypeName(typ: any): string {
if (Array.isArray(typ)) {
if (typ.length === 2 && typ[0] === undefined) {
return `an optional ${prettyTypeName(typ[1])}`;
} else {
return `one of [${typ.map(a => { return prettyTypeName(a); }).join(", ")}]`;
}
} else if (typeof typ === "object" && typ.literal !== undefined) {
return typ.literal;
} else {
return typeof typ;
}
}
function jsonToJSProps(typ: any): any {
if (typ.jsonToJS === undefined) {
const map: any = {};
typ.props.forEach((p: any) => map[p.json] = { key: p.js, typ: p.typ });
typ.jsonToJS = map;
}
return typ.jsonToJS;
}
function jsToJSONProps(typ: any): any {
if (typ.jsToJSON === undefined) {
const map: any = {};
typ.props.forEach((p: any) => map[p.js] = { key: p.json, typ: p.typ });
typ.jsToJSON = map;
}
return typ.jsToJSON;
}
function transform(val: any, typ: any, getProps: any, key: any = '', parent: any = ''): any {
function transformPrimitive(typ: string, val: any): any {
if (typeof typ === typeof val) return val;
return invalidValue(typ, val, key, parent);
}
function transformUnion(typs: any[], val: any): any {
// val must validate against one typ in typs
const l = typs.length;
for (let i = 0; i < l; i++) {
const typ = typs[i];
try {
return transform(val, typ, getProps);
} catch (_) {}
}
return invalidValue(typs, val, key, parent);
}
function transformEnum(cases: string[], val: any): any {
if (cases.indexOf(val) !== -1) return val;
return invalidValue(cases.map(a => { return l(a); }), val, key, parent);
}
function transformArray(typ: any, val: any): any {
// val must be an array with no invalid elements
if (!Array.isArray(val)) return invalidValue(l("array"), val, key, parent);
return val.map(el => transform(el, typ, getProps));
}
function transformDate(val: any): any {
if (val === null) {
return null;
}
const d = new Date(val);
if (isNaN(d.valueOf())) {
return invalidValue(l("Date"), val, key, parent);
}
return d;
}
function transformObject(props: { [k: string]: any }, additional: any, val: any): any {
if (val === null || typeof val !== "object" || Array.isArray(val)) {
return invalidValue(l(ref || "object"), val, key, parent);
}
const result: any = {};
Object.getOwnPropertyNames(props).forEach(key => {
const prop = props[key];
const v = Object.prototype.hasOwnProperty.call(val, key) ? val[key] : undefined;
result[prop.key] = transform(v, prop.typ, getProps, key, ref);
});
Object.getOwnPropertyNames(val).forEach(key => {
if (!Object.prototype.hasOwnProperty.call(props, key)) {
result[key] = transform(val[key], additional, getProps, key, ref);
}
});
return result;
}
if (typ === "any") return val;
if (typ === null) {
if (val === null) return val;
return invalidValue(typ, val, key, parent);
}
if (typ === false) return invalidValue(typ, val, key, parent);
let ref: any = undefined;
while (typeof typ === "object" && typ.ref !== undefined) {
ref = typ.ref;
typ = typeMap[typ.ref];
}
if (Array.isArray(typ)) return transformEnum(typ, val);
if (typeof typ === "object") {
return typ.hasOwnProperty("unionMembers") ? transformUnion(typ.unionMembers, val)
: typ.hasOwnProperty("arrayItems") ? transformArray(typ.arrayItems, val)
: typ.hasOwnProperty("props") ? transformObject(getProps(typ), typ.additional, val)
: invalidValue(typ, val, key, parent);
}
// Numbers can be parsed by Date but shouldn't be.
if (typ === Date && typeof val !== "number") return transformDate(val);
return transformPrimitive(typ, val);
}
function cast<T>(val: any, typ: any): T {
return transform(val, typ, jsonToJSProps);
}
function uncast<T>(val: T, typ: any): any {
return transform(val, typ, jsToJSONProps);
}
function l(typ: any) {
return { literal: typ };
}
function a(typ: any) {
return { arrayItems: typ };
}
function u(...typs: any[]) {
return { unionMembers: typs };
}
function o(props: any[], additional: any) {
return { props, additional };
}
function m(additional: any) {
return { props: [], additional };
}
function r(name: string) {
return { ref: name };
}
const typeMap: any = {
"TranslationLanguage": o([
{ json: "_key", js: "_key", typ: r("Key") },
{ json: "name", js: "name", typ: r("Name") },
], "any"),
"Key": [
"de",
"en",
"es",
"fr",
"ja",
"ko",
"ru",
"zh",
],
"Name": [
"Chinese",
"English",
"French",
"German",
"Japanese",
"Korean",
"Russian",
"Spanish",
],
};