Men's Extra-Wide Comfort Shoes for Curing Arthritis  Stunahome.com
Men's Extra-Wide Comfort Shoes for Curing Arthritis  Stunahome.com
Men's Extra-Wide Comfort Shoes for Curing Arthritis  Stunahome.com
Men's Extra-Wide Comfort Shoes for Curing Arthritis  Stunahome.com
Men's Extra-Wide Comfort Shoes for Curing Arthritis  Stunahome.com
Men's Extra-Wide Comfort Shoes for Curing Arthritis  Stunahome.com
Men's Extra-Wide Comfort Shoes for Curing Arthritis  Stunahome.com
Men's Extra-Wide Comfort Shoes for Curing Arthritis  Stunahome.com
Men's Extra-Wide Comfort Shoes for Curing Arthritis  Stunahome.com
Men's Extra-Wide Comfort Shoes for Curing Arthritis  Stunahome.com
Men's Extra-Wide Comfort Shoes for Curing Arthritis  Stunahome.com
Men's Extra-Wide Comfort Shoes for Curing Arthritis  Stunahome.com
Men's Extra-Wide Comfort Shoes for Curing Arthritis  Stunahome.com
Men's Extra-Wide Comfort Shoes for Curing Arthritis  Stunahome.com
Men's Extra-Wide Comfort Shoes for Curing Arthritis  Stunahome.com
Men's Extra-Wide Comfort Shoes for Curing Arthritis  Stunahome.com
Men's Extra-Wide Comfort Shoes for Curing Arthritis  Stunahome.com
Men's Extra-Wide Comfort Shoes for Curing Arthritis  Stunahome.com
Men's Extra-Wide Comfort Shoes for Curing Arthritis  Stunahome.com
Men's Extra-Wide Comfort Shoes for Curing Arthritis  Stunahome.com
Men's Extra-Wide Comfort Shoes for Curing Arthritis  Stunahome.com
Men's Extra-Wide Comfort Shoes for Curing Arthritis  Stunahome.com
Men's Extra-Wide Comfort Shoes for Curing Arthritis  Stunahome.com
Men's Extra-Wide Comfort Shoes for Curing Arthritis  Stunahome.com
Men's Extra-Wide Comfort Shoes for Curing Arthritis  Stunahome.com
Men's Extra-Wide Comfort Shoes for Curing Arthritis  Stunahome.com
Men's Extra-Wide Comfort Shoes for Curing Arthritis  Stunahome.com
Men's Extra-Wide Comfort Shoes for Curing Arthritis  Stunahome.com
Men's Extra-Wide Comfort Shoes for Curing Arthritis  Stunahome.com
Men's Extra-Wide Comfort Shoes for Curing Arthritis  Stunahome.com
Men's Extra-Wide Comfort Shoes for Curing Arthritis  Stunahome.com
Men's Extra-Wide Comfort Shoes for Curing Arthritis  Stunahome.com
Men's Extra-Wide Comfort Shoes for Curing Arthritis  Stunahome.com
Men's Extra-Wide Comfort Shoes for Curing Arthritis  Stunahome.com
Men's Extra-Wide Comfort Shoes for Curing Arthritis  Stunahome.com
Men's Extra-Wide Comfort Shoes for Curing Arthritis  Stunahome.com

Men's Extra-Wide Comfort Shoes for Curing Arthritis

Fits True to Size
Free Return & Exchange

color - Blue

Please select a color

size

Please select a size

Price

£99.00 £69.00
1 sold
The current item does not participate in the discount gift campaign. Switch the participating items to check the design.
(This prompt will not be displayed on the client-side)

Quantity

