Skip to content

Commit

Permalink
temp fix for ios-only UI components
Browse files Browse the repository at this point in the history
  • Loading branch information
alwx committed Jan 25, 2016
1 parent 2f6b8b0 commit 122d541
Show file tree
Hide file tree
Showing 386 changed files with 147,517 additions and 133 deletions.
19 changes: 10 additions & 9 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,32 +1,33 @@
# What is Luno?

**Luno** is a demo mobile application written in ClojureScript.
It uses [React Native](https://facebook.github.io/react-native/), [Reagent](https://reagent-project.github.io/), [Re-natal](https://github.com/drapanjanas/re-natal) and a couple of React Native libraries, for example, awesome [React Native Material Design](http://react-native-material-design.github.io/) libraries.
It uses [React Native](https://facebook.github.io/react-native/), [Reagent](https://reagent-project.github.io/), [Re-natal](https://github.com/drapanjanas/re-natal) and a couple of React Native libraries, for example, awesome [React Native Material Design](http://react-native-material-design.github.io/).

It is just proof of concept, and main purpose of Luno is to demonstrate how is it possible to create reusable components,
how to use Navigation Drawer, Navigator and NavigatorIOS, and how to create apps indistinguishable from native Android or iOS apps.
It is just proof of concept, and main purpose of Luno is to demonstrate how to create reusable components,
use Navigation Drawer, Navigator and NavigatorIOS, how to work with native libraries (it uses [Material Dialogs](https://github.com/afollestad/material-dialogs) for Android)
and how to create apps indistinguishable from native Android or iOS apps.

Luno is not completed, more features are coming.

## Screenshots

![Android & iOS](https://raw.githubusercontent.com/alwx/luno-react-native/master/_screenshots/android-ios.png)

## API

Luno uses OpenWeatherMap API to load information about weather, and Bing Search API to load images.
Both APIs require application IDs, but I don't mind of using my AppIDs (see src/luno/config.cljs for keys)

But these APIs are limited — for example Bing API allows you to perform 5000 searches per month. In the case you don't
But these APIs have some limits — for example Bing API allows you to perform 5000 searches per month. In the case you don't
see pictures or something works not the way you want it to work, please, obtain your own API keys and try running app again.

## Screenshots

![Android & iOS](https://raw.githubusercontent.com/alwx/luno-react-native/master/_screenshots/android-ios.png)

## How to run?

Luno is based on re-natal. Please, refer to [re-natal documentation](https://github.com/drapanjanas/re-natal/blob/master/README.md) to run this app on iOS or Android.

## TODO

* Ability to save cities to internal database
* Improved error handling
* Error handling

Feel free to send pull request with any additions. And, of course, I am open for any suggestions for code style, architecture or UI.
12 changes: 9 additions & 3 deletions src/luno/ios/core.cljs
Original file line number Diff line number Diff line change
Expand Up @@ -19,10 +19,16 @@
(def info-icon
"")

;;TODO: move it to better place
(def tab-bar-ios
(r/adapt-react-class (.-TabBarIOS js/React)))
(def tab-bar-ios-item
(r/adapt-react-class (.-TabBarIOS.Item js/React)))

(defn root-scene [{navigator :navigator}]
(let [tab (subscribe [:get-ios-tab])]
[ui/tab-bar-ios
[ui/tab-bar-ios-item {:icon {:uri cloud-icon :scale 4}
[tab-bar-ios
[tab-bar-ios-item {:icon {:uri cloud-icon :scale 4}
:selected (= @tab "main")
:on-press #(dispatch [:set-ios-tab "main"])
:title "Weather"}
Expand All @@ -39,7 +45,7 @@
[ui/view {:style {:padding 10
:background-color "transparent"}}
component]])))}]]
[ui/tab-bar-ios-item {:icon {:uri info-icon :scale 5}
[tab-bar-ios-item {:icon {:uri info-icon :scale 5}
:selected (= @tab "about")
:on-press #(dispatch [:set-ios-tab "about"])
:title "About"}
Expand Down
5 changes: 0 additions & 5 deletions src/luno/ui.cljs
Original file line number Diff line number Diff line change
Expand Up @@ -59,11 +59,6 @@
(def drawer-section
(r/adapt-react-class (.-Drawer.Section js/MaterialDesign)))

(defn tab-bar-ios []
(r/adapt-react-class (.-TabBarIOS js/React)))
(defn tab-bar-ios-item []
(r/adapt-react-class (.-TabBarIOS.Item js/React)))

;; Other

(def intent-android
Expand Down
2 changes: 1 addition & 1 deletion target/android/env/android/main.cljs.cache.edn
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
;; Analyzed by ClojureScript 1.7.170
{:use-macros nil, :excludes #{}, :name env.android.main, :imports nil, :requires {core luno.android.core, luno.android.core luno.android.core, figwheel figwheel.client, figwheel.client figwheel.client}, :uses nil, :require-macros {figwheel figwheel.client, figwheel.client figwheel.client}, :cljs.analyzer/constants {:seen #{:heads-up-display :jsload-callback :websocket-url}, :order [:websocket-url :heads-up-display :jsload-callback]}, :doc nil}
{:name env.android.main, :doc nil, :excludes #{}, :use-macros nil, :require-macros {figwheel figwheel.client, figwheel.client figwheel.client}, :uses nil, :requires {core luno.android.core, luno.android.core luno.android.core, figwheel figwheel.client, figwheel.client figwheel.client}, :imports nil, :cljs.analyzer/constants {:seen #{:heads-up-display :jsload-callback :websocket-url}, :order [:websocket-url :heads-up-display :jsload-callback]}}
Loading

0 comments on commit 122d541

Please sign in to comment.