tabexseriescomponents 0.0.64 → 0.0.66

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 (178) hide show
  1. package/dist/index.cjs.js +25023 -16634
  2. package/dist/index.esm.js +25033 -16645
  3. package/dist/index.umd.js +24824 -16437
  4. package/package.json +1 -1
  5. package/src1-10/Contexts/LanguageContext.jsx +347 -0
  6. package/src1-10/Contexts/ProductsCardsSectionContext.jsx +28 -0
  7. package/src1-10/StylesJS/Customstyles.js +235 -0
  8. package/src1-10/TabexComponents/Cards/CategoryCardwithhoveraction/CategoryCardwithhoveraction.jsx +205 -0
  9. package/src1-10/TabexComponents/Cards/Categorycard_fullimage/Categorycard_fullimage.jsx +239 -0
  10. package/src1-10/TabexComponents/Cards/Categorycard_slidebgscaled/Categorycard_slidebgscaled.jsx +198 -0
  11. package/src1-10/TabexComponents/Cards/Categorycard_with_trianglebg/Categorycard_with_trianglebg.jsx +169 -0
  12. package/src1-10/TabexComponents/Cards/Categorycard_with_twolinestransition/Categorycard_with_twolinestransition.jsx +180 -0
  13. package/src1-10/TabexComponents/Cards/Categorycard_withshapes/Categorycard_withshapes.jsx +162 -0
  14. package/src1-10/TabexComponents/Cards/Categorycard_withtext/Categorycard_withtext.jsx +184 -0
  15. package/src1-10/TabexComponents/Cards/Classiccategorycard/Classiccategorycard.jsx +149 -0
  16. package/src1-10/TabexComponents/Cards/Horizontalcard/Horizontalcard.jsx +271 -0
  17. package/src1-10/TabexComponents/Cards/MenuCard/MenuCard.jsx +546 -0
  18. package/src1-10/TabexComponents/Cards/ModernProductCard/ModernProductCard.jsx +474 -0
  19. package/src1-10/TabexComponents/Cards/Productcard6/Productcard6.jsx +290 -0
  20. package/src1-10/TabexComponents/Cards/Productcard7/Productcard7.jsx +278 -0
  21. package/src1-10/TabexComponents/Cards/Productcard_animatedbuttons/Productcard_animatedbuttons.jsx +293 -0
  22. package/src1-10/TabexComponents/Cards/Productcard_with_circularbg/Productcard_with_circularbg.jsx +278 -0
  23. package/src1-10/TabexComponents/Cards/Productcard_with_circularhover/Productcard_with_circularhover.jsx +312 -0
  24. package/src1-10/TabexComponents/Cards/Productcard_with_slideanimation/Productcard_with_slideanimation.jsx +279 -0
  25. package/src1-10/TabexComponents/Cards/Productcard_with_variants/Productcard_with_variants.jsx +293 -0
  26. package/src1-10/TabexComponents/Cards/Productcard_with_zoominonhover/Productcard_with_zoominonhover.jsx +456 -0
  27. package/src1-10/TabexComponents/Cards/Productcarddefault/Productcarddefault.jsx +272 -0
  28. package/src1-10/TabexComponents/Cards/Productccard_with_imageontopleft/Productccard_with_imageontopleft.jsx +286 -0
  29. package/src1-10/TabexComponents/Cards/Prouductcard_with_zoomhover/Prouductcard_with_zoomhover.jsx +127 -0
  30. package/src1-10/TabexComponents/Cards/Simplecategorycardwithtextbelow/Simplecategorycardwithtextbelow.jsx +126 -0
  31. package/src1-10/TabexComponents/Cards/Simpleproductcard/Simpleproductcard.jsx +292 -0
  32. package/src1-10/TabexComponents/Cards/StylishProductCard/StylishProductCard.jsx +281 -0
  33. package/src1-10/TabexComponents/Footer/Footer1/Footer1.jsx +418 -0
  34. package/src1-10/TabexComponents/Footer/Footer2/Footer2.jsx +381 -0
  35. package/src1-10/TabexComponents/Footer/Footer3/Footer3.jsx +316 -0
  36. package/src1-10/TabexComponents/Footer/Footer4/Footer4.jsx +437 -0
  37. package/src1-10/TabexComponents/Footer/Footer5/Footer5.jsx +488 -0
  38. package/src1-10/TabexComponents/Footer/Footer6/Footer6.jsx +286 -0
  39. package/src1-10/TabexComponents/Footer/Footer7/Footer7.jsx +370 -0
  40. package/src1-10/TabexComponents/Footer/Simplefooter/Simplefooter.jsx +231 -0
  41. package/src1-10/TabexComponents/Generalfiles/images/egyptflag.png +0 -0
  42. package/src1-10/TabexComponents/Generalfiles/images/noimage.png +0 -0
  43. package/src1-10/TabexComponents/Generalfiles/images/payment/cod.png +0 -0
  44. package/src1-10/TabexComponents/Generalfiles/images/payment/fawry.png +0 -0
  45. package/src1-10/TabexComponents/Generalfiles/images/payment/payment.png +0 -0
  46. package/src1-10/TabexComponents/Generalfiles/images/payment/paymob.png +0 -0
  47. package/src1-10/TabexComponents/Generalfiles/images/payment/paypal.png +0 -0
  48. package/src1-10/TabexComponents/Generalfiles/images/payment/visa.png +0 -0
  49. package/src1-10/TabexComponents/Generalfiles/images/shoppingcart.png +0 -0
  50. package/src1-10/TabexComponents/Generalfiles/images/tabexlogo.png +0 -0
  51. package/src1-10/TabexComponents/Generalfiles/images/unknownmaleuser.png +0 -0
  52. package/src1-10/TabexComponents/Generalfiles/images/usflag.png +0 -0
  53. package/src1-10/TabexComponents/Generalfiles/images/whatsapp.png +0 -0
  54. package/src1-10/TabexComponents/Headers/AllinoneHeader/AllinoneHeader.jsx +722 -0
  55. package/src1-10/TabexComponents/Headers/ClassicHeader/ClassicHeader.jsx +681 -0
  56. package/src1-10/TabexComponents/Headers/Header4/Header4.jsx +614 -0
  57. package/src1-10/TabexComponents/Headers/Header6/Header6.jsx +666 -0
  58. package/src1-10/TabexComponents/Headers/Header8/Header8.jsx +888 -0
  59. package/src1-10/TabexComponents/Headers/HeaderRestaurant/HeaderRestaurant.jsx +710 -0
  60. package/src1-10/TabexComponents/Headers/Header_threesectionslogocentered/Header_threesectionslogocentered.jsx +769 -0
  61. package/src1-10/TabexComponents/Headers/Headerresponsive/Headerresponsive.jsx +666 -0
  62. package/src1-10/TabexComponents/Headers/HeaderwithContactinfo/HeaderwithContactinfo.jsx +940 -0
  63. package/src1-10/TabexComponents/Headers/Modernheader/Modernheader.jsx +714 -0
  64. package/src1-10/TabexComponents/Headers/StylishHeader/StylishHeader.jsx +833 -0
  65. package/src1-10/TabexComponents/Headers/Subheader/Subheader.jsx +239 -0
  66. package/src1-10/TabexComponents/Sections/BackgroundImages/Backgroundimage1/Backgroundimage1.jsx +312 -0
  67. package/src1-10/TabexComponents/Sections/BackgroundImages/Backgroundimage_with_toppill/Backgroundimage_with_toppill.jsx +278 -0
  68. package/src1-10/TabexComponents/Sections/BackgroundImages/BackgroundimageandTextsection/BackgroundimageandTextsection.jsx +129 -0
  69. package/src1-10/TabexComponents/Sections/BackgroundImages/Section_with_rightbgcont/Section_with_rightbgcont.jsx +153 -0
  70. package/src1-10/TabexComponents/Sections/BackgroundImages/Threebgimages/Threebgimages.jsx +295 -0
  71. package/src1-10/TabexComponents/Sections/BackgroundImages/Twobgimages/Twobgimages.jsx +409 -0
  72. package/src1-10/TabexComponents/Sections/Cards/CardsSection/CardsSection.jsx +793 -0
  73. package/src1-10/TabexComponents/Sections/Cards/CardsSection2/CardsSection2.jsx +486 -0
  74. package/src1-10/TabexComponents/Sections/Cards/CardsSection7/CardsSection7.js +888 -0
  75. package/src1-10/TabexComponents/Sections/Cards/CardsSection8/CardsSection8.js +419 -0
  76. package/src1-10/TabexComponents/Sections/Cards/Sixverticalcardssection/Sixverticalcardssection.jsx +512 -0
  77. package/src1-10/TabexComponents/Sections/Slideshow/AboutSection/AboutSection.jsx +281 -0
  78. package/src1-10/TabexComponents/Sections/Slideshow/Backgroundimage_with_topcircle/Backgroundimage_with_topcircle.jsx +166 -0
  79. package/src1-10/TabexComponents/Sections/Slideshow/Freetextsection/Freetextsection.jsx +152 -0
  80. package/src1-10/TabexComponents/Sections/Slideshow/Image_with_leftwords/Image_with_leftwords.jsx +139 -0
  81. package/src1-10/TabexComponents/Sections/Slideshow/Image_with_rightwords/Image_with_rightwords.jsx +146 -0
  82. package/src1-10/TabexComponents/Sections/Slideshow/Servicesection/Servicesection.jsx +209 -0
  83. package/src1-10/TabexComponents/Sections/Slideshow/ServicesectionCenteredcards/ServicesectionCenteredcards.jsx +145 -0
  84. package/src1-10/TabexComponents/Sections/Slideshow/Slideshow_with_rotatedsquare/Slideshow_with_rotatedsquare.jsx +252 -0
  85. package/src1-10/TabexComponents/Sections/Slideshow/Slideshow_with_squarebg/Slideshow_with_squarebg.jsx +175 -0
  86. package/src1-10/TabexComponents/Sections/Slideshow/Slideshowdifferentanimations/Slideshowdifferentanimations.jsx +154 -0
  87. package/src1-10/TabexComponents/Sections/Slideshow/Slideshowfade/Slideshowfade.jsx +193 -0
  88. package/src1-10/TabexComponents/Sections/Slideshow/Slideshowslide/Slideshowslide.jsx +197 -0
  89. package/src1-10/TabexComponents/Sections/Slideshow/Slideshowzoom/Arrow.js +91 -0
  90. package/src1-10/TabexComponents/Sections/Slideshow/Slideshowzoom/Slideshowzoom.jsx +309 -0
  91. package/src1-10/TabexComponents/StaticPages/AccountInformation/AccountInformation.jsx +260 -0
  92. package/src1-10/TabexComponents/StaticPages/CartSlider/CartSlider.jsx +459 -0
  93. package/src1-10/TabexComponents/StaticPages/Categoriesdropdown/Categoriesdropdown.jsx +216 -0
  94. package/src1-10/TabexComponents/StaticPages/Checkout/Checkout.jsx +1220 -0
  95. package/src1-10/TabexComponents/StaticPages/Filter/Filter.jsx +542 -0
  96. package/src1-10/TabexComponents/StaticPages/Login/FacebookLoginButton.jsx +51 -0
  97. package/src1-10/TabexComponents/StaticPages/Login/GoogleLoginButton.jsx +35 -0
  98. package/src1-10/TabexComponents/StaticPages/Login/Login.jsx +299 -0
  99. package/src1-10/TabexComponents/StaticPages/OrderSuccess/OrderSuccess.js +192 -0
  100. package/src1-10/TabexComponents/StaticPages/Ordershistory/Ordershistory.jsx +1271 -0
  101. package/src1-10/TabexComponents/StaticPages/Policies/Policies.jsx +353 -0
  102. package/src1-10/TabexComponents/StaticPages/Productinfo/Productinfo.jsx +1456 -0
  103. package/src1-10/TabexComponents/StaticPages/Searchlist/Searchlist.jsx +209 -0
  104. package/src1-10/TabexComponents/StaticPages/Signup/CustomerInformationForm.jsx +776 -0
  105. package/src1-10/TabexComponents/StaticPages/Signup/Signup.jsx +157 -0
  106. package/src1-10/TabexComponents/StaticPages/Staticpagesrouter/Staticpagesrouter.jsx +285 -0
  107. package/src1-10/TabexComponents/StaticPages/Viewcart/Viewcart.js +1090 -0
  108. package/src1-10/TabexComponents/StaticPages/Wishlist/Wishlist.jsx +606 -0
  109. package/src1-10/assets/images/cod.png +0 -0
  110. package/src1-10/assets/images/egyptflag.png +0 -0
  111. package/src1-10/assets/images/fawry.png +0 -0
  112. package/src1-10/assets/images/payment.png +0 -0
  113. package/src1-10/assets/images/paymob.png +0 -0
  114. package/src1-10/assets/images/paypal.png +0 -0
  115. package/src1-10/assets/images/shoppingcart.png +0 -0
  116. package/src1-10/assets/images/usflag.png +0 -0
  117. package/src1-10/assets/images/visa.png +0 -0
  118. package/src1-10/assets/images/whatsapp.png +0 -0
  119. package/src1-10/button.jsx +40 -0
  120. package/src1-10/index.jsx +179 -0
  121. package/src1-10/styles/Home.module.css +129 -0
  122. package/src1-10/styles/cards/Categorcycard_fullimage.module.css +10 -0
  123. package/src1-10/styles/cards/Categorycard_slidebgscaled.module.css +73 -0
  124. package/src1-10/styles/cards/Categorycard_withshapes.module.css +189 -0
  125. package/src1-10/styles/cards/Productcard6.module.css +9 -0
  126. package/src1-10/styles/cards/Productcard_with_circularbg.module.css +137 -0
  127. package/src1-10/styles/cards/Productccard_with_zoominonhover.module.css +51 -0
  128. package/src1-10/styles/cards/Prouductcard_with_zoomhover.module.css +61 -0
  129. package/src1-10/styles/cards/categorycard.module.css +102 -0
  130. package/src1-10/styles/cards/categorycard3.module.css +51 -0
  131. package/src1-10/styles/cards/categorycardwithtext.module.css +40 -0
  132. package/src1-10/styles/cards/productcard_animatedbuttons.module.css +104 -0
  133. package/src1-10/styles/cards/productcard_with_textonhover.module.css +12 -0
  134. package/src1-10/styles/cards/productccard_with_imageontopleft.module.css +85 -0
  135. package/src1-10/styles/general/bootstrap.css +4415 -0
  136. package/src1-10/styles/general/dropdown.css +199 -0
  137. package/src1-10/styles/general/editorbardropdown.module.css +94 -0
  138. package/src1-10/styles/general/filter.module.css +108 -0
  139. package/src1-10/styles/general/form.module.css +273 -0
  140. package/src1-10/styles/general/general.module.css +861 -0
  141. package/src1-10/styles/general/image-gallery.css +481 -0
  142. package/src1-10/styles/general/react-accessible-accordion.module.css +52 -0
  143. package/src1-10/styles/general/react-phone-input-2.module.css +927 -0
  144. package/src1-10/styles/general/scrollbtn.module.css +22 -0
  145. package/src1-10/styles/general/slick.module.css +166 -0
  146. package/src1-10/styles/general/tabs.module.css +110 -0
  147. package/src1-10/styles/general/workplaceeditor.module.css +328 -0
  148. package/src1-10/styles/globals.css +26 -0
  149. package/src1-10/styles/headers/Allinoneheader.module.css +91 -0
  150. package/src1-10/styles/headers/Header7.module.css +50 -0
  151. package/src1-10/styles/headers/Header_threesectionslogocentered.module.css +97 -0
  152. package/src1-10/styles/headers/Sideheader.module.css +108 -0
  153. package/src1-10/styles/headers/classicheaderstyles.module.css +16 -0
  154. package/src1-10/styles/headers/dropdown.css +0 -0
  155. package/src1-10/styles/headers/header4.module.css +175 -0
  156. package/src1-10/styles/headers/header5.module.css +30 -0
  157. package/src1-10/styles/headers/header6.module.css +117 -0
  158. package/src1-10/styles/headers/header_contactinfo.module.css +78 -0
  159. package/src1-10/styles/headers/headerresturant.module.css +89 -0
  160. package/src1-10/styles/headers/headerstyles.module.css +24 -0
  161. package/src1-10/styles/headers/modernheader.module.css +78 -0
  162. package/src1-10/styles/headers/subheader.module.css +114 -0
  163. package/src1-10/styles/sections/Backgroundimage1.module.css +17 -0
  164. package/src1-10/styles/sections/Backgroundimage_with_topcircle.module.css +28 -0
  165. package/src1-10/styles/sections/Section_with_rightbgcont.module.css +49 -0
  166. package/src1-10/styles/sections/Slideshow_with_rotatedsquare.module.css +35 -0
  167. package/src1-10/styles/sections/Slideshow_with_squarebg.module.css +39 -0
  168. package/src1-10/styles/staticpages/accordion.module.css +9 -0
  169. package/src1-10/styles/staticpages/cart.module.css +108 -0
  170. package/src1-10/styles/staticpages/dropdown.css +196 -0
  171. package/src1-10/styles/staticpages/filter.module.css +139 -0
  172. package/src1-10/styles/staticpages/login.module.css +146 -0
  173. package/src1-10/styles/staticpages/productinfo.module.css +54 -0
  174. package/src1-10/styles/staticpages/shop.module.css +191 -0
  175. package/src1-10/styles/staticpages/signup.module.css +206 -0
  176. package/src1-10/styles/staticpages/staticroutersidenav.module.css +129 -0
  177. package/src1-10/styles/staticpages/viewcart.module.css +129 -0
  178. package/src1-10/styles/staticpages/wishlist.module.css +29 -0
