telegram-node-bot
Version:
Module for creating Telegram bots.
151 lines (137 loc) • 3.87 kB
JavaScript
'use strict'
const InlineKeyboardMarkup = require('./InlineKeyboardMarkup')
const InputMessageContent = require('./InputMessageContent')
const InlineQueryResult = require('./InlineQueryResult')
/**
* Represents a link to a video file stored on the Telegram servers. By default, this video file will be sent by the user with an optional caption. Alternatively, you can use input_message_content to send a message with the specified content instead of the video.
*/
class InlineQueryResultCachedVideo extends InlineQueryResult {
/**
*
* @param {string} type
* @param {string} id
* @param {string} videoFileId
* @param {string} title
* @param {string|null} [description]
* @param {string|null} [caption]
* @param {InlineKeyboardMarkup|null} [replyMarkup]
* @param {InputMessageContent|null} [inputMessageContent]
*/
constructor(
type,
id,
videoFileId,
title,
description,
caption,
replyMarkup,
inputMessageContent
) {
super()
this._type = type
this._id = id
this._videoFileId = videoFileId
this._title = title
this._description = description
this._caption = caption
this._replyMarkup = replyMarkup
this._inputMessageContent = inputMessageContent
}
/**
* Type of the result, must be video
* @returns {string}
*/
get type() {
return this._type
}
/**
* Unique identifier for this result, 1-64 bytes
* @returns {string}
*/
get id() {
return this._id
}
/**
* A valid file identifier for the video file
* @returns {string}
*/
get videoFileId() {
return this._videoFileId
}
/**
* Title for the result
* @returns {string}
*/
get title() {
return this._title
}
/**
* Short description of the result
* @returns {string|null}
*/
get description() {
return this._description
}
/**
* Caption of the video to be sent, 0-200 characters
* @returns {string|null}
*/
get caption() {
return this._caption
}
/**
* Inline keyboard attached to the message
* @returns {InlineKeyboardMarkup|null}
*/
get replyMarkup() {
return this._replyMarkup
}
/**
* Content of the message to be sent instead of the video
* @returns {InputMessageContent|null}
*/
get inputMessageContent() {
return this._inputMessageContent
}
/**
*
* @param {Object} raw
* @returns {InlineQueryResultCachedVideo}
*/
static deserialize(raw) {
return new InlineQueryResultCachedVideo(
raw['type'],
raw['id'],
raw['video_file_id'],
raw['title'],
raw['description'] ? raw['description'] : null,
raw['caption'] ? raw['caption'] : null,
raw['reply_markup'] ? InlineKeyboardMarkup.deserialize(raw['reply_markup']) : null,
raw['input_message_content'] ? InputMessageContent.deserialize(raw['input_message_content']) : null
)
}
/**
*
* @returns {Object}
*/
serialize() {
return {
type: this.type ? this.type : undefined,
id: this.id ? this.id : undefined,
video_file_id: this.videoFileId ? this.videoFileId : undefined,
title: this.title ? this.title : undefined,
description: this.description ? this.description : undefined,
caption: this.caption ? this.caption : undefined,
reply_markup: this.replyMarkup ? this.replyMarkup.serialize() : undefined,
input_message_content: this.inputMessageContent ? this.inputMessageContent.serialize() : undefined
}
}
/**
*
* @returns {string}
*/
toJSON() {
return this.serialize()
}
}
module.exports = InlineQueryResultCachedVideo