chrome.action

ब्यौरा

Google Chrome के टूलबार में एक्सटेंशन के आइकॉन को कंट्रोल करने के लिए, chrome.action API का इस्तेमाल करें.

कार्रवाई वाले आइकॉन, ब्राउज़र टूलबार में ओमनीबॉक्स के बगल में दिखते हैं. इंस्टॉल करने के बाद, ये एक्सटेंशन मेन्यू (पज़ल पीस आइकॉन) में दिखते हैं. उपयोगकर्ता, आपके एक्सटेंशन के आइकॉन को टूलबार में पिन कर सकते हैं.

उपलब्धता

Chrome 88 या इसके बाद का वर्शन MV3 या इसके बाद का वर्शन

मेनिफ़ेस्ट

इस एपीआई का इस्तेमाल करने के लिए, इन कुंजियों को मेनिफ़ेस्ट फ़ाइल में एलान करना होगा.

"action"

chrome.action एपीआई का इस्तेमाल करने के लिए, 3 का "manifest_version" तय करें. साथ ही, अपनी मेनिफ़ेस्ट फ़ाइल में "action" कुंजी शामिल करें.

{
  "name": "Action Extension",
  ...
  "action": {
    "default_icon": {              // optional
      "16": "images/icon16.png",   // optional
      "24": "images/icon24.png",   // optional
      "32": "images/icon32.png"    // optional
    },
    "default_title": "Click Me",   // optional, shown in tooltip
    "default_popup": "popup.html"  // optional
  },
  ...
}

"action" कुंजी (और इसके चाइल्ड) का इस्तेमाल करना ज़रूरी नहीं है. इसे शामिल न करने पर भी, एक्सटेंशन को टूलबार में दिखाया जाता है, ताकि एक्सटेंशन के मेन्यू को ऐक्सेस किया जा सके. इसलिए, हमारा सुझाव है कि आप हमेशा कम से कम "action" और "default_icon" कुंजियां शामिल करें.

कॉन्सेप्ट और इस्तेमाल

यूज़र इंटरफ़ेस (यूआई) के हिस्से

आइकॉन

यह आइकॉन, आपके एक्सटेंशन के टूलबार पर मौजूद मुख्य इमेज होती है. इसे आपके मेनिफ़ेस्ट की "action" कुंजी में मौजूद "default_icon" कुंजी से सेट किया जाता है. आइकॉन की चौड़ाई और लंबाई 16 डिवाइस-इंडिपेंडेंट पिक्सल (डीआईपी) होनी चाहिए.

"default_icon" कुंजी, इमेज पाथ के लिए साइज़ की डिक्शनरी होती है. Chrome इन आइकॉन का इस्तेमाल करके यह तय करता है कि इमेज को किस स्केल पर दिखाना है. अगर एग्ज़ैक्ट मैच नहीं मिलता है, तो Chrome सबसे मिलते-जुलते फ़ॉन्ट को चुनता है और उसे इमेज के हिसाब से स्केल करता है. इससे इमेज की क्वालिटी पर असर पड़ सकता है.

1.5x या 1.2x जैसे कम इस्तेमाल होने वाले स्केल फ़ैक्टर वाले डिवाइसों का इस्तेमाल अब ज़्यादा होने लगा है. इसलिए, हमारा सुझाव है कि आप अपने आइकॉन के लिए कई साइज़ उपलब्ध कराएं. इससे, आइकॉन के डिसप्ले साइज़ में होने वाले संभावित बदलावों के हिसाब से, आपका एक्सटेंशन आने वाले समय में भी काम करता रहेगा. हालांकि, अगर सिर्फ़ एक साइज़ दिया जा रहा है, तो "default_icon" कुंजी को डिक्शनरी के बजाय, एक आइकॉन के पाथ वाली स्ट्रिंग पर भी सेट किया जा सकता है.

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

const canvas = new OffscreenCanvas(16, 16);
const context = canvas.getContext('2d');
context.clearRect(0, 0, 16, 16);
context.fillStyle = '#00FF00';  // Green
context.fillRect(0, 0, 16, 16);
const imageData = context.getImageData(0, 0, 16, 16);
chrome.action.setIcon({imageData: imageData}, () => { /* ... */ });

