कंपनी का ब्यौरा
Google Chrome के मुख्य टूलबार में पता बार की दाईं ओर मौजूद आइकॉन जोड़ने के लिए, chrome.pageAction
API का इस्तेमाल करें. पेज की कार्रवाइयां, मौजूदा पेज पर की जा सकने वाली कार्रवाइयों को दिखाती हैं, लेकिन वे सभी पेजों पर लागू नहीं होतीं. कोई गतिविधि न होने पर, पेज पर की जाने वाली कार्रवाइयां धूसर रं�� में दिखती हैं.
उपलब्धता
कुछ उदाहरण:
- इस पेज के आरएसएस फ़ीड की सदस्यता लें
- इस पेज के फ़ोटो से एक स्लाइड शो बनाएं
नीचे दिए गए स्क्रीनशॉट में मौजूद आरएसएस आइकॉन, पेज पर की जाने वाली कार्रवाई के बारे में बताता है. इसकी मदद से, मौजूदा पेज के लिए आरएसएस फ़ीड की सदस्यता ली जा सकती है.
छिपी हुई पेज कार्रवाइयां धूसर रंग में दिखती हैं. उदाहरण के लिए, नीचे दिया गया आरएसएस फ़ीड धूसर हो गया है, क्योंकि मौजूदा पेज के लिए फ़ीड की सदस्यता नहीं ली जा सकती:
इसके बजाय, कृपया ब्राउज़र की मदद से कार्रवाई करें, ताकि उपयोगकर्ता आपके एक्सटेंशन से हमेशा इंटरैक्ट कर सकें.
मेनिफ़ेस्ट
एक्सटेंशन मेनिफ़ेस्ट में अपने पेज की कार्रवाई को इस तरह रजिस्टर करें:
{
"name": "My extension",
...
"page_action": {
"default_icon": { // optional
"16": "images/icon16.png", // optional
"24": "images/icon24.png", // optional
"32": "images/icon32.png" // optional
},
"default_title": "Google Mail", // optional; shown in tooltip
"default_popup": "popup.html" // optional
},
...
}
आम तौर पर, 1.5x या 1.2x जैसे कम इस्तेमाल होने वाले स्केल फ़ैक्टर वाले डिवाइस ज़्यादा आम होते जा रहे हैं. इसलिए, आपको अपने आइकॉन के लिए एक से ज़्यादा साइज़ उपलब्ध कराने का सुझाव दिया जाता है. Chrome सबसे नज़दीकी को चुनेगा और उसे 16-डिप स्पेस में भरने के लिए स्केल करेगा. इससे यह भी पक्का होता है कि अगर आइकॉन का डिसप्ले साइज़ कभी भी बदला जाता है, तो आपको अलग-अलग आइकॉन देने के लिए कुछ और करने की ज़रूरत नहीं है! हालांकि, ��गर साइज़ का अंतर बहुत ज़्यादा है, तो इस स्केलिंग से आइकॉन में बारीकियां दिख सकती हैं या वह धुंधला दिख सकता है.
डिफ़ॉल्ट आइकॉन को रजिस्टर करने के लिए, पुराना सिंटैक्स अब भी इस्तेमाल किया जा सकता है:
{
"name": "My extension",
...
"page_action": {
...
"default_icon": "images/icon32.png" // optional
// equivalent to "default_icon": { "32": "images/icon32.png" }
},
...
}
यूज़र इंटरफ़ेस (यूआई) के हिस्से
ब्राउज़र ऐक्शन की तरह, पेज ऐक्शन में एक आइकॉन, टूलटिप, और पॉप-अप हो सकता है. हालाँकि, उनमें बैज नहीं हो सकते. इसके अलावा, पेज की कार्रवाइयों को धूसर किया जा सकता है. ब्राउज़र ऐक्शन यूज़र इंटरफ़ेस (यूआई) के बारे में पढ़कर, आइकॉन, टूलटिप, और पॉप-अप के बारे में जानकारी पाई जा सकती है.
pageAction.show
और pageAction.hide
तरीकों का इस्तेमाल करके, पेज ऐक्शन को दिखाया जाता है और धूसर किया जाता है. डिफ़ॉल्ट रूप से, पेज कार्रवाई धूसर दिखती है. इसे दिखाने पर, आपको वह टैब चुनना होगा जिसमें आइकॉन दिखना चाहिए. यह आइकॉन तब तक दिखता रहता है, जब तक टैब बंद नहीं किया जाता या कोई दूसरा यूआरएल दिखाना शुरू नहीं करता. ऐसा इसलिए, क्योंकि उपयोगकर्ता किसी लिंक पर क्लिक करता है.
सलाह
सबसे अच्छे विज़ुअल इफ़ेक्ट के लिए, इन दिशा-निर्देशों का पालन करें:
- पेज ऐक्शन का इस्तेमाल उन सुविधाओं के लिए करें जो सिर्फ़ कुछ पेजों के लिए काम की हों.
- उन सुविधाओं के लिए पेज ऐक्शन का इस्तेमाल न करें जो ज़्यादातर पेजों के लिए काम की हैं. इसके बजाय, ब्राउज़र ऐक्शन का इस्तेमाल करें.
- अपने आइकॉन को लगातार ऐनिमेट न करें. यह तो बस परेशान करता है.
टाइप
ImageDataType
किसी इमेज के लिए Pixel डेटा. यह कोई ImageData ऑब्जेक्ट होना चाहिए (जैसे, किसी canvas
एलिमेंट से).
टाइप
ImageData
TabDetails
प्रॉपर्टी
-
tabId
नंबर ज़रूरी नहीं
उस टैब का आईडी जिसकी क्वेरी की स्थिति. अगर कोई टैब तय नहीं किया गया है, तो खास टैब के बजाय कोई अन्य स्थिति दिखेगी.
तरीके
getPopup()
chrome.pageAction.getPopup(
details: TabDetails,
callback?: function,
)
इस पेज कार्रवाई के लिए एचटीएमएल दस्तावेज़ को पॉप-अप के तौर पर सेट करता है.
पैरामीटर
-
जानकारी
-
कॉलबैक
फ़ंक्शन ज़रूरी नहीं
callback
पैरामीटर ऐसा दिखता है:(result: string) => void
-
नतीजा
स्ट्रिंग
-
लौटाए गए प्रॉडक्ट
-
प्रॉमिस<string>
Chrome 101 और उसके बाद के वर्शनप्रॉमिस सिर्फ़ मेनिफ़ेस्ट V3 और उसके बाद के वर्शन पर काम करता है. अन्य प्लैटफ़ॉर्म के लिए कॉलबैक का इस्तेमाल करना ज़रूरी है.
getTitle()
chrome.pageAction.getTitle(
details: TabDetails,
callback?: function,
)
पेज की कार्रवाई का टाइटल दिखाता है.
पैरामीटर
-
जानकारी
-
कॉलबैक
फ़ंक्शन ज़रूरी नहीं
callback
पैरामीटर ऐसा दिखता है:(result: string) => void
-
नतीजा
स्ट्रिंग
-
लौटाए गए प्रॉडक्ट
-
प्रॉमिस<string>
Chrome 101 और उसके बाद के वर्शनप्रॉमिस सिर्फ़ मेनिफ़ेस्ट V3 और उसके बाद के वर्शन पर काम करता है. अन्य प्लैटफ़ॉर्म के लिए कॉलबैक का इस्तेमाल करना ज़रूरी है.
hide()
chrome.pageAction.hide(
tabId: number,
callback?: function,
)
पेज की कार्रवाई को छिपा देता है. छिपी हुई पेज कार्रवाइयां अब भी Chrome टूलबार म��ं दिखती हैं, लेकिन धूसर की जाती हैं.
पैरामीटर
-
tabId
नंबर
उस टैब का आईडी जिसके लिए आपको पेज की कार्रवाई में बदलाव करना है.
-
कॉलबैक
फ़ंक्शन ज़रूरी नहीं
Chrome 67 और इसके बाद के वर्शनcallback
पैरामीटर ऐसा दिखता है:() => void
लौटाए गए प्रॉडक्ट
-
Promise<void>
Chrome 101 और उसके बाद के वर्शनप्रॉमिस सिर्फ़ मेनिफ़ेस्ट V3 और उसके बाद के वर्शन पर काम करता है. अन्य प्लैटफ़ॉर्म के लिए कॉलबैक का इस्तेमाल करना ज़रूरी है.
setIcon()
chrome.pageAction.setIcon(
details: object,
callback?: function,
)
पेज कार्रवाई के लिए आइकॉन सेट करता है. आइकॉन की जानकारी, किसी इमेज फ़ाइल के पाथ या कैनवस एलिमेंट के पिक्सल डेटा के तौर पर दी जा सकती है. इसके अलावा, इन दोनों में से किसी एक की डिक्शनरी के तौर पर भी इसका इस्तेमाल किया जा सकता है. पाथ या imageData प्रॉपर्टी के बारे में बताना ज़रूरी है.
पैरामीटर
-
जानकारी
ऑब्जेक्ट
-
iconIndex
नंबर ज़रूरी नहीं
अब काम नहीं करता. इस तर्क को अनदेखा कर दिया गया है.
-
imageData
ImageData | ऑब्जेक्ट ज़रूरी नहीं
सेट किए जाने वाले आइकॉन को दिखाने के लिए, ImageData ऑब्जेक्ट या डिक्शनरी {size -> ImageData} का इस्तेमाल करें. अगर आइकॉन को डिक्शनरी के तौर पर सेट किया गया है, तो इस्तेमाल की जाने वाली असल इमेज को स्क्रीन के पिक्सल की सघनता के आधार पर चुना जाता है. अगर एक स्क्रीन स्पेस यूनिट में फ़िट होने वाले इमेज पिक्सल की संख्या
scale
के बराबर है, तोscale
* n साइज़ वाली इमेज चुनी जाएगी. यहां n, यूज़र इंटरफ़ेस (यूआई) में दिखने वाले आइकॉन का साइज़ होगा. कम से कम एक इमेज का होना ज़रूरी है. ध्यान दें कि 'details.imageData = foo', 'details.imageData = {'16': foo}' के बराबर है -
पाथ
स्ट्रिंग | ऑब्जेक्ट ज़रूरी नहीं
रिलेटिव इमेज पाथ या शब्दकोश {size ->रिलेटिव इमेज पाथ} है, जो सेट किए जाने वाले आइकॉन की ओर इशारा करता है. अगर आइकॉन को डिक्शनरी के तौर पर सेट किया गया है, तो इस्तेमाल की जाने वाली असल इमेज को स्क्रीन के पिक्सल की सघनता के आधार पर चुना जाता है. अगर एक स्क्रीन स्पेस यूनिट में फ़िट होने वाले इमेज पिक्सल की संख्या
scale
के बराबर है, तोscale
* n साइज़ वाली इमेज चुनी जाएगी. यहां n, यूज़र इंटरफ़ेस (यूआई) में दिखने वाले आइकॉन का साइज़ होगा. कम से कम एक इमेज का होना ज़रूरी है. ध्यान दें कि 'details.path = foo', 'details.path = {'16': foo}' के बराबर है -
tabId
नंबर
उस टैब का आईडी जिसके लिए आपको पेज की कार्रवाई में बदलाव करना है.
-
-
कॉलबैक
फ़ंक्शन ज़रूरी नहीं
callback
पैरामीटर ऐसा दिखता है:() => void
लौटाए गए प्रॉडक्ट
-
Promise<void>
Chrome 101 और उसके बाद के वर्शनप्रॉमिस सिर्फ़ मेनिफ़ेस्ट V3 और उसके बाद के वर्शन पर काम करता है. अन्य प्लैटफ़ॉर्म के लिए कॉलबैक का इस्तेमाल करना ज़रूरी है.
setPopup()
chrome.pageAction.setPopup(
details: object,
callback?: function,
)
यह एचटीएमएल दस्तावेज़ को पॉप-अप के तौर पर सेट करता है, ताकि उपयोगकर्ता के पेज कार्रवाई के आइकॉन पर क्लिक कर सके.
पैरामीटर
-
जानकारी
ऑब्जेक्ट
-
पॉप-अप
स्ट्रिंग
पॉप-अप में दिखाने के लिए, एचटीएमएल फ़ाइल का रिलेटिव पाथ. अगर इसे खाली स्ट्रिंग (
''
) पर सेट किया जाता है, तो कोई पॉप-अप नहीं दिखेगा. -
tabId
नंबर
उस टैब का आईडी जिसके लिए आपको पेज की कार्रवाई में बदलाव करना है.
-
-
कॉलबैक
फ़ंक्शन ज़रूरी नहीं
Chrome 67 और इसके बाद के वर्शनcallback
पैरामीटर ऐसा दिखता है:() => void
लौटाए गए प्रॉडक्ट
-
Promise<void>
Chrome 101 और उसके बाद के वर्शनप्रॉमिस सिर्फ़ मेनिफ़ेस्ट V3 और उसके बाद के वर्शन पर काम करता है. अन्य प्लैटफ़ॉर्म के लिए कॉलबैक का इस्तेमाल करना ज़रूरी है.
setTitle()
chrome.pageAction.setTitle(
details: object,
callback?: function,
)
पेज की कार्रवाई का शीर्षक सेट करता है. यह जानकारी, पेज पर की जाने वाली कार्रवाई के टूलटिप के तौर पर दिखती है.
पैरामीटर
-
जानकारी
ऑब्जेक्ट
-
tabId
नंबर
उस टैब का आईडी जिसके लिए आपको पेज की कार्रवाई में बदलाव करना है.
-
title
स्ट्रिंग
टूलटिप स्ट्रिंग.
-
-
कॉलबैक
फ़ंक्शन ज़रूरी नहीं
Chrome 67 और इसके बाद के वर्शनcallback
पैरामीटर ऐसा दिखता है:() => void
लौटाए गए प्रॉडक्ट
-
Promise<void>
Chrome 101 और उसके बाद के वर्शनप्रॉमिस सिर्फ़ मेनिफ़ेस्ट V3 और उसके बाद के वर्शन पर काम करता है. अन्य प्लैटफ़ॉर्म के लिए कॉलबैक का इस्तेमाल करना ज़रूरी है.
show()
chrome.pageAction.show(
tabId: number,
callback?: function,
)
पेज पर की गई कार्रवाई दिखाता है. जब भी टैब चुना जाता है, तब पेज की कार्रवाई दिखती है.
पैरामीटर
-
tabId
नंबर
उस टैब का आईडी जिसके लिए आपको पेज की कार्रवाई में बदलाव करना है.
-
कॉलबैक
फ़ंक्शन ज़रूरी नहीं
Chrome 67 और इसके बाद के वर्शनcallback
पैरामीटर ऐसा दिखता है:() => void
लौटाए गए प्रॉडक्ट
-
Promise<void>
Chrome 101 और उसके बाद के वर्शनप्रॉमिस सिर्फ़ मेनिफ़ेस्ट V3 और उसके बाद के वर्शन पर काम करता है. अन्य प्लैटफ़ॉर्म के लिए कॉलबैक का इस्तेमाल करना ज़रूरी है.