mirror of
https://github.com/dancojocaru2000/CfrTrainInfoTelegramBot.git
synced 2025-06-19 10:42:32 +03:00
Compare commits
2 commits
c985a6575a
...
f7970ff50f
Author | SHA1 | Date | |
---|---|---|---|
f7970ff50f | |||
365e76b4aa |
1 changed files with 30 additions and 9 deletions
|
@ -26,7 +26,7 @@ const (
|
||||||
|
|
||||||
subscribeButton = "Subscribe to updates"
|
subscribeButton = "Subscribe to updates"
|
||||||
unsubscribeButton = "Unsubscribe from updates"
|
unsubscribeButton = "Unsubscribe from updates"
|
||||||
openInWebAppButton = "Open in WebApp"
|
viewInWebAppButton = "View in WebApp"
|
||||||
)
|
)
|
||||||
|
|
||||||
const (
|
const (
|
||||||
|
@ -182,7 +182,7 @@ func HandleTrainNumberCommand(ctx context.Context, trainNumber string, date time
|
||||||
}
|
}
|
||||||
messageText.WriteString(fmt.Sprintf("Next stop: %s, arriving in %s at %s\n", nextStop.Name, arrStr, arrTime.In(utils.Location).Format("15:04")))
|
messageText.WriteString(fmt.Sprintf("Next stop: %s, arriving in %s at %s\n", nextStop.Name, arrStr, arrTime.In(utils.Location).Format("15:04")))
|
||||||
} else {
|
} else {
|
||||||
depStr := "less than 1m"
|
depStr := ""
|
||||||
depTime := nextStop.Departure.ScheduleTime.Add(func() time.Duration {
|
depTime := nextStop.Departure.ScheduleTime.Add(func() time.Duration {
|
||||||
if nextStop.Departure.Status != nil {
|
if nextStop.Departure.Status != nil {
|
||||||
return time.Minute * time.Duration(nextStop.Departure.Status.Delay)
|
return time.Minute * time.Duration(nextStop.Departure.Status.Delay)
|
||||||
|
@ -191,12 +191,25 @@ func HandleTrainNumberCommand(ctx context.Context, trainNumber string, date time
|
||||||
}
|
}
|
||||||
}())
|
}())
|
||||||
depDiff := depTime.Sub(time.Now())
|
depDiff := depTime.Sub(time.Now())
|
||||||
if depDiff/time.Hour >= 1 {
|
if depDiff/(time.Hour*24) >= 1 {
|
||||||
depStr = fmt.Sprintf("%dh%dm", depDiff/time.Hour, (depDiff%time.Hour)/time.Minute)
|
depStr += fmt.Sprintf("%dd", depDiff/(time.Hour*24))
|
||||||
} else if depDiff/time.Minute >= 1 {
|
depDiff = depDiff % (time.Hour * 24)
|
||||||
depStr = fmt.Sprintf("%dm", depDiff/time.Minute)
|
}
|
||||||
|
if depDiff/time.Hour >= 1 {
|
||||||
|
depStr += fmt.Sprintf("%dh", depDiff/time.Hour)
|
||||||
|
depDiff = depDiff % time.Hour
|
||||||
|
}
|
||||||
|
if depDiff/time.Minute >= 1 {
|
||||||
|
depStr += fmt.Sprintf("%dm", depDiff/time.Minute)
|
||||||
|
}
|
||||||
|
if len(depStr) == 0 {
|
||||||
|
depStr = "less than 1m"
|
||||||
|
}
|
||||||
|
if nextStopIdx == 0 {
|
||||||
|
messageText.WriteString(fmt.Sprintf("The train will depart from %s in %s at %s\n", nextStop.Name, depStr, depTime.In(utils.Location).Format("15:04")))
|
||||||
|
} else {
|
||||||
|
messageText.WriteString(fmt.Sprintf("Currently stopped at: %s, departing in %s at %s\n", nextStop.Name, depStr, depTime.In(utils.Location).Format("15:04")))
|
||||||
}
|
}
|
||||||
messageText.WriteString(fmt.Sprintf("Currently stopped at: %s, departing in %s at %s\n", nextStop.Name, depStr, depTime.In(utils.Location).Format("15:04")))
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if group.Status != nil {
|
if group.Status != nil {
|
||||||
|
@ -290,8 +303,16 @@ func GetTrainNumberCommandResponseButtons(trainNumber string, date time.Time, gr
|
||||||
}
|
}
|
||||||
result = append(result, []models.InlineKeyboardButton{
|
result = append(result, []models.InlineKeyboardButton{
|
||||||
{
|
{
|
||||||
Text: openInWebAppButton,
|
Text: viewInWebAppButton,
|
||||||
URL: kaiUrl.String(),
|
WebApp: &models.WebAppInfo{
|
||||||
|
URL: func() string {
|
||||||
|
miniAppUrl := *kaiUrl
|
||||||
|
miniAppUrlQuery := miniAppUrl.Query()
|
||||||
|
miniAppUrlQuery.Add("tg", "1")
|
||||||
|
miniAppUrl.RawQuery = miniAppUrlQuery.Encode()
|
||||||
|
return miniAppUrl.String()
|
||||||
|
}(),
|
||||||
|
},
|
||||||
},
|
},
|
||||||
})
|
})
|
||||||
return models.InlineKeyboardMarkup{
|
return models.InlineKeyboardMarkup{
|
||||||
|
|
Loading…
Add table
Reference in a new issue