पैक्ड एक्सटेंशन (जो .crx फ़ाइल से इंस्टॉल किए जाते हैं) के लिए, इमेज ऐसे ज़्यादातर फ़ॉर्मैट में हो सकती हैं जिन्हें Blink रेंडरिंग इंजन दिखा सकता है. इनमें PNG, JPEG, BMP, ICO वगैरह शामिल हैं. SVG फ़ाइल फ़ॉर्मैट का इस्तेमाल नहीं किया जा सकता. अनपैक किए गए एक्सटेंशन में, PNG इमेज का इस्तेमाल करना ज़रूरी है.

टूलटिप (टाइटल)

जब उपयोगकर्ता, टूलबार में एक्सटेंशन के आइकॉन पर माउस पॉइंटर को घुमाता है, तब टूलटिप या टाइटल दिखता है. जब बटन पर फ़ोकस किया जाता है, तब स्क्रीन रीडर इस टेक्स्ट को भी पढ़ता है.

डिफ़ॉल्ट टूलटिप को manifest.json में मौजूद "action" कुंजी के "default_title" फ़ील्ड का इस्तेमाल करके सेट किया जाता है. action.setTitle() को कॉल करके, इसे प्रोग्राम के हिसाब से भी सेट किया जा सकता है.

बैज

कार्रवाइयों में, "बैज" दिखाने का विकल्प होता है. यह आइकॉन के ऊपर लेयर किया गया थोड़ा सा टेक्स्ट होता है. इसकी मदद से, एक्सटेंशन की स्थिति के बारे में थोड़ी जानकारी दिखाने के लिए, कार्रवाई को अपडेट किया जा सकता है. जैसे, काउंटर. बैज में एक टेक्स्ट कॉम्पोनेंट और बैकग्राउंड का रंग होता है. जगह सीमित होने की वजह से, हमारा सुझाव है कि बैज के टेक्स्ट में चार या इससे कम वर्णों का इस्तेमाल करें.

बैज बनाने के लिए, action.setBadgeBackgroundColor() और action.setBadgeText() को कॉल करके, इसे प्रोग्राम के हिसाब से सेट करें. मेनिफ़ेस्ट में, बैज की डिफ़ॉल्ट सेटिंग मौजूद नहीं है. बैज के रंग की वैल्यू, 0 से 255 के बीच के चार पूर्णांकों का एक ऐसा कलेक्शन हो सकता है जो बैज के आरजीबीए रंग को बनाता है. इसके अलावा, यह सीएसएस रंग की वैल्यू वाली स्ट्रिंग भी हो सकती है.

chrome.action.setBadgeBackgroundColor(
  {color: [0, 255, 0, 0]},  // Green
  () => { /* ... */ },
);

chrome.action.setBadgeBackgroundColor(
  {color: '#00FF00'},  // Also green
  () => { /* ... */ },
);

chrome.action.setBadgeBackgroundColor(
  {color: 'green'},  // Also, also green
  () => { /* ... */ },
);

जब उपयोगकर्ता टूलबार में एक्सटेंशन के ऐक्शन बटन पर क्लिक करता है, तब ऐक्शन का पॉप-अप दिखता है. पॉप-अप में आपकी पसंद का कोई भी एचटीएमएल कॉन्टेंट शामिल किया जा सकता है. साथ ही, यह कॉन्टेंट के हिसाब से अपने-आप सेट हो जाएगा. पॉप-अप का साइज़ 25x25 और 800x600 पिक्सल के बीच होना चाहिए.

पॉप-अप को शुरू में, manifest.json फ़ाइल में मौजूद "action" कुंजी में "default_popup" प्रॉपर्टी के ज़रिए सेट किया जाता है. अगर यह प्रॉपर्टी मौजूद है, तो इसे एक्सटेंशन डायरेक्ट्री में मौजूद किसी रिलेटिव पाथ की ओर ले जाना चाहिए. action.setPopup() तरीके का इस्तेमाल करके, इसे डाइनैमिक तौर पर भी अपडेट किया जा सकता है, ताकि यह किसी दूसरे रिलेटिव पाथ की ओर इशारा करे.

उपयोग के उदाहरण

हर टैब की स्थिति

