tabexseriescomponents 0.0.64 → 0.0.65

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (179) hide show
  1. package/dist/index.cjs.js +6838 -6468
  2. package/dist/index.esm.js +6841 -6471
  3. package/dist/index.umd.js +6841 -6472
  4. package/package.json +1 -1
  5. package/srcOLD/Contexts/LanguageContext.jsx +347 -0
  6. package/srcOLD/Contexts/ProductsCardsSectionContext.jsx +28 -0
  7. package/srcOLD/StylesJS/Customstyles.js +235 -0
  8. package/srcOLD/TabexComponents/Cards/CategoryCardwithhoveraction/CategoryCardwithhoveraction.jsx +214 -0
  9. package/srcOLD/TabexComponents/Cards/Categorycard_fullimage/Categorycard_fullimage.jsx +258 -0
  10. package/srcOLD/TabexComponents/Cards/Categorycard_slidebgscaled/Categorycard_slidebgscaled.jsx +206 -0
  11. package/srcOLD/TabexComponents/Cards/Categorycard_with_trianglebg/Categorycard_with_trianglebg.jsx +176 -0
  12. package/srcOLD/TabexComponents/Cards/Categorycard_with_twolinestransition/Categorycard_with_twolinestransition.jsx +207 -0
  13. package/srcOLD/TabexComponents/Cards/Categorycard_withshapes/Categorycard_withshapes.jsx +162 -0
  14. package/srcOLD/TabexComponents/Cards/Categorycard_withtext/Categorycard_withtext.jsx +193 -0
  15. package/srcOLD/TabexComponents/Cards/Classiccategorycard/Classiccategorycard.jsx +158 -0
  16. package/srcOLD/TabexComponents/Cards/Horizontalcard/Horizontalcard.jsx +286 -0
  17. package/srcOLD/TabexComponents/Cards/MenuCard/MenuCard.jsx +558 -0
  18. package/srcOLD/TabexComponents/Cards/ModernProductCard/ModernProductCard.jsx +486 -0
  19. package/srcOLD/TabexComponents/Cards/Productcard6/Productcard6.jsx +300 -0
  20. package/srcOLD/TabexComponents/Cards/Productcard7/Productcard7.jsx +288 -0
  21. package/srcOLD/TabexComponents/Cards/Productcard_animatedbuttons/Productcard_animatedbuttons.jsx +307 -0
  22. package/srcOLD/TabexComponents/Cards/Productcard_with_circularbg/Productcard_with_circularbg.jsx +295 -0
  23. package/srcOLD/TabexComponents/Cards/Productcard_with_circularhover/Productcard_with_circularhover.jsx +325 -0
  24. package/srcOLD/TabexComponents/Cards/Productcard_with_slideanimation/Productcard_with_slideanimation.jsx +290 -0
  25. package/srcOLD/TabexComponents/Cards/Productcard_with_variants/Productcard_with_variants.jsx +303 -0
  26. package/srcOLD/TabexComponents/Cards/Productcard_with_zoominonhover/Productcard_with_zoominonhover.jsx +466 -0
  27. package/srcOLD/TabexComponents/Cards/Productcarddefault/Productcarddefault.jsx +282 -0
  28. package/srcOLD/TabexComponents/Cards/Productccard_with_imageontopleft/Productccard_with_imageontopleft.jsx +298 -0
  29. package/srcOLD/TabexComponents/Cards/Prouductcard_with_zoomhover/Prouductcard_with_zoomhover.jsx +139 -0
  30. package/srcOLD/TabexComponents/Cards/Simplecategorycardwithtextbelow/Simplecategorycardwithtextbelow.jsx +135 -0
  31. package/srcOLD/TabexComponents/Cards/Simpleproductcard/Simpleproductcard.jsx +304 -0
  32. package/srcOLD/TabexComponents/Cards/StylishProductCard/StylishProductCard.jsx +291 -0
  33. package/srcOLD/TabexComponents/Footer/Footer1/Footer1.jsx +418 -0
  34. package/srcOLD/TabexComponents/Footer/Footer2/Footer2.jsx +382 -0
  35. package/srcOLD/TabexComponents/Footer/Footer3/Footer3.jsx +308 -0
  36. package/srcOLD/TabexComponents/Footer/Footer4/Footer4.jsx +438 -0
  37. package/srcOLD/TabexComponents/Footer/Footer5/Footer5.jsx +495 -0
  38. package/srcOLD/TabexComponents/Footer/Footer6/Footer6.jsx +295 -0
  39. package/srcOLD/TabexComponents/Footer/Footer7/Footer7.jsx +373 -0
  40. package/srcOLD/TabexComponents/Footer/Simplefooter/Simplefooter.jsx +238 -0
  41. package/srcOLD/TabexComponents/Generalfiles/images/egyptflag.png +0 -0
  42. package/srcOLD/TabexComponents/Generalfiles/images/noimage.png +0 -0
  43. package/srcOLD/TabexComponents/Generalfiles/images/payment/cod.png +0 -0
  44. package/srcOLD/TabexComponents/Generalfiles/images/payment/fawry.png +0 -0
  45. package/srcOLD/TabexComponents/Generalfiles/images/payment/payment.png +0 -0
  46. package/srcOLD/TabexComponents/Generalfiles/images/payment/paymob.png +0 -0
  47. package/srcOLD/TabexComponents/Generalfiles/images/payment/paypal.png +0 -0
  48. package/srcOLD/TabexComponents/Generalfiles/images/payment/visa.png +0 -0
  49. package/srcOLD/TabexComponents/Generalfiles/images/shoppingcart.png +0 -0
  50. package/srcOLD/TabexComponents/Generalfiles/images/tabexlogo.png +0 -0
  51. package/srcOLD/TabexComponents/Generalfiles/images/unknownmaleuser.png +0 -0
  52. package/srcOLD/TabexComponents/Generalfiles/images/usflag.png +0 -0
  53. package/srcOLD/TabexComponents/Generalfiles/images/whatsapp.png +0 -0
  54. package/srcOLD/TabexComponents/Headers/AllinoneHeader/AllinoneHeader.jsx +724 -0
  55. package/srcOLD/TabexComponents/Headers/ClassicHeader/ClassicHeader.jsx +687 -0
  56. package/srcOLD/TabexComponents/Headers/Header4/Header4.jsx +632 -0
  57. package/srcOLD/TabexComponents/Headers/Header6/Header6.jsx +669 -0
  58. package/srcOLD/TabexComponents/Headers/Header8/Header8.jsx +882 -0
  59. package/srcOLD/TabexComponents/Headers/HeaderRestaurant/HeaderRestaurant.jsx +754 -0
  60. package/srcOLD/TabexComponents/Headers/Header_threesectionslogocentered/Header_threesectionslogocentered.jsx +798 -0
  61. package/srcOLD/TabexComponents/Headers/Headerresponsive/Headerresponsive.jsx +686 -0
  62. package/srcOLD/TabexComponents/Headers/HeaderwithContactinfo/HeaderwithContactinfo.jsx +938 -0
  63. package/srcOLD/TabexComponents/Headers/Modernheader/Modernheader.jsx +706 -0
  64. package/srcOLD/TabexComponents/Headers/StylishHeader/StylishHeader.jsx +821 -0
  65. package/srcOLD/TabexComponents/Headers/Subheader/Subheader copy.jsx +228 -0
  66. package/srcOLD/TabexComponents/Headers/Subheader/Subheader.jsx +251 -0
  67. package/srcOLD/TabexComponents/Sections/BackgroundImages/Backgroundimage1/Backgroundimage1.jsx +312 -0
  68. package/srcOLD/TabexComponents/Sections/BackgroundImages/Backgroundimage_with_toppill/Backgroundimage_with_toppill.jsx +278 -0
  69. package/srcOLD/TabexComponents/Sections/BackgroundImages/BackgroundimageandTextsection/BackgroundimageandTextsection.jsx +138 -0
  70. package/srcOLD/TabexComponents/Sections/BackgroundImages/Section_with_rightbgcont/Section_with_rightbgcont.jsx +160 -0
  71. package/srcOLD/TabexComponents/Sections/BackgroundImages/Threebgimages/Threebgimages.jsx +295 -0
  72. package/srcOLD/TabexComponents/Sections/BackgroundImages/Twobgimages/Twobgimages.jsx +784 -0
  73. package/srcOLD/TabexComponents/Sections/Cards/CardsSection/CardsSection.jsx +861 -0
  74. package/srcOLD/TabexComponents/Sections/Cards/CardsSection2/CardsSection2.js +496 -0
  75. package/srcOLD/TabexComponents/Sections/Cards/CardsSection7/CardsSection7.js +888 -0
  76. package/srcOLD/TabexComponents/Sections/Cards/CardsSection8/CardsSection8.js +419 -0
  77. package/srcOLD/TabexComponents/Sections/Cards/Sixverticalcardssection/Sixverticalcardssection.js +552 -0
  78. package/srcOLD/TabexComponents/Sections/Slideshow/AboutSection/AboutSection.jsx +281 -0
  79. package/srcOLD/TabexComponents/Sections/Slideshow/Backgroundimage_with_topcircle/Backgroundimage_with_topcircle.jsx +166 -0
  80. package/srcOLD/TabexComponents/Sections/Slideshow/Freetextsection/Freetextsection.jsx +152 -0
  81. package/srcOLD/TabexComponents/Sections/Slideshow/Image_with_leftwords/Image_with_leftwords.jsx +284 -0
  82. package/srcOLD/TabexComponents/Sections/Slideshow/Image_with_rightwords/Image_with_rightwords.jsx +146 -0
  83. package/srcOLD/TabexComponents/Sections/Slideshow/Servicesection/Servicesection.jsx +209 -0
  84. package/srcOLD/TabexComponents/Sections/Slideshow/ServicesectionCenteredcards/ServicesectionCenteredcards.jsx +145 -0
  85. package/srcOLD/TabexComponents/Sections/Slideshow/Slideshow_with_rotatedsquare/Slideshow_with_rotatedsquare.jsx +252 -0
  86. package/srcOLD/TabexComponents/Sections/Slideshow/Slideshow_with_squarebg/Slideshow_with_squarebg.jsx +175 -0
  87. package/srcOLD/TabexComponents/Sections/Slideshow/Slideshowdifferentanimations/Slideshowdifferentanimations.jsx +154 -0
  88. package/srcOLD/TabexComponents/Sections/Slideshow/Slideshowfade/Slideshowfade.jsx +201 -0
  89. package/srcOLD/TabexComponents/Sections/Slideshow/Slideshowslide/Slideshowslide.jsx +414 -0
  90. package/srcOLD/TabexComponents/Sections/Slideshow/Slideshowzoom/Slideshowzoom.jsx +270 -0
  91. package/srcOLD/TabexComponents/StaticPages/Aboutus/Aboutus.js +175 -0
  92. package/srcOLD/TabexComponents/StaticPages/AccountInformation/AccountInformation.jsx +275 -0
  93. package/srcOLD/TabexComponents/StaticPages/CartSlider/CartSlider.jsx +459 -0
  94. package/srcOLD/TabexComponents/StaticPages/Categoriesdropdown/Categoriesdropdown.js +146 -0
  95. package/srcOLD/TabexComponents/StaticPages/Checkout/Checkout.jsx +1220 -0
  96. package/srcOLD/TabexComponents/StaticPages/Filter/Filter.jsx +542 -0
  97. package/srcOLD/TabexComponents/StaticPages/Login/FacebookLoginButton.jsx +51 -0
  98. package/srcOLD/TabexComponents/StaticPages/Login/GoogleLoginButton.jsx +35 -0
  99. package/srcOLD/TabexComponents/StaticPages/Login/Login.jsx +299 -0
  100. package/srcOLD/TabexComponents/StaticPages/OrderSuccess/OrderSuccess.js +192 -0
  101. package/srcOLD/TabexComponents/StaticPages/Ordershistory/Ordershistory.jsx +1285 -0
  102. package/srcOLD/TabexComponents/StaticPages/Policies/Policies.jsx +358 -0
  103. package/srcOLD/TabexComponents/StaticPages/Productinfo/Productinfo.jsx +1506 -0
  104. package/srcOLD/TabexComponents/StaticPages/Searchlist/Searchlist.jsx +225 -0
  105. package/srcOLD/TabexComponents/StaticPages/Signup/CustomerInformationForm.jsx +788 -0
  106. package/srcOLD/TabexComponents/StaticPages/Signup/Signup.jsx +157 -0
  107. package/srcOLD/TabexComponents/StaticPages/Staticpagesrouter/Staticpagesrouter.jsx +295 -0
  108. package/srcOLD/TabexComponents/StaticPages/Viewcart/Viewcart.js +1090 -0
  109. package/srcOLD/TabexComponents/StaticPages/Wishlist/Wishlist.jsx +629 -0
  110. package/srcOLD/assets/images/cod.png +0 -0
  111. package/srcOLD/assets/images/egyptflag.png +0 -0
  112. package/srcOLD/assets/images/fawry.png +0 -0
  113. package/srcOLD/assets/images/payment.png +0 -0
  114. package/srcOLD/assets/images/paymob.png +0 -0
  115. package/srcOLD/assets/images/paypal.png +0 -0
  116. package/srcOLD/assets/images/shoppingcart.png +0 -0
  117. package/srcOLD/assets/images/usflag.png +0 -0
  118. package/srcOLD/assets/images/visa.png +0 -0
  119. package/srcOLD/assets/images/whatsapp.png +0 -0
  120. package/srcOLD/button.jsx +40 -0
  121. package/srcOLD/index.jsx +175 -0
  122. package/srcOLD/styles/Home.module.css +129 -0
  123. package/srcOLD/styles/cards/Categorcycard_fullimage.module.css +10 -0
  124. package/srcOLD/styles/cards/Categorycard_slidebgscaled.module.css +73 -0
  125. package/srcOLD/styles/cards/Categorycard_withshapes.module.css +189 -0
  126. package/srcOLD/styles/cards/Productcard6.module.css +9 -0
  127. package/srcOLD/styles/cards/Productcard_with_circularbg.module.css +137 -0
  128. package/srcOLD/styles/cards/Productccard_with_zoominonhover.module.css +51 -0
  129. package/srcOLD/styles/cards/Prouductcard_with_zoomhover.module.css +61 -0
  130. package/srcOLD/styles/cards/categorycard.module.css +102 -0
  131. package/srcOLD/styles/cards/categorycard3.module.css +51 -0
  132. package/srcOLD/styles/cards/categorycardwithtext.module.css +40 -0
  133. package/srcOLD/styles/cards/productcard_animatedbuttons.module.css +104 -0
  134. package/srcOLD/styles/cards/productcard_with_textonhover.module.css +12 -0
  135. package/srcOLD/styles/cards/productccard_with_imageontopleft.module.css +85 -0
  136. package/srcOLD/styles/general/bootstrap.css +4420 -0
  137. package/srcOLD/styles/general/dropdown.css +199 -0
  138. package/srcOLD/styles/general/editorbardropdown.module.css +94 -0
  139. package/srcOLD/styles/general/filter.module.css +108 -0
  140. package/srcOLD/styles/general/form.module.css +273 -0
  141. package/srcOLD/styles/general/general.module.css +709 -0
  142. package/srcOLD/styles/general/image-gallery.css +481 -0
  143. package/srcOLD/styles/general/react-accessible-accordion.module.css +52 -0
  144. package/srcOLD/styles/general/react-phone-input-2.module.css +927 -0
  145. package/srcOLD/styles/general/scrollbtn.module.css +22 -0
  146. package/srcOLD/styles/general/slick.module.css +166 -0
  147. package/srcOLD/styles/general/tabs.module.css +110 -0
  148. package/srcOLD/styles/general/workplaceeditor.module.css +328 -0
  149. package/srcOLD/styles/globals.css +26 -0
  150. package/srcOLD/styles/headers/Allinoneheader.module.css +91 -0
  151. package/srcOLD/styles/headers/Header7.module.css +50 -0
  152. package/srcOLD/styles/headers/Header_threesectionslogocentered.module.css +97 -0
  153. package/srcOLD/styles/headers/Sideheader.module.css +108 -0
  154. package/srcOLD/styles/headers/classicheaderstyles.module.css +16 -0
  155. package/srcOLD/styles/headers/dropdown.css +0 -0
  156. package/srcOLD/styles/headers/header4.module.css +175 -0
  157. package/srcOLD/styles/headers/header5.module.css +30 -0
  158. package/srcOLD/styles/headers/header6.module.css +117 -0
  159. package/srcOLD/styles/headers/header_contactinfo.module.css +78 -0
  160. package/srcOLD/styles/headers/headerresturant.module.css +89 -0
  161. package/srcOLD/styles/headers/headerstyles.module.css +24 -0
  162. package/srcOLD/styles/headers/modernheader.module.css +78 -0
  163. package/srcOLD/styles/headers/subheader.module.css +114 -0
  164. package/srcOLD/styles/sections/Backgroundimage1.module.css +17 -0
  165. package/srcOLD/styles/sections/Backgroundimage_with_topcircle.module.css +28 -0
  166. package/srcOLD/styles/sections/Section_with_rightbgcont.module.css +49 -0
  167. package/srcOLD/styles/sections/Slideshow_with_rotatedsquare.module.css +35 -0
  168. package/srcOLD/styles/sections/Slideshow_with_squarebg.module.css +39 -0
  169. package/srcOLD/styles/staticpages/accordion.module.css +9 -0
  170. package/srcOLD/styles/staticpages/cart.module.css +108 -0
  171. package/srcOLD/styles/staticpages/dropdown.css +196 -0
  172. package/srcOLD/styles/staticpages/filter.module.css +139 -0
  173. package/srcOLD/styles/staticpages/login.module.css +146 -0
  174. package/srcOLD/styles/staticpages/productinfo.module.css +54 -0
  175. package/srcOLD/styles/staticpages/shop.module.css +191 -0
  176. package/srcOLD/styles/staticpages/signup.module.css +206 -0
  177. package/srcOLD/styles/staticpages/staticroutersidenav.module.css +129 -0
  178. package/srcOLD/styles/staticpages/viewcart.module.css +129 -0
  179. package/srcOLD/styles/staticpages/wishlist.module.css +29 -0
