Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/contigen/persist
A contact sharing progressive web app using the Contact Picker API, QR Codes and vCards to embed contact data for contactless/seamless transfer across devices on the Web
https://github.com/contigen/persist
contact-picker qrcode
Last synced: about 2 months ago
JSON representation
A contact sharing progressive web app using the Contact Picker API, QR Codes and vCards to embed contact data for contactless/seamless transfer across devices on the Web
- Host: GitHub
- URL: https://github.com/contigen/persist
- Owner: contigen
- Created: 2024-07-19T00:23:21.000Z (6 months ago)
- Default Branch: main
- Last Pushed: 2024-07-28T07:48:50.000Z (5 months ago)
- Last Synced: 2024-10-18T23:09:09.069Z (3 months ago)
- Topics: contact-picker, qrcode
- Language: TypeScript
- Homepage: https://persist-tau.vercel.app
- Size: 470 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Persist
A contact sharing progressive web app using the Contact Picker API, QR Codes and vCards to embed contact data for contactless/seamless transfer across devices on the Web. The app/PWA offers a refined way of sharing contacts during social interactions, events, networking sessions and whatnots.
It enables users to select contacts from their phonebook, generate vCard files to import contacts on other devices, and share them via dynamically generated QR codes.
The PWA is live at [persist-tau.vercel.app](https://persist-tau.vercel.app)# Features
- Contact Selection with Vibration Feedback: users can select contacts from their phonebook, with vibration feedback provided, via the Vibration API, to confirm their action
- Generate vCard files to import contacts on other devices
- Personal and shared contact forms, with local storage persistence
- Share contacts via dynamically generated QR codes - download & scan QR Codes in-app
- Imported contacts' list with link to each contact and local storage persistence
- Toast notifications for user feedback
- Progressive Web Application - Installable app## Technologies
- React
- TypeScript
- TailwindCSS for styling## Gotcha
The Contact Picker API only works in Chromium Browsers and Safari (requires enabling a feature flag).
Ability to save contacts directly has been revoked on the Web (Firefox's deprecated Contacts API)## Misc.
Other transfer protocols were evaluated like the Web Bluetooth API, WebSockets and even the Web NFC API, for contact sharing.
- **Web Bluetooth API**: The current implementation of the API doesn't allow for P2P connection.
- **WebSockets**: While WebSockets offer real-time communication capabilities, they require a server-side component to handle connections and message exchanges. This adds additional complexity and infrastructure requirements, which were deemed unnecessary for the current app state.
- **Web NFC API**: The Web NFC API enables interaction with NFC tags for contactless data transfer. Although promising, it is not yet widely supported across all devices and browsers, which will limit the app’s accessibility and functionality for users.
Quick Response Codes affords the best compatibility for the current app state: doesn't introduce any server-side effect, convenient for storage.
Regardless, future updates could include:
Remote Contact Sharing via WebSockets: Implementing WebSocket-based contact sharing could enable real-time updates and interactions, allowing users to exchange contact information instantly regardless of location.
Exporting Contacts to NFC Tags using Web NFC API for quick and intuitive data transfer.
## Usage
If you use this project, please provide appropriate credit to acknowledge the original work.
If this project inspires you to create something, I'd love to hear about it. Please reach out and share your work with me.
### Development dependencies
- `Vite` as the dev server with HMR and some ESLint rules.
- `VitePWA` to serve the app as a PWA for offline capabilities and native-like app feel
- `Bun` as the runtime### Development Scripts
To start the dev server:
```
bun install && bun run dev
```To build the app and start the prod server:
```
bun run build && bun run preview
```