/** @private {string} */ class SpzCustomAnchorScroll extends SPZ.BaseElement { static deferredMount() { return false; } constructor(element) { super(element); /** @private {Element} */ this.scrollableContainer_ = null; } isLayoutSupported(layout) { return layout == SPZCore.Layout.LOGIC; } buildCallback() { this.viewport_ = this.getViewport(); this.initActions_(); } setTarget(containerId, targetId) { this.containerId = '#' + containerId; this.targetId = '#' + targetId; } scrollToTarget() { const container = document.querySelector(this.containerId); const target = container.querySelector(this.targetId); const {scrollTop} = container; const eleOffsetTop = this.getOffsetTop_(target, container); this.viewport_ .interpolateScrollIntoView_( container, scrollTop, scrollTop + eleOffsetTop ); } initActions_() { this.registerAction( 'scrollToTarget', (invocation) => this.scrollToTarget(invocation?.caller) ); this.registerAction( 'setTarget', (invocation) => this.setTarget(invocation?.args?.containerId, invocation?.args?.targetId) ); } /** * @param {Element} element * @param {Element} container * @return {number} * @private */ getOffsetTop_(element, container) { if (!element./*OK*/ getClientRects().length) { return 0; } const rect = element./*OK*/ getBoundingClientRect(); if (rect.width || rect.height) { return rect.top - container./*OK*/ getBoundingClientRect().top; } return rect.top; } } SPZ.defineElement('spz-custom-anchor-scroll', SpzCustomAnchorScroll); const STRENGTHEN_TRUST_URL = "/api/strengthen_trust/settings"; class SpzCustomStrengthenTrust extends SPZ.BaseElement { constructor(element) { super(element); this.renderElement_ = null; } isLayoutSupported(layout) { return layout == SPZCore.Layout.CONTAINER; } buildCallback() { this.xhr_ = SPZServices.xhrFor(this.win); const renderId = this.element.getAttribute('render-id'); SPZCore.Dom.waitForChild( document.body, () => !!document.getElementById(renderId), () => { this.renderElement_ = SPZCore.Dom.scopedQuerySelector( document.body, `#${renderId}` ); if (this.renderElement_) { this.render_(); } this.registerAction('track', (invocation) => { this.track_(invocation.args); }); } ); } render_() { this.fetchData_().then((data) => { if (!data) { return; } SPZ.whenApiDefined(this.renderElement_).then((apis) => { apis?.render(data); document.querySelector('#strengthen-trust-render-1539149753700').addEventListener('click',(event)=>{ if(event.target.nodeName == 'A'){ this.track_({type: 'trust_content_click'}); } }) }); }); } track_(data = {}) { const track = window.sa && window.sa.track; if (!track) { return; } track('trust_enhancement_event', data); } parseJSON_(string) { let result = {}; try { result = JSON.parse(string); } catch (e) {} return result; } fetchData_() { return this.xhr_ .fetchJson(STRENGTHEN_TRUST_URL) .then((responseData) => { if (!responseData || !responseData.data) { return null; } const data = responseData.data; const moduleSettings = (data.module_settings || []).reduce((result, moduleSetting) => { return result.concat(Object.assign(moduleSetting, { logos: (moduleSetting.logos || []).map((item) => { return moduleSetting.logos_type == 'custom' ? this.parseJSON_(item) : item; }) })); }, []); return Object.assign(data, { module_settings: moduleSettings, isEditor: window.self !== window.top, }); }); } } SPZ.defineElement('spz-custom-strengthen-trust', SpzCustomStrengthenTrust);

THESE SHOES ARE SPECIALLY DESIGNED TO COMFORT COMMON WIDE FOOT PROBLEMS

KEY BENEFITS

WIDE WIDTH

The wide toe box offers a comfortable, non-binding fit, and eases pressure on sensitive feet. Stretch breathable mesh upper expand with your foot when you walk, perfect for all seasons and outdoor activities. More comfortable closely fit to help you reduce irritation.

EXTRA DEPTH

Extra depth design with 3-in-1 removable memory foam insoles provides ample space for custom made orthotics. These comfortable paddings provide moderate control and support and protection for swollen feet, offering the best solution and customized fit for problem feet.

3-in-1 ARCH SUPPORT

These shoes corrects posture and eliminates muscle imbalances by balancing your feet at the perfect angle its original position to realign skeleton positioning.

Simply, slip them on and snug your feet in place around the toe clasp for enhanced support.

