UNPKG

@drincs/pixi-vn

Version:

Pixi'VN is a npm package that provides various features for creating visual novels.

51 lines (48 loc) 2.14 kB
import { LabelIdType } from '../types/LabelIdType.mjs'; import { StepLabelType } from '../types/StepLabelType.mjs'; import { StepHistoryDataType } from '../types/StepHistoryDataType.mjs'; import LabelProps from '../interface/LabelProps.mjs'; import '@drincs/pixi-vn/dist/override'; declare abstract class LabelAbstract<TLabel, TProps extends {} = {}> { /** * @param id is the id of the label * @param props is the properties of the label */ constructor(id: LabelIdType, props?: LabelProps<TLabel>); private _id; /** * Get the id of the label. This variable is used in the system to get the label by id, {@link getLabelById} */ get id(): LabelIdType; /** * Get the steps of the label. */ abstract get steps(): StepLabelType<TProps>[]; /** * Get the corresponding steps number * @param externalSteps * @returns Numer of corresponding steps, for example, if externalSteps is [ABC, DEF, GHI] and the steps of the label is [ABC, GHT], the result will be 1 */ protected getCorrespondingStepsNumber(externalSteps: StepHistoryDataType[] | StepLabelType[]): number; private _onStepStart; /** * Is a function that will be executed in {@link Label#onStepStart} and when the user goes back to it or when the user laods a save file. * @returns Promise<void> or void */ get onStepStart(): ((stepIndex: number, label: TLabel) => void | Promise<void>) | undefined; private _onLoadStep; /** * Get the function that will be executed a old step is reloaded. A step is reloaded when the user goes back to it or when the user laods a save file. * @returns Promise<void> or void */ get onLoadStep(): ((stepIndex: number, label: TLabel) => void | Promise<void>) | undefined; private _onStepEnd; /** * Is a function that will be executed when the step ends. * @returns Promise<void> or void */ get onStepEnd(): ((stepIndex: number, label: TLabel) => void | Promise<void>) | undefined; private _choiseIndex; get choiseIndex(): number | undefined; } export { LabelAbstract as default };