Skip to content

Commit

Permalink
Merge branch 'tap-to-pay' of https://github.com/hackclub/hcb-mobile i…
Browse files Browse the repository at this point in the history
…nto tap-to-pay
  • Loading branch information
YodaLightsabr committed Dec 8, 2024
2 parents 04973f1 + ad1dd5e commit 0bba00b
Show file tree
Hide file tree
Showing 4 changed files with 71 additions and 4 deletions.
2 changes: 2 additions & 0 deletions .env
Original file line number Diff line number Diff line change
@@ -1 +1,3 @@
EXPO_PUBLIC_API_BASE=https://hcb.hackclub.com/api/v4
EXPO_PUBLIC_CLIENT_ID=yt8JHmPDmmYYLUmoEiGtocYwg5fSOGCrcIY3G-vkMRs
EXPO_PUBLIC_STRIPE_API_KEY=pk_live_UAjIP1Kss29XZ6tW0MFWkjUQ
42 changes: 41 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -9,10 +9,50 @@

</div>

## Setup

HCB Mobile connects to HCB throught the v4 API.
You can either connect to the production HCB instance, or a local development instance.

### Production HCB

Set your `.env` to include the following variables:

```
EXPO_PUBLIC_API_BASE=https://hcb.hackclub.com/api/v4
EXPO_PUBLIC_CLIENT_ID=yt8JHmPDmmYYLUmoEiGtocYwg5fSOGCrcIY3G-vkMRs
EXPO_PUBLIC_STRIPE_API_KEY=pk_live_UAjIP1Kss29XZ6tW0MFWkjUQ
```

### Development HCB

Go into the Rails console on your development server (`bin/rails c`), and run the following:

```
app = Doorkeeper::Application.create(name: "mobile", redirect_uri: "hcb://", scopes: ["read", "write"], confidential: false)
```

Then, set your `.env` to include the following variables:

```
EXPO_PUBLIC_API_BASE=http://<host>/api/v4
EXPO_PUBLIC_CLIENT_ID=<uid field from the Doorkeeper app>
```

## Building on iOS

1. Install Xcode/Node.js
2. `npm install`
3. `npm run ios` - builds and runs the app in a simulator
- Run with the `--device` flag to get a device selector, e.g. to run on a physical iPhone
- Run with the `-- --device` flag to get a device selector, e.g. to run on a physical iPhone
- Bonus task: fry an egg on your Mac while this runs

## Building on Android

1. Install Android Studio & Node.js
2. Setup a new AVD in Android Studio with api >= 34
3. Install & set your `JAVA_HOME` to a Java 17 SDK
4. `npm install`
5. `npm run android` - builds and runs the app in a simulator
- Run with the `-- --device` flag to get a device selector, e.g. to run on a physical Android phone
- Bonus task: painfully watch Gradle attempt to work
29 changes: 27 additions & 2 deletions src/components/PaymentCard.tsx
Original file line number Diff line number Diff line change
@@ -1,6 +1,13 @@
import { useTheme } from "@react-navigation/native";
import capitalize from "lodash/capitalize";
import { Text, View, ViewProps } from "react-native";
import { useEffect, useRef, useState } from "react";
import {
AppState,
type AppStateStatus,
Text,
View,
ViewProps,
} from "react-native";
// import Animated, {
// SharedTransition,
// withSpring,
Expand Down Expand Up @@ -28,6 +35,24 @@ export default function PaymentCard({
}: ViewProps & { card: Card; details?: CardDetails }) {
const { colors: themeColors, dark } = useTheme();

const appState = useRef(AppState.currentState);
const [isAppInBackground, setisAppInBackground] = useState(appState.current);

// Add listener for whenever app goes into the background on iOS
// to hide the card details (e.g. in app switcher)
// https://reactnative.dev/docs/appstate
useEffect(() => {
const subscription = AppState.addEventListener(
"change",
(nextAppState: AppStateStatus) => {
appState.current = nextAppState;
setisAppInBackground(appState.current);
},
);

return () => subscription.remove();
});

return (
<View
style={{
Expand Down Expand Up @@ -79,7 +104,7 @@ export default function PaymentCard({
fontFamily: "JetBrains Mono",
}}
>
{details
{details && isAppInBackground === "active"
? renderCardNumber(details.number)
: redactedCardNumber(card.last4)}
</Text>
Expand Down
2 changes: 1 addition & 1 deletion src/pages/organization/Donation.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -402,7 +402,7 @@ function Keyboard({ amount, setAmount} : any) {
const [error, setError] = useState(false);
function pressNumber(amount: string, number: number) {
if (
parseFloat(amount.replace("$", "0") + number) > 9999 ||
parseFloat(amount.replace("$", "0") + number) > 9999.99 ||
(amount == "$" && number == 0) ||
amount[amount.length - 3] == "."
) {
Expand Down

0 comments on commit 0bba00b

Please sign in to comment.