Target Cart Summary

Summarize Target Cart

スクリプトをインストールするには、Tampermonkey, GreasemonkeyViolentmonkey のような拡張機能のインストールが必要です。

You will need to install an extension such as Tampermonkey to install this script.

スクリプトをインストールするには、TampermonkeyViolentmonkey のような拡張機能のインストールが必要です。

スクリプトをインストールするには、TampermonkeyUserscripts のような拡張機能のインストールが必要です。

このスクリプトをインストールするには、Tampermonkeyなどの拡張機能をインストールする必要があります。

このスクリプトをインストールするには、ユーザースクリプト管理ツールの拡張機能をインストールする必要があります。

(ユーザースクリプト管理ツールは設定済みなのでインストール!)

このスタイルをインストールするには、Stylusなどの拡張機能をインストールする必要があります。

このスタイルをインストールするには、Stylus などの拡張機能をインストールする必要があります。

このスタイルをインストールするには、Stylus tなどの拡張機能をインストールする必要があります。

このスタイルをインストールするには、ユーザースタイル管理用の拡張機能をインストールする必要があります。

このスタイルをインストールするには、ユーザースタイル管理用の拡張機能をインストールする必要があります。

このスタイルをインストールするには、ユーザースタイル管理用の拡張機能をインストールする必要があります。

(ユーザースタイル管理ツールは設定済みなのでインストール!)

このスクリプトの質問や評価の投稿はこちら通報はこちらへお寄せください
// ==UserScript==
// @name        Target Cart Summary
// @namespace   nikhilweee
// @match       https://www.target.com/cart
// @grant       none
// @version     1.0
// @author      nikhilweee
// @description Summarize Target Cart
// @icon        https://www.target.com/favicon.ico
// ==/UserScript==

function allElementsLoaded() {
  const detailsCards = document.querySelectorAll('[data-test="cartItem"]');
  return detailsCards.length > 0;
}

function runScriptWhenReady() {
  if (allElementsLoaded()) {
    const detailsCards = document.querySelectorAll('[data-test="cartItem"]');
    const table = document.createElement("table");
    table.style = "width: 100%; text-align: left;";
    table.innerHTML = "<th>Price</th><th>Item</th>";

    detailsCards.forEach((card) => {
      const itemName =
        card
          .querySelector('[data-test="cartItem-title"]')
          ?.textContent.trim() || "";
      const quantity = card.querySelector("select")?.value || "1";
      const itemPrice =
        card
          .querySelector('[data-test="cartItem-price"]')
          ?.textContent.trim() || "";
      let unitPrice =
        card
          .querySelector('[data-test="cartItem-unitPrice"]')
          ?.textContent.trim() || "";
      unitPrice = unitPrice.replace("each ", "") || itemPrice;
      const [itemNameShort, _] = itemName.split(" - ");
      const row = table.insertRow();
      row.innerHTML = `<td>${itemPrice}</td><td>(${quantity}) ${itemNameShort}</td>`;
    });

    const invoiceMetaElement = document.querySelector(
      '[data-test="cart-item-groups"]'
    );
    console.log(table);
    invoiceMetaElement.insertBefore(table, invoiceMetaElement.firstChild);
  } else {
    setTimeout(runScriptWhenReady, 100);
  }
}

window.addEventListener("load", runScriptWhenReady);