It's lightweight, but with a wedge design, you can walk more steadily & stand for hours without any strain or imbalance.

  • Distribute Pressure Evenly

  • Correct Poor Posture

  • Realign skeleton

EASY TO PUT ON & OFF

Forefoot straps are highly adjustable thanks to velcro closures, the range of adjustment is ideal for changes in the degree of swelling. Wearing the lightweight diabetic shoe can help alleviate pressure on swollen feet, bunions, oedema, lymphedema, diabetes or hammer toes.

BREATHABLE & LIGHTWEIGHT MATERIAL

Stretchable, breathable and lightweight upper keeps feet cool and dry. Smooth and breathable interior offers a great in-shoe feel. Soft foam padded tongue and collar. Protective firm heel counter enhances stability and extra support for making more efficient walking. Simply the most unique extra wide orthopedic walking/nursing shoes for women on the market. 

FLEXIBLE 

Highly durable and flexible rubber outsole and lightweight midsole. EVA molded midsole and TPU Air cushion system absorbs impacting shock and increases rebound, promotes a smoother transition to midstance and give an energetic feeling. 

NON SLIP SOLE

Outsole bottom treads with extra grip offer superior slip resistance.

TARGET USER & OCCASION 

Ideal for those with wide feet or who need extra stretch, comfort and soft to accommodate, relief Swollen Feet, Bunions, Plantar Fasciitis, Corns, Calluses, Osteoarthritis, Rheumatoid Arthritis, Hammer Toes, Morton's Neuroma, Oedema, Dementia, Injuries involving tendons, muscles, and bones or need a Post-op shoe.

SIZE CHART 

Stunahome wide shoes are different from normal shoe size

We recommend buying the dimensions according to the FOOT LENGTH

For example: Your foot length is 10inch, so according to our ruler chart you should choose UK7.5.

Not sure how to measure foot length?

The following instructions will help you.

  • Take a piece of paper and a pen or pencil
  • Stand with your heels against the wall
  • Stand upright, placing your weight on both feet
  • Get someone else to draw a line be the tip of your toe
  • Measure the length from the wall to the line
  • Compare the foot length with size chart

Specifications:

  • Shoe Size Options: UK7-13 (Unisex, women buy according to foot length)

  • Closure Type: Velcro design

  • Upper Material: Breathable Knit Mesh

  • Lining Material: Soft Synthetic Fabric

  • Insole Material: Orthopedic Comfort Cushioning

  • Outsole Material: Durable Non-Slip Rubber

  • Features: Lightweight | Breathable | Shock Absorption | Orthopedic Support

Note: To ensure the quality and effectiveness of the shoes, we have to hand made some parts of the shoes leading to long production time. Please patiently wait about 5 days for tracking number and another 10 days for delivery

WHY US?

  • We work directly with manufacturers all over the world to ensure the best quality of our products. We have a Quality Control Department which helps us to keep our promise!
  • Price is always competitive.
  • Awesome Customer Service
  • Amazing products along with High Quality
  • Read reviews from our lovely customers

Click BUY NOW To Order Yours Now!

Can These Shoes Help You?

Trusted Solution for All Foot Conditions

Our Orthopedic Shoes have been specifically designed to provide 24/7 comfort to your feet.

Select Your Condition:

RELIEF FOR

Foot Pain

Immediate Relief: Provides instant cushioning to alleviate pain and discomfort in your feet.

Enhanced Support: Offers excellent arch support to prevent strain and reduce overall foot pain.

Improves Mobility: Enhances foot flexibility and range of motion, making daily activities more comfortable.

Reduces Fatigue: Alleviates foot and leg fatigue by distributing weight evenly across the foot.

Prevents Recurrence: Helps prevent future foot pain by maintaining proper foot alignment and support.

RELIEF FOR

Plantar Fasciitis

Reduces Heel Pain: Provides targeted support to alleviate pressure on the plantar fascia, reducing heel pain.

Improves Foot Alignment: Enhances foot posture and alignment, preventing strain on the plantar fascia.

