17 changed files with 142 additions and 89 deletions
@ -0,0 +1,98 @@ |
|||
<template> |
|||
<template v-if="$parent.notification.type === name"> |
|||
<div class="mb-3"> |
|||
<label for="telegram-bot-token" class="form-label">Bot Token</label> |
|||
<HiddenInput id="telegram-bot-token" v-model="$parent.notification.telegramBotToken" :required="true" autocomplete="one-time-code"></HiddenInput> |
|||
<div class="form-text"> |
|||
You can get a token from <a href="https://t.me/BotFather" target="_blank">https://t.me/BotFather</a>. |
|||
</div> |
|||
</div> |
|||
|
|||
<div class="mb-3"> |
|||
<label for="telegram-chat-id" class="form-label">Chat ID</label> |
|||
|
|||
<div class="input-group mb-3"> |
|||
<input id="telegram-chat-id" v-model="$parent.notification.telegramChatID" type="text" class="form-control" required> |
|||
<button v-if="$parent.notification.telegramBotToken" class="btn btn-outline-secondary" type="button" @click="autoGetTelegramChatID"> |
|||
{{ $t("Auto Get") }} |
|||
</button> |
|||
</div> |
|||
|
|||
<div class="form-text"> |
|||
Support Direct Chat / Group / Channel's Chat ID |
|||
|
|||
<p style="margin-top: 8px;"> |
|||
You can get your chat id by sending message to the bot and go to this url to view the chat_id: |
|||
</p> |
|||
|
|||
<p style="margin-top: 8px;"> |
|||
<template v-if="$parent.notification.telegramBotToken"> |
|||
<a :href="telegramGetUpdatesURL" target="_blank" style="word-break: break-word;">{{ telegramGetUpdatesURL }}</a> |
|||
</template> |
|||
|
|||
<template v-else> |
|||
{{ telegramGetUpdatesURL }} |
|||
</template> |
|||
</p> |
|||
</div> |
|||
</div> |
|||
</template> |
|||
</template> |
|||
|
|||
<script> |
|||
import HiddenInput from "../HiddenInput.vue"; |
|||
import axios from "axios"; |
|||
import { useToast } from "vue-toastification" |
|||
const toast = useToast(); |
|||
|
|||
export default { |
|||
components: { |
|||
HiddenInput, |
|||
}, |
|||
data() { |
|||
return { |
|||
name: "telegram", |
|||
} |
|||
}, |
|||
computed: { |
|||
telegramGetUpdatesURL() { |
|||
let token = "<YOUR BOT TOKEN HERE>" |
|||
|
|||
if (this.$parent.notification.telegramBotToken) { |
|||
token = this.$parent.notification.telegramBotToken; |
|||
} |
|||
|
|||
return `https://api.telegram.org/bot${token}/getUpdates`; |
|||
}, |
|||
}, |
|||
mounted() { |
|||
console.log(this.$parent.notification.type); |
|||
}, |
|||
methods: { |
|||
async autoGetTelegramChatID() { |
|||
try { |
|||
let res = await axios.get(this.telegramGetUpdatesURL) |
|||
|
|||
if (res.data.result.length >= 1) { |
|||
let update = res.data.result[res.data.result.length - 1] |
|||
|
|||
if (update.channel_post) { |
|||
this.notification.telegramChatID = update.channel_post.chat.id; |
|||
} else if (update.message) { |
|||
this.notification.telegramChatID = update.message.chat.id; |
|||
} else { |
|||
throw new Error("Chat ID is not found, please send a message to this bot first") |
|||
} |
|||
|
|||
} else { |
|||
throw new Error("Chat ID is not found, please send a message to this bot first") |
|||
} |
|||
|
|||
} catch (error) { |
|||
toast.error(error.message) |
|||
} |
|||
|
|||
}, |
|||
} |
|||
} |
|||
</script> |
Loading…
Reference in new issue