Edificio estensione di google chrome per ordinare le schede aperte da elemento DOM

0

Domanda

Sto costruendo un estensione di google chrome. L'obiettivo è quello di ordinare tutte le schede aperte da youtube con video durata (da basso a alto).

Ho trovato questo codice su GitHub del progetto, ha spiegato in questo tutorial:

popup.js

function byAlphabeticalURLOrder(tab1, tab2) {
  if (tab1.url < tab2.url) {
    return -1;
  } else if (tab1.url > tab2.url) {
    return 1;
  }
  return 0;
}

chrome.tabs.query({windowId: chrome.windows.WINDOW_ID_CURRENT}, (tabs) => {
  tabs.sort(byAlphabeticalURLOrder);
  for (let i = 0; i < tabs.length; i++) {
    chrome.tabs.move(tabs[i].id, {index: i});
  }
});

Questo codice funziona perfettamente con l'ordinamento in ordine alfabetico. Tuttavia, voglio adeguare l'ordinamento durata del video.

Così ho scritto questo file per ottenere il video di una durata di tutte le schede aperte, ma ancora non è possibile andare in giro per i "ordinamento o lo spostamento di schede" parte.

popup.js

chrome.tabs.query({
  windowId: chrome.windows.WINDOW_ID_CURRENT
}, (tabs) => {
  chrome.tabs.query({}, function (tabs) {
    for (var i = 0; i < tabs.length; i++) {
      chrome.tabs.executeScript(tabs[i].id, {
        code: '(' + function () {
          return {
            seconds: document.querySelector("video").duration
          };
        } + ')()'
      }, function (result) {
        document.write(result[0].seconds + '<br>');
      });
    }
  });
});

Output (Video durata in secondi) - (Appare in popup.html):

1229.041
187.501
510.581
609.941
1473.821
955.481
5464.281
59.201
1787.701
1523.941
1

Migliore risposta

1

Non è chiaro quello che hai provato, ma si possono aggiungere i valori per gli oggetti in un array esistente nel vostro ciclo e poi ordinare la matrice in un secondo loop. Perché executeScript è asincrono, è necessario attendere per il primo ciclo di finitura, il che significa che la risoluzione di un elenco di promesse, per poi ordinare la lista in duratavideo, quindi spostare le linguette.

Ecco cosa mi è venuta per MV3. Probabilmente ci sono più puliti modi per fare questo (io sono abbastanza nuovo a questo):

*Modifiche: modifiche Minori al ripulito l'organizzazione del codice. In allegato la funzione per azione (I. e., viene eseguita facendo clic su estensioni di google Chrome sul pulsante con l'icona).

popup.js


chrome.action.onClicked.addListener(sortTabsbyDuration);

async function sortTabsbyDuration() {
  async function createListEntry(tabId, i) {
    return new Promise((resolve) => {
      if (/\.youtube\.com\/watch\?/.test(tabs[i].url)) {
        chrome.scripting.executeScript(
          { target: { tabId: tabId }, func: getYouTubeLength, args: [tabId] },
          (returnValue) => {
            resolve(returnValue[0].result);
          }
        );
      } else {
        resolve({
          tabId: tabId,
          vidLength: 9999999999,
        });
      }
    });
  }
  function getYouTubeLength(aTab) {
    let vidLength = document.querySelector("video").duration;
    if (!vidLength) {
      vidLength=1;
    }
    return {
      tabId: aTab,
      vidLength: vidLength,
    };
  }
  // MAIN:
  const tabs = await chrome.tabs.query({ currentWindow: true });
  let promiseList = [];
  for (var index = 0; index < tabs.length; index++) {
    promiseList.push(createListEntry(tabs[index].id, index));
  }
  const promisesFinished = Promise.all(promiseList);
  const sortedList = (await promisesFinished).sort((a, b) => {
    return a.vidLength - b.vidLength;
  });
  console.log(sortedList);
  for (let index = 0; index < sortedList.length; index++) {
    await chrome.tabs.move(sortedList[index].tabId, { index: index });
  }
}

manifesto.json

{
    "manifest_version": 3,
    "name": "Sort Your Tubes",
    "version": "0.0.0.2",
    "action": {
        "default_title": "Click to sort YouTube videos by video length."
    },
    "background": {
        "service_worker": "popup.js"
    },
    "permissions": [
        "tabs",
        "scripting"        
    ],
    "host_permissions": [
        "*://www.youtube.com/*"        
    ]
}
2021-11-24 02:59:05

Wow, che è stato molto utile, grazie per il vostro grande risposta!!!
iamzeid

In altre lingue

Questa pagina è in altre lingue

Русский
..................................................................................................................
Polski
..................................................................................................................
Română
..................................................................................................................
한국어
..................................................................................................................
हिन्दी
..................................................................................................................
Français
..................................................................................................................
Türk
..................................................................................................................
Česk
..................................................................................................................
Português
..................................................................................................................
ไทย
..................................................................................................................
中文
..................................................................................................................
Español
..................................................................................................................
Slovenský
..................................................................................................................