ओएस इंटिग्रेशन

वेब ऐप्लिकेशन का दायरा बहुत बड़ा होता है. ये कई प्लैटफ़ॉर्म पर काम करते हैं. इन्हें लिंक की मदद से आसानी से शेयर किया जा सकता है. हालांकि, आम तौर पर इनमें ऑपरेटिंग सिस्टम के साथ इंटिग्रेशन की सुविधा नहीं होती थी. कुछ समय पहले तक, इन्हें इंस्टॉल भी नहीं किया जा सकता था. हालांकि, अब ऐसा नहीं है. अब हम अपने PWA में काम की सुविधाएं जोड़ने के लिए, इस इंटिग्रेशन का फ़ायदा ले सकते हैं. आइए, इनमें से कुछ विकल्पों के बारे में जानें.

फ़ाइलों का इस्तेमाल करने वाले उपयोगकर्ता का सामान्य वर्कफ़्लो कुछ ऐसा दिखता है:

  • डिवाइस से कोई फ़ाइल या फ़ोल्डर चुनें और उसे सीधे खोलें.
  • उन फ़ाइलों या फ़ोल्डर में बदलाव करें और बदलावों को सीधे सेव करें.
  • नई फ़ाइलें और फ़ोल्डर बनाएं.

फ़ाइल सिस्टम ऐक्सेस एपीआई के आने से पहले, वेब ऐप्लिकेशन ऐसा नहीं कर सकते थे. फ़ाइलें खोलने के लिए, फ़ाइल अपलोड करना ज़रूरी था. साथ ही, बदलावों को सेव करने के लिए, उपयोगकर्ताओं को उन्हें डाउनलोड करना पड़ता था. साथ ही, वेब के पास उपयोगकर्ता के फ़ाइल सिस्टम में नई फ़ाइलें और फ़ोल्डर बनाने का कोई ऐक्सेस नहीं था.

फ़ाइल खोलना

किसी फ़ाइल को खोलने के लिए, हम window.showOpenFilePicker() तरीके का इस्तेमाल करते हैं. ध्यान दें कि इस तरीके के लिए, उपयोगकर्ता के जेस्चर की ज़रूरत होती है. जैसे, बटन पर क्लिक करना. फ़ाइल खोलने के लिए, बाकी सेटअप यहां दिया गया है:

  1. फ़ाइल सिस्टम ऐक्सेस के फ़ाइल पिकर एपीआई से फ़ाइल हैंडल कैप्चर करें. इससे आपको फ़ाइल के बारे में बुनियादी जानकारी मिलती है.
  2. हैंडल के getFile() तरीके का इस्तेमाल करने पर, आपको एक खास तरह का Blob मिलेगा, जिसे File कहा जाता है. इसमें फ़ाइल के बारे में, सिर्फ़ पढ़ने के लिए उपलब्ध अतिरिक्त प्रॉपर्टी (जैसे, नाम और पिछली बार बदलाव करने की तारीख) शामिल होती हैं. यह एक Blob है, इसलिए इसका कॉन्टेंट पाने के लिए, Blob के मेथड, जैसे कि text() को कॉल किया जा सकता है.
// Have the user select a file.
const [ handle ] = await window.showOpenFilePicker();
// Get the File object from the handle.
const file = await handle.getFile();
// Get the file content.
// Also available, slice(), stream(), arrayBuffer()
const content = await file.text();

बदलाव सेव किए जा रहे हैं

किसी फ़ाइल में किए गए बदलावों को सेव करने के लिए, आपको उपयोगकर्ता के जेस्चर की भी ज़रूरत होती है. इसके बाद:

  1. FileSystemWritableFileStream बनाने के लिए, फ़ाइल हैंडल का इस्तेमाल करें.
  2. स्ट्रीम में बदलाव करना. इससे फ़ाइल अपडेट नहीं होगी. इसके बजाय, आम तौर पर एक अस्थायी फ़ाइल बनाई जाती है.
  3. आखिर में, बदलाव करने के बाद स्ट्रीम को बंद करें. इससे, बदलावों को कुछ समय के लिए लागू करने के बजाय, हमेशा के लिए लागू कर दिया जाता है.