एक्सटेंशन ऐक्शन की स्थिति, हर टैब के लिए अलग-अलग हो सकती है. किसी टैब के लिए वैल्यू सेट करने के लिए, action API के सेटिंग के तरीकों में tabId प्रॉपर्टी का इस्तेमाल करें. उदाहरण के लिए, किसी टैब के लिए बैज का टेक्स्ट सेट करने के लिए, कुछ ऐसा करें:

function getTabId() { /* ... */}
function getTabBadge() { /* ... */}

chrome.action.setBadgeText(
  {
    text: getTabBadge(tabId),
    tabId: getTabId(),
  },
  () => { ... }
);

अगर tabId प्रॉपर्टी को शामिल नहीं किया जाता है, तो सेटिंग को ग्लोबल सेटिंग माना जाता है. टैब के हिसाब से की गई सेटिंग को ग्लोबल सेटिंग के मुकाबले ज़्यादा प्राथमिकता दी जाती है.

चालू की गई स्थिति

डिफ़ॉल्ट रूप से, टूलबार में मौजूद कार्रवाइयां हर टैब पर चालू होती हैं. इसका मतलब है कि उन पर क्लिक किया जा सकता है. मेनिफ़ेस्ट की action कुंजी में default_state प्रॉपर्टी सेट करके, इस डिफ़ॉल्ट सेटिंग को बदला जा सकता है. अगर default_state को "disabled" पर सेट किया जाता है, तो कार्रवाई डिफ़ॉल्ट रूप से बंद हो जाती है. इस पर क्लिक करने की सुविधा को प्रोग्राम के हिसाब से चालू करना होगा. अगर default_state को "enabled" (डिफ़ॉल्ट) पर सेट किया जाता है, तो कार्रवाई डिफ़ॉल्ट रूप से चालू होती है और इस पर क्लिक किया जा सकता है.

action.enable() और action.disable() तरीकों का इस्तेमाल करके, प्रोग्राम के हिसाब से स्थिति को कंट्रोल किया जा सकता है. इससे सिर्फ़ इस बात पर असर पड़ता है कि आपके एक्सटेंशन को पॉप-अप (अगर कोई हो) या action.onClicked इवेंट भेजा जाता है या नहीं. इससे टूलबार में कार्रवाई की मौजूदगी पर कोई असर नहीं पड़ता.

उदाहरण

यहां कुछ सामान्य उदाहरण दिए गए हैं कि एक्सटेंशन में कार्रवाइयों का इस्तेमाल कैसे किया जाता है. इस एपीआई को आज़माने के लिए, chrome-extension-samples रिपॉज़िटरी से Action API का उदाहरण इंस्टॉल करें.

पॉप-अप दिखाना

आम तौर पर, जब उपयोगकर्ता एक्सटेंशन की कार्रवाई पर क्लिक करता है, तो एक्सटेंशन एक पॉप-अप दिखाता है. अपने एक्सटेंशन में इस सुविधा को लागू करने के लिए, manifest.json में पॉप-अप का एलान करें. साथ ही, वह कॉन्टेंट तय करें जिसे Chrome को पॉप-अप में दिखाना चाहिए.

// manifest.json
{
  "name": "Action popup demo",
  "version": "1.0",
  "manifest_version": 3,
  "action": {
    "default_title": "Click to view a popup",
    "default_popup": "popup.html"
  }
}
<!-- popup.html -->
<!DOCTYPE html>
<html>
<head>
  <style>
    html {
      min-height: 5em;
      min-width: 10em;
      background: salmon;
    }
  </style>
</head>
<body>
  <p>Hello, world!</p>
</body>
</html>

क्लिक करने पर कॉन्टेंट स्क्रिप्ट डालना

एक्सटेंशन के लिए, एक्सटेंशन की कार्रवाई का इस्तेमाल करके अपनी मुख्य सुविधा को दिखाना एक सामान्य पैटर्न है. इस उदाहरण में, इस पैटर्न के बारे में बताया गया है. जब उपयोगकर्ता इस कार्रवाई पर क्लिक करता है, तो एक्सटेंशन मौजूदा पेज में कॉन्टेंट स्क्रिप्ट इंजेक्ट करता है. इसके बाद, कॉन्टेंट स्क्रिप्ट एक सूचना दिखाती है. इससे यह पुष्टि की जाती है कि सब कुछ ठीक से काम कर रहा है.

