mirror-chatterino2/docs/ChatterinoTheme.schema.json

399 lines
12 KiB
JSON
Raw Normal View History

{
"$schema": "http://json-schema.org/draft-07/schema",
"title": "Chatterino Theme",
"description": "Colors and metadata for a Chatterino 2 theme",
"definitions": {
"qt-color": {
"type": "string",
"$comment": "https://doc.qt.io/qt-5/qcolor.html#setNamedColor",
"anyOf": [
{
"title": "#RGB",
"pattern": "^#[a-fA-F0-9]{3}$"
},
{
"title": "#RRGGBB",
"pattern": "^#[a-fA-F0-9]{6}$"
},
{
"title": "#AARRGGBB",
"$comment": "Note that this isn't identical to the CSS Color Moudle Level 4 <hex-color> where the alpha value is at the end.",
"pattern": "^#[a-fA-F0-9]{8}$"
},
{
"title": "#RRRGGGBBB",
"pattern": "^#[a-fA-F0-9]{9}$"
},
{
"title": "#RRRRGGGGBBBB",
"pattern": "^#[a-fA-F0-9]{12}$"
},
{
"title": "SVG Color",
"description": "This is stricter than Qt. You could theoretically put tabs an spaces between characters in a named color and capitalize the color.",
"$comment": "https://www.w3.org/TR/SVG11/types.html#ColorKeywords",
"enum": [
"aliceblue",
"antiquewhite",
"aqua",
"aquamarine",
"azure",
"beige",
"bisque",
"black",
"blanchedalmond",
"blue",
"blueviolet",
"brown",
"burlywood",
"cadetblue",
"chartreuse",
"chocolate",
"coral",
"cornflowerblue",
"cornsilk",
"crimson",
"cyan",
"darkblue",
"darkcyan",
"darkgoldenrod",
"darkgray",
"darkgreen",
"darkgrey",
"darkkhaki",
"darkmagenta",
"darkolivegreen",
"darkorange",
"darkorchid",
"darkred",
"darksalmon",
"darkseagreen",
"darkslateblue",
"darkslategray",
"darkslategrey",
"darkturquoise",
"darkviolet",
"deeppink",
"deepskyblue",
"dimgray",
"dimgrey",
"dodgerblue",
"firebrick",
"floralwhite",
"forestgreen",
"fuchsia",
"gainsboro",
"ghostwhite",
"gold",
"goldenrod",
"gray",
"grey",
"green",
"greenyellow",
"honeydew",
"hotpink",
"indianred",
"indigo",
"ivory",
"khaki",
"lavender",
"lavenderblush",
"lawngreen",
"lemonchiffon",
"lightblue",
"lightcoral",
"lightcyan",
"lightgoldenrodyellow",
"lightgray",
"lightgreen",
"lightgrey",
"lightpink",
"lightsalmon",
"lightseagreen",
"lightskyblue",
"lightslategray",
"lightslategrey",
"lightsteelblue",
"lightyellow",
"lime",
"limegreen",
"linen",
"magenta",
"maroon",
"mediumaquamarine",
"mediumblue",
"mediumorchid",
"mediumpurple",
"mediumseagreen",
"mediumslateblue",
"mediumspringgreen",
"mediumturquoise",
"mediumvioletred",
"midnightblue",
"mintcream",
"mistyrose",
"moccasin",
"navajowhite",
"navy",
"oldlace",
"olive",
"olivedrab",
"orange",
"orangered",
"orchid",
"palegoldenrod",
"palegreen",
"paleturquoise",
"palevioletred",
"papayawhip",
"peachpuff",
"peru",
"pink",
"plum",
"powderblue",
"purple",
"red",
"rosybrown",
"royalblue",
"saddlebrown",
"salmon",
"sandybrown",
"seagreen",
"seashell",
"sienna",
"silver",
"skyblue",
"slateblue",
"slategray",
"slategrey",
"snow",
"springgreen",
"steelblue",
"tan",
"teal",
"thistle",
"tomato",
"turquoise",
"violet",
"wheat",
"white",
"whitesmoke",
"yellow",
"yellowgreen"
]
},
{
"title": "transparent",
"enum": ["transparent"]
}
]
},
"tab-colors": {
"type": "object",
"additionalProperties": false,
"properties": {
"backgrounds": {
"type": "object",
"additionalProperties": false,
"properties": {
"hover": { "$ref": "#/definitions/qt-color" },
"regular": { "$ref": "#/definitions/qt-color" },
"unfocused": { "$ref": "#/definitions/qt-color" }
},
"required": ["hover", "regular", "unfocused"]
},
"line": {
"type": "object",
"additionalProperties": false,
"properties": {
"hover": { "$ref": "#/definitions/qt-color" },
"regular": { "$ref": "#/definitions/qt-color" },
"unfocused": { "$ref": "#/definitions/qt-color" }
},
"required": ["hover", "regular", "unfocused"]
},
"text": { "$ref": "#/definitions/qt-color" }
},
"required": ["backgrounds", "line", "text"]
}
},
"type": "object",
"additionalProperties": false,
"properties": {
"colors": {
"type": "object",
"additionalProperties": false,
"properties": {
"accent": { "$ref": "#/definitions/qt-color" },
"messages": {
"type": "object",
"additionalProperties": false,
"properties": {
"backgrounds": {
"type": "object",
"additionalProperties": false,
"properties": {
"alternate": { "$ref": "#/definitions/qt-color" },
"regular": { "$ref": "#/definitions/qt-color" }
},
"required": ["alternate", "regular"]
},
"disabled": { "$ref": "#/definitions/qt-color" },
"highlightAnimationEnd": { "$ref": "#/definitions/qt-color" },
"highlightAnimationStart": { "$ref": "#/definitions/qt-color" },
"selection": { "$ref": "#/definitions/qt-color" },
"textColors": {
"type": "object",
"additionalProperties": false,
"properties": {
"caret": { "$ref": "#/definitions/qt-color" },
"chatPlaceholder": { "$ref": "#/definitions/qt-color" },
"link": { "$ref": "#/definitions/qt-color" },
"regular": { "$ref": "#/definitions/qt-color" },
"system": { "$ref": "#/definitions/qt-color" }
},
"required": [
"caret",
"chatPlaceholder",
"link",
"regular",
"system"
]
}
},
"required": [
"backgrounds",
"disabled",
"highlightAnimationEnd",
"highlightAnimationStart",
"selection",
"textColors"
]
},
"scrollbars": {
"type": "object",
"additionalProperties": false,
"properties": {
"background": { "$ref": "#/definitions/qt-color" },
"thumb": { "$ref": "#/definitions/qt-color" },
"thumbSelected": { "$ref": "#/definitions/qt-color" }
},
"required": ["background", "thumb", "thumbSelected"]
},
"splits": {
"type": "object",
"additionalProperties": false,
"properties": {
"background": { "$ref": "#/definitions/qt-color" },
"dropPreview": { "$ref": "#/definitions/qt-color" },
"dropPreviewBorder": { "$ref": "#/definitions/qt-color" },
"dropTargetRect": { "$ref": "#/definitions/qt-color" },
"dropTargetRectBorder": { "$ref": "#/definitions/qt-color" },
"header": {
"type": "object",
"additionalProperties": false,
"properties": {
"background": { "$ref": "#/definitions/qt-color" },
"border": { "$ref": "#/definitions/qt-color" },
"focusedBackground": { "$ref": "#/definitions/qt-color" },
"focusedBorder": { "$ref": "#/definitions/qt-color" },
"focusedText": { "$ref": "#/definitions/qt-color" },
"text": { "$ref": "#/definitions/qt-color" }
},
"required": [
"background",
"border",
"focusedBackground",
"focusedBorder",
"focusedText",
"text"
]
},
"input": {
"type": "object",
"additionalProperties": false,
"properties": {
"background": { "$ref": "#/definitions/qt-color" },
"text": { "$ref": "#/definitions/qt-color" }
},
"required": ["background", "text"]
},
"messageSeperator": { "$ref": "#/definitions/qt-color" },
"resizeHandle": { "$ref": "#/definitions/qt-color" },
"resizeHandleBackground": { "$ref": "#/definitions/qt-color" }
},
"required": [
"background",
"dropPreview",
"dropPreviewBorder",
"dropTargetRect",
"dropTargetRectBorder",
"header",
"input",
"messageSeperator",
"resizeHandle",
"resizeHandleBackground"
]
},
"tabs": {
"type": "object",
"additionalProperties": false,
"properties": {
"dividerLine": { "$ref": "#/definitions/qt-color" },
"highlighted": {
"$ref": "#/definitions/tab-colors"
},
"newMessage": {
"$ref": "#/definitions/tab-colors"
},
"regular": {
"$ref": "#/definitions/tab-colors"
},
"selected": {
"$ref": "#/definitions/tab-colors"
}
},
"required": [
"dividerLine",
"highlighted",
"newMessage",
"regular",
"selected"
]
},
"window": {
"type": "object",
"additionalProperties": false,
"properties": {
"background": { "$ref": "#/definitions/qt-color" },
"text": { "$ref": "#/definitions/qt-color" }
},
"required": ["background", "text"]
}
},
"required": [
"accent",
"messages",
"scrollbars",
"splits",
"tabs",
"window"
]
},
"metadata": {
"type": "object",
"additionalProperties": false,
"properties": {
"iconTheme": {
"$comment": "Determines which icons to use. 'dark' will use dark icons (best for a light theme). 'light' will use light icons.",
"enum": ["light", "dark"],
"default": "light"
}
},
"required": ["iconTheme"]
},
"$schema": { "type": "string" }
},
"required": ["colors", "metadata"]
}