इसे कोड में देखें:

// Make a writable stream from the handle.
const writable = await handle.createWritable();
// Write the contents of the file to the stream.
await writable.write(contents);
// Close the file and write the contents to disk.
await writable.close();

फ़ाइल मैनेज करना

फ़ाइल सिस्टम ऐक्सेस एपीआई की मदद से, अपने ऐप्लिकेशन में फ़ाइलें खोली जा सकती हैं. हालांकि, क्या इसके उलट भी किया जा सकता है? उपयोगकर्ता, फ़ाइलें खोलने के लिए अपने पसंदीदा ऐप्लिकेशन को डिफ़ॉल्ट तौर पर सेट करना चाहते हैं. फ़ाइल मैनेज करने वाला एपीआई, एक्सपेरिमेंट के तौर पर उपलब्ध एक एपीआई है. इसकी मदद से, इंस्टॉल किए गए PWA: उपयोगकर्ता के डिवाइस पर फ़ाइल हैंडलर के तौर पर रजिस्टर कर सकते हैं. इसके लिए, वेब ऐप्लिकेशन मेनिफ़ेस्ट में मौजूद MIME टाइप और फ़ाइल एक्सटेंशन की जानकारी दी जाती है. इस्तेमाल किए जा सकने वाले एक्सटेंशन के लिए, फ़ाइल के कस्टम आइकॉन तय किए जा सकते हैं.

रजिस्टर होने के बाद, इंस्टॉल किया गया PWA, उपयोगकर्ता के फ़ाइल सिस्टम में एक विकल्प के तौर पर दिखेगा. इससे, उपयोगकर्ता सीधे उसमें फ़ाइल खोल पाएंगे. यहां टेक्स्ट फ़ाइलें पढ़ने के लिए, पीडब्ल्यूए के मेनिफ़ेस्ट सेटअप का उदाहरण दिया गया है:

...
"file_handlers": [
     {
         "action": "/open-file",
         "accept": {
             "text/*": [".txt"]
         }
     }
]
...

यूआरएल हैंडल करना

यूआरएल मैनेज करने की सुविधा की मदद से, आपका PWA ऑपरेटिंग सिस्टम से अपने दायरे में आने वाले लिंक कैप्चर कर सकता है. साथ ही, उन्हें डिफ़ॉल्ट ब्राउज़र टैब के बजाय, PWA विंडो में रेंडर कर सकता है. उदाहरण के लिए, अगर आपको PWA से लिंक करने वाला कोई मैसेज मिलता है या आपने अपने PWA में डीप लिंक (किसी खास कॉन्टेंट पर ले जाने वाला यूआरएल) पर क्लिक किया है, तो कॉन्टेंट एक स्टैंडअलोन विंडो में खुलेगा.

WebAPK का इस्तेमाल करने पर, यह सुविधा Android पर अपने-आप उपलब्ध हो जाती है. जैसे, जब उपयोगकर्ता Chrome की मदद से कोई PWA इंस्टॉल करते हैं. Safari से, iOS और iPadOS पर इंस्टॉल किए गए PWA के यूआरएल कैप्चर नहीं किए जा सकते.

वेब ब्राउज़र कम्यूनिटी ने डेस्कटॉप ब्राउज़र के लिए, एक नया स्पेसिफ़िकेशन बनाया है. फ़िलहाल, यह स्पेसिफ़िकेशन प्रयोग के तौर पर उपलब्ध है. इसमें मेनिफ़ेस्ट फ़ाइल का एक नया सदस्य जोड़ा गया है: url_handlers. इस प्रॉपर्टी में उन ऑरिजिन की सूची होनी चाहिए जिन्हें PWA कैप्चर करना चाहता है. आपके PWA के ऑरिजिन को अपने-आप अनुमति मिल जाएगी. साथ ही, हर दूसरे ऑरिजिन को web-app-origin-association नाम की फ़ाइल के ज़रिए, ऑपरेशन को मैनेज करने की अनुमति देनी होगी. उदाहरण के लिए, अगर आपके PWA का मेनिफ़ेस्ट, web.dev पर होस्ट किया गया है और आपको app.web.dev ऑरिजिन जोड़ना है, तो यह इस तरह दिखेगा:

"url_handlers": [
    {"origin": "https://app.web.dev"},
]

इस मामले में, ब्राउज़र यह जांच करेगा कि app.web.dev/.well-known/web-app-origin-association पर कोई फ़ाइल मौजूद है या नहीं. इसके लिए, वह PWA के स्कोप यूआरएल से यूआरएल हैंडल करने की सुविधा को स्वीकार करेगा. डेवलपर को यह फ़ाइल बनानी होगी. नीचे दिए गए उदाहरण में, फ़ाइल इस तरह दिखती है:

{
    "web_apps": [
        {
            "manifest": "/mypwa/app.webmanifest",
            "details": {
                "paths": [ "/*" ]
            }
        }
    ]
}

यूआरएल प्रोटोकॉल को हैंडल करना

यूआरएल हैंडल करने की सुविधा, स्टैंडर्ड https प्रोटोकॉल यूआरएल के साथ काम करती है. हालांकि, pwa:// जैसे कस्टम यूआरआई-स्कीम का इस्तेमाल किया जा सकता है. कई ऑपरेटिंग सिस्टम में, इंस्टॉल किए गए ऐप्लिकेशन को यह सुविधा तब मिलती है, जब वे अपने स्कीम रजिस्टर करते हैं.

PWA के लिए, यूआरएल प्रोटोकॉल हैंडलर एपीआई का इस्तेमाल करके यह सुविधा चालू की जाती है. यह सुविधा सिर्फ़ डेस्कटॉप डिवाइसों पर उपलब्ध है. ऐप्लिकेशन स्टोर पर अपना PWA उपलब्ध कराकर, सिर्फ़ मोबाइल डिवाइसों के लिए कस्टम प्रोटोकॉल की अनुमति दी जा सकती है.

रजिस्टर करने के लिए, registerProtocolHandler() तरीके का इस्तेमाल किया जा सकता है. इसके अलावा, अपने मेनिफ़ेस्ट में protocol_handlers सदस्य का इस्तेमाल किया जा सकता है. इसके लिए, अपनी पसंद की स्कीम और उस यूआरएल का इस्तेमाल करें जिसे आपको अपने PWA के कॉन्टेक्स्ट में लोड करना है. जैसे:

...
{
  "protocol_handlers": [
    {
      "protocol": "web+pwa",
      "url": "/from-protocol?value=%s"
    },
  ]
}
...

यूआरएल from-protocol को सही हैंडलर पर भेजा जा सकता है और अपने PWA में क्वेरी स्ट्रिंग value पाई जा सकती है. %s, उस यूआरएल का प्लेसहोल्डर है जिसकी वजह से कार्रवाई शुरू हुई. इसलिए, अगर आपके पास <a href="web+pwa://testing"> जैसा कोई लिंक है, तो आपका PWA /from-protocol?value=testing खोलेगा.

दूसरे ऐप्लिकेशन से कॉल करना

हर प्लैटफ़ॉर्म पर उपयोगकर्ताओं के डिवाइसों में इंस्टॉल किए गए किसी भी अन्य ऐप्लिकेशन (PWA या नहीं) से कनेक्ट करने के लिए, यूआरआई स्कीम का इस्तेमाल किया जा सकता है. आपको सिर्फ़ एक लिंक बनाना होगा या navigator.href का इस्तेमाल करके, अपनी पसंद के यूआरआई स्कीम पर जाना होगा. इसके लिए, यूआरएल-एस्केप किए गए फ़ॉर्म में आर्ग्युमेंट पास करें.