// manifest.json
{
  "name": "Action script injection demo",
  "version": "1.0",
  "manifest_version": 3,
  "action": {
    "default_title": "Click to show an alert"
  },
  "permissions": ["activeTab", "scripting"],
  "background": {
    "service_worker": "background.js"
  }
}
// background.js
chrome.action.onClicked.addListener((tab) => {
  chrome.scripting.executeScript({
    target: {tabId: tab.id},
    files: ['content.js']
  });
});
// content.js
alert('Hello, world!');

declarativeContent की मदद से कार्रवाइयों को दोहराना

इस उदाहरण में दिखाया गया है कि एक्सटेंशन का बैकग्राउंड लॉजिक, (a) डिफ़ॉल्ट रूप से किसी कार्रवाई को कैसे बंद कर सकता है और (b) चुनिंदा साइटों पर कार्रवाई चालू करने के लिए, declarativeContent का इस्तेमाल कैसे कर सकता है.

// service-worker.js

// Wrap in an onInstalled callback to avoid unnecessary work
// every time the service worker is run
chrome.runtime.onInstalled.addListener(() => {
  // Page actions are disabled by default and enabled on select tabs
  chrome.action.disable();

  // Clear all rules to ensure only our expected rules are set
  chrome.declarativeContent.onPageChanged.removeRules(undefined, () => {
    // Declare a rule to enable the action on example.com pages
    let exampleRule = {
      conditions: [
        new chrome.declarativeContent.PageStateMatcher({
          pageUrl: {hostSuffix: '.example.com'},
        })
      ],
      actions: [new chrome.declarativeContent.ShowAction()],
    };

    // Finally, apply our new array of rules
    let rules = [exampleRule];
    chrome.declarativeContent.onPageChanged.addRules(rules);
  });
});

टाइप

OpenPopupOptions

Chrome 99 या इसके बाद का वर्शन

प्रॉपर्टी

  • windowId

    number ज़रूरी नहीं

    कार्रवाई वाला पॉपअप खोलने के लिए, विंडो का आईडी. अगर कोई विंडो तय नहीं की गई है, तो डिफ़ॉल्ट रूप से, चालू विंडो पर सेट होता है.

TabDetails

प्रॉपर्टी

  • tabId

    number ज़रूरी नहीं

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

UserSettings

Chrome 91 या इसके बाद के वर्शन

एक्सटेंशन की कार्रवाई से जुड़ी, उपयोगकर्ता की ओर से तय की गई सेटिंग का कलेक्शन.

प्रॉपर्टी

  • isOnToolbar

    बूलियन

    इससे पता चलता है कि एक्सटेंशन का ऐक्शन आइकॉन, ब्राउज़र विंडो के टॉप-लेवल टूलबार पर दिखता है या नहीं. इसका मतलब यह है कि उपयोगकर्ता ने एक्सटेंशन को 'पिन किया है' या नहीं.

UserSettingsChange

Chrome 130 या इसके बाद के वर्शन

प्रॉपर्टी

  • isOnToolbar

    बूलियन ज़रूरी नहीं है

    इससे पता चलता है कि एक्सटेंशन का ऐक्शन आइकॉन, ब्राउज़र विंडो के टॉप-लेवल टूलबार पर दिखता है या नहीं. इसका मतलब यह है कि उपयोगकर्ता ने एक्सटेंशन को 'पिन किया है' या नहीं.

तरीके

disable()

chrome.action.disable(
  tabId?: number,
)
: Promise<void>

इससे किसी टैब के लिए कार्रवाई बंद हो जाती है.

पैरामीटर

  • tabId

    number ज़रूरी नहीं

    उस टैब का आईडी जिसके लिए आपको कार्रवाई में बदलाव करना है.

रिटर्न

  • Promise<void>

enable()

chrome.action.enable(
  tabId?: number,
)
: Promise<void>

यह कुकी, किसी टैब के लिए कार्रवाई करने की सुविधा चालू करती है. कार्रवाइयां करने की सुविधा डिफ़ॉल्ट रूप से चालू होती है.

पैरामीटर

  • tabId

    number ज़रूरी नहीं

    उस टैब का आईडी जिसके लिए आपको कार्रवाई में बदलाव करना है.

रिटर्न

  • Promise<void>

getBadgeBackgroundColor()

chrome.action.getBadgeBackgroundColor(
  details: TabDetails,
)
: Promise<extensionTypes.ColorArray>

