diff --git a/.travis.yml b/.travis.yml index 6b0e4916..5dbda892 100644 --- a/.travis.yml +++ b/.travis.yml @@ -8,4 +8,6 @@ addons: - libcap-dev install: - python setup.py install -script: pybitmessage -t +script: + - python checkdeps.py + - pybitmessage -t diff --git a/README.md b/README.md index 5dfe24df..c3dcb540 100644 --- a/README.md +++ b/README.md @@ -19,7 +19,7 @@ pseudo-mailing list: BM-2D9QKN4teYRvoq2fyzpiftPh9WP9qggtzh Feel welcome to join chan "bitmessage", BM-2cWy7cvHoq3f1rYMerRJp8PT653jjSuEdY -which is on preview here: http://beamstat.com/chan/bitmessage +which is on preview here: https://beamstat.com/chan/bitmessage References ---------- diff --git a/android_instruction.rst b/android_instruction.rst new file mode 100644 index 00000000..fab55b55 --- /dev/null +++ b/android_instruction.rst @@ -0,0 +1,43 @@ +PyBitmessage(Android) + +This sample aims to be as close to a real world example of a mobile. It has a more refined design and also provides a practical example of how a mobile app would interact and communicate with its adresses. + +Steps for trying out this sample: + +Compile and install the mobile app onto your mobile device or emulator. + + +Getting Started + +This sample uses the kivy as Kivy is an open source, cross-platform Python framework for the development of applications that make use of innovative, multi-touch user interfaces. The aim is to allow for quick and easy interaction design and rapid prototyping whilst making your code reusable and deployable. + +Kivy is written in Python and Cython, supports various input devices and has an extensive widget library. With the same codebase, you can target Windows, OS X, Linux, Android and iOS. All Kivy widgets are built with multitouch support. + +Kivy in support take Buildozer which is a tool that automates the entire build process. It downloads and sets up all the prequisites for python-for-android, including the android SDK and NDK, then builds an apk that can be automatically pushed to the device. + +Buildozer currently works only in Linux, and is an alpha release, but it already works well and can significantly simplify the apk build. + +To build this project, use the "Buildozer android release deploy run" command or use. +Buildozer ue=sed for creating application packages easily.The goal is to have one "buildozer.spec" file in your app directory, describing your application requirements and settings such as title, icon, included modules etc. Buildozer will use that spec to create a package for Android, iOS, Windows, OSX and/or Linux. + +Installing Requirements + +You can create a package for android using the python-for-android project as with using the Buildozer tool to automate the entire process. You can also see Packaging your application for the Kivy Launcher to run kivy programs without compiling them. + +You can get buildozer at https://github.com/kivy/buildozer or you can directly install using pip install buildozer + +This will install buildozer in your system. Afterwards, navigate to your project directory and run: + +buildozer init + +This creates a buildozer.spec file controlling your build configuration. You should edit it appropriately with your app name etc. You can set variables to control most or all of the parameters passed to python-for-android. + +Install buildozer’s dependencies. + +Finally, plug in your android device and run: + +buildozer android debug deploy run >> To build, push and automatically run the apk on your device. Here we used debug as tested in debug mode for now. + +Packaging your application for the Kivy Launcher + + diff --git a/checkdeps.py b/checkdeps.py index e8597bab..7665418f 100755 --- a/checkdeps.py +++ b/checkdeps.py @@ -14,6 +14,7 @@ Limitations: from __future__ import print_function import os +import sys from distutils.errors import CompileError from importlib import import_module @@ -155,6 +156,8 @@ if prereqs: OPSYS = detectOS() CMD = PACKAGE_MANAGER[OPSYS] if OPSYS in PACKAGE_MANAGER else 'UNKNOWN_INSTALLER' for lhs, rhs in EXTRAS_REQUIRE.items(): + if OPSYS is None: + break if rhs and any([ EXTRAS_REQUIRE_DEPS[x][OPSYS] for x in rhs @@ -180,5 +183,7 @@ if (not compiler or prereqs) and OPSYS in PACKAGE_MANAGER: if not compiler: compilerToPackages() prereqToPackages() + if mandatory: + sys.exit(1) else: print("All the dependencies satisfied, you can install PyBitmessage") diff --git a/src/bitmessagekivy/main.kv b/src/bitmessagekivy/main.kv index 3c73080a..ed8ad339 100644 --- a/src/bitmessagekivy/main.kv +++ b/src/bitmessagekivy/main.kv @@ -1,167 +1,256 @@ -#:import FadeTransition kivy.uix.screenmanager.FadeTransition - -: - BoxLayout: - orientation: "vertical" - BoxLayout: - size_hint: 1, None +: + id: nav_drawer + NavigationDrawerIconButton: + Button: + id: btn + background_color:app.theme_cls.primary_dark + text: 'BM-2cSvewtJw8o8eqcFzmLeXHza4BVsRsirKk' + on_release: dropdown.open(self) + pos_hint: {'x': 0, 'y': 0.3} + size_hint_y: None height: '48dp' + + DropDown: + + id: dropdown + on_parent: self.dismiss() + on_select: btn.text = '{}'.format(args[1]) Button: - text: 'messages' - on_release: sm.current = 'screen_one' - background_color: (0,0,0,0) - color: 0,0,0,1 - Button: - text: 'send' - on_release: sm.current = 'screen_two' - background_color: (0,0,0,0) - color: 0,0,0,1 - Button: - text: 'subscription' - on_release: sm.current = 'screen_three' - background_color: (0,0,0,0) - color: 0,0,0,1 - Button: - text: 'four' - on_release: sm.current = 'screen_four' - background_color: (0,0,0,0) - color: 0,0,0,1 + background_color:app.theme_cls.primary_dark + text: 'BM-2cSvewtJw8o8eqcFzmLeXHza4BVsRsirKk' + size_hint_y: None + height: '48dp' + on_release: dropdown.select('BM-2cSvewtJw8o8eqcFzmLeXHza4BVsRsirKk') + on_release: app.root.ids.scr_mngr.current = 'dialog' Button: - text: 'chans' - on_release: sm.current = 'screen_five' - background_color: (0,0,0,0) - color: 0,0,0,1 - Button: - text: 'blacklist' - on_release: sm.current = 'screen_six' - background_color: (0,0,0,0) - color: 0,0,0,1 + background_color:app.theme_cls.primary_dark + text: 'BM-2cSvewtJw8o8eqcFzmLeXHza4BVsRsirKk' + size_hint_y: None + height: '48dp' + on_release: dropdown.select('BM-2cSvewtJw8o8eqcFzmLeXHza4BVsRsirKk') + on_release: app.root.ids.scr_mngr.current = 'button' - ScreenManager: - id: sm - transition: FadeTransition() - Screen_One: - Screen_Two: - Screen_three: - Screen_four: - Screen_five: - Screen_six: - EmailScreen: - -: - name: 'screen_one' - BoxLayout: - padding: 10,10,10,300 - orientation: "vertical" + NavigationDrawerIconButton: + icon: 'email' + text: "inbox" + on_release: app.root.ids.scr_mngr.current = 'inbox' + NavigationDrawerIconButton: + icon: 'email' + text: "sent" + on_release: app.root.ids.scr_mngr.current = 'sent' + NavigationDrawerIconButton: + icon: 'email' + text: "trash" + on_release: app.root.ids.scr_mngr.current = 'trash' + NavigationDrawerIconButton: + icon: 'email' + text: "dialog" + on_release: app.root.ids.scr_mngr.current = 'dialog' + NavigationDrawerIconButton: + icon: 'email' + text: "test" + on_release: app.root.ids.scr_mngr.current = 'test' + NavigationDrawerIconButton: + text: "new identity" + icon:'notifications-add' + on_release: app.root.ids.scr_mngr.current = 'newidentity' + +BoxLayout: + orientation: 'vertical' + Toolbar: + id: toolbar + title: 'PyBitmessage' + background_color: app.theme_cls.primary_dark + left_action_items: [['menu', lambda x: app.nav_drawer.toggle()]] Button: - text: "create" - size_hint_y: 0.3 - size_hint_x: 0.1 + text:"EXIT" color: 0,0,0,1 background_color: (0,0,0,0) - Button: - text: "inbox" - background_color: (0,0,0,0) - size_hint_y: 0.3 + size_hint_y: 0.1 size_hint_x: 0.1 - color: 0,0,0,1 - Button: - text: "new" - background_color: (0,0,0,0) - size_hint_y: 0.3 - size_hint_x: 0.1 - color: 0,0,0,1 - on_press: - root.manager.current = 'email' - Button: - text: "sents" - background_color: (0,0,0,0) - size_hint_y: 0.3 - size_hint_x: 0.1 - color: 0,0,0,1 + pos_hint: {'x': 0.8, 'y':0.4} + on_press: app.say_exit() -: - name: 'screen_two' + + ScreenManager: + id: scr_mngr + Inbox: + id:sc1 + Sent: + id:sc2 + Trash: + id:sc3 + Dialog: + id:sc4 + Test: + id:sc5 + Create: + id:sc6 + NewIdentity: + id:sc7 + + Button: + height:100 + size_hint_y: 0.1 + size_hint_x: 0.1 + pos_hint: {'x': 0.85, 'y': 0.5} + background_color: (0,0,0,0) + on_press: scr_mngr.current = 'create' + Image: + source: 'images/plus.png' + y: self.parent.y + x: self.parent.x + self.parent.width - 50 + size: 70, 70 +: + name: 'inbox' + +: + name: 'sent' + +: + name: 'trash' + +: + name: 'dialog' Label: - text: "Two" - -: - name: 'screen_three' + text:"I have a good dialox box" + color: 0,0,0,1 +: + name: 'test' Label: - text: "Three" + text:"I am in test" + color: 0,0,0,1 -: - name: 'screen_four' - Label: - text: "four" - -: - name: 'screen_five' - Label: - text: "Two" - -: - name: 'screen_six' - Label: - text: "Two" - -: - name: 'email' - BoxLayout: - padding: 100,10,100,100 - id: login_layout - orientation: "vertical" - GridLayout: - rows: 2 - orientation: 'vertical' - spacing: 10 +: + name: 'create' + GridLayout: + rows: 5 + cols: 1 + padding: 60,60,60,60 + spacing: 50 + BoxLayout: + size_hint_y: None + height: '32dp' Label: - text: 'From: ' - background_color: (0,0,0,0) + text: 'FROM' color: 0,0,0,1 - font_size: 18 - pos_hint: {"x":.15,"y":1} - text_size: root.width-20, 20 + Spinner: + size_hint: 1,1 + pos_hint: {"x":0,"top":1.} + pos: 10,10 + id: spinner_id + text: '' + self.ids.subject.text = '' + self.ids.recipent.text = '' return None - def sayexit(self): - """Method will exit the application screen.""" - shutdown.doCleanShutdown() - Window.close() + def cancel(self): + self.ids.message.text = '' + self.ids.spinner_id.text = '