Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/tamotam-com/tamotam-app
(π§ͺ Early Beta) π€ TamoTam. HangOut. Offline.
https://github.com/tamotam-com/tamotam-app
android entertainment event-app firebase firestore hacktoberfest hacktoberfest2024 ios javascript lifestyle lifestyle-app offline-app people react react-native react-native-app reactjs redux social-network typescript
Last synced: 3 months ago
JSON representation
(π§ͺ Early Beta) π€ TamoTam. HangOut. Offline.
- Host: GitHub
- URL: https://github.com/tamotam-com/tamotam-app
- Owner: tamotam-com
- Created: 2021-06-23T15:38:48.000Z (over 3 years ago)
- Default Branch: master
- Last Pushed: 2024-04-25T13:33:45.000Z (9 months ago)
- Last Synced: 2024-09-28T18:42:59.194Z (4 months ago)
- Topics: android, entertainment, event-app, firebase, firestore, hacktoberfest, hacktoberfest2024, ios, javascript, lifestyle, lifestyle-app, offline-app, people, react, react-native, react-native-app, reactjs, redux, social-network, typescript
- Language: TypeScript
- Homepage: https://tamotam.com
- Size: 2.87 MB
- Stars: 35
- Watchers: 1
- Forks: 4
- Open Issues: 33
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# π€ TamoTam. HangOut. Offline.
[![TamoTam in Apple App Store](docs/AppleAppStoreButton.png)](https://apps.apple.com/pl/app/tamotam-hangout-offline/id1625649957)
[![TamoTam in Google Play Store](docs/GooglePlayStoreButton.png)](https://play.google.com/store/apps/details?id=com.tamotam.application)## Description
Map with offline events happening around you. You don't need to log in or register.
### Go Online to be Offline.
TamoTam aims to limit online time spent on digital applications in favor of offline social life outside the screen.
The application aims to be minimalistic and exclude features such as:
- Addictive Feed,
- Destructive Notifications,
- Brain-affecting Likes,
- Comments, #StopHate,
- Share, #StopFakeNews,
- Other complicated Algorithms unconsciously affect your stay online.That's because we believe Social Media affects us mentally, such as Anxiety, Depression, Fear Of Missing Out (FOMO), Fear of Speaking Up, Isolation, and more.
Look what's happening around you in Real. Offline. Social Life.
Could you add your events (log in or registration required) to contribute to that idea?### Note
The application is in an early stage of development with a number of [improvements & issues](https://github.com/tamotam-com/tamotam-app/issues).
It will take time before the application will be complete, performant and user-friendly, but in late 2023 we expect Early Beta.Thanks in advance for understanding while reviewing TamoTam.
## Developers
That's an Open Source project; feel free to contribute.
### Frontend/JavaScript/Web Developer interested in React Native/JavaScript Mobile Development?
The project is a combination of a personal education project to learn JavaScript Mobile Development using `React Native` and business idea to create a mobile app with offline-only events to limit online time.
Therefore, even if that's just from business point of view super easy app for now, it contains several nice technical implementation, which helped me to understand the ecosystem on `React Native` and become better developer.
### Technological stack
- `React/Native` + `TypeScript`;
- `Redux`;
- Different databases (`Firebase`, `SQLite`, `AsyncStorage`);
- `AsyncStorage`, which is really comparable to `localStorage` we have on Web;
- Caching data using `AsyncStorage`;
- Making the Web code actually compiled & working with deployed app to the store;
- Logging & Monitoring to `Firebase Analytics`/`Firebase Performance Monitoring`;
- Reporting crashes to `Firebase Crashlytics`;
- Handling environmental variables in `Android`, `iOS`, and `Web` - changes in native code were required;
- Integration of 3rd party tools, like `Firebase`-* and `Google Maps`;
- Usage, looks & feel of `Material Design` (`React Native Paper`) in a real application.### Stay up to date
Keep yourself up to date about TamoTam and me motivated by giving a **Star** :-)
![Star TamoTam on GitHub](docs/star.webm)## Run it
### Android Simulator
1. Run on `Android Studio`
2. `yarn start`
3. `adb reverse tcp:8081 tcp:8081`Alternatively, `expo run:android --variant release`, for production version.
#### Kill Android Simulator
`adb -s emulator-5554 emu kill`, where `emulator-5554` is the emulator name.
### iOS Simulator
1. Build using `Xcode`, if the application isn't installed on the simulator
2. `yarn start`
3. `i`Alternatively, `expo run:ios --configuration Release`, for production version.
### Release
1. `eas build -p android`
2. `eas build -p ios`## Architecture
We're using `Redux`, but the easiest to understand the architecture is the image below with `Flux` architecture, which in fact is really similar. However, it's important to note we're using 1 store, like in `Redux` architecture.
![Data Flow Architecture image](docs/dataFlowArchitecture.png)
*Image source: https://www.freecodecamp.org/news/an-introduction-to-the-flux-architectural-pattern-674ea74775c9/*External API's, like `Ticketmaster`, provide +/- 10k of external events. The `TamoTam`'s client is fetching also events added by the user, from `Firebase`. After all events will be fetched, those are being cached locally, using [AsyncStorage](https://github.com/react-native-async-storage/async-storage). After events are being cached locally on a device, the user can save their favourite events. Those saved events are also saved locally on a device. Those are saved using `SQLite`. In addition to that, users can add their own events, and those are saved in `Firebase`.
![Application Architecture image](docs/applicationArchitecture.svg)
*Made using: https://app.diagrams.net*## In media
- [Codrops Newsletter](https://tympanus.net/codrops/collective/collective-736/)
- [React Status Newsletter](https://react.statuscode.com/issues/310)
- [Reddit r/reactnative](https://www.reddit.com/r/reactnative/comments/xzcxn8/react_native_typescript_app_with_firebase/)## Research
- [Brain Drain: The Mere Presence of Oneβs Own Smartphone Reduces Available Cognitive Capacity](https://www.journals.uchicago.edu/doi/full/10.1086/691462)
- [No More FOMO: Limiting Social Media Decreases Loneliness and Depression](https://guilfordjournals.com/doi/10.1521/jscp.2018.37.10.751)
- [Increases in Depression, SelfβHarm, and Suicide Among U.S. Adolescents After 2012 and Links to Technology Use: Possible Mechanisms](https://prcp.psychiatryonline.org/doi/full/10.1176/appi.prcp.20190015)
- [A systematic review: the influence of social media on depression, anxiety and psychological distress in adolescents](https://www.tandfonline.com/doi/full/10.1080/02673843.2019.1590851)
- [Cognitive Effects of Social Media Use: A Case of Older Adults](https://journals.sagepub.com/doi/full/10.1177/2056305118787203)
- [Associations between smartphone use and mental health and well-being among young Swiss men](https://www.sciencedirect.com/science/article/pii/S002239562200588X)
- [Excessive Smartphone Use Is Associated With Health Problems in Adolescents and Young Adults](https://www.frontiersin.org/articles/10.3389/fpsyt.2021.669042/full)## Contact
contact[at]tamotam[dot]com
(demo) number of Android downloads badge: [https://playbadges.pavi2410.me/badge/full?id=com.tamotam.application](https://playbadges.pavi2410.me/badge/full?id=com.tamotam.application)