@@ -0,0 +1,466 @@
1
+ import React, { useEffect, useState, useContext } from 'react';
2
+ // import { LanguageContext } from '../../../../../../../Contexts/LanguageContext';
3
+ // import { FetchingContext } from '../../../../../../../Contexts/FetchingContext';
4
+ // import { WebsiteDesignWorkPlaceContext } from '../../../../../../../Contexts/WebsiteDesignWorkPlaceContext';
5
+ // import { TemplateRoutingContext } from '../../../../../../../Contexts/TemplateRoutingContext';
6
+ import cardsstyles from '../../../styles/cards/Productccard_with_zoominonhover.module.css';
7
+ import { css } from 'glamor';
8
+ import { AiFillStar, AiOutlineHeart } from 'react-icons/ai';
9
+ import { IKImage } from 'imagekitio-react';
10
+ import { FiShoppingCart } from 'react-icons/fi';
11
+ import { IKpublicKey, IKurlEndpoint } from '../../../../Env';
12
+ import { CircularProgress } from 'react-cssfx-loading';
13
+ const Productcard_with_zoominonhover = (props) => {
14
+ // const { lang, langdetect } = useContext(LanguageContext);
15
+ // const { fetch_inst_tabex_websitetemplatesQueryContext, sectionindexcontext, pageindexcontext, StatePagePropertiesContext } = useContext(WebsiteDesignWorkPlaceContext);
16
+ // const { addtofavoritescontext, setShowProductInfoModalContext, ProductIdProdutInfoModalContext, setProductIdProdutInfoModalContext, AddtoCartContext, AddtoCartMutationContext } =
17
+ // useContext(FetchingContext);
18
+ const [sectionproperties, setsectionproperties] = useState('');
19
+ const [item, setitem] = useState(props.cardinfoitemprops);
20
+ const StatePagePropertiesContext = props.actions.StatePagePropertiesContext;
21
+ const lang = props.actions.lang;
22
+ const langdetect = props.actions.langdetect;
23
+ const setShowProductInfoModalContext = props.actions.setShowProductInfoModalContext;
24
+ const addtofavoritescontext = props.actions.addtofavoritescontext;
25
+ const setProductIdProdutInfoModalContext = props.actions.setProductIdProdutInfoModalContext;
26
+ const AddtoCartContext = props.actions.AddtoCartContext;
27
+ const AddtoCartMutationContext = props.actions.AddtoCartMutationContext;
28
+
29
+ const NotificationManager = NotificationManager;
30
+
31
+ useEffect(() => {
32
+ if (props.srcfrom == 'addsectionform') {
33
+ var secpropobj = {};
34
+ props.defaultproperties.forEach(function (defaultpropobj, defaultpropindex) {
35
+ secpropobj[defaultpropobj.property_css_name] = defaultpropobj.property_value;
36
+ });
37
+ setsectionproperties({ ...secpropobj });
38
+ } else {
39
+ var secpropobj = {};
40
+ StatePagePropertiesContext.pageobj.sections.forEach(function (sectionitem, sectionindex) {
41
+ if (sectionitem.sectionid == props.sectionidprops) {
42
+ sectionitem.sectionproperties.forEach(function (sectionpropertiesobj, sectionpropertiesindex) {
43
+ secpropobj[sectionpropertiesobj.property_css_name] = sectionpropertiesobj.property_value;
44
+ });
45
+ }
46
+ });
47
+ setsectionproperties({ ...secpropobj });
48
+ }
49
+ }, [StatePagePropertiesContext]);
50
+ useEffect(() => {
51
+ if (props.cardinfoitemprops != undefined) {
52
+ setitem(props.cardinfoitemprops);
53
+ }
54
+ }, [props.cardinfoitemprops]);
55
+ const updatequantity = (type) => {
56
+ var tempitem = { ...item };
57
+ tempitem.quantity = parseInt(tempitem.quantity);
58
+ if (type == 'add') {
59
+ tempitem.quantity = tempitem.quantity + 1;
60
+ } else if (type == 'remove') {
61
+ tempitem.quantity = tempitem.quantity - 1;
62
+ }
63
+ if (tempitem.quantity <= 0) {
64
+ tempitem.quantity = 0;
65
+ }
66
+ setitem({ ...tempitem });
67
+ };
68
+ const addtocartfunc = () => {
69
+ const addtocardpayloadobj = {
70
+ functype: 'add',
71
+ productid: item.productid,
72
+ variantid: '',
73
+ quantity: item.quantity,
74
+ };
75
+
76
+ var runfunc = false;
77
+ if (addtocardpayloadobj.productid.length != 0 && addtocardpayloadobj.quantity > 0) {
78
+ if (item.hasvariants == 1) {
79
+ if (addtocardpayloadobj.variantid.length != 0) {
80
+ runfunc = true;
81
+ } else {
82
+ NotificationManager.warning('', 'Please Choose Product Options');
83
+ }
84
+ } else {
85
+ runfunc = true;
86
+ }
87
+ } else {
88
+ NotificationManager.warning('', 'Please Choose Quantity');
89
+ }
90
+
91
+ if (runfunc == true) {
92
+ AddtoCartContext(addtocardpayloadobj);
93
+ }
94
+ };
95
+ const cardsstyles2 = {
96
+ productcard: css({
97
+ background: sectionproperties.backgroundColortransparent == 'Transparent' ? 'transparent' : sectionproperties.backgroundColor,
98
+ opacity: sectionproperties.cardbg_opacity,
99
+ borderBottomLeftRadius: sectionproperties.borderBottomLeftRadius + 'px',
100
+ borderBottomRightRadius: sectionproperties.borderBottomRightRadius + 'px',
101
+ borderTopLeftRadius: sectionproperties.borderTopLeftRadius + 'px',
102
+ borderTopRightRadius: sectionproperties.borderTopRightRadius + 'px',
103
+ paddingTop: sectionproperties.paddingTop + 'px',
104
+ paddingBottom: sectionproperties.paddingBottom + 'px',
105
+ paddingLeft: sectionproperties.paddingLeft + 'px',
106
+ paddingRight: sectionproperties.paddingRight + 'px',
107
+ boxShadow: sectionproperties.sectioncardshadow == 'Show' ? '0 0 10px ' + sectionproperties.sectioncardshadowcolor : 'none',
108
+ border: sectionproperties.sectioncardborderwidth + 'px solid ' + sectionproperties.sectioncardbordercolor,
109
+ transition: '.3s',
110
+ ':hover': {
111
+ zIndex: 1000,
112
+ },
113
+ }),
114
+ productNameStyles: css({
115
+ color: sectionproperties.prodNameColor,
116
+ fontSize: sectionproperties.prodNameFontSize + 'px',
117
+ textTransform: sectionproperties.prodNameTextTranform,
118
+ fontWeight: sectionproperties.prodNameFontWeight,
119
+ transition: '.3s',
120
+ cursor: 'pointer',
121
+ ':hover': {
122
+ color: sectionproperties.prodNameColorOnHover,
123
+ },
124
+ }),
125
+ productDescStyles: css({
126
+ color: sectionproperties.prodCatColor,
127
+ fontSize: sectionproperties.prodCatFontSize + 'px',
128
+ textTransform: sectionproperties.prodCatTextTranform,
129
+ fontWeight: sectionproperties.prodCatFontWeight,
130
+ transition: '.3s',
131
+ }),
132
+ productPricestyles: css({
133
+ color: sectionproperties.prodPriceColor,
134
+ fontSize: sectionproperties.prodpriceFontSize + 'px',
135
+ fontWeight: sectionproperties.prodPriceFontWeight,
136
+ }),
137
+ productSalePricestyles: css({
138
+ color: sectionproperties.prodsalePriceColor,
139
+ fontSize: sectionproperties.prodsalepriceFontSize + 'px',
140
+ fontWeight: sectionproperties.prodsalePriceFontWeight,
141
+ }),
142
+ producttotalstyles: css({
143
+ color: sectionproperties.total_color,
144
+ fontSize: sectionproperties.total_fontsize + 'px',
145
+ fontWeight: 500,
146
+ }),
147
+ wishlist_btn: css({
148
+ width: sectionproperties.favBtnWidth + 'px',
149
+ height: sectionproperties.favBtnHeight + 'px',
150
+ background: sectionproperties.favbtn_bgtransparent == 'Transparent' ? 'transparent' : sectionproperties.favBtnbgColor,
151
+ borderRadius: sectionproperties.fav_btn_borderBottomLeftRadius + 'px',
152
+ color: sectionproperties.favBtniconcolor,
153
+ fontSize: sectionproperties.favBtnTextfontsize + 'px',
154
+ textTransform: sectionproperties.favBtnTexttransform,
155
+ fontWeight: sectionproperties.favBtnTextfontweight,
156
+ transition: '.3s',
157
+ border: sectionproperties.favbtnborderwidth + 'px solid ' + sectionproperties.favbtnbordercolor,
158
+ ':hover': {
159
+ background: sectionproperties.favbtn_transparentbgcoloronhover == 'Transparent' ? 'transparent' : sectionproperties.favBtnbgColoronhover,
160
+ color: sectionproperties.favBtnTextcoloronhover,
161
+ },
162
+ }),
163
+ cart_btn: css({
164
+ width: sectionproperties.cartBtnWidth + 'px',
165
+ height: sectionproperties.cartBtnHeight + 'px',
166
+ background: sectionproperties.cartbtn_bgtransparent == 'Transparent' ? 'transparent' : sectionproperties.cartBtnbgColor,
167
+ borderRadius: sectionproperties.cart_btn_borderBottomLeftRadius + 'px',
168
+ color: sectionproperties.cartBtnTextcolor,
169
+ fontSize: sectionproperties.cartBtnTextfontsize + 'px',
170
+ // fontSize: sectionproperties.cartBtn_iconFontSize + 'px',
171
+ textTransform: sectionproperties.cartBtnTexttransform,
172
+ fontWeight: sectionproperties.cartBtnTextfontweight,
173
+ border: sectionproperties.cartbtnborderwidth + 'px solid ' + sectionproperties.cartbtnbordercolor,
174
+ transition: '.3s',
175
+ ':hover': {
176
+ background: sectionproperties.cartbtn_transparentbgcoloronhover == 'Transparent' ? 'transparent' : sectionproperties.cartBtnbgColoronhover,
177
+ color: sectionproperties.cartBtnTextcoloronhover,
178
+ },
179
+ }),
180
+ img_container: css({
181
+ position: 'relative',
182
+ height: sectionproperties.prodimage_height + 'px',
183
+ border: sectionproperties.prodimage_borderwidth + 'px solid ' + sectionproperties.prodimage_color,
184
+ borderBottomLeftRadius: sectionproperties.prodimage__borderBottomLeftRadius + 'px',
185
+ borderBottomRightRadius: sectionproperties.prodimage__borderBottomRightRadius + 'px',
186
+ borderTopLeftRadius: sectionproperties.prodimage__borderTopLeftRadius + 'px',
187
+ borderTopRightRadius: sectionproperties.prodimage__borderTopRightRadius + 'px',
188
+ background: sectionproperties.prodimage_bgcolor,
189
+ }),
190
+ quantitybtn: css({
191
+ flex: 1,
192
+ border: sectionproperties.quantitybtnborderwidth + 'px solid ' + sectionproperties.quantitybtnbordercolor,
193
+ height: sectionproperties.quantitybtn_height + 'px',
194
+ height: '40px',
195
+ display: 'flex',
196
+ flexDirection: 'row',
197
+ overflow: 'hidden',
198
+ borderRadius: sectionproperties.quantitybtn_borderradius + 'px',
199
+ background: sectionproperties.quantitybtn_bgcolor,
200
+ alignItems: 'center',
201
+ justifyContent: 'center',
202
+ margin: 0,
203
+ position: 'relative',
204
+ fontWeight: sectionproperties.quantitybtn_textfontweight,
205
+ color: sectionproperties.quantitybtn_textcolor,
206
+ fontSize: sectionproperties.quantitybtn_textfontsize + 'px',
207
+ }),
208
+ quantitybtn_text: css({
209
+ margin: 'auto',
210
+ }),
211
+ add_quantitybtn_icon_container: css({
212
+ position: 'relative',
213
+ width: sectionproperties.add_quantitybtn_width + 'px',
214
+ height: sectionproperties.add_quantitybtn_height + 'px',
215
+ background: sectionproperties.add_quantitybtn_bgcolor,
216
+ display: 'flex',
217
+ alignItems: 'center',
218
+ justifyContent: 'center',
219
+ borderRadius: sectionproperties.add_quantitybtn_borderradius + 'px',
220
+ fontSize: sectionproperties.add_quantitybtn_textfontsize + 'px',
221
+ color: sectionproperties.add_quantitybtn_textcolor,
222
+ transition: '.3s',
223
+ ':hover': {
224
+ color: sectionproperties.add_quantitybtn_textcoloronhover,
225
+ background: sectionproperties.add_quantitybtn_bgcoloronhover,
226
+ },
227
+ }),
228
+ minus_quantitybtn_icon_container: css({
229
+ position: 'relative',
230
+ width: sectionproperties.remove_quantitybtn_width + 'px',
231
+ height: sectionproperties.remove_quantitybtn_height + 'px',
232
+ background: sectionproperties.remove_quantitybtn_bgcolor,
233
+ display: 'flex',
234
+ alignItems: 'center',
235
+ justifyContent: 'center',
236
+ borderRadius: sectionproperties.remove_quantitybtn_borderradius + 'px',
237
+ fontSize: sectionproperties.remove_quantitybtn_textfontsize + '25px',
238
+ color: sectionproperties.remove_quantitybtn_textcolor,
239
+ transition: '.3s',
240
+ ':hover': {
241
+ color: sectionproperties.remove_quantitybtn_textcoloronhover,
242
+ background: sectionproperties.remove_quantitybtn_bgcoloronhover,
243
+ },
244
+ }),
245
+ };
246
+ const addtocartbuttonrender = () => {
247
+ if (AddtoCartMutationContext.isLoading) {
248
+ if (AddtoCartMutationContext?.variables?.productid == item.productid) {
249
+ return (
250
+ <div className={' d-flex align-items-center justify-content-center '}>
251
+ <CircularProgress color="white" width="20px" height="20px" duration="1s" />
252
+ </div>
253
+ );
254
+ } else {
255
+ return lang.addtocart;
256
+ }
257
+ }
258
+ if (!AddtoCartMutationContext.isLoading) {
259
+ return lang.addtocart;
260
+ }
261
+ };
262
+ return (
263
+ <div
264
+ className="row ml-0 mr-0 w-100 mb-sm-5"
265
+ style={{
266
+ paddingLeft: sectionproperties.card_marginLeft + 'px',
267
+ paddingRight: sectionproperties.card_marginRight + 'px',
268
+ marginBottom: sectionproperties.marginBottom + 'px',
269
+ minHeight: '370px',
270
+ }}
271
+ >
272
+ {sectionproperties.length != 0 && (
273
+ <div className={`${cardsstyles.productcard} ${cardsstyles2.productcard}` + ' w-100 '}>
274
+ <div className={`${cardsstyles.card_inner}`}>
275
+ <div className={`${cardsstyles.card_thumbnail}`}>
276
+ <div
277
+ className={`${cardsstyles.img_container} ${cardsstyles2.img_container}` + ' w-100 '}
278
+ onClick={() => {
279
+ setShowProductInfoModalContext(true);
280
+ setProductIdProdutInfoModalContext(item.productid);
281
+ }}
282
+ style={{ cursor: 'pointer', overflow: 'hidden' }}
283
+ >
284
+ <IKImage
285
+ urlEndpoint={IKurlEndpoint}
286
+ publicKey={IKpublicKey}
287
+ path={'/tr:w-300,h-300/' + item.image}
288
+ style={{
289
+ width: '100%',
290
+ objectFit: 'contain',
291
+ position: 'relative',
292
+ borderBottomLeftRadius: sectionproperties.prodimage__borderBottomLeftRadius + 'px',
293
+ borderBottomRightRadius: sectionproperties.prodimage__borderBottomRightRadius + 'px',
294
+ borderTopLeftRadius: sectionproperties.prodimage__borderTopLeftRadius + 'px',
295
+ borderTopRightRadius: sectionproperties.prodimage__borderTopRightRadius + 'px',
296
+ marginBottom: 'auto',
297
+ }}
298
+ loading="lazy"
299
+ />
300
+ </div>
301
+ {sectionproperties.favBtnShow == 'Show' && (
302
+ <div
303
+ className={`${cardsstyles.wishlistbtn}`}
304
+ onClick={() => {
305
+ addtofavoritescontext(item.productid);
306
+ }}
307
+ >
308
+ <button
309
+ className={` ${cardsstyles2.wishlist_btn}` + ' m-0 p-0 d-flex align-items-center justify-content-center '}
310
+ style={{
311
+ position: 'absolute',
312
+ top: 10,
313
+ right: 10,
314
+ background: item.IsFavExists == true ? sectionproperties.activebgcolor : '',
315
+ }}
316
+ >
317
+ {item.IsFavExists && (
318
+ <i className="h-100 d-flex align-items-center justify-content-center">
319
+ <AiFillStar size={sectionproperties.favBtnIconfontsize} style={{ color: sectionproperties.activefaviconcolor }} />
320
+ </i>
321
+ )}
322
+ {!item.IsFavExists && (
323
+ <i className="h-100 d-flex align-items-center justify-content-center">
324
+ <AiFillStar size={sectionproperties.favBtnIconfontsize} />
325
+ </i>
326
+ )}
327
+ </button>
328
+ </div>
329
+ )}
330
+ </div>
331
+ <div className={`${cardsstyles.product_details}` + ' mb-2 '}>
332
+ {sectionproperties.prodNameShow == 'Show' && (
333
+ <div className="col-lg-12" style={{ minHeight: '5vh' }}>
334
+ <p className={`${cardsstyles2.productNameStyles}` + ' m-0 p-0 wordbreak wordbreak2 '} style={{ textAlign: langdetect == 'en' ? 'left' : 'right' }}>
335
+ {item.name}
336
+ </p>
337
+ </div>
338
+ )}
339
+ <div className="col-lg-12 d-flex align-items-center">
340
+ {sectionproperties.prodPriceShow == 'Show' && (
341
+ <p className={`${cardsstyles2.productPricestyles}` + ' m-0 p-0 wordbreak '} style={{ textAlign: langdetect == 'en' ? 'left' : 'right' }}>
342
+ {langdetect == 'en' ? 'EGP' : ''} {item.hassale == 1 ? item.defaultsaleprice : item.defaultprice} {langdetect == 'en' ? '' : 'ج.م'}
343
+ </p>
344
+ )}
345
+ {item.hassale == 1 && (
346
+ <p
347
+ className={`${cardsstyles2.productSalePricestyles}` + ' linethrough mt-auto mb-0 p-0 wordbreak mr-1 ml-1 '}
348
+ style={{ textAlign: langdetect == 'en' ? 'left' : 'right' }}
349
+ >
350
+ {langdetect == 'en' ? 'EGP' : ''} {item.defaultprice} {langdetect == 'en' ? '' : 'ج.م'}
351
+ </p>
352
+ )}
353
+ </div>
354
+ </div>
355
+ <div className={`${cardsstyles.card_informationcontainer}`}>
356
+ <div className="row m-0 w-100 d-flex align-items-center">
357
+ <button className={`${cardsstyles2.quantitybtn}` + ' p-0 d-flex align-items-center justify-content-center '}>
358
+ {langdetect == 'en' && (
359
+ <span
360
+ className={`${cardsstyles2.minus_quantitybtn_icon_container}` + ' m-1 '}
361
+ style={{ transform: ' rotate(-180deg)' }}
362
+ onClick={() => {
363
+ if (item.hasvariants == 0) {
364
+ updatequantity('remove');
365
+ } else {
366
+ setShowProductInfoModalContext(true);
367
+ setProductIdProdutInfoModalContext(item.productid);
368
+ }
369
+ }}
370
+ >
371
+ <i className="fa fa-chevron-up font-12"></i>
372
+ </span>
373
+ )}
374
+ {langdetect == 'ar' && (
375
+ <span
376
+ className={`${cardsstyles2.add_quantitybtn_icon_container}` + ' m-1 '}
377
+ onClick={() => {
378
+ updatequantity('add');
379
+ }}
380
+ >
381
+ <i className="fa fa-chevron-up font-12"></i>
382
+ </span>
383
+ )}
384
+ <span className={`${cardsstyles2.quantitybtn_text}` + ' d-flex align-items-center justify-content-center '}>{item.quantity}</span>
385
+ {langdetect == 'ar' && (
386
+ <span
387
+ className={`${cardsstyles2.minus_quantitybtn_icon_container}` + ' m-1 '}
388
+ style={{ transform: ' rotate(-180deg)' }}
389
+ onClick={() => {
390
+ updatequantity('remove');
391
+ }}
392
+ >
393
+ <i className="fa fa-chevron-up font-12"></i>
394
+ </span>
395
+ )}
396
+ {langdetect == 'en' && (
397
+ <span
398
+ className={`${cardsstyles2.add_quantitybtn_icon_container}` + ' m-1 '}
399
+ onClick={() => {
400
+ if (item.hasvariants == 0) {
401
+ updatequantity('add');
402
+ } else {
403
+ setShowProductInfoModalContext(true);
404
+ setProductIdProdutInfoModalContext(item.productid);
405
+ }
406
+ }}
407
+ >
408
+ <i className="fa fa-chevron-up font-12"></i>
409
+ </span>
410
+ )}
411
+ </button>
412
+ <div className="d-flex justify-content-start pl-2 pr-2" style={{ flex: 1 }}>
413
+ <p
414
+ className={`${cardsstyles2.producttotalstyles}` + ' mb-0 '}
415
+ style={{
416
+ textAlign: langdetect == 'en' ? 'left' : 'right',
417
+ }}
418
+ >
419
+ {lang.total}: <br />
420
+ <span
421
+ style={{
422
+ color: sectionproperties.total_secondaryColor,
423
+ fontWeight: sectionproperties.total_fontweight,
424
+ textAlign: langdetect == 'en' ? 'left' : 'right',
425
+ }}
426
+ >
427
+ {langdetect == 'en' ? 'EGP' : ''} {item.hassale == 1 ? item.quantity * item.defaultsaleprice : item.quantity * item.defaultprice}{' '}
428
+ {langdetect == 'en' ? '' : 'ج.م'}
429
+ </span>
430
+ </p>
431
+ </div>
432
+ </div>
433
+ <div className="col-lg-12 d-flex align-items-center justify-content-center p-0 mb-2 mt-2">
434
+ {sectionproperties.cartBtnShow == 'Show' && (
435
+ <p
436
+ className={`${cardsstyles2.cart_btn}` + ' font-md-13 m-0 p-0 d-flex align-items-center justify-content-center cursor-pointer '}
437
+ onClick={() => {
438
+ if (item.hasvariants == 0) {
439
+ addtocartfunc();
440
+ } else {
441
+ setShowProductInfoModalContext(true);
442
+ setProductIdProdutInfoModalContext(item.productid);
443
+ }
444
+ }}
445
+ disabled={AddtoCartMutationContext.isLoading}
446
+ >
447
+ <i
448
+ className={
449
+ langdetect == 'en' ? 'h-100 mr-2 d-flex align-items-center justify-content-center' : 'h-100 ml-2 d-flex align-items-center justify-content-center'
450
+ }
451
+ >
452
+ <FiShoppingCart size={sectionproperties.cartBtn_iconFontSize} />
453
+ </i>
454
+
455
+ {addtocartbuttonrender()}
456
+ </p>
457
+ )}
458
+ </div>
459
+ </div>
460
+ </div>
461
+ </div>
462
+ )}
463
+ </div>
464
+ );
465
+ };
466
+ export default Productcard_with_zoominonhover;