कार्रवाई के बैकग्राउंड का रंग मिलता है.

पैरामीटर

रिटर्न

getBadgeText()

chrome.action.getBadgeText(
  details: TabDetails,
)
: Promise<string>

कार्रवाई के बैज का टेक्स्ट मिलता है. अगर कोई टैब नहीं चुना जाता है, तो टैब के हिसाब से नहीं, बल्कि सामान्य बैज टेक्स्ट दिखता है. अगर displayActionCountAsBadgeText चालू है, तो प्लेसहोल्डर टेक्स्ट तब तक दिखेगा, जब तक declarativeNetRequestFeedback की अनुमति नहीं दी जाती या टैब के हिसाब से बैज टेक्स्ट नहीं दिया जाता.

पैरामीटर

रिटर्न

  • Promise<string>

getBadgeTextColor()

Chrome 110 या इसके बाद का वर्शन
chrome.action.getBadgeTextColor(
  details: TabDetails,
)
: Promise<extensionTypes.ColorArray>

इससे कार्रवाई के टेक्स्ट का रंग मिलता है.

पैरामीटर

रिटर्न

getPopup()

chrome.action.getPopup(
  details: TabDetails,
)
: Promise<string>

इस कार्रवाई के लिए, पॉप-अप के तौर पर सेट किए गए एचटीएमएल दस्तावेज़ को दिखाता है.

पैरामीटर

रिटर्न

  • Promise<string>

getTitle()

chrome.action.getTitle(
  details: TabDetails,
)
: Promise<string>

कार्रवाई का टाइटल मिलता है.

पैरामीटर

रिटर्न

  • Promise<string>

getUserSettings()

Chrome 91 या इसके बाद के वर्शन
chrome.action.getUserSettings(): Promise<UserSettings>

यह एक्सटेंशन की कार्रवाई से जुड़ी, उपयोगकर्ता की तय की गई सेटिंग दिखाता है.

रिटर्न

isEnabled()

Chrome 110 या इसके बाद का वर्शन
chrome.action.isEnabled(
  tabId?: number,
)
: Promise<boolean>

इससे पता चलता है कि किसी टैब के लिए एक्सटेंशन ऐक्शन चालू है या नहीं. अगर कोई tabId नहीं दिया गया है, तो इससे पता चलता है कि एक्सटेंशन ऐक्शन, ग्लोबल लेवल पर चालू है या नहीं. सिर्फ़ declarativeContent का इस्तेमाल करके चालू की गई कार्रवाइयां हमेशा गलत जवाब देती हैं.

पैरामीटर

  • tabId

    number ज़रूरी नहीं

    उस टैब का आईडी जिसके लिए आपको चालू होने की स्थिति की जांच करनी है.

रिटर्न

  • Promise<boolean>

openPopup()

Chrome 127+
chrome.action.openPopup(
  options?: OpenPopupOptions,
)
: Promise<void>

इससे एक्सटेंशन का पॉप-अप खुलता है. Chrome 118 और Chrome 126 के बीच, यह सुविधा सिर्फ़ उन एक्सटेंशन के लिए उपलब्ध है जिन्हें नीति के तहत इंस्टॉल किया गया है.

पैरामीटर

  • विकल्प

    OpenPopupOptions ज़रूरी नहीं है

    इससे पॉप-अप खोलने के विकल्प तय किए जाते हैं.

रिटर्न

  • Promise<void>

setBadgeBackgroundColor()

chrome.action.setBadgeBackgroundColor(
  details: object,
)
: Promise<void>

इस विकल्प से, बैज के बैकग्राउंड का रंग सेट किया जाता है.

पैरामीटर

  • विवरण

    ऑब्जेक्ट

    • रंग

      string | ColorArray

      यह [0,255] रेंज में मौजूद चार पूर्णांकों का एक कलेक्शन होता है. इससे बैज का आरजीबीए रंग बनता है. उदाहरण के लिए, गहरा लाल रंग [255, 0, 0, 255] है. यह CSS वैल्यू वाली स्ट्रिंग भी हो सकती है. इसमें अपारदर्शी लाल रंग के लिए #FF0000 या #F00 का इस्तेमाल किया जाता है.

    • tabId

      number ज़रूरी नहीं

      इससे बदलाव सिर्फ़ तब लागू होता है, जब कोई टैब चुना जाता है. टैब बंद होने पर, यह कुकी अपने-आप रीसेट हो जाती है.

