Как исправить проблемы с ctx при переходе сцен в Telegraf и машинописном тексте?Javascript

Форум по Javascript
Ответить Пред. темаСлед. тема
Anonymous
 Как исправить проблемы с ctx при переходе сцен в Telegraf и машинописном тексте?

Сообщение Anonymous »

Я пытаюсь создать множество сцен с помощью встроенной клавиатуры и возможностью перехода от одной сцены к другой после выбора опции.
У меня возникла ошибка с экзаменом.
>Ошибка: свойство «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
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение
  • При использовании 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
  • При использовании ctx.moveto () с HTML Canvas Tag Ctx.arc (), moveto () рисует линию [дубликат]
    Anonymous » » в форуме Html
    0 Ответы
    12 Просмотры
    Последнее сообщение Anonymous

Вернуться в «Javascript»