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
|
|
|
|
|
2021-02-16 14:12:40 +00:00
|
|
|
/**
|
|
|
|
* 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;
|
|
|
|
};
|
2021-02-16 14:12:40 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* 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[];
|
|
|
|
};
|
2021-02-16 14:12:40 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* 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-16 14:12:40 +00:00
|
|
|
|
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.
|
|
|
|
*/
|
2021-02-23 18:55:47 +00:00
|
|
|
export type TCategory = "games" | "mods" | "comics" | "animations" | "assets";
|
2021-02-21 11:49:58 +00:00
|
|
|
|
2021-02-25 11:03:09 +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-02-25 11:03:09 +00:00
|
|
|
|
2021-02-16 14:12:40 +00:00
|
|
|
/**
|
2021-03-04 11:26:45 +00:00
|
|
|
* Collection of values defined for each
|
2021-02-16 14:12:40 +00:00
|
|
|
* 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;
|
2021-02-16 14:12:40 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* 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;
|
2021-02-16 14:12:40 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* 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[];
|
2021-02-16 14:12:40 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* 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[];
|
2021-02-16 14:12:40 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* 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-02-16 14:12:40 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2021-03-04 11:26:45 +00:00
|
|
|
* Collection of values extrapolated from the
|
2021-02-16 14:12:40 +00:00
|
|
|
* F95 platform representing a particular work.
|
|
|
|
*/
|
2021-03-04 11:26:45 +00:00
|
|
|
export interface IHandiwork extends IGame, IComic, IAnimation, IAsset {}
|
2021-02-23 18:55:47 +00:00
|
|
|
|
|
|
|
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>;
|
|
|
|
}
|