रिटर्न

  • Promise<void>

setBadgeText()

chrome.action.setBadgeText(
  details: object,
)
: Promise<void>

इस विकल्प से, कार्रवाई के लिए बैज का टेक्स्ट सेट किया जाता है. बैज, आइकॉन के ऊपर दिखता है.

पैरामीटर

  • विवरण

    ऑब्जेक्ट

    • tabId

      number ज़रूरी नहीं

      इससे बदलाव सिर्फ़ तब लागू होता है, जब कोई टैब चुना जाता है. टैब बंद होने पर, यह कुकी अपने-आप रीसेट हो जाती है.

    • टेक्स्ट

      string ज़रूरी नहीं है

      इसमें कितने भी वर्ण पास किए जा सकते हैं. हालांकि, इसमें सिर्फ़ चार वर्ण दिखते हैं. अगर कोई खाली स्ट्रिंग ('') पास की जाती है, तो बैज का टेक्स्ट मिट जाता है. अगर tabId तय किया गया है और text शून्य है, तो तय किए गए टैब का टेक्स्ट मिटा दिया जाता है. साथ ही, डिफ़ॉल्ट रूप से ग्लोबल बैज का टेक्स्ट सेट हो जाता है.

रिटर्न

  • Promise<void>

setBadgeTextColor()

Chrome 110 या इसके बाद का वर्शन
chrome.action.setBadgeTextColor(
  details: object,
)
: Promise<void>

इस विकल्प से, बैज के टेक्स्ट का रंग सेट किया जाता है.

पैरामीटर

  • विवरण

    ऑब्जेक्ट

    • रंग

      string | ColorArray

      यह [0,255] रेंज में मौजूद चार पूर्णांकों का एक कलेक्शन होता है. इससे बैज का आरजीबीए रंग बनता है. उदाहरण के लिए, गहरा लाल रंग [255, 0, 0, 255] है. यह CSS वैल्यू वाली स्ट्रिंग भी हो सकती है. इसमें अपारदर्शी लाल रंग के लिए #FF0000 या #F00 का इस्तेमाल किया जाता है. इस वैल्यू को सेट न करने पर, बैज के बैकग्राउंड के रंग से अलग रंग अपने-आप चुना जाएगा, ताकि टेक्स्ट दिखे. जिन रंगों की ऐल्फ़ा वैल्यू 0 के बराबर होगी उन्हें सेट नहीं किया जाएगा. साथ ही, एक गड़बड़ी दिखेगी.

    • tabId

      number ज़रूरी नहीं

      इससे बदलाव सिर्फ़ तब लागू होता है, जब कोई टैब चुना जाता है. टैब बंद होने पर, यह कुकी अपने-आप रीसेट हो जाती है.

रिटर्न

  • Promise<void>

setIcon()

chrome.action.setIcon(
  details: object,
)
: Promise<void>

कार्रवाई के लिए आइकॉन सेट करता है. आइकॉन को इमेज फ़ाइल के पाथ या कैनवस एलिमेंट से पिक्सल डेटा के तौर पर तय किया जा सकता है. इसके अलावा, इसे इनमें से किसी एक के डिक्शनरी के तौर पर भी तय किया जा सकता है. पाथ या imageData प्रॉपर्टी में से किसी एक को तय करना ज़रूरी है.