@@ -0,0 +1,474 @@
1
+ import React, { useEffect, useState, useContext } from 'react';
2
+ import { css } from 'glamor';
3
+ import { IKImage } from 'imagekitio-react';
4
+ import { IKpublicKey, IKurlEndpoint } from '../../../../Env';
5
+ import { FiShoppingCart, FiShoppingBag } from 'react-icons/fi';
6
+ import { IoBagHandleOutline } from 'react-icons/io5';
7
+ import { CgShoppingBag } from 'react-icons/cg';
8
+ import { BsBag } from 'react-icons/bs';
9
+ import { MdOutlineShoppingCart } from 'react-icons/md';
10
+ import { AiFillStar, AiOutlineStar } from 'react-icons/ai';
11
+ import { FaRegHeart, FaHeart } from 'react-icons/fa';
12
+ import { BsHandbag } from 'react-icons/bs';
13
+
14
+ const ModernProductCard = (props) => {
15
+ const [sectionproperties, setsectionproperties] = useState('');
16
+ const [item, setitem] = useState(props.cardinfoitemprops);
17
+ const StatePagePropertiesContext = props.actions.StatePagePropertiesContext;
18
+ const lang = props.actions.lang;
19
+ const langdetect = props.actions.langdetect;
20
+ const setShowProductInfoModalContext = props.actions.setShowProductInfoModalContext;
21
+ const addtofavoritescontext = props.actions.addtofavoritescontext;
22
+ const setProductIdProdutInfoModalContext = props.actions.setProductIdProdutInfoModalContext;
23
+ const AddtoCartContext = props.actions.AddtoCartContext;
24
+ const AddtoCartMutationContext = props.actions.AddtoCartMutationContext;
25
+ const StaticPagesLinksContext = props.actions.StaticPagesLinksContext;
26
+ const routingcountext = props.actions.routingcountext;
27
+ const NotificationManager = NotificationManager;
28
+ const updatequantity = (type) => {
29
+ var tempitem = { ...item };
30
+ tempitem.quantity = parseInt(tempitem.quantity);
31
+ if (type == 'add') {
32
+ tempitem.quantity = tempitem.quantity + 1;
33
+ } else if (type == 'remove') {
34
+ tempitem.quantity = tempitem.quantity - 1;
35
+ }
36
+ if (tempitem.quantity <= 0) {
37
+ tempitem.quantity = 0;
38
+ }
39
+ setitem({ ...tempitem });
40
+ };
41
+ useEffect(() => {
42
+ if (props.srcfrom == 'addsectionform') {
43
+ var secpropobj = {};
44
+ props.defaultproperties.forEach(function (defaultpropobj, defaultpropindex) {
45
+ secpropobj[defaultpropobj.property_css_name] = defaultpropobj.property_value;
46
+ });
47
+
48
+ setsectionproperties({ ...secpropobj });
49
+ } else {
50
+ var secpropobj = {};
51
+ StatePagePropertiesContext.pageobj.sections.forEach(function (sectionitem, sectionindex) {
52
+ if (sectionitem.sectionid == props.sectionidprops) {
53
+ sectionitem.sectionproperties.forEach(function (sectionpropertiesobj, sectionpropertiesindex) {
54
+ secpropobj[sectionpropertiesobj.property_css_name] = sectionpropertiesobj.property_value;
55
+ });
56
+ }
57
+ });
58
+ setsectionproperties({ ...secpropobj });
59
+ }
60
+ }, [StatePagePropertiesContext]);
61
+ const plainString = (html) => {
62
+ var divContainer = document.createElement('div');
63
+ divContainer.innerHTML = html;
64
+ return divContainer.textContent || divContainer.innerText || '';
65
+ };
66
+ const addtocartfunc = () => {
67
+ const addtocardpayloadobj = {
68
+ functype: 'add',
69
+ productid: item.productid,
70
+ variantid: '',
71
+ quantity: item.quantity,
72
+ };
73
+ var runfunc = false;
74
+ if (addtocardpayloadobj.productid.length != 0 && addtocardpayloadobj.quantity > 0) {
75
+ if (item.hasvariants == 1) {
76
+ if (addtocardpayloadobj.variantid.length != 0) {
77
+ runfunc = true;
78
+ } else {
79
+ NotificationManager.warning('', 'Please Choose Product Options');
80
+ }
81
+ } else {
82
+ runfunc = true;
83
+ }
84
+ } else {
85
+ NotificationManager.warning('', 'Please Choose Quantity');
86
+ }
87
+
88
+ if (runfunc == true) {
89
+ AddtoCartContext(addtocardpayloadobj);
90
+ }
91
+ };
92
+
93
+ const card_cssstyles = {
94
+ productcard: css({
95
+ background: sectionproperties.backgroundColortransparent == 'Transparent' ? 'transparent' : sectionproperties.backgroundColor,
96
+ borderBottomLeftRadius: sectionproperties.borderBottomLeftRadius + 'px',
97
+ borderBottomRightRadius: sectionproperties.borderBottomRightRadius + 'px',
98
+ borderTopLeftRadius: sectionproperties.borderTopLeftRadius + 'px',
99
+ borderTopRightRadius: sectionproperties.borderTopRightRadius + 'px',
100
+ marginTop: sectionproperties.marginTop + 'px',
101
+ marginBottom: sectionproperties.marginBottom + 'px',
102
+ paddingLeft: sectionproperties.paddingLeft + 'px',
103
+ paddingRight: sectionproperties.paddingRight + 'px',
104
+ paddingTop: sectionproperties.paddingTop + 'px',
105
+ paddingBottom: sectionproperties.paddingBottom + 'px',
106
+ border: sectionproperties.sectioncardborderwidth + 'px solid ' + sectionproperties.sectioncardbordercolor,
107
+ transition: '.3s',
108
+ color: sectionproperties.prodNameColor,
109
+ ':hover': {
110
+ color: sectionproperties.prodNameColorOnHover,
111
+ },
112
+ }),
113
+ productcardimagecont: css({
114
+ position: 'relative',
115
+ overflow: 'hidden',
116
+ height: sectionproperties.image_height + 'px',
117
+ background: sectionproperties.image_bgtransparent == 'Transparent' ? '' : sectionproperties.image_bgcolor,
118
+ border: sectionproperties.image_borderwidth + 'px solid ' + sectionproperties.image_bordercolor,
119
+ borderBottomLeftRadius: sectionproperties.image_borderBottomLeftRadius + 'px',
120
+ borderBottomRightRadius: sectionproperties.image_borderBottomRightRadius + 'px',
121
+ borderTopLeftRadius: sectionproperties.image_bordertopleftradius + 'px',
122
+ borderTopRightRadius: sectionproperties.image_bordertoprightradius + 'px',
123
+ transition: '.3s',
124
+ }),
125
+ productNameStyles: css({
126
+ fontSize: sectionproperties.prodNameFontSize + 'px',
127
+ textTransform: sectionproperties.prodNameTextTranform,
128
+ fontWeight: sectionproperties.prodNameFontWeight,
129
+ transition: '.3s',
130
+ cursor: 'pointer',
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
+ wishlist_btn: css({
143
+ width: sectionproperties.favBtnWidth + 'px',
144
+ height: sectionproperties.favBtnHeight + 'px',
145
+ background: sectionproperties.favbtn_bgtransparent == 'Transparent' ? 'transparent' : sectionproperties.favBtnbgColor,
146
+ borderRadius: sectionproperties.fav_btn_borderBottomLeftRadius + 'px',
147
+ color: sectionproperties.favBtniconcolor,
148
+ fontSize: sectionproperties.favBtnTextfontsize + 'px',
149
+ border: sectionproperties.favbtnborderwidth + 'px solid ' + sectionproperties.favbtnbordercolor,
150
+ transition: '.3s',
151
+ ':hover': {
152
+ background: sectionproperties.favbtn_transparentbgcoloronhover == 'Transparent' ? 'transparent' : sectionproperties.favBtnbgColoronhover,
153
+ color: sectionproperties.favBtnTextcoloronhover,
154
+ },
155
+ }),
156
+ cart_btn: css({
157
+ width: sectionproperties.cartBtnWidth + 'px',
158
+ height: sectionproperties.cartBtnHeight + 'px',
159
+ background: sectionproperties.cartbtn_bgtransparent == 'Transparent' ? 'transparent' : sectionproperties.cartBtnbgColor,
160
+ borderRadius: sectionproperties.cart_btn_borderBottomLeftRadius + 'px',
161
+ color: sectionproperties.cart_iconcolor,
162
+ border: sectionproperties.cartbtnborderwidth + 'px solid ' + sectionproperties.cartbtnbordercolor,
163
+ transition: '.3s',
164
+ ':hover': {
165
+ background: sectionproperties.cartbtn_transparentbgcoloronhover == 'Transparent' ? 'transparent' : sectionproperties.cartBtnbgColoronhover,
166
+ color: sectionproperties.cartBtnTextcoloronhover,
167
+ },
168
+ }),
169
+ quantitybtn: css({
170
+ flex: 1,
171
+ border: sectionproperties.quantitybtnborderwidth + 'px solid ' + sectionproperties.quantitybtnbordercolor,
172
+ height: sectionproperties.quantitybtn_height + 'px',
173
+ height: '40px',
174
+ display: 'flex',
175
+ flexDirection: 'row',
176
+ overflow: 'hidden',
177
+ borderRadius: sectionproperties.quantitybtn_borderradius + 'px',
178
+ background: sectionproperties.quantitybtn_bgcolor,
179
+ alignItems: 'center',
180
+ justifyContent: 'center',
181
+ margin: 0,
182
+ position: 'relative',
183
+ fontWeight: sectionproperties.quantitybtn_textfontweight,
184
+ color: sectionproperties.quantitybtn_textcolor,
185
+ fontSize: sectionproperties.quantitybtn_textfontsize + 'px',
186
+ }),
187
+ quantitybtn_text: css({
188
+ margin: 'auto',
189
+ }),
190
+ add_quantitybtn_icon_container: css({
191
+ position: 'relative',
192
+ width: sectionproperties.add_quantitybtn_width + 'px',
193
+ height: sectionproperties.add_quantitybtn_height + 'px',
194
+ background: sectionproperties.add_quantitybtn_bgcolor,
195
+ display: 'flex',
196
+ alignItems: 'center',
197
+ justifyContent: 'center',
198
+ borderRadius: sectionproperties.add_quantitybtn_borderradius + 'px',
199
+ fontSize: sectionproperties.add_quantitybtn_textfontsize + 'px',
200
+ color: sectionproperties.add_quantitybtn_textcolor,
201
+ transition: '.3s',
202
+ ':hover': {
203
+ color: sectionproperties.add_quantitybtn_textcoloronhover,
204
+ background: sectionproperties.add_quantitybtn_bgcoloronhover,
205
+ },
206
+ }),
207
+ minus_quantitybtn_icon_container: css({
208
+ position: 'relative',
209
+ width: sectionproperties.remove_quantitybtn_width + 'px',
210
+ height: sectionproperties.remove_quantitybtn_height + 'px',
211
+ background: sectionproperties.remove_quantitybtn_bgcolor,
212
+ display: 'flex',
213
+ alignItems: 'center',
214
+ justifyContent: 'center',
215
+ borderRadius: sectionproperties.remove_quantitybtn_borderradius + 'px',
216
+ fontSize: sectionproperties.remove_quantitybtn_textfontsize + 'px',
217
+ color: sectionproperties.remove_quantitybtn_textcolor,
218
+ transition: '.3s',
219
+ ':hover': {
220
+ color: sectionproperties.remove_quantitybtn_textcoloronhover,
221
+ background: sectionproperties.remove_quantitybtn_bgcoloronhover,
222
+ },
223
+ }),
224
+ producttotalstyles: css({
225
+ color: sectionproperties.total_color,
226
+ fontSize: sectionproperties.total_fontsize + 'px',
227
+ fontWeight: 500,
228
+ }),
229
+ productDescStyles: css({
230
+ color: sectionproperties.prodCatColor,
231
+ fontSize: sectionproperties.prodCatFontSize + 'px',
232
+ textTransform: sectionproperties.prodCatTextTranform,
233
+ fontWeight: sectionproperties.prodCatFontWeight,
234
+ transition: '.3s',
235
+ marginLeft: sectionproperties.description_marginLeft + 'px',
236
+ marginRight: sectionproperties.description_marginRight + 'px',
237
+ marginBottom: sectionproperties.descriptionMarginBottom + 'px',
238
+ }),
239
+ };
240
+
241
+ return (
242
+ <div
243
+ class="row m-0 w-100 p-sm-1"
244
+ style={{
245
+ paddingLeft: sectionproperties.card_marginLeft + 'px',
246
+ paddingRight: sectionproperties.card_marginRight + 'px',
247
+ }}
248
+ >
249
+ {sectionproperties.length != 0 && (
250
+ <div class={`${card_cssstyles.productcard}` + ' cursor-pointer col-lg-12 w-100 '}>
251
+ <div
252
+ onClick={() => {
253
+ if (props.fetchingtypeprops == 'collections') {
254
+ routingcountext(StaticPagesLinksContext.GeneralProductsComponent, true, item.collectionid);
255
+ } else {
256
+ routingcountext(StaticPagesLinksContext.productinfo, true, item.productid);
257
+ }
258
+ }}
259
+ class={`${card_cssstyles.productcardimagecont}` + ' col-lg-12 p-0 '}
260
+ style={{
261
+ height: sectionproperties.image_height + 'px',
262
+ borderBottomLeftRadius: sectionproperties.image_borderBottomLeftRadius + 'px',
263
+ borderBottomRightRadius: sectionproperties.image_borderBottomRightRadius + 'px',
264
+ borderTopLeftRadius: sectionproperties.image_bordertopleftradius + 'px',
265
+ borderTopRightRadius: sectionproperties.image_bordertoprightradius + 'px',
266
+ marginBottom: sectionproperties.image_mb + 'px',
267
+ overflow: 'hidden',
268
+ }}
269
+ >
270
+ <IKImage
271
+ urlEndpoint={IKurlEndpoint}
272
+ publicKey={IKpublicKey}
273
+ path={item.image}
274
+ loading="lazy"
275
+ style={{
276
+ width: '100%',
277
+ height: '100%',
278
+ objectFit: 'contain',
279
+ }}
280
+ />
281
+ {sectionproperties.favBtnShow == 'Show' && (
282
+ <button
283
+ class={` ${card_cssstyles.wishlist_btn}` + ' m-0 p-0 d-flex align-items-center justify-content-center '}
284
+ onClick={(e) => {
285
+ e.stopPropagation();
286
+ addtofavoritescontext(item.productid);
287
+ }}
288
+ style={{
289
+ position: 'absolute',
290
+ top: 10,
291
+ right: langdetect == 'en' ? 10 : 0,
292
+ left: langdetect == 'en' ? 0 : 10,
293
+ background: item.IsFavExists == true ? sectionproperties.activebgcolor : '',
294
+ }}
295
+ >
296
+ {item.IsFavExists && (
297
+ <i class="h-100 d-flex align-items-center justify-content-center">
298
+ {sectionproperties.faviconshape == 'Star Shape' && (
299
+ <AiFillStar size={sectionproperties.favBtnIconfontsize} style={{ color: sectionproperties.activefaviconcolor }} />
300
+ )}
301
+ {sectionproperties.faviconshape == 'Heart Shape' && (
302
+ <FaHeart size={sectionproperties.favBtnIconfontsize} style={{ color: sectionproperties.activefaviconcolor }} />
303
+ )}
304
+ </i>
305
+ )}
306
+ {!item.IsFavExists && (
307
+ <i class="h-100 d-flex align-items-center justify-content-center">
308
+ {sectionproperties.faviconshape == 'Star Shape' && <AiOutlineStar size={sectionproperties.favBtnIconfontsize} />}
309
+ {sectionproperties.faviconshape == 'Heart Shape' && <FaRegHeart size={sectionproperties.favBtnIconfontsize} />}
310
+ </i>
311
+ )}
312
+ </button>
313
+ )}
314
+ {sectionproperties.prodsalePriceshow == 'Show' && item?.hassale == 1 && (
315
+ <div
316
+ class="allcentered"
317
+ style={{
318
+ position: 'absolute',
319
+ top: 10,
320
+ right: langdetect == 'en' ? 10 : '',
321
+ left: langdetect == 'en' ? '' : 10,
322
+ width: sectionproperties.badge_width + 'px',
323
+ height: sectionproperties.badge_height + 'px',
324
+ background: sectionproperties.badge_bgcolor,
325
+ borderRadius: sectionproperties.badge_borderradius + 'px',
326
+ }}
327
+ >
328
+ <p class="m-0 p-0" style={{ color: sectionproperties.badge_color, fontSize: sectionproperties.badge_fontsize + 'px' }}>
329
+ {langdetect == 'en' ? sectionproperties.badgeContentEn : sectionproperties.badgeContentAr}
330
+ </p>
331
+ </div>
332
+ )}
333
+ </div>
334
+ <div>
335
+ <div class="row m-0 w-100">
336
+ {sectionproperties.prodNameShow == 'Show' && (
337
+ <div
338
+ onClick={() => {
339
+ if (props.fetchingtypeprops == 'collections') {
340
+ routingcountext(StaticPagesLinksContext.GeneralProductsComponent, true, item.collectionid);
341
+ } else {
342
+ routingcountext(StaticPagesLinksContext.productinfo, true, item.productid);
343
+ }
344
+ }}
345
+ class="col-lg-12 p-0 "
346
+ >
347
+ <p
348
+ class={`${card_cssstyles.productNameStyles}` + ' font-md-15 wordbreak wordbreak1 -noellipsis m-0 '}
349
+ style={{
350
+ textAlign: langdetect == 'en' ? 'left' : 'right',
351
+ }}
352
+ >
353
+ {item.name}
354
+ </p>
355
+ </div>
356
+ )}
357
+ {sectionproperties.prodCatShow == 'Show' && (
358
+ <p
359
+ class={`${card_cssstyles.productDescStyles}` + ' col-lg-12 wordbreak wordbreak2 p-0 '}
360
+ style={{
361
+ textAlign: langdetect == 'en' ? 'left' : 'right',
362
+ }}
363
+ >
364
+ {plainString(langdetect == 'en' ? item.description_en : item.description_ar)}
365
+ </p>
366
+ )}
367
+
368
+ <div class="col-lg-12 col-md-12 col-sm-12 d-flex align-items-center p-0">
369
+ <div class="row m-0 w-100 d-flex align-items-center">
370
+ {sectionproperties.prodPriceShow == 'Show' && (
371
+ <p class={`${card_cssstyles.productPricestyles}` + ' m-0 '}>
372
+ {langdetect == 'en' ? 'EGP' : ''} {item.hassale == 1 ? item.defaultsaleprice : item.defaultprice} {langdetect == 'en' ? '' : 'ج.م'}
373
+ </p>
374
+ )}
375
+ {sectionproperties.prodsalePriceshow == 'Show' && item.hassale == 1 && (
376
+ <p class={`${card_cssstyles.productSalePricestyles}` + ' linethrough m-0 mr-3 ml-3 '}>
377
+ {langdetect == 'en' ? 'EGP' : ''} {item.defaultprice} {langdetect == 'en' ? '' : 'ج.م'}
378
+ </p>
379
+ )}
380
+ </div>
381
+ </div>
382
+ <div class="row mt-1 m-0 w-100">
383
+ <div class="col-lg-6 col-md-8 col-sm-8 p-0">
384
+ <div style={{ width: sectionproperties.quantitybtn_width + 'px' }} class={' row m-0 d-flex align-items-center '}>
385
+ <button class={`${card_cssstyles.quantitybtn}` + ' p-0 d-flex align-items-center justify-content-center '}>
386
+ {langdetect == 'en' && (
387
+ <span
388
+ class={`${card_cssstyles.minus_quantitybtn_icon_container}` + ' m-1 '}
389
+ style={{ transform: ' rotate(-180deg)' }}
390
+ onClick={() => {
391
+ updatequantity('remove');
392
+ }}
393
+ >
394
+ <i class="fa fa-chevron-up "></i>
395
+ </span>
396
+ )}
397
+ {langdetect == 'ar' && (
398
+ <span
399
+ class={`${card_cssstyles.add_quantitybtn_icon_container}` + ' m-1 '}
400
+ onClick={() => {
401
+ updatequantity('add');
402
+ }}
403
+ >
404
+ <i class="fa fa-chevron-up"></i>
405
+ </span>
406
+ )}
407
+ <span
408
+ class={`${card_cssstyles.quantitybtn_text}` + ' d-flex align-items-center justify-content-center '}
409
+ style={{
410
+ background: sectionproperties.quantbtntextbgcolor,
411
+ width: sectionproperties.quantitybtntextwidth + 'px',
412
+ height: sectionproperties.quantitybtntextheight + 'px',
413
+ borderRadius: sectionproperties.addquantitytextborderraduis + 'px',
414
+ }}
415
+ >
416
+ {item.quantity}
417
+ </span>
418
+ {langdetect == 'ar' && (
419
+ <span
420
+ class={`${card_cssstyles.minus_quantitybtn_icon_container}` + ' m-1 '}
421
+ style={{ transform: ' rotate(-180deg)' }}
422
+ onClick={() => {
423
+ updatequantity('remove');
424
+ }}
425
+ >
426
+ <i class="fa fa-chevron-up "></i>
427
+ </span>
428
+ )}
429
+ {langdetect == 'en' && (
430
+ <span
431
+ class={`${card_cssstyles.add_quantitybtn_icon_container}` + ' m-1 '}
432
+ onClick={() => {
433
+ updatequantity('add');
434
+ }}
435
+ >
436
+ <i class="fa fa-chevron-up"></i>
437
+ </span>
438
+ )}
439
+ </button>
440
+ </div>
441
+ </div>
442
+ {sectionproperties.cartBtnShow == 'Show' && (
443
+ <div class="col-lg-6 col-md-4 col-sm-4 d-flex align-items-center justify-content-end p-0">
444
+ <button
445
+ class={`${card_cssstyles.cart_btn}` + ' font-md-13 m-0 p-0 d-flex align-items-center justify-content-center '}
446
+ onClick={() => {
447
+ if (item.hasvariants == 0) {
448
+ addtocartfunc();
449
+ } else {
450
+ setShowProductInfoModalContext(true);
451
+ setProductIdProdutInfoModalContext(item.productid);
452
+ }
453
+ }}
454
+ >
455
+ <i class={'h-100 d-flex align-items-center justify-content-center'}>
456
+ {sectionproperties.carticonstyle == 'Shopping bag 1' && <FiShoppingBag class="" size={sectionproperties.cartBtn_iconFontSize} />}
457
+ {sectionproperties.carticonstyle == 'Shopping bag 2' && <CgShoppingBag class="" size={sectionproperties.cartBtn_iconFontSize} />}
458
+ {sectionproperties.carticonstyle == 'Shopping bag 3' && <BsBag class="" size={sectionproperties.cartBtn_iconFontSize} />}
459
+ {sectionproperties.carticonstyle == 'Shopping bag 4' && <BsHandbag size={sectionproperties.cartBtn_iconFontSize} />}
460
+ {sectionproperties.carticonstyle == 'Shopping cart 1' && <FiShoppingCart class="" size={sectionproperties.cartBtn_iconFontSize} />}
461
+ {sectionproperties.carticonstyle == 'Shopping cart 2' && <MdOutlineShoppingCart size={sectionproperties.cartBtn_iconFontSize} />}
462
+ </i>
463
+ </button>
464
+ </div>
465
+ )}
466
+ </div>
467
+ </div>
468
+ </div>
469
+ </div>
470
+ )}
471
+ </div>
472
+ );
473
+ };
474
+ export default ModernProductCard;