Browse Source

feat: add claim route deep linking support

- Add claim route to deep link schema
- Add claim view test to deeplink tests
- Update build docs for clean web builds
- Add rm -rf dist to build steps

Technical Changes:
- Add claim schema with id parameter
- Add claim route test using generated claim ID
- Add clean step before web/capacitor builds
- Update Android build instructions

This adds support for deep linking to claim views and
improves the build process reliability by ensuring clean
builds. The claim route allows direct navigation to claim
details via external links.
pull/127/head
Matthew Raymer 2 days ago
parent
commit
b590e41ec8
  1. 44
      BUILDING.md
  2. 9
      src/services/deepLinks.ts
  3. 21
      src/types/deepLinks.ts
  4. 3
      test-scripts/run-deeplink-tests.sh

44
BUILDING.md

@ -135,6 +135,7 @@ Prerequisites: Android Studio with SDK installed
1. Build the web assets:
```bash
rm -rf dist
npm run build:web
npm run build:capacitor
```
@ -163,19 +164,19 @@ Prerequisites: Android Studio with SDK installed
You must add the following intent filter to the `android/app/src/main/AndroidManifest.xml` file:
```xml
```xml
<intent-filter android:autoVerify="true">
<action android:name="android.intent.action.VIEW" />
<category android:name="android.intent.category.DEFAULT" />
<category android:name="android.intent.category.BROWSABLE" />
<data android:scheme="timesafari" />
</intent-filter>
```
```
You must also add the following to the `android/app/build.gradle` file:
```gradle
android {
```gradle
android {
// ... existing config ...
lintOptions {
@ -189,13 +190,13 @@ android {
ignore 'LintBaseline'
ignore 'LintBaselineFixed'
}
}
```
}
```
Modify `/android/build.gradle` to use a stable version of AGP and make sure Kotlin version is compatible.
```gradle
buildscript {
```gradle
buildscript {
repositories {
google()
mavenCentral()
@ -207,32 +208,33 @@ buildscript {
// Make sure Kotlin version is compatible
classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:1.8.0"
}
}
}
allprojects {
allprojects {
repositories {
google()
mavenCentral()
}
}
}
// Add this to handle version conflicts
configurations.all {
// Add this to handle version conflicts
configurations.all {
resolutionStrategy {
force 'org.jetbrains.kotlin:kotlin-stdlib:1.8.0'
force 'org.jetbrains.kotlin:kotlin-stdlib-common:1.8.0'
}
}
```
}
```
## Building Android from the console
```bash
./gradlew clean
./gradlew build -Dlint.baselines.continue=true
npx cap
```
```bash
cd android
./gradlew clean
./gradlew build -Dlint.baselines.continue=true
cd ..
npx cap run android
```
## Development

9
src/services/deepLinks.ts

@ -110,11 +110,18 @@ export class DeepLinkHandler {
query: Record<string, string>,
): Promise<void> {
const routeMap: Record<string, string> = {
"user-profile": "user-profile",
"project": "project",
"onboard-meeting-setup": "onboard-meeting-setup",
"invite-one-accept": "invite-one-accept",
"contact-import": "contact-import",
"confirm-gift": "confirm-gift",
"claim": "claim",
"claim-cert": "claim-cert",
"claim-add-raw": "claim-add-raw",
"contact-edit": "contact-edit",
"contacts": "contacts",
did: "did"
"did": "did"
};
const routeName = routeMap[path];

21
src/types/deepLinks.ts

@ -36,6 +36,27 @@ export const baseUrlSchema = z.object({
// Parameter validation schemas for each route type
export const deepLinkSchemas = {
"user-profile": z.object({
id: z.string()
}),
"project-details": z.object({
id: z.string()
}),
"onboard-meeting-setup": z.object({
id: z.string()
}),
"invite-one-accept": z.object({
id: z.string()
}),
"contact-import": z.object({
jwt: z.string()
}),
"confirm-gift": z.object({
id: z.string()
}),
"claim": z.object({
id: z.string()
}),
"claim-cert": z.object({
id: z.string()
}),

3
test-scripts/run-deeplink-tests.sh

@ -104,6 +104,9 @@ main() {
CONTACTS=$(cat .generated/contacts.json)
# 1. Claim-based deeplinks
execute_deeplink "timesafari://claim/$(jq -r .claim_id <<< "$CLAIM_DETAILS")" \
"Testing claim view"
execute_deeplink "timesafari://claim-cert/$(jq -r .claim_id <<< "$CLAIM_DETAILS")" \
"Testing claim certificate view"

Loading…
Cancel
Save