पैरामीटर

  • विवरण

    ऑब्जेक्ट

    • imageData

      ImageData | object वैकल्पिक

      ImageData ऑब्जेक्ट या डिक्शनरी {size -> ImageData} में से कोई एक. यह डिक्शनरी, सेट किए जाने वाले आइकॉन को दिखाती है. अगर आइकॉन को डिक्शनरी के तौर पर तय किया जाता है, तो इस्तेमाल की जाने वाली असली इमेज को स्क्रीन की पिक्सल डेंसिटी के हिसाब से चुना जाता है. अगर स्क्रीन स्पेस की एक यूनिट में फ़िट होने वाले इमेज पिक्सल की संख्या scale के बराबर है, तो scale * n साइज़ वाली इमेज चुनी जाएगी. यहां n, यूज़र इंटरफ़ेस (यूआई) में आइकॉन का साइज़ है. कम से कम एक इमेज के बारे में बताना ज़रूरी है. ध्यान दें कि 'details.imageData = foo', 'details.imageData = {'16': foo}' के बराबर है

    • पाथ

      string | object ज़रूरी नहीं

      सेट किए जाने वाले आइकॉन की ओर ले जाने वाला, इमेज का मिलता-जुलता पाथ या {size -> relative image path} डिक्शनरी. अगर आइकॉन को डिक्शनरी के तौर पर तय किया जाता है, तो इस्तेमाल की जाने वाली असली इमेज को स्क्रीन की पिक्सल डेंसिटी के हिसाब से चुना जाता है. अगर स्क्रीन स्पेस की एक यूनिट में फ़िट होने वाले इमेज पिक्सल की संख्या scale के बराबर है, तो scale * n साइज़ वाली इमेज चुनी जाएगी. यहां n, यूज़र इंटरफ़ेस (यूआई) में आइकॉन का साइज़ है. कम से कम एक इमेज के बारे में बताना ज़रूरी है. ध्यान दें कि 'details.path = foo' का मतलब 'details.path = {'16': foo}' है

    • tabId

      number ज़रूरी नहीं

      इससे बदलाव सिर्फ़ तब लागू होता है, जब कोई टैब चुना जाता है. टैब बंद होने पर, यह कुकी अपने-आप रीसेट हो जाती है.

रिटर्न

  • Promise<void>

    Chrome 96 और इसके बाद के वर्शन

setPopup()

chrome.action.setPopup(
  details: object,
)
: Promise<void>

इस विकल्प का इस्तेमाल करके, एचटीएमएल दस्तावेज़ को सेट किया जाता है. इससे उपयोगकर्ता के कार्रवाई वाले आइकॉन पर क्लिक करने पर, एचटीएमएल दस्तावेज़ पॉप-अप के तौर पर खुलता है.

पैरामीटर

  • विवरण

    ऑब्जेक्ट

    • पॉप-अप

      स्ट्रिंग

      पॉप-अप में दिखाने के लिए, एचटीएमएल फ़ाइल का रिलेटिव पाथ. अगर इसे खाली स्ट्रिंग ('') पर सेट किया जाता है, तो कोई पॉप-अप नहीं दिखता है.

    • tabId

      number ज़रूरी नहीं

      इससे बदलाव सिर्फ़ तब लागू होता है, जब कोई टैब चुना जाता है. टैब बंद होने पर, यह कुकी अपने-आप रीसेट हो जाती है.

रिटर्न

  • Promise<void>

setTitle()

chrome.action.setTitle(
  details: object,
)
: Promise<void>

इससे कार्रवाई का टाइटल सेट किया जाता है. यह टूलटिप में दिखता है.

पैरामीटर

  • विवरण

    ऑब्जेक्ट

    • tabId

      number ज़रूरी नहीं

      इससे बदलाव सिर्फ़ तब लागू होता है, जब कोई टैब चुना जाता है. टैब बंद होने पर, यह कुकी अपने-आप रीसेट हो जाती है.

    • title

      स्ट्रिंग

      माउस घुमाने पर, कार्रवाई के लिए दिखने वाली स्ट्रिंग.

रिटर्न

  • Promise<void>

इवेंट

onClicked

chrome.action.onClicked.addListener(
  callback: function,
)

कार्रवाई वाले आइकॉन पर क्लिक करने पर ट्रिगर होता है. अगर कार्रवाई में पॉप-अप है, तो यह इवेंट ट्रिगर नहीं होगा.

पैरामीटर

  • कॉलबैक

    फ़ंक्शन

    callback पैरामीटर ऐसा दिखता है:

    (tab: tabs.Tab) => void

onUserSettingsChanged

Chrome 130 या इसके बाद के वर्शन
chrome.action.onUserSettingsChanged.addListener(
  callback: function,
)

यह इवेंट तब ट्रिगर होता है, जब उपयोगकर्ता की ओर से तय की गई एक्सटेंशन की सेटिंग में बदलाव होता है.

पैरामीटर

  • कॉलबैक

    फ़ंक्शन

    callback पैरामीटर ऐसा दिखता है:

    (change: UserSettingsChange) => void