Increases Mobility: Enhances foot flexibility and range of motion, making daily activities more comfortable.

Offers Arch Support: Provides robust arch support to reduce tension on the plantar fascia.

Prevents Recurrence: Helps prevent future episodes of plantar fasciitis by maintaining proper foot alignment.

RELIEF FOR

Neuropathy


Enhances Foot Sensitivity: Cushions and supports to improve nerve function and foot sensitivity.


Reduces Numbness and Tingling: Alleviates uncomfortable sensations associated with neuropathy.


Improves Circulation: Boosts blood flow to the feet, enhancing overall foot health.


Provides Comfort: Offers soft, cushioned support to ease pain and discomfort.


Stabilizes Foot Position: Prevents foot slippage and reduces the risk of injury.

RELIEF FOR

Flat Feet

Provides Arch Support: Enhances arch support to prevent overpronation and pain.


Improves Alignment: Corrects foot posture to reduce strain on the feet and legs.


Reduces Fatigue: Alleviates foot and leg fatigue by distributing weight evenly.


Prevents Pain: Minimizes the risk of developing foot pain and discomfort.


Enhances Stability: Provides a stable base for walking and standing.


RELIEF FOR

Back Pain

Improves Posture: Provides excellent arch support and proper foot alignment, which helps improve overall posture and reduce strain on the back.


Reduces Back Strain: Cushions and supports the feet to alleviate pressure on the lower back, minimizing pain and discomfort.


Enhances Comfort: Offers all-day comfort with soft, supportive cushioning, reducing the impact on your back with every step.


Even Weight Distribution: Distributes weight evenly across the foot, reducing uneven stress on the spine and lower back.


Increases Mobility: Promotes better foot mechanics and stability, allowing you to move more freely and comfortably without exacerbating back pain.

RELIEF FOR

Diabetes

Prevents Ulcers: Minimizes pressure points to prevent the development of foot ulcers.


Enhances Blood Flow: Promotes better circulation to support foot health.


Reduces Blister Risk: Features seamless interiors to reduce friction and prevent blisters.


Offers Cushioning: Provides soft cushioning to protect sensitive feet from pain.


Maintains Foot Health: Supports overall foot health by keeping feet dry and comfortable.

RELIEF FOR

Arthritis

Eases Joint Pain: Provides cushioning to reduce joint pain and discomfort.


Improves Mobility: Enhances foot flexibility and range of motion.


Reduces Inflammation: Helps reduce inflammation and swelling in the feet.


Offers Support: Provides firm support to relieve pressure on arthritic joints.


Enhances Comfort: Offers all-day comfort with soft, supportive cushioning.

RELIEF FOR

Heel Pain

Alleviates Heel Pain: Provides targeted cushioning to reduce pressure and pain in the heel area, offering immediate relief.


Enhanced Arch Support: Offers superior arch support to prevent overpronation and alleviate strain on the heel.


Reduces Inflammation: Helps reduce inflammation and discomfort in the heel with soft, supportive materials.


Improves Foot Alignment: Corrects foot posture to evenly distribute pressure and minimize heel pain.


Increases Comfort: Ensures all-day comfort with plush cushioning and ergonomic design, allowing you to walk pain-free.

RELIEF FOR

Hammer Toes

Reduces Toe Pain: Provides gentle cushioning and support to alleviate pain caused by hammer toes.


Prevents Friction: Features a spacious toe box to reduce friction and pressure on the toes, preventing corns and calluses.


Enhances Comfort: Offers soft, supportive cushioning that adapts to the shape of your feet, ensuring all-day comfort.


Corrects Toe Alignment: Supports proper toe alignment to minimize discomfort and prevent the condition from worsening.


Improves Mobility: Promotes better foot mechanics and flexibility, allowing you to move more comfortably and naturally.

RELIEF FOR

Bunions

Reduces Bunion Pain: Cushions the bunion area to relieve pain and pressure.


Improves Foot Alignment: Corrects foot posture to reduce bunion progression.


Prevents Friction: Features a seamless design to prevent rubbing and blisters.


