diff --git a/joseGarcia/CodeChallenges/LoginForm/.expo-shared/assets.json b/joseGarcia/CodeChallenges/LoginForm/.expo-shared/assets.json
new file mode 100644
index 0000000..1e6decf
--- /dev/null
+++ b/joseGarcia/CodeChallenges/LoginForm/.expo-shared/assets.json
@@ -0,0 +1,4 @@
+{
+ "12bb71342c6255bbf50437ec8f4441c083f47cdb74bd89160c15e4f43e52a1cb": true,
+ "40b842e832070c58deac6aa9e08fa459302ee3f9da492c7e77d93d2fbf4a56fd": true
+}
diff --git a/joseGarcia/CodeChallenges/LoginForm/.gitignore b/joseGarcia/CodeChallenges/LoginForm/.gitignore
new file mode 100644
index 0000000..9b57dd1
--- /dev/null
+++ b/joseGarcia/CodeChallenges/LoginForm/.gitignore
@@ -0,0 +1,15 @@
+node_modules/**/*
+coverage/*
+.expo/*
+npm-debug.*
+*.jks
+*.p8
+*.p12
+*.key
+*.mobileprovision
+*.orig.*
+web-build/
+web-report/
+
+# macOS
+.DS_Store
\ No newline at end of file
diff --git a/joseGarcia/CodeChallenges/LoginForm/.watchmanconfig b/joseGarcia/CodeChallenges/LoginForm/.watchmanconfig
new file mode 100644
index 0000000..e69de29
diff --git a/joseGarcia/CodeChallenges/LoginForm/App.js b/joseGarcia/CodeChallenges/LoginForm/App.js
new file mode 100644
index 0000000..601ef51
--- /dev/null
+++ b/joseGarcia/CodeChallenges/LoginForm/App.js
@@ -0,0 +1,18 @@
+import React from 'react';
+import { StyleSheet } from 'react-native';
+import LoginNavigator from './navigation/LoginNavigator'
+
+export default function App() {
+ return (
+
+ );
+}
+
+const styles = StyleSheet.create({
+ container: {
+ flex: 1,
+ backgroundColor: '#fff',
+ alignItems: 'center',
+ justifyContent: 'center'
+ }
+});
diff --git a/joseGarcia/CodeChallenges/LoginForm/_tests_/App.test.js b/joseGarcia/CodeChallenges/LoginForm/_tests_/App.test.js
new file mode 100644
index 0000000..3484c20
--- /dev/null
+++ b/joseGarcia/CodeChallenges/LoginForm/_tests_/App.test.js
@@ -0,0 +1,16 @@
+import React from 'react';
+import renderer from 'react-test-renderer';
+
+import App from '../App';
+
+describe('', () => {
+ it('has 1 child', () => {
+ const tree = renderer.create().toJSON();
+ expect(tree.children.length).toBe(1);
+ });
+
+ it('renders correctly', () => {
+ const tree = renderer.create().toJSON();
+ expect(tree).toMatchSnapshot();
+ });
+});
\ No newline at end of file
diff --git a/joseGarcia/CodeChallenges/LoginForm/_tests_/__snapshots__/App.test.js.snap b/joseGarcia/CodeChallenges/LoginForm/_tests_/__snapshots__/App.test.js.snap
new file mode 100644
index 0000000..a068102
--- /dev/null
+++ b/joseGarcia/CodeChallenges/LoginForm/_tests_/__snapshots__/App.test.js.snap
@@ -0,0 +1,325 @@
+// Jest Snapshot v1, https://goo.gl/fbAQLP
+
+exports[` renders correctly 1`] = `
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Log In
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Login
+
+
+
+
+
+
+
+
+`;
diff --git a/joseGarcia/CodeChallenges/LoginForm/app.json b/joseGarcia/CodeChallenges/LoginForm/app.json
new file mode 100644
index 0000000..9ac205e
--- /dev/null
+++ b/joseGarcia/CodeChallenges/LoginForm/app.json
@@ -0,0 +1,28 @@
+{
+ "expo": {
+ "name": "LoginForm",
+ "slug": "LoginForm",
+ "platforms": [
+ "ios",
+ "android",
+ "web"
+ ],
+ "version": "1.0.0",
+ "orientation": "portrait",
+ "icon": "./assets/icon.png",
+ "splash": {
+ "image": "./assets/splash.png",
+ "resizeMode": "contain",
+ "backgroundColor": "#ffffff"
+ },
+ "updates": {
+ "fallbackToCacheTimeout": 0
+ },
+ "assetBundlePatterns": [
+ "**/*"
+ ],
+ "ios": {
+ "supportsTablet": true
+ }
+ }
+}
diff --git a/joseGarcia/CodeChallenges/LoginForm/assets/icon.png b/joseGarcia/CodeChallenges/LoginForm/assets/icon.png
new file mode 100644
index 0000000..6eaf302
Binary files /dev/null and b/joseGarcia/CodeChallenges/LoginForm/assets/icon.png differ
diff --git a/joseGarcia/CodeChallenges/LoginForm/assets/splash.png b/joseGarcia/CodeChallenges/LoginForm/assets/splash.png
new file mode 100644
index 0000000..cc94f37
Binary files /dev/null and b/joseGarcia/CodeChallenges/LoginForm/assets/splash.png differ
diff --git a/joseGarcia/CodeChallenges/LoginForm/babel.config.js b/joseGarcia/CodeChallenges/LoginForm/babel.config.js
new file mode 100644
index 0000000..2900afe
--- /dev/null
+++ b/joseGarcia/CodeChallenges/LoginForm/babel.config.js
@@ -0,0 +1,6 @@
+module.exports = function(api) {
+ api.cache(true);
+ return {
+ presets: ['babel-preset-expo'],
+ };
+};
diff --git a/joseGarcia/CodeChallenges/LoginForm/components/Input.js b/joseGarcia/CodeChallenges/LoginForm/components/Input.js
new file mode 100644
index 0000000..8c4544d
--- /dev/null
+++ b/joseGarcia/CodeChallenges/LoginForm/components/Input.js
@@ -0,0 +1,9 @@
+import React from 'react';
+import { TextInput, StyleSheet } from 'react-native';
+import DefaultStyles from '../constants/default-styles';
+
+const Input = props => {
+ return ;
+};
+
+export default Input;
\ No newline at end of file
diff --git a/joseGarcia/CodeChallenges/LoginForm/components/MainButton.js b/joseGarcia/CodeChallenges/LoginForm/components/MainButton.js
new file mode 100644
index 0000000..b86bd6f
--- /dev/null
+++ b/joseGarcia/CodeChallenges/LoginForm/components/MainButton.js
@@ -0,0 +1,17 @@
+import React from 'react';
+import { View, Text, TouchableOpacity, Platform, TouchableNativeFeedback } from 'react-native';
+
+import DefaultStyles from '../constants/default-styles'
+
+const MainButton = props => {
+ const ButtonComponent = Platform.OS === 'android' ? TouchableNativeFeedback : TouchableOpacity
+ return (
+
+
+ {props.children}
+
+
+ );
+};
+
+export default MainButton;
\ No newline at end of file
diff --git a/joseGarcia/CodeChallenges/LoginForm/constants/colors.js b/joseGarcia/CodeChallenges/LoginForm/constants/colors.js
new file mode 100644
index 0000000..a7912a0
--- /dev/null
+++ b/joseGarcia/CodeChallenges/LoginForm/constants/colors.js
@@ -0,0 +1,4 @@
+export default {
+ primary: "#f7287b",
+ accent: "#c717fc"
+}
\ No newline at end of file
diff --git a/joseGarcia/CodeChallenges/LoginForm/constants/default-styles.js b/joseGarcia/CodeChallenges/LoginForm/constants/default-styles.js
new file mode 100644
index 0000000..2697b9d
--- /dev/null
+++ b/joseGarcia/CodeChallenges/LoginForm/constants/default-styles.js
@@ -0,0 +1,41 @@
+import { StyleSheet, Platform } from 'react-native';
+import Colors from '../constants/colors'
+
+export default StyleSheet.create({
+ input: {
+ height: 30,
+ borderBottomColor: 'grey',
+ borderBottomWidth: 1,
+ marginVertical: 10
+ },
+ title: {
+ fontSize: 18,
+ color: Platform.OS === 'android' ? 'white' : Colors.primary
+ },
+ button: {
+ backgroundColor: Colors.primary,
+ paddingVertical: 12,
+ paddingHorizontal: 30,
+ borderRadius: 25
+ },
+ buttonText: {
+ color: 'white',
+ fontSize: 18
+ },
+ headerBase: {
+ width: '100%',
+ height: 90,
+ paddingTop: 36,
+ alignItems: 'center',
+ justifyContent: 'center',
+
+ },
+ headerIOS: {
+ backgroundColor: 'white',
+ borderBottomColor: '#ccc',
+ borderBottomWidth: 1
+ },
+ headerAndroid: {
+ backgroundColor: Colors.primary
+ }
+});
\ No newline at end of file
diff --git a/joseGarcia/CodeChallenges/LoginForm/coverage/clover.xml b/joseGarcia/CodeChallenges/LoginForm/coverage/clover.xml
new file mode 100644
index 0000000..c38d972
--- /dev/null
+++ b/joseGarcia/CodeChallenges/LoginForm/coverage/clover.xml
@@ -0,0 +1,101 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/joseGarcia/CodeChallenges/LoginForm/coverage/coverage-final.json b/joseGarcia/CodeChallenges/LoginForm/coverage/coverage-final.json
new file mode 100644
index 0000000..9920695
--- /dev/null
+++ b/joseGarcia/CodeChallenges/LoginForm/coverage/coverage-final.json
@@ -0,0 +1,12 @@
+{"/Users/josegarcia/Desktop/Stuff/coding_challenges/jose/CodeChallenges/LoginForm/App.js": {"path":"/Users/josegarcia/Desktop/Stuff/coding_challenges/jose/CodeChallenges/LoginForm/App.js","statementMap":{"0":{"start":{"line":6,"column":2},"end":{"line":8,"column":4}},"1":{"start":{"line":11,"column":15},"end":{"line":18,"column":2}}},"fnMap":{"0":{"name":"App","decl":{"start":{"line":5,"column":24},"end":{"line":5,"column":27}},"loc":{"start":{"line":5,"column":30},"end":{"line":9,"column":1}},"line":5}},"branchMap":{},"s":{"0":2,"1":1},"f":{"0":2},"b":{},"_coverageSchema":"43e27e138ebf9cfc5966b082cf9a028302ed4184","hash":"89bcfd444aedd65c2e0a63037cbf18a12dbae734"}
+,"/Users/josegarcia/Desktop/Stuff/coding_challenges/jose/CodeChallenges/LoginForm/components/Input.js": {"path":"/Users/josegarcia/Desktop/Stuff/coding_challenges/jose/CodeChallenges/LoginForm/components/Input.js","statementMap":{"0":{"start":{"line":5,"column":14},"end":{"line":7,"column":1}},"1":{"start":{"line":6,"column":4},"end":{"line":6,"column":87}}},"fnMap":{"0":{"name":"(anonymous_0)","decl":{"start":{"line":5,"column":14},"end":{"line":5,"column":15}},"loc":{"start":{"line":5,"column":23},"end":{"line":7,"column":1}},"line":5}},"branchMap":{},"s":{"0":1,"1":0},"f":{"0":0},"b":{},"_coverageSchema":"43e27e138ebf9cfc5966b082cf9a028302ed4184","hash":"d7cf42841c7a5478958ac40dbba4fb59c8e735f3"}
+,"/Users/josegarcia/Desktop/Stuff/coding_challenges/jose/CodeChallenges/LoginForm/components/MainButton.js": {"path":"/Users/josegarcia/Desktop/Stuff/coding_challenges/jose/CodeChallenges/LoginForm/components/MainButton.js","statementMap":{"0":{"start":{"line":6,"column":19},"end":{"line":15,"column":1}},"1":{"start":{"line":7,"column":28},"end":{"line":7,"column":98}},"2":{"start":{"line":8,"column":4},"end":{"line":14,"column":6}}},"fnMap":{"0":{"name":"(anonymous_0)","decl":{"start":{"line":6,"column":19},"end":{"line":6,"column":20}},"loc":{"start":{"line":6,"column":28},"end":{"line":15,"column":1}},"line":6}},"branchMap":{"0":{"loc":{"start":{"line":7,"column":28},"end":{"line":7,"column":98}},"type":"cond-expr","locations":[{"start":{"line":7,"column":56},"end":{"line":7,"column":79}},{"start":{"line":7,"column":82},"end":{"line":7,"column":98}}],"line":7}},"s":{"0":1,"1":0,"2":0},"f":{"0":0},"b":{"0":[0,0]},"_coverageSchema":"43e27e138ebf9cfc5966b082cf9a028302ed4184","hash":"d2f8ce5b5d3bfbde77a99636b195ee5cdb0fb66d"}
+,"/Users/josegarcia/Desktop/Stuff/coding_challenges/jose/CodeChallenges/LoginForm/constants/colors.js": {"path":"/Users/josegarcia/Desktop/Stuff/coding_challenges/jose/CodeChallenges/LoginForm/constants/colors.js","statementMap":{},"fnMap":{},"branchMap":{},"s":{},"f":{},"b":{},"_coverageSchema":"43e27e138ebf9cfc5966b082cf9a028302ed4184","hash":"25e1e11fcc4925d3a0f941e989f347c44771ba8d"}
+,"/Users/josegarcia/Desktop/Stuff/coding_challenges/jose/CodeChallenges/LoginForm/constants/default-styles.js": {"path":"/Users/josegarcia/Desktop/Stuff/coding_challenges/jose/CodeChallenges/LoginForm/constants/default-styles.js","statementMap":{},"fnMap":{},"branchMap":{"0":{"loc":{"start":{"line":13,"column":15},"end":{"line":13,"column":67}},"type":"cond-expr","locations":[{"start":{"line":13,"column":43},"end":{"line":13,"column":50}},{"start":{"line":13,"column":53},"end":{"line":13,"column":67}}],"line":13}},"s":{},"f":{},"b":{"0":[0,1]},"_coverageSchema":"43e27e138ebf9cfc5966b082cf9a028302ed4184","hash":"4aed8a839487daf31df8436e3f12ee3c821330f5"}
+,"/Users/josegarcia/Desktop/Stuff/coding_challenges/jose/CodeChallenges/LoginForm/data/dummy-data.js": {"path":"/Users/josegarcia/Desktop/Stuff/coding_challenges/jose/CodeChallenges/LoginForm/data/dummy-data.js","statementMap":{"0":{"start":{"line":1,"column":21},"end":{"line":6,"column":1}}},"fnMap":{},"branchMap":{},"s":{"0":1},"f":{},"b":{},"_coverageSchema":"43e27e138ebf9cfc5966b082cf9a028302ed4184","hash":"734415704e78ef01c42ed3f96097d905e065fa89"}
+,"/Users/josegarcia/Desktop/Stuff/coding_challenges/jose/CodeChallenges/LoginForm/navigation/LoginNavigator.js": {"path":"/Users/josegarcia/Desktop/Stuff/coding_challenges/jose/CodeChallenges/LoginForm/navigation/LoginNavigator.js","statementMap":{"0":{"start":{"line":11,"column":23},"end":{"line":26,"column":1}}},"fnMap":{},"branchMap":{"0":{"loc":{"start":{"line":21,"column":33},"end":{"line":21,"column":85}},"type":"cond-expr","locations":[{"start":{"line":21,"column":61},"end":{"line":21,"column":75}},{"start":{"line":21,"column":78},"end":{"line":21,"column":85}}],"line":21},"1":{"loc":{"start":{"line":23,"column":29},"end":{"line":23,"column":81}},"type":"cond-expr","locations":[{"start":{"line":23,"column":57},"end":{"line":23,"column":64}},{"start":{"line":23,"column":67},"end":{"line":23,"column":81}}],"line":23}},"s":{"0":1},"f":{},"b":{"0":[0,1],"1":[0,1]},"_coverageSchema":"43e27e138ebf9cfc5966b082cf9a028302ed4184","hash":"82965da533af6c76168c11be5e8db862f338ed31"}
+,"/Users/josegarcia/Desktop/Stuff/coding_challenges/jose/CodeChallenges/LoginForm/navigation/MainNavigator.js": {"path":"/Users/josegarcia/Desktop/Stuff/coding_challenges/jose/CodeChallenges/LoginForm/navigation/MainNavigator.js","statementMap":{"0":{"start":{"line":8,"column":22},"end":{"line":20,"column":1}}},"fnMap":{},"branchMap":{"0":{"loc":{"start":{"line":15,"column":33},"end":{"line":15,"column":85}},"type":"cond-expr","locations":[{"start":{"line":15,"column":61},"end":{"line":15,"column":75}},{"start":{"line":15,"column":78},"end":{"line":15,"column":85}}],"line":15},"1":{"loc":{"start":{"line":17,"column":29},"end":{"line":17,"column":81}},"type":"cond-expr","locations":[{"start":{"line":17,"column":57},"end":{"line":17,"column":64}},{"start":{"line":17,"column":67},"end":{"line":17,"column":81}}],"line":17}},"s":{"0":0},"f":{},"b":{"0":[0,0],"1":[0,0]},"hash":"11f580e4614ea698068deff43990b9a5f45d737b"}
+,"/Users/josegarcia/Desktop/Stuff/coding_challenges/jose/CodeChallenges/LoginForm/screens/HomeScreen.js": {"path":"/Users/josegarcia/Desktop/Stuff/coding_challenges/jose/CodeChallenges/LoginForm/screens/HomeScreen.js","statementMap":{"0":{"start":{"line":4,"column":19},"end":{"line":12,"column":1}},"1":{"start":{"line":6,"column":19},"end":{"line":6,"column":33}},"2":{"start":{"line":7,"column":4},"end":{"line":11,"column":6}}},"fnMap":{"0":{"name":"(anonymous_0)","decl":{"start":{"line":4,"column":19},"end":{"line":4,"column":20}},"loc":{"start":{"line":4,"column":28},"end":{"line":12,"column":1}},"line":4}},"branchMap":{},"s":{"0":2,"1":1,"2":1},"f":{"0":1},"b":{},"_coverageSchema":"43e27e138ebf9cfc5966b082cf9a028302ed4184","hash":"3d5dcb76a070ba11c4a0087d0bfcfbbb716ac7ca"}
+,"/Users/josegarcia/Desktop/Stuff/coding_challenges/jose/CodeChallenges/LoginForm/screens/login_flow/LoginFormScreen.js": {"path":"/Users/josegarcia/Desktop/Stuff/coding_challenges/jose/CodeChallenges/LoginForm/screens/login_flow/LoginFormScreen.js","statementMap":{"0":{"start":{"line":8,"column":24},"end":{"line":84,"column":1}},"1":{"start":{"line":9,"column":36},"end":{"line":9,"column":48}},"2":{"start":{"line":10,"column":36},"end":{"line":10,"column":48}},"3":{"start":{"line":12,"column":33},"end":{"line":14,"column":5}},"4":{"start":{"line":13,"column":8},"end":{"line":13,"column":39}},"5":{"start":{"line":16,"column":33},"end":{"line":18,"column":5}},"6":{"start":{"line":17,"column":8},"end":{"line":17,"column":39}},"7":{"start":{"line":20,"column":30},"end":{"line":23,"column":5}},"8":{"start":{"line":21,"column":8},"end":{"line":21,"column":23}},"9":{"start":{"line":22,"column":8},"end":{"line":22,"column":23}},"10":{"start":{"line":25,"column":25},"end":{"line":33,"column":5}},"11":{"start":{"line":26,"column":8},"end":{"line":31,"column":9}},"12":{"start":{"line":27,"column":12},"end":{"line":30,"column":13}},"13":{"start":{"line":28,"column":16},"end":{"line":28,"column":33}},"14":{"start":{"line":29,"column":16},"end":{"line":29,"column":23}},"15":{"start":{"line":32,"column":8},"end":{"line":32,"column":28}},"16":{"start":{"line":35,"column":30},"end":{"line":37,"column":5}},"17":{"start":{"line":36,"column":8},"end":{"line":36,"column":44}},"18":{"start":{"line":39,"column":33},"end":{"line":41,"column":5}},"19":{"start":{"line":40,"column":8},"end":{"line":40,"column":43}},"20":{"start":{"line":43,"column":30},"end":{"line":49,"column":5}},"21":{"start":{"line":44,"column":8},"end":{"line":48,"column":10}},"22":{"start":{"line":51,"column":27},"end":{"line":59,"column":5}},"23":{"start":{"line":52,"column":8},"end":{"line":58,"column":10}},"24":{"start":{"line":61,"column":4},"end":{"line":83,"column":5}}},"fnMap":{"0":{"name":"(anonymous_0)","decl":{"start":{"line":8,"column":24},"end":{"line":8,"column":25}},"loc":{"start":{"line":8,"column":33},"end":{"line":84,"column":1}},"line":8},"1":{"name":"(anonymous_1)","decl":{"start":{"line":12,"column":33},"end":{"line":12,"column":34}},"loc":{"start":{"line":12,"column":54},"end":{"line":14,"column":5}},"line":12},"2":{"name":"(anonymous_2)","decl":{"start":{"line":16,"column":33},"end":{"line":16,"column":34}},"loc":{"start":{"line":16,"column":54},"end":{"line":18,"column":5}},"line":16},"3":{"name":"(anonymous_3)","decl":{"start":{"line":20,"column":30},"end":{"line":20,"column":31}},"loc":{"start":{"line":20,"column":36},"end":{"line":23,"column":5}},"line":20},"4":{"name":"(anonymous_4)","decl":{"start":{"line":25,"column":25},"end":{"line":25,"column":26}},"loc":{"start":{"line":25,"column":31},"end":{"line":33,"column":5}},"line":25},"5":{"name":"(anonymous_5)","decl":{"start":{"line":35,"column":30},"end":{"line":35,"column":31}},"loc":{"start":{"line":35,"column":36},"end":{"line":37,"column":5}},"line":35},"6":{"name":"(anonymous_6)","decl":{"start":{"line":39,"column":33},"end":{"line":39,"column":34}},"loc":{"start":{"line":39,"column":39},"end":{"line":41,"column":5}},"line":39},"7":{"name":"(anonymous_7)","decl":{"start":{"line":43,"column":30},"end":{"line":43,"column":31}},"loc":{"start":{"line":43,"column":36},"end":{"line":49,"column":5}},"line":43},"8":{"name":"(anonymous_8)","decl":{"start":{"line":51,"column":27},"end":{"line":51,"column":28}},"loc":{"start":{"line":51,"column":33},"end":{"line":59,"column":5}},"line":51}},"branchMap":{"0":{"loc":{"start":{"line":26,"column":8},"end":{"line":31,"column":9}},"type":"if","locations":[{"start":{"line":26,"column":8},"end":{"line":31,"column":9}},{"start":{"line":26,"column":8},"end":{"line":31,"column":9}}],"line":26},"1":{"loc":{"start":{"line":27,"column":12},"end":{"line":30,"column":13}},"type":"if","locations":[{"start":{"line":27,"column":12},"end":{"line":30,"column":13}},{"start":{"line":27,"column":12},"end":{"line":30,"column":13}}],"line":27}},"s":{"0":1,"1":0,"2":0,"3":0,"4":0,"5":0,"6":0,"7":0,"8":0,"9":0,"10":0,"11":0,"12":0,"13":0,"14":0,"15":0,"16":0,"17":0,"18":0,"19":0,"20":0,"21":0,"22":0,"23":0,"24":0},"f":{"0":0,"1":0,"2":0,"3":0,"4":0,"5":0,"6":0,"7":0,"8":0},"b":{"0":[0,0],"1":[0,0]},"_coverageSchema":"43e27e138ebf9cfc5966b082cf9a028302ed4184","hash":"a1c27cde83364532b54ab32f8bdca7aea4cd0c4f"}
+,"/Users/josegarcia/Desktop/Stuff/coding_challenges/jose/CodeChallenges/LoginForm/screens/login_flow/LoginScreen.js": {"path":"/Users/josegarcia/Desktop/Stuff/coding_challenges/jose/CodeChallenges/LoginForm/screens/login_flow/LoginScreen.js","statementMap":{"0":{"start":{"line":4,"column":20},"end":{"line":15,"column":1}},"1":{"start":{"line":5,"column":4},"end":{"line":14,"column":5}},"2":{"start":{"line":10,"column":20},"end":{"line":10,"column":58}}},"fnMap":{"0":{"name":"(anonymous_0)","decl":{"start":{"line":4,"column":20},"end":{"line":4,"column":21}},"loc":{"start":{"line":4,"column":29},"end":{"line":15,"column":1}},"line":4},"1":{"name":"(anonymous_1)","decl":{"start":{"line":9,"column":25},"end":{"line":9,"column":26}},"loc":{"start":{"line":9,"column":31},"end":{"line":11,"column":17}},"line":9}},"branchMap":{},"s":{"0":1,"1":2,"2":0},"f":{"0":2,"1":0},"b":{},"_coverageSchema":"43e27e138ebf9cfc5966b082cf9a028302ed4184","hash":"856413ee497ef72548755edb9a788adc4ecc662d"}
+}
diff --git a/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/App.js.html b/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/App.js.html
new file mode 100644
index 0000000..014d92b
--- /dev/null
+++ b/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/App.js.html
@@ -0,0 +1,133 @@
+
+
+
+
+
+ Code coverage report for LoginForm/App.js
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 100%
+ Statements
+ 2/2
+
+
+
+
+ 100%
+ Branches
+ 0/0
+
+
+
+
+ 100%
+ Functions
+ 1/1
+
+
+
+
+ 100%
+ Lines
+ 2/2
+
+
+
+
+
+ Press n or j to go to the next uncovered block, b, p or k for the previous block.
+
+
+
+
+| 1
+2
+3
+4
+5
+6
+7
+8
+9
+10
+11
+12
+13
+14
+15
+16
+17
+18
+19 |
+
+
+
+
+2x
+
+
+
+
+1x
+
+
+
+
+
+
+
+ | import React from 'react';
+import { StyleSheet } from 'react-native';
+import LoginNavigator from './navigation/LoginNavigator'
+
+export default function App() {
+ return (
+ <LoginNavigator />
+ );
+}
+
+const styles = StyleSheet.create({
+ container: {
+ flex: 1,
+ backgroundColor: '#fff',
+ alignItems: 'center',
+ justifyContent: 'center'
+ }
+});
+ |
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/components/Input.js.html b/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/components/Input.js.html
new file mode 100644
index 0000000..d23240b
--- /dev/null
+++ b/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/components/Input.js.html
@@ -0,0 +1,103 @@
+
+
+
+
+
+ Code coverage report for LoginForm/components/Input.js
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 50%
+ Statements
+ 1/2
+
+
+
+
+ 100%
+ Branches
+ 0/0
+
+
+
+
+ 0%
+ Functions
+ 0/1
+
+
+
+
+ 50%
+ Lines
+ 1/2
+
+
+
+
+
+ Press n or j to go to the next uncovered block, b, p or k for the previous block.
+
+
+
+
+| 1
+2
+3
+4
+5
+6
+7
+8
+9 |
+
+
+
+1x
+
+
+
+ | import React from 'react';
+import { TextInput, StyleSheet } from 'react-native';
+import DefaultStyles from '../constants/default-styles';
+
+const Input = props => {
+ return <TextInput {...props} style={{ ...DefaultStyles.input, ...props.style }} />;
+};
+
+export default Input; |
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/components/MainButton.js.html b/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/components/MainButton.js.html
new file mode 100644
index 0000000..482b978
--- /dev/null
+++ b/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/components/MainButton.js.html
@@ -0,0 +1,127 @@
+
+
+
+
+
+ Code coverage report for LoginForm/components/MainButton.js
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 33.33%
+ Statements
+ 1/3
+
+
+
+
+ 0%
+ Branches
+ 0/2
+
+
+
+
+ 0%
+ Functions
+ 0/1
+
+
+
+
+ 33.33%
+ Lines
+ 1/3
+
+
+
+
+
+ Press n or j to go to the next uncovered block, b, p or k for the previous block.
+
+
+
+
+| 1
+2
+3
+4
+5
+6
+7
+8
+9
+10
+11
+12
+13
+14
+15
+16
+17 |
+
+
+
+
+1x
+
+
+
+
+
+
+
+
+
+
+ | import React from 'react';
+import { View, Text, TouchableOpacity, Platform, TouchableNativeFeedback } from 'react-native';
+
+import DefaultStyles from '../constants/default-styles'
+
+const MainButton = props => {
+ const ButtonComponent = Platform.OS === 'android' ? TouchableNativeFeedback : TouchableOpacity
+ return (
+ <ButtonComponent activeOpacity={0.6} onPress={props.onPress}>
+ <View style={DefaultStyles.button}>
+ <Text style={DefaultStyles.buttonText}>{props.children}</Text>
+ </View>
+ </ButtonComponent>
+ );
+};
+
+export default MainButton; |
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/components/index.html b/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/components/index.html
new file mode 100644
index 0000000..46f517a
--- /dev/null
+++ b/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/components/index.html
@@ -0,0 +1,125 @@
+
+
+
+
+
+ Code coverage report for LoginForm/components
+
+
+
+
+
+
+
+
+
+
+
All files LoginForm/components
+
+
+
+ 40%
+ Statements
+ 2/5
+
+
+
+
+ 0%
+ Branches
+ 0/2
+
+
+
+
+ 0%
+ Functions
+ 0/2
+
+
+
+
+ 40%
+ Lines
+ 2/5
+
+
+
+
+
+ Press n or j to go to the next uncovered block, b, p or k for the previous block.
+
+
+
+
+
+
+
+ | File |
+ |
+ Statements |
+ |
+ Branches |
+ |
+ Functions |
+ |
+ Lines |
+ |
+
+
+
+ | Input.js |
+
+
+ |
+ 50% |
+ 1/2 |
+ 100% |
+ 0/0 |
+ 0% |
+ 0/1 |
+ 50% |
+ 1/2 |
+
+
+
+ | MainButton.js |
+
+
+ |
+ 33.33% |
+ 1/3 |
+ 0% |
+ 0/2 |
+ 0% |
+ 0/1 |
+ 33.33% |
+ 1/3 |
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/constants/colors.js.html b/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/constants/colors.js.html
new file mode 100644
index 0000000..0a30f77
--- /dev/null
+++ b/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/constants/colors.js.html
@@ -0,0 +1,88 @@
+
+
+
+
+
+ Code coverage report for LoginForm/constants/colors.js
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 0%
+ Statements
+ 0/0
+
+
+
+
+ 0%
+ Branches
+ 0/0
+
+
+
+
+ 0%
+ Functions
+ 0/0
+
+
+
+
+ 0%
+ Lines
+ 0/0
+
+
+
+
+
+ Press n or j to go to the next uncovered block, b, p or k for the previous block.
+
+
+
+
+| 1
+2
+3
+4 |
+
+
+ | export default {
+ primary: "#f7287b",
+ accent: "#c717fc"
+} |
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/constants/default-styles.js.html b/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/constants/default-styles.js.html
new file mode 100644
index 0000000..952a3ca
--- /dev/null
+++ b/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/constants/default-styles.js.html
@@ -0,0 +1,199 @@
+
+
+
+
+
+ Code coverage report for LoginForm/constants/default-styles.js
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 0%
+ Statements
+ 0/0
+
+
+
+
+ 0%
+ Branches
+ 1/2
+
+
+
+
+ 0%
+ Functions
+ 0/0
+
+
+
+
+ 0%
+ Lines
+ 0/0
+
+
+
+
+
+ Press n or j to go to the next uncovered block, b, p or k for the previous block.
+
+
+
+
+| 1
+2
+3
+4
+5
+6
+7
+8
+9
+10
+11
+12
+13
+14
+15
+16
+17
+18
+19
+20
+21
+22
+23
+24
+25
+26
+27
+28
+29
+30
+31
+32
+33
+34
+35
+36
+37
+38
+39
+40
+41 |
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ | import { StyleSheet, Platform } from 'react-native';
+import Colors from '../constants/colors'
+
+export default StyleSheet.create({
+ input: {
+ height: 30,
+ borderBottomColor: 'grey',
+ borderBottomWidth: 1,
+ marginVertical: 10
+ },
+ title: {
+ fontSize: 18,
+ color: Platform.OS === 'android' ? 'white' : Colors.primary
+ },
+ button: {
+ backgroundColor: Colors.primary,
+ paddingVertical: 12,
+ paddingHorizontal: 30,
+ borderRadius: 25
+ },
+ buttonText: {
+ color: 'white',
+ fontSize: 18
+ },
+ headerBase: {
+ width: '100%',
+ height: 90,
+ paddingTop: 36,
+ alignItems: 'center',
+ justifyContent: 'center',
+
+ },
+ headerIOS: {
+ backgroundColor: 'white',
+ borderBottomColor: '#ccc',
+ borderBottomWidth: 1
+ },
+ headerAndroid: {
+ backgroundColor: Colors.primary
+ }
+}); |
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/constants/index.html b/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/constants/index.html
new file mode 100644
index 0000000..3afc616
--- /dev/null
+++ b/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/constants/index.html
@@ -0,0 +1,125 @@
+
+
+
+
+
+ Code coverage report for LoginForm/constants
+
+
+
+
+
+
+
+
+
+
+
All files LoginForm/constants
+
+
+
+ 0%
+ Statements
+ 0/0
+
+
+
+
+ 0%
+ Branches
+ 1/2
+
+
+
+
+ 0%
+ Functions
+ 0/0
+
+
+
+
+ 0%
+ Lines
+ 0/0
+
+
+
+
+
+ Press n or j to go to the next uncovered block, b, p or k for the previous block.
+
+
+
+
+
+
+
+ | File |
+ |
+ Statements |
+ |
+ Branches |
+ |
+ Functions |
+ |
+ Lines |
+ |
+
+
+
+ | colors.js |
+
+
+ |
+ 0% |
+ 0/0 |
+ 0% |
+ 0/0 |
+ 0% |
+ 0/0 |
+ 0% |
+ 0/0 |
+
+
+
+ | default-styles.js |
+
+
+ |
+ 0% |
+ 0/0 |
+ 0% |
+ 1/2 |
+ 0% |
+ 0/0 |
+ 0% |
+ 0/0 |
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/data/dummy-data.js.html b/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/data/dummy-data.js.html
new file mode 100644
index 0000000..05708e5
--- /dev/null
+++ b/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/data/dummy-data.js.html
@@ -0,0 +1,97 @@
+
+
+
+
+
+ Code coverage report for LoginForm/data/dummy-data.js
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 100%
+ Statements
+ 1/1
+
+
+
+
+ 100%
+ Branches
+ 0/0
+
+
+
+
+ 100%
+ Functions
+ 0/0
+
+
+
+
+ 100%
+ Lines
+ 1/1
+
+
+
+
+
+ Press n or j to go to the next uncovered block, b, p or k for the previous block.
+
+
+
+
+| 1
+2
+3
+4
+5
+6
+7 | 1x
+
+
+
+
+
+ | export const USERS = {
+ "rob123": "0000000",
+ "sarab13": "12345678",
+ "sp123": "123",
+ "spteacher": "0000000"
+}
+ |
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/data/index.html b/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/data/index.html
new file mode 100644
index 0000000..f74f267
--- /dev/null
+++ b/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/data/index.html
@@ -0,0 +1,110 @@
+
+
+
+
+
+ Code coverage report for LoginForm/data
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 100%
+ Statements
+ 1/1
+
+
+
+
+ 100%
+ Branches
+ 0/0
+
+
+
+
+ 100%
+ Functions
+ 0/0
+
+
+
+
+ 100%
+ Lines
+ 1/1
+
+
+
+
+
+ Press n or j to go to the next uncovered block, b, p or k for the previous block.
+
+
+
+
+
+
+
+ | File |
+ |
+ Statements |
+ |
+ Branches |
+ |
+ Functions |
+ |
+ Lines |
+ |
+
+
+
+ | dummy-data.js |
+
+
+ |
+ 100% |
+ 1/1 |
+ 100% |
+ 0/0 |
+ 100% |
+ 0/0 |
+ 100% |
+ 1/1 |
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/index.html b/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/index.html
new file mode 100644
index 0000000..30d1a00
--- /dev/null
+++ b/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/index.html
@@ -0,0 +1,110 @@
+
+
+
+
+
+ Code coverage report for LoginForm
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 100%
+ Statements
+ 2/2
+
+
+
+
+ 100%
+ Branches
+ 0/0
+
+
+
+
+ 100%
+ Functions
+ 1/1
+
+
+
+
+ 100%
+ Lines
+ 2/2
+
+
+
+
+
+ Press n or j to go to the next uncovered block, b, p or k for the previous block.
+
+
+
+
+
+
+
+ | File |
+ |
+ Statements |
+ |
+ Branches |
+ |
+ Functions |
+ |
+ Lines |
+ |
+
+
+
+ | App.js |
+
+
+ |
+ 100% |
+ 2/2 |
+ 100% |
+ 0/0 |
+ 100% |
+ 1/1 |
+ 100% |
+ 2/2 |
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/navigation/LoginNavigator.js.html b/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/navigation/LoginNavigator.js.html
new file mode 100644
index 0000000..126e0dc
--- /dev/null
+++ b/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/navigation/LoginNavigator.js.html
@@ -0,0 +1,160 @@
+
+
+
+
+
+ Code coverage report for LoginForm/navigation/LoginNavigator.js
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 100%
+ Statements
+ 1/1
+
+
+
+
+ 50%
+ Branches
+ 2/4
+
+
+
+
+ 100%
+ Functions
+ 0/0
+
+
+
+
+ 100%
+ Lines
+ 1/1
+
+
+
+
+
+ Press n or j to go to the next uncovered block, b, p or k for the previous block.
+
+
+
+
+| 1
+2
+3
+4
+5
+6
+7
+8
+9
+10
+11
+12
+13
+14
+15
+16
+17
+18
+19
+20
+21
+22
+23
+24
+25
+26
+27
+28 |
+
+
+
+
+
+
+
+
+
+1x
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ | import { Platform } from 'react-native';
+import { createStackNavigator } from 'react-navigation-stack';
+import { createAppContainer } from 'react-navigation';
+
+import LoginScreen from '../screens/login_flow/LoginScreen';
+import LoginFormScreen from '../screens/login_flow/LoginFormScreen';
+// import MainNavigator from '../navigation/MainNavigator';
+import Colors from '../constants/colors';
+import HomeScreen from '../screens/HomeScreen';
+
+const LoginNavigator = createStackNavigator(
+ {
+ Login: LoginScreen,
+ LoginForm: LoginFormScreen,
+ Home: HomeScreen
+ // Home: MainNavigator
+ },
+ {
+ defaultNavigationOptions: {
+ headerStyle: {
+ backgroundColor: Platform.OS === 'android' ? Colors.primary : 'white'
+ },
+ headerTintColor: Platform.OS === 'android' ? 'white' : Colors.primary
+ }
+ }
+);
+
+export default createAppContainer(LoginNavigator); |
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/navigation/MainNavigator.js.html b/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/navigation/MainNavigator.js.html
new file mode 100644
index 0000000..f6397da
--- /dev/null
+++ b/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/navigation/MainNavigator.js.html
@@ -0,0 +1,142 @@
+
+
+
+
+
+ Code coverage report for LoginForm/navigation/MainNavigator.js
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 0%
+ Statements
+ 0/1
+
+
+
+
+ 0%
+ Branches
+ 0/4
+
+
+
+
+ 100%
+ Functions
+ 0/0
+
+
+
+
+ 0%
+ Lines
+ 0/1
+
+
+
+
+
+ Press n or j to go to the next uncovered block, b, p or k for the previous block.
+
+
+
+
+| 1
+2
+3
+4
+5
+6
+7
+8
+9
+10
+11
+12
+13
+14
+15
+16
+17
+18
+19
+20
+21
+22 |
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ | import { Platform } from 'react-native';
+import { createStackNavigator } from 'react-navigation-stack';
+import { createAppContainer } from 'react-navigation';
+import HomeScreen from '../screens/HomeScreen';
+
+import Colors from '../constants/colors'
+
+const MainNavigator = createStackNavigator(
+ {
+ Home: HomeScreen
+ },
+ {
+ defaultNavigationOptions: {
+ headerStyle: {
+ backgroundColor: Platform.OS === 'android' ? Colors.primary : 'white'
+ },
+ headerTintColor: Platform.OS === 'android' ? 'white' : Colors.primary
+ }
+ }
+);
+
+export default createAppContainer(MainNavigator); |
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/navigation/index.html b/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/navigation/index.html
new file mode 100644
index 0000000..b36d301
--- /dev/null
+++ b/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/navigation/index.html
@@ -0,0 +1,125 @@
+
+
+
+
+
+ Code coverage report for LoginForm/navigation
+
+
+
+
+
+
+
+
+
+
+
All files LoginForm/navigation
+
+
+
+ 50%
+ Statements
+ 1/2
+
+
+
+
+ 25%
+ Branches
+ 2/8
+
+
+
+
+ 100%
+ Functions
+ 0/0
+
+
+
+
+ 50%
+ Lines
+ 1/2
+
+
+
+
+
+ Press n or j to go to the next uncovered block, b, p or k for the previous block.
+
+
+
+
+
+
+
+ | File |
+ |
+ Statements |
+ |
+ Branches |
+ |
+ Functions |
+ |
+ Lines |
+ |
+
+
+
+ | LoginNavigator.js |
+
+
+ |
+ 100% |
+ 1/1 |
+ 50% |
+ 2/4 |
+ 100% |
+ 0/0 |
+ 100% |
+ 1/1 |
+
+
+
+ | MainNavigator.js |
+
+
+ |
+ 0% |
+ 0/1 |
+ 0% |
+ 0/4 |
+ 100% |
+ 0/0 |
+ 0% |
+ 0/1 |
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/screens/HomeScreen.js.html b/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/screens/HomeScreen.js.html
new file mode 100644
index 0000000..d562af2
--- /dev/null
+++ b/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/screens/HomeScreen.js.html
@@ -0,0 +1,121 @@
+
+
+
+
+
+ Code coverage report for LoginForm/screens/HomeScreen.js
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 100%
+ Statements
+ 3/3
+
+
+
+
+ 100%
+ Branches
+ 0/0
+
+
+
+
+ 100%
+ Functions
+ 1/1
+
+
+
+
+ 100%
+ Lines
+ 3/3
+
+
+
+
+
+ Press n or j to go to the next uncovered block, b, p or k for the previous block.
+
+
+
+
+| 1
+2
+3
+4
+5
+6
+7
+8
+9
+10
+11
+12
+13
+14
+15 |
+
+
+2x
+
+1x
+1x
+
+
+
+
+
+
+
+ | import React from 'react';
+import { View, Text } from 'react-native';
+
+const HomeScreen = props => {
+ // let username = props.navigation.getParam('usernameKey');
+ let username = props.username;
+ return (
+ <View>
+ <Text>{username}</Text>
+ </View>
+ );
+}
+
+
+export default HomeScreen; |
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/screens/index.html b/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/screens/index.html
new file mode 100644
index 0000000..856d96f
--- /dev/null
+++ b/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/screens/index.html
@@ -0,0 +1,110 @@
+
+
+
+
+
+ Code coverage report for LoginForm/screens
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 100%
+ Statements
+ 3/3
+
+
+
+
+ 100%
+ Branches
+ 0/0
+
+
+
+
+ 100%
+ Functions
+ 1/1
+
+
+
+
+ 100%
+ Lines
+ 3/3
+
+
+
+
+
+ Press n or j to go to the next uncovered block, b, p or k for the previous block.
+
+
+
+
+
+
+
+ | File |
+ |
+ Statements |
+ |
+ Branches |
+ |
+ Functions |
+ |
+ Lines |
+ |
+
+
+
+ | HomeScreen.js |
+
+
+ |
+ 100% |
+ 3/3 |
+ 100% |
+ 0/0 |
+ 100% |
+ 1/1 |
+ 100% |
+ 3/3 |
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/screens/login_flow/LoginFormScreen.js.html b/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/screens/login_flow/LoginFormScreen.js.html
new file mode 100644
index 0000000..8de915a
--- /dev/null
+++ b/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/screens/login_flow/LoginFormScreen.js.html
@@ -0,0 +1,334 @@
+
+
+
+
+
+ Code coverage report for LoginForm/screens/login_flow/LoginFormScreen.js
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 4%
+ Statements
+ 1/25
+
+
+
+
+ 0%
+ Branches
+ 0/4
+
+
+
+
+ 0%
+ Functions
+ 0/9
+
+
+
+
+ 4%
+ Lines
+ 1/25
+
+
+
+
+
+ Press n or j to go to the next uncovered block, b, p or k for the previous block.
+
+
+
+
+| 1
+2
+3
+4
+5
+6
+7
+8
+9
+10
+11
+12
+13
+14
+15
+16
+17
+18
+19
+20
+21
+22
+23
+24
+25
+26
+27
+28
+29
+30
+31
+32
+33
+34
+35
+36
+37
+38
+39
+40
+41
+42
+43
+44
+45
+46
+47
+48
+49
+50
+51
+52
+53
+54
+55
+56
+57
+58
+59
+60
+61
+62
+63
+64
+65
+66
+67
+68
+69
+70
+71
+72
+73
+74
+75
+76
+77
+78
+79
+80
+81
+82
+83
+84
+85
+86 |
+
+
+
+
+
+
+1x
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ | import React, { useState } from 'react';
+import { View, Alert } from 'react-native';
+import Input from '../../components/Input';
+import DefaultStyles from '../../constants/default-styles';
+import MainButton from '../../components/MainButton';
+import { USERS } from '../../data/dummy-data';
+
+const LoginFormScreen = props => {
+ const [username, setUsername] = useState('');
+ const [password, setPassword] = useState('');
+
+ const usernameInputHandler = usernameInputText => {
+ setUsername(usernameInputText);
+ }
+
+ const passwordInputHandler = passwordInputText => {
+ setPassword(passwordInputText);
+ }
+
+ const resetInputHandler = () => {
+ setUsername('')
+ setPassword('')
+ }
+
+ const attemptLogin = () => {
+ if (checkIfUserExists(username)) {
+ if (checkPasswordMatches(password)) {
+ openNextScreen();
+ return;
+ }
+ }
+ displayLoginError();
+ }
+
+ const checkIfUserExists = () => {
+ return USERS[username] !== undefined
+ }
+
+ const checkPasswordMatches = () => {
+ return USERS[username] === password
+ }
+
+ const displayLoginError = () => {
+ Alert.alert(
+ 'Invalid!',
+ 'The username/password is incorrect',
+ [{ text: 'Okay', style: 'destructive', onPress: resetInputHandler }]
+ );
+ }
+
+ const openNextScreen = () => {
+ props.navigation.navigate({
+ routeName: 'Home',
+ params: {
+ usernameKey: username
+ }
+
+ })
+ }
+
+ return (
+ <View>
+ <Input
+ style={DefaultStyles.input}
+ value={username}
+ autoCapitalize="none"
+ onChangeText={usernameInputHandler}
+ autoCorrect={false}
+ maxLength={20}
+ />
+ <Input
+ style={DefaultStyles.input}
+ blurOnSubmit
+ keyboardType="visible-password"
+ value={password}
+ autoCapitalize="none"
+ onChangeText={passwordInputHandler}
+ autoCorrect={false}
+ maxLength={20}
+ />
+ <MainButton onPress={attemptLogin}>Log In</MainButton>
+ </View>
+ )
+}
+
+export default LoginFormScreen; |
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/screens/login_flow/LoginScreen.js.html b/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/screens/login_flow/LoginScreen.js.html
new file mode 100644
index 0000000..014175d
--- /dev/null
+++ b/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/screens/login_flow/LoginScreen.js.html
@@ -0,0 +1,127 @@
+
+
+
+
+
+ Code coverage report for LoginForm/screens/login_flow/LoginScreen.js
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 66.67%
+ Statements
+ 2/3
+
+
+
+
+ 100%
+ Branches
+ 0/0
+
+
+
+
+ 50%
+ Functions
+ 1/2
+
+
+
+
+ 66.67%
+ Lines
+ 2/3
+
+
+
+
+
+ Press n or j to go to the next uncovered block, b, p or k for the previous block.
+
+
+
+
+| 1
+2
+3
+4
+5
+6
+7
+8
+9
+10
+11
+12
+13
+14
+15
+16
+17 |
+
+
+1x
+2x
+
+
+
+
+
+
+
+
+
+
+
+ | import React from 'react';
+import { View, Button } from 'react-native';
+
+const LoginScreen = props => {
+ return (
+ <View>
+ <Button
+ title="Log In"
+ onPress={() => {
+ props.navigation.navigate('LoginForm')
+ }}
+ />
+ </View>
+ )
+}
+
+export default LoginScreen; |
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/screens/login_flow/index.html b/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/screens/login_flow/index.html
new file mode 100644
index 0000000..e7b7f94
--- /dev/null
+++ b/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/LoginForm/screens/login_flow/index.html
@@ -0,0 +1,125 @@
+
+
+
+
+
+ Code coverage report for LoginForm/screens/login_flow
+
+
+
+
+
+
+
+
+
+
+
All files LoginForm/screens/login_flow
+
+
+
+ 10.71%
+ Statements
+ 3/28
+
+
+
+
+ 0%
+ Branches
+ 0/4
+
+
+
+
+ 9.09%
+ Functions
+ 1/11
+
+
+
+
+ 10.71%
+ Lines
+ 3/28
+
+
+
+
+
+ Press n or j to go to the next uncovered block, b, p or k for the previous block.
+
+
+
+
+
+
+
+ | File |
+ |
+ Statements |
+ |
+ Branches |
+ |
+ Functions |
+ |
+ Lines |
+ |
+
+
+
+ | LoginFormScreen.js |
+
+
+ |
+ 4% |
+ 1/25 |
+ 0% |
+ 0/4 |
+ 0% |
+ 0/9 |
+ 4% |
+ 1/25 |
+
+
+
+ | LoginScreen.js |
+
+
+ |
+ 66.67% |
+ 2/3 |
+ 100% |
+ 0/0 |
+ 50% |
+ 1/2 |
+ 66.67% |
+ 2/3 |
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/base.css b/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/base.css
new file mode 100644
index 0000000..f418035
--- /dev/null
+++ b/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/base.css
@@ -0,0 +1,224 @@
+body, html {
+ margin:0; padding: 0;
+ height: 100%;
+}
+body {
+ font-family: Helvetica Neue, Helvetica, Arial;
+ font-size: 14px;
+ color:#333;
+}
+.small { font-size: 12px; }
+*, *:after, *:before {
+ -webkit-box-sizing:border-box;
+ -moz-box-sizing:border-box;
+ box-sizing:border-box;
+ }
+h1 { font-size: 20px; margin: 0;}
+h2 { font-size: 14px; }
+pre {
+ font: 12px/1.4 Consolas, "Liberation Mono", Menlo, Courier, monospace;
+ margin: 0;
+ padding: 0;
+ -moz-tab-size: 2;
+ -o-tab-size: 2;
+ tab-size: 2;
+}
+a { color:#0074D9; text-decoration:none; }
+a:hover { text-decoration:underline; }
+.strong { font-weight: bold; }
+.space-top1 { padding: 10px 0 0 0; }
+.pad2y { padding: 20px 0; }
+.pad1y { padding: 10px 0; }
+.pad2x { padding: 0 20px; }
+.pad2 { padding: 20px; }
+.pad1 { padding: 10px; }
+.space-left2 { padding-left:55px; }
+.space-right2 { padding-right:20px; }
+.center { text-align:center; }
+.clearfix { display:block; }
+.clearfix:after {
+ content:'';
+ display:block;
+ height:0;
+ clear:both;
+ visibility:hidden;
+ }
+.fl { float: left; }
+@media only screen and (max-width:640px) {
+ .col3 { width:100%; max-width:100%; }
+ .hide-mobile { display:none!important; }
+}
+
+.quiet {
+ color: #7f7f7f;
+ color: rgba(0,0,0,0.5);
+}
+.quiet a { opacity: 0.7; }
+
+.fraction {
+ font-family: Consolas, 'Liberation Mono', Menlo, Courier, monospace;
+ font-size: 10px;
+ color: #555;
+ background: #E8E8E8;
+ padding: 4px 5px;
+ border-radius: 3px;
+ vertical-align: middle;
+}
+
+div.path a:link, div.path a:visited { color: #333; }
+table.coverage {
+ border-collapse: collapse;
+ margin: 10px 0 0 0;
+ padding: 0;
+}
+
+table.coverage td {
+ margin: 0;
+ padding: 0;
+ vertical-align: top;
+}
+table.coverage td.line-count {
+ text-align: right;
+ padding: 0 5px 0 20px;
+}
+table.coverage td.line-coverage {
+ text-align: right;
+ padding-right: 10px;
+ min-width:20px;
+}
+
+table.coverage td span.cline-any {
+ display: inline-block;
+ padding: 0 5px;
+ width: 100%;
+}
+.missing-if-branch {
+ display: inline-block;
+ margin-right: 5px;
+ border-radius: 3px;
+ position: relative;
+ padding: 0 4px;
+ background: #333;
+ color: yellow;
+}
+
+.skip-if-branch {
+ display: none;
+ margin-right: 10px;
+ position: relative;
+ padding: 0 4px;
+ background: #ccc;
+ color: white;
+}
+.missing-if-branch .typ, .skip-if-branch .typ {
+ color: inherit !important;
+}
+.coverage-summary {
+ border-collapse: collapse;
+ width: 100%;
+}
+.coverage-summary tr { border-bottom: 1px solid #bbb; }
+.keyline-all { border: 1px solid #ddd; }
+.coverage-summary td, .coverage-summary th { padding: 10px; }
+.coverage-summary tbody { border: 1px solid #bbb; }
+.coverage-summary td { border-right: 1px solid #bbb; }
+.coverage-summary td:last-child { border-right: none; }
+.coverage-summary th {
+ text-align: left;
+ font-weight: normal;
+ white-space: nowrap;
+}
+.coverage-summary th.file { border-right: none !important; }
+.coverage-summary th.pct { }
+.coverage-summary th.pic,
+.coverage-summary th.abs,
+.coverage-summary td.pct,
+.coverage-summary td.abs { text-align: right; }
+.coverage-summary td.file { white-space: nowrap; }
+.coverage-summary td.pic { min-width: 120px !important; }
+.coverage-summary tfoot td { }
+
+.coverage-summary .sorter {
+ height: 10px;
+ width: 7px;
+ display: inline-block;
+ margin-left: 0.5em;
+ background: url(sort-arrow-sprite.png) no-repeat scroll 0 0 transparent;
+}
+.coverage-summary .sorted .sorter {
+ background-position: 0 -20px;
+}
+.coverage-summary .sorted-desc .sorter {
+ background-position: 0 -10px;
+}
+.status-line { height: 10px; }
+/* yellow */
+.cbranch-no { background: yellow !important; color: #111; }
+/* dark red */
+.red.solid, .status-line.low, .low .cover-fill { background:#C21F39 }
+.low .chart { border:1px solid #C21F39 }
+.highlighted,
+.highlighted .cstat-no, .highlighted .fstat-no, .highlighted .cbranch-no{
+ background: #C21F39 !important;
+}
+/* medium red */
+.cstat-no, .fstat-no, .cbranch-no, .cbranch-no { background:#F6C6CE }
+/* light red */
+.low, .cline-no { background:#FCE1E5 }
+/* light green */
+.high, .cline-yes { background:rgb(230,245,208) }
+/* medium green */
+.cstat-yes { background:rgb(161,215,106) }
+/* dark green */
+.status-line.high, .high .cover-fill { background:rgb(77,146,33) }
+.high .chart { border:1px solid rgb(77,146,33) }
+/* dark yellow (gold) */
+.status-line.medium, .medium .cover-fill { background: #f9cd0b; }
+.medium .chart { border:1px solid #f9cd0b; }
+/* light yellow */
+.medium { background: #fff4c2; }
+
+.cstat-skip { background: #ddd; color: #111; }
+.fstat-skip { background: #ddd; color: #111 !important; }
+.cbranch-skip { background: #ddd !important; color: #111; }
+
+span.cline-neutral { background: #eaeaea; }
+
+.coverage-summary td.empty {
+ opacity: .5;
+ padding-top: 4px;
+ padding-bottom: 4px;
+ line-height: 1;
+ color: #888;
+}
+
+.cover-fill, .cover-empty {
+ display:inline-block;
+ height: 12px;
+}
+.chart {
+ line-height: 0;
+}
+.cover-empty {
+ background: white;
+}
+.cover-full {
+ border-right: none !important;
+}
+pre.prettyprint {
+ border: none !important;
+ padding: 0 !important;
+ margin: 0 !important;
+}
+.com { color: #999 !important; }
+.ignore-none { color: #999; font-weight: normal; }
+
+.wrapper {
+ min-height: 100%;
+ height: auto !important;
+ height: 100%;
+ margin: 0 auto -48px;
+}
+.footer, .push {
+ height: 48px;
+}
diff --git a/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/block-navigation.js b/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/block-navigation.js
new file mode 100644
index 0000000..c7ff5a5
--- /dev/null
+++ b/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/block-navigation.js
@@ -0,0 +1,79 @@
+/* eslint-disable */
+var jumpToCode = (function init() {
+ // Classes of code we would like to highlight in the file view
+ var missingCoverageClasses = ['.cbranch-no', '.cstat-no', '.fstat-no'];
+
+ // Elements to highlight in the file listing view
+ var fileListingElements = ['td.pct.low'];
+
+ // We don't want to select elements that are direct descendants of another match
+ var notSelector = ':not(' + missingCoverageClasses.join('):not(') + ') > '; // becomes `:not(a):not(b) > `
+
+ // Selecter that finds elements on the page to which we can jump
+ var selector =
+ fileListingElements.join(', ') +
+ ', ' +
+ notSelector +
+ missingCoverageClasses.join(', ' + notSelector); // becomes `:not(a):not(b) > a, :not(a):not(b) > b`
+
+ // The NodeList of matching elements
+ var missingCoverageElements = document.querySelectorAll(selector);
+
+ var currentIndex;
+
+ function toggleClass(index) {
+ missingCoverageElements
+ .item(currentIndex)
+ .classList.remove('highlighted');
+ missingCoverageElements.item(index).classList.add('highlighted');
+ }
+
+ function makeCurrent(index) {
+ toggleClass(index);
+ currentIndex = index;
+ missingCoverageElements.item(index).scrollIntoView({
+ behavior: 'smooth',
+ block: 'center',
+ inline: 'center'
+ });
+ }
+
+ function goToPrevious() {
+ var nextIndex = 0;
+ if (typeof currentIndex !== 'number' || currentIndex === 0) {
+ nextIndex = missingCoverageElements.length - 1;
+ } else if (missingCoverageElements.length > 1) {
+ nextIndex = currentIndex - 1;
+ }
+
+ makeCurrent(nextIndex);
+ }
+
+ function goToNext() {
+ var nextIndex = 0;
+
+ if (
+ typeof currentIndex === 'number' &&
+ currentIndex < missingCoverageElements.length - 1
+ ) {
+ nextIndex = currentIndex + 1;
+ }
+
+ makeCurrent(nextIndex);
+ }
+
+ return function jump(event) {
+ switch (event.which) {
+ case 78: // n
+ case 74: // j
+ goToNext();
+ break;
+ case 66: // b
+ case 75: // k
+ case 80: // p
+ goToPrevious();
+ break;
+ }
+ };
+})();
+window.addEventListener('keydown', jumpToCode);
diff --git a/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/index.html b/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/index.html
new file mode 100644
index 0000000..88c25e5
--- /dev/null
+++ b/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/index.html
@@ -0,0 +1,200 @@
+
+
+
+
+
+ Code coverage report for All files
+
+
+
+
+
+
+
+
+
+
+
All files
+
+
+
+ 29.27%
+ Statements
+ 12/41
+
+
+
+
+ 18.75%
+ Branches
+ 3/16
+
+
+
+
+ 20%
+ Functions
+ 3/15
+
+
+
+
+ 29.27%
+ Lines
+ 12/41
+
+
+
+
+
+ Press n or j to go to the next uncovered block, b, p or k for the previous block.
+
+
+
+
+
+
+
+ | File |
+ |
+ Statements |
+ |
+ Branches |
+ |
+ Functions |
+ |
+ Lines |
+ |
+
+
+
+ | LoginForm |
+
+
+ |
+ 100% |
+ 2/2 |
+ 100% |
+ 0/0 |
+ 100% |
+ 1/1 |
+ 100% |
+ 2/2 |
+
+
+
+ | LoginForm/components |
+
+
+ |
+ 40% |
+ 2/5 |
+ 0% |
+ 0/2 |
+ 0% |
+ 0/2 |
+ 40% |
+ 2/5 |
+
+
+
+ | LoginForm/constants |
+
+
+ |
+ 0% |
+ 0/0 |
+ 0% |
+ 1/2 |
+ 0% |
+ 0/0 |
+ 0% |
+ 0/0 |
+
+
+
+ | LoginForm/data |
+
+
+ |
+ 100% |
+ 1/1 |
+ 100% |
+ 0/0 |
+ 100% |
+ 0/0 |
+ 100% |
+ 1/1 |
+
+
+
+ | LoginForm/navigation |
+
+
+ |
+ 50% |
+ 1/2 |
+ 25% |
+ 2/8 |
+ 100% |
+ 0/0 |
+ 50% |
+ 1/2 |
+
+
+
+ | LoginForm/screens |
+
+
+ |
+ 100% |
+ 3/3 |
+ 100% |
+ 0/0 |
+ 100% |
+ 1/1 |
+ 100% |
+ 3/3 |
+
+
+
+ | LoginForm/screens/login_flow |
+
+
+ |
+ 10.71% |
+ 3/28 |
+ 0% |
+ 0/4 |
+ 9.09% |
+ 1/11 |
+ 10.71% |
+ 3/28 |
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/prettify.css b/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/prettify.css
new file mode 100644
index 0000000..b317a7c
--- /dev/null
+++ b/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/prettify.css
@@ -0,0 +1 @@
+.pln{color:#000}@media screen{.str{color:#080}.kwd{color:#008}.com{color:#800}.typ{color:#606}.lit{color:#066}.pun,.opn,.clo{color:#660}.tag{color:#008}.atn{color:#606}.atv{color:#080}.dec,.var{color:#606}.fun{color:red}}@media print,projection{.str{color:#060}.kwd{color:#006;font-weight:bold}.com{color:#600;font-style:italic}.typ{color:#404;font-weight:bold}.lit{color:#044}.pun,.opn,.clo{color:#440}.tag{color:#006;font-weight:bold}.atn{color:#404}.atv{color:#060}}pre.prettyprint{padding:2px;border:1px solid #888}ol.linenums{margin-top:0;margin-bottom:0}li.L0,li.L1,li.L2,li.L3,li.L5,li.L6,li.L7,li.L8{list-style-type:none}li.L1,li.L3,li.L5,li.L7,li.L9{background:#eee}
diff --git a/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/prettify.js b/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/prettify.js
new file mode 100644
index 0000000..b322523
--- /dev/null
+++ b/joseGarcia/CodeChallenges/LoginForm/coverage/lcov-report/prettify.js
@@ -0,0 +1,2 @@
+/* eslint-disable */
+window.PR_SHOULD_USE_CONTINUATION=true;(function(){var h=["break,continue,do,else,for,if,return,while"];var u=[h,"auto,case,char,const,default,double,enum,extern,float,goto,int,long,register,short,signed,sizeof,static,struct,switch,typedef,union,unsigned,void,volatile"];var p=[u,"catch,class,delete,false,import,new,operator,private,protected,public,this,throw,true,try,typeof"];var l=[p,"alignof,align_union,asm,axiom,bool,concept,concept_map,const_cast,constexpr,decltype,dynamic_cast,explicit,export,friend,inline,late_check,mutable,namespace,nullptr,reinterpret_cast,static_assert,static_cast,template,typeid,typename,using,virtual,where"];var x=[p,"abstract,boolean,byte,extends,final,finally,implements,import,instanceof,null,native,package,strictfp,super,synchronized,throws,transient"];var R=[x,"as,base,by,checked,decimal,delegate,descending,dynamic,event,fixed,foreach,from,group,implicit,in,interface,internal,into,is,lock,object,out,override,orderby,params,partial,readonly,ref,sbyte,sealed,stackalloc,string,select,uint,ulong,unchecked,unsafe,ushort,var"];var r="all,and,by,catch,class,else,extends,false,finally,for,if,in,is,isnt,loop,new,no,not,null,of,off,on,or,return,super,then,true,try,unless,until,when,while,yes";var w=[p,"debugger,eval,export,function,get,null,set,undefined,var,with,Infinity,NaN"];var s="caller,delete,die,do,dump,elsif,eval,exit,foreach,for,goto,if,import,last,local,my,next,no,our,print,package,redo,require,sub,undef,unless,until,use,wantarray,while,BEGIN,END";var I=[h,"and,as,assert,class,def,del,elif,except,exec,finally,from,global,import,in,is,lambda,nonlocal,not,or,pass,print,raise,try,with,yield,False,True,None"];var f=[h,"alias,and,begin,case,class,def,defined,elsif,end,ensure,false,in,module,next,nil,not,or,redo,rescue,retry,self,super,then,true,undef,unless,until,when,yield,BEGIN,END"];var H=[h,"case,done,elif,esac,eval,fi,function,in,local,set,then,until"];var A=[l,R,w,s+I,f,H];var e=/^(DIR|FILE|vector|(de|priority_)?queue|list|stack|(const_)?iterator|(multi)?(set|map)|bitset|u?(int|float)\d*)/;var C="str";var z="kwd";var j="com";var O="typ";var G="lit";var L="pun";var F="pln";var m="tag";var E="dec";var J="src";var P="atn";var n="atv";var N="nocode";var M="(?:^^\\.?|[+-]|\\!|\\!=|\\!==|\\#|\\%|\\%=|&|&&|&&=|&=|\\(|\\*|\\*=|\\+=|\\,|\\-=|\\->|\\/|\\/=|:|::|\\;|<|<<|<<=|<=|=|==|===|>|>=|>>|>>=|>>>|>>>=|\\?|\\@|\\[|\\^|\\^=|\\^\\^|\\^\\^=|\\{|\\||\\|=|\\|\\||\\|\\|=|\\~|break|case|continue|delete|do|else|finally|instanceof|return|throw|try|typeof)\\s*";function k(Z){var ad=0;var S=false;var ac=false;for(var V=0,U=Z.length;V122)){if(!(al<65||ag>90)){af.push([Math.max(65,ag)|32,Math.min(al,90)|32])}if(!(al<97||ag>122)){af.push([Math.max(97,ag)&~32,Math.min(al,122)&~32])}}}}af.sort(function(av,au){return(av[0]-au[0])||(au[1]-av[1])});var ai=[];var ap=[NaN,NaN];for(var ar=0;arat[0]){if(at[1]+1>at[0]){an.push("-")}an.push(T(at[1]))}}an.push("]");return an.join("")}function W(al){var aj=al.source.match(new RegExp("(?:\\[(?:[^\\x5C\\x5D]|\\\\[\\s\\S])*\\]|\\\\u[A-Fa-f0-9]{4}|\\\\x[A-Fa-f0-9]{2}|\\\\[0-9]+|\\\\[^ux0-9]|\\(\\?[:!=]|[\\(\\)\\^]|[^\\x5B\\x5C\\(\\)\\^]+)","g"));var ah=aj.length;var an=[];for(var ak=0,am=0;ak=2&&ai==="["){aj[ak]=X(ag)}else{if(ai!=="\\"){aj[ak]=ag.replace(/[a-zA-Z]/g,function(ao){var ap=ao.charCodeAt(0);return"["+String.fromCharCode(ap&~32,ap|32)+"]"})}}}}return aj.join("")}var aa=[];for(var V=0,U=Z.length;V=0;){S[ac.charAt(ae)]=Y}}var af=Y[1];var aa=""+af;if(!ag.hasOwnProperty(aa)){ah.push(af);ag[aa]=null}}ah.push(/[\0-\uffff]/);V=k(ah)})();var X=T.length;var W=function(ah){var Z=ah.sourceCode,Y=ah.basePos;var ad=[Y,F];var af=0;var an=Z.match(V)||[];var aj={};for(var ae=0,aq=an.length;ae=5&&"lang-"===ap.substring(0,5);if(am&&!(ai&&typeof ai[1]==="string")){am=false;ap=J}if(!am){aj[ag]=ap}}var ab=af;af+=ag.length;if(!am){ad.push(Y+ab,ap)}else{var al=ai[1];var ak=ag.indexOf(al);var ac=ak+al.length;if(ai[2]){ac=ag.length-ai[2].length;ak=ac-al.length}var ar=ap.substring(5);B(Y+ab,ag.substring(0,ak),W,ad);B(Y+ab+ak,al,q(ar,al),ad);B(Y+ab+ac,ag.substring(ac),W,ad)}}ah.decorations=ad};return W}function i(T){var W=[],S=[];if(T.tripleQuotedStrings){W.push([C,/^(?:\'\'\'(?:[^\'\\]|\\[\s\S]|\'{1,2}(?=[^\']))*(?:\'\'\'|$)|\"\"\"(?:[^\"\\]|\\[\s\S]|\"{1,2}(?=[^\"]))*(?:\"\"\"|$)|\'(?:[^\\\']|\\[\s\S])*(?:\'|$)|\"(?:[^\\\"]|\\[\s\S])*(?:\"|$))/,null,"'\""])}else{if(T.multiLineStrings){W.push([C,/^(?:\'(?:[^\\\']|\\[\s\S])*(?:\'|$)|\"(?:[^\\\"]|\\[\s\S])*(?:\"|$)|\`(?:[^\\\`]|\\[\s\S])*(?:\`|$))/,null,"'\"`"])}else{W.push([C,/^(?:\'(?:[^\\\'\r\n]|\\.)*(?:\'|$)|\"(?:[^\\\"\r\n]|\\.)*(?:\"|$))/,null,"\"'"])}}if(T.verbatimStrings){S.push([C,/^@\"(?:[^\"]|\"\")*(?:\"|$)/,null])}var Y=T.hashComments;if(Y){if(T.cStyleComments){if(Y>1){W.push([j,/^#(?:##(?:[^#]|#(?!##))*(?:###|$)|.*)/,null,"#"])}else{W.push([j,/^#(?:(?:define|elif|else|endif|error|ifdef|include|ifndef|line|pragma|undef|warning)\b|[^\r\n]*)/,null,"#"])}S.push([C,/^<(?:(?:(?:\.\.\/)*|\/?)(?:[\w-]+(?:\/[\w-]+)+)?[\w-]+\.h|[a-z]\w*)>/,null])}else{W.push([j,/^#[^\r\n]*/,null,"#"])}}if(T.cStyleComments){S.push([j,/^\/\/[^\r\n]*/,null]);S.push([j,/^\/\*[\s\S]*?(?:\*\/|$)/,null])}if(T.regexLiterals){var X=("/(?=[^/*])(?:[^/\\x5B\\x5C]|\\x5C[\\s\\S]|\\x5B(?:[^\\x5C\\x5D]|\\x5C[\\s\\S])*(?:\\x5D|$))+/");S.push(["lang-regex",new RegExp("^"+M+"("+X+")")])}var V=T.types;if(V){S.push([O,V])}var U=(""+T.keywords).replace(/^ | $/g,"");if(U.length){S.push([z,new RegExp("^(?:"+U.replace(/[\s,]+/g,"|")+")\\b"),null])}W.push([F,/^\s+/,null," \r\n\t\xA0"]);S.push([G,/^@[a-z_$][a-z_$@0-9]*/i,null],[O,/^(?:[@_]?[A-Z]+[a-z][A-Za-z_$@0-9]*|\w+_t\b)/,null],[F,/^[a-z_$][a-z_$@0-9]*/i,null],[G,new RegExp("^(?:0x[a-f0-9]+|(?:\\d(?:_\\d+)*\\d*(?:\\.\\d*)?|\\.\\d\\+)(?:e[+\\-]?\\d+)?)[a-z]*","i"),null,"0123456789"],[F,/^\\[\s\S]?/,null],[L,/^.[^\s\w\.$@\'\"\`\/\#\\]*/,null]);return g(W,S)}var K=i({keywords:A,hashComments:true,cStyleComments:true,multiLineStrings:true,regexLiterals:true});function Q(V,ag){var U=/(?:^|\s)nocode(?:\s|$)/;var ab=/\r\n?|\n/;var ac=V.ownerDocument;var S;if(V.currentStyle){S=V.currentStyle.whiteSpace}else{if(window.getComputedStyle){S=ac.defaultView.getComputedStyle(V,null).getPropertyValue("white-space")}}var Z=S&&"pre"===S.substring(0,3);var af=ac.createElement("LI");while(V.firstChild){af.appendChild(V.firstChild)}var W=[af];function ae(al){switch(al.nodeType){case 1:if(U.test(al.className)){break}if("BR"===al.nodeName){ad(al);if(al.parentNode){al.parentNode.removeChild(al)}}else{for(var an=al.firstChild;an;an=an.nextSibling){ae(an)}}break;case 3:case 4:if(Z){var am=al.nodeValue;var aj=am.match(ab);if(aj){var ai=am.substring(0,aj.index);al.nodeValue=ai;var ah=am.substring(aj.index+aj[0].length);if(ah){var ak=al.parentNode;ak.insertBefore(ac.createTextNode(ah),al.nextSibling)}ad(al);if(!ai){al.parentNode.removeChild(al)}}}break}}function ad(ak){while(!ak.nextSibling){ak=ak.parentNode;if(!ak){return}}function ai(al,ar){var aq=ar?al.cloneNode(false):al;var ao=al.parentNode;if(ao){var ap=ai(ao,1);var an=al.nextSibling;ap.appendChild(aq);for(var am=an;am;am=an){an=am.nextSibling;ap.appendChild(am)}}return aq}var ah=ai(ak.nextSibling,0);for(var aj;(aj=ah.parentNode)&&aj.nodeType===1;){ah=aj}W.push(ah)}for(var Y=0;Y=S){ah+=2}if(V>=ap){Z+=2}}}var t={};function c(U,V){for(var S=V.length;--S>=0;){var T=V[S];if(!t.hasOwnProperty(T)){t[T]=U}else{if(window.console){console.warn("cannot override language handler %s",T)}}}}function q(T,S){if(!(T&&t.hasOwnProperty(T))){T=/^\s*]*(?:>|$)/],[j,/^<\!--[\s\S]*?(?:-\->|$)/],["lang-",/^<\?([\s\S]+?)(?:\?>|$)/],["lang-",/^<%([\s\S]+?)(?:%>|$)/],[L,/^(?:<[%?]|[%?]>)/],["lang-",/^]*>([\s\S]+?)<\/xmp\b[^>]*>/i],["lang-js",/^