@twurple/eventsub-base
Version:
Base for the other Twurple EventSub packages
107 lines (106 loc) • 3.28 kB
JavaScript
import { __decorate } from "tslib";
import { Enumerable } from '@d-fischer/shared-utils';
import { checkRelationAssertion, DataObject, rawDataSymbol, rtfm } from '@twurple/common';
import { EventSubChannelHypeTrainContribution } from './common/EventSubChannelHypeTrainContribution.js';
/**
* An EventSub event representing progress towards the Hype Train goal.
*/
let EventSubChannelHypeTrainProgressEvent = class EventSubChannelHypeTrainProgressEvent extends DataObject {
/** @internal */ _client;
/** @internal */
constructor(data, client) {
super(data);
this._client = client;
}
/**
* The ID of the Hype Train.
*/
get id() {
return this[rawDataSymbol].id;
}
/**
* The ID of the broadcaster.
*/
get broadcasterId() {
return this[rawDataSymbol].broadcaster_user_id;
}
/**
* The name of the broadcaster.
*/
get broadcasterName() {
return this[rawDataSymbol].broadcaster_user_login;
}
/**
* The display name of the broadcaster.
*/
get broadcasterDisplayName() {
return this[rawDataSymbol].broadcaster_user_name;
}
/**
* Gets more information about the broadcaster.
*/
async getBroadcaster() {
return checkRelationAssertion(await this._client.users.getUserById(this[rawDataSymbol].broadcaster_user_id));
}
/**
* The current level of the Hype Train.
*/
get level() {
return this[rawDataSymbol].level;
}
/**
* The total points contributed to the Hype Train.
*/
get total() {
return this[rawDataSymbol].total;
}
/**
* The number of points contributed to the Hype Train at the current level.
*/
get progress() {
return this[rawDataSymbol].progress;
}
/**
* The number of points required to reach the next level.
*/
get goal() {
return this[rawDataSymbol].goal;
}
/**
* The contributors with the most points, for both bits and subscriptions.
*/
get topContributors() {
return (this[rawDataSymbol].top_contributions?.map(data => new EventSubChannelHypeTrainContribution(data, this._client)) ?? []);
}
/**
* The most recent contribution.
*/
get lastContribution() {
return new EventSubChannelHypeTrainContribution(this[rawDataSymbol].last_contribution, this._client);
}
/**
* The time when the Hype Train started.
*/
get startDate() {
return new Date(this[rawDataSymbol].started_at);
}
/**
* The time when the Hype Train is expected to end, unless extended by reaching the goal.
*/
get expiryDate() {
return new Date(this[rawDataSymbol].expires_at);
}
/**
* Indicates if the Hype Train is a Golden Kappa Train.
*/
get isGoldenKappaTrain() {
return this[rawDataSymbol].is_golden_kappa_train;
}
};
__decorate([
Enumerable(false)
], EventSubChannelHypeTrainProgressEvent.prototype, "_client", void 0);
EventSubChannelHypeTrainProgressEvent = __decorate([
rtfm('eventsub-base', 'EventSubChannelHypeTrainProgressEvent', 'broadcasterId')
], EventSubChannelHypeTrainProgressEvent);
export { EventSubChannelHypeTrainProgressEvent };