如何解决电报内联键盘和用户输入数据
我正在 Google Apps Script 上开发 Telegram bot 用于个人目的:输入不同类型的费用/收入。
我在 Google 电子表格中记录了多种类型的费用。
我的想法
我在实施费用输入时遇到了问题。 我喜欢这是如何在官方机器人@BotFather 中实现的
@BotFather
您如何正确实现这一点?最好用 GAS。
谢谢。
Bot.gs
//import firebase realtime database method
import{db} from './firebase-config';
//handling the posts from the database
const [posts,setPosts]= useState([]);
//handling the user information
const [authData,setAuthData] = useState([])
useEffect(() => {
//fetching posts from the database
db.collection('posts').onSnapshot(snapshot => {
setPosts(snapshot.docs.map(doc => ({
id: doc.id,post: doc.data()
})))
});
//fetching the users information
db.collection('users').onSnapshot(snapshot=>{
setAuthData(snapshot.docs.forEach((doc)=>({
id: doc.id,authData: doc.data()
})))
console.log(authData)
})
},[])
doPost.gs
var token = "<BOT_TOKEN>";
var telegramUrl = "https://api.telegram.org/bot" + token;
var webAppUrl = "https://script.google.com/macros/s/<ID>/exec";
function getMe() {
var url = telegramUrl + "/getMe";
var response = UrlFetchApp.fetch(url);
Logger.log(response.getContentText());
}
function setWebhook() {
var url = telegramUrl + "/setWebhook?url=" + webAppUrl;
var response = UrlFetchApp.fetch(url);
Logger.log(response.getContentText());
}
function deletWebhook() {
var url = telegramUrl + "/setWebhook";
var response = UrlFetchApp.fetch(url);
}
function doGet(e) {
return HtmlService.createHtmlOutput("Webhook is working.");
}
// Send message
function sendMessage(chat_id,text) {
var data = {
method: "post",payload: {
method: "sendMessage",chat_id: String(chat_id),text: text,parse_mode: "HTML",disable_web_page_preview: true
}
};
UrlFetchApp.fetch("https://api.telegram.org/bot" + token + "/",data);
}
// Delete message
function deleteMessage(chat_id,message_id) {
var data = {
method: "post",payload: {
method: "deleteMessage",message_id: parseInt(message_id,10)
}
};
UrlFetchApp.fetch("https://api.telegram.org/bot" + token + "/",data);
}
// Edit message
function editMessage(chat_id,message_id,payload: {
method: "editMessageText",10),data);
}
// Send message and keyboard
function sendMessageKeyboard(chat_id,text,keyboard) {
var data = {
method: "post",reply_markup: JSON.stringify(keyboard)
}
};
UrlFetchApp.fetch("https://api.telegram.org/bot" + token + "/",data);
}
// Hide keyboard
function hideKeyBoard(chat_id,payload: {
method: "editMessageReplyMarkup",data);
}
// Replace keyboard
function replaceKeyBoard(chat_id,data);
}
Keyboard.gs
function doPost(e) {
var contents = JSON.parse(e.postData.contents);
if (contents.callback_query) {
var message_id = contents.callback_query.message.message_id;
var data = contents.callback_query.data;
var multiData = data.split(" ");
var chat_id = contents.callback_query.from.id;
if (data == 'Back') {
replaceKeyBoard(chat_id,KEYBOARD_COMPANIES);
} else if (data == 'Cancel') {
deleteMessage(chat_id,message_id);
sendMessageKeyboard(chat_id,"Choose the action:",KEYBOARD_COMPANIES);
} else if (data == 'Common') {
replaceKeyBoard(chat_id,KEYBOARD_COMMON);
} else if ((multiData[1]) && (multiData[0] == 'Common')) {
deleteMessage(chat_id,"<b>Expense: " + multiData[0] + " -> " + multiData[1] + ".</b> Input the value:",KEYBOARD_INPUT);
}
} else if (contents.message) {
var chat_id = contents.message.from.id;
var text = contents.message.text;
if (text == "/start") {
deleteMessage(chat_id,contents.message.message_id)
sendMessageKeyboard(chat_id,KEYBOARD_COMPANIES);
} else if (!isNaN(parseFloat(text)) && isFinite(text)) {
for (var i = 0; i < logins.length; i++) {
if (chat_id == logins[i]) {
sBot.getRange("C" + (i + 2)).setValue(text);
replaceKeyBoard(chat_id,sBot.getRange("D" + (i + 2)).getValue());
}
}
}
}
}
Functions.gs
// 1 Companies
var KEYBOARD_COMPANIES = {
"inline_keyboard": [
[{ "text": "Common",'callback_data': 'Common' }],[{ "text": "Smoky Unicorn",'callback_data': 'Smoky Unicorn' }],[{ "text": "Pussy Stuff",'callback_data': 'Pussy Stuff' }],[{ "text": "Trash Seller",'callback_data': 'Trash Seller' }]
]
};
// 1.1 Common
var KEYBOARD_COMMON = {
"inline_keyboard": [
[{ "text": "Back",'callback_data': 'Back' }],[{ "text": "Taxi",'callback_data': 'Common Taxi' }],[{ "text": "Food",'callback_data': 'Common Food' }],[{ "text": "Party",'callback_data': 'Common Party' }]
]
};
// Reply
var FORCE_REPLY = {
"force_reply": true
};
// Input the value
var KEYBOARD_INPUT = {
"inline_keyboard": [
[{ "text": "Cancel",'callback_data': 'Cancel' }]
]
};
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。