Compare commits
	
		
			2 Commits
		
	
	
		
			c1e7c0eb38
			...
			0e2b714848
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 0e2b714848 | |||
| df55dbf6c7 | 
| @@ -2,7 +2,12 @@ import datetime | |||||||
| import os | import os | ||||||
| from telegram.ext import ConversationHandler, CommandHandler, MessageHandler, filters, CallbackQueryHandler | from telegram.ext import ConversationHandler, CommandHandler, MessageHandler, filters, CallbackQueryHandler | ||||||
| from telegram import InlineKeyboardButton, InlineKeyboardMarkup | from telegram import InlineKeyboardButton, InlineKeyboardMarkup | ||||||
| ACTION_CHOICE, DATE_ENTRY, ADD_CONTENT = range(3) | from telegram.constants import ParseMode | ||||||
|  |  | ||||||
|  |  | ||||||
|  | ENTRY_OPTIONS, CONTENT_ENTRY = range(2) | ||||||
|  | BUTTON_COUNT = 5 | ||||||
|  |  | ||||||
|  |  | ||||||
| from .basehandler import BaseHandler | from .basehandler import BaseHandler | ||||||
|  |  | ||||||
| @@ -13,17 +18,15 @@ class JournalHandler(BaseHandler): | |||||||
|         self.handler = ConversationHandler( |         self.handler = ConversationHandler( | ||||||
|             entry_points=[CommandHandler(entry_string, self.entry_point)], |             entry_points=[CommandHandler(entry_string, self.entry_point)], | ||||||
|             states={ |             states={ | ||||||
|                 ACTION_CHOICE: [ |                 ENTRY_OPTIONS: [ | ||||||
|                     CallbackQueryHandler(self.date_choice, pattern="today|yesterday"), |                     CallbackQueryHandler(self.date_button, pattern=r"^\d{8}$"), # a serialized date | ||||||
|                     CallbackQueryHandler(self.date_custom, pattern="custom"), |                     CallbackQueryHandler(self.date_custom, pattern=r"^\d{1,3}$"), # a ~ small delta | ||||||
|                     CallbackQueryHandler(self.option_delete, pattern="delete") |                     CallbackQueryHandler(self.option_delete, pattern="delete"), | ||||||
|                     ], |  | ||||||
|                 DATE_ENTRY: [ |  | ||||||
|                     MessageHandler(filters.ALL, self.date_entry), |                     MessageHandler(filters.ALL, self.date_entry), | ||||||
|                     ], |                     ], | ||||||
|                 ADD_CONTENT: [ |                 CONTENT_ENTRY: [ | ||||||
|                     MessageHandler(filters.ALL, self.content_save), |                     MessageHandler(filters.ALL, self.content_save), | ||||||
|                     ] |                     ], | ||||||
|             }, |             }, | ||||||
|             fallbacks=[], |             fallbacks=[], | ||||||
|         ) |         ) | ||||||
| @@ -37,30 +40,31 @@ class JournalHandler(BaseHandler): | |||||||
|             await update.message.reply_text("You are not authorized to use this bot") |             await update.message.reply_text("You are not authorized to use this bot") | ||||||
|             return ConversationHandler.END |             return ConversationHandler.END | ||||||
|  |  | ||||||
|  |         dates = [(datetime.datetime.now() - datetime.timedelta(days = i)).date() for i in range(BUTTON_COUNT)][::-1] | ||||||
|  |         names = [d.strftime("%d.%m.") for d in dates] | ||||||
|  |         callbacks = [d.strftime("%d%m%Y") for d in dates] | ||||||
|  |         names[-1] = "Today" | ||||||
|  |         names[-2] = "Yesterday" | ||||||
|  |  | ||||||
|         options = [[ |         options = [ | ||||||
|                 InlineKeyboardButton("Today", callback_data="today"), |             [ | ||||||
|                 InlineKeyboardButton("Yesterday", callback_data="yesterday"), |                 InlineKeyboardButton("<<", callback_data=BUTTON_COUNT) | ||||||
|                 InlineKeyboardButton("Custom date", callback_data="custom"), |                 ] + [ | ||||||
|  |                 InlineKeyboardButton(n, callback_data=c) for n,c in zip(names, callbacks) | ||||||
|             ], |             ], | ||||||
|             [ |             [ | ||||||
|                 InlineKeyboardButton("Delete", callback_data="delete") |                 InlineKeyboardButton("Delete", callback_data="delete") | ||||||
|             ] |             ] | ||||||
|         ] |         ] | ||||||
|         keyboard = InlineKeyboardMarkup(options) |         keyboard = InlineKeyboardMarkup(options) | ||||||
|         await update.message.reply_text("Please choose an option for the entry:", reply_markup=keyboard) |         await update.message.reply_text("Please choose a date \(or type it in the format _DDMMYYYY_\)", reply_markup=keyboard, parse_mode=ParseMode.MARKDOWN_V2) | ||||||
|         return ACTION_CHOICE |         return ENTRY_OPTIONS | ||||||
|  |  | ||||||
|  |  | ||||||
|     async def date_choice(self, update, context): |     async def date_button(self, update, context): | ||||||
|         query = update.callback_query |         query = update.callback_query | ||||||
|         await query.answer() |         await query.answer() | ||||||
|         if query.data == "today": |         date = datetime.datetime.strptime(query.data, "%d%m%Y").date() | ||||||
|             date = datetime.datetime.now().date() |  | ||||||
|         elif query.data == "yesterday": |  | ||||||
|             date = datetime.datetime.now().date() - datetime.timedelta(days=1) |  | ||||||
|         else: |  | ||||||
|             raise ValueError("Invalid date choice") |  | ||||||
|  |  | ||||||
|         with self.models.db: |         with self.models.db: | ||||||
|             self.current_model, new = self.models.JournalEntry.get_or_create( |             self.current_model, new = self.models.JournalEntry.get_or_create( | ||||||
| @@ -75,15 +79,34 @@ class JournalHandler(BaseHandler): | |||||||
|             await query.edit_message_text(text="An entry already exists for this date") |             await query.edit_message_text(text="An entry already exists for this date") | ||||||
|             return ConversationHandler.END |             return ConversationHandler.END | ||||||
|          |          | ||||||
|         return ADD_CONTENT |         return CONTENT_ENTRY | ||||||
|  |  | ||||||
|  |  | ||||||
|     async def date_custom(self, update, context): |     async def date_custom(self, update, context): | ||||||
|         query = update.callback_query |         query = update.callback_query | ||||||
|         await query.answer() |         await query.answer() | ||||||
|         await query.edit_message_text(text="Please enter the date in the format DDMMYYYY") |         delta = int(query.data) | ||||||
|         return DATE_ENTRY |  | ||||||
|  |  | ||||||
|  |         dates = [(datetime.datetime.now() - datetime.timedelta(days = i + delta)).date() for i in range(BUTTON_COUNT - 1)][::-1] | ||||||
|  |         names = [d.strftime("%d.%m.") for d in dates] | ||||||
|  |         callbacks = [d.strftime("%d%m%Y") for d in dates] | ||||||
|  |  | ||||||
|  |         options = [ | ||||||
|  |             [ | ||||||
|  |                 InlineKeyboardButton("<<", callback_data=delta + (BUTTON_COUNT - 1)) | ||||||
|  |                 ] + [ | ||||||
|  |                 InlineKeyboardButton(n, callback_data=c) for n,c in zip(names, callbacks) | ||||||
|  |                 ] + [ | ||||||
|  |                 InlineKeyboardButton(">>", callback_data=delta - (BUTTON_COUNT - 1)) | ||||||
|  |             ], | ||||||
|  |             [ | ||||||
|  |                 InlineKeyboardButton("Delete", callback_data="delete") | ||||||
|  |             ] | ||||||
|  |         ] | ||||||
|  |         keyboard = InlineKeyboardMarkup(options) | ||||||
|  |         await query.edit_message_text("Please choose a date \(or type it in the format _DDMMYYYY_\)", parse_mode=ParseMode.MARKDOWN_V2) | ||||||
|  |  | ||||||
|  |         return ENTRY_OPTIONS | ||||||
|  |  | ||||||
|     async def date_entry(self, update, context): |     async def date_entry(self, update, context): | ||||||
|         date = update.message.text |         date = update.message.text | ||||||
| @@ -91,8 +114,8 @@ class JournalHandler(BaseHandler): | |||||||
|         try: |         try: | ||||||
|             date = datetime.datetime.strptime(date, "%d%m%Y").date() |             date = datetime.datetime.strptime(date, "%d%m%Y").date() | ||||||
|         except ValueError: |         except ValueError: | ||||||
|             await update.message.reply_text("Please enter the date in the format DDMMYYYY") |             await update.message.reply_text("Please enter the date in the format _DDMMYYYY_", parse_mode=ParseMode.MARKDOWN_V2) | ||||||
|             return DATE_ENTRY |             return ENTRY_OPTIONS | ||||||
|          |          | ||||||
|         if context.chat_data.get("delete", False): # if not set, delete was not chosen |         if context.chat_data.get("delete", False): # if not set, delete was not chosen | ||||||
|             with self.models.db: |             with self.models.db: | ||||||
| @@ -118,7 +141,7 @@ class JournalHandler(BaseHandler): | |||||||
|                 await update.message.reply_text( |                 await update.message.reply_text( | ||||||
|                     text=f"Journal entry no. {count}. What happened on {self.current_model.date_pretty}?" |                     text=f"Journal entry no. {count}. What happened on {self.current_model.date_pretty}?" | ||||||
|                 ) |                 ) | ||||||
|                 return ADD_CONTENT |                 return CONTENT_ENTRY | ||||||
|  |  | ||||||
|  |  | ||||||
|     async def content_save(self, update, context): |     async def content_save(self, update, context): | ||||||
| @@ -148,9 +171,9 @@ class JournalHandler(BaseHandler): | |||||||
|     async def option_delete(self, update, context): |     async def option_delete(self, update, context): | ||||||
|         query = update.callback_query |         query = update.callback_query | ||||||
|         await query.answer() |         await query.answer() | ||||||
|         await query.edit_message_text(text="Please enter the date in the format DDMMYYYY") |         await query.edit_message_text(text="Please enter the date in the format _DDMMYYYY_", parse_mode=ParseMode.MARKDOWN_V2) | ||||||
|         context.chat_data["delete"] = True |         context.chat_data["delete"] = True | ||||||
|         return DATE_ENTRY |         return ENTRY_OPTIONS | ||||||
|  |  | ||||||
|  |  | ||||||
|     async def delete_entry(self, update, context): |     async def delete_entry(self, update, context): | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user