mirror of
https://github.com/GoogleChrome/chrome-extensions-samples.git
synced 2026-03-27 13:29:34 +07:00
Add DevTools Tips example (#1013)
* Add DevTools Tips example * Update functional-samples/tutorial.focus-mode-debugging/README.md Co-authored-by: Joe Medley <jmedley@google.com> --------- Co-authored-by: Joe Medley <jmedley@google.com>
This commit is contained in:
@@ -0,0 +1,44 @@
|
||||
// Copyright 2023 Google LLC
|
||||
//
|
||||
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||
// you may not use this file except in compliance with the License.
|
||||
// You may obtain a copy of the License at
|
||||
//
|
||||
// https://www.apache.org/licenses/LICENSE-2.0
|
||||
//
|
||||
// Unless required by applicable law or agreed to in writing, software
|
||||
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
// See the License for the specific language governing permissions and
|
||||
// limitations under the License.
|
||||
|
||||
chrome.runtime.onInstalled.addListener(() => {
|
||||
chrome.action.setBadgeText({
|
||||
text: 'OFF'
|
||||
});
|
||||
});
|
||||
|
||||
const extensions = 'https://developer.chrome.com/docs/extensions';
|
||||
const webstore = 'https://developer.chrome.com/docs/webstore';
|
||||
|
||||
// When the user clicks on the extension action
|
||||
chrome.action.onClicked.addListener(async (tab) => {
|
||||
if (tab.url?.startsWith(extensions) || tab.url?.startsWith(webstore)) {
|
||||
// We retrieve the action badge to check if the extension is 'ON' or 'OFF'
|
||||
const prevState = await chrome.action.getBadgeText({ tabId: tab.id });
|
||||
// Next state will always be the opposite
|
||||
const nextState = prevState === 'ON' ? 'OFF' : 'ON';
|
||||
|
||||
// Set the action badge to the next state
|
||||
await chrome.action.setBadgeText({
|
||||
tabId: tab.id,
|
||||
text: nextState
|
||||
});
|
||||
|
||||
if (nextState === 'ON') {
|
||||
chrome.tabs.sendMessage(tab.id, { data: 'focus-on' });
|
||||
} else if (nextState === 'OFF') {
|
||||
chrome.tabs.sendMessage(tab.id, { data: 'focus-off' });
|
||||
}
|
||||
}
|
||||
});
|
||||
@@ -0,0 +1,24 @@
|
||||
// Copyright 2023 Google LLC
|
||||
//
|
||||
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||
// you may not use this file except in compliance with the License.
|
||||
// You may obtain a copy of the License at
|
||||
//
|
||||
// https://www.apache.org/licenses/LICENSE-2.0
|
||||
//
|
||||
// Unless required by applicable law or agreed to in writing, software
|
||||
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
// See the License for the specific language governing permissions and
|
||||
// limitations under the License.
|
||||
|
||||
chrome.runtime.onMessage.addListener((msg) => {
|
||||
switch (msg.data) {
|
||||
case 'focus-on':
|
||||
document.body.setAttribute('data-focus-mode', 'on');
|
||||
break;
|
||||
case 'focus-off':
|
||||
document.body.removeAttribute('data-focus-mode');
|
||||
break;
|
||||
}
|
||||
});
|
||||
Reference in New Issue
Block a user