फ़ाइल मैनेज करने वाले एपीआई की मदद से, वेब ऐप्लिकेशन अपने-आप फ़ाइल हैंडलर के तौर पर रजिस्टर हो जाते हैं. ऐसा उन फ़ाइल फ़ॉर्मैट के लिए किया जाता है जिनमें वे काम कर सकते हैं. जानें कि इमेज एडिटिंग ऐप्लिकेशन Photopea, इस एपीआई का इस्तेमाल कैसे करता है.
परिचय
(यह लेख, वीडियो के तौर पर भी उपलब्ध है.)
Photopea एक मुफ़्त ऑनलाइन इमेज एडिटर है. इसे इवान कुत्स्किर ने बनाया है. इवान ने साल 2012 में इस ऐप्लिकेशन पर काम करना शुरू किया था. साथ ही, वे Photopea में जोड़ी गई मुख्य सुविधाओं के बारे में बताने के लिए एक ब्लॉग भी चलाते हैं. Photopea, PSD (Adobe Photoshop), XCF (GIMP), Sketch (Sketch ऐप्लिकेशन), XD (Adobe XD), और CDR (CorelDRAW) फ़ॉर्मैट के साथ काम कर सकता है.
Photopea पर फ़ाइल मैनेज करना
इंस्टॉल किए जा सकने वाले PWA के तौर पर, Photopea एक स्टैंडअलोन विंडो में चलता है. ऐसा तब होता है, जब उपयोगकर्ता ऐप्लिकेशन को इंस्टॉल करना चुनता है. ऐसा करने पर, PWA की एक खास सुविधा चालू हो जाती है. Photopea इसका ज़्यादा इस्तेमाल करता है: फ़ाइल मैनेज करने की सुविधा.
फ़ाइल मैनेज करने वाले एपीआई का एलान वाला हिस्सा
इंस्टॉल होने के बाद, Photopea, ऑपरेटिंग सिस्टम के साथ काम करने वाले अलग-अलग फ़ाइल फ़ॉर्मैट के लिए खुद को फ़ाइल हैंडलर के तौर पर रजिस्टर करता है. ऐसा वेब ऐप्लिकेशन मेनिफ़ेस्ट में, file_handlers
फ़ील्ड को जोड़ने पर होता है. इस्तेमाल किए जा सकने वाले हर फ़ाइल टाइप को ऑब्जेक्ट माना जाता है. action
की वैल्यू के तौर पर रिलेटिव यूआरएल होता है. accept
ऑब्जेक्ट, MIME टाइप और उनसे जुड़े फ़ाइल एक्सटेंशन का एक मैप होता है. उदाहरण के लिए, {"image/jpeg": [".jpeg", ".jpg"]}
. यहां दिया गया कोड, Photopea के वेब ऐप्लिकेशन का प्रोडक्शन मेनिफ़ेस्ट है. इसमें काम के हिस्सों को हाइलाइट किया गया है.
{
"name": "Photopea",
"short_name": "Photopea",
"display": "standalone",
"icons": [
{ "src": "promo/icon512.png", "type": "image/png", "sizes": "512x512" },
{ "src": "promo/maskable512.png", "type": "image/png", "sizes": "512x512", "purpose":"maskable" }
],
"start_url": "/?utm_source=homescreen",
"background_color":"#0f171d",
"theme_color": "#474747",
"file_handlers": [
{ "action": "/", "accept": { "image/psd" : [ ".psd" ] } },
{ "action": "/", "accept": { "image/jpeg": [ ".jpeg", ".jpg" ] } },
{ "action": "/", "accept": { "image/png" : [ ".png" ] } },
{ "action": "/", "accept": { "image/webp": [ ".webp" ] } },
{ "action": "/", "accept": { "image/bmp" : [ ".bmp" ] } },
{ "action": "/", "accept": { "image/gif" : [ ".gif" ] } },
{ "action": "/", "accept": { "image/svg+xml": [ ".svg" ] } },
{ "action": "/", "accept": { "image/pdf" : [ ".pdf" ] } },
{ "action": "/", "accept": { "image/tiff": [ ".tif", ".tiff" ] } },
{ "action": "/", "accept": { "image/ai" : [ ".ai" ] } },
{ "action": "/", "accept": { "image/psb": [ ".psb" ] } },
{ "action": "/", "accept": { "image/xcf": [ ".xcf" ] } },
{ "action": "/", "accept": { "image/sketch": [ ".sketch" ] } },
{ "action": "/", "accept": { "image/xd" : [ ".xd" ] } },
{ "action": "/", "accept": { "image/pxd": [ ".pxd" ] } },
{ "action": "/", "accept": { "image/cdr": [ ".cdr" ] } },
{ "action": "/", "accept": { "image/eps": [ ".eps", ".ps" ] } },
{ "action": "/", "accept": { "image/x-icon": [ ".ico" ] } },
{ "action": "/", "accept": { "image/jpx": [ ".jpx" ] } },
{ "action": "/", "accept": { "image/jp2": [ ".jp2" ] } },
{ "action": "/", "accept": { "image/x-tga": [ ".tga" ] } },
{ "action": "/", "accept": { "image/vnd-ms.dds": [ ".dds" ] } }
],
"share_target": {
"action": "/",
"method": "POST",
"enctype": "multipart/form-data",
"params": {
"files": [
{
"name": "image",
"accept": ["image/jpeg", "image/png", "image/webp", "image/gif"]
}
]
}
}
}
फ़ाइल मैनेज करने वाले एपीआई का ज़रूरी हिस्सा
इसके बाद, एपीआई का ज़रूरी हिस्सा उन फ़ाइलों को मैनेज करता है जिन्हें ऑपरेटिंग सिस्टम, PWA को पास करता है. Photopea का कोड, साफ़ तौर पर छोटा किया गया है और उसमें कुछ कम जानकारी दी गई है. हालांकि, फिर भी नीचे दिए गए स्निपेट की खास जानकारी को समझना मुश्किल नहीं है. LaunchQueue
इंटरफ़ेस (N
के तौर पर छोटा किया गया) में एक setConsumer()
तरीका है, जो फ़ंक्शन को तर्क के तौर पर स्वीकार करता है. बदले में, यह फ़ंक्शन एक LaunchParams
ऑब्जेक्ट (W
के तौर पर कम से कम किया गया) लेता है. इस LaunchParams
ऑब्जेक्ट में एक files
प्रॉपर्टी है, जो FileSystemHandle
ऑब्जेक्ट के रीड-ओनली कलेक्शन पर ले जाती है. इसके बाद, बाकी कोड उस कलेक्शन में मौजूद हर ऑब्जेक्ट के लिए, getFile()
को कॉल करके File
ऑब्जेक्ट (G
के तौर पर छोटा किया गया) पाता है. इसके बाद, इस फ़ाइल को Photopea में मौजूद अन्य लॉजिक को भेज दिया जाता है, जो फ़ाइल को दिखाने का काम करता है.
var N = window.launchQueue;
if (N) {
var $ = this.UA;
N.setConsumer(function (W) {
var O = W.files;
console.log(O);
for (var Y = 0; Y < O.length; Y++) {
var T = O[Y];
T.getFile().then(function (G) {
$.YO([G], null, null, null, [T]);
});
}
});
}
मीटिंग में सामने आए नतीजे
Photopea को इमेज के लिए फ़ाइल हैंडलर बनाने का अनुरोध, उपयोगकर्ता लंबे समय से कर रहे हैं. साल 2020 में जब यह सवाल पूछा गया था, तब इस सुविधा के बारे में सोचा भी नहीं जा सकता था. हालांकि, एक उत्साही उपयोगकर्ता ने फ़ाइल मैनेज करने वाले एपीआई को 2022 की शुरुआत में, उसके शुरुआती चरणों में खोजा. तब यह सुविधा फ़्लैग के पीछे थी. फ़ाइल को मैनेज करने की सुविधा को आखिरकार Chrome 102 में भेज दिया गया. यह Photopea की पसंदीदा सुविधा रही है. इसके उपयोगकर्ता हर दिन इसका इस्तेमाल करते हैं. कुछ लोगों ने इसे गेमचेंजर भी कहा है. Photopea को एक बार आज़माएं और इसे अपने डेस्कटॉप पर इंस्टॉल करें. इसके बाद, कोई ऐसा फ़ाइल फ़ॉर्मैट खोलें जिस पर यह सुविधा काम करती हो! इमेज एडिट करने के लिए शुभकामनाएं!