160 Pcs Auto/ Home Hand Tool Kit - Wrenches Pliers Ratchets Sockets w/ Toolbox [A Variety of Color Options]
160 Pcs Auto/ Home Hand Tool Kit - Wrenches Pliers Ratchets Sockets w/ Toolbox [A Variety of Color Options]
${function() {
const variantData = data.variant || {"id":"5c017412-0fcc-4e2b-a170-9ccb4ba5b432","product_id":"1345618a-e1f9-4521-8bbd-91e2a284908a","title":"Yellow","weight_unit":"lb","inventory_quantity":0,"sku":"TOOLS-00024","barcode":"","position":1,"option1":"Yellow","option2":"","option3":"","note":"","image":{"src":"\/\/img.staticdj.com\/45f2fb09aa34325e5dddcce2c5b94fa6.jpeg","path":"45f2fb09aa34325e5dddcce2c5b94fa6.jpeg","width":600,"height":600,"alt":"","aspect_ratio":1},"wholesale_price":[{"price":61.99,"min_quantity":1}],"weight":"0","compare_at_price":"0","price":"61.99","retail_price":"0","available":true,"url":"\/products\/tools-00023?variant=5c017412-0fcc-4e2b-a170-9ccb4ba5b432","available_quantity":999999999,"options":[{"name":"Color","value":"Yellow"}],"off_ratio":"0","flashsale_info":{"variant_id":"5c017412-0fcc-4e2b-a170-9ccb4ba5b432","product_id":"","quantity":0,"discount_id":"","limit_time":0,"limit_buy":0,"user_limit_buy":0,"discount_sales":0,"discount_sales_rate":"","discount_stock":0,"ends_at":0,"starts_at":0,"allow_oversold":"","allocation_method":"","price":"61.99","compare_at_price":"","discount_price":"61.99","customary_saved_price":"","customary_off_ratio":"","discount_saved_price":"","discount_off_ratio":"0","use_before_price":false,"before_price":"","title":"","properties":"","color_setting_promotional_copy":"","discount_quantity":0,"is_need_split":false},"sales":0};
const saveType = null;
const productSaveLabel = null;
return `
-
${ variantData.off_ratio }%
`; }()}
${function(){
return `
${data.starNum}/${data.starTotal}
`;
}()}
${function(){
return `
${data.showStarText === 'true' ? `
${data.starNum}/${data.starTotal}
` : ''}
`;
}()}
const TAG = 'spz-custom-revue-star';
class SPZCustomRevueStar extends SPZ.BaseElement {
constructor(element) {
super(element);
}
static deferredMount() {
return false;
}
buildCallback = () => {
this.action_ = SPZServices.actionServiceForDoc(this.element);
this.templates_ = SPZServices.templatesForDoc(this.element);
this.xhr_ = SPZServices.xhrFor(this.win);
this.starNum = this.element.getAttribute('starNum');
this.starTotal = this.element.getAttribute('starTotal');
this.showStarText = this.element.getAttribute('showStarText');
this.starColor = this.element.getAttribute('color');
this.interact = this.element.getAttribute('interact');
this.starSize = this.element.getAttribute('starSize') || 14;
}
mountCallback = () => {
this.doRender_({
starTotal: this.starTotal,
totalArray: Array.from({ length: Number(this.starTotal) }, (v, k) => k + 1),
starNum: this.starNum,
showStarText: this.showStarText,
starColor: this.starColor,
starSize: this.starSize
}).then(() => {
if (this.interact) {
this.addEventListeners_();
}
});
}
addEventListeners_ = () => {
const stars = document.querySelectorAll('.revue-star__star');
stars.forEach(star => {
star.addEventListener('click', event => {
const starEl = star.closest('.revue-star__star');
const starIndex = Number(starEl.dataset.index);
let isHalf = event.offsetX < star.offsetWidth / 2;
// rtl
if (document.documentElement.getAttribute('dir') === 'rtl') {
isHalf = event.offsetX > star.offsetWidth / 2;
}
const starValue = isHalf ? starIndex - 0.5 : starIndex;
this.starClickHandler_({ value: starValue });
});
});
}
renderStar = () => {
const isRtl = document.documentElement.getAttribute('dir') === 'rtl';
const stars = this.element.querySelectorAll('.revue-star__star');
stars.forEach((star, i) => {
const starIndex = i + 1;
const starEl = star.querySelector('svg:nth-child(2)');
const isHalf = this.starNum % 1 > 0 && Math.ceil(this.starNum) === starIndex;
const isSolid = starIndex <= Math.ceil(this.starNum);
starEl.style.display = isSolid ? 'block' : 'none';
if (isHalf) {
if (isRtl) {
// RTL布局下,如果是半星,显示星星的右半边
starEl.style.clipPath = `polygon(50% 0, 100% 0, 100% 100%, 50% 100%)`;
} else {
// LTR布局下,如果是半星,显示星星的左半边
starEl.style.clipPath = `polygon(0 0, 50% 0, 50% 100%, 0 100%)`;
}
} else {
starEl.style.clipPath = `polygon(0 0, 100% 0, 100% 100%, 0 100%)`
}
});
const showCountEle = this.element.querySelector('#revue-star-show-count');
showCountEle && SPZ.whenApiDefined(showCountEle).then((api) => {
api.render({ starNum: this.starNum, starTotal: this.starTotal });
});
}
doRender_ = (data) => {
return this.templates_
.findAndRenderTemplate(this.element, { starSize: this.starSize, ...data }, null)
.then((el) => {
const children = this.element.querySelector('*:not(template)');
children && SPZCore.Dom.removeElement(children);
this.element.appendChild(el);
})
.then(() => {
this.starNum = data.starNum;
this.renderStar();
});
}
starClickHandler_ = (event) => {
this.starNum = event.value;
this.renderStar();
this.triggerEvent_('change', { value: event.value });
}
triggerEvent_(name, data) {
const event = SPZUtils.Event.create(this.win, `${ TAG }.${ name }`, data || {});
this.action_.trigger(this.element, name, event);
}
isLayoutSupported(layout) {
return layout == SPZCore.Layout.CONTAINER;
}
}
SPZ.defineElement(TAG, SPZCustomRevueStar)
()
try {
const productId = window.SHOPLAZZA.meta.page.resource_id;
const productType = `default`;
const getProductReviews = (star_least) =>
fetch('/api/comment/count-star-multi',
{
method: 'POST',
headers: {
'Content-Type': 'application/json',
},
body: JSON.stringify({
product_id: [productId],
star_least: star_least || 1,
}),
}).then(res => res.json());
try {
const section = document.querySelector('#revue-product-star');
if(productType === "gift_card" && section) {
section.style.display = 'none';
}
} catch(e) {
console.log(e);
window.addEventListener('load', () => {
try {
const section = document.querySelector('#revue-product-star');
if(productType=== "gift_card" && section) {
section.style.display = 'none';
}
} catch(e) {
console.log(e)
}
})
}
const getReviewsConfig = async () => {
let data = {};
const url = new URL(window.location.href);
const preview_theme_id = url.searchParams.get('preview_theme_id');
const commentConfig = await fetch('/api/comment-config', {
method: 'GET',
headers: {
'Content-Type': 'application/json',
}
}).then(res => res.json());
data = commentConfig.data;
const themeConfig = await fetch(`/api/comment-config?theme_id=${preview_theme_id || ''}`, {
method: 'GET',
headers: {
'Content-Type': 'application/json',
}
}).then(res => res.json());
if (themeConfig?.data && themeConfig.data.star_color) {
data.star_color = themeConfig.data.star_color;
}
if (preview_theme_id) {
data.star_least = window.apps_global && apps_global.reviews && apps_global.reviews.preview_star_least;
} else if (themeConfig?.data && themeConfig.data.product_settings) {
data.star_least = themeConfig.data.product_settings.star_least;
}
return data;
};
if (productId && window.SHOPLAZZA.meta.page.template_type == 1) {
getReviewsConfig().then(async res => {
const config = res;
let review = await getProductReviews(config.star_least);
review = review.data[productId];
if (!config.open_status || (!review.comment_avg_star && !config.show_no_comment_star)) return;
const render = async () => {
const section = document.querySelector('#revue-product-star');
const starComponent = document.querySelector('#revue-product-star-component');
const count = document.querySelector('#revue-product-star-count');
count.innerText = review.published_count;
const api = await SPZ.whenApiDefined(starComponent);
api.doRender_({
starNum: review.comment_avg_star,
starTotal: 5,
showStarText: false,
starColor: config.star_color,
totalArray: Array.from({ length: 5 }, (v, k) => k + 1)
});
section.style.opacity = 1;
}
render();
document.addEventListener('dj.editor.update', render);
});
}
} catch (e) {console.warn(e)};
${function() {
const minInventory = parseInt('7');
const maxInventory = parseInt('10');
const randomInventory = Math.round(Math.random() * (maxInventory - minInventory)) + minInventory;
const customText = "Only {stock} item(s) left in stock!".replace(/\{stock\}/g, '' + randomInventory + '');
const barWidth = (randomInventory / maxInventory) * 100 + '%';
return `
`;
}()}
${function(){
return `
Please select a Color
`;
}()}
Product was out of stock.
Enjoy free shipping on every order, delivered to your doorstep no matter where you are in the world.
Shop with confidence with our hassle-free returns policy, ensuring you love what you buy.
Designed with the planet in mind, all our products are committed to sustainable practices.
Your payment information is always protected with our advanced, encrypted checkout security.
Description:
Some say that tool sets are not worth it, because you end up with a lot of pieces you don’t need. But that ignores the audience for whom a pre-packaged set of tools can be perfect: the person who owns no tools and doesn’t know where to begin; the person who used to own a set of tools which got loaned out and not returned; someone with a basic set who needs an upgrade; and finally, the person whose tools don’t match and is missing the ‘in-betweenâ€?pieces. If this describes you (or someone you know), be sure to look over the DNA brand tool sets that we feature on CA Auto Parts. We have household hand tool sets; hand tools plus cordless drill sets; screwdriver/pliers/socket sets; impact socket sets; and much more. All of our tool sets include attractive, color-keyed storage/carrying cases, making movement from home to job site and back a cinch. If you bought each component in any of these sets separately, you would easily pay up to 5 times as much. Our DNA tool sets make great gifts for any occasion at any time of year!
Specifics and Features:
This 160-pc. tool set with case includes most of the tools that you need around the home.
Includes: 1 quick-release ratchet, 1 extension bar, 18 sockets, 6 wrenches, 16 hex keys, 1 magnetic holder
SAE / Metric Sockets include 6-point standard socket depths
Needle Nose & Diagonal Cutter
6 Precision Screw Drivers
Precision Philips & Standard Screw Drivers - 4
The tools are made of drop forged steel and have a chrome-plated finish for long-lasting durability
The tool set comes with a carrying case, making it easy and convenient to move the tools when you need to fix up a car outside of your garage
Package Included:
1 Quick-Release 3/8" ratchet
1 X 3" Extension Bar
1/4 Sockets : 5mm, 6mm, 7mm, 8mm, 9mm, 10mm, 11mm, 3/16", 1/4", 9/32", 5/16", 11/32", 3/8", 7/16"
3/8" Sockets : 1/2", 9/16", 12mm, 14mm
8 X Wrenches : 1/16", 5/64", 3/32", 1/8", 5/32", 3/16", 7/32", 1/4"
12oz Tubular Steel Hammer
16 Hex Keys
1 X Needle Nose Plier
1 X Diagonal Cutter
4 X Precision Screw Drivers
4 In 1 Screw Driver
1 X Utility Knife
1 X 10' Measuring Tape
1 X Fastener Assortment Case
1 X Spark Plug Socket
${function(){
const variantData = data.variant || null;
return `
Vendor by :
${data.product && data.product.vendor}
Weight :
${variantData && variantData.weight}${variantData && variantData.weight_unit}
Barcode :
${variantData && variantData.barcode}
Sku :
${variantData && variantData.sku}
Inventory :
${variantData && variantData.available_quantity}
` }()}