commit
e4c1a57c22
|
@ -10,36 +10,14 @@ from pythonforandroid.recipe import PythonRecipe
|
||||||
class KivyMDRecipe(PythonRecipe):
|
class KivyMDRecipe(PythonRecipe):
|
||||||
# This recipe installs KivyMD into the android dist from source
|
# This recipe installs KivyMD into the android dist from source
|
||||||
version = 'master'
|
version = 'master'
|
||||||
# url = 'https://gitlab.com/kivymd/KivyMD/repository/{version}/archive.zip'
|
url = 'https://github.com/surbhicis/kivymd/archive/master.zip'
|
||||||
url = 'https://github.com/HeaTTheatR/KivyMD/archive/master.zip'
|
|
||||||
depends = ['kivy']
|
depends = ['kivy']
|
||||||
site_packages_name = 'kivymd'
|
site_packages_name = 'kivymd'
|
||||||
call_hostpython_via_targetpython = False
|
call_hostpython_via_targetpython = False
|
||||||
# patches = ['kivymd-fix-dev-compatibility.patch']
|
|
||||||
# Made commented as use different repo for updates
|
|
||||||
|
|
||||||
def should_build(self, arch):
|
def should_build(self, arch):
|
||||||
return True
|
return True
|
||||||
|
|
||||||
# def unpack(self, arch):
|
|
||||||
# info_main('Unpacking {} for {}'.format(self.name, arch))
|
|
||||||
#
|
|
||||||
# build_dir = self.get_build_container_dir(arch)
|
|
||||||
#
|
|
||||||
# user_dir = environ.get('P4A_{}_DIR'.format(self.name.lower()))
|
|
||||||
#
|
|
||||||
# if user_dir is not None:
|
|
||||||
# info("Installing KivyMD development version (from modded source)")
|
|
||||||
# self.clean_build()
|
|
||||||
# shprint(sh.rm, '-rf', build_dir)
|
|
||||||
# shprint(sh.mkdir, '-p', build_dir)
|
|
||||||
# shprint(sh.rmdir, build_dir)
|
|
||||||
# ensure_dir(build_dir)
|
|
||||||
# ensure_dir(build_dir + "/kivymd")
|
|
||||||
# shprint(sh.cp, user_dir + '/setup.py', self.get_build_dir(arch) + "/setup.py")
|
|
||||||
# shprint(sh.cp, '-a', user_dir + "/kivymd", self.get_build_dir(arch) + "/kivymd")
|
|
||||||
# return
|
|
||||||
|
|
||||||
def get_recipe_env(self, arch):
|
def get_recipe_env(self, arch):
|
||||||
env = super(KivyMDRecipe, self).get_recipe_env(arch)
|
env = super(KivyMDRecipe, self).get_recipe_env(arch)
|
||||||
env['PYTHON_ROOT'] = self.ctx.get_python_install_dir()
|
env['PYTHON_ROOT'] = self.ctx.get_python_install_dir()
|
||||||
|
|
|
@ -174,44 +174,6 @@ NavigationLayout:
|
||||||
background_palette: 'Primary'
|
background_palette: 'Primary'
|
||||||
background_hue: '500'
|
background_hue: '500'
|
||||||
left_action_items: [['menu', lambda x: app.root.toggle_nav_drawer()]]
|
left_action_items: [['menu', lambda x: app.root.toggle_nav_drawer()]]
|
||||||
Button:
|
|
||||||
id: reset_navbar
|
|
||||||
size_hint_y: 0.35
|
|
||||||
size_hint_x: 0.2
|
|
||||||
opacity: 0
|
|
||||||
disabled: True
|
|
||||||
pos_hint: {'x': .1, 'y': 0.3}
|
|
||||||
color: 0,0,0,1
|
|
||||||
background_color: (0,0,0,0)
|
|
||||||
on_press:app.reset_navdrawer(self)
|
|
||||||
Image:
|
|
||||||
source: './images/left_arrow.png'
|
|
||||||
center_x: self.parent.center_x
|
|
||||||
center_y: self.parent.center_y
|
|
||||||
size: 40, 40
|
|
||||||
TextInput:
|
|
||||||
id: search_input
|
|
||||||
hint_text: 'search'
|
|
||||||
opacity: 0
|
|
||||||
size_hint: 1,None
|
|
||||||
height: dp(32)
|
|
||||||
disabled: True
|
|
||||||
pos_hint: {'center_x':.565,'center_y': .5}
|
|
||||||
multiline: False
|
|
||||||
padding_y: [self.height / 2.0 - (self.line_height / 2.0) * len(self._lines), 0]
|
|
||||||
padding_x: 20,20
|
|
||||||
Button:
|
|
||||||
id: serch_btn
|
|
||||||
size_hint_y: 0.35
|
|
||||||
size_hint_x: 0.2
|
|
||||||
pos_hint: {'x': .1, 'y': 0.3}
|
|
||||||
color: 0,0,0,1
|
|
||||||
background_color: (0,0,0,0)
|
|
||||||
Image:
|
|
||||||
source: './images/search_mail.png'
|
|
||||||
center_x: self.parent.center_x
|
|
||||||
center_y: self.parent.center_y
|
|
||||||
size: 55, 55
|
|
||||||
Button:
|
Button:
|
||||||
id: myButton
|
id: myButton
|
||||||
size_hint_y: 0.35
|
size_hint_y: 0.35
|
||||||
|
@ -282,7 +244,7 @@ NavigationLayout:
|
||||||
root_layout: root
|
root_layout: root
|
||||||
MDList:
|
MDList:
|
||||||
id: ml
|
id: ml
|
||||||
ComposerButton
|
ComposerButton:
|
||||||
|
|
||||||
<Sent>:
|
<Sent>:
|
||||||
name: 'sent'
|
name: 'sent'
|
||||||
|
|
|
@ -45,6 +45,7 @@ from functools import partial
|
||||||
from kivy.uix.carousel import Carousel
|
from kivy.uix.carousel import Carousel
|
||||||
from kivy.utils import platform
|
from kivy.utils import platform
|
||||||
from kivy.uix.spinner import Spinner
|
from kivy.uix.spinner import Spinner
|
||||||
|
from kivymd.textfields import MDTextField
|
||||||
|
|
||||||
|
|
||||||
class Navigatorss(MDNavigationDrawer):
|
class Navigatorss(MDNavigationDrawer):
|
||||||
|
@ -147,6 +148,7 @@ class Inbox(Screen):
|
||||||
|
|
||||||
def inbox_detail(self, receivedTime, *args):
|
def inbox_detail(self, receivedTime, *args):
|
||||||
"""Load inbox page details."""
|
"""Load inbox page details."""
|
||||||
|
remove_search_bar(self)
|
||||||
state.detailPageType = 'inbox'
|
state.detailPageType = 'inbox'
|
||||||
state.sentMailTime = receivedTime
|
state.sentMailTime = receivedTime
|
||||||
if self.manager:
|
if self.manager:
|
||||||
|
@ -154,7 +156,6 @@ class Inbox(Screen):
|
||||||
else:
|
else:
|
||||||
src_mng_obj = self.parent.parent
|
src_mng_obj = self.parent.parent
|
||||||
|
|
||||||
hide_search_btn(src_mng_obj)
|
|
||||||
src_mng_obj.screens[13].clear_widgets()
|
src_mng_obj.screens[13].clear_widgets()
|
||||||
src_mng_obj.screens[13].add_widget(MailDetail())
|
src_mng_obj.screens[13].add_widget(MailDetail())
|
||||||
src_mng_obj.current = 'mailDetail'
|
src_mng_obj.current = 'mailDetail'
|
||||||
|
@ -463,10 +464,6 @@ class DropDownWidget(BoxLayout):
|
||||||
self.parent.parent.current = 'sent'
|
self.parent.parent.current = 'sent'
|
||||||
self.ids.btn.text = 'select'
|
self.ids.btn.text = 'select'
|
||||||
self.ids.ti.text = ''
|
self.ids.ti.text = ''
|
||||||
self.parent.parent.parent.parent.parent\
|
|
||||||
.ids.serch_btn.opacity = 1
|
|
||||||
self.parent.parent.parent.parent.parent\
|
|
||||||
.ids.serch_btn.disabled = False
|
|
||||||
|
|
||||||
return None
|
return None
|
||||||
else:
|
else:
|
||||||
|
@ -727,13 +724,13 @@ class Sent(Screen):
|
||||||
|
|
||||||
def sent_detail(self, lastsenttime, *args):
|
def sent_detail(self, lastsenttime, *args):
|
||||||
"""Load sent mail details."""
|
"""Load sent mail details."""
|
||||||
|
remove_search_bar(self)
|
||||||
state.detailPageType = 'sent'
|
state.detailPageType = 'sent'
|
||||||
state.sentMailTime = lastsenttime
|
state.sentMailTime = lastsenttime
|
||||||
if self.manager:
|
if self.manager:
|
||||||
src_mng_obj = self.manager
|
src_mng_obj = self.manager
|
||||||
else:
|
else:
|
||||||
src_mng_obj = self.parent.parent
|
src_mng_obj = self.parent.parent
|
||||||
hide_search_btn(src_mng_obj)
|
|
||||||
src_mng_obj.screens[13].clear_widgets()
|
src_mng_obj.screens[13].clear_widgets()
|
||||||
src_mng_obj.screens[13].add_widget(MailDetail())
|
src_mng_obj.screens[13].add_widget(MailDetail())
|
||||||
src_mng_obj.current = 'mailDetail'
|
src_mng_obj.current = 'mailDetail'
|
||||||
|
@ -993,7 +990,7 @@ class NavigateApp(App):
|
||||||
if self.root.ids.scr_mngr.current == "mailDetail":
|
if self.root.ids.scr_mngr.current == "mailDetail":
|
||||||
self.root.ids.scr_mngr.current = \
|
self.root.ids.scr_mngr.current = \
|
||||||
'sent' if state.detailPageType == 'sent' else 'inbox'
|
'sent' if state.detailPageType == 'sent' else 'inbox'
|
||||||
show_search_btn(self)
|
self.add_search_bar()
|
||||||
elif self.root.ids.scr_mngr.current == "create":
|
elif self.root.ids.scr_mngr.current == "create":
|
||||||
composer_objs = self.root
|
composer_objs = self.root
|
||||||
from_addr = str(self.root.children[1].children[0].children[
|
from_addr = str(self.root.children[1].children[0].children[
|
||||||
|
@ -1002,16 +999,15 @@ class NavigateApp(App):
|
||||||
0].children[0].children[0].ids.txt_input.text)
|
0].children[0].children[0].ids.txt_input.text)
|
||||||
if from_addr and to_addr:
|
if from_addr and to_addr:
|
||||||
Draft().draft_msg(composer_objs)
|
Draft().draft_msg(composer_objs)
|
||||||
self.root.ids.serch_btn.opacity = 1
|
|
||||||
self.root.ids.serch_btn.disabled = False
|
|
||||||
self.root.ids.scr_mngr.current = 'inbox'
|
self.root.ids.scr_mngr.current = 'inbox'
|
||||||
|
self.add_search_bar()
|
||||||
elif self.root.ids.scr_mngr.current == "showqrcode":
|
elif self.root.ids.scr_mngr.current == "showqrcode":
|
||||||
self.root.ids.scr_mngr.current = 'myaddress'
|
self.root.ids.scr_mngr.current = 'myaddress'
|
||||||
elif self.root.ids.scr_mngr.current == "random":
|
elif self.root.ids.scr_mngr.current == "random":
|
||||||
self.root.ids.scr_mngr.current = 'login'
|
self.root.ids.scr_mngr.current = 'login'
|
||||||
else:
|
else:
|
||||||
self.root.ids.scr_mngr.current = 'inbox'
|
self.root.ids.scr_mngr.current = 'inbox'
|
||||||
show_search_btn(self)
|
self.add_search_bar()
|
||||||
self.root.ids.scr_mngr.transition.direction = 'right'
|
self.root.ids.scr_mngr.transition.direction = 'right'
|
||||||
self.root.ids.scr_mngr.transition.bind(on_complete=self.restart)
|
self.root.ids.scr_mngr.transition.bind(on_complete=self.restart)
|
||||||
return True
|
return True
|
||||||
|
@ -1029,8 +1025,7 @@ class NavigateApp(App):
|
||||||
|
|
||||||
def clear_composer(self):
|
def clear_composer(self):
|
||||||
"""If slow down the nwe will make new composer edit screen."""
|
"""If slow down the nwe will make new composer edit screen."""
|
||||||
self.root.ids.serch_btn.opacity = 0
|
self.root.ids.search_bar.clear_widgets()
|
||||||
self.root.ids.serch_btn.disabled = True
|
|
||||||
composer_obj = self.root.ids.sc3.children[0].ids
|
composer_obj = self.root.ids.sc3.children[0].ids
|
||||||
composer_obj.ti.text = ''
|
composer_obj.ti.text = ''
|
||||||
composer_obj.btn.text = 'Select'
|
composer_obj.btn.text = 'Select'
|
||||||
|
@ -1085,8 +1080,8 @@ class NavigateApp(App):
|
||||||
return f_name[0][:14] + '...' if len(f_name[0]) > 15 else f_name[0]
|
return f_name[0][:14] + '...' if len(f_name[0]) > 15 else f_name[0]
|
||||||
return ''
|
return ''
|
||||||
|
|
||||||
def searchQuery(self, instance):
|
def searchQuery(self, instance, *args):
|
||||||
"""Method used for showing searched mails."""
|
'''This method is used for showing searched mails'''
|
||||||
state.search_screen = self.root.ids.scr_mngr.current
|
state.search_screen = self.root.ids.scr_mngr.current
|
||||||
state.searcing_text = str(instance.text).strip()
|
state.searcing_text = str(instance.text).strip()
|
||||||
if state.search_screen == 'inbox':
|
if state.search_screen == 'inbox':
|
||||||
|
@ -1097,35 +1092,14 @@ class NavigateApp(App):
|
||||||
self.root.ids.sc4.add_widget(Sent())
|
self.root.ids.sc4.add_widget(Sent())
|
||||||
self.root.ids.scr_mngr.current = state.search_screen
|
self.root.ids.scr_mngr.current = state.search_screen
|
||||||
|
|
||||||
def reset_navdrawer(self, instance):
|
|
||||||
"""Method 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):
|
def check_search_screen(self, instance):
|
||||||
"""Method shows search button on inbox and sent screen only."""
|
"""Method used for showing search button only on inbox or sent screen."""
|
||||||
if instance.text == 'Inbox' or instance.text == 'Sent':
|
if instance.text == 'Inbox' or instance.text == 'Sent':
|
||||||
if not self.root.ids.search_bar.children:
|
if not self.root.ids.search_bar.children:
|
||||||
self.root.ids.search_bar.add_widget(
|
self.root.ids.search_bar.add_widget(MDIconButton(icon = 'magnify'))
|
||||||
MDIconButton(icon='magnify'))
|
text_field = MDTextField(id='search_field', hint_text='Search icon')
|
||||||
self.root.ids.serch_btn.opacity = 1
|
text_field.bind(text = self.searchQuery)
|
||||||
self.root.ids.serch_btn.disabled = False
|
self.root.ids.search_bar.add_widget(text_field)
|
||||||
state.searcing_text = ''
|
state.searcing_text = ''
|
||||||
self.root.ids.sc1.clear_widgets()
|
self.root.ids.sc1.clear_widgets()
|
||||||
self.root.ids.sc4.clear_widgets()
|
self.root.ids.sc4.clear_widgets()
|
||||||
|
@ -1133,10 +1107,15 @@ class NavigateApp(App):
|
||||||
self.root.ids.sc4.add_widget(Sent())
|
self.root.ids.sc4.add_widget(Sent())
|
||||||
else:
|
else:
|
||||||
self.root.ids.search_bar.clear_widgets()
|
self.root.ids.search_bar.clear_widgets()
|
||||||
self.root.ids.serch_btn.opacity = 0
|
|
||||||
self.root.ids.serch_btn.disabled = True
|
|
||||||
return
|
return
|
||||||
|
|
||||||
|
def add_search_bar(self):
|
||||||
|
"""This method is used for adding search function on screen"""
|
||||||
|
if not self.root.ids.search_bar.children:
|
||||||
|
self.root.ids.search_bar.add_widget(MDIconButton(icon = 'magnify'))
|
||||||
|
text_field = MDTextField(id='search_field', hint_text='Search icon')
|
||||||
|
text_field.bind(text = self.searchQuery)
|
||||||
|
self.root.ids.search_bar.add_widget(text_field)
|
||||||
|
|
||||||
class GrashofPopup(Popup):
|
class GrashofPopup(Popup):
|
||||||
"""Methods for saving contacts, error messages."""
|
"""Methods for saving contacts, error messages."""
|
||||||
|
@ -1170,8 +1149,6 @@ class GrashofPopup(Popup):
|
||||||
queues.UISignalQueue.put(('rerenderAddressBook', ''))
|
queues.UISignalQueue.put(('rerenderAddressBook', ''))
|
||||||
self.dismiss()
|
self.dismiss()
|
||||||
sqlExecute("INSERT INTO addressbook VALUES(?,?)", label, address)
|
sqlExecute("INSERT INTO addressbook VALUES(?,?)", label, address)
|
||||||
self.parent.children[1].ids.serch_btn.opacity = 0
|
|
||||||
self.parent.children[1].ids.serch_btn.disabled = True
|
|
||||||
self.parent.children[1].ids.scr_mngr.current = 'addressbook'
|
self.parent.children[1].ids.scr_mngr.current = 'addressbook'
|
||||||
|
|
||||||
def show_error_message(self):
|
def show_error_message(self):
|
||||||
|
@ -1306,8 +1283,6 @@ class MailDetail(Screen):
|
||||||
state.trash_count = str(int(state.trash_count) + 1)
|
state.trash_count = str(int(state.trash_count) + 1)
|
||||||
self.parent.parent.screens[4].clear_widgets()
|
self.parent.parent.screens[4].clear_widgets()
|
||||||
self.parent.parent.screens[4].add_widget(Trash())
|
self.parent.parent.screens[4].add_widget(Trash())
|
||||||
self.parent.parent.parent.parent.parent.ids.serch_btn.opacity = 1
|
|
||||||
self.parent.parent.parent.parent.parent.ids.serch_btn.disabled = False
|
|
||||||
|
|
||||||
def inbox_reply(self):
|
def inbox_reply(self):
|
||||||
"""Method used for replying inbox messages."""
|
"""Method used for replying inbox messages."""
|
||||||
|
@ -1554,29 +1529,6 @@ class Draft(Screen):
|
||||||
return
|
return
|
||||||
|
|
||||||
|
|
||||||
def show_search_btn(self):
|
|
||||||
"""Method 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):
|
|
||||||
"""Method 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):
|
class CustomSpinner(Spinner):
|
||||||
"""This class is used for setting spinner size."""
|
"""This class is used for setting spinner size."""
|
||||||
|
|
||||||
|
@ -1585,3 +1537,7 @@ class CustomSpinner(Spinner):
|
||||||
super(CustomSpinner, self).__init__(*args, **kwargs)
|
super(CustomSpinner, self).__init__(*args, **kwargs)
|
||||||
max = 2.8
|
max = 2.8
|
||||||
self.dropdown_cls.max_height = self.height * max + max * 4
|
self.dropdown_cls.max_height = self.height * max + max * 4
|
||||||
|
|
||||||
|
|
||||||
|
def remove_search_bar(self):
|
||||||
|
self.parent.parent.parent.parent.parent.ids.search_bar.clear_widgets()
|
||||||
|
|
|
@ -247,7 +247,10 @@ class Main:
|
||||||
' \'-c\' as a commandline argument.'
|
' \'-c\' as a commandline argument.'
|
||||||
)
|
)
|
||||||
# is the application already running? If yes then exit.
|
# is the application already running? If yes then exit.
|
||||||
|
try:
|
||||||
shared.thisapp = singleinstance("", daemon)
|
shared.thisapp = singleinstance("", daemon)
|
||||||
|
except Exception as e:
|
||||||
|
pass
|
||||||
|
|
||||||
if daemon:
|
if daemon:
|
||||||
with shared.printLock:
|
with shared.printLock:
|
||||||
|
|
|
@ -1,10 +1,10 @@
|
||||||
[app]
|
[app]
|
||||||
|
|
||||||
# (str) Title of your application
|
# (str) Title of your application
|
||||||
title = bluewhale
|
title = messageapp
|
||||||
|
|
||||||
# (str) Package name
|
# (str) Package name
|
||||||
package.name = bluewhale
|
package.name = messageapp
|
||||||
|
|
||||||
# (str) Package domain (needed for android/ios packaging)
|
# (str) Package domain (needed for android/ios packaging)
|
||||||
package.domain = org.test
|
package.domain = org.test
|
||||||
|
@ -35,21 +35,29 @@ version = 0.1
|
||||||
# version.filename = %(source.dir)s/main.py
|
# version.filename = %(source.dir)s/main.py
|
||||||
|
|
||||||
# (list) Application requirements
|
# (list) Application requirements
|
||||||
# comma seperated e.g. requirements = sqlite3,kivy
|
# comma separated e.g. requirements = sqlite3,kivy
|
||||||
requirements = python2, sqlite3, kivy, openssl, bitmsghash, libexpat, kivymd
|
requirements =
|
||||||
|
openssl,
|
||||||
|
sqlite3,
|
||||||
|
python2,
|
||||||
|
kivy,
|
||||||
|
bitmsghash,
|
||||||
|
kivymd,
|
||||||
|
kivy-garden,
|
||||||
|
qrcode
|
||||||
|
|
||||||
# (str) Custom source folders for requirements
|
# (str) Custom source folders for requirements
|
||||||
# Sets custom source for any requirements with recipes
|
# Sets custom source for any requirements with recipes
|
||||||
# requirements.source.kivy = ../../kivy
|
# requirements.source.kivy = ../../kivy
|
||||||
|
|
||||||
# (list) Garden requirements
|
# (list) Garden requirements
|
||||||
#garden_requirements =
|
garden_requirements = qrcode
|
||||||
|
|
||||||
# (str) Presplash of the application
|
# (str) Presplash of the application
|
||||||
presplash.filename = "images/presplas.gif"
|
#presplash.filename = %(source.dir)s/data/presplash.png
|
||||||
|
|
||||||
# (str) Icon of the application
|
# (str) Icon of the application
|
||||||
icon.filename ='images/if_android_1220385.png'
|
#icon.filename = %(source.dir)s/data/icon.png
|
||||||
|
|
||||||
# (str) Supported orientation (one of landscape, portrait or all)
|
# (str) Supported orientation (one of landscape, portrait or all)
|
||||||
orientation = portrait
|
orientation = portrait
|
||||||
|
@ -88,28 +96,28 @@ fullscreen = 0
|
||||||
android.permissions = INTERNET, WRITE_EXTERNAL_STORAGE, READ_EXTERNAL_STORAGE
|
android.permissions = INTERNET, WRITE_EXTERNAL_STORAGE, READ_EXTERNAL_STORAGE
|
||||||
|
|
||||||
# (int) Android API to use
|
# (int) Android API to use
|
||||||
android.api = 19
|
android.api = 27
|
||||||
|
|
||||||
# (int) Minimum API required
|
# (int) Minimum API required
|
||||||
#android.minapi = 9
|
android.minapi = 21
|
||||||
|
|
||||||
# (int) Android SDK version to use
|
# (int) Android SDK version to use
|
||||||
android.sdk = 20
|
android.sdk = 20
|
||||||
|
|
||||||
# (str) Android NDK version to use
|
# (str) Android NDK version to use
|
||||||
android.ndk = 10e
|
android.ndk = 17c
|
||||||
|
|
||||||
# (bool) Use --private data storage (True) or --dir public storage (False)
|
# (bool) Use --private data storage (True) or --dir public storage (False)
|
||||||
# android.private_storage = True
|
# android.private_storage = True
|
||||||
|
|
||||||
# (str) Android NDK directory (if empty, it will be automatically downloaded.)
|
# (str) Android NDK directory (if empty, it will be automatically downloaded.)
|
||||||
android.ndk_path =/home/cis/Downloads/android-ndk-r10e
|
#android.ndk_path =
|
||||||
|
|
||||||
# (str) Android SDK directory (if empty, it will be automatically downloaded.)
|
# (str) Android SDK directory (if empty, it will be automatically downloaded.)
|
||||||
android.sdk_path =/home/cis/Android/Sdk
|
#android.sdk_path =
|
||||||
|
|
||||||
# (str) ANT directory (if empty, it will be automatically downloaded.)
|
# (str) ANT directory (if empty, it will be automatically downloaded.)
|
||||||
android.ant_path =/home/cis/apache-ant-1.10.5
|
#android.ant_path =
|
||||||
|
|
||||||
# (bool) If True, then skip trying to update the Android sdk
|
# (bool) If True, then skip trying to update the Android sdk
|
||||||
# This can be useful to avoid excess Internet downloads or save time
|
# This can be useful to avoid excess Internet downloads or save time
|
||||||
|
@ -146,7 +154,10 @@ android.ant_path =/home/cis/apache-ant-1.10.5
|
||||||
# bootstrap)
|
# bootstrap)
|
||||||
#android.gradle_dependencies =
|
#android.gradle_dependencies =
|
||||||
|
|
||||||
# (str) python-for-android branch to use, defaults to master
|
# (list) Java classes to add as activities to the manifest.
|
||||||
|
#android.add_activites = com.example.ExampleActivity
|
||||||
|
|
||||||
|
# (str) python-for-android branch to use, defaults to stable
|
||||||
p4a.branch = master
|
p4a.branch = master
|
||||||
|
|
||||||
# (str) OUYA Console category. Should be one of GAME or APP
|
# (str) OUYA Console category. Should be one of GAME or APP
|
||||||
|
@ -159,7 +170,10 @@ p4a.branch = master
|
||||||
# (str) XML file to include as an intent filters in <activity> tag
|
# (str) XML file to include as an intent filters in <activity> tag
|
||||||
#android.manifest.intent_filters =
|
#android.manifest.intent_filters =
|
||||||
|
|
||||||
# (list) Android additionnal libraries to copy into libs/armeabi
|
# (str) launchMode to set for the main activity
|
||||||
|
#android.manifest.launch_mode = standard
|
||||||
|
|
||||||
|
# (list) Android additional libraries to copy into libs/armeabi
|
||||||
#android.add_libs_armeabi = libs/android/*.so
|
#android.add_libs_armeabi = libs/android/*.so
|
||||||
#android.add_libs_armeabi_v7a = libs/android-v7/*.so
|
#android.add_libs_armeabi_v7a = libs/android-v7/*.so
|
||||||
#android.add_libs_x86 = libs/android-x86/*.so
|
#android.add_libs_x86 = libs/android-x86/*.so
|
||||||
|
@ -193,7 +207,7 @@ android.arch = armeabi-v7a
|
||||||
#p4a.source_dir =
|
#p4a.source_dir =
|
||||||
|
|
||||||
# (str) The directory in which python-for-android should look for your own build recipes (if any)
|
# (str) The directory in which python-for-android should look for your own build recipes (if any)
|
||||||
p4a.local_recipes =/home/cis/Desktop/Mobileandroid/peter_android/PyBitmessage/src/bitmessagekivy/android/python-for-android/recipes/
|
p4a.local_recipes = /home/cis/navjotrepo/PyBitmessage/src/bitmessagekivy/android/python-for-android/recipes/
|
||||||
|
|
||||||
# (str) Filename to the hook for p4a
|
# (str) Filename to the hook for p4a
|
||||||
#p4a.hook =
|
#p4a.hook =
|
||||||
|
@ -201,6 +215,9 @@ p4a.local_recipes =/home/cis/Desktop/Mobileandroid/peter_android/PyBitmessage/sr
|
||||||
# (str) Bootstrap to use for android builds
|
# (str) Bootstrap to use for android builds
|
||||||
# p4a.bootstrap = sdl2
|
# p4a.bootstrap = sdl2
|
||||||
|
|
||||||
|
# (int) port number to specify an explicit --port= p4a argument (eg for bootstrap flask)
|
||||||
|
#p4a.port =
|
||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
# iOS specific
|
# iOS specific
|
||||||
|
|
|
@ -43,7 +43,8 @@ def lookupAppdataFolder():
|
||||||
sys.exit()
|
sys.exit()
|
||||||
elif platform == 'android':
|
elif platform == 'android':
|
||||||
# dataFolder = path.join(os.path.dirname(os.path.abspath("__file__")), "PyBitmessage") + '/'
|
# dataFolder = path.join(os.path.dirname(os.path.abspath("__file__")), "PyBitmessage") + '/'
|
||||||
dataFolder = path.join('/sdcard/', 'DCIM/', APPNAME) + '/'
|
dataFolder = path.join(os.environ['ANDROID_PRIVATE'] + '/', APPNAME) + '/'
|
||||||
|
# dataFolder = path.join('/sdcard/', 'DCIM/', APPNAME) + '/'
|
||||||
|
|
||||||
elif 'win32' in sys.platform or 'win64' in sys.platform:
|
elif 'win32' in sys.platform or 'win64' in sys.platform:
|
||||||
dataFolder = path.join(environ['APPDATA'].decode(sys.getfilesystemencoding(), 'ignore'), APPNAME) + path.sep
|
dataFolder = path.join(environ['APPDATA'].decode(sys.getfilesystemencoding(), 'ignore'), APPNAME) + path.sep
|
||||||
|
|
|
@ -534,6 +534,8 @@ def loadOpenSSL():
|
||||||
elif platform == "android":
|
elif platform == "android":
|
||||||
libdir.append('libcrypto1.0.2p.so')
|
libdir.append('libcrypto1.0.2p.so')
|
||||||
libdir.append('libssl1.0.2p.so')
|
libdir.append('libssl1.0.2p.so')
|
||||||
|
libdir.append('libcrypto1.1.so')
|
||||||
|
libdir.append('libssl1.1.so')
|
||||||
|
|
||||||
else:
|
else:
|
||||||
libdir.append('libcrypto.so')
|
libdir.append('libcrypto.so')
|
||||||
|
@ -541,7 +543,10 @@ def loadOpenSSL():
|
||||||
libdir.append('libcrypto.so.1.0.0')
|
libdir.append('libcrypto.so.1.0.0')
|
||||||
libdir.append('libssl.so.1.0.0')
|
libdir.append('libssl.so.1.0.0')
|
||||||
if 'linux' in sys.platform or 'darwin' in sys.platform or 'bsd' in sys.platform:
|
if 'linux' in sys.platform or 'darwin' in sys.platform or 'bsd' in sys.platform:
|
||||||
|
try:
|
||||||
libdir.append(find_library('ssl'))
|
libdir.append(find_library('ssl'))
|
||||||
|
except OSError:
|
||||||
|
pass
|
||||||
elif 'win32' in sys.platform or 'win64' in sys.platform:
|
elif 'win32' in sys.platform or 'win64' in sys.platform:
|
||||||
libdir.append(find_library('libeay32'))
|
libdir.append(find_library('libeay32'))
|
||||||
for library in libdir:
|
for library in libdir:
|
||||||
|
|
Reference in New Issue
Block a user