इसके लिए, आम तौर पर इस्तेमाल होने वाले स्टैंडर्ड स्कीम का इस्तेमाल किया जा सकता है. जैसे, फ़ोन कॉल के लिए tel:, ईमेल भेजने के लिए mailto: या टेक्स्ट मैसेज के लिए sms:. इसके अलावा, अन्य ऐप्लिकेशन के यूआरएल स्कीम के बारे में भी जाना जा सकता है. जैसे, मैसेजिंग, मैप, नेविगेशन, ऑनलाइन मीटिंग, सोशल नेटवर्क, और ऐप्लिकेशन स्टोर के लिए इस्तेमाल होने वाले स्कीम.

वेब शेयर

Browser Support

  • Chrome: 89.
  • Edge: 93.
  • Firefox: behind a flag.
  • Safari: 12.1.

Source

Web Share API की मदद से, आपका PWA, शेयर किए गए चैनल के ज़रिए डिवाइस में इंस्टॉल किए गए अन्य ऐप्लिकेशन को कॉन्टेंट भेज सकता है.

यह एपीआई सिर्फ़ उन ऑपरेटिंग सिस्टम पर उपलब्ध है जिनमें share प्रोसेस मौजूद है. इनमें Android, iOS, iPadOS, Windows, और ChromeOS शामिल हैं. इस तरह का आइटम शेयर किया जा सकता है:

  • टेक्स्ट (title और text प्रॉपर्टी)
  • यूआरएल (url प्रॉपर्टी)
  • फ़ाइलें (files प्रॉपर्टी).

यह देखने के लिए कि मौजूदा डिवाइस, टेक्स्ट जैसे आसान डेटा को शेयर कर सकता है या नहीं, navigator.share() तरीके की उपलब्धता देखें. फ़ाइलें शेयर करने के लिए, navigator.canShare() तरीके की उपलब्धता देखें.

navigator.share(objectToShare) को कॉल करके, शेयर करने का अनुरोध किया जाता है. यह कॉल एक Promise दिखाता है, जो undefined के साथ पूरा होता है या किसी अपवाद के साथ अस्वीकार होता है.

वेब शेयर की सुविधा की मदद से, Android पर Chrome और iOS पर Safari, शेयर शीट खोलते हुए.

वेब शेयर टारगेट

वेब शेयर टारगेट एपीआई की मदद से, आपके PWA को उस डिवाइस पर मौजूद किसी दूसरे ऐप्लिकेशन से शेयर करने की सुविधा मिलती है. भले ही, वह ऐप्लिकेशन PWA हो या न हो. आपके PWA को किसी दूसरे ऐप्लिकेशन से शेयर किया गया डेटा मिलता है.

फ़िलहाल, यह सुविधा Android पर WebAPK और ChromeOS के साथ उपलब्ध है. यह सुविधा सिर्फ़ तब काम करती है, जब उपयोगकर्ता आपका PWA इंस्टॉल कर लेता है. ऐप्लिकेशन इंस्टॉल होने पर, ब्राउज़र ऑपरेटिंग सिस्टम में शेयर टारगेट को रजिस्टर करता है.

आपने मेनिफ़ेस्ट में वेब शेयर टारगेट को वेब शेयर टारगेट के ड्राफ़्ट स्पेसिफ़िकेशन में बताए गए share_target सदस्य के साथ सेट अप किया है. share_target को कुछ प्रॉपर्टी वाले ऑब्जेक्ट पर सेट किया गया है:

action
यूआरएल, जिसे PWA विंडो में लोड किया जाएगा. इस विंडो में शेयर किया गया डेटा मिल सकता है.
method
कार्रवाई के लिए, एचटीटीपी वर्ब का तरीका इस्तेमाल किया जाएगा. जैसे, GET, POST या PUT.
enctype
(ज़रूरी नहीं) पैरामीटर के लिए, डिफ़ॉल्ट रूप से application/x-www-form-urlencoded कोडिंग टाइप होता है. हालांकि, POST जैसे तरीकों के लिए, इसे multipart/form-data के तौर पर भी सेट किया जा सकता है.
params
यह एक ऐसा ऑब्जेक्ट है जो वेब शेयर की title, text, url, और files बटन की मदद से शेयर किए गए डेटा को उन आर्ग्युमेंट से मैप करेगा जिन्हें ब्राउज़र, चुने गए कोड में बदलने की सुविधा का इस्तेमाल करके, यूआरएल (method: 'GET' पर) या अनुरोध के मुख्य हिस्से में पास करेगा.

उदाहरण के लिए, अपने मेनिफ़ेस्ट में जोड़कर, अपने PWA के लिए यह तय किया जा सकता है कि आपको शेयर किया गया डेटा (सिर्फ़ टाइटल और यूआरएल) चाहिए या नहीं:

...
"share_target": {
   "action": "/receive-share/",
   "method": "GET",
   "params": {
      "title": "shared_title",
      "url": "shared_url"
   }
}
...

पिछले सैंपल से, अगर सिस्टम में कोई ऐप्लिकेशन किसी टाइटल के साथ यूआरएल शेयर कर रहा है और उपयोगकर्ता डायलॉग से आपका PWA चुनता है, तो ब्राउज़र आपके ऑरिजिन के /receive-share/?shared_title=AAA&shared_url=BBB पर एक नया नेविगेशन बनाएगा. यहां AAA, शेयर किया गया टाइटल है और BBB, शेयर किया गया यूआरएल है. window.location स्ट्रिंग से उस डेटा को पढ़ने के लिए, JavaScript का इस्तेमाल किया जा सकता है. इसके लिए, URL कन्स्ट्रक्टर की मदद से, स्ट्रिंग को पार्स करें.

ब्राउज़र, ऑपरेटिंग सिस्टम की शेयर एंट्री को फ़ीड करने के लिए, आपके मेनिफ़ेस्ट में मौजूद PWA के नाम और आइकॉन का इस्तेमाल करेगा. इसके लिए, कोई दूसरा सेट नहीं चुना जा सकता.

ज़्यादा जानकारी वाले उदाहरणों और फ़ाइलें पाने के तरीके के बारे में जानने के लिए, Web Share Target API की मदद से शेयर किया गया डेटा पाना लेख पढ़ें

संपर्क पिकर

Browser Support

  • Chrome: not supported.
  • Edge: not supported.
  • Firefox: not supported.
  • Safari: not supported.

Source

संपर्क पिकर एपीआई की मदद से, डिवाइस से उपयोगकर्ता के सभी संपर्कों के साथ नेटिव डायलॉग रेंडर करने का अनुरोध किया जा सकता है, ताकि उपयोगकर्ता एक या उससे ज़्यादा संपर्क चुन सके. इसके बाद, आपके PWA को उन संपर्कों से वह डेटा मिल सकता है जो आपको चाहिए.

Contact Picker API मुख्य रूप से मोबाइल डिवाइसों पर उपलब्ध है. साथ ही, काम करने वाले प्लैटफ़ॉर्म पर, navigator.contacts इंटरफ़ेस की मदद से सभी काम किए जाते हैं.

navigator.contacts.getProperties() का इस्तेमाल करके, उपलब्ध प्रॉपर्टी के लिए क्वेरी करने का अनुरोध किया जा सकता है. साथ ही, अपनी पसंद की प्रॉपर्टी की सूची के साथ, एक या उससे ज़्यादा संपर्कों को चुनने का अनुरोध किया जा सकता है.

कुछ सैंपल प्रॉपर्टी name, email, address, और tel हैं. जब उपयोगकर्ता से एक या उससे ज़्यादा संपर्क चुनने के लिए कहा जाता है, तो navigator.contacts.select(properties) को कॉल किया जा सकता है. साथ ही, आपको जिन प्रॉपर्टी की वैल्यू चाहिए उन्हें भी पास किया जा सकता है.

नीचे दिए गए सैंपल में, पिकर को मिले संपर्कों की सूची दी गई है.

async function getContacts() {
   const properties = ['name', 'email', 'tel'];
   const options = { multiple: true };
   try {
     const contacts = await navigator.contacts.select(properties, options);
     console.log(contacts);
   } catch (ex) {
     // Handle any errors here.
   }
}

संसाधन