Enhances Comfort: Provides soft, supportive cushioning for all-day comfort.


Supports Foot Health: Helps maintain overall foot health by reducing strain on the bunion area.

RELIEF FOR

Drop Foot

Improves Foot Stability: Provides excellent support and stability to help control foot drop and enhance walking gait.


Enhances Mobility: Offers firm yet comfortable support that allows for smoother, more natural foot movement.


Reduces Trip Hazard: Features a supportive design that helps lift the foot, reducing the risk of tripping and falling.


Promotes Proper Foot Alignment: Ensures proper foot alignment and support, which can alleviate strain on the lower leg and improve overall mobility.


Increases Comfort: Delivers all-day comfort with cushioned insoles and ergonomic design, making it easier to walk without discomfort.

RELIEF FOR

Pronation

Corrects Foot Alignment: Provides excellent arch support to correct overpronation and promote proper foot alignment.


Reduces Pain and Discomfort: Alleviates pain associated with overpronation by evenly distributing weight across the foot.


Enhances Stability: Offers stability and support to prevent the foot from rolling inward, reducing the risk of injuries.


Improves Posture: Supports proper body alignment, which can help improve posture and reduce strain on the legs and back.


Increases Comfort: Ensures all-day comfort with cushioned insoles and ergonomic design, making it easier to walk and stand without discomfort.

RELIEF FOR

Achilles Tendinitis

Reduces Heel Pain: Cushions the heel to alleviate pain from Achilles tendinitis.


Enhanced Support: Offers excellent arch support to prevent strain and reduce overall foot pain.


Reduces Inflammation: Helps reduce inflammation and discomfort in the Achilles area.


Offers Support: Provides firm support to the heel and arch to relieve pressure.


Promotes Healing: Supports the healing process by minimizing strain on the Achilles tendon.

RELIEF FOR

Morton's Neuroma

Reduces Forefoot Pain: Cushions the metatarsal area to alleviate pain.


Enhances Foot Support: Provides extra support to the ball of the foot.


Improves Comfort: Offers soft cushioning to enhance overall foot comfort.


Distributes Pressure: Evenly distributes pressure across the foot to prevent pain.


Increases Mobility: Enhances foot flexibility and reduces pain during movement.

FAQs

1. What is the 60 Day Wear Test Guarantee?

We believe 100% in our products. This is why we offer a 60-Day Wear Test Guarantee where you can test the shoes and decide for yourself.

2. Why Should We Take Care Of Our Feet?

The feet are the foundation of the entire human body. They support your body from the ground up.

3. What is the Plantar Fascia?

The plantar fascia muscle is a long band of muscle tissue and ligaments that stretches all the way from your heel bone to the front of your foot. This supports the arch and bone structure of the foot. When inflamed, this causes a variety of issues in the foot such as Plantar Fasciitis, and Heel Pain.

4. Who Should Wear Orthopedic Shoes?

Orthopedic shoes help align a patient's feet and off-load areas of increased stress (like a collapsed arch, an arthritic joint, or a diabetic ulcer or callus).

5. Can normal people wear orthopedic shoes?

People of all ages wear orthopedic shoes. They are also popular among people without foot problems because they are specifically designed to support the foot, ankle, and leg‘s structure and mechanics and strengthen important muscles.

6. What Happens If I Order the Wrong Size?

Don't worry, this happens. Just send your order back and we will ship the correct size to you at no extra cost.

60 Days Money Back Guarantee

We offer a 60-day guarantee to eliminate your foot pain! We fully stand behind our product and believe we have the best product in the industry. We want to give you a full 2 months to try out our product, and if you don't like it 100%, you can contact us and we'll find a solution.

