Prosta, jednokolorowa koszulka z bawełny i lnu, z półrękawem i dekoltem w kształcie litery V
${function() {
const variantData = data.variant || {"id":"1c6dcbc4-d598-4c31-8246-2b75229490b3","product_id":"3c7e52b8-e0ab-423c-9c38-dbdbfe1f31f1","title":"Bia\u0142y-M","weight_unit":"kg","inventory_quantity":992,"sku":"kb30-White-M","barcode":"","position":1,"option1":"Bia\u0142y","option2":"M","option3":"","note":"","image":{"src":"\/\/img.staticdj.com\/cba29db3de4f0cdec2f694775c153a9e.jpeg","path":"cba29db3de4f0cdec2f694775c153a9e.jpeg","width":2105,"height":2825,"alt":"","aspect_ratio":0.7451327433628319},"wholesale_price":[{"price":128,"min_quantity":1}],"weight":"0","compare_at_price":"0","price":"128","retail_price":"0","available":true,"url":"\/products\/simple-solid-color-v-neck-half-sleeve-t-shirt?variant=1c6dcbc4-d598-4c31-8246-2b75229490b3","available_quantity":999999999,"options":[{"name":"Kolor","value":"Bia\u0142y"},{"name":"Rozmiar","value":"M"}],"off_ratio":0,"flashsale_info":[],"sales":0};
const saveType = "amount";
const productLabelDiscountOn = true;
return `
-
${saveType == 'percentage'
? `-${variantData.off_ratio}%`
: `-`
}
`;
}()}
${function(){
const tipText = "Wybierz {{ name }}".replace(/\{\{\s+name\s+\}\}/g, data);
return `${tipText}
`
}()}
${function(){
const tipText = "Wybierz {{ name }}".replace(/\{\{\s+name\s+\}\}/g, data);
return `${tipText}
`
}()}
Produkt był niedostępny.
Produkt niedostępny.
DHL Płatność gotówką przy odbiorze
Masz prawo zwrócić produkt w ciągu 14 dni
Zapłać online i zyskaj 10% rabatu
SPECYFIKACJE
- Typ topu: T-shirt
- Styl: swobodny
- Materiał: mieszanki bawełny
- Okazja: Codziennie
- Dekolt: dekolt w kształcie litery V_V
- Typ wzoru: jednolity kolor
- Rodzaj rękawa: Zwykły rękaw
- Długość rękawa: połowa rękawa
- Typ dopasowania: Regularny
- Sezon: wiosna, lato
- Pakiet zawiera: 1 x koszulkę
TABELA ROZMIARÓW
Rozmiar |
Biust |
Długość |
CM |
CAL |
CM |
CAL |
|
|
|
|
|
M |
100 |
39,37 |
66,5 |
26.18 |
L |
105 |
41,34 |
68 |
26,77 |
XL |
111 |
43,70 |
69,5 |
27.36 |
2XL |
117 |
46.06 |
71 |
27,95 |
3XL |
123 |
48,43 |
71 |
27,95 |
NOTATKA
- Aby wybrać rozmiar, należy ściśle przestrzegać tabeli rozmiarów. Nie wybieraj bezpośrednio według swoich nawyków.
- Rozmiar może różnić się od 1-3 cm ze względu na pomiary ręczne. Uwaga podczas pomiaru.
- Ze względu na różne wyświetlacze i efekty świetlne rzeczywisty kolor przedmiotu może nieznacznie różnić się od koloru pokazanego na zdjęciach.
Oto, co mówią nasi klienci.
Najnowsza
Najbardziej lubiany
Najwyższe oceny
Najniższe oceny
Najbardziej lubiany
Najwyższe oceny
Najniższe oceny
×
${function(){
const limit = typeof data === 'number' ? data : 0;
return `
Zdjęcia/wideo (${limit || 0}/5)
` }()}
${(function(){
const closeIcon =
'
';
if (item.type === 'image') {
return `
${closeIcon}
`
}
return `
${closeIcon}
`
})()}
class SpzCustomFileUpload extends SPZ.BaseElement {
constructor(element) {
super(element);
this.uploadCount_ = 0;
this.fileList_ = [];
}
buildCallback() {
this.action = SPZServices.actionServiceForDoc(this.element);
this.registerAction('upload', (data) => {
this.handleFileUpload_(data.event?.detail?.data || []);
});
this.registerAction('delete', (data) => {
this.handleFileDelete_(data?.args?.data);
});
this.registerAction('preview', (data) => {
this.handleFilePreview_(data?.args?.data);
});
this.registerAction('limit', (data) => {
this.handleFileLimit_();
});
this.registerAction('sizeLimit', (data) => {
this.handleFileSizeLimit_();
});
}
isLayoutSupported(layout) {
return layout == SPZCore.Layout.LOGIC;
}
setData_(count, file) {
this.uploadCount_ = count;
this.fileList_ = file;
}
handleFileUpload_(data) {
data.forEach(i => {
if(this.fileList_.some(j => j.url === i.url)) return;
this.fileList_.push(i);
})
this.uploadCount_++;
sessionStorage.setItem('fileList', JSON.stringify(this.fileList_));
this.triggerEvent_("handleFileUpload", { count: this.uploadCount_, files: this.fileList_});
if(this.fileList_.length >= 5){
document.querySelector('#review_upload').style.display = 'none';
}
if(this.fileList_.length > 0){
document.querySelector('.apps-reviews-write-anonymous-box').style.marginTop = '8px';
}
}
handleFileDelete_(index) {
this.fileList_.splice(index, 1);
this.uploadCount_--;
sessionStorage.setItem('fileList', JSON.stringify(this.fileList_));
this.triggerEvent_("handleFileDelete", { count: this.uploadCount_, files: this.fileList_});
document.querySelector('#review_upload').style.display = 'block';
if(this.fileList_?.length === 0){
document.querySelector('.apps-reviews-write-anonymous-box').style.marginTop = '132px';
}
}
handleFilePreview_(index) {
const finalPreviewData = this.fileList_[index];
const filePreviewModal = document.getElementById('filePreviewModal');
const fullScreenVideo = document.getElementById('fullScreenVideo');
const fullScreenImage = document.getElementById('fullScreenImage');
const previewModalClose = document.getElementById('previewModalClose');
const previewLoading = document.getElementById('previewLoading');
filePreviewModal.style.display = 'block';
previewLoading.style.display = 'flex';
if(finalPreviewData?.type === 'video'){
const media = this.mediaParse_(this.fileList_[index]?.url);
fullScreenVideo.addEventListener('canplaythrough', function() {
previewLoading.style.display = 'none';
});
fullScreenImage.src = '';
fullScreenImage.style.display = 'none';
fullScreenVideo.style.display = 'block';
fullScreenVideo.src = media.mp4 || '';
} else {
fullScreenImage.onload = function() {
previewLoading.style.display = 'none';
};
fullScreenVideo.src = '';
fullScreenVideo.style.display = 'none';
fullScreenImage.style.display = 'block';
fullScreenImage.src = finalPreviewData.url;
}
previewModalClose.addEventListener('click', function() {
filePreviewModal.style.display = 'none';
});
}
handleFileLimit_() {
alert(window.AppReviewsLocale.comment_file_limit || 'please do not upload files more than 5');
this.triggerEvent_("handleFileLimit");
}
handleFileSizeLimit_() {
alert(window.AppReviewsLocale.comment_file_size_limit || 'File size does not exceed 10M');
}
clear(){
this.fileList_ = [];
this.uploadCount_ = 0;
sessionStorage.setItem('fileList', JSON.stringify(this.fileList_));
this.triggerEvent_("handleClear", { count: this.uploadCount_, files: this.fileList_});
document.querySelector('#review_upload').style.display = 'block';
}
mediaParse_(url) {
var result = {};
try {
url.replace(/[?&]+([^=&]+)=([^&]*)/gi, function (str, key, value) {
try {
result[key] = decodeURIComponent(value);
} catch (e) {
result[key] = value;
}
});
result.preview_image = url.split('?')[0];
} catch (e) {};
return result;
}
triggerEvent_(name, data) {
const event = SPZUtils.Event.create(this.win, name, data);
this.action.trigger(this.element, name, event);
}
}
SPZ.defineElement('spz-custom-file-upload', SpzCustomFileUpload);
The review would not show in product details on storefront since it does not support to.