Я пытаюсь создать множество сцен с помощью встроенной клавиатуры и возможностью перехода от одной сцены к другой после выбора опции.
У меня возникла ошибка с экзаменом.
>Ошибка: свойство «examId» не существует для типа «SceneSession».ts(2339)
Единственное свойство сеанса — __сцены
import { Telegraf, Scenes, session, Context, Markup } from 'telegraf';
// Define scene constants
const SCENES = {
EXAMS: 'exams-scene',
YEARS: 'years-scene',
} as const;
// Extend SceneSessionData to include custom fields
interface MySessionData extends Scenes.SceneSessionData {
examId?: number;
year?: string;
subject?: string;
paper?: string;
currentPage?: number;
lastActivity?: number;
}
interface MyContext extends Scenes.SceneContext {
session: Scenes.SceneSession;
scene: Scenes.SceneContextScene;
}
// Initialize scenes
const examsScene = new Scenes.BaseScene(SCENES.EXAMS);
const yearsScene = new Scenes.BaseScene(SCENES.YEARS);
// Exam selection scene
examsScene.enter(async (ctx) => {
const exams = [
{ id: 1, title: 'GCE O-Level' },
{ id: 2, title: 'GCE A-Level, BACALUREATE' },
{ id: 3, title: 'IGCSE' },
{ id: 4, title: 'SAT' },
];
const keyboard = Markup.inlineKeyboard([
...exams.map((exam) => [
Markup.button.callback(exam.title, `select_exam:${exam.id}`),
]),
[Markup.button.callback('« Main Menu', 'main_menu')],
]);
await ctx.reply('Select an exam:', keyboard);
});
// Handle exam selection
examsScene.action(/^select_exam:(\d+)$/, async (ctx) => {
ctx.session.examId = parseInt(ctx.match[1], 10); // Store examId in the session
await ctx.reply(`You selected exam ID: ${ctx.session.examId}`);
await ctx.scene.enter(SCENES.YEARS); // Proceed to the next scene
});
Подробнее здесь: https://stackoverflow.com/questions/793 ... typescript
Как исправить проблемы с ctx при переходе сцен в Telegraf и машинописном тексте? ⇐ Javascript
-
- Похожие темы
- Ответы
- Просмотры
- Последнее сообщение
-
-
При использовании ctx.moveto () с HTML Canvas Tag Ctx.arc (), moveto () рисует линию
Anonymous » » в форуме Html - 0 Ответы
- 8 Просмотры
-
Последнее сообщение Anonymous
-
-
-
При использовании ctx.moveto () с HTML Canvas Tag Ctx.arc (), moveto () рисует линию
Anonymous » » в форуме Javascript - 0 Ответы
- 11 Просмотры
-
Последнее сообщение Anonymous
-
-
-
При использовании ctx.moveto () с HTML Canvas Tag Ctx.arc (), moveto () рисует линию
Anonymous » » в форуме Html - 0 Ответы
- 8 Просмотры
-
Последнее сообщение Anonymous
-
-
-
При использовании ctx.moveto () с HTML Canvas Tag Ctx.arc (), moveto () рисует линию
Anonymous » » в форуме Html - 0 Ответы
- 14 Просмотры
-
Последнее сообщение Anonymous
-