diff --git a/.expo/packager-info.json b/.expo/packager-info.json index 92db722..ced9713 100644 --- a/.expo/packager-info.json +++ b/.expo/packager-info.json @@ -1,10 +1,10 @@ { "devToolsPort": 19002, - "expoServerPort": null, - "packagerPort": null, - "packagerPid": null, - "expoServerNgrokUrl": null, - "packagerNgrokUrl": null, - "ngrokPid": null, + "expoServerPort": 19000, + "packagerPort": 19001, + "packagerPid": 24496, + "expoServerNgrokUrl": "https://3f-pii.williamluke.giza-native.exp.direct", + "packagerNgrokUrl": "https://packager.3f-pii.williamluke.giza-native.exp.direct", + "ngrokPid": 14344, "webpackServerPort": null } \ No newline at end of file diff --git a/.expo/settings.json b/.expo/settings.json index 45ad40f..2540290 100644 --- a/.expo/settings.json +++ b/.expo/settings.json @@ -1,5 +1,5 @@ { - "hostType": "lan", + "hostType": "tunnel", "lanType": "ip", "dev": true, "minify": false, diff --git a/App.js b/App.js new file mode 100644 index 0000000..3aff1ee --- /dev/null +++ b/App.js @@ -0,0 +1,2 @@ +import App from './src/App'; +export default App \ No newline at end of file diff --git a/ReadMe.md b/ReadMe.md new file mode 100644 index 0000000..1d06793 --- /dev/null +++ b/ReadMe.md @@ -0,0 +1,38 @@ +# Giza + +Open Source Power Outage Tracker + +[![version-badge][version-badge]][versions] +[![license-badge][license-badge]][license] +[![PRs Welcome][prs-badge]][prs] +[![Donate][donate-badge]][donate] +[![Code of Conduct][coc-badge]][coc] + +## Reason + +- Improved fault finding +- Better distribution of public infomation + +## Features + +- [ ] Planed Outages +- [ ] Reporting +- [ ] Outage Heatmap + - [ ] Customizable Date Range +- [ ] User Account + - [ ] KPLC Acc No. + +## LICENSE + +MIT + +[versions]: https://github.com/kentcdodds/custom-badges/releases +[version-badge]: https://img.shields.io/badge/-Proudly--Kenyan-red.svg?style=flat-square&logoPosition=-5&logoWidth=35&logo= +[license-badge]: https://img.shields.io/badge/license-MIT%20License-blue.svg?style=flat-square +[license]: https://github.com/kentcdodds/custom-badges/blob/master/LICENSE +[prs-badge]: https://img.shields.io/badge/PRs-welcome-brightgreen.svg?style=flat-square +[prs]: http://makeapullrequest.com +[donate-badge]: https://img.shields.io/badge/$-support-green.svg?style=flat-square +[donate]: http://kcd.im/donate +[coc-badge]: https://img.shields.io/badge/code%20of-conduct-ff69b4.svg?style=flat-square +[coc]: https://github.com/kentcdodds/custom-badges/blob/master/CODE_OF_CONDUCT.md \ No newline at end of file diff --git a/src/App.tsx b/src/App.tsx index b8ac6f7..7ff20e6 100644 --- a/src/App.tsx +++ b/src/App.tsx @@ -1,6 +1,6 @@ +import { AppLoading, Asset, Font, Icon } from 'expo'; import React from 'react'; import { Platform, StatusBar, StyleSheet, View } from 'react-native'; -import { AppLoading, Asset, Font, Icon } from 'expo'; import AppNavigator from './navigation/AppNavigator'; export default class App extends React.Component { @@ -30,15 +30,15 @@ export default class App extends React.Component { _loadResourcesAsync = async () => { return Promise.all([ Asset.loadAsync([ - require('./assets/images/homescreen192.png'), - require('./assets/images/robot-prod.png'), + require('../assets/images/homescreen192.png'), + require('../assets/images/robot-prod.png'), ]), Font.loadAsync({ // This is the font that we are using for our tab bar ...Icon.Ionicons.font, // We include SpaceMono because we use it in HomeScreen.js. Feel free // to remove this if you are not using it in your app - 'space-mono': require('./assets/fonts/SpaceMono-Regular.ttf'), + 'space-mono': require('../assets/fonts/SpaceMono-Regular.ttf'), }), ]); }; diff --git a/src/components/Map.tsx b/src/components/Map.tsx index e798353..4579d5c 100644 --- a/src/components/Map.tsx +++ b/src/components/Map.tsx @@ -1,19 +1,341 @@ import React from 'react'; -import { MapView } from 'expo'; +import { Platform } from 'react-native'; +import { Constants, Location, Permissions } from 'expo'; +import MapView, { Circle } from 'react-native-maps'; -export default class App extends React.Component { +interface IState { + location: Location.LocationData; + errorMessage: string | null; +} +const mapStyles = [ + { + elementType: 'geometry', + stylers: [ + { + color: '#ebe3cd' + } + ] + }, + { + elementType: 'labels.text.fill', + stylers: [ + { + color: '#523735' + } + ] + }, + { + elementType: 'labels.text.stroke', + stylers: [ + { + color: '#f5f1e6' + } + ] + }, + { + featureType: 'administrative', + elementType: 'geometry.stroke', + stylers: [ + { + color: '#c9b2a6' + } + ] + }, + { + featureType: 'administrative.land_parcel', + elementType: 'geometry.stroke', + stylers: [ + { + color: '#dcd2be' + } + ] + }, + { + featureType: 'administrative.land_parcel', + elementType: 'labels', + stylers: [ + { + visibility: 'off' + } + ] + }, + { + featureType: 'administrative.land_parcel', + elementType: 'labels.text.fill', + stylers: [ + { + color: '#ae9e90' + } + ] + }, + { + featureType: 'landscape.natural', + elementType: 'geometry', + stylers: [ + { + color: '#dfd2ae' + } + ] + }, + { + featureType: 'poi', + elementType: 'geometry', + stylers: [ + { + color: '#dfd2ae' + } + ] + }, + { + featureType: 'poi', + elementType: 'labels.text', + stylers: [ + { + visibility: 'off' + } + ] + }, + { + featureType: 'poi', + elementType: 'labels.text.fill', + stylers: [ + { + color: '#93817c' + } + ] + }, + { + featureType: 'poi.business', + stylers: [ + { + visibility: 'off' + } + ] + }, + { + featureType: 'poi.park', + elementType: 'geometry.fill', + stylers: [ + { + color: '#a5b076' + } + ] + }, + { + featureType: 'poi.park', + elementType: 'labels.text.fill', + stylers: [ + { + color: '#447530' + } + ] + }, + { + featureType: 'road', + elementType: 'geometry', + stylers: [ + { + color: '#f5f1e6' + } + ] + }, + { + featureType: 'road', + elementType: 'labels.icon', + stylers: [ + { + visibility: 'off' + } + ] + }, + { + featureType: 'road.arterial', + elementType: 'geometry', + stylers: [ + { + color: '#fdfcf8' + } + ] + }, + { + featureType: 'road.highway', + elementType: 'geometry', + stylers: [ + { + color: '#f8c967' + } + ] + }, + { + featureType: 'road.highway', + elementType: 'geometry.stroke', + stylers: [ + { + color: '#e9bc62' + } + ] + }, + { + featureType: 'road.highway.controlled_access', + elementType: 'geometry', + stylers: [ + { + color: '#e98d58' + } + ] + }, + { + featureType: 'road.highway.controlled_access', + elementType: 'geometry.stroke', + stylers: [ + { + color: '#db8555' + } + ] + }, + { + featureType: 'road.local', + elementType: 'labels', + stylers: [ + { + visibility: 'off' + } + ] + }, + { + featureType: 'road.local', + elementType: 'labels.text.fill', + stylers: [ + { + color: '#806b63' + } + ] + }, + { + featureType: 'transit', + stylers: [ + { + visibility: 'off' + } + ] + }, + { + featureType: 'transit.line', + elementType: 'geometry', + stylers: [ + { + color: '#dfd2ae' + } + ] + }, + { + featureType: 'transit.line', + elementType: 'labels.text.fill', + stylers: [ + { + color: '#8f7d77' + } + ] + }, + { + featureType: 'transit.line', + elementType: 'labels.text.stroke', + stylers: [ + { + color: '#ebe3cd' + } + ] + }, + { + featureType: 'transit.station', + elementType: 'geometry', + stylers: [ + { + color: '#dfd2ae' + } + ] + }, + { + featureType: 'water', + elementType: 'geometry.fill', + stylers: [ + { + color: '#b9d3c2' + } + ] + }, + { + featureType: 'water', + elementType: 'labels.text.fill', + stylers: [ + { + color: '#92998d' + } + ] + } +] +export default class Map extends React.Component<{},IState> { + state = { + region: { latitude: 37.78825, longitude: -122.4324, latitudeDelta: 0.0922, longitudeDelta: 0.0421 }, + location: {coords: { latitude: 37.78825, longitude: -122.4324, accuracy: 1000}}, + errorMessage: null + } + componentWillMount() { + if (Platform.OS === 'android' && !Constants.isDevice) { + this.setState({ + errorMessage: 'Oops, this will not work on Sketch in an Android emulator. Try it on your device!', + }); + } else { + this._getLocationAsync(); + } + } + + _getLocationAsync = async () => { + let { status } = await Permissions.askAsync(Permissions.LOCATION); + if (status !== 'granted') { + this.setState({ + errorMessage: 'Permission to access location was denied', + }); + } + + let location = await Location.getCurrentPositionAsync({accuracy: Location.Accuracy.Low}); + this.setState({ location }); + }; render() { + const {location} = this.state; + const region = (location && location.coords) ? { + latitude: location.coords.latitude, + longitude: location.coords.longitude, + latitudeDelta: 0.0922, + longitudeDelta: 0.0421 + } : undefined return ( + > + { + location + ? + : 'Nope' + } + ); } } diff --git a/src/screens/HomeScreen.tsx b/src/screens/HomeScreen.tsx index bf7ceb1..bbb9c20 100644 --- a/src/screens/HomeScreen.tsx +++ b/src/screens/HomeScreen.tsx @@ -1,16 +1,12 @@ import * as React from 'react'; import { - Image, Platform, - ScrollView, StyleSheet, Text, - TouchableOpacity, View, } from 'react-native'; import { WebBrowser } from 'expo'; import Map from '../components/Map' -import { MonoText } from '../components/StyledText'; export default class HomeScreen extends React.Component { static navigationOptions = { diff --git a/src/screens/LinksScreen.tsx b/src/screens/LinksScreen.tsx index 949120d..cf738dc 100644 --- a/src/screens/LinksScreen.tsx +++ b/src/screens/LinksScreen.tsx @@ -4,7 +4,7 @@ import { ExpoLinksView } from '@expo/samples'; export default class LinksScreen extends React.Component { static navigationOptions = { - title: 'Links', + title: 'Outages', }; render() {