2019-05-09 14:48:29 +02:00
# -*- coding: utf-8 -*-
2018-07-09 13:17:59 +02:00
from kivy . app import App
2018-07-18 14:49:39 +02:00
from kivy . lang import Builder
2019-05-09 14:48:29 +02:00
from kivy . metrics import dp
from kivy . properties import ObjectProperty
from kivy . uix . image import Image
2019-08-02 11:11:33 +02:00
from kivy . uix . screenmanager import Screen , NoTransition
2019-05-09 14:48:29 +02:00
from kivymd . bottomsheet import MDListBottomSheet , MDGridBottomSheet
from kivymd . button import MDIconButton
from kivymd . date_picker import MDDatePicker
from kivymd . dialog import MDDialog
from kivymd . label import MDLabel
from kivymd . list import ILeftBody , ILeftBodyTouch , IRightBodyTouch , BaseListItem
from kivymd . material_resources import DEVICE_TYPE
from kivymd . navigationdrawer import MDNavigationDrawer , NavigationDrawerHeaderBase
from kivymd . selectioncontrols import MDCheckbox
from kivymd . snackbar import Snackbar
2018-07-25 12:25:47 +02:00
from kivymd . theming import ThemeManager
2019-05-09 14:48:29 +02:00
from kivymd . time_picker import MDTimePicker
from kivymd . list import ThreeLineAvatarIconListItem , TwoLineAvatarIconListItem , TwoLineListItem
from kivy . properties import ListProperty , StringProperty , BooleanProperty
from kivy . clock import Clock
2018-07-24 12:05:39 +02:00
from bmconfigparser import BMConfigParser
2019-05-09 14:48:29 +02:00
import state
import queues
from kivy . uix . popup import Popup
from helper_sql import *
from kivy . uix . gridlayout import GridLayout
from kivy . app import App
from kivy . uix . textinput import TextInput
from kivy . lang import Builder
from kivy . uix . boxlayout import BoxLayout
from kivy . uix . floatlayout import FloatLayout
from kivy . properties import NumericProperty , ListProperty , BooleanProperty , ObjectProperty
from kivy . uix . recycleview import RecycleView
from kivy . uix . recyclegridlayout import RecycleGridLayout
from kivy . uix . recycleview . views import RecycleDataViewBehavior
from kivy . uix . label import Label
from kivy . uix . recycleboxlayout import RecycleBoxLayout
from kivy . uix . behaviors import FocusBehavior
from kivy . uix . recycleview . layout import LayoutSelectionBehavior
import time
from uikivysignaler import UIkivySignaler
from semaphores import kivyuisignaler
from kivy . uix . button import Button
import kivy_helper_search
2018-09-05 12:12:41 +02:00
from kivy . core . window import Window
2019-05-28 13:12:51 +02:00
from functools import partial
2019-06-06 15:48:20 +02:00
from kivy . uix . carousel import Carousel
2019-06-28 16:54:47 +02:00
from kivy . utils import platform
2019-08-02 11:11:33 +02:00
from kivy . uix . spinner import Spinner
2019-08-05 09:41:56 +02:00
from kivymd . textfields import MDTextField
2019-05-13 13:31:33 +02:00
2019-05-09 14:48:29 +02:00
class Navigatorss ( MDNavigationDrawer ) :
image_source = StringProperty ( ' images/qidenticon_two.png ' )
title = StringProperty ( ' Navigation ' )
drawer_logo = StringProperty ( )
2018-08-31 13:19:57 +02:00
2018-07-03 11:08:02 +02:00
2019-05-09 14:48:29 +02:00
class Inbox ( Screen ) :
""" Inbox Screen uses screen to show widgets of screens. """
2019-06-06 15:48:20 +02:00
data = ListProperty ( )
2019-05-09 14:48:29 +02:00
def __init__ ( self , * args , * * kwargs ) :
super ( Inbox , self ) . __init__ ( * args , * * kwargs )
2019-05-13 13:31:33 +02:00
if state . association == ' ' :
if BMConfigParser ( ) . addresses ( ) :
state . association = BMConfigParser ( ) . addresses ( ) [ 0 ]
2019-05-09 14:48:29 +02:00
Clock . schedule_once ( self . init_ui , 0 )
2018-08-31 13:19:57 +02:00
2019-05-09 14:48:29 +02:00
def init_ui ( self , dt = 0 ) :
2019-06-06 15:48:20 +02:00
""" Clock Schdule for method inbox accounts. """
2019-05-13 13:31:33 +02:00
self . inboxaccounts ( )
print ( dt )
def inboxaccounts ( self ) :
""" Load inbox accounts. """
account = state . association
self . loadMessagelist ( account , ' All ' , ' ' )
def loadMessagelist ( self , account , where = " " , what = " " ) :
2019-06-06 15:48:20 +02:00
""" Load Inbox list for Inbox messages. """
2019-08-02 11:11:33 +02:00
if state . searcing_text :
where = [ ' subject ' , ' message ' ]
what = state . searcing_text
2019-05-13 13:31:33 +02:00
xAddress = ' toaddress '
data = [ ]
queryreturn = kivy_helper_search . search_sql (
xAddress , account , " inbox " , where , what , False )
if queryreturn :
for mail in queryreturn :
third_text = mail [ 3 ] . replace ( ' \n ' , ' ' )
2019-06-06 15:48:20 +02:00
data . append ( { ' text ' : mail [ 4 ] . strip ( ) , ' secondary_text ' : mail [ 5 ] [ : 10 ] + ' ........... ' if len ( mail [ 3 ] ) > 10 else mail [ 3 ] + ' \n ' + " " + ( third_text [ : 25 ] + ' ...! ' ) if len ( third_text ) > 25 else third_text , ' receivedTime ' : mail [ 6 ] } )
2019-05-09 14:48:29 +02:00
for item in data :
2019-05-13 13:31:33 +02:00
meny = ThreeLineAvatarIconListItem ( text = item [ ' text ' ] , secondary_text = item [ ' secondary_text ' ] , theme_text_color = ' Custom ' , text_color = NavigateApp ( ) . theme_cls . primary_color )
2019-08-02 11:11:33 +02:00
meny . add_widget ( AvatarSampleWidget ( source = ' ./images/text_images/ {} .png ' . format ( item [ ' secondary_text ' ] [ 0 ] . upper ( ) if ( item [ ' secondary_text ' ] [ 0 ] . upper ( ) > = ' A ' and item [ ' secondary_text ' ] [ 0 ] . upper ( ) < = ' Z ' ) else ' ! ' ) ) )
2019-06-06 15:48:20 +02:00
meny . bind ( on_press = partial ( self . inbox_detail , item [ ' receivedTime ' ] ) )
carousel = Carousel ( direction = ' right ' )
2019-06-28 16:54:47 +02:00
if platform == ' android ' :
2019-08-02 11:11:33 +02:00
carousel . height = 150
elif platform == ' linux ' :
carousel . height = meny . height - 10
2019-06-06 15:48:20 +02:00
carousel . size_hint_y = None
carousel . ignore_perpendicular_swipes = True
carousel . data_index = 0
carousel . min_move = 0.2
del_btn = Button ( text = ' Delete ' )
2019-07-17 10:50:27 +02:00
del_btn . background_normal = ' '
del_btn . background_color = ( 1 , 0 , 0 , 1 )
2019-06-06 15:48:20 +02:00
del_btn . bind ( on_press = partial ( self . delete , item [ ' receivedTime ' ] ) )
carousel . add_widget ( del_btn )
carousel . add_widget ( meny )
ach_btn = Button ( text = ' Achieve ' )
ach_btn . background_color = ( 0 , 1 , 0 , 1 )
ach_btn . bind ( on_press = partial ( self . archive , item [ ' receivedTime ' ] ) )
carousel . add_widget ( ach_btn )
2019-08-02 11:11:33 +02:00
carousel . index = 1
2019-06-06 15:48:20 +02:00
self . ids . ml . add_widget ( carousel )
2019-05-09 14:48:29 +02:00
else :
2019-05-13 13:31:33 +02:00
content = MDLabel ( font_style = ' Body1 ' ,
theme_text_color = ' Primary ' ,
text = " yet no message for this account!!!!!!!!!!!!! " ,
halign = ' center ' ,
bold = True ,
size_hint_y = None ,
valign = ' top ' )
self . ids . ml . add_widget ( content )
2019-05-09 14:48:29 +02:00
2019-06-06 15:48:20 +02:00
def inbox_detail ( self , receivedTime , * args ) :
""" Load inbox page details """
state . detailPageType = ' inbox '
state . sentMailTime = receivedTime
if self . manager :
src_mng_obj = self . manager
else :
src_mng_obj = self . parent . parent
2019-08-02 11:11:33 +02:00
hide_search_btn ( src_mng_obj )
2019-06-06 15:48:20 +02:00
src_mng_obj . screens [ 13 ] . clear_widgets ( )
src_mng_obj . screens [ 13 ] . add_widget ( MailDetail ( ) )
src_mng_obj . current = ' mailDetail '
def delete ( self , data_index , instance , * args ) :
""" Delete inbox mail from inbox listing """
sqlExecute ( " UPDATE inbox SET folder = ' trash ' WHERE received = {} ; " . format ( data_index ) )
2019-07-17 10:50:27 +02:00
msg_count_objs = self . parent . parent . parent . parent . children [ 2 ] . children [ 0 ] . ids
if int ( state . inbox_count ) > 0 :
msg_count_objs . inbox_cnt . badge_text = str ( int ( state . inbox_count ) - 1 )
msg_count_objs . trash_cnt . badge_text = str ( int ( state . trash_count ) + 1 )
state . inbox_count = str ( int ( state . inbox_count ) - 1 )
state . trash_count = str ( int ( state . trash_count ) + 1 )
2019-06-06 15:48:20 +02:00
self . ids . ml . remove_widget ( instance . parent . parent )
self . update_trash ( )
def archive ( self , data_index , instance , * args ) :
""" Archive inbox mail from inbox listing """
sqlExecute ( " UPDATE inbox SET folder = ' trash ' WHERE received = {} ; " . format ( data_index ) )
self . ids . ml . remove_widget ( instance . parent . parent )
self . update_trash ( )
def update_trash ( self ) :
""" Update trash screen mails which is deleted from inbox """
try :
self . parent . screens [ 4 ] . clear_widgets ( )
self . parent . screens [ 4 ] . add_widget ( Trash ( ) )
except Exception as e :
self . parent . parent . screens [ 4 ] . clear_widgets ( )
self . parent . parent . screens [ 4 ] . add_widget ( Trash ( ) )
2019-08-02 11:11:33 +02:00
def refresh_callback ( self , * args ) :
""" A method that updates the state of your application
while the spinner remains on the screen . """
def refresh_callback ( interval ) :
""" This methods is used for loading the inbox screen data """
self . ids . ml . clear_widgets ( )
self . remove_widget ( self . children [ 1 ] )
try :
screens_obj = self . parent . screens [ 0 ]
except Exception as e :
screens_obj = self . parent . parent . screens [ 0 ]
screens_obj . add_widget ( Inbox ( ) )
self . ids . refresh_layout . refresh_done ( )
self . tick = 0
Clock . schedule_once ( refresh_callback , 1 )
2019-06-06 15:48:20 +02:00
2019-05-09 14:48:29 +02:00
class MyAddress ( Screen ) :
""" MyAddress Screen uses screen to show widgets of screens. """
def __init__ ( self , * args , * * kwargs ) :
super ( MyAddress , self ) . __init__ ( * args , * * kwargs )
Clock . schedule_once ( self . init_ui , 0 )
def init_ui ( self , dt = 0 ) :
""" Clock Schdule for method inbox accounts. """
2019-06-28 16:54:47 +02:00
if BMConfigParser ( ) . addresses ( ) or state . kivyapp . variable_1 :
2019-05-13 13:31:33 +02:00
data = [ ]
2019-06-28 16:54:47 +02:00
for address in state . kivyapp . variable_1 :
2019-05-13 13:31:33 +02:00
data . append ( { ' text ' : BMConfigParser ( ) . get ( address , ' label ' ) , ' secondary_text ' : address } )
for item in data :
meny = TwoLineAvatarIconListItem ( text = item [ ' text ' ] , secondary_text = item [ ' secondary_text ' ] , theme_text_color = ' Custom ' , text_color = NavigateApp ( ) . theme_cls . primary_color )
2019-08-02 11:11:33 +02:00
meny . add_widget ( AvatarSampleWidget ( source = ' ./images/text_images/ {} .png ' . format ( item [ ' text ' ] [ 0 ] . upper ( ) if ( item [ ' text ' ] [ 0 ] . upper ( ) > = ' A ' and item [ ' text ' ] [ 0 ] . upper ( ) < = ' Z ' ) else ' ! ' ) ) )
2019-06-28 16:54:47 +02:00
meny . bind ( on_press = partial ( self . myadd_detail , item [ ' secondary_text ' ] , item [ ' text ' ] ) )
2019-05-13 13:31:33 +02:00
self . ids . ml . add_widget ( meny )
else :
content = MDLabel ( font_style = ' Body1 ' ,
theme_text_color = ' Primary ' ,
text = " yet no address is created by user!!!!!!!!!!!!! " ,
halign = ' center ' ,
bold = True ,
size_hint_y = None ,
valign = ' top ' )
self . ids . ml . add_widget ( content )
2019-05-28 13:12:51 +02:00
try :
self . manager . current = ' login '
except Exception as e :
pass
2019-05-09 14:48:29 +02:00
2019-06-28 16:54:47 +02:00
def myadd_detail ( self , fromaddress , label , * args ) :
2019-06-06 15:48:20 +02:00
p = MyaddDetailPopup ( )
p . open ( )
2019-06-28 16:54:47 +02:00
p . set_address ( fromaddress , label )
2019-06-06 15:48:20 +02:00
2019-08-02 11:11:33 +02:00
def refresh_callback ( self , * args ) :
""" A method that updates the state of your application
while the spinner remains on the screen . """
def refresh_callback ( interval ) :
""" This methods is used for loading the myaddress screen data """
self . ids . ml . clear_widgets ( )
self . remove_widget ( self . children [ 1 ] )
try :
screens_obj = self . parent . screens [ 9 ]
except Exception as e :
screens_obj = self . parent . parent . screens [ 9 ]
screens_obj . add_widget ( MyAddress ( ) )
self . ids . refresh_layout . refresh_done ( )
self . tick = 0
Clock . schedule_once ( refresh_callback , 1 )
2019-05-09 14:48:29 +02:00
class AddressBook ( Screen ) :
""" AddressBook Screen uses screen to show widgets of screens. """
def __init__ ( self , * args , * * kwargs ) :
super ( AddressBook , self ) . __init__ ( * args , * * kwargs )
Clock . schedule_once ( self . init_ui , 0 )
2018-07-03 12:06:20 +02:00
2019-05-09 14:48:29 +02:00
def init_ui ( self , dt = 0 ) :
""" Clock Schdule for method inbox accounts. """
data = sqlQuery ( " SELECT label, address from addressbook " )
if data :
for item in data :
meny = TwoLineAvatarIconListItem ( text = item [ 0 ] , secondary_text = item [ 1 ] , theme_text_color = ' Custom ' , text_color = NavigateApp ( ) . theme_cls . primary_color )
2019-08-02 11:11:33 +02:00
meny . add_widget ( AvatarSampleWidget ( source = ' ./images/text_images/ {} .png ' . format ( item [ 0 ] [ 0 ] . upper ( ) if ( item [ 0 ] [ 0 ] . upper ( ) > = ' A ' and item [ 0 ] [ 0 ] . upper ( ) < = ' Z ' ) else ' ! ' ) ) )
2019-06-28 16:54:47 +02:00
meny . bind ( on_press = partial ( self . addBook_detail , item [ 1 ] , item [ 0 ] ) )
2019-07-17 10:50:27 +02:00
carousel = Carousel ( direction = ' right ' )
if platform == ' android ' :
2019-08-02 11:11:33 +02:00
carousel . height = 140
elif platform == ' linux ' :
carousel . height = meny . height - 10
2019-07-17 10:50:27 +02:00
carousel . size_hint_y = None
carousel . ignore_perpendicular_swipes = True
carousel . data_index = 0
carousel . min_move = 0.2
del_btn = Button ( text = ' Delete ' )
del_btn . background_normal = ' '
del_btn . background_color = ( 1 , 0 , 0 , 1 )
del_btn . bind ( on_press = partial ( self . delete_address , item [ 1 ] ) )
carousel . add_widget ( del_btn )
carousel . add_widget ( meny )
carousel . index = 1
self . ids . ml . add_widget ( carousel )
2019-05-09 14:48:29 +02:00
else :
content = MDLabel ( font_style = ' Body1 ' ,
theme_text_color = ' Primary ' ,
text = " No Contact Found yet...... " ,
halign = ' center ' ,
bold = True ,
size_hint_y = None ,
valign = ' top ' )
self . ids . ml . add_widget ( content )
def refreshs ( self , * args ) :
state . navinstance . ids . sc11 . clear_widgets ( )
state . navinstance . ids . sc11 . add_widget ( AddressBook ( ) )
2019-06-28 16:54:47 +02:00
def addBook_detail ( self , address , label , * args ) :
p = AddbookDetailPopup ( )
p . open ( )
p . set_addbook_data ( address , label )
2019-05-13 13:31:33 +02:00
2019-07-17 10:50:27 +02:00
def delete_address ( self , address , instance , * args ) :
""" Delete inbox mail from inbox listing """
self . ids . ml . remove_widget ( instance . parent . parent )
sqlExecute ( " DELETE FROM addressbook WHERE address = ' {} ' ; " . format ( address ) )
2019-05-09 14:48:29 +02:00
class SelectableRecycleBoxLayout ( FocusBehavior , LayoutSelectionBehavior ,
RecycleBoxLayout ) :
''' Adds selection and focus behaviour to the view. '''
2019-05-13 13:31:33 +02:00
pass
2019-05-09 14:48:29 +02:00
class SelectableLabel ( RecycleDataViewBehavior , Label ) :
''' Add selection support to the Label '''
index = None
selected = BooleanProperty ( False )
selectable = BooleanProperty ( True )
def refresh_view_attrs ( self , rv , index , data ) :
''' Catch and handle the view changes '''
self . index = index
return super ( SelectableLabel , self ) . refresh_view_attrs (
rv , index , data )
def on_touch_down ( self , touch ) :
''' Add selection on touch down '''
if super ( SelectableLabel , self ) . on_touch_down ( touch ) :
2018-09-05 12:12:41 +02:00
return True
2019-05-09 14:48:29 +02:00
if self . collide_point ( * touch . pos ) and self . selectable :
return self . parent . select_with_touch ( self . index , touch )
2018-09-05 12:12:41 +02:00
2019-05-09 14:48:29 +02:00
def apply_selection ( self , rv , index , is_selected ) :
''' Respond to the selection of items in the view. '''
self . selected = is_selected
if is_selected :
print ( " selection changed to {0} " . format ( rv . data [ index ] ) )
rv . parent . txt_input . text = rv . parent . txt_input . text . replace ( rv . parent . txt_input . text , rv . data [ index ] [ ' text ' ] )
2018-09-05 12:12:41 +02:00
2018-08-07 08:14:14 +02:00
2019-05-09 14:48:29 +02:00
class RV ( RecycleView ) :
def __init__ ( self , * * kwargs ) :
super ( RV , self ) . __init__ ( * * kwargs )
2018-07-03 12:06:20 +02:00
2018-08-21 14:48:16 +02:00
2019-05-09 14:48:29 +02:00
class DropDownWidget ( BoxLayout ) :
txt_input = ObjectProperty ( )
rv = ObjectProperty ( )
2018-08-21 14:48:16 +02:00
2019-05-09 14:48:29 +02:00
def send ( self ) :
""" Send message from one address to another. """
fromAddress = str ( self . ids . ti . text )
toAddress = str ( self . ids . txt_input . text )
subject = str ( self . ids . subject . text )
message = str ( self . ids . body . text )
encoding = 3
print ( " message: " , self . ids . body . text )
sendMessageToPeople = True
if sendMessageToPeople :
2019-05-13 13:31:33 +02:00
if toAddress != ' ' and subject and message :
2019-05-09 14:48:29 +02:00
from addresses import decodeAddress
status , addressVersionNumber , streamNumber , ripe = decodeAddress (
toAddress )
if status == ' success ' :
from addresses import *
toAddress = addBMIfNotPresent ( toAddress )
statusIconColor = ' red '
if addressVersionNumber > 4 or addressVersionNumber < = 1 :
print ( " addressVersionNumber > 4 or addressVersionNumber <= 1 " )
if streamNumber > 1 or streamNumber == 0 :
print ( " streamNumber > 1 or streamNumber == 0 " )
if statusIconColor == ' red ' :
print ( " shared.statusIconColor == ' red ' " )
stealthLevel = BMConfigParser ( ) . safeGetInt (
' bitmessagesettings ' , ' ackstealthlevel ' )
from helper_ackPayload import genAckPayload
ackdata = genAckPayload ( streamNumber , stealthLevel )
t = ( )
sqlExecute (
''' INSERT INTO sent VALUES (?,?,?,?,?,?,?,?,?,?,?,?,?,?,?) ''' ,
' ' ,
toAddress ,
ripe ,
fromAddress ,
subject ,
message ,
ackdata ,
int ( time . time ( ) ) ,
int ( time . time ( ) ) ,
0 ,
' msgqueued ' ,
0 ,
' sent ' ,
encoding ,
BMConfigParser ( ) . getint ( ' bitmessagesettings ' , ' ttl ' ) )
2019-06-28 16:54:47 +02:00
state . check_sent_acc = fromAddress
state . msg_counter_objs = self . parent . parent . parent . parent . parent . parent . children [ 0 ] . children [ 2 ] . children [ 0 ] . ids
# state.msg_counter_objs.send_cnt.badge_text = str(int(state.sent_count) + 1)
# state.sent_count = str(int(state.sent_count) + 1)
2019-05-09 14:48:29 +02:00
self . parent . parent . screens [ 3 ] . clear_widgets ( )
self . parent . parent . screens [ 3 ] . add_widget ( Sent ( ) )
toLabel = ' '
queues . workerQueue . put ( ( ' sendmessage ' , toAddress ) )
print ( " sqlExecute successfully ####################### " )
self . ids . body . text = ' '
self . ids . ti . text = ' '
self . ids . subject . text = ' '
self . ids . txt_input . text = ' '
self . parent . parent . current = ' sent '
self . ids . btn . text = ' select '
self . ids . ti . text = ' '
2019-08-02 11:11:33 +02:00
self . parent . parent . parent . parent . parent . ids . serch_btn . opacity = 1
self . parent . parent . parent . parent . parent . ids . serch_btn . disabled = False
2019-06-28 16:54:47 +02:00
2019-05-09 14:48:29 +02:00
return None
2019-05-13 13:31:33 +02:00
else :
msg = ' Enter a valid recipients address '
elif not toAddress :
2019-05-28 13:12:51 +02:00
msg = ' Please fill the form '
else :
msg = ' Please fill the form '
self . address_error_message ( msg )
2019-05-13 13:31:33 +02:00
def address_error_message ( self , msg ) :
self . box = FloatLayout ( )
self . lab = ( Label ( text = msg , font_size = 25 ,
size_hint = ( None , None ) , pos_hint = { ' x ' : .25 , ' y ' : .6 } ) )
self . box . add_widget ( self . lab )
self . but = ( Button ( text = " dismiss " , size_hint = ( None , None ) ,
width = 200 , height = 50 , pos_hint = { ' x ' : .3 , ' y ' : 0 } ) )
self . box . add_widget ( self . but )
self . main_pop = Popup ( title = " Error " , content = self . box ,
size_hint = ( None , None ) , size = ( 550 , 400 ) , auto_dismiss = False , title_size = 30 )
self . but . bind ( on_press = self . main_pop . dismiss )
2019-06-06 15:48:20 +02:00
# self.main_pop.background = './images/popup.jpeg'
2019-05-13 13:31:33 +02:00
self . main_pop . open ( )
2018-08-31 13:19:57 +02:00
2018-07-24 12:05:39 +02:00
2019-05-09 14:48:29 +02:00
class MyTextInput ( TextInput ) :
txt_input = ObjectProperty ( )
flt_list = ObjectProperty ( )
word_list = ListProperty ( )
# this is the variable storing the number to which the look-up will start
starting_no = NumericProperty ( 3 )
suggestion_text = ' '
def __init__ ( self , * * kwargs ) :
super ( MyTextInput , self ) . __init__ ( * * kwargs )
def on_text ( self , instance , value ) :
# find all the occurrence of the word
self . parent . parent . parent . parent . ids . rv . data = [ ]
matches = [ self . word_list [ i ] for i in range ( len ( self . word_list ) ) if self . word_list [ i ] [ : self . starting_no ] == value [ : self . starting_no ] ]
# display the data in the recycleview
display_data = [ ]
for i in matches :
display_data . append ( { ' text ' : i } )
self . parent . parent . parent . parent . ids . rv . data = display_data
# ensure the size is okay
if len ( matches ) < = 10 :
2019-05-13 13:31:33 +02:00
self . parent . height = ( 250 + ( len ( matches ) * 20 ) )
else :
2019-05-09 14:48:29 +02:00
self . parent . height = 400
def keyboard_on_key_down ( self , window , keycode , text , modifiers ) :
if self . suggestion_text and keycode [ 1 ] == ' tab ' :
self . insert_text ( self . suggestion_text + ' ' )
return True
return super ( MyTextInput , self ) . keyboard_on_key_down ( window , keycode , text , modifiers )
2018-08-31 13:19:57 +02:00
2019-05-09 14:48:29 +02:00
class Payment ( Screen ) :
pass
2018-07-03 12:06:20 +02:00
2019-05-13 13:31:33 +02:00
2019-05-09 14:48:29 +02:00
class Login ( Screen ) :
pass
2018-07-03 12:06:20 +02:00
2018-08-31 13:19:57 +02:00
2019-05-09 14:48:29 +02:00
class NetworkStat ( Screen ) :
text_variable_1 = StringProperty ( ' {0} :: {1} ' . format ( ' Total Connections ' , ' 0 ' ) )
text_variable_2 = StringProperty ( ' Processed {0} per-to-per messages ' . format ( ' 0 ' ) )
text_variable_3 = StringProperty ( ' Processed {0} brodcast messages ' . format ( ' 0 ' ) )
text_variable_4 = StringProperty ( ' Processed {0} public keys ' . format ( ' 0 ' ) )
text_variable_5 = StringProperty ( ' Processed {0} object to be synced ' . format ( ' 0 ' ) )
2018-08-21 14:48:16 +02:00
2018-08-04 10:30:12 +02:00
def __init__ ( self , * args , * * kwargs ) :
2019-05-09 14:48:29 +02:00
super ( NetworkStat , self ) . __init__ ( * args , * * kwargs )
Clock . schedule_interval ( self . init_ui , 1 )
2018-08-04 10:30:12 +02:00
def init_ui ( self , dt = 0 ) :
2018-09-01 13:45:39 +02:00
""" Clock Schdule for method inbox accounts. """
2019-05-09 14:48:29 +02:00
import network . stats
import shared
2019-05-13 13:31:33 +02:00
from network import objectracker
2019-05-09 14:48:29 +02:00
self . text_variable_1 = ' {0} :: {1} ' . format ( ' Total Connections ' , str ( len ( network . stats . connectedHostsList ( ) ) ) )
self . text_variable_2 = ' Processed {0} per-to-per messages ' . format ( str ( shared . numberOfMessagesProcessed ) )
self . text_variable_3 = ' Processed {0} brodcast messages ' . format ( str ( shared . numberOfBroadcastsProcessed ) )
self . text_variable_4 = ' Processed {0} public keys ' . format ( str ( shared . numberOfPubkeysProcessed ) )
self . text_variable_5 = ' {0} object to be synced ' . format ( len ( objectracker . missingObjects ) )
2018-08-04 10:30:12 +02:00
2018-08-07 08:14:14 +02:00
2019-05-09 14:48:29 +02:00
class ContentNavigationDrawer ( Navigatorss ) :
pass
2018-08-04 10:30:12 +02:00
2019-05-09 14:48:29 +02:00
class Random ( Screen ) :
is_active = BooleanProperty ( False )
checked = StringProperty ( " " )
# self.manager.parent.ids.create.children[0].source = 'images/plus-4-xxl.png'
def generateaddress ( self ) :
import queues
# queues.apiAddressGeneratorReturnQueue.queue.clear()
streamNumberForAddress = 1
label = self . ids . label . text
eighteenByteRipe = False
nonceTrialsPerByte = 1000
payloadLengthExtraBytes = 1000
2019-05-13 13:31:33 +02:00
if self . ids . label . text :
queues . addressGeneratorQueue . put ( (
' createRandomAddress ' ,
4 , streamNumberForAddress ,
label , 1 , " " , eighteenByteRipe ,
nonceTrialsPerByte ,
payloadLengthExtraBytes )
)
2019-06-06 15:48:20 +02:00
# self.manager.current = 'add_sucess'
self . manager . current = ' myaddress '
2019-05-13 13:31:33 +02:00
self . ids . label . text = ' '
2019-05-28 13:12:51 +02:00
self . parent . parent . parent . parent . ids . toolbar . opacity = 1
self . parent . parent . parent . parent . ids . toolbar . disabled = False
2018-08-04 10:30:12 +02:00
2019-06-28 16:54:47 +02:00
# state.myAddressObj = self.parent.parent.parent.parent.ids.sc10
self . parent . parent . parent . parent . ids . sc10 . clear_widgets ( )
self . parent . parent . parent . parent . ids . sc10 . add_widget ( MyAddress ( ) )
2018-08-04 10:30:12 +02:00
class AddressSuccessful ( Screen ) :
pass
2018-07-03 11:08:02 +02:00
2018-07-24 12:05:39 +02:00
2018-07-18 14:49:39 +02:00
class Sent ( Screen ) :
2018-08-31 13:19:57 +02:00
""" Sent Screen uses screen to show widgets of screens. """
2018-08-21 14:48:16 +02:00
data = ListProperty ( )
2018-08-09 12:20:20 +02:00
def __init__ ( self , * args , * * kwargs ) :
super ( Sent , self ) . __init__ ( * args , * * kwargs )
2018-09-04 14:44:28 +02:00
if state . association == ' ' :
2019-05-09 14:48:29 +02:00
if BMConfigParser ( ) . addresses ( ) :
state . association = BMConfigParser ( ) . addresses ( ) [ 0 ]
2018-08-09 12:20:20 +02:00
Clock . schedule_once ( self . init_ui , 0 )
def init_ui ( self , dt = 0 ) :
2018-09-01 13:45:39 +02:00
""" Clock Schdule for method sent accounts. """
2018-08-21 14:48:16 +02:00
self . sentaccounts ( )
2018-08-31 14:34:20 +02:00
print ( dt )
2018-08-09 12:20:20 +02:00
2018-08-21 14:48:16 +02:00
def sentaccounts ( self ) :
2018-09-01 13:45:39 +02:00
""" Load sent accounts. """
2018-09-04 14:44:28 +02:00
account = state . association
2018-08-21 14:48:16 +02:00
self . loadSent ( account , ' All ' , ' ' )
2018-08-09 12:20:20 +02:00
2018-08-21 14:48:16 +02:00
def loadSent ( self , account , where = " " , what = " " ) :
2018-09-01 13:45:39 +02:00
""" Load Sent list for Sent messages. """
2019-08-02 11:11:33 +02:00
if state . searcing_text :
where = [ ' subject ' , ' message ' ]
what = state . searcing_text
2018-08-09 12:20:20 +02:00
xAddress = ' fromaddress '
2018-08-31 13:19:57 +02:00
queryreturn = kivy_helper_search . search_sql (
xAddress , account , " sent " , where , what , False )
2019-06-28 16:54:47 +02:00
if state . msg_counter_objs and state . association == state . check_sent_acc :
state . msg_counter_objs . send_cnt . badge_text = str ( len ( queryreturn ) )
state . sent_count = str ( int ( state . sent_count ) + 1 )
state . check_sent_acc = None
2018-08-09 12:20:20 +02:00
if queryreturn :
2019-05-09 14:48:29 +02:00
for mail in queryreturn :
third_text = mail [ 3 ] . replace ( ' \n ' , ' ' )
2019-06-06 15:48:20 +02:00
self . data . append ( { ' text ' : mail [ 1 ] . strip ( ) , ' secondary_text ' : mail [ 2 ] [ : 10 ] + ' ........... ' if len ( mail [ 2 ] ) > 10 else mail [ 2 ] + ' \n ' + " " + ( third_text [ : 25 ] + ' ...! ' ) if len ( third_text ) > 25 else third_text , ' lastactiontime ' : mail [ 6 ] } )
for item in self . data :
2019-05-13 13:31:33 +02:00
meny = ThreeLineAvatarIconListItem ( text = item [ ' text ' ] , secondary_text = item [ ' secondary_text ' ] , theme_text_color = ' Custom ' , text_color = NavigateApp ( ) . theme_cls . primary_color )
2019-08-02 11:11:33 +02:00
meny . add_widget ( AvatarSampleWidget ( source = ' ./images/text_images/ {} .png ' . format ( item [ ' secondary_text ' ] [ 0 ] . upper ( ) if ( item [ ' secondary_text ' ] [ 0 ] . upper ( ) > = ' A ' and item [ ' secondary_text ' ] [ 0 ] . upper ( ) < = ' Z ' ) else ' ! ' ) ) )
2019-05-28 13:12:51 +02:00
meny . bind ( on_press = partial ( self . sent_detail , item [ ' lastactiontime ' ] ) )
2019-06-06 15:48:20 +02:00
carousel = Carousel ( direction = ' right ' )
2019-06-28 16:54:47 +02:00
if platform == ' android ' :
2019-08-02 11:11:33 +02:00
carousel . height = 150
elif platform == ' linux ' :
carousel . height = meny . height - 10
2019-06-06 15:48:20 +02:00
carousel . size_hint_y = None
carousel . ignore_perpendicular_swipes = True
carousel . data_index = 0
carousel . min_move = 0.2
del_btn = Button ( text = ' Delete ' )
2019-07-17 10:50:27 +02:00
del_btn . background_normal = ' '
del_btn . background_color = ( 1.0 , 0.0 , 0.0 , 1.0 )
2019-06-06 15:48:20 +02:00
del_btn . bind ( on_press = partial ( self . delete , item [ ' lastactiontime ' ] ) )
carousel . add_widget ( del_btn )
carousel . add_widget ( meny )
ach_btn = Button ( text = ' Achieve ' )
ach_btn . background_color = ( 0 , 1 , 0 , 1 )
ach_btn . bind ( on_press = partial ( self . archive , item [ ' lastactiontime ' ] ) )
carousel . add_widget ( ach_btn )
carousel . index = 1
self . ids . ml . add_widget ( carousel )
2018-08-09 12:20:20 +02:00
else :
2019-05-09 14:48:29 +02:00
content = MDLabel ( font_style = ' Body1 ' ,
2019-05-13 13:31:33 +02:00
theme_text_color = ' Primary ' ,
text = " yet no message for this account!!!!!!!!!!!!! " ,
halign = ' center ' ,
bold = True ,
size_hint_y = None ,
valign = ' top ' )
2019-05-09 14:48:29 +02:00
self . ids . ml . add_widget ( content )
2018-07-24 12:05:39 +02:00
2019-05-28 13:12:51 +02:00
def sent_detail ( self , lastsenttime , * args ) :
2019-06-06 15:48:20 +02:00
""" Load sent mail details """
state . detailPageType = ' sent '
2019-05-28 13:12:51 +02:00
state . sentMailTime = lastsenttime
if self . manager :
src_mng_obj = self . manager
else :
src_mng_obj = self . parent . parent
2019-08-02 11:11:33 +02:00
hide_search_btn ( src_mng_obj )
2019-05-28 13:12:51 +02:00
src_mng_obj . screens [ 13 ] . clear_widgets ( )
2019-06-06 15:48:20 +02:00
src_mng_obj . screens [ 13 ] . add_widget ( MailDetail ( ) )
src_mng_obj . current = ' mailDetail '
def delete ( self , data_index , instance , * args ) :
""" delete sent mail from sent mail listing """
2019-06-28 16:54:47 +02:00
try :
2019-08-02 11:11:33 +02:00
msg_count_objs = self . parent . parent . parent . parent . children [ 2 ] . children [ 0 ] . ids
2019-06-28 16:54:47 +02:00
except Exception as e :
msg_count_objs = self . parent . parent . parent . parent . parent . children [ 2 ] . children [ 0 ] . ids
if int ( state . sent_count ) > 0 :
msg_count_objs . send_cnt . badge_text = str ( int ( state . sent_count ) - 1 )
msg_count_objs . trash_cnt . badge_text = str ( int ( state . trash_count ) + 1 )
state . sent_count = str ( int ( state . sent_count ) - 1 )
state . trash_count = str ( int ( state . trash_count ) + 1 )
2019-06-06 15:48:20 +02:00
sqlExecute ( " UPDATE sent SET folder = ' trash ' WHERE lastactiontime = {} ; " . format ( data_index ) )
self . ids . ml . remove_widget ( instance . parent . parent )
self . update_trash ( )
def archive ( self , data_index , instance , * args ) :
""" archive sent mail from sent mail listing """
sqlExecute ( " UPDATE sent SET folder = ' trash ' WHERE lastactiontime = {} ; " . format ( data_index ) )
self . ids . ml . remove_widget ( instance . parent . parent )
self . update_trash ( )
def update_trash ( self ) :
""" Update trash screen mails which is deleted from inbox """
try :
self . parent . screens [ 4 ] . clear_widgets ( )
self . parent . screens [ 4 ] . add_widget ( Trash ( ) )
except Exception as e :
self . parent . parent . screens [ 4 ] . clear_widgets ( )
self . parent . parent . screens [ 4 ] . add_widget ( Trash ( ) )
2019-05-28 13:12:51 +02:00
2019-05-13 13:31:33 +02:00
2018-07-18 14:49:39 +02:00
class Trash ( Screen ) :
2018-08-31 13:19:57 +02:00
""" Trash Screen uses screen to show widgets of screens. """
2018-08-21 14:48:16 +02:00
def __init__ ( self , * args , * * kwargs ) :
super ( Trash , self ) . __init__ ( * args , * * kwargs )
Clock . schedule_once ( self . init_ui , 0 )
def init_ui ( self , dt = 0 ) :
2018-09-01 13:45:39 +02:00
""" Clock Schdule for method inbox accounts. """
2019-06-28 16:54:47 +02:00
if state . association == ' ' :
if BMConfigParser ( ) . addresses ( ) :
state . association = BMConfigParser ( ) . addresses ( ) [ 0 ]
inbox = sqlQuery ( " SELECT toaddress, fromaddress, subject, message from inbox WHERE folder = ' trash ' and fromaddress = ' {} ' ; " . format ( state . association ) )
sent = sqlQuery ( " SELECT toaddress, fromaddress, subject, message from sent WHERE folder = ' trash ' and fromaddress = ' {} ' ; " . format ( state . association ) )
2019-06-06 15:48:20 +02:00
trash_data = inbox + sent
2019-06-28 16:54:47 +02:00
2019-06-06 15:48:20 +02:00
for item in trash_data :
meny = ThreeLineAvatarIconListItem ( text = item [ 1 ] , secondary_text = item [ 2 ] , theme_text_color = ' Custom ' , text_color = NavigateApp ( ) . theme_cls . primary_color )
2019-08-02 11:11:33 +02:00
meny . add_widget ( AvatarSampleWidget ( source = ' ./images/text_images/ {} .png ' . format ( item [ 2 ] [ 0 ] . upper ( ) if ( item [ 2 ] [ 0 ] . upper ( ) > = ' A ' and item [ 2 ] [ 0 ] . upper ( ) < = ' Z ' ) else ' ! ' ) ) )
2019-05-09 14:48:29 +02:00
self . ids . ml . add_widget ( meny )
2018-08-21 14:48:16 +02:00
2019-05-09 14:48:29 +02:00
class Page ( Screen ) :
pass
2018-07-03 11:08:02 +02:00
2019-05-09 14:48:29 +02:00
class Create ( Screen ) :
def __init__ ( self , * * kwargs ) :
super ( Create , self ) . __init__ ( * * kwargs )
widget_1 = DropDownWidget ( )
from helper_sql import *
widget_1 . ids . txt_input . word_list = [ addr [ 1 ] for addr in sqlQuery ( " SELECT label, address from addressbook " ) ]
widget_1 . ids . txt_input . starting_no = 2
self . add_widget ( widget_1 )
2018-08-31 14:34:20 +02:00
2019-05-13 13:31:33 +02:00
2019-05-09 14:48:29 +02:00
class AddressSuccessful ( Screen ) :
2018-07-18 14:49:39 +02:00
pass
2018-07-03 11:08:02 +02:00
2019-05-09 14:48:29 +02:00
class Setting ( Screen ) :
2018-07-18 14:49:39 +02:00
pass
2018-07-03 11:08:02 +02:00
2018-07-07 14:11:58 +02:00
2019-05-09 14:48:29 +02:00
class NavigateApp ( App ) :
theme_cls = ThemeManager ( )
previous_date = ObjectProperty ( )
obj_1 = ObjectProperty ( )
variable_1 = ListProperty ( BMConfigParser ( ) . addresses ( ) )
nav_drawer = ObjectProperty ( )
2019-06-28 16:54:47 +02:00
state . screen_density = Window . size
2019-05-13 13:31:33 +02:00
title = " PyBitmessage "
2019-07-17 10:50:27 +02:00
imgstatus = False
2019-05-09 14:48:29 +02:00
count = 0
menu_items = [
{ ' viewclass ' : ' MDMenuItem ' ,
' text ' : ' Example item ' } ,
{ ' viewclass ' : ' MDMenuItem ' ,
' text ' : ' Example item ' } ,
{ ' viewclass ' : ' MDMenuItem ' ,
' text ' : ' Example item ' } ,
{ ' viewclass ' : ' MDMenuItem ' ,
' text ' : ' Example item ' } ,
{ ' viewclass ' : ' MDMenuItem ' ,
' text ' : ' Example item ' } ,
{ ' viewclass ' : ' MDMenuItem ' ,
' text ' : ' Example item ' } ,
{ ' viewclass ' : ' MDMenuItem ' ,
' text ' : ' Example item ' } ,
]
2018-07-24 12:05:39 +02:00
2019-05-09 14:48:29 +02:00
def build ( self ) :
2019-08-02 11:11:33 +02:00
import os
2019-05-09 14:48:29 +02:00
main_widget = Builder . load_file (
os . path . join ( os . path . dirname ( __file__ ) , ' main.kv ' ) )
self . nav_drawer = Navigatorss ( )
self . obj_1 = AddressBook ( )
kivysignalthread = UIkivySignaler ( )
kivysignalthread . daemon = True
kivysignalthread . start ( )
2019-06-06 15:48:20 +02:00
Window . bind ( on_keyboard = self . on_key )
2019-05-09 14:48:29 +02:00
return main_widget
2018-07-24 12:05:39 +02:00
2019-05-09 14:48:29 +02:00
def run ( self ) :
kivyuisignaler . release ( )
super ( NavigateApp , self ) . run ( )
2018-07-24 14:42:53 +02:00
2019-05-09 14:48:29 +02:00
def show_address_success ( self ) :
content = MDLabel ( font_style = ' Body1 ' ,
theme_text_color = ' Secondary ' ,
text = " Successfully Saved your contact address. "
" That ' s pretty awesome right! " ,
size_hint_y = None ,
valign = ' top ' )
content . bind ( texture_size = content . setter ( ' size ' ) )
self . dialog . open ( )
2018-07-24 12:05:39 +02:00
2019-05-09 14:48:29 +02:00
@staticmethod
def showmeaddresses ( name = " text " ) :
""" Show the addresses in spinner to make as dropdown. """
if name == " text " :
if bmconfigparserigParser ( ) . addresses ( ) :
return BMConfigParser ( ) . addresses ( ) [ 0 ] [ : 16 ] + ' .. '
else :
return " textdemo "
elif name == " values " :
if BMConfigParser ( ) . addresses ( ) :
return [ address [ : 16 ] + ' .. ' for address in BMConfigParser ( ) . addresses ( ) ]
else :
return " valuesdemo "
2018-07-24 12:05:39 +02:00
2019-05-09 14:48:29 +02:00
def getCurrentAccountData ( self , text ) :
""" Get Current Address Account Data. """
2019-07-17 10:50:27 +02:00
address_label = self . current_address_label ( BMConfigParser ( ) . get ( text , ' label ' ) )
self . root_window . children [ 1 ] . ids . toolbar . title = address_label
2019-05-09 14:48:29 +02:00
state . association = text
self . root . ids . sc1 . clear_widgets ( )
self . root . ids . sc4 . clear_widgets ( )
self . root . ids . sc5 . clear_widgets ( )
2019-07-17 10:50:27 +02:00
self . root . ids . sc16 . clear_widgets ( )
2019-05-09 14:48:29 +02:00
self . root . ids . sc1 . add_widget ( Inbox ( ) )
self . root . ids . sc4 . add_widget ( Sent ( ) )
self . root . ids . sc5 . add_widget ( Trash ( ) )
2019-07-17 10:50:27 +02:00
self . root . ids . sc16 . add_widget ( Draft ( ) )
2019-06-06 15:48:20 +02:00
self . root . ids . scr_mngr . current = ' inbox '
2018-08-31 13:19:57 +02:00
2019-06-28 16:54:47 +02:00
msg_counter_objs = self . root_window . children [ 1 ] . children [ 2 ] . children [ 0 ] . ids
state . sent_count = str ( sqlQuery ( " SELECT COUNT(*) FROM sent WHERE fromaddress = ' {} ' and folder = ' sent ' ; " . format ( state . association ) ) [ 0 ] [ 0 ] )
state . inbox_count = str ( sqlQuery ( " SELECT COUNT(*) FROM inbox WHERE fromaddress = ' {} ' and folder = ' inbox ' ; " . format ( state . association ) ) [ 0 ] [ 0 ] )
state . trash_count = str ( sqlQuery ( " SELECT (SELECT count(*) FROM sent where fromaddress = ' {0} ' and folder = ' trash ' )+(SELECT count(*) FROM inbox where fromaddress = ' {0} ' and folder = ' trash ' ) AS SumCount " . format ( state . association ) ) [ 0 ] [ 0 ] )
2019-07-17 10:50:27 +02:00
state . draft_count = str ( sqlQuery ( " SELECT COUNT(*) FROM sent WHERE fromaddress = ' {} ' and folder = ' draft ' ; " . format ( state . association ) ) [ 0 ] [ 0 ] )
2019-06-28 16:54:47 +02:00
if msg_counter_objs :
msg_counter_objs . send_cnt . badge_text = state . sent_count
msg_counter_objs . inbox_cnt . badge_text = state . inbox_count
msg_counter_objs . trash_cnt . badge_text = state . trash_count
2019-07-17 10:50:27 +02:00
msg_counter_objs . draft_cnt . badge_text = state . draft_count
2019-06-28 16:54:47 +02:00
2019-05-09 14:48:29 +02:00
def getInboxMessageDetail ( self , instance ) :
""" It will get message detail after make selected message description. """
try :
self . root . ids . _mngr . current = ' page '
except AttributeError :
self . parent . manager . current = ' page '
print ( ' Message Clicked {} ' . format ( instance ) )
2018-08-04 10:30:12 +02:00
2019-05-09 14:48:29 +02:00
@staticmethod
def getCurrentAccount ( ) :
""" It uses to get current account label. """
if state . association :
return state . association
else :
return " Bitmessage Login "
2018-09-05 16:18:57 +02:00
2019-05-09 14:48:29 +02:00
def addingtoaddressbook ( self ) :
p = GrashofPopup ( )
p . open ( )
def getDefaultAccData ( self ) :
if BMConfigParser ( ) . addresses ( ) :
return BMConfigParser ( ) . addresses ( ) [ 0 ]
return ' Select Address '
2019-05-28 13:12:51 +02:00
def addressexist ( self ) :
if BMConfigParser ( ) . addresses ( ) :
return True
return False
2019-06-06 15:48:20 +02:00
def on_key ( self , window , key , * args ) :
2019-07-17 10:50:27 +02:00
""" This method is used for going on previous screen """
2019-06-06 15:48:20 +02:00
if key == 27 : # the esc key
2019-07-17 10:50:27 +02:00
if self . root . ids . scr_mngr . current == " mailDetail " :
self . root . ids . scr_mngr . current = ' sent ' if state . detailPageType == ' sent ' else ' inbox '
2019-08-02 11:11:33 +02:00
show_search_btn ( self )
2019-06-06 15:48:20 +02:00
# this is for direction of the screen comesup
2019-07-17 10:50:27 +02:00
elif self . root . ids . scr_mngr . current == " create " :
composer_objs = self . root
from_addr = str ( self . root . children [ 1 ] . children [ 0 ] . children [ 0 ] . children [ 0 ] . children [ 0 ] . ids . ti . text )
to_addr = str ( self . root . children [ 1 ] . children [ 0 ] . children [ 0 ] . children [ 0 ] . children [ 0 ] . ids . txt_input . text )
if from_addr and to_addr :
Draft ( ) . draft_msg ( composer_objs )
2019-08-02 11:11:33 +02:00
self . root . ids . serch_btn . opacity = 1
self . root . ids . serch_btn . disabled = False
2019-06-06 15:48:20 +02:00
self . root . ids . scr_mngr . current = ' inbox '
2019-07-17 10:50:27 +02:00
elif self . root . ids . scr_mngr . current == " showqrcode " :
self . root . ids . scr_mngr . current = ' myaddress '
elif self . root . ids . scr_mngr . current == " random " :
2019-08-02 11:11:33 +02:00
self . root . ids . scr_mngr . current = ' login '
2019-06-06 15:48:20 +02:00
else :
2019-07-17 10:50:27 +02:00
self . root . ids . scr_mngr . current = ' inbox '
2019-08-02 11:11:33 +02:00
show_search_btn ( self )
2019-07-17 10:50:27 +02:00
self . root . ids . scr_mngr . transition . direction = ' right '
self . root . ids . scr_mngr . transition . bind ( on_complete = self . restart )
return True
2019-08-02 11:11:33 +02:00
def restart ( self , * args ) :
2019-07-17 10:50:27 +02:00
""" this method is used to set transition direction """
self . root . ids . scr_mngr . transition . direction = ' left '
self . root . ids . scr_mngr . transition . unbind ( on_complete = self . restart )
2019-06-06 15:48:20 +02:00
def status_dispatching ( self , data ) :
ackData , message = data
if state . ackdata == ackData :
state . status . status = message
2019-06-28 16:54:47 +02:00
def clear_composer ( self ) :
""" if slow down the nwe will make new composer edit screen """
2019-08-02 11:11:33 +02:00
self . root . ids . serch_btn . opacity = 0
self . root . ids . serch_btn . disabled = True
2019-06-28 16:54:47 +02:00
composer_obj = self . root . ids . sc3 . children [ 0 ] . ids
composer_obj . ti . text = ' '
2019-07-17 10:50:27 +02:00
composer_obj . btn . text = ' Select '
2019-06-28 16:54:47 +02:00
composer_obj . txt_input . text = ' '
composer_obj . subject . text = ' '
def on_stop ( self ) :
""" On stop methos is used for stoping the runing script """
print ( " **************************EXITING FROM APPLICATION***************************** " )
import shutdown
shutdown . doCleanShutdown ( )
def mail_count ( self , text ) :
if state . association == ' ' :
if BMConfigParser ( ) . addresses ( ) :
state . association = BMConfigParser ( ) . addresses ( ) [ 0 ]
if text == ' Sent ' :
state . sent_count = str ( sqlQuery ( " SELECT COUNT(*) FROM {0} WHERE fromaddress = ' {1} ' and folder = ' {0} ' ; " . format ( text . lower ( ) , state . association ) ) [ 0 ] [ 0 ] )
return state . sent_count
elif text == ' Inbox ' :
state . inbox_count = str ( sqlQuery ( " SELECT COUNT(*) FROM {0} WHERE fromaddress = ' {1} ' and folder = ' {0} ' ; " . format ( text . lower ( ) , state . association ) ) [ 0 ] [ 0 ] )
return state . inbox_count
elif text == ' Trash ' :
state . trash_count = str ( sqlQuery ( " SELECT (SELECT count(*) FROM sent where fromaddress = ' {0} ' and folder = ' trash ' )+(SELECT count(*) FROM inbox where fromaddress = ' {0} ' and folder = ' trash ' ) AS SumCount " . format ( state . association ) ) [ 0 ] [ 0 ] )
return state . trash_count
2019-07-17 10:50:27 +02:00
elif text == ' Draft ' :
state . draft_count = str ( sqlQuery ( " SELECT COUNT(*) FROM sent WHERE fromaddress = ' {1} ' and folder = ' {0} ' ; " . format ( text . lower ( ) , state . association ) ) [ 0 ] [ 0 ] )
return state . draft_count
2019-08-02 11:11:33 +02:00
def current_address_label ( self , current_address = None ) :
2019-07-17 10:50:27 +02:00
if BMConfigParser ( ) . addresses ( ) or current_address :
if current_address :
first_name = current_address
2019-08-02 11:11:33 +02:00
else :
2019-07-17 10:50:27 +02:00
first_name = BMConfigParser ( ) . get ( BMConfigParser ( ) . addresses ( ) [ 0 ] , ' label ' )
f_name = first_name . split ( )
return f_name [ 0 ] [ : 14 ] + ' ... ' if len ( f_name [ 0 ] ) > 15 else f_name [ 0 ]
return ' '
2019-06-28 16:54:47 +02:00
2019-08-05 09:41:56 +02:00
def searchQuery ( self , instance ) :
2019-08-02 11:11:33 +02:00
''' This method is used for showing searched mails '''
2019-08-05 09:41:56 +02:00
# import pdb;pdb.set_trace()
if str ( instance . text ) :
2019-08-02 11:11:33 +02:00
state . search_screen = self . root . ids . scr_mngr . current
2019-08-05 09:41:56 +02:00
state . searcing_text = str ( instance . text ) . strip ( )
2019-08-02 11:11:33 +02:00
if state . search_screen == ' inbox ' :
self . root . ids . sc1 . clear_widgets ( )
self . root . ids . sc1 . add_widget ( Inbox ( ) )
else :
self . root . ids . sc4 . clear_widgets ( )
self . root . ids . sc4 . add_widget ( Sent ( ) )
self . root . ids . scr_mngr . current = state . search_screen
2019-08-05 09:41:56 +02:00
# if self.root.ids.search_input.opacity == 0:
# self.root.ids.search_input.opacity = 1
# self.root.ids.search_input.size_hint = 4,None
# # self.root.ids.serch_btn.opacity = 0
# # self.root.ids.serch_btn.disabled = True
# self.root.ids.search_input.disabled = False
# self.root.ids.search_input.focus = True
# self.root.ids.toolbar.left_action_items = []
# self.root.ids.toolbar.title = ''
# self.root.ids.myButton.opacity = 0
# self.root.ids.myButton.disabled = True
# self.root.ids.reset_navbar.opacity = 1
# self.root.ids.reset_navbar.disabled = False
# elif str(text):
# state.search_screen = self.root.ids.scr_mngr.current
# state.searcing_text = str(text).strip()
# if state.search_screen == 'inbox':
# self.root.ids.sc1.clear_widgets()
# self.root.ids.sc1.add_widget(Inbox())
# else:
# self.root.ids.sc4.clear_widgets()
# self.root.ids.sc4.add_widget(Sent())
# self.root.ids.scr_mngr.current = state.search_screen
2019-08-02 11:11:33 +02:00
def reset_navdrawer ( self , instance ) :
''' This methos is used for reseting navigation drawer '''
self . root . ids . search_input . text = ' '
self . root . ids . search_input . opacity = 0
self . root . ids . search_input . size_hint = 1 , None
self . root . ids . search_input . disabled = True
self . root . ids . toolbar . left_action_items = [ [ ' menu ' , lambda x : self . root . toggle_nav_drawer ( ) ] ]
self . root . ids . toolbar . title = self . current_address_label ( )
self . root . ids . myButton . opacity = 1
self . root . ids . myButton . disabled = False
self . root . ids . reset_navbar . opacity = 0
self . root . ids . reset_navbar . disabled = True
state . searcing_text = ' '
if state . search_screen == ' inbox ' :
self . root . ids . sc1 . clear_widgets ( )
self . root . ids . sc1 . add_widget ( Inbox ( ) )
else :
self . root . ids . sc4 . clear_widgets ( )
self . root . ids . sc4 . add_widget ( Sent ( ) )
def check_search_screen ( self , instance ) :
''' This method is used for showing search button only on inbox or sent screen '''
if instance . text == ' Inbox ' or instance . text == ' Sent ' :
2019-08-05 09:41:56 +02:00
if not self . root . ids . search_bar . children :
self . root . ids . search_bar . add_widget ( MDIconButton ( icon = ' magnify ' ) )
# self.root.ids.search_bar.add_widget(MDTextField(id='search_field', hint_text='Search icon', on_text=app.searchQuery(self)))
2019-08-02 11:11:33 +02:00
self . root . ids . serch_btn . opacity = 1
self . root . ids . serch_btn . disabled = False
state . searcing_text = ' '
self . root . ids . sc1 . clear_widgets ( )
self . root . ids . sc4 . clear_widgets ( )
self . root . ids . sc1 . add_widget ( Inbox ( ) )
self . root . ids . sc4 . add_widget ( Sent ( ) )
else :
2019-08-05 09:41:56 +02:00
self . root . ids . search_bar . clear_widgets ( )
2019-08-02 11:11:33 +02:00
self . root . ids . serch_btn . opacity = 0
self . root . ids . serch_btn . disabled = True
return
2019-05-09 14:48:29 +02:00
class GrashofPopup ( Popup ) :
def __init__ ( self , * * kwargs ) :
super ( GrashofPopup , self ) . __init__ ( * * kwargs )
2019-06-28 16:54:47 +02:00
if state . screen_density [ 0 ] < = 720 :
self . size_hint_y = 0.4
self . size_hint_x = 0.9
else :
self . size_hint_y = 0.42
self . size_hint_x = 0.7
2019-05-09 14:48:29 +02:00
def savecontact ( self ) :
2019-07-17 10:50:27 +02:00
my_addresses = self . parent . children [ 1 ] . children [ 2 ] . children [ 0 ] . ids . btn . values
entered_text = str ( self . ids . label . text )
if entered_text in my_addresses :
self . ids . label . focus = True
self . ids . label . helper_text = ' Please Enter corrent address '
elif entered_text == ' ' :
self . ids . label . focus = True
self . ids . label . helper_text = ' This field is required '
2019-05-09 14:48:29 +02:00
label = self . ids . label . text
address = self . ids . address . text
if label and address :
state . navinstance = self . parent . children [ 1 ]
queues . UISignalQueue . put ( ( ' rerenderAddressBook ' , ' ' ) )
self . dismiss ( )
sqlExecute ( " INSERT INTO addressbook VALUES(?,?) " , label , address )
2019-08-02 11:11:33 +02:00
self . parent . children [ 1 ] . ids . serch_btn . opacity = 0
self . parent . children [ 1 ] . ids . serch_btn . disabled = True
2019-06-28 16:54:47 +02:00
self . parent . children [ 1 ] . ids . scr_mngr . current = ' addressbook '
2019-05-09 14:48:29 +02:00
def show_error_message ( self ) :
content = MDLabel ( font_style = ' Body1 ' ,
theme_text_color = ' Secondary ' ,
text = " Hey you are not allowed to save blank address contact. "
" That ' s wrong! " ,
size_hint_y = None ,
valign = ' top ' )
content . bind ( texture_size = content . setter ( ' size ' ) )
self . dialog = MDDialog ( content = content ,
size_hint = ( .8 , None ) ,
height = dp ( 200 ) ,
auto_dismiss = False )
self . dialog . add_action_button ( " ok " ,
action = lambda * x : self . dialog . dismiss ( ) )
self . dialog . open ( )
class AvatarSampleWidget ( ILeftBody , Image ) :
pass
2018-09-05 16:12:55 +02:00
2019-05-09 14:48:29 +02:00
class IconLeftSampleWidget ( ILeftBodyTouch , MDIconButton ) :
pass
2018-09-05 16:12:55 +02:00
2019-05-09 14:48:29 +02:00
class IconRightSampleWidget ( IRightBodyTouch , MDCheckbox ) :
pass
class NavigationDrawerTwoLineListItem (
TwoLineListItem , NavigationDrawerHeaderBase ) :
address_property = StringProperty ( )
def __init__ ( self , * * kwargs ) :
super ( NavigationDrawerTwoLineListItem , self ) . __init__ ( * * kwargs )
Clock . schedule_once ( lambda dt : self . setup ( ) )
def setup ( self ) :
"""
Binds Controller . current_account property .
"""
pass
def on_current_account ( self , account ) :
pass
def _update_specific_text_color ( self , instance , value ) :
pass
def _set_active ( self , active , list ) :
2019-05-28 13:12:51 +02:00
pass
2019-06-06 15:48:20 +02:00
class MailDetail ( Screen ) :
""" MailDetail Screen uses to show the detail of mails. """
2019-05-28 13:12:51 +02:00
to_addr = StringProperty ( )
from_addr = StringProperty ( )
subject = StringProperty ( )
message = StringProperty ( )
2019-06-06 15:48:20 +02:00
status = StringProperty ( )
2019-06-28 16:54:47 +02:00
page_type = StringProperty ( )
2019-05-28 13:12:51 +02:00
def __init__ ( self , * args , * * kwargs ) :
2019-06-06 15:48:20 +02:00
super ( MailDetail , self ) . __init__ ( * args , * * kwargs )
2019-05-28 13:12:51 +02:00
Clock . schedule_once ( self . init_ui , 0 )
def init_ui ( self , dt = 0 ) :
2019-06-06 15:48:20 +02:00
""" Clock Schdule for method MailDetail mails. """
2019-06-28 16:54:47 +02:00
self . page_type = state . detailPageType if state . detailPageType else ' '
2019-06-06 15:48:20 +02:00
if state . detailPageType == ' sent ' :
data = sqlQuery ( " select toaddress, fromaddress, subject, message , status, ackdata from sent where lastactiontime = {} ; " . format ( state . sentMailTime ) )
state . status = self
state . ackdata = data [ 0 ] [ 5 ]
self . assign_mail_details ( data )
elif state . detailPageType == ' inbox ' :
data = sqlQuery ( " select toaddress, fromaddress, subject, message from inbox where received = {} ; " . format ( state . sentMailTime ) )
self . assign_mail_details ( data )
def assign_mail_details ( self , data ) :
self . to_addr = data [ 0 ] [ 0 ]
self . from_addr = data [ 0 ] [ 1 ]
self . subject = data [ 0 ] [ 2 ] . upper ( )
self . message = data [ 0 ] [ 3 ]
if len ( data [ 0 ] ) == 6 :
self . status = data [ 0 ] [ 4 ]
def delete_mail ( self ) :
2019-07-17 10:50:27 +02:00
msg_count_objs = self . parent . parent . parent . parent . parent . children [ 2 ] . children [ 0 ] . ids
2019-06-06 15:48:20 +02:00
if state . detailPageType == ' sent ' :
sqlExecute ( " UPDATE sent SET folder = ' trash ' WHERE lastactiontime = {} ; " . format ( state . sentMailTime ) )
2019-07-17 10:50:27 +02:00
msg_count_objs . send_cnt . badge_text = str ( int ( state . sent_count ) - 1 )
state . sent_count = str ( int ( state . sent_count ) - 1 )
2019-06-06 15:48:20 +02:00
self . parent . parent . screens [ 3 ] . clear_widgets ( )
self . parent . parent . screens [ 3 ] . add_widget ( Sent ( ) )
self . parent . parent . current = ' sent '
2019-06-28 16:54:47 +02:00
elif state . detailPageType == ' inbox ' :
sqlExecute ( " UPDATE inbox SET folder = ' trash ' WHERE received = {} ; " . format ( state . sentMailTime ) )
2019-07-17 10:50:27 +02:00
msg_count_objs . inbox_cnt . badge_text = str ( int ( state . inbox_count ) - 1 )
state . inbox_count = str ( int ( state . inbox_count ) - 1 )
2019-06-28 16:54:47 +02:00
self . parent . parent . screens [ 0 ] . clear_widgets ( )
self . parent . parent . screens [ 0 ] . add_widget ( Inbox ( ) )
self . parent . parent . current = ' inbox '
2019-07-17 10:50:27 +02:00
msg_count_objs . trash_cnt . badge_text = str ( int ( state . trash_count ) + 1 )
state . trash_count = str ( int ( state . trash_count ) + 1 )
2019-06-06 15:48:20 +02:00
self . parent . parent . screens [ 4 ] . clear_widgets ( )
self . parent . parent . screens [ 4 ] . add_widget ( Trash ( ) )
2019-08-02 11:11:33 +02:00
self . parent . parent . parent . parent . parent . ids . serch_btn . opacity = 1
self . parent . parent . parent . parent . parent . ids . serch_btn . disabled = False
2019-06-06 15:48:20 +02:00
2019-06-28 16:54:47 +02:00
def inbox_reply ( self ) :
""" This method is used for replying inbox messages """
data = sqlQuery ( " select toaddress, fromaddress, subject, message from inbox where received = {} ; " . format ( state . sentMailTime ) )
composer_obj = self . parent . parent . screens [ 2 ] . children [ 0 ] . ids
composer_obj . ti . text = data [ 0 ] [ 1 ]
composer_obj . btn . text = data [ 0 ] [ 1 ]
composer_obj . txt_input . text = data [ 0 ] [ 0 ]
composer_obj . subject . text = data [ 0 ] [ 2 ]
self . parent . parent . current = ' create '
def copy_sent_mail ( self ) :
""" This method is used for copying sent mail to the composer """
pass
2019-06-06 15:48:20 +02:00
class MyaddDetailPopup ( Popup ) :
""" MyaddDetailPopup pop is used for showing my address detail """
address_label = StringProperty ( )
address = StringProperty ( )
def __init__ ( self , * * kwargs ) :
super ( MyaddDetailPopup , self ) . __init__ ( * * kwargs )
2019-06-28 16:54:47 +02:00
if state . screen_density [ 0 ] < = 720 :
self . size_hint_y = 0.32
self . size_hint_x = 0.9
else :
self . size_hint_y = 0.32
self . size_hint_x = 0.7
2019-06-06 15:48:20 +02:00
2019-06-28 16:54:47 +02:00
def set_address ( self , address , label ) :
2019-06-06 15:48:20 +02:00
""" Getting address for displaying details on popup """
2019-06-28 16:54:47 +02:00
self . address_label = label
self . address = address
def send_message_from ( self ) :
""" This method used to fill from address of composer autofield """
window_obj = self . parent . children [ 1 ] . ids
window_obj . sc3 . children [ 0 ] . ids . ti . text = self . address
window_obj . sc3 . children [ 0 ] . ids . btn . text = self . address
window_obj . sc3 . children [ 0 ] . ids . txt_input . text = ' '
window_obj . sc3 . children [ 0 ] . ids . subject . text = ' '
window_obj . sc3 . children [ 0 ] . ids . body . text = ' '
window_obj . scr_mngr . current = ' create '
self . dismiss ( )
class AddbookDetailPopup ( Popup ) :
""" AddbookDetailPopup pop is used for showing my address detail """
address_label = StringProperty ( )
address = StringProperty ( )
def __init__ ( self , * * kwargs ) :
super ( AddbookDetailPopup , self ) . __init__ ( * * kwargs )
if state . screen_density [ 0 ] < = 720 :
self . size_hint_y = 0.35
self . size_hint_x = 0.95
else :
self . size_hint_y = 0.35
self . size_hint_x = 0.7
def set_addbook_data ( self , address , label ) :
""" Getting address book data for detial dipaly """
self . address_label = label
self . address = address
def update_addbook_label ( self , address ) :
""" Updating the label of address book address """
if str ( self . ids . add_label . text ) :
sqlExecute ( " UPDATE addressbook SET label = ' {} ' WHERE address = ' {} ' ; " . format ( str ( self . ids . add_label . text ) , address ) )
self . parent . children [ 1 ] . ids . sc11 . clear_widgets ( )
self . parent . children [ 1 ] . ids . sc11 . add_widget ( AddressBook ( ) )
self . dismiss ( )
def send_message_to ( self ) :
""" This method used to fill to_address of composer autofield """
window_obj = self . parent . children [ 1 ] . ids
window_obj . sc3 . children [ 0 ] . ids . txt_input . text = self . address
window_obj . sc3 . children [ 0 ] . ids . ti . text = ' '
window_obj . sc3 . children [ 0 ] . ids . btn . text = ' '
window_obj . sc3 . children [ 0 ] . ids . subject . text = ' '
window_obj . sc3 . children [ 0 ] . ids . body . text = ' '
window_obj . scr_mngr . current = ' create '
self . dismiss ( )
class ShowQRCode ( Screen ) :
""" ShowQRCode Screen uses to show the detail of mails. """
def qrdisplay ( self ) :
self . ids . qr . clear_widgets ( )
2019-08-05 09:41:56 +02:00
from kivy . garden . qrcode import QRCodeWidget
self . ids . qr . add_widget ( QRCodeWidget ( data = self . manager . get_parent_window ( ) . children [ 0 ] . address ) )
2019-07-17 10:50:27 +02:00
class Draft ( Screen ) :
""" Draft screen is used to show the list of draft messages. """
data = ListProperty ( )
def __init__ ( self , * args , * * kwargs ) :
super ( Draft , self ) . __init__ ( * args , * * kwargs )
if state . association == ' ' :
if BMConfigParser ( ) . addresses ( ) :
state . association = BMConfigParser ( ) . addresses ( ) [ 0 ]
Clock . schedule_once ( self . init_ui , 0 )
def init_ui ( self , dt = 0 ) :
""" Clock Schdule for method draft accounts. """
self . sentaccounts ( )
print ( dt )
def sentaccounts ( self ) :
""" Load draft accounts. """
account = state . association
self . loadSent ( account , ' All ' , ' ' )
def loadSent ( self , account , where = " " , what = " " ) :
""" Load draft list for Draft messages. """
xAddress = ' fromaddress '
queryreturn = kivy_helper_search . search_sql (
xAddress , account , " draft " , where , what , False )
if state . msg_counter_objs :
state . msg_counter_objs . draft_cnt . badge_text = str ( len ( queryreturn ) )
if queryreturn :
for mail in queryreturn :
third_text = mail [ 3 ] . replace ( ' \n ' , ' ' )
self . data . append ( { ' text ' : mail [ 1 ] . strip ( ) , ' secondary_text ' : mail [ 2 ] [ : 10 ] + ' ........... ' if len ( mail [ 2 ] ) > 10 else mail [ 2 ] + ' \n ' + " " + ( third_text [ : 25 ] + ' ...! ' ) if len ( third_text ) > 25 else third_text , ' lastactiontime ' : mail [ 6 ] } )
for item in self . data :
meny = TwoLineAvatarIconListItem ( text = ' Draft ' , secondary_text = item [ ' text ' ] , theme_text_color = ' Custom ' , text_color = NavigateApp ( ) . theme_cls . primary_color )
meny . add_widget ( AvatarSampleWidget ( source = ' ./images/avatar.png ' ) )
carousel = Carousel ( direction = ' right ' )
if platform == ' android ' :
2019-08-02 11:11:33 +02:00
carousel . height = 150
elif platform == ' linux ' :
carousel . height = meny . height - 10
2019-07-17 10:50:27 +02:00
carousel . size_hint_y = None
carousel . ignore_perpendicular_swipes = True
carousel . data_index = 0
carousel . min_move = 0.2
del_btn = Button ( text = ' Delete ' )
del_btn . background_normal = ' '
del_btn . background_color = ( 1.0 , 0.0 , 0.0 , 1.0 )
del_btn . bind ( on_press = partial ( self . delete_draft , item [ ' lastactiontime ' ] ) )
carousel . add_widget ( del_btn )
carousel . add_widget ( meny )
carousel . index = 1
self . ids . ml . add_widget ( carousel )
else :
content = MDLabel ( font_style = ' Body1 ' ,
theme_text_color = ' Primary ' ,
text = " yet no message for this account!!!!!!!!!!!!! " ,
halign = ' center ' ,
bold = True ,
size_hint_y = None ,
valign = ' top ' )
self . ids . ml . add_widget ( content )
def delete_draft ( self , data_index , instance , * args ) :
""" This method is used to delete draft message permanently """
sqlExecute ( " DELETE FROM sent WHERE lastactiontime = ' {} ' ; " . format ( data_index ) )
try :
msg_count_objs = self . parent . parent . parent . parent . children [ 2 ] . children [ 0 ] . ids
except Exception as e :
msg_count_objs = self . parent . parent . parent . parent . parent . children [ 2 ] . children [ 0 ] . ids
if int ( state . draft_count ) > 0 :
msg_count_objs . draft_cnt . badge_text = str ( int ( state . draft_count ) - 1 )
state . draft_count = str ( int ( state . draft_count ) - 1 )
self . ids . ml . remove_widget ( instance . parent . parent )
def draft_msg ( self , src_object ) :
""" This method is used for saving draft mails """
composer_object = src_object . children [ 1 ] . children [ 0 ] . children [ 0 ] . children [ 0 ] . children [ 0 ] . ids
fromAddress = str ( composer_object . ti . text )
toAddress = str ( composer_object . txt_input . text )
subject = str ( composer_object . subject . text )
message = str ( composer_object . body . text )
encoding = 3
sendMessageToPeople = True
if sendMessageToPeople :
from addresses import decodeAddress
status , addressVersionNumber , streamNumber , ripe = decodeAddress (
toAddress )
from addresses import *
toAddress = addBMIfNotPresent ( toAddress )
statusIconColor = ' red '
stealthLevel = BMConfigParser ( ) . safeGetInt (
' bitmessagesettings ' , ' ackstealthlevel ' )
from helper_ackPayload import genAckPayload
ackdata = genAckPayload ( streamNumber , stealthLevel )
t = ( )
sqlExecute (
''' INSERT INTO sent VALUES (?,?,?,?,?,?,?,?,?,?,?,?,?,?,?) ''' ,
' ' ,
toAddress ,
ripe ,
fromAddress ,
subject ,
message ,
ackdata ,
int ( time . time ( ) ) ,
int ( time . time ( ) ) ,
0 ,
' msgqueued ' ,
0 ,
' draft ' ,
encoding ,
BMConfigParser ( ) . getint ( ' bitmessagesettings ' , ' ttl ' ) )
state . msg_counter_objs = src_object . children [ 2 ] . children [ 0 ] . ids
state . draft_count = str ( int ( state . draft_count ) + 1 )
src_object . ids . sc16 . clear_widgets ( )
src_object . ids . sc16 . add_widget ( Draft ( ) )
2019-08-02 11:11:33 +02:00
return
def show_search_btn ( self ) :
''' This method is used to show search button '''
self . root . ids . serch_btn . opacity = 1
self . root . ids . serch_btn . disabled = False
def hide_search_btn ( mgr_objs ) :
''' This method is used to hide search button and search box '''
mgr_objs . parent . parent . parent . ids . serch_btn . opacity = 0
mgr_objs . parent . parent . parent . ids . serch_btn . disabled = True
mgr_objs . parent . parent . parent . ids . search_input . size_hint = 1 , None
mgr_objs . parent . parent . parent . ids . search_input . disabled = True
mgr_objs . parent . parent . parent . ids . search_input . opacity = 0
mgr_objs . parent . parent . parent . ids . toolbar . left_action_items = [ [ ' menu ' , lambda x : mgr_objs . parent . parent . parent . toggle_nav_drawer ( ) ] ]
mgr_objs . parent . parent . parent . ids . toolbar . title = NavigateApp ( ) . current_address_label ( )
mgr_objs . parent . parent . parent . ids . myButton . opacity = 1
mgr_objs . parent . parent . parent . ids . myButton . disabled = False
mgr_objs . parent . parent . parent . ids . reset_navbar . opacity = 0
mgr_objs . parent . parent . parent . ids . reset_navbar . disabled = True
class CustomSpinner ( Spinner ) :
''' This class is used for setting spinner size '''
def __init__ ( self , * args , * * kwargs ) :
''' This methods is used for setting size of spinner '''
super ( CustomSpinner , self ) . __init__ ( * args , * * kwargs )
max = 2.8
self . dropdown_cls . max_height = self . height * max + max * 4