packages = new PackageList(this).getPackages();
27 | // Packages that cannot be autolinked yet can be added manually here, for example:
28 | // packages.add(new MyReactNativePackage());
29 | return packages;
30 | }
31 |
32 | @Override
33 | protected String getJSMainModuleName() {
34 | return "index";
35 | }
36 | };
37 |
38 | @Override
39 | public ReactNativeHost getReactNativeHost() {
40 | return mReactNativeHost;
41 | }
42 |
43 | @Override
44 | public void onCreate() {
45 | super.onCreate();
46 | SoLoader.init(this, /* native exopackage */ false);
47 | initializeFlipper(this, getReactNativeHost().getReactInstanceManager());
48 | }
49 |
50 | /**
51 | * Loads Flipper in React Native templates. Call this in the onCreate method with something like
52 | * initializeFlipper(this, getReactNativeHost().getReactInstanceManager());
53 | *
54 | * @param context
55 | * @param reactInstanceManager
56 | */
57 | private static void initializeFlipper(
58 | Context context, ReactInstanceManager reactInstanceManager) {
59 | if (BuildConfig.DEBUG) {
60 | try {
61 | /*
62 | We use reflection here to pick up the class that initializes Flipper,
63 | since Flipper library is not available in release mode
64 | */
65 | Class> aClass = Class.forName("com.sangeet.ReactNativeFlipper");
66 | aClass
67 | .getMethod("initializeFlipper", Context.class, ReactInstanceManager.class)
68 | .invoke(null, context, reactInstanceManager);
69 | } catch (ClassNotFoundException e) {
70 | e.printStackTrace();
71 | } catch (NoSuchMethodException e) {
72 | e.printStackTrace();
73 | } catch (IllegalAccessException e) {
74 | e.printStackTrace();
75 | } catch (InvocationTargetException e) {
76 | e.printStackTrace();
77 | }
78 | }
79 | }
80 | }
81 |
--------------------------------------------------------------------------------
/gradlew.bat:
--------------------------------------------------------------------------------
1 | @rem
2 | @rem Copyright 2015 the original author or authors.
3 | @rem
4 | @rem Licensed under the Apache License, Version 2.0 (the "License");
5 | @rem you may not use this file except in compliance with the License.
6 | @rem You may obtain a copy of the License at
7 | @rem
8 | @rem https://www.apache.org/licenses/LICENSE-2.0
9 | @rem
10 | @rem Unless required by applicable law or agreed to in writing, software
11 | @rem distributed under the License is distributed on an "AS IS" BASIS,
12 | @rem WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 | @rem See the License for the specific language governing permissions and
14 | @rem limitations under the License.
15 | @rem
16 |
17 | @if "%DEBUG%" == "" @echo off
18 | @rem ##########################################################################
19 | @rem
20 | @rem Gradle startup script for Windows
21 | @rem
22 | @rem ##########################################################################
23 |
24 | @rem Set local scope for the variables with windows NT shell
25 | if "%OS%"=="Windows_NT" setlocal
26 |
27 | set DIRNAME=%~dp0
28 | if "%DIRNAME%" == "" set DIRNAME=.
29 | set APP_BASE_NAME=%~n0
30 | set APP_HOME=%DIRNAME%
31 |
32 | @rem Resolve any "." and ".." in APP_HOME to make it shorter.
33 | for %%i in ("%APP_HOME%") do set APP_HOME=%%~fi
34 |
35 | @rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
36 | set DEFAULT_JVM_OPTS="-Xmx64m" "-Xms64m"
37 |
38 | @rem Find java.exe
39 | if defined JAVA_HOME goto findJavaFromJavaHome
40 |
41 | set JAVA_EXE=java.exe
42 | %JAVA_EXE% -version >NUL 2>&1
43 | if "%ERRORLEVEL%" == "0" goto execute
44 |
45 | echo.
46 | echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
47 | echo.
48 | echo Please set the JAVA_HOME variable in your environment to match the
49 | echo location of your Java installation.
50 |
51 | goto fail
52 |
53 | :findJavaFromJavaHome
54 | set JAVA_HOME=%JAVA_HOME:"=%
55 | set JAVA_EXE=%JAVA_HOME%/bin/java.exe
56 |
57 | if exist "%JAVA_EXE%" goto execute
58 |
59 | echo.
60 | echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME%
61 | echo.
62 | echo Please set the JAVA_HOME variable in your environment to match the
63 | echo location of your Java installation.
64 |
65 | goto fail
66 |
67 | :execute
68 | @rem Setup the command line
69 |
70 | set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar
71 |
72 |
73 | @rem Execute Gradle
74 | "%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %*
75 |
76 | :end
77 | @rem End local scope for the variables with windows NT shell
78 | if "%ERRORLEVEL%"=="0" goto mainEnd
79 |
80 | :fail
81 | rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of
82 | rem the _cmd.exe /c_ return code!
83 | if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1
84 | exit /b 1
85 |
86 | :mainEnd
87 | if "%OS%"=="Windows_NT" endlocal
88 |
89 | :omega
90 |
--------------------------------------------------------------------------------
/android/gradlew.bat:
--------------------------------------------------------------------------------
1 | @rem
2 | @rem Copyright 2015 the original author or authors.
3 | @rem
4 | @rem Licensed under the Apache License, Version 2.0 (the "License");
5 | @rem you may not use this file except in compliance with the License.
6 | @rem You may obtain a copy of the License at
7 | @rem
8 | @rem https://www.apache.org/licenses/LICENSE-2.0
9 | @rem
10 | @rem Unless required by applicable law or agreed to in writing, software
11 | @rem distributed under the License is distributed on an "AS IS" BASIS,
12 | @rem WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 | @rem See the License for the specific language governing permissions and
14 | @rem limitations under the License.
15 | @rem
16 |
17 | @if "%DEBUG%" == "" @echo off
18 | @rem ##########################################################################
19 | @rem
20 | @rem Gradle startup script for Windows
21 | @rem
22 | @rem ##########################################################################
23 |
24 | @rem Set local scope for the variables with windows NT shell
25 | if "%OS%"=="Windows_NT" setlocal
26 |
27 | set DIRNAME=%~dp0
28 | if "%DIRNAME%" == "" set DIRNAME=.
29 | set APP_BASE_NAME=%~n0
30 | set APP_HOME=%DIRNAME%
31 |
32 | @rem Resolve any "." and ".." in APP_HOME to make it shorter.
33 | for %%i in ("%APP_HOME%") do set APP_HOME=%%~fi
34 |
35 | @rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
36 | set DEFAULT_JVM_OPTS="-Xmx64m" "-Xms64m"
37 |
38 | @rem Find java.exe
39 | if defined JAVA_HOME goto findJavaFromJavaHome
40 |
41 | set JAVA_EXE=java.exe
42 | %JAVA_EXE% -version >NUL 2>&1
43 | if "%ERRORLEVEL%" == "0" goto init
44 |
45 | echo.
46 | echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
47 | echo.
48 | echo Please set the JAVA_HOME variable in your environment to match the
49 | echo location of your Java installation.
50 |
51 | goto fail
52 |
53 | :findJavaFromJavaHome
54 | set JAVA_HOME=%JAVA_HOME:"=%
55 | set JAVA_EXE=%JAVA_HOME%/bin/java.exe
56 |
57 | if exist "%JAVA_EXE%" goto init
58 |
59 | echo.
60 | echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME%
61 | echo.
62 | echo Please set the JAVA_HOME variable in your environment to match the
63 | echo location of your Java installation.
64 |
65 | goto fail
66 |
67 | :init
68 | @rem Get command-line arguments, handling Windows variants
69 |
70 | if not "%OS%" == "Windows_NT" goto win9xME_args
71 |
72 | :win9xME_args
73 | @rem Slurp the command line arguments.
74 | set CMD_LINE_ARGS=
75 | set _SKIP=2
76 |
77 | :win9xME_args_slurp
78 | if "x%~1" == "x" goto execute
79 |
80 | set CMD_LINE_ARGS=%*
81 |
82 | :execute
83 | @rem Setup the command line
84 |
85 | set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar
86 |
87 | @rem Execute Gradle
88 | "%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %CMD_LINE_ARGS%
89 |
90 | :end
91 | @rem End local scope for the variables with windows NT shell
92 | if "%ERRORLEVEL%"=="0" goto mainEnd
93 |
94 | :fail
95 | rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of
96 | rem the _cmd.exe /c_ return code!
97 | if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1
98 | exit /b 1
99 |
100 | :mainEnd
101 | if "%OS%"=="Windows_NT" endlocal
102 |
103 | :omega
104 |
--------------------------------------------------------------------------------
/android/app/src/debug/java/com/sangeet/ReactNativeFlipper.java:
--------------------------------------------------------------------------------
1 | /**
2 | * Copyright (c) Facebook, Inc. and its affiliates.
3 | *
4 | * This source code is licensed under the MIT license found in the LICENSE file in the root
5 | * directory of this source tree.
6 | */
7 | package com.sangeet;
8 |
9 | import android.content.Context;
10 | import com.facebook.flipper.android.AndroidFlipperClient;
11 | import com.facebook.flipper.android.utils.FlipperUtils;
12 | import com.facebook.flipper.core.FlipperClient;
13 | import com.facebook.flipper.plugins.crashreporter.CrashReporterPlugin;
14 | import com.facebook.flipper.plugins.databases.DatabasesFlipperPlugin;
15 | import com.facebook.flipper.plugins.fresco.FrescoFlipperPlugin;
16 | import com.facebook.flipper.plugins.inspector.DescriptorMapping;
17 | import com.facebook.flipper.plugins.inspector.InspectorFlipperPlugin;
18 | import com.facebook.flipper.plugins.network.FlipperOkhttpInterceptor;
19 | import com.facebook.flipper.plugins.network.NetworkFlipperPlugin;
20 | import com.facebook.flipper.plugins.react.ReactFlipperPlugin;
21 | import com.facebook.flipper.plugins.sharedpreferences.SharedPreferencesFlipperPlugin;
22 | import com.facebook.react.ReactInstanceManager;
23 | import com.facebook.react.bridge.ReactContext;
24 | import com.facebook.react.modules.network.NetworkingModule;
25 | import okhttp3.OkHttpClient;
26 |
27 | public class ReactNativeFlipper {
28 | public static void initializeFlipper(Context context, ReactInstanceManager reactInstanceManager) {
29 | if (FlipperUtils.shouldEnableFlipper(context)) {
30 | final FlipperClient client = AndroidFlipperClient.getInstance(context);
31 |
32 | client.addPlugin(new InspectorFlipperPlugin(context, DescriptorMapping.withDefaults()));
33 | client.addPlugin(new ReactFlipperPlugin());
34 | client.addPlugin(new DatabasesFlipperPlugin(context));
35 | client.addPlugin(new SharedPreferencesFlipperPlugin(context));
36 | client.addPlugin(CrashReporterPlugin.getInstance());
37 |
38 | NetworkFlipperPlugin networkFlipperPlugin = new NetworkFlipperPlugin();
39 | NetworkingModule.setCustomClientBuilder(
40 | new NetworkingModule.CustomClientBuilder() {
41 | @Override
42 | public void apply(OkHttpClient.Builder builder) {
43 | builder.addNetworkInterceptor(new FlipperOkhttpInterceptor(networkFlipperPlugin));
44 | }
45 | });
46 | client.addPlugin(networkFlipperPlugin);
47 | client.start();
48 |
49 | // Fresco Plugin needs to ensure that ImagePipelineFactory is initialized
50 | // Hence we run if after all native modules have been initialized
51 | ReactContext reactContext = reactInstanceManager.getCurrentReactContext();
52 | if (reactContext == null) {
53 | reactInstanceManager.addReactInstanceEventListener(
54 | new ReactInstanceManager.ReactInstanceEventListener() {
55 | @Override
56 | public void onReactContextInitialized(ReactContext reactContext) {
57 | reactInstanceManager.removeReactInstanceEventListener(this);
58 | reactContext.runOnNativeModulesQueueThread(
59 | new Runnable() {
60 | @Override
61 | public void run() {
62 | client.addPlugin(new FrescoFlipperPlugin());
63 | }
64 | });
65 | }
66 | });
67 | } else {
68 | client.addPlugin(new FrescoFlipperPlugin());
69 | }
70 | }
71 | }
72 | }
73 |
--------------------------------------------------------------------------------
/screens/SongsListScreen.js:
--------------------------------------------------------------------------------
1 | import React, {useCallback} from 'react';
2 | import {View, Text, StyleSheet, Image, Dimensions} from 'react-native';
3 | import {ScrollView, FlatList} from 'react-native-gesture-handler';
4 | import {useSelector, useDispatch} from 'react-redux';
5 | import Ionicons from 'react-native-vector-icons/Ionicons';
6 |
7 | import {toggleFavourite} from '../store/actions/songsActions';
8 |
9 | import {
10 | CLASSICS,
11 | DANCE,
12 | GENRES,
13 | ROCKON,
14 | ROM,
15 | SOOTHING,
16 | WORKOUT,
17 | } from '../components/data';
18 | import SongItem from '../components/SongItem';
19 | import Colors from '../components/Colors';
20 |
21 | const {width, height} = Dimensions.get('window');
22 |
23 | const SongsListScreen = (props) => {
24 | const gid = props.navigation.getParam('gid');//getting the genre passed as param
25 |
26 | const displayedGenre = GENRES.find((genre) => genre.id === gid); //finding the genre by the id whose songs are going to be displayed
27 |
28 | let arr = [{}];
29 | if (gid === '1') {
30 | arr = ROM;
31 | } else if (gid === '2') {
32 | arr = SOOTHING;
33 | } else if (gid === '3') {
34 | arr = ROCKON;
35 | } else if (gid === '4') {
36 | arr = CLASSICS;
37 | } else if (gid === '5') {
38 | arr = WORKOUT;
39 | } else if (gid === '6') {
40 | arr = DANCE;
41 | }
42 |
43 | const displayedSongs = arr.filter((song) => song.genre.indexOf(gid) >= 0); //filter out the songs of the same genre,
44 | // not needed though coz arr also contains the songs of the required genre
45 |
46 | const renderSongItem = ({item, index}) => {
47 | return (
48 |
53 | props.navigation.navigate('SongsPlay', {
54 | sid: item.id,
55 | gid: item.genre,
56 | })
57 | }
58 | onLike={() => {}}
59 | />
60 | );
61 | };
62 |
63 | return (
64 |
65 | props.navigation.goBack()}
70 | />
71 |
72 |
73 |
74 |
78 |
79 | {displayedGenre.title}
80 |
81 |
82 |
83 |
84 |
85 |
86 | );
87 | };
88 |
89 | const styles = StyleSheet.create({
90 | screen: {
91 | flex: 1,
92 | padding: height/75,
93 | backgroundColor: 'black',
94 | },
95 | genreContainer: {
96 | paddingHorizontal: height/10.7,
97 | paddingTop: height/20,
98 | paddingBottom: height/18.7,
99 | },
100 | genreImage: {
101 | borderRadius: height/5,
102 | overflow: 'hidden',
103 | },
104 |
105 | genreTitle: {
106 | paddingTop: height/75,
107 | fontSize: height/25,
108 | fontWeight: 'bold',
109 | textAlign: 'center',
110 | color: 'white',
111 | },
112 | listContainer: {
113 | padding: height/75,
114 | },
115 | });
116 |
117 | export default SongsListScreen;
118 |
--------------------------------------------------------------------------------
/ios/Sangeet.xcodeproj/xcshareddata/xcschemes/Sangeet.xcscheme:
--------------------------------------------------------------------------------
1 |
2 |
5 |
8 |
9 |
15 |
21 |
22 |
23 |
24 |
25 |
30 |
31 |
33 |
39 |
40 |
41 |
42 |
43 |
53 |
55 |
61 |
62 |
63 |
64 |
70 |
72 |
78 |
79 |
80 |
81 |
83 |
84 |
87 |
88 |
89 |
--------------------------------------------------------------------------------
/screens/HomeScreen.js:
--------------------------------------------------------------------------------
1 | import React from 'react';
2 | import {View, Text, StyleSheet, Dimensions, FlatList} from 'react-native';
3 | import {ScrollView, TouchableOpacity} from 'react-native-gesture-handler';
4 |
5 | import {GENRES, SONGS} from '../components/data';
6 | import GenreGrid from '../components/GenreGrid';
7 | import Recomm from '../components/Recomm';
8 |
9 | const {width, height} = Dimensions.get('window');
10 |
11 | const HomeScreen = (props) => {
12 | const renderGenreItem = ({item, index}) => {
13 | return (
14 | {
18 | props.navigation.navigate('SongsList', {gid: item.id}); //passing the id of genre as params to view its songs in the next screens
19 | }}
20 | />
21 | );
22 | };
23 |
24 | const renderSongItem = ({item, index}) => {
25 | return (
26 |
31 | props.navigation.navigate('SongsPlay', {
32 | sid: item.id,
33 | gid: item.genre,
34 | })
35 | }
36 | />
37 | );
38 | };
39 |
40 | return (
41 |
42 |
43 |
44 | Namaste!
45 | {/* {
47 | props.navigation.navigate('Search');//added just for test purpose
48 | }}>
49 | Search
50 | */}
51 |
52 | Choose your favourite genre!
53 |
54 |
55 | item.id}
57 | key={GENRES} //new thing, Changing numColumns on the fly is not supported. Change the key prop on FlatList when changing the number of columns to force a fresh render of the component.
58 | data={GENRES}
59 | renderItem={renderGenreItem}
60 | numColumns={2}
61 | />
62 |
63 |
64 | English Tracks
65 |
71 |
72 |
73 |
74 | );
75 | };
76 |
77 | const styles = StyleSheet.create({
78 | welcome: {
79 | padding: height / 37,
80 | },
81 | header: {
82 | color: 'white',
83 | fontSize: height / 25,
84 | paddingBottom: height / 37,
85 | paddingTop: height / 50,
86 | paddingLeft: width / 25,
87 | fontWeight: 'bold',
88 | },
89 | subHeader: {
90 | fontSize: height / 41,
91 | color: 'gray',
92 | paddingBottom: height / 75,
93 | paddingLeft: width / 25,
94 | fontWeight: 'bold',
95 | },
96 | listOfGenres: {
97 | flex: 1,
98 | marginBottom: height / 37,
99 | },
100 |
101 | recomm: {
102 | padding: height / 75,
103 | height: height / 2,
104 | },
105 | recommText: {
106 | color: 'gray',
107 | fontSize: height / 41,
108 | marginBottom: height / 50,
109 | fontWeight: 'bold',
110 | },
111 | });
112 |
113 | export default HomeScreen;
114 |
--------------------------------------------------------------------------------
/ios/Sangeet.xcodeproj/xcshareddata/xcschemes/Sangeet-tvOS.xcscheme:
--------------------------------------------------------------------------------
1 |
2 |
5 |
8 |
9 |
15 |
21 |
22 |
23 |
24 |
25 |
30 |
31 |
33 |
39 |
40 |
41 |
42 |
43 |
53 |
55 |
61 |
62 |
63 |
64 |
70 |
72 |
78 |
79 |
80 |
81 |
83 |
84 |
87 |
88 |
89 |
--------------------------------------------------------------------------------
/navigation/SongsNavigator.js:
--------------------------------------------------------------------------------
1 | import React from 'react';
2 | import {createAppContainer} from 'react-navigation';
3 | import {createStackNavigator} from 'react-navigation-stack';
4 | import {createBottomTabNavigator} from 'react-navigation-tabs';
5 | import {createMaterialBottomTabNavigator} from 'react-navigation-material-bottom-tabs';
6 | import {Platform, Text} from 'react-native';
7 |
8 | import HomeScreen from '../screens/HomeScreen';
9 | import FavouritesScreen from '../screens/FavouritesScreen';
10 | import SongsListScreen from '../screens/SongsListScreen';
11 | import SongsPlayScreen from '../screens/SongsPlayScreen';
12 | import SearchScreen from '../screens/SearchScreen';
13 |
14 | import MaterialIcons from 'react-native-vector-icons/MaterialIcons';
15 | import EvilIcons from 'react-native-vector-icons/EvilIcons';
16 | import Ionicons from 'react-native-vector-icons/Ionicons';
17 |
18 | import Colors from '../components/Colors';
19 |
20 | const AllSongsNavigator = createStackNavigator(
21 | {
22 | Home: HomeScreen,
23 | SongsList: SongsListScreen,
24 | SongsPlay: SongsPlayScreen,
25 | },
26 | {
27 | defaultNavigationOptions: {
28 | headerShown: false,
29 | },
30 | },
31 | );
32 |
33 | const FavSongsNavigator = createStackNavigator(
34 | {
35 | Fav: FavouritesScreen,
36 | SongsPlay: SongsPlayScreen,
37 | },
38 | {
39 | defaultNavigationOptions: {
40 | headerShown: false,
41 | },
42 | },
43 | );
44 |
45 | const Searchnavigator = createStackNavigator(
46 | {
47 | Search: SearchScreen,
48 | },
49 | {
50 | defaultNavigationOptions: {
51 | headerShown: false,
52 | },
53 | },
54 | );
55 |
56 | const tabScreenConfig = {
57 | All: {
58 | screen: AllSongsNavigator,
59 | navigationOptions: {
60 | tabBarIcon: (tabInfo) => {
61 | return ;
62 | },
63 | tabBarColor: '#282828',
64 | tabBarLabel: Platform.OS === 'android' ? Home : 'Home',
65 | },
66 | },
67 | SearchIcon: {
68 | screen: Searchnavigator,
69 | navigationOptions: {
70 | tabBarIcon: (tabInfo) => {
71 | return ;
72 | },
73 | tabBarColor: '#282828',
74 | tabBarLabel: Platform.OS === 'android' ? Search : 'Search',
75 | },
76 | },
77 | Favourites: {
78 | screen: FavSongsNavigator,
79 | navigationOptions: {
80 | tabBarIcon: (tabInfo) => {
81 | return ;
82 | },
83 | tabBarColor: '#282828',
84 | tabBarLabel:
85 | Platform.OS === 'android' ? Favourites : 'Favourites',
86 | },
87 | },
88 | };
89 |
90 | const SongsNavigator =
91 | Platform.OS === 'android'
92 | ? createMaterialBottomTabNavigator(tabScreenConfig, {
93 | //for android like effect
94 | activeColor: Colors.primary,
95 | inactiveColor: '#a6a6a6',
96 | shifting: true,
97 | })
98 | : createBottomTabNavigator(tabScreenConfig, {
99 | //for ios like effect
100 | tabBarOptions: {
101 | inactiveBackgroundColor: Colors.accent,
102 | activeBackgroundColor: Colors.primary,
103 | activeTintColor: Colors.primary,
104 | inactiveTintColor: 'rgba( 10, 10, 10, 0.6)', //temporary colors
105 | tabStyle: {
106 | borderColor: '#a6a6a6',
107 | borderWidth: 1,
108 | },
109 | /* labelStyle: {
110 | fontFamily: 'open-sans',
111 | }, */
112 | },
113 | });
114 |
115 | export default createAppContainer(SongsNavigator);
116 |
--------------------------------------------------------------------------------
/ios/Sangeet/LaunchScreen.storyboard:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
7 |
8 |
9 |
10 |
11 |
12 |
13 |
14 |
15 |
16 |
17 |
18 |
19 |
25 |
31 |
37 |
38 |
39 |
40 |
41 |
42 |
43 |
44 |
45 |
46 |
47 |
48 |
49 |
50 |
51 |
52 |
53 |
54 |
55 |
56 |
57 |
58 |
59 |
--------------------------------------------------------------------------------
/android/gradlew:
--------------------------------------------------------------------------------
1 | #!/usr/bin/env sh
2 |
3 | #
4 | # Copyright 2015 the original author or authors.
5 | #
6 | # Licensed under the Apache License, Version 2.0 (the "License");
7 | # you may not use this file except in compliance with the License.
8 | # You may obtain a copy of the License at
9 | #
10 | # https://www.apache.org/licenses/LICENSE-2.0
11 | #
12 | # Unless required by applicable law or agreed to in writing, software
13 | # distributed under the License is distributed on an "AS IS" BASIS,
14 | # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15 | # See the License for the specific language governing permissions and
16 | # limitations under the License.
17 | #
18 |
19 | ##############################################################################
20 | ##
21 | ## Gradle start up script for UN*X
22 | ##
23 | ##############################################################################
24 |
25 | # Attempt to set APP_HOME
26 | # Resolve links: $0 may be a link
27 | PRG="$0"
28 | # Need this for relative symlinks.
29 | while [ -h "$PRG" ] ; do
30 | ls=`ls -ld "$PRG"`
31 | link=`expr "$ls" : '.*-> \(.*\)$'`
32 | if expr "$link" : '/.*' > /dev/null; then
33 | PRG="$link"
34 | else
35 | PRG=`dirname "$PRG"`"/$link"
36 | fi
37 | done
38 | SAVED="`pwd`"
39 | cd "`dirname \"$PRG\"`/" >/dev/null
40 | APP_HOME="`pwd -P`"
41 | cd "$SAVED" >/dev/null
42 |
43 | APP_NAME="Gradle"
44 | APP_BASE_NAME=`basename "$0"`
45 |
46 | # Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
47 | DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"'
48 |
49 | # Use the maximum available, or set MAX_FD != -1 to use that value.
50 | MAX_FD="maximum"
51 |
52 | warn () {
53 | echo "$*"
54 | }
55 |
56 | die () {
57 | echo
58 | echo "$*"
59 | echo
60 | exit 1
61 | }
62 |
63 | # OS specific support (must be 'true' or 'false').
64 | cygwin=false
65 | msys=false
66 | darwin=false
67 | nonstop=false
68 | case "`uname`" in
69 | CYGWIN* )
70 | cygwin=true
71 | ;;
72 | Darwin* )
73 | darwin=true
74 | ;;
75 | MINGW* )
76 | msys=true
77 | ;;
78 | NONSTOP* )
79 | nonstop=true
80 | ;;
81 | esac
82 |
83 | CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar
84 |
85 | # Determine the Java command to use to start the JVM.
86 | if [ -n "$JAVA_HOME" ] ; then
87 | if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
88 | # IBM's JDK on AIX uses strange locations for the executables
89 | JAVACMD="$JAVA_HOME/jre/sh/java"
90 | else
91 | JAVACMD="$JAVA_HOME/bin/java"
92 | fi
93 | if [ ! -x "$JAVACMD" ] ; then
94 | die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME
95 |
96 | Please set the JAVA_HOME variable in your environment to match the
97 | location of your Java installation."
98 | fi
99 | else
100 | JAVACMD="java"
101 | which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
102 |
103 | Please set the JAVA_HOME variable in your environment to match the
104 | location of your Java installation."
105 | fi
106 |
107 | # Increase the maximum file descriptors if we can.
108 | if [ "$cygwin" = "false" -a "$darwin" = "false" -a "$nonstop" = "false" ] ; then
109 | MAX_FD_LIMIT=`ulimit -H -n`
110 | if [ $? -eq 0 ] ; then
111 | if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then
112 | MAX_FD="$MAX_FD_LIMIT"
113 | fi
114 | ulimit -n $MAX_FD
115 | if [ $? -ne 0 ] ; then
116 | warn "Could not set maximum file descriptor limit: $MAX_FD"
117 | fi
118 | else
119 | warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT"
120 | fi
121 | fi
122 |
123 | # For Darwin, add options to specify how the application appears in the dock
124 | if $darwin; then
125 | GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\""
126 | fi
127 |
128 | # For Cygwin or MSYS, switch paths to Windows format before running java
129 | if [ "$cygwin" = "true" -o "$msys" = "true" ] ; then
130 | APP_HOME=`cygpath --path --mixed "$APP_HOME"`
131 | CLASSPATH=`cygpath --path --mixed "$CLASSPATH"`
132 | JAVACMD=`cygpath --unix "$JAVACMD"`
133 |
134 | # We build the pattern for arguments to be converted via cygpath
135 | ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null`
136 | SEP=""
137 | for dir in $ROOTDIRSRAW ; do
138 | ROOTDIRS="$ROOTDIRS$SEP$dir"
139 | SEP="|"
140 | done
141 | OURCYGPATTERN="(^($ROOTDIRS))"
142 | # Add a user-defined pattern to the cygpath arguments
143 | if [ "$GRADLE_CYGPATTERN" != "" ] ; then
144 | OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)"
145 | fi
146 | # Now convert the arguments - kludge to limit ourselves to /bin/sh
147 | i=0
148 | for arg in "$@" ; do
149 | CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -`
150 | CHECK2=`echo "$arg"|egrep -c "^-"` ### Determine if an option
151 |
152 | if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then ### Added a condition
153 | eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"`
154 | else
155 | eval `echo args$i`="\"$arg\""
156 | fi
157 | i=`expr $i + 1`
158 | done
159 | case $i in
160 | 0) set -- ;;
161 | 1) set -- "$args0" ;;
162 | 2) set -- "$args0" "$args1" ;;
163 | 3) set -- "$args0" "$args1" "$args2" ;;
164 | 4) set -- "$args0" "$args1" "$args2" "$args3" ;;
165 | 5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;;
166 | 6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;;
167 | 7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;;
168 | 8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;;
169 | 9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;;
170 | esac
171 | fi
172 |
173 | # Escape application args
174 | save () {
175 | for i do printf %s\\n "$i" | sed "s/'/'\\\\''/g;1s/^/'/;\$s/\$/' \\\\/" ; done
176 | echo " "
177 | }
178 | APP_ARGS=`save "$@"`
179 |
180 | # Collect all arguments for the java command, following the shell quoting and substitution rules
181 | eval set -- $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS "\"-Dorg.gradle.appname=$APP_BASE_NAME\"" -classpath "\"$CLASSPATH\"" org.gradle.wrapper.GradleWrapperMain "$APP_ARGS"
182 |
183 | exec "$JAVACMD" "$@"
184 |
--------------------------------------------------------------------------------
/gradlew:
--------------------------------------------------------------------------------
1 | #!/usr/bin/env sh
2 |
3 | #
4 | # Copyright 2015 the original author or authors.
5 | #
6 | # Licensed under the Apache License, Version 2.0 (the "License");
7 | # you may not use this file except in compliance with the License.
8 | # You may obtain a copy of the License at
9 | #
10 | # https://www.apache.org/licenses/LICENSE-2.0
11 | #
12 | # Unless required by applicable law or agreed to in writing, software
13 | # distributed under the License is distributed on an "AS IS" BASIS,
14 | # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15 | # See the License for the specific language governing permissions and
16 | # limitations under the License.
17 | #
18 |
19 | ##############################################################################
20 | ##
21 | ## Gradle start up script for UN*X
22 | ##
23 | ##############################################################################
24 |
25 | # Attempt to set APP_HOME
26 | # Resolve links: $0 may be a link
27 | PRG="$0"
28 | # Need this for relative symlinks.
29 | while [ -h "$PRG" ] ; do
30 | ls=`ls -ld "$PRG"`
31 | link=`expr "$ls" : '.*-> \(.*\)$'`
32 | if expr "$link" : '/.*' > /dev/null; then
33 | PRG="$link"
34 | else
35 | PRG=`dirname "$PRG"`"/$link"
36 | fi
37 | done
38 | SAVED="`pwd`"
39 | cd "`dirname \"$PRG\"`/" >/dev/null
40 | APP_HOME="`pwd -P`"
41 | cd "$SAVED" >/dev/null
42 |
43 | APP_NAME="Gradle"
44 | APP_BASE_NAME=`basename "$0"`
45 |
46 | # Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
47 | DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"'
48 |
49 | # Use the maximum available, or set MAX_FD != -1 to use that value.
50 | MAX_FD="maximum"
51 |
52 | warn () {
53 | echo "$*"
54 | }
55 |
56 | die () {
57 | echo
58 | echo "$*"
59 | echo
60 | exit 1
61 | }
62 |
63 | # OS specific support (must be 'true' or 'false').
64 | cygwin=false
65 | msys=false
66 | darwin=false
67 | nonstop=false
68 | case "`uname`" in
69 | CYGWIN* )
70 | cygwin=true
71 | ;;
72 | Darwin* )
73 | darwin=true
74 | ;;
75 | MINGW* )
76 | msys=true
77 | ;;
78 | NONSTOP* )
79 | nonstop=true
80 | ;;
81 | esac
82 |
83 | CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar
84 |
85 |
86 | # Determine the Java command to use to start the JVM.
87 | if [ -n "$JAVA_HOME" ] ; then
88 | if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
89 | # IBM's JDK on AIX uses strange locations for the executables
90 | JAVACMD="$JAVA_HOME/jre/sh/java"
91 | else
92 | JAVACMD="$JAVA_HOME/bin/java"
93 | fi
94 | if [ ! -x "$JAVACMD" ] ; then
95 | die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME
96 |
97 | Please set the JAVA_HOME variable in your environment to match the
98 | location of your Java installation."
99 | fi
100 | else
101 | JAVACMD="java"
102 | which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
103 |
104 | Please set the JAVA_HOME variable in your environment to match the
105 | location of your Java installation."
106 | fi
107 |
108 | # Increase the maximum file descriptors if we can.
109 | if [ "$cygwin" = "false" -a "$darwin" = "false" -a "$nonstop" = "false" ] ; then
110 | MAX_FD_LIMIT=`ulimit -H -n`
111 | if [ $? -eq 0 ] ; then
112 | if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then
113 | MAX_FD="$MAX_FD_LIMIT"
114 | fi
115 | ulimit -n $MAX_FD
116 | if [ $? -ne 0 ] ; then
117 | warn "Could not set maximum file descriptor limit: $MAX_FD"
118 | fi
119 | else
120 | warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT"
121 | fi
122 | fi
123 |
124 | # For Darwin, add options to specify how the application appears in the dock
125 | if $darwin; then
126 | GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\""
127 | fi
128 |
129 | # For Cygwin or MSYS, switch paths to Windows format before running java
130 | if [ "$cygwin" = "true" -o "$msys" = "true" ] ; then
131 | APP_HOME=`cygpath --path --mixed "$APP_HOME"`
132 | CLASSPATH=`cygpath --path --mixed "$CLASSPATH"`
133 |
134 | JAVACMD=`cygpath --unix "$JAVACMD"`
135 |
136 | # We build the pattern for arguments to be converted via cygpath
137 | ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null`
138 | SEP=""
139 | for dir in $ROOTDIRSRAW ; do
140 | ROOTDIRS="$ROOTDIRS$SEP$dir"
141 | SEP="|"
142 | done
143 | OURCYGPATTERN="(^($ROOTDIRS))"
144 | # Add a user-defined pattern to the cygpath arguments
145 | if [ "$GRADLE_CYGPATTERN" != "" ] ; then
146 | OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)"
147 | fi
148 | # Now convert the arguments - kludge to limit ourselves to /bin/sh
149 | i=0
150 | for arg in "$@" ; do
151 | CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -`
152 | CHECK2=`echo "$arg"|egrep -c "^-"` ### Determine if an option
153 |
154 | if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then ### Added a condition
155 | eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"`
156 | else
157 | eval `echo args$i`="\"$arg\""
158 | fi
159 | i=`expr $i + 1`
160 | done
161 | case $i in
162 | 0) set -- ;;
163 | 1) set -- "$args0" ;;
164 | 2) set -- "$args0" "$args1" ;;
165 | 3) set -- "$args0" "$args1" "$args2" ;;
166 | 4) set -- "$args0" "$args1" "$args2" "$args3" ;;
167 | 5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;;
168 | 6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;;
169 | 7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;;
170 | 8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;;
171 | 9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;;
172 | esac
173 | fi
174 |
175 | # Escape application args
176 | save () {
177 | for i do printf %s\\n "$i" | sed "s/'/'\\\\''/g;1s/^/'/;\$s/\$/' \\\\/" ; done
178 | echo " "
179 | }
180 | APP_ARGS=`save "$@"`
181 |
182 | # Collect all arguments for the java command, following the shell quoting and substitution rules
183 | eval set -- $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS "\"-Dorg.gradle.appname=$APP_BASE_NAME\"" -classpath "\"$CLASSPATH\"" org.gradle.wrapper.GradleWrapperMain "$APP_ARGS"
184 |
185 | exec "$JAVACMD" "$@"
186 |
--------------------------------------------------------------------------------
/components/data.js:
--------------------------------------------------------------------------------
1 | import Song from '../models/Song';
2 | import Genre from '../models/Genre';
3 |
4 | export const GENRES = [
5 | new Genre(
6 | '1',
7 | 'Romantic',
8 | 'https://res.cloudinary.com/dht1rd0lr/image/upload/v1600086093/rom_rzxckc.jpg',
9 | ),
10 | new Genre(
11 | '2',
12 | 'Soothing',
13 | 'https://res.cloudinary.com/dht1rd0lr/image/upload/v1600086191/soothing_l2fhdm.jpg',
14 | ),
15 | new Genre(
16 | '3',
17 | 'Rock-on',
18 | 'https://res.cloudinary.com/dht1rd0lr/image/upload/v1600086245/rockon_fgsbfk.jpg',
19 | ),
20 | new Genre(
21 | '4',
22 | 'Classics',
23 | 'https://res.cloudinary.com/dht1rd0lr/image/upload/v1600085955/classics_h9mj11.jpg',
24 | ),
25 | new Genre(
26 | '5',
27 | 'Workout',
28 | 'https://res.cloudinary.com/dht1rd0lr/image/upload/v1600086391/workout_qa5lhh.jpg',
29 | ),
30 | new Genre(
31 | '6',
32 | 'Dance',
33 | 'https://res.cloudinary.com/dht1rd0lr/image/upload/v1600085955/dance_bzgn8j.jpg',
34 | ),
35 | ];
36 |
37 | export const ROM = [
38 | new Song(
39 | '0',
40 | '1',
41 | 'Tera Hone Laga Hoon',
42 | 'Atif Aslam',
43 | 'https://res.cloudinary.com/dht1rd0lr/image/upload/v1600079503/terahonelagahoon_d2fnjz.jpg',
44 | 'https://res.cloudinary.com/dht1rd0lr/video/upload/v1600078103/terahonelagahoon_b8bbt1.mp3',
45 | ),
46 | new Song(
47 | '1',
48 | '1',
49 | 'Khuda Jaane',
50 | 'KK',
51 | 'https://res.cloudinary.com/dht1rd0lr/image/upload/v1600078155/khudajaane_lndcmv.jpg',
52 | 'https://res.cloudinary.com/dht1rd0lr/video/upload/v1600078117/khudajaane_phty09.mp3',
53 | ),
54 | new Song(
55 | '2',
56 | '1',
57 | 'Tujhe Kitna Chahne Lage Hum',
58 | 'Arijit Singh',
59 | 'https://res.cloudinary.com/dht1rd0lr/image/upload/v1600079505/tujhekitnachahne_jfebva.jpg',
60 | 'https://res.cloudinary.com/dht1rd0lr/video/upload/v1600079384/tujhekitnachahne_dc7bjl.mp3',
61 | ),
62 | new Song(
63 | '3',
64 | '1',
65 | 'Nazm Nazm',
66 | 'Arko Pravo Mukherjee',
67 | 'https://res.cloudinary.com/dht1rd0lr/image/upload/v1600079502/nazmnazm_ufymwt.jpg',
68 | 'https://res.cloudinary.com/dht1rd0lr/video/upload/v1600079361/nazmnazm_bajafk.mp3',
69 | ),
70 | ];
71 |
72 | export const SOOTHING = [
73 | new Song(
74 | '0',
75 | '2',
76 | 'Kabira',
77 | 'Tochi Raina, Rekha Bhardwaj',
78 | 'https://res.cloudinary.com/dht1rd0lr/image/upload/v1600079502/kabira_oo1mis.jpg',
79 | 'https://res.cloudinary.com/dht1rd0lr/video/upload/v1600079348/kabira_jinll6.mp3',
80 | ),
81 | new Song(
82 | '1',
83 | '2',
84 | 'Khaabon Ke Parindey',
85 | 'Alyssa Mendonsa, Mohit Chauhan',
86 | 'https://res.cloudinary.com/dht1rd0lr/image/upload/v1600079503/khaabonkeparindey_hbqh3n.jpg',
87 | 'https://res.cloudinary.com/dht1rd0lr/video/upload/v1600079339/khaabonkeparindey_ywje8n.mp3',
88 | ),
89 | ];
90 |
91 | export const ROCKON = [
92 | new Song(
93 | '0',
94 | '3',
95 | 'Apna Time Aaega',
96 | 'Ranveer Singh',
97 | 'https://res.cloudinary.com/dht1rd0lr/image/upload/v1600079501/apnatimeaaega_jenq8u.jpg',
98 | 'https://res.cloudinary.com/dht1rd0lr/video/upload/v1600079453/gullyboy_osvfcf.mp3',
99 | ),
100 | new Song(
101 | '1',
102 | '3',
103 | 'Manali Trance',
104 | 'Yo Yo Honey Singh, Neha Kakkar',
105 | 'https://res.cloudinary.com/dht1rd0lr/image/upload/v1600079502/manalitrance_t9rq4v.jpg',
106 | 'https://res.cloudinary.com/dht1rd0lr/video/upload/v1600079476/manalitrance_nrfpvt.mp3',
107 | ),
108 | ];
109 |
110 | export const CLASSICS = [
111 | new Song(
112 | '0',
113 | '4',
114 | 'Haal Kaisa Hai Janab Ka',
115 | 'Kishore Kumar, Asha Bhosle',
116 | 'https://res.cloudinary.com/dht1rd0lr/image/upload/v1600079501/haalkaisahaijanabka_hqx7vk.jpg',
117 | 'https://res.cloudinary.com/dht1rd0lr/video/upload/v1600084050/haalkaisahaijanabka_zkjiou.mp3',
118 | ),
119 | ];
120 |
121 | export const WORKOUT = [
122 | new Song(
123 | '0',
124 | '5',
125 | 'Soorma',
126 | 'Shankar Mahadevan',
127 | 'https://res.cloudinary.com/dht1rd0lr/image/upload/v1600079503/soorma_fxyjnr.jpg',
128 | 'https://res.cloudinary.com/dht1rd0lr/video/upload/v1600079360/soorma_jlw3ei.mp3',
129 | ),
130 | new Song(
131 | '1',
132 | '5',
133 | 'Zinda',
134 | 'Siddharth Mahadevan',
135 | 'https://res.cloudinary.com/dht1rd0lr/image/upload/v1600079503/zinda_vd2cjg.jpg',
136 | 'https://res.cloudinary.com/dht1rd0lr/video/upload/v1600079377/zinda_cdx5dp.mp3',
137 | ),
138 | ];
139 |
140 | export const DANCE = [
141 | new Song(
142 | '0',
143 | '6',
144 | 'Bom Diggy Diggy',
145 | 'Jasmin Walia, Zack Knight',
146 | 'https://res.cloudinary.com/dht1rd0lr/image/upload/v1600079501/bomdiggy_ly8gwx.jpg',
147 | 'https://res.cloudinary.com/dht1rd0lr/video/upload/v1600079360/bomdiggy_ckt8du.mp3',
148 | ),
149 | new Song(
150 | '1',
151 | '6',
152 | 'The Breakup Song',
153 | 'Pritam Chakraborty',
154 | 'https://res.cloudinary.com/dht1rd0lr/image/upload/v1600079501/breakup_tq11h7.jpg',
155 | 'https://res.cloudinary.com/dht1rd0lr/video/upload/v1600079342/breakupsong_nr2o91.mp3',
156 | ),
157 | new Song(
158 | '2',
159 | '6',
160 | 'Haan Main Galat',
161 | 'Arijit Singh, Pritam Chakraborty',
162 | 'https://res.cloudinary.com/dht1rd0lr/image/upload/v1600084536/haanmaingalat_qtiscp.jpg',
163 | 'https://res.cloudinary.com/dht1rd0lr/video/upload/v1600079347/haanmaingalat_jttxst.mp3',
164 | ),
165 | ];
166 |
167 | export const SONGS = [
168 | new Song(
169 | '0',
170 | '7',
171 | 'Death Bed',
172 | 'Powfu',
173 | 'https://samplesongs.netlify.app/album-arts/death-bed.jpg',
174 | 'https://res.cloudinary.com/dht1rd0lr/video/upload/v1600018774/song2_bxpoj6.mp3',
175 | ),
176 | new Song(
177 | '1',
178 | '7',
179 | 'Bad Liar',
180 | 'Imagine Dragons',
181 | 'https://samplesongs.netlify.app/album-arts/bad-liar.jpg',
182 | 'https://samplesongs.netlify.app/Bad%20Liar.mp3',
183 | ),
184 | new Song(
185 | '2',
186 | '7',
187 | 'Faded',
188 | 'Alan Walker',
189 | 'https://samplesongs.netlify.app/album-arts/faded.jpg',
190 | 'https://samplesongs.netlify.app/Faded.mp3',
191 | ),
192 | new Song(
193 | '3',
194 | '7',
195 | 'Hate Me',
196 | 'Ellie Goulding',
197 | 'https://samplesongs.netlify.app/album-arts/hate-me.jpg',
198 | 'https://samplesongs.netlify.app/Hate%20Me.mp3',
199 | ),
200 | new Song(
201 | '4',
202 | '7',
203 | 'Solo',
204 | 'Clean Bandit',
205 | 'https://samplesongs.netlify.app/album-arts/solo.jpg',
206 | 'https://samplesongs.netlify.app/Solo.mp3',
207 | ),
208 | new Song(
209 | '5',
210 | '7',
211 | 'Without Me',
212 | 'Halsey',
213 | 'https://samplesongs.netlify.app/album-arts/without-me.jpg',
214 | 'https://samplesongs.netlify.app/Without%20Me.mp3',
215 | ),
216 | ];
217 |
--------------------------------------------------------------------------------
/screens/SongsPlayScreen.js:
--------------------------------------------------------------------------------
1 | import React, {useRef, useEffect, useState, useCallback} from 'react';
2 | import {
3 | View,
4 | Text,
5 | StyleSheet,
6 | Image,
7 | Dimensions,
8 | Animated,
9 | } from 'react-native';
10 | import {SafeAreaView} from 'react-native-safe-area-context';
11 | import {FlatList} from 'react-native-gesture-handler';
12 | import Ionicons from 'react-native-vector-icons/Ionicons';
13 | import {toggleFavourite} from '../store/actions/songsActions';
14 | import {useDispatch, useSelector} from 'react-redux';
15 |
16 | import TrackPlayer from 'react-native-track-player';
17 |
18 | import {
19 | ROM,
20 | SOOTHING,
21 | ROCKON,
22 | CLASSICS,
23 | WORKOUT,
24 | DANCE,
25 | SONGS,
26 | } from '../components/data';
27 | import Controller from '../components/Controller';
28 | import MySlider from '../components/MySlider';
29 | import Colors from '../components/Colors';
30 |
31 | const {width, height} = Dimensions.get('window');
32 |
33 | const SongsPlayScreen = (props) => {
34 | const sId = props.navigation.getParam('sid');
35 | const gId = props.navigation.getParam('gid');
36 | let arr = [{}];
37 | if (gId === '1') {
38 | arr = ROM;
39 | } else if (gId === '2') {
40 | arr = SOOTHING;
41 | } else if (gId === '3') {
42 | arr = ROCKON;
43 | } else if (gId === '4') {
44 | arr = CLASSICS;
45 | } else if (gId === '5') {
46 | arr = WORKOUT;
47 | } else if (gId === '6') {
48 | arr = DANCE;
49 | } else if (gId === '7') {
50 | arr = SONGS;
51 | }
52 |
53 | const displayedSongs = arr.filter((song) => song.genre.indexOf(gId) >= 0);
54 |
55 | const scrollX = useRef(new Animated.Value(0)).current; //useRef to survive from re rendering,
56 | //mutable but will not be re-created evry time the component re-renders
57 | //and if changes will not force re render of the component
58 | //Animated.value will allow React to make changes in the JSX without re-rendering
59 | const [songIndex, setSongIndex] = useState(0);
60 | const slider = useRef(null); // to not re-initialize it
61 | const [isPlayerReady, setIsPlayerReady] = useState(false);
62 |
63 | useEffect(() => {
64 | scrollX.addListener(({value}) => {
65 | console.log(value);
66 | const index = Math.round(value / width); //get the index of the song
67 | setSongIndex(index); //set the next song in queue
68 | console.log(index);
69 | });
70 |
71 | TrackPlayer.setupPlayer().then(async () => {
72 | console.log('Player ready');
73 | await TrackPlayer.add(displayedSongs);
74 | TrackPlayer.skip(sId); //to start from the selected song
75 | setIsPlayerReady(true);
76 | TrackPlayer.play();
77 | });
78 | return () => {
79 | scrollX.removeAllListeners();
80 | }; //clean up function
81 | }, []); //because we want to attach the listener only once,
82 | //and set the trackPlayer only once not again and again
83 |
84 | useEffect(() => {
85 | if (isPlayerReady) {
86 | TrackPlayer.skip(displayedSongs[songIndex].id);
87 | }
88 | }, [songIndex]); //whenever scroll value changes hence songIndex changes then the songTrack
89 | // will also skip to that id
90 |
91 | const goNext = () => {
92 | slider.current.scrollToOffset({
93 | offset: (songIndex + 1) * width,
94 | }); //Flatlist will scroll to the next item in the queue, default parameter animated is always true
95 | };
96 |
97 | const goPrevious = () => {
98 | slider.current.scrollToOffset({
99 | offset: (songIndex - 1) * width,
100 | }); //Flatlist will scroll to the previous item in the queue
101 | };
102 |
103 | const dispatch = useDispatch();
104 |
105 | const currentSongIsFav = useSelector((state) =>
106 | state.songs.favSongs.some(
107 | (song) => song.id === displayedSongs[songIndex].id,
108 | ),
109 | );
110 |
111 | const toggleFavouriteHandler = useCallback(() => {
112 | //useCallback to prevent recreation of this function
113 | //after every rerender but not needed here
114 | //earlier I thought I'll add this fav icon in the header, for that I had to pass it to the header using params
115 | //with help of useEffect and the dependency would be the same funcion, so to prevent infinite number of loops
116 | console.log('liked');
117 | dispatch(toggleFavourite(displayedSongs[songIndex].id, gId));
118 | }, [dispatch, displayedSongs[songIndex].id, gId]);
119 |
120 | const renderSongItem = ({item, index}) => {
121 | return (
122 |
123 |
127 |
128 | );
129 | };
130 |
131 | return (
132 |
133 |
134 |
135 | props.navigation.goBack()}
140 | />
141 |
147 |
148 | item.id}
155 | getItemLayout={(data, index) => ({
156 | length: width,
157 | offset: width * index,
158 | index,
159 | })}
160 | initialScrollIndex={parseInt(sId)} //to start from a specific song in the specific genre
161 | ref={slider} //coz we want to make changes in the Flatlist with respect to the slider
162 | scrollEventThrottle={16} //to make the animation faster and smoother
163 | onScroll={Animated.event(
164 | //event triggered for scrolling in x direction
165 | [{nativeEvent: {contentOffset: {x: scrollX}}}],
166 | {
167 | useNativeDriver: false, //to improve performance of animations. if false, animations done on js thread
168 | },
169 | )}
170 | />
171 |
172 |
173 |
174 | {displayedSongs[songIndex].title}
175 |
176 | {displayedSongs[songIndex].artist}
177 |
178 |
179 |
180 |
181 | );
182 | };
183 |
184 | const styles = StyleSheet.create({
185 | icon: {
186 | padding: height / 37.5,
187 | flexDirection: 'row',
188 | justifyContent: 'space-between',
189 | },
190 | imgContainer: {
191 | width: width,
192 | alignItems: 'center',
193 | },
194 | songinfoCont: {
195 | padding: height / 37.5,
196 | alignItems: 'center',
197 | marginBottom: height / 150,
198 | },
199 | title: {
200 | fontSize: height / 34,
201 | color: 'white',
202 | paddingBottom: height / 150,
203 | },
204 | artist: {
205 | fontSize: height / 41.6,
206 | color: 'gray',
207 | },
208 | });
209 |
210 | export default SongsPlayScreen;
211 |
--------------------------------------------------------------------------------
/android/app/build.gradle:
--------------------------------------------------------------------------------
1 | apply plugin: "com.android.application"
2 |
3 | import com.android.build.OutputFile
4 |
5 | /**
6 | * The react.gradle file registers a task for each build variant (e.g. bundleDebugJsAndAssets
7 | * and bundleReleaseJsAndAssets).
8 | * These basically call `react-native bundle` with the correct arguments during the Android build
9 | * cycle. By default, bundleDebugJsAndAssets is skipped, as in debug/dev mode we prefer to load the
10 | * bundle directly from the development server. Below you can see all the possible configurations
11 | * and their defaults. If you decide to add a configuration block, make sure to add it before the
12 | * `apply from: "../../node_modules/react-native/react.gradle"` line.
13 | *
14 | * project.ext.react = [
15 | * // the name of the generated asset file containing your JS bundle
16 | * bundleAssetName: "index.android.bundle",
17 | *
18 | * // the entry file for bundle generation. If none specified and
19 | * // "index.android.js" exists, it will be used. Otherwise "index.js" is
20 | * // default. Can be overridden with ENTRY_FILE environment variable.
21 | * entryFile: "index.android.js",
22 | *
23 | * // https://reactnative.dev/docs/performance#enable-the-ram-format
24 | * bundleCommand: "ram-bundle",
25 | *
26 | * // whether to bundle JS and assets in debug mode
27 | * bundleInDebug: false,
28 | *
29 | * // whether to bundle JS and assets in release mode
30 | * bundleInRelease: true,
31 | *
32 | * // whether to bundle JS and assets in another build variant (if configured).
33 | * // See http://tools.android.com/tech-docs/new-build-system/user-guide#TOC-Build-Variants
34 | * // The configuration property can be in the following formats
35 | * // 'bundleIn${productFlavor}${buildType}'
36 | * // 'bundleIn${buildType}'
37 | * // bundleInFreeDebug: true,
38 | * // bundleInPaidRelease: true,
39 | * // bundleInBeta: true,
40 | *
41 | * // whether to disable dev mode in custom build variants (by default only disabled in release)
42 | * // for example: to disable dev mode in the staging build type (if configured)
43 | * devDisabledInStaging: true,
44 | * // The configuration property can be in the following formats
45 | * // 'devDisabledIn${productFlavor}${buildType}'
46 | * // 'devDisabledIn${buildType}'
47 | *
48 | * // the root of your project, i.e. where "package.json" lives
49 | * root: "../../",
50 | *
51 | * // where to put the JS bundle asset in debug mode
52 | * jsBundleDirDebug: "$buildDir/intermediates/assets/debug",
53 | *
54 | * // where to put the JS bundle asset in release mode
55 | * jsBundleDirRelease: "$buildDir/intermediates/assets/release",
56 | *
57 | * // where to put drawable resources / React Native assets, e.g. the ones you use via
58 | * // require('./image.png')), in debug mode
59 | * resourcesDirDebug: "$buildDir/intermediates/res/merged/debug",
60 | *
61 | * // where to put drawable resources / React Native assets, e.g. the ones you use via
62 | * // require('./image.png')), in release mode
63 | * resourcesDirRelease: "$buildDir/intermediates/res/merged/release",
64 | *
65 | * // by default the gradle tasks are skipped if none of the JS files or assets change; this means
66 | * // that we don't look at files in android/ or ios/ to determine whether the tasks are up to
67 | * // date; if you have any other folders that you want to ignore for performance reasons (gradle
68 | * // indexes the entire tree), add them here. Alternatively, if you have JS files in android/
69 | * // for example, you might want to remove it from here.
70 | * inputExcludes: ["android/**", "ios/**"],
71 | *
72 | * // override which node gets called and with what additional arguments
73 | * nodeExecutableAndArgs: ["node"],
74 | *
75 | * // supply additional arguments to the packager
76 | * extraPackagerArgs: []
77 | * ]
78 | */
79 |
80 | project.ext.react = [
81 | enableHermes: false, // clean and rebuild if changing
82 | ]
83 |
84 | apply from: "../../node_modules/react-native/react.gradle"
85 |
86 | /* project.ext.vectoricons = [
87 | iconFontNames: [ 'MaterialIcons.ttf', 'EvilIcons.ttf', '' ] // Name of the font files you want to copy
88 | ] */
89 |
90 | apply from: "../../node_modules/react-native-vector-icons/fonts.gradle"
91 |
92 | /**
93 | * Set this to true to create two separate APKs instead of one:
94 | * - An APK that only works on ARM devices
95 | * - An APK that only works on x86 devices
96 | * The advantage is the size of the APK is reduced by about 4MB.
97 | * Upload all the APKs to the Play Store and people will download
98 | * the correct one based on the CPU architecture of their device.
99 | */
100 | def enableSeparateBuildPerCPUArchitecture = false
101 |
102 | /**
103 | * Run Proguard to shrink the Java bytecode in release builds.
104 | */
105 | def enableProguardInReleaseBuilds = false
106 |
107 | /**
108 | * The preferred build flavor of JavaScriptCore.
109 | *
110 | * For example, to use the international variant, you can use:
111 | * `def jscFlavor = 'org.webkit:android-jsc-intl:+'`
112 | *
113 | * The international variant includes ICU i18n library and necessary data
114 | * allowing to use e.g. `Date.toLocaleString` and `String.localeCompare` that
115 | * give correct results when using with locales other than en-US. Note that
116 | * this variant is about 6MiB larger per architecture than default.
117 | */
118 | def jscFlavor = 'org.webkit:android-jsc:+'
119 |
120 | /**
121 | * Whether to enable the Hermes VM.
122 | *
123 | * This should be set on project.ext.react and mirrored here. If it is not set
124 | * on project.ext.react, JavaScript will not be compiled to Hermes Bytecode
125 | * and the benefits of using Hermes will therefore be sharply reduced.
126 | */
127 | def enableHermes = project.ext.react.get("enableHermes", false);
128 |
129 | android {
130 | compileSdkVersion rootProject.ext.compileSdkVersion
131 |
132 | compileOptions {
133 | sourceCompatibility JavaVersion.VERSION_1_8
134 | targetCompatibility JavaVersion.VERSION_1_8
135 | }
136 |
137 | defaultConfig {
138 | applicationId "com.sangeet"
139 | minSdkVersion rootProject.ext.minSdkVersion
140 | targetSdkVersion rootProject.ext.targetSdkVersion
141 | versionCode 1
142 | versionName "1.0"
143 | }
144 | splits {
145 | abi {
146 | reset()
147 | enable enableSeparateBuildPerCPUArchitecture
148 | universalApk false // If true, also generate a universal APK
149 | include "armeabi-v7a", "x86", "arm64-v8a", "x86_64"
150 | }
151 | }
152 | signingConfigs {
153 | debug {
154 | storeFile file('debug.keystore')
155 | storePassword 'android'
156 | keyAlias 'androiddebugkey'
157 | keyPassword 'android'
158 | }
159 | }
160 | buildTypes {
161 | debug {
162 | signingConfig signingConfigs.debug
163 | }
164 | release {
165 | // Caution! In production, you need to generate your own keystore file.
166 | // see https://reactnative.dev/docs/signed-apk-android.
167 | signingConfig signingConfigs.debug
168 | minifyEnabled enableProguardInReleaseBuilds
169 | proguardFiles getDefaultProguardFile("proguard-android.txt"), "proguard-rules.pro"
170 | }
171 | }
172 |
173 | // applicationVariants are e.g. debug, release
174 | applicationVariants.all { variant ->
175 | variant.outputs.each { output ->
176 | // For each separate APK per architecture, set a unique version code as described here:
177 | // https://developer.android.com/studio/build/configure-apk-splits.html
178 | def versionCodes = ["armeabi-v7a": 1, "x86": 2, "arm64-v8a": 3, "x86_64": 4]
179 | def abi = output.getFilter(OutputFile.ABI)
180 | if (abi != null) { // null for the universal-debug, universal-release variants
181 | output.versionCodeOverride =
182 | versionCodes.get(abi) * 1048576 + defaultConfig.versionCode
183 | }
184 |
185 | }
186 | }
187 | }
188 |
189 | dependencies {
190 | implementation fileTree(dir: "libs", include: ["*.jar"])
191 | //noinspection GradleDynamicVersion
192 | implementation "com.facebook.react:react-native:+" // From node_modules
193 |
194 | implementation "androidx.swiperefreshlayout:swiperefreshlayout:1.0.0"
195 |
196 | debugImplementation("com.facebook.flipper:flipper:${FLIPPER_VERSION}") {
197 | exclude group:'com.facebook.fbjni'
198 | }
199 |
200 | debugImplementation("com.facebook.flipper:flipper-network-plugin:${FLIPPER_VERSION}") {
201 | exclude group:'com.facebook.flipper'
202 | exclude group:'com.squareup.okhttp3', module:'okhttp'
203 | }
204 |
205 | debugImplementation("com.facebook.flipper:flipper-fresco-plugin:${FLIPPER_VERSION}") {
206 | exclude group:'com.facebook.flipper'
207 | }
208 |
209 | if (enableHermes) {
210 | def hermesPath = "../../node_modules/hermes-engine/android/";
211 | debugImplementation files(hermesPath + "hermes-debug.aar")
212 | releaseImplementation files(hermesPath + "hermes-release.aar")
213 | } else {
214 | implementation jscFlavor
215 | }
216 | }
217 |
218 | // Run this once to be able to run the application with BUCK
219 | // puts all compile dependencies into folder libs for BUCK to use
220 | task copyDownloadableDepsToLibs(type: Copy) {
221 | from configurations.compile
222 | into 'libs'
223 | }
224 |
225 | apply from: file("../../node_modules/@react-native-community/cli-platform-android/native_modules.gradle"); applyNativeModulesAppBuildGradle(project)
226 |
--------------------------------------------------------------------------------
/ios/Sangeet.xcodeproj/project.pbxproj:
--------------------------------------------------------------------------------
1 | // !$*UTF8*$!
2 | {
3 | archiveVersion = 1;
4 | classes = {
5 | };
6 | objectVersion = 46;
7 | objects = {
8 |
9 | /* Begin PBXBuildFile section */
10 | 00E356F31AD99517003FC87E /* SangeetTests.m in Sources */ = {isa = PBXBuildFile; fileRef = 00E356F21AD99517003FC87E /* SangeetTests.m */; };
11 | 13B07FBC1A68108700A75B9A /* AppDelegate.m in Sources */ = {isa = PBXBuildFile; fileRef = 13B07FB01A68108700A75B9A /* AppDelegate.m */; };
12 | 13B07FBF1A68108700A75B9A /* Images.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 13B07FB51A68108700A75B9A /* Images.xcassets */; };
13 | 13B07FC11A68108700A75B9A /* main.m in Sources */ = {isa = PBXBuildFile; fileRef = 13B07FB71A68108700A75B9A /* main.m */; };
14 | 2D02E4BC1E0B4A80006451C7 /* AppDelegate.m in Sources */ = {isa = PBXBuildFile; fileRef = 13B07FB01A68108700A75B9A /* AppDelegate.m */; };
15 | 2D02E4BD1E0B4A84006451C7 /* Images.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 13B07FB51A68108700A75B9A /* Images.xcassets */; };
16 | 2D02E4BF1E0B4AB3006451C7 /* main.m in Sources */ = {isa = PBXBuildFile; fileRef = 13B07FB71A68108700A75B9A /* main.m */; };
17 | 2DCD954D1E0B4F2C00145EB5 /* SangeetTests.m in Sources */ = {isa = PBXBuildFile; fileRef = 00E356F21AD99517003FC87E /* SangeetTests.m */; };
18 | 81AB9BB82411601600AC10FF /* LaunchScreen.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 81AB9BB72411601600AC10FF /* LaunchScreen.storyboard */; };
19 | /* End PBXBuildFile section */
20 |
21 | /* Begin PBXContainerItemProxy section */
22 | 00E356F41AD99517003FC87E /* PBXContainerItemProxy */ = {
23 | isa = PBXContainerItemProxy;
24 | containerPortal = 83CBB9F71A601CBA00E9B192 /* Project object */;
25 | proxyType = 1;
26 | remoteGlobalIDString = 13B07F861A680F5B00A75B9A;
27 | remoteInfo = Sangeet;
28 | };
29 | 2D02E4911E0B4A5D006451C7 /* PBXContainerItemProxy */ = {
30 | isa = PBXContainerItemProxy;
31 | containerPortal = 83CBB9F71A601CBA00E9B192 /* Project object */;
32 | proxyType = 1;
33 | remoteGlobalIDString = 2D02E47A1E0B4A5D006451C7;
34 | remoteInfo = "Sangeet-tvOS";
35 | };
36 | /* End PBXContainerItemProxy section */
37 |
38 | /* Begin PBXFileReference section */
39 | 008F07F21AC5B25A0029DE68 /* main.jsbundle */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = main.jsbundle; sourceTree = ""; };
40 | 00E356EE1AD99517003FC87E /* SangeetTests.xctest */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = SangeetTests.xctest; sourceTree = BUILT_PRODUCTS_DIR; };
41 | 00E356F11AD99517003FC87E /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = ""; };
42 | 00E356F21AD99517003FC87E /* SangeetTests.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = SangeetTests.m; sourceTree = ""; };
43 | 13B07F961A680F5B00A75B9A /* Sangeet.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = Sangeet.app; sourceTree = BUILT_PRODUCTS_DIR; };
44 | 13B07FAF1A68108700A75B9A /* AppDelegate.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = AppDelegate.h; path = Sangeet/AppDelegate.h; sourceTree = ""; };
45 | 13B07FB01A68108700A75B9A /* AppDelegate.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = AppDelegate.m; path = Sangeet/AppDelegate.m; sourceTree = ""; };
46 | 13B07FB51A68108700A75B9A /* Images.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; name = Images.xcassets; path = Sangeet/Images.xcassets; sourceTree = ""; };
47 | 13B07FB61A68108700A75B9A /* Info.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; name = Info.plist; path = Sangeet/Info.plist; sourceTree = ""; };
48 | 13B07FB71A68108700A75B9A /* main.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = main.m; path = Sangeet/main.m; sourceTree = ""; };
49 | 2D02E47B1E0B4A5D006451C7 /* Sangeet-tvOS.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = "Sangeet-tvOS.app"; sourceTree = BUILT_PRODUCTS_DIR; };
50 | 2D02E4901E0B4A5D006451C7 /* Sangeet-tvOSTests.xctest */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = "Sangeet-tvOSTests.xctest"; sourceTree = BUILT_PRODUCTS_DIR; };
51 | 81AB9BB72411601600AC10FF /* LaunchScreen.storyboard */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = file.storyboard; name = LaunchScreen.storyboard; path = Sangeet/LaunchScreen.storyboard; sourceTree = ""; };
52 | ED297162215061F000B7C4FE /* JavaScriptCore.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = JavaScriptCore.framework; path = System/Library/Frameworks/JavaScriptCore.framework; sourceTree = SDKROOT; };
53 | ED2971642150620600B7C4FE /* JavaScriptCore.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = JavaScriptCore.framework; path = Platforms/AppleTVOS.platform/Developer/SDKs/AppleTVOS12.0.sdk/System/Library/Frameworks/JavaScriptCore.framework; sourceTree = DEVELOPER_DIR; };
54 | /* End PBXFileReference section */
55 |
56 | /* Begin PBXFrameworksBuildPhase section */
57 | 00E356EB1AD99517003FC87E /* Frameworks */ = {
58 | isa = PBXFrameworksBuildPhase;
59 | buildActionMask = 2147483647;
60 | files = (
61 | );
62 | runOnlyForDeploymentPostprocessing = 0;
63 | };
64 | 13B07F8C1A680F5B00A75B9A /* Frameworks */ = {
65 | isa = PBXFrameworksBuildPhase;
66 | buildActionMask = 2147483647;
67 | files = (
68 | );
69 | runOnlyForDeploymentPostprocessing = 0;
70 | };
71 | 2D02E4781E0B4A5D006451C7 /* Frameworks */ = {
72 | isa = PBXFrameworksBuildPhase;
73 | buildActionMask = 2147483647;
74 | files = (
75 | );
76 | runOnlyForDeploymentPostprocessing = 0;
77 | };
78 | 2D02E48D1E0B4A5D006451C7 /* Frameworks */ = {
79 | isa = PBXFrameworksBuildPhase;
80 | buildActionMask = 2147483647;
81 | files = (
82 | );
83 | runOnlyForDeploymentPostprocessing = 0;
84 | };
85 | /* End PBXFrameworksBuildPhase section */
86 |
87 | /* Begin PBXGroup section */
88 | 00E356EF1AD99517003FC87E /* SangeetTests */ = {
89 | isa = PBXGroup;
90 | children = (
91 | 00E356F21AD99517003FC87E /* SangeetTests.m */,
92 | 00E356F01AD99517003FC87E /* Supporting Files */,
93 | );
94 | path = SangeetTests;
95 | sourceTree = "";
96 | };
97 | 00E356F01AD99517003FC87E /* Supporting Files */ = {
98 | isa = PBXGroup;
99 | children = (
100 | 00E356F11AD99517003FC87E /* Info.plist */,
101 | );
102 | name = "Supporting Files";
103 | sourceTree = "";
104 | };
105 | 13B07FAE1A68108700A75B9A /* Sangeet */ = {
106 | isa = PBXGroup;
107 | children = (
108 | 008F07F21AC5B25A0029DE68 /* main.jsbundle */,
109 | 13B07FAF1A68108700A75B9A /* AppDelegate.h */,
110 | 13B07FB01A68108700A75B9A /* AppDelegate.m */,
111 | 13B07FB51A68108700A75B9A /* Images.xcassets */,
112 | 13B07FB61A68108700A75B9A /* Info.plist */,
113 | 81AB9BB72411601600AC10FF /* LaunchScreen.storyboard */,
114 | 13B07FB71A68108700A75B9A /* main.m */,
115 | );
116 | name = Sangeet;
117 | sourceTree = "";
118 | };
119 | 2D16E6871FA4F8E400B85C8A /* Frameworks */ = {
120 | isa = PBXGroup;
121 | children = (
122 | ED297162215061F000B7C4FE /* JavaScriptCore.framework */,
123 | ED2971642150620600B7C4FE /* JavaScriptCore.framework */,
124 | );
125 | name = Frameworks;
126 | sourceTree = "";
127 | };
128 | 832341AE1AAA6A7D00B99B32 /* Libraries */ = {
129 | isa = PBXGroup;
130 | children = (
131 | );
132 | name = Libraries;
133 | sourceTree = "";
134 | };
135 | 83CBB9F61A601CBA00E9B192 = {
136 | isa = PBXGroup;
137 | children = (
138 | 13B07FAE1A68108700A75B9A /* Sangeet */,
139 | 832341AE1AAA6A7D00B99B32 /* Libraries */,
140 | 00E356EF1AD99517003FC87E /* SangeetTests */,
141 | 83CBBA001A601CBA00E9B192 /* Products */,
142 | 2D16E6871FA4F8E400B85C8A /* Frameworks */,
143 | );
144 | indentWidth = 2;
145 | sourceTree = "";
146 | tabWidth = 2;
147 | usesTabs = 0;
148 | };
149 | 83CBBA001A601CBA00E9B192 /* Products */ = {
150 | isa = PBXGroup;
151 | children = (
152 | 13B07F961A680F5B00A75B9A /* Sangeet.app */,
153 | 00E356EE1AD99517003FC87E /* SangeetTests.xctest */,
154 | 2D02E47B1E0B4A5D006451C7 /* Sangeet-tvOS.app */,
155 | 2D02E4901E0B4A5D006451C7 /* Sangeet-tvOSTests.xctest */,
156 | );
157 | name = Products;
158 | sourceTree = "";
159 | };
160 | /* End PBXGroup section */
161 |
162 | /* Begin PBXNativeTarget section */
163 | 00E356ED1AD99517003FC87E /* SangeetTests */ = {
164 | isa = PBXNativeTarget;
165 | buildConfigurationList = 00E357021AD99517003FC87E /* Build configuration list for PBXNativeTarget "SangeetTests" */;
166 | buildPhases = (
167 | 00E356EA1AD99517003FC87E /* Sources */,
168 | 00E356EB1AD99517003FC87E /* Frameworks */,
169 | 00E356EC1AD99517003FC87E /* Resources */,
170 | );
171 | buildRules = (
172 | );
173 | dependencies = (
174 | 00E356F51AD99517003FC87E /* PBXTargetDependency */,
175 | );
176 | name = SangeetTests;
177 | productName = SangeetTests;
178 | productReference = 00E356EE1AD99517003FC87E /* SangeetTests.xctest */;
179 | productType = "com.apple.product-type.bundle.unit-test";
180 | };
181 | 13B07F861A680F5B00A75B9A /* Sangeet */ = {
182 | isa = PBXNativeTarget;
183 | buildConfigurationList = 13B07F931A680F5B00A75B9A /* Build configuration list for PBXNativeTarget "Sangeet" */;
184 | buildPhases = (
185 | FD10A7F022414F080027D42C /* Start Packager */,
186 | 13B07F871A680F5B00A75B9A /* Sources */,
187 | 13B07F8C1A680F5B00A75B9A /* Frameworks */,
188 | 13B07F8E1A680F5B00A75B9A /* Resources */,
189 | 00DD1BFF1BD5951E006B06BC /* Bundle React Native code and images */,
190 | );
191 | buildRules = (
192 | );
193 | dependencies = (
194 | );
195 | name = Sangeet;
196 | productName = Sangeet;
197 | productReference = 13B07F961A680F5B00A75B9A /* Sangeet.app */;
198 | productType = "com.apple.product-type.application";
199 | };
200 | 2D02E47A1E0B4A5D006451C7 /* Sangeet-tvOS */ = {
201 | isa = PBXNativeTarget;
202 | buildConfigurationList = 2D02E4BA1E0B4A5E006451C7 /* Build configuration list for PBXNativeTarget "Sangeet-tvOS" */;
203 | buildPhases = (
204 | FD10A7F122414F3F0027D42C /* Start Packager */,
205 | 2D02E4771E0B4A5D006451C7 /* Sources */,
206 | 2D02E4781E0B4A5D006451C7 /* Frameworks */,
207 | 2D02E4791E0B4A5D006451C7 /* Resources */,
208 | 2D02E4CB1E0B4B27006451C7 /* Bundle React Native Code And Images */,
209 | );
210 | buildRules = (
211 | );
212 | dependencies = (
213 | );
214 | name = "Sangeet-tvOS";
215 | productName = "Sangeet-tvOS";
216 | productReference = 2D02E47B1E0B4A5D006451C7 /* Sangeet-tvOS.app */;
217 | productType = "com.apple.product-type.application";
218 | };
219 | 2D02E48F1E0B4A5D006451C7 /* Sangeet-tvOSTests */ = {
220 | isa = PBXNativeTarget;
221 | buildConfigurationList = 2D02E4BB1E0B4A5E006451C7 /* Build configuration list for PBXNativeTarget "Sangeet-tvOSTests" */;
222 | buildPhases = (
223 | 2D02E48C1E0B4A5D006451C7 /* Sources */,
224 | 2D02E48D1E0B4A5D006451C7 /* Frameworks */,
225 | 2D02E48E1E0B4A5D006451C7 /* Resources */,
226 | );
227 | buildRules = (
228 | );
229 | dependencies = (
230 | 2D02E4921E0B4A5D006451C7 /* PBXTargetDependency */,
231 | );
232 | name = "Sangeet-tvOSTests";
233 | productName = "Sangeet-tvOSTests";
234 | productReference = 2D02E4901E0B4A5D006451C7 /* Sangeet-tvOSTests.xctest */;
235 | productType = "com.apple.product-type.bundle.unit-test";
236 | };
237 | /* End PBXNativeTarget section */
238 |
239 | /* Begin PBXProject section */
240 | 83CBB9F71A601CBA00E9B192 /* Project object */ = {
241 | isa = PBXProject;
242 | attributes = {
243 | LastUpgradeCheck = 1130;
244 | TargetAttributes = {
245 | 00E356ED1AD99517003FC87E = {
246 | CreatedOnToolsVersion = 6.2;
247 | TestTargetID = 13B07F861A680F5B00A75B9A;
248 | };
249 | 13B07F861A680F5B00A75B9A = {
250 | LastSwiftMigration = 1120;
251 | };
252 | 2D02E47A1E0B4A5D006451C7 = {
253 | CreatedOnToolsVersion = 8.2.1;
254 | ProvisioningStyle = Automatic;
255 | };
256 | 2D02E48F1E0B4A5D006451C7 = {
257 | CreatedOnToolsVersion = 8.2.1;
258 | ProvisioningStyle = Automatic;
259 | TestTargetID = 2D02E47A1E0B4A5D006451C7;
260 | };
261 | };
262 | };
263 | buildConfigurationList = 83CBB9FA1A601CBA00E9B192 /* Build configuration list for PBXProject "Sangeet" */;
264 | compatibilityVersion = "Xcode 3.2";
265 | developmentRegion = en;
266 | hasScannedForEncodings = 0;
267 | knownRegions = (
268 | en,
269 | Base,
270 | );
271 | mainGroup = 83CBB9F61A601CBA00E9B192;
272 | productRefGroup = 83CBBA001A601CBA00E9B192 /* Products */;
273 | projectDirPath = "";
274 | projectRoot = "";
275 | targets = (
276 | 13B07F861A680F5B00A75B9A /* Sangeet */,
277 | 00E356ED1AD99517003FC87E /* SangeetTests */,
278 | 2D02E47A1E0B4A5D006451C7 /* Sangeet-tvOS */,
279 | 2D02E48F1E0B4A5D006451C7 /* Sangeet-tvOSTests */,
280 | );
281 | };
282 | /* End PBXProject section */
283 |
284 | /* Begin PBXResourcesBuildPhase section */
285 | 00E356EC1AD99517003FC87E /* Resources */ = {
286 | isa = PBXResourcesBuildPhase;
287 | buildActionMask = 2147483647;
288 | files = (
289 | );
290 | runOnlyForDeploymentPostprocessing = 0;
291 | };
292 | 13B07F8E1A680F5B00A75B9A /* Resources */ = {
293 | isa = PBXResourcesBuildPhase;
294 | buildActionMask = 2147483647;
295 | files = (
296 | 81AB9BB82411601600AC10FF /* LaunchScreen.storyboard in Resources */,
297 | 13B07FBF1A68108700A75B9A /* Images.xcassets in Resources */,
298 | );
299 | runOnlyForDeploymentPostprocessing = 0;
300 | };
301 | 2D02E4791E0B4A5D006451C7 /* Resources */ = {
302 | isa = PBXResourcesBuildPhase;
303 | buildActionMask = 2147483647;
304 | files = (
305 | 2D02E4BD1E0B4A84006451C7 /* Images.xcassets in Resources */,
306 | );
307 | runOnlyForDeploymentPostprocessing = 0;
308 | };
309 | 2D02E48E1E0B4A5D006451C7 /* Resources */ = {
310 | isa = PBXResourcesBuildPhase;
311 | buildActionMask = 2147483647;
312 | files = (
313 | );
314 | runOnlyForDeploymentPostprocessing = 0;
315 | };
316 | /* End PBXResourcesBuildPhase section */
317 |
318 | /* Begin PBXShellScriptBuildPhase section */
319 | 00DD1BFF1BD5951E006B06BC /* Bundle React Native code and images */ = {
320 | isa = PBXShellScriptBuildPhase;
321 | buildActionMask = 2147483647;
322 | files = (
323 | );
324 | inputPaths = (
325 | );
326 | name = "Bundle React Native code and images";
327 | outputPaths = (
328 | );
329 | runOnlyForDeploymentPostprocessing = 0;
330 | shellPath = /bin/sh;
331 | shellScript = "export NODE_BINARY=node\n../node_modules/react-native/scripts/react-native-xcode.sh";
332 | };
333 | 2D02E4CB1E0B4B27006451C7 /* Bundle React Native Code And Images */ = {
334 | isa = PBXShellScriptBuildPhase;
335 | buildActionMask = 2147483647;
336 | files = (
337 | );
338 | inputPaths = (
339 | );
340 | name = "Bundle React Native Code And Images";
341 | outputPaths = (
342 | );
343 | runOnlyForDeploymentPostprocessing = 0;
344 | shellPath = /bin/sh;
345 | shellScript = "export NODE_BINARY=node\n../node_modules/react-native/scripts/react-native-xcode.sh";
346 | };
347 | FD10A7F022414F080027D42C /* Start Packager */ = {
348 | isa = PBXShellScriptBuildPhase;
349 | buildActionMask = 2147483647;
350 | files = (
351 | );
352 | inputFileListPaths = (
353 | );
354 | inputPaths = (
355 | );
356 | name = "Start Packager";
357 | outputFileListPaths = (
358 | );
359 | outputPaths = (
360 | );
361 | runOnlyForDeploymentPostprocessing = 0;
362 | shellPath = /bin/sh;
363 | shellScript = "export RCT_METRO_PORT=\"${RCT_METRO_PORT:=8081}\"\necho \"export RCT_METRO_PORT=${RCT_METRO_PORT}\" > \"${SRCROOT}/../node_modules/react-native/scripts/.packager.env\"\nif [ -z \"${RCT_NO_LAUNCH_PACKAGER+xxx}\" ] ; then\n if nc -w 5 -z localhost ${RCT_METRO_PORT} ; then\n if ! curl -s \"http://localhost:${RCT_METRO_PORT}/status\" | grep -q \"packager-status:running\" ; then\n echo \"Port ${RCT_METRO_PORT} already in use, packager is either not running or not running correctly\"\n exit 2\n fi\n else\n open \"$SRCROOT/../node_modules/react-native/scripts/launchPackager.command\" || echo \"Can't start packager automatically\"\n fi\nfi\n";
364 | showEnvVarsInLog = 0;
365 | };
366 | FD10A7F122414F3F0027D42C /* Start Packager */ = {
367 | isa = PBXShellScriptBuildPhase;
368 | buildActionMask = 2147483647;
369 | files = (
370 | );
371 | inputFileListPaths = (
372 | );
373 | inputPaths = (
374 | );
375 | name = "Start Packager";
376 | outputFileListPaths = (
377 | );
378 | outputPaths = (
379 | );
380 | runOnlyForDeploymentPostprocessing = 0;
381 | shellPath = /bin/sh;
382 | shellScript = "export RCT_METRO_PORT=\"${RCT_METRO_PORT:=8081}\"\necho \"export RCT_METRO_PORT=${RCT_METRO_PORT}\" > \"${SRCROOT}/../node_modules/react-native/scripts/.packager.env\"\nif [ -z \"${RCT_NO_LAUNCH_PACKAGER+xxx}\" ] ; then\n if nc -w 5 -z localhost ${RCT_METRO_PORT} ; then\n if ! curl -s \"http://localhost:${RCT_METRO_PORT}/status\" | grep -q \"packager-status:running\" ; then\n echo \"Port ${RCT_METRO_PORT} already in use, packager is either not running or not running correctly\"\n exit 2\n fi\n else\n open \"$SRCROOT/../node_modules/react-native/scripts/launchPackager.command\" || echo \"Can't start packager automatically\"\n fi\nfi\n";
383 | showEnvVarsInLog = 0;
384 | };
385 | /* End PBXShellScriptBuildPhase section */
386 |
387 | /* Begin PBXSourcesBuildPhase section */
388 | 00E356EA1AD99517003FC87E /* Sources */ = {
389 | isa = PBXSourcesBuildPhase;
390 | buildActionMask = 2147483647;
391 | files = (
392 | 00E356F31AD99517003FC87E /* SangeetTests.m in Sources */,
393 | );
394 | runOnlyForDeploymentPostprocessing = 0;
395 | };
396 | 13B07F871A680F5B00A75B9A /* Sources */ = {
397 | isa = PBXSourcesBuildPhase;
398 | buildActionMask = 2147483647;
399 | files = (
400 | 13B07FBC1A68108700A75B9A /* AppDelegate.m in Sources */,
401 | 13B07FC11A68108700A75B9A /* main.m in Sources */,
402 | );
403 | runOnlyForDeploymentPostprocessing = 0;
404 | };
405 | 2D02E4771E0B4A5D006451C7 /* Sources */ = {
406 | isa = PBXSourcesBuildPhase;
407 | buildActionMask = 2147483647;
408 | files = (
409 | 2D02E4BF1E0B4AB3006451C7 /* main.m in Sources */,
410 | 2D02E4BC1E0B4A80006451C7 /* AppDelegate.m in Sources */,
411 | );
412 | runOnlyForDeploymentPostprocessing = 0;
413 | };
414 | 2D02E48C1E0B4A5D006451C7 /* Sources */ = {
415 | isa = PBXSourcesBuildPhase;
416 | buildActionMask = 2147483647;
417 | files = (
418 | 2DCD954D1E0B4F2C00145EB5 /* SangeetTests.m in Sources */,
419 | );
420 | runOnlyForDeploymentPostprocessing = 0;
421 | };
422 | /* End PBXSourcesBuildPhase section */
423 |
424 | /* Begin PBXTargetDependency section */
425 | 00E356F51AD99517003FC87E /* PBXTargetDependency */ = {
426 | isa = PBXTargetDependency;
427 | target = 13B07F861A680F5B00A75B9A /* Sangeet */;
428 | targetProxy = 00E356F41AD99517003FC87E /* PBXContainerItemProxy */;
429 | };
430 | 2D02E4921E0B4A5D006451C7 /* PBXTargetDependency */ = {
431 | isa = PBXTargetDependency;
432 | target = 2D02E47A1E0B4A5D006451C7 /* Sangeet-tvOS */;
433 | targetProxy = 2D02E4911E0B4A5D006451C7 /* PBXContainerItemProxy */;
434 | };
435 | /* End PBXTargetDependency section */
436 |
437 | /* Begin XCBuildConfiguration section */
438 | 00E356F61AD99517003FC87E /* Debug */ = {
439 | isa = XCBuildConfiguration;
440 | buildSettings = {
441 | BUNDLE_LOADER = "$(TEST_HOST)";
442 | GCC_PREPROCESSOR_DEFINITIONS = (
443 | "DEBUG=1",
444 | "$(inherited)",
445 | );
446 | INFOPLIST_FILE = SangeetTests/Info.plist;
447 | IPHONEOS_DEPLOYMENT_TARGET = 10.0;
448 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks";
449 | OTHER_LDFLAGS = (
450 | "-ObjC",
451 | "-lc++",
452 | "$(inherited)",
453 | );
454 | PRODUCT_BUNDLE_IDENTIFIER = "org.reactjs.native.example.$(PRODUCT_NAME:rfc1034identifier)";
455 | PRODUCT_NAME = "$(TARGET_NAME)";
456 | TEST_HOST = "$(BUILT_PRODUCTS_DIR)/Sangeet.app/Sangeet";
457 | };
458 | name = Debug;
459 | };
460 | 00E356F71AD99517003FC87E /* Release */ = {
461 | isa = XCBuildConfiguration;
462 | buildSettings = {
463 | BUNDLE_LOADER = "$(TEST_HOST)";
464 | COPY_PHASE_STRIP = NO;
465 | INFOPLIST_FILE = SangeetTests/Info.plist;
466 | IPHONEOS_DEPLOYMENT_TARGET = 10.0;
467 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks";
468 | OTHER_LDFLAGS = (
469 | "-ObjC",
470 | "-lc++",
471 | "$(inherited)",
472 | );
473 | PRODUCT_BUNDLE_IDENTIFIER = "org.reactjs.native.example.$(PRODUCT_NAME:rfc1034identifier)";
474 | PRODUCT_NAME = "$(TARGET_NAME)";
475 | TEST_HOST = "$(BUILT_PRODUCTS_DIR)/Sangeet.app/Sangeet";
476 | };
477 | name = Release;
478 | };
479 | 13B07F941A680F5B00A75B9A /* Debug */ = {
480 | isa = XCBuildConfiguration;
481 | buildSettings = {
482 | ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
483 | CLANG_ENABLE_MODULES = YES;
484 | CURRENT_PROJECT_VERSION = 1;
485 | ENABLE_BITCODE = NO;
486 | INFOPLIST_FILE = Sangeet/Info.plist;
487 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks";
488 | OTHER_LDFLAGS = (
489 | "$(inherited)",
490 | "-ObjC",
491 | "-lc++",
492 | );
493 | PRODUCT_BUNDLE_IDENTIFIER = "org.reactjs.native.example.$(PRODUCT_NAME:rfc1034identifier)";
494 | PRODUCT_NAME = Sangeet;
495 | SWIFT_OPTIMIZATION_LEVEL = "-Onone";
496 | SWIFT_VERSION = 5.0;
497 | VERSIONING_SYSTEM = "apple-generic";
498 | };
499 | name = Debug;
500 | };
501 | 13B07F951A680F5B00A75B9A /* Release */ = {
502 | isa = XCBuildConfiguration;
503 | buildSettings = {
504 | ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
505 | CLANG_ENABLE_MODULES = YES;
506 | CURRENT_PROJECT_VERSION = 1;
507 | INFOPLIST_FILE = Sangeet/Info.plist;
508 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks";
509 | OTHER_LDFLAGS = (
510 | "$(inherited)",
511 | "-ObjC",
512 | "-lc++",
513 | );
514 | PRODUCT_BUNDLE_IDENTIFIER = "org.reactjs.native.example.$(PRODUCT_NAME:rfc1034identifier)";
515 | PRODUCT_NAME = Sangeet;
516 | SWIFT_VERSION = 5.0;
517 | VERSIONING_SYSTEM = "apple-generic";
518 | };
519 | name = Release;
520 | };
521 | 2D02E4971E0B4A5E006451C7 /* Debug */ = {
522 | isa = XCBuildConfiguration;
523 | buildSettings = {
524 | ASSETCATALOG_COMPILER_APPICON_NAME = "App Icon & Top Shelf Image";
525 | ASSETCATALOG_COMPILER_LAUNCHIMAGE_NAME = LaunchImage;
526 | CLANG_ANALYZER_NONNULL = YES;
527 | CLANG_WARN_DOCUMENTATION_COMMENTS = YES;
528 | CLANG_WARN_INFINITE_RECURSION = YES;
529 | CLANG_WARN_SUSPICIOUS_MOVE = YES;
530 | DEBUG_INFORMATION_FORMAT = dwarf;
531 | ENABLE_TESTABILITY = YES;
532 | GCC_NO_COMMON_BLOCKS = YES;
533 | INFOPLIST_FILE = "Sangeet-tvOS/Info.plist";
534 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks";
535 | OTHER_LDFLAGS = (
536 | "$(inherited)",
537 | "-ObjC",
538 | "-lc++",
539 | );
540 | PRODUCT_BUNDLE_IDENTIFIER = "org.reactjs.native.example.Sangeet-tvOS";
541 | PRODUCT_NAME = "$(TARGET_NAME)";
542 | SDKROOT = appletvos;
543 | TARGETED_DEVICE_FAMILY = 3;
544 | TVOS_DEPLOYMENT_TARGET = 10.0;
545 | };
546 | name = Debug;
547 | };
548 | 2D02E4981E0B4A5E006451C7 /* Release */ = {
549 | isa = XCBuildConfiguration;
550 | buildSettings = {
551 | ASSETCATALOG_COMPILER_APPICON_NAME = "App Icon & Top Shelf Image";
552 | ASSETCATALOG_COMPILER_LAUNCHIMAGE_NAME = LaunchImage;
553 | CLANG_ANALYZER_NONNULL = YES;
554 | CLANG_WARN_DOCUMENTATION_COMMENTS = YES;
555 | CLANG_WARN_INFINITE_RECURSION = YES;
556 | CLANG_WARN_SUSPICIOUS_MOVE = YES;
557 | COPY_PHASE_STRIP = NO;
558 | DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym";
559 | GCC_NO_COMMON_BLOCKS = YES;
560 | INFOPLIST_FILE = "Sangeet-tvOS/Info.plist";
561 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks";
562 | OTHER_LDFLAGS = (
563 | "$(inherited)",
564 | "-ObjC",
565 | "-lc++",
566 | );
567 | PRODUCT_BUNDLE_IDENTIFIER = "org.reactjs.native.example.Sangeet-tvOS";
568 | PRODUCT_NAME = "$(TARGET_NAME)";
569 | SDKROOT = appletvos;
570 | TARGETED_DEVICE_FAMILY = 3;
571 | TVOS_DEPLOYMENT_TARGET = 10.0;
572 | };
573 | name = Release;
574 | };
575 | 2D02E4991E0B4A5E006451C7 /* Debug */ = {
576 | isa = XCBuildConfiguration;
577 | buildSettings = {
578 | BUNDLE_LOADER = "$(TEST_HOST)";
579 | CLANG_ANALYZER_NONNULL = YES;
580 | CLANG_WARN_DOCUMENTATION_COMMENTS = YES;
581 | CLANG_WARN_INFINITE_RECURSION = YES;
582 | CLANG_WARN_SUSPICIOUS_MOVE = YES;
583 | DEBUG_INFORMATION_FORMAT = dwarf;
584 | ENABLE_TESTABILITY = YES;
585 | GCC_NO_COMMON_BLOCKS = YES;
586 | INFOPLIST_FILE = "Sangeet-tvOSTests/Info.plist";
587 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks";
588 | OTHER_LDFLAGS = (
589 | "$(inherited)",
590 | "-ObjC",
591 | "-lc++",
592 | );
593 | PRODUCT_BUNDLE_IDENTIFIER = "org.reactjs.native.example.Sangeet-tvOSTests";
594 | PRODUCT_NAME = "$(TARGET_NAME)";
595 | SDKROOT = appletvos;
596 | TEST_HOST = "$(BUILT_PRODUCTS_DIR)/Sangeet-tvOS.app/Sangeet-tvOS";
597 | TVOS_DEPLOYMENT_TARGET = 10.1;
598 | };
599 | name = Debug;
600 | };
601 | 2D02E49A1E0B4A5E006451C7 /* Release */ = {
602 | isa = XCBuildConfiguration;
603 | buildSettings = {
604 | BUNDLE_LOADER = "$(TEST_HOST)";
605 | CLANG_ANALYZER_NONNULL = YES;
606 | CLANG_WARN_DOCUMENTATION_COMMENTS = YES;
607 | CLANG_WARN_INFINITE_RECURSION = YES;
608 | CLANG_WARN_SUSPICIOUS_MOVE = YES;
609 | COPY_PHASE_STRIP = NO;
610 | DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym";
611 | GCC_NO_COMMON_BLOCKS = YES;
612 | INFOPLIST_FILE = "Sangeet-tvOSTests/Info.plist";
613 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks";
614 | OTHER_LDFLAGS = (
615 | "$(inherited)",
616 | "-ObjC",
617 | "-lc++",
618 | );
619 | PRODUCT_BUNDLE_IDENTIFIER = "org.reactjs.native.example.Sangeet-tvOSTests";
620 | PRODUCT_NAME = "$(TARGET_NAME)";
621 | SDKROOT = appletvos;
622 | TEST_HOST = "$(BUILT_PRODUCTS_DIR)/Sangeet-tvOS.app/Sangeet-tvOS";
623 | TVOS_DEPLOYMENT_TARGET = 10.1;
624 | };
625 | name = Release;
626 | };
627 | 83CBBA201A601CBA00E9B192 /* Debug */ = {
628 | isa = XCBuildConfiguration;
629 | buildSettings = {
630 | ALWAYS_SEARCH_USER_PATHS = NO;
631 | CLANG_ANALYZER_LOCALIZABILITY_NONLOCALIZED = YES;
632 | CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x";
633 | CLANG_CXX_LIBRARY = "libc++";
634 | CLANG_ENABLE_MODULES = YES;
635 | CLANG_ENABLE_OBJC_ARC = YES;
636 | CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES;
637 | CLANG_WARN_BOOL_CONVERSION = YES;
638 | CLANG_WARN_COMMA = YES;
639 | CLANG_WARN_CONSTANT_CONVERSION = YES;
640 | CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES;
641 | CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;
642 | CLANG_WARN_EMPTY_BODY = YES;
643 | CLANG_WARN_ENUM_CONVERSION = YES;
644 | CLANG_WARN_INFINITE_RECURSION = YES;
645 | CLANG_WARN_INT_CONVERSION = YES;
646 | CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES;
647 | CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES;
648 | CLANG_WARN_OBJC_LITERAL_CONVERSION = YES;
649 | CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
650 | CLANG_WARN_RANGE_LOOP_ANALYSIS = YES;
651 | CLANG_WARN_STRICT_PROTOTYPES = YES;
652 | CLANG_WARN_SUSPICIOUS_MOVE = YES;
653 | CLANG_WARN_UNREACHABLE_CODE = YES;
654 | CLANG_WARN__DUPLICATE_METHOD_MATCH = YES;
655 | "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer";
656 | COPY_PHASE_STRIP = NO;
657 | ENABLE_STRICT_OBJC_MSGSEND = YES;
658 | ENABLE_TESTABILITY = YES;
659 | GCC_C_LANGUAGE_STANDARD = gnu99;
660 | GCC_DYNAMIC_NO_PIC = NO;
661 | GCC_NO_COMMON_BLOCKS = YES;
662 | GCC_OPTIMIZATION_LEVEL = 0;
663 | GCC_PREPROCESSOR_DEFINITIONS = (
664 | "DEBUG=1",
665 | "$(inherited)",
666 | );
667 | GCC_SYMBOLS_PRIVATE_EXTERN = NO;
668 | GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
669 | GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;
670 | GCC_WARN_UNDECLARED_SELECTOR = YES;
671 | GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
672 | GCC_WARN_UNUSED_FUNCTION = YES;
673 | GCC_WARN_UNUSED_VARIABLE = YES;
674 | IPHONEOS_DEPLOYMENT_TARGET = 10.0;
675 | LD_RUNPATH_SEARCH_PATHS = "/usr/lib/swift $(inherited)";
676 | LIBRARY_SEARCH_PATHS = (
677 | "\"$(TOOLCHAIN_DIR)/usr/lib/swift/$(PLATFORM_NAME)\"",
678 | "\"$(TOOLCHAIN_DIR)/usr/lib/swift-5.0/$(PLATFORM_NAME)\"",
679 | "\"$(inherited)\"",
680 | );
681 | MTL_ENABLE_DEBUG_INFO = YES;
682 | ONLY_ACTIVE_ARCH = YES;
683 | SDKROOT = iphoneos;
684 | };
685 | name = Debug;
686 | };
687 | 83CBBA211A601CBA00E9B192 /* Release */ = {
688 | isa = XCBuildConfiguration;
689 | buildSettings = {
690 | ALWAYS_SEARCH_USER_PATHS = NO;
691 | CLANG_ANALYZER_LOCALIZABILITY_NONLOCALIZED = YES;
692 | CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x";
693 | CLANG_CXX_LIBRARY = "libc++";
694 | CLANG_ENABLE_MODULES = YES;
695 | CLANG_ENABLE_OBJC_ARC = YES;
696 | CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES;
697 | CLANG_WARN_BOOL_CONVERSION = YES;
698 | CLANG_WARN_COMMA = YES;
699 | CLANG_WARN_CONSTANT_CONVERSION = YES;
700 | CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES;
701 | CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;
702 | CLANG_WARN_EMPTY_BODY = YES;
703 | CLANG_WARN_ENUM_CONVERSION = YES;
704 | CLANG_WARN_INFINITE_RECURSION = YES;
705 | CLANG_WARN_INT_CONVERSION = YES;
706 | CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES;
707 | CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES;
708 | CLANG_WARN_OBJC_LITERAL_CONVERSION = YES;
709 | CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
710 | CLANG_WARN_RANGE_LOOP_ANALYSIS = YES;
711 | CLANG_WARN_STRICT_PROTOTYPES = YES;
712 | CLANG_WARN_SUSPICIOUS_MOVE = YES;
713 | CLANG_WARN_UNREACHABLE_CODE = YES;
714 | CLANG_WARN__DUPLICATE_METHOD_MATCH = YES;
715 | "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer";
716 | COPY_PHASE_STRIP = YES;
717 | ENABLE_NS_ASSERTIONS = NO;
718 | ENABLE_STRICT_OBJC_MSGSEND = YES;
719 | GCC_C_LANGUAGE_STANDARD = gnu99;
720 | GCC_NO_COMMON_BLOCKS = YES;
721 | GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
722 | GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;
723 | GCC_WARN_UNDECLARED_SELECTOR = YES;
724 | GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
725 | GCC_WARN_UNUSED_FUNCTION = YES;
726 | GCC_WARN_UNUSED_VARIABLE = YES;
727 | IPHONEOS_DEPLOYMENT_TARGET = 10.0;
728 | LD_RUNPATH_SEARCH_PATHS = "/usr/lib/swift $(inherited)";
729 | LIBRARY_SEARCH_PATHS = (
730 | "\"$(TOOLCHAIN_DIR)/usr/lib/swift/$(PLATFORM_NAME)\"",
731 | "\"$(TOOLCHAIN_DIR)/usr/lib/swift-5.0/$(PLATFORM_NAME)\"",
732 | "\"$(inherited)\"",
733 | );
734 | MTL_ENABLE_DEBUG_INFO = NO;
735 | SDKROOT = iphoneos;
736 | VALIDATE_PRODUCT = YES;
737 | };
738 | name = Release;
739 | };
740 | /* End XCBuildConfiguration section */
741 |
742 | /* Begin XCConfigurationList section */
743 | 00E357021AD99517003FC87E /* Build configuration list for PBXNativeTarget "SangeetTests" */ = {
744 | isa = XCConfigurationList;
745 | buildConfigurations = (
746 | 00E356F61AD99517003FC87E /* Debug */,
747 | 00E356F71AD99517003FC87E /* Release */,
748 | );
749 | defaultConfigurationIsVisible = 0;
750 | defaultConfigurationName = Release;
751 | };
752 | 13B07F931A680F5B00A75B9A /* Build configuration list for PBXNativeTarget "Sangeet" */ = {
753 | isa = XCConfigurationList;
754 | buildConfigurations = (
755 | 13B07F941A680F5B00A75B9A /* Debug */,
756 | 13B07F951A680F5B00A75B9A /* Release */,
757 | );
758 | defaultConfigurationIsVisible = 0;
759 | defaultConfigurationName = Release;
760 | };
761 | 2D02E4BA1E0B4A5E006451C7 /* Build configuration list for PBXNativeTarget "Sangeet-tvOS" */ = {
762 | isa = XCConfigurationList;
763 | buildConfigurations = (
764 | 2D02E4971E0B4A5E006451C7 /* Debug */,
765 | 2D02E4981E0B4A5E006451C7 /* Release */,
766 | );
767 | defaultConfigurationIsVisible = 0;
768 | defaultConfigurationName = Release;
769 | };
770 | 2D02E4BB1E0B4A5E006451C7 /* Build configuration list for PBXNativeTarget "Sangeet-tvOSTests" */ = {
771 | isa = XCConfigurationList;
772 | buildConfigurations = (
773 | 2D02E4991E0B4A5E006451C7 /* Debug */,
774 | 2D02E49A1E0B4A5E006451C7 /* Release */,
775 | );
776 | defaultConfigurationIsVisible = 0;
777 | defaultConfigurationName = Release;
778 | };
779 | 83CBB9FA1A601CBA00E9B192 /* Build configuration list for PBXProject "Sangeet" */ = {
780 | isa = XCConfigurationList;
781 | buildConfigurations = (
782 | 83CBBA201A601CBA00E9B192 /* Debug */,
783 | 83CBBA211A601CBA00E9B192 /* Release */,
784 | );
785 | defaultConfigurationIsVisible = 0;
786 | defaultConfigurationName = Release;
787 | };
788 | /* End XCConfigurationList section */
789 | };
790 | rootObject = 83CBB9F71A601CBA00E9B192 /* Project object */;
791 | }
792 |
--------------------------------------------------------------------------------