Refactored allmail screen and removed unused code
This commit is contained in:
parent
188ded2231
commit
e386b8dd43
|
@ -9,9 +9,6 @@ All mails are managed in allmail screen
|
||||||
|
|
||||||
"""
|
"""
|
||||||
|
|
||||||
import os
|
|
||||||
from functools import partial
|
|
||||||
|
|
||||||
from kivy.clock import Clock
|
from kivy.clock import Clock
|
||||||
from kivy.properties import (
|
from kivy.properties import (
|
||||||
ListProperty,
|
ListProperty,
|
||||||
|
@ -20,23 +17,16 @@ from kivy.properties import (
|
||||||
from kivy.uix.screenmanager import Screen
|
from kivy.uix.screenmanager import Screen
|
||||||
from kivy.app import App
|
from kivy.app import App
|
||||||
|
|
||||||
import helper_inbox
|
from pybitmessage.bitmessagekivy.baseclass.common import (
|
||||||
import helper_sent
|
show_limited_cnt, empty_screen_label, kivy_state_variables,
|
||||||
|
|
||||||
from bitmessagekivy.baseclass.common import (
|
|
||||||
showLimitedCnt, toast, ThemeClsColor, mail_detail_screen,
|
|
||||||
avatarImageFirstLetter, CustomSwipeToDeleteItem,
|
|
||||||
ShowTimeHistoy, empty_screen_label, kivy_state_variables,
|
|
||||||
msg_content_length
|
|
||||||
)
|
)
|
||||||
|
|
||||||
from debug import logger
|
import logging
|
||||||
from helper_sql import sqlQuery
|
logger = logging.getLogger('default')
|
||||||
|
|
||||||
|
|
||||||
class Allmails(Screen):
|
class Allmails(Screen):
|
||||||
"""Allmails Screen for kivy Ui"""
|
"""Allmails Screen for kivy Ui"""
|
||||||
|
|
||||||
data = ListProperty()
|
data = ListProperty()
|
||||||
has_refreshed = True
|
has_refreshed = True
|
||||||
all_mails = ListProperty()
|
all_mails = ListProperty()
|
||||||
|
@ -47,9 +37,9 @@ class Allmails(Screen):
|
||||||
"""Method Parsing the address"""
|
"""Method Parsing the address"""
|
||||||
super(Allmails, self).__init__(*args, **kwargs)
|
super(Allmails, self).__init__(*args, **kwargs)
|
||||||
self.kivy_state = kivy_state_variables()
|
self.kivy_state = kivy_state_variables()
|
||||||
if self.kivy_state.association == '':
|
if self.kivy_state.selected_address == '':
|
||||||
if App.get_running_app().variable_1:
|
if App.get_running_app().identity_list:
|
||||||
self.kivy_state.association = App.get_running_app().variable_1[0]
|
self.kivy_state.selected_address = App.get_running_app().identity_list[0]
|
||||||
Clock.schedule_once(self.init_ui, 0)
|
Clock.schedule_once(self.init_ui, 0)
|
||||||
|
|
||||||
def init_ui(self, dt=0):
|
def init_ui(self, dt=0):
|
||||||
|
@ -59,133 +49,19 @@ class Allmails(Screen):
|
||||||
|
|
||||||
def loadMessagelist(self):
|
def loadMessagelist(self):
|
||||||
"""Load Inbox, Sent anf Draft list of messages"""
|
"""Load Inbox, Sent anf Draft list of messages"""
|
||||||
self.account = self.kivy_state.association
|
self.account = self.kivy_state.selected_address
|
||||||
self.ids.tag_label.text = ''
|
self.ids.tag_label.text = ''
|
||||||
self.allMessageQuery(0, 20)
|
|
||||||
if self.all_mails:
|
if self.all_mails:
|
||||||
self.ids.tag_label.text = 'All Mails'
|
self.ids.tag_label.text = 'All Mails'
|
||||||
App.get_running_app().get_inbox_count()
|
|
||||||
App.get_running_app().get_sent_count()
|
|
||||||
self.kivy_state.all_count = str(
|
self.kivy_state.all_count = str(
|
||||||
int(self.kivy_state.sent_count) + int(self.kivy_state.inbox_count))
|
int(self.kivy_state.sent_count) + int(self.kivy_state.inbox_count))
|
||||||
self.set_AllmailCnt(self.kivy_state.all_count)
|
self.set_AllmailCnt(self.kivy_state.all_count)
|
||||||
self.set_mdlist()
|
|
||||||
self.ids.scroll_y.bind(scroll_y=self.check_scroll_y)
|
|
||||||
else:
|
else:
|
||||||
self.set_AllmailCnt('0')
|
self.set_AllmailCnt('0')
|
||||||
self.ids.ml.add_widget(empty_screen_label(self.label_str))
|
self.ids.ml.add_widget(empty_screen_label(self.label_str))
|
||||||
|
|
||||||
def allMessageQuery(self, start_indx, end_indx):
|
|
||||||
"""Retrieving data from inbox or sent both tables"""
|
|
||||||
self.all_mails = sqlQuery(
|
|
||||||
"SELECT toaddress, fromaddress, subject, message, folder, ackdata"
|
|
||||||
" As id, DATE(senttime) As actionTime, senttime as msgtime FROM sent WHERE"
|
|
||||||
" folder = 'sent' and fromaddress = ?"
|
|
||||||
" UNION SELECT toaddress, fromaddress, subject, message, folder,"
|
|
||||||
" msgid As id, DATE(received) As actionTime, received as msgtime FROM inbox"
|
|
||||||
" WHERE folder = 'inbox' and toaddress = ?"
|
|
||||||
" ORDER BY actionTime DESC limit ?, ?", self.account, self.account, start_indx, end_indx)
|
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def set_AllmailCnt(Count):
|
def set_AllmailCnt(Count):
|
||||||
"""This method is used to set allmails message count"""
|
"""This method is used to set allmails message count"""
|
||||||
allmailCnt_obj = App.get_running_app().root.ids.content_drawer.ids.allmail_cnt
|
allmailCnt_obj = App.get_running_app().root.ids.content_drawer.ids.allmail_cnt
|
||||||
allmailCnt_obj.ids.badge_txt.text = showLimitedCnt(int(Count))
|
allmailCnt_obj.ids.badge_txt.text = show_limited_cnt(int(Count))
|
||||||
|
|
||||||
def set_mdlist(self):
|
|
||||||
"""This method is used to create mdList for allmaills"""
|
|
||||||
data_exist = len(self.ids.ml.children)
|
|
||||||
for item in self.all_mails:
|
|
||||||
body = item[3].decode() if isinstance(item[3], bytes) else item[3]
|
|
||||||
subject = item[2].decode() if isinstance(item[2], bytes) else item[2]
|
|
||||||
message_row = CustomSwipeToDeleteItem(
|
|
||||||
text=item[1],
|
|
||||||
)
|
|
||||||
listItem = message_row.ids.content
|
|
||||||
secondary_text = msg_content_length(body, subject)
|
|
||||||
listItem.secondary_text = secondary_text
|
|
||||||
listItem.theme_text_color = "Custom"
|
|
||||||
listItem.text_color = ThemeClsColor
|
|
||||||
img_latter = os.path.join(self.kivy_state.imageDir, "text_images", "{}.png".format(
|
|
||||||
avatarImageFirstLetter(body.strip())))
|
|
||||||
message_row.ids.avater_img.source = img_latter
|
|
||||||
listItem.bind(on_release=partial(
|
|
||||||
self.mail_detail, item[5], item[4], message_row))
|
|
||||||
message_row.ids.time_tag.text = str(ShowTimeHistoy(item[7]))
|
|
||||||
message_row.ids.chip_tag.text = item[4]
|
|
||||||
message_row.ids.delete_msg.bind(on_press=partial(
|
|
||||||
self.swipe_delete, item[5], item[4]))
|
|
||||||
self.ids.ml.add_widget(message_row)
|
|
||||||
updated_data = len(self.ids.ml.children)
|
|
||||||
self.has_refreshed = True if data_exist != updated_data else False
|
|
||||||
|
|
||||||
def check_scroll_y(self, instance, somethingelse):
|
|
||||||
"""Scroll fixed length"""
|
|
||||||
if self.ids.scroll_y.scroll_y <= -0.00 and self.has_refreshed:
|
|
||||||
self.ids.scroll_y.scroll_y = .06
|
|
||||||
load_more = len(self.ids.ml.children)
|
|
||||||
self.updating_allmail(load_more)
|
|
||||||
|
|
||||||
def updating_allmail(self, load_more):
|
|
||||||
"""This method is used to update the all mail
|
|
||||||
listing value on the scroll of screen"""
|
|
||||||
self.allMessageQuery(load_more, 5)
|
|
||||||
self.set_mdlist()
|
|
||||||
|
|
||||||
def mail_detail(self, unique_id, folder, instance, *args):
|
|
||||||
"""Load sent and inbox mail details"""
|
|
||||||
if instance.state == 'closed':
|
|
||||||
instance.ids.delete_msg.disabled = True
|
|
||||||
self.kivy_state.is_allmail = True
|
|
||||||
mail_detail_screen(self, unique_id, instance, folder, *args)
|
|
||||||
else:
|
|
||||||
instance.ids.delete_msg.disabled = False
|
|
||||||
|
|
||||||
def swipe_delete(self, unique_id, folder, instance, *args):
|
|
||||||
"""Delete inbox mail from all mail listing"""
|
|
||||||
if folder == 'inbox':
|
|
||||||
helper_inbox.trash(unique_id) # msgid
|
|
||||||
else:
|
|
||||||
helper_sent.delete(unique_id) # ackdata
|
|
||||||
self.ids.ml.remove_widget(instance.parent.parent)
|
|
||||||
try:
|
|
||||||
msg_count_objs = self.parent.parent.ids.content_drawer.ids
|
|
||||||
nav_lay_obj = self.parent.parent.ids
|
|
||||||
except Exception:
|
|
||||||
msg_count_objs = self.parent.parent.parent.ids.content_drawer.ids
|
|
||||||
nav_lay_obj = self.parent.parent.parent.ids
|
|
||||||
if folder == 'inbox':
|
|
||||||
msg_count_objs.inbox_cnt.ids.badge_txt.text = showLimitedCnt(int(self.kivy_state.inbox_count) - 1)
|
|
||||||
self.kivy_state.inbox_count = str(int(self.kivy_state.inbox_count) - 1)
|
|
||||||
nav_lay_obj.sc1.ids.ml.clear_widgets()
|
|
||||||
nav_lay_obj.sc1.loadMessagelist(self.kivy_state.association)
|
|
||||||
else:
|
|
||||||
msg_count_objs.send_cnt.ids.badge_txt.text = showLimitedCnt(int(self.kivy_state.sent_count) - 1)
|
|
||||||
self.kivy_state.sent_count = str(int(self.kivy_state.sent_count) - 1)
|
|
||||||
nav_lay_obj.sc4.ids.ml.clear_widgets()
|
|
||||||
nav_lay_obj.sc4.loadSent(self.kivy_state.association)
|
|
||||||
if folder != 'inbox':
|
|
||||||
msg_count_objs.allmail_cnt.ids.badge_txt.text = showLimitedCnt(int(self.kivy_state.all_count) - 1)
|
|
||||||
self.kivy_state.all_count = str(int(self.kivy_state.all_count) - 1)
|
|
||||||
msg_count_objs.trash_cnt.ids.badge_txt.text = showLimitedCnt(int(self.kivy_state.trash_count) + 1)
|
|
||||||
self.kivy_state.trash_count = str(int(self.kivy_state.trash_count) + 1)
|
|
||||||
if int(self.kivy_state.all_count) <= 0:
|
|
||||||
self.ids.tag_label.text = ''
|
|
||||||
nav_lay_obj.sc17.remove_widget(instance.parent.parent)
|
|
||||||
toast('Deleted')
|
|
||||||
|
|
||||||
def refresh_callback(self, *args):
|
|
||||||
"""Method updates the state of application,
|
|
||||||
While the spinner remains on the screen"""
|
|
||||||
def refresh_callback(interval):
|
|
||||||
"""Load the allmails screen data"""
|
|
||||||
self.ids.ml.clear_widgets()
|
|
||||||
self.remove_widget(self.children[1])
|
|
||||||
try:
|
|
||||||
screens_obj = self.parent.screens[16]
|
|
||||||
except Exception:
|
|
||||||
screens_obj = self.parent.parent.screens[16]
|
|
||||||
screens_obj.add_widget(Allmails())
|
|
||||||
self.ids.refresh_layout.refresh_done()
|
|
||||||
self.tick = 0
|
|
||||||
Clock.schedule_once(refresh_callback, 1)
|
|
||||||
|
|
|
@ -240,6 +240,8 @@ MDNavigationLayout:
|
||||||
id:id_sent
|
id:id_sent
|
||||||
Trash:
|
Trash:
|
||||||
id:id_trash
|
id:id_trash
|
||||||
|
Allmails:
|
||||||
|
id:id_allmail
|
||||||
|
|
||||||
MDNavigationDrawer:
|
MDNavigationDrawer:
|
||||||
id: nav_drawer
|
id: nav_drawer
|
||||||
|
|
|
@ -50,5 +50,10 @@
|
||||||
"Popups": {
|
"Popups": {
|
||||||
"kv_string": "popup",
|
"kv_string": "popup",
|
||||||
"Import": "from pybitmessage.bitmessagekivy.baseclass.popup import *"
|
"Import": "from pybitmessage.bitmessagekivy.baseclass.popup import *"
|
||||||
|
},
|
||||||
|
"All Mails": {
|
||||||
|
"kv_string": "allmails",
|
||||||
|
"name_screen": "allmails",
|
||||||
|
"Import": "from pybitmessage.bitmessagekivy.baseclass.allmail import Allmails"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -6,7 +6,7 @@ from .common import ordered
|
||||||
class AllMailMessage(TeleniumTestProcess):
|
class AllMailMessage(TeleniumTestProcess):
|
||||||
"""AllMail Screen Functionality Testing"""
|
"""AllMail Screen Functionality Testing"""
|
||||||
|
|
||||||
@skip_screen_checks
|
# @skip_screen_checks
|
||||||
@ordered
|
@ordered
|
||||||
def test_show_allmail_list(self):
|
def test_show_allmail_list(self):
|
||||||
"""Show All Messages on Mail Screen/Window"""
|
"""Show All Messages on Mail Screen/Window"""
|
||||||
|
|
Reference in New Issue
Block a user