F95API/src/scripts/interfaces.ts

331 lines
6.3 KiB
TypeScript
Raw Normal View History

2021-03-04 12:19:49 +00:00
// Copyright (c) 2021 MillenniumEarl
//
// This software is released under the MIT License.
// https://opensource.org/licenses/MIT
/**
* Data relating to an external platform (i.e. Patreon).
*/
2021-02-21 13:40:05 +00:00
export type TExternalPlatform = {
2021-03-04 11:26:45 +00:00
/**
* name of the platform.
*/
name: string;
/**
* link to the platform.
*/
link: string;
};
/**
* Information about the author of a work.
*/
2021-02-21 13:40:05 +00:00
export type TAuthor = {
2021-03-04 11:26:45 +00:00
/**
* Plain name or username of the author.
*/
name: string;
/**
*
*/
platforms: TExternalPlatform[];
};
/**
* Information on the evaluation of a work.
*/
2021-02-21 13:40:05 +00:00
export type TRating = {
2021-03-04 11:26:45 +00:00
/**
* average value of evaluations.
*/
average: number;
/**
* Best rating received.
*/
best: number;
/**
* Number of ratings made by users.
*/
count: number;
};
2021-02-21 11:49:58 +00:00
/**
* List of possible graphics engines used for game development.
*/
2021-03-04 11:26:45 +00:00
export type TEngine =
| "QSP"
| "RPGM"
| "Unity"
| "HTML"
| "RAGS"
| "Java"
| "Ren'Py"
| "Flash"
| "ADRIFT"
| "Others"
| "Tads"
| "Wolf RPG"
| "Unreal Engine"
| "WebGL";
2021-02-21 11:49:58 +00:00
/**
* List of possible progress states associated with a game.
*/
2021-02-21 13:40:05 +00:00
export type TStatus = "Completed" | "Ongoing" | "Abandoned" | "Onhold";
2021-02-21 11:49:58 +00:00
/**
* List of possible categories of a particular work.
*/
export type TCategory = "games" | "mods" | "comics" | "animations" | "assets";
2021-02-21 11:49:58 +00:00
/**
* Valid names of classes that implement the IQuery interface.
*/
2021-03-04 11:26:45 +00:00
export type TQueryInterface =
| "LatestSearchQuery"
| "ThreadSearchQuery"
| "HandiworkSearchQuery";
/**
2021-03-04 11:26:45 +00:00
* Collection of values defined for each
* handiwork on the F95Zone platform.
*/
2021-02-21 11:49:58 +00:00
export interface IBasic {
2021-03-04 11:26:45 +00:00
/**
* Authors of the work.
*/
authors: TAuthor[];
/**
* Category of the work..
*/
category: TCategory;
/**
* List of changes of the work for each version.
*/
changelog: string[];
/**
* link to the cover image of the work.
*/
cover: string;
/**
* Unique ID of the work on the platform.
*/
id: number;
/**
* Last update of the opera thread.
*/
lastThreadUpdate: Date;
/**
* Plain name of the work (without tags and/or prefixes)
*/
name: string;
/**
* Work description
*/
overview: string;
/**
* List of prefixes associated with the work.
*/
prefixes: string[];
/**
* Evaluation of the work by the users of the platform.
*/
rating: TRating;
/**
* List of tags associated with the work.
*/
tags: string[];
/**
* Date of publication of the thread associated with the work.
*/
threadPublishingDate: Date;
/**
* URL to the work's official conversation on the F95Zone portal.
*/
url: string;
}
/**
* Collection of values representing a game present on the F95Zone platform.
*/
2021-02-21 11:49:58 +00:00
export interface IGame extends IBasic {
2021-03-04 11:26:45 +00:00
/**
* Specify whether the work has censorship
* measures regarding NSFW scenes
*/
censored: boolean;
/**
* Graphics engine used for game development.
*/
engine: TEngine;
/**
* List of genres associated with the work.
*/
genre: string[];
/**
* Author's Guide to Installation.
*/
installation: string;
/**
* List of available languages.
*/
language: string[];
/**
* Last time the work underwent updates.
*/
lastRelease: Date;
/**
* Indicates that this item represents a mod.
*/
mod: boolean;
/**
* List of OS for which the work is compatible.
*/
os: string[];
/**
* Indicates the progress of a game.
*/
status: TStatus;
/**
* Version of the work.
*/
version: string;
}
/**
* Collection of values representing a comic present on the F95Zone platform.
*/
2021-02-21 11:49:58 +00:00
export interface IComic extends IBasic {
2021-03-04 11:26:45 +00:00
/**
* List of genres associated with the work.
*/
genre: string[];
/**
* Number of pages or elements that make up the work.
*/
pages: string;
/**
* List of resolutions available for the work.
*/
resolution: string[];
}
/**
* Collection of values representing an animation present on the F95Zone platform.
*/
2021-02-21 11:49:58 +00:00
export interface IAnimation extends IBasic {
2021-03-04 11:26:45 +00:00
/**
* Specify whether the work has censorship
* measures regarding NSFW scenes
*/
censored: boolean;
/**
* List of genres associated with the work.
*/
genre: string[];
/**
* Author's Guide to Installation.
*/
installation: string;
/**
* List of available languages.
*/
language: string[];
/**
* Length of the animation.
*/
lenght: string;
/**
* Number of pages or elements that make up the work.
*/
pages: string;
/**
* List of resolutions available for the work.
*/
resolution: string[];
}
/**
* Collection of values representing an asset present on the F95Zone platform.
*/
2021-02-21 11:49:58 +00:00
export interface IAsset extends IBasic {
2021-03-04 11:26:45 +00:00
/**
* External URL of the asset.
*/
assetLink: string;
/**
* List of URLs of assets associated with the work
* (for example same collection).
*/
associatedAssets: string[];
/**
* Software compatible with the work.
*/
compatibleSoftware: string;
/**
* List of assets url included in the work or used to develop it.
*/
includedAssets: string[];
/**
* List of official links of the work, external to the platform.
*/
officialLinks: string[];
/**
* Unique SKU value of the work.
*/
sku: string;
}
/**
2021-03-04 11:26:45 +00:00
* Collection of values extrapolated from the
* F95 platform representing a particular work.
*/
2021-03-04 11:26:45 +00:00
export interface IHandiwork extends IGame, IComic, IAnimation, IAsset {}
export interface IQuery {
2021-03-04 11:26:45 +00:00
/**
* Name of the implemented interface.
*/
itype: TQueryInterface;
/**
* Category of items to search among.
*/
category: TCategory;
/**
* Tags to be include in the search.
* Max. 5 tags
*/
includedTags: string[];
/**
* Prefixes to include in the search.
*/
includedPrefixes: string[];
/**
* Index of the page to be obtained.
* Between 1 and infinity.
*/
page: number;
/**
* Verify that the query values are valid.
*/
validate(): boolean;
/**
* Search with the data in the query and returns the result.
*
* If the query is invalid it throws an exception.
*/
execute(): any;
}
2021-03-10 09:06:44 +00:00
/**
* It represents an object that obtains the data
* only on the explicit request of the user and
* only after its establishment.
*/
export interface ILazy {
/**
* Gets the data relating to the object.
*/
fetch(): Promise<void>;
}