Customer Reviews
Here are what our customers say.
Write a Review
Customer Reviews
Wow you reached the bottom
Newest
Most liked
Highest ratings
Lowest ratings
×
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.
class SpzSmartBlockComponent extends SPZ.BaseElement { constructor(element) { super(element); this.templates_ = null; this.container_ = null; this.i18n_ = {}; this.config_ = {}; this.show_type_ = 3; this.product_resource_id_ = ''; this.collection_resource_id_ = ''; this.cart_items_ = []; this.customer_id_ = ''; this.order_id_ = ''; } static deferredMount() { return false; } isLayoutSupported(layout) { return layout == SPZCore.Layout.CONTAINER; } buildCallback() { const template_type = window.SHOPLAZZA.meta.page.template_type; if (template_type === 1) { this.show_type_ = 3; this.product_resource_id_ = window.SHOPLAZZA.meta.page.resource_id; } else if (template_type === 2) { this.show_type_ = 4; this.collection_resource_id_ = window.SHOPLAZZA.meta.page.resource_id; } else if (template_type === 15){ this.show_type_ = 5; } else if (template_type === 13){ this.show_type_ = 6; } else if (template_type === 20){ this.show_type_ = 7; this.customer_id_ = window.SHOPLAZZA.customer.customer_id; } else if (template_type === 35){ this.show_type_ = 8; this.order_id_ = window.location.pathname.split('/').pop(); } this.templates_ = SPZServices.templatesForDoc(this.element); this.setAction_(); } mountCallback() { console.log('appzebu smart mounted'); const that = this; const themeName = window.SHOPLAZZA.theme.merchant_theme_name; const isGeek = /Geek/.test(themeName); this.fetchRules().then((res) => { if (res && res.rules && res.rules.length) { const blockEl = document.getElementById('smart_recommend_block'); SPZ.whenApiDefined(blockEl).then((api) => { api.render({data: res}, true).then(() => { if (isGeek && that.show_type_ === 6) { blockEl.querySelector('.plugin_container_wrpper').style.padding = '30px 0'; } const recommendStyle = document.createElement('style'); recommendStyle.innerHTML = ` .plugin__recommend_container,.app-recommend-card { display: none !important; } `; document.head.appendChild(recommendStyle); const fetchList = []; res.rules.forEach((rule) => { fetchList.push(this.fetchRuleProductList(rule.id)); }); const fetchAll = Promise.all(fetchList); fetchAll.then((p_res) => { res.rules.forEach((rule, index) => { rule.products = p_res[index] && p_res[index].products; const ruleEl = document.getElementById('smart_recommend_rule_' + rule.id); SPZ.whenApiDefined(ruleEl).then((api) => { api.render({data: rule}, true).then(() => { that.impressListen(`#smart_recommend_rule_ul_${rule.id}`, function(){ that.trackRuleImpress(rule); }); const btnElList = document.querySelectorAll(`#smart_recommend_rule_ul_${rule.id} button`); btnElList.forEach((btnEl) => { if (btnEl && rule.config && rule.config.quick_shop_button_bg_color && rule.config.quick_shop_button_text_color) { btnEl.style.backgroundColor = rule.config.quick_shop_button_bg_color; btnEl.style.color = rule.config.quick_shop_button_text_color; } }) }); }); }); }); }) }) } else { if (window.top !== window.self) { const template_type = window.SHOPLAZZA.meta.page.template_type; const holderEl = document.getElementById('smart_recommend_preview_no_data_placeholder'); SPZ.whenApiDefined(holderEl).then((api) => { api.render({data: { isCart: template_type === 13, isCollection: template_type === 2, isProduct: template_type === 1, isIndex: template_type === 15 }}, true); }); } } }); } setAction_() { this.registerAction('quickShop', (data) => { const that = this; const product_id = data.args.product_id; const productIndex = data.args.productIndex; const rule_id = data.args.rule_id; const ssp = data.args.ssp; const scm = data.args.scm; const cfb = data.args.cfb; const ifb = data.args.ifb; const modalRender = document.getElementById('smart_recommend_product_modal_render'); if (product_id) { this.fetchProductData(product_id).then((res) => { const product = res.products && res.products.length && res.products[0] || {}; product.cfb = cfb; product.ifb = ifb; SPZ.whenApiDefined(modalRender).then((api) => { api.render({product: product, productIndex: productIndex, rule_id: rule_id, ssp: ssp, scm: scm, show_type: that.show_type_}, true).then(() => { const modalEl = document.getElementById('smart_recommend_product_modal'); SPZ.whenApiDefined(modalEl).then((modal) => { that.impressListen('#smart_recommend_product_modal', function(){ that.trackQuickShop({ rule_id: rule_id, product_id: product_id }); }); modal.open(); }); const formEl = document.getElementById('smart_recommend_product_form'); SPZ.whenApiDefined(formEl).then((form) => { form.setProduct(product); }); const variantEl = document.getElementById('smart_recommend_product_variants'); SPZ.whenApiDefined(variantEl).then((variant) => { variant.handleRender(product); }); }); }) }); } }); this.registerAction('handleScroll', (data) => { this.directTo(data.args.rule_id, data.args.direction); }); this.registerAction('handleProductChange', (data) => { const variant = data.args.data.variant; const product = data.args.data.product; const imageRenderEl = document.getElementById('smart_recommend_product_image'); SPZ.whenApiDefined(imageRenderEl).then((api) => { api.render({ variant: variant, product: product }); }); }); this.registerAction('handleAtcSuccess', (detail) => { const data = detail.args; data.data.product = data.data.product || {}; data.data.variant = data.data.variant || {}; const product_id = data.data.product.id; const product_title = data.data.product.title; const variant_id = data.data.variant.id; const price = data.data.variant.price; const rule_id = data.rule_id; const aid = `smart_recommend.${this.show_type_}.${rule_id}`; const ifb = data.data.product.ifb; const cfb = data.data.product.cfb; const ssp = data.ssp; const scm = data.scm; const spm = `smart_recommend_${this.show_type_}.${data.spmIndex}`; const params = { id: product_id, product_id: product_id, number: 1, name: product_title, variant_id: variant_id, childrenId: variant_id, item_price: price, source: 'add_to_cart', _extra: { aid: aid, ifb: ifb, cfb: cfb, scm: scm, spm: `..${window.SHOPLAZZA.meta.page.template_name}.${spm}`, ssp: ssp, } }; this.tranckAddToCart(params); }); this.registerAction('addATCHook', (data) => { const params = data.args; const spm = `smart_recommend_${this.show_type_}.${params.spmIndex}`; this.myInterceptor_ = window.djInterceptors && window.djInterceptors.track.use({ event: 'dj.addToCart', params: { aid: `smart_recommend.${this.show_type_}.` + params.rule_id, ssp: params.ssp, scm: params.scm, cfb: params.cfb, spm: `..${window.SHOPLAZZA.meta.page.template_name}.${spm}`, }, once: true }); }); } tranckAddToCart(detail) { if (window.$) { window.$(document.body).trigger('dj.addToCart', detail); } } fetchRules() { const payload = { show_type: this.show_type_, }; let that = this; if (this.show_type_ === 6) { let line_items = []; return this.fetchCart().then((res) => { if (res && res.cart && res.cart.line_items) { line_items = res.cart.line_items.map((item) => { return { product_id: item.product_id, variant_id: item.variant_id, quantity: item.quantity, price: item.price } }); } payload.line_items = line_items; that.cart_items_ = line_items; return that.fetchRulesRequest(payload); }); } else { if (this.show_type_ === 3) { payload.line_items = [{ product_id: this.product_resource_id_ }]; } else if (this.show_type_ === 4) { payload.collection_id = this.collection_resource_id_; } else if (this.show_type_ === 7) { payload.customer_id = this.customer_id_; } else if (this.show_type_ === 8) { payload.order_id = this.order_id_; } return this.fetchRulesRequest(payload); } } fetchRulesRequest(payload) { return fetch(window.SHOPLAZZA.routes.root + "/api/possum/recommend_query", { method: "POST", headers: { "Content-Type": "application/json" }, body: JSON.stringify(payload) }).then(function(res){ if(res.ok){ return res.json(); } }); } fetchCart() { return fetch(`/api/cart/cart-select?r=${Math.random().toString(36).slice(-4)}`) .then((res) => { if (res.ok) { return res.json(); } }); } fetchRuleProductList(rule_id) { const payload = { page: 1, limit: 100, fields: ["title", "url", "image", "min_price_variant.price", "min_price_variant.compare_at_price"], rule_id: rule_id, }; if (this.show_type_ === 3) { payload.line_items = [{ product_id: this.product_resource_id_ }]; } else if (this.show_type_ === 4) { payload.collection_id = this.collection_resource_id_; } else if (this.show_type_ === 6) { payload.line_items = this.cart_items_; } else if (this.show_type_ === 7) { payload.customer_id = this.customer_id_; } else if (this.show_type_ === 8) { payload.order_id = this.order_id_; } return fetch(window.SHOPLAZZA.routes.root + "/api/possum/recommend_products", { method: "POST", headers: { "Content-Type": "application/json" }, body: JSON.stringify(payload) }).then(function(res){ if(res.ok){ return res.json(); } }).catch(function(err){ console.log(err); }); } fetchProductData(product_id) { return fetch(window.SHOPLAZZA.routes.root + "/api/possum/products", { method: "POST", headers: { "Content-Type": "application/json" }, body: JSON.stringify({ product_ids: [product_id], fields: [ "images", "options", "min_price_variant", "variants"] }) }).then(function(res){ if(res.ok){ return res.json(); } }).catch(function(err){ console.log(err); const loadingEl = document.getElementById('smart_recommend_loading'); if (loadingEl) { loadingEl.style.display = 'none'; } }); } getStyle(ele, style) { if (!ele) return; if (window.getComputedStyle) { return window.getComputedStyle(ele)[style]; } return ele.currentStyle[style]; } directTo(id, direction) { const scrollElement = document.getElementById(`smart_recommend_rule_ul_${id}`); const blockWidth = parseInt(this.getStyle(scrollElement, 'width')); const scrollLength = (blockWidth * 0.19 - 12) * 5; const scrollPoint = scrollElement.scrollWidth - scrollElement.clientWidth; if (!scrollElement) return; if (direction === 'left') { if (document.dir === 'rtl') { scrollElement.scrollTo({ left: Math.abs(scrollElement.scrollLeft) >= scrollPoint - 100 ? 0 : scrollElement.scrollLeft - scrollLength, behavior: 'smooth' }); return; } scrollElement.scrollTo({ left: Math.max(scrollElement.scrollLeft - scrollLength, 0), behavior: 'smooth' }); } else { if (document.dir === 'rtl') { scrollElement.scrollTo({ left: Math.abs(scrollElement.scrollLeft) >= scrollPoint + 100 ? 0 : scrollElement.scrollLeft + scrollLength, behavior: 'smooth' }); return; } scrollElement.scrollTo({ left: scrollElement.scrollLeft >= scrollPoint - 100 ? 0 : scrollElement.scrollLeft + scrollLength, behavior: 'smooth' }); } } trackRuleImpress(rule) { if (window.sa && window.sa.track) { window.sa.track("plugin_common", { plugin_name: "upsell", event_type: "impressions", rule_id: rule.id, ssp: rule.ssp, scm: rule.scm, show_type: this.show_type_, support_app_block: window.SHOPLAZZA.theme.support_app_block }); window.sa.track("module_impressions", { aid: `smart_recommend.${this.show_type_}.${rule.id}`, support_app_block: window.SHOPLAZZA.theme.support_app_block }); } } trackQuickShop(data) { window.sa && sa.track && sa.track("plugin_common", { plugin_name: "upsell", event_type: "quick_shop", rule_id: data.rule_id, product_id: data.product_id, show_type: this.show_type_, }); } impressListen(selector, cb) { const el = document.querySelector(selector); const onImpress = (e) => { if (e) { e.stopPropagation(); } cb(); }; if (el && !el.getAttribute('imprsd')) { el.addEventListener('impress', onImpress) } else if (el) { onImpress(); } } } SPZ.defineElement('spz-custom-smart-block', SpzSmartBlockComponent);