JFIFXX    $.' ",#(7),01444'9=82<.342  2!!22222222222222222222222222222222222222222222222222"4 ,PG"Z_4˷kjزZ,F+_z,© zh6٨icfu#ډb_N?wQ5-~I8TK<5oIv-k_U_~bMdӜUHh?]EwQk{_}qFW7HTՑYF?_'ϔ_Ջt=||I 6έ"D/[k9Y8ds|\Ҿp6Ҵ].6znopM[mei$[soᘨ˸ nɜG-ĨUycP3.DBli;hjx7Z^NhN3u{:jx힞#M&jL P@_ P&o89@Sz6t7#Oߋ s}YfTlmrZ)'Nk۞pw\Tȯ?8`Oi{wﭹW[r Q4F׊3m&L=h3z~#\l :F,j@ ʱwQT8"kJO6֚l}R>ډK]y&p}b;N1mr$|7>e@BTM*-iHgD) Em|ؘbҗaҾt4oG*oCNrPQ@z,|?W[0:n,jWiEW$~/hp\?{(0+Y8rΟ+>S-SVN;}s?. w9˟<Mq4Wv'{)01mBVW[8/< %wT^5b)iM pgN&ݝVO~qu9 !J27$O-! :%H ـyΠM=t{!S oK8txA& j0 vF Y|y ~6@c1vOpIg4lODL Rcj_uX63?nkWyf;^*B @~a`Eu+6L.ü>}y}_O6͐:YrGXkGl^w~㒶syIu! W XN7BVO!X2wvGRfT#t/?%8^WaTGcLMI(J1~8?aT ]ASE(*E} 2#I/׍qz^t̔bYz4xt){ OH+(EA&NXTo"XC')}Jzp ~5}^+6wcQ|LpdH}(.|kc4^"Z?ȕ a<L!039C EuCFEwç ;n?*oB8bʝ'#RqfM}7]s2tcS{\icTx;\7KPʇ Z O-~c>"?PEO8@8GQgaՎ󁶠䧘_%#r>1zaebqcPѵn#L =׀t L7`VA{C:ge@w1 Xp3c3ġpM"'-@n4fGB3DJ8[JoߐgK)ƛ$ 83+ 6ʻ SkI*KZlT _`?KQKdB`s}>`*>,*@JdoF*弝O}ks]yߘc1GV<=776qPTtXԀ!9*44Tހ3XΛex46YD  BdemDa\_l,G/֌7Y](xTt^%GE4}bTڹ;Y)BQu>J/J ⮶.XԄjݳ+Ed r5_D1 o Bx΢#<W8R6@gM. drD>(otU@x=~v2 ӣdoBd3eO6㣷ݜ66YQz`S{\P~z m5{J/L1xO\ZFu>ck#&:`$ai>2ΔloF[hlEܺΠk:)` $[69kOw\|8}ބ:񶐕IA1/=2[,!.}gN#ub ~݊}34qdELc$"[qU硬g^%B zrpJru%v\h1Yne`ǥ:gpQM~^Xi `S:V29.PV?Bk AEvw%_9CQwKekPؠ\;Io d{ ߞoc1eP\ `E=@KIRYK2NPlLɀ)&eB+ь( JTx_?EZ }@ 6U뙢طzdWIn` D噥[uV"G&Ú2g}&m?ċ"Om# {ON"SXNeysQ@FnVgdX~nj]J58up~.`r\O,ư0oS _Ml4kv\JSdxSW<AeIX$Iw:Sy›R9Q[,5;@]%u@ *rolbI  +%m:͇ZVủθau,RW33 dJeTYE.Mϧ-oj3+yy^cVO9NV\nd1 !͕_)av;թMlWR1)ElP;yوÏu 3k5Pr6<⒲l!˞*u־n!l:UNW %Chx8vL'X@*)̮ˍ D-M+JUkvK+x8cY?Ԡ~3mo|u@[XeYC\Kpx8oCC&N~3-H MXsu<`~"WL$8ξ3a)|:@m\^`@ҷ)5p+6p%i)P Mngc#0AruzRL+xSS?ʮ}()#tmˇ!0}}y$6Lt;$ʳ{^6{v6ķܰgVcnn ~zx«,2u?cE+ȘH؎%Za)X>uWTzNyosFQƤ$*&LLXL)1" LeOɟ9=:tZcŽY?ӭVwv~,Yrۗ|yGaFC.+ v1fήJ]STBn5sW}y$~z'c 8  ,! pVNSNNqy8z˱A4*'2n<s^ǧ˭PJޮɏUGLJ*#i}K%,)[z21z ?Nin1?TIR#m-1lA`fT5+ܐcq՝ʐ,3f2Uեmab#ŠdQy>\)SLYw#.ʑf ,"+w~N'cO3FN<)j&,- љ֊_zSTǦw>?nU仆Ve0$CdrP m׈eXmVu L.bֹ [Դaզ*\y8Է:Ez\0KqC b̘cөQ=0YsNS.3.Oo:#v7[#߫ 5܎LEr49nCOWlG^0k%;YߝZǓ:S#|}y,/kLd TA(AI$+I3;Y*Z}|ӧOdv..#:nf>>ȶITX 8y"dR|)0=n46ⲑ+ra ~]R̲c?6(q;5% |uj~z8R=XIV=|{vGj\gcqz؋%Mߍ1y#@f^^>N#x#۹6Y~?dfPO{P4Vu1E1J *|%JN`eWuzk M6q t[ gGvWIGu_ft5j"Y:Tɐ*; e54q$C2d} _SL#mYpO.C;cHi#֩%+) ӍƲVSYźg |tj38r|V1#;.SQA[S#`n+$$I P\[@s(EDzP])8G#0B[ىXIIq<9~[Z멜Z⊔IWU&A>P~#dp]9 "cP Md?٥Ifتuk/F9c*9Ǎ:ØFzn*@|Iށ9N3{'['ͬҲ4#}!V Fu,,mTIkv C7vB6kT91*l '~ƞFlU'M ][ΩũJ_{iIn$L jOdxkza۪#EClx˘oVɞljr)/,߬hL#^Lф,íMƁe̩NBLiLq}(q6IçJ$WE$:=#(KBzђ xlx?>Պ+>W,Ly!_DŌlQ![ SJ1ƐY}b,+Loxɓ)=yoh@꥟/Iѭ=Py9 ۍYӘe+pJnϱ?V\SO%(t =?MR[Șd/ nlB7j !;ӥ/[-A>dNsLj ,ɪv=1c.SQO3UƀܽE̻9GϷD7(}Ävӌ\y_0[w <΍>a_[0+LF.޺f>oNTq;y\bՃyjH<|q-eɏ_?_9+PHp$[uxK wMwNی'$Y2=qKBP~Yul:[<F12O5=d]Ysw:ϮEj,_QXz`H1,#II dwrP˂@ZJVy$\y{}^~[:NߌUOdؾe${p>G3cĖlʌ ת[`ϱ-WdgIig2 }s ؤ(%#sS@~3XnRG~\jc3vӍLM[JBTs3}jNʖW;7ç?=XF=-=qߚ#='c7ڑWI(O+=:uxqe2zi+kuGR0&eniT^J~\jyp'dtGsO39* b#Ɋ p[BwsT>d4ۧsnvnU_~,vƜJ1s QIz)(lv8MU=;56Gs#KMP=LvyGd}VwWBF'à ?MHUg2 !p7Qjڴ=ju JnA suMeƆҔ!)'8Ϣٔޝ(Vpצ֖d=ICJǠ{qkԭ߸i@Ku|p=..*+xz[Aqġ#s2aƊRR)*HRsi~a &fMP-KL@ZXy'x{}Zm+:)) IJ-iu ܒH'L(7yGӜq j 6ߌg1go,kرtY?W,pefOQS!K۟cҒA|սj>=⬒˧L[ ߿2JaB~Ru:Q] 0H~]7ƼI(}cq 'ήETq?fabӥvr )o-Q_'ᴎoK;Vo%~OK *bf:-ťIR`B5!RB@ï u ̯e\_U_ gES3QTaxU<~c?*#]MW,[8Oax]1bC|踤Plw5V%){t<d50iXSUm:Z┵i"1^B-PhJ&)O*DcWvM)}Pܗ-q\mmζZ-l@}aE6F@&Sg@ݚM ȹ 4#p\HdYDoH"\..RBHz_/5˘6KhJRPmƶim3,#ccoqa)*PtRmk7xDE\Y閣_X<~)c[[BP6YqS0%_;Àv~| VS؇ 'O0F0\U-d@7SJ*z3nyPOm~P3|Yʉr#CSN@ ƮRN)r"C:: #qbY. 6[2K2uǦHYRQMV G$Q+.>nNHq^ qmMVD+-#*U̒ p욳u:IBmPV@Or[b= 1UE_NmyKbNOU}the`|6֮P>\2PVIDiPO;9rmAHGWS]J*_G+kP2KaZH'KxWMZ%OYDRc+o?qGhmdSoh\D|:WUAQc yTq~^H/#pCZTI1ӏT4"ČZ}`w#*,ʹ 0i課Om*da^gJ݅{le9uF#Tֲ̲ٞC"qߍ ոޑo#XZTp@ o8(jdxw],f`~|,s^f1t|m򸄭/ctr5s79Q4H1꠲BB@l9@C+wpxu£Yc9?`@#omHs2)=2.ljg9$YS%*LRY7Z,*=䷘$armoϰUW.|rufIGwtZwo~5 YյhO+=8fF)W7L9lM̘·Y֘YLf큹pRF99.A "wz=E\Z'a 2Ǚ#;'}G*l^"q+2FQ hjkŦ${ޮ-T٭cf|3#~RJt$b(R(rdx >U b&9,>%E\ Άe$'q't*אެb-|dSBOO$R+H)܎K1m`;J2Y~9Og8=vqD`K[F)k[1m޼cn]skz$@)!I x՝"v9=ZA=`Ɠi :E)`7vI}dYI_ o:obo 3Q&D&2= Ά;>hy.*ⅥSӬ+q&j|UƧ}J0WW< ۋS)jQRjƯrN)Gű4Ѷ(S)Ǣ8iW52No˓ ۍ%5brOnL;n\G=^UdI8$&h'+(cȁ߫klS^cƗjԌEꭔgFȒ@}O*;evWVYJ\]X'5ղkFb 6Ro՜mi Ni>J?lPmU}>_Z&KKqrIDՉ~q3fL:Se>E-G{L6pe,8QIhaXaUA'ʂs+טIjP-y8ۈZ?J$WP Rs]|l(ԓsƊio(S0Y 8T97.WiLc~dxcE|2!XKƘਫ਼$((6~|d9u+qd^389Y6L.I?iIq9)O/뚅OXXVZF[یgQLK1RҖr@v#XlFНyS87kF!AsM^rkpjPDyS$Nqnxҍ!Uf!ehi2m`YI9r6 TFC}/y^Η5d'9A-J>{_l+`A['յϛ#w:݅%X}&PStQ"-\縵/$ƗhXb*yBS;Wջ_mcvt?2}1;qSdd~u:2k52R~z+|HE!)Ǟl7`0<,2*Hl-x^'_TVgZA'j ^2ΪN7t?w x1fIzC-ȖK^q;-WDvT78Z hK(P:Q- 8nZ܃e貾<1YT<,"6{/ ?͟|1:#gW>$dJdB=jf[%rE^il:BxSּ1հ,=*7 fcG#q eh?27,!7x6nLC4x},GeǝtC.vS F43zz\;QYC,6~;RYS/6|25vTimlv& nRh^ejRLGf? ۉҬܦƩ|Ȱ>3!viʯ>vオX3e_1zKȗ\qHS,EW[㺨uch⍸O}a>q6n6N6qN ! 1AQaq0@"2BRb#Pr3C`Scst$4D%Td ?Na3mCwxAmqmm$4n淿t'C"wzU=D\R+wp+YT&պ@ƃ3ޯ?AﶂaŘ@-Q=9Dռѻ@MVP܅G5fY6# ?0UQ,IX(6ڵ[DIMNލc&υj\XR|,4 jThAe^db#$]wOӪ1y%LYm뭛CUƃߜ}Cy1XνmF8jI]HۺиE@Ii;r8ӭVFՇ| &?3|xBMuSGe=Ӕ#BE5GY!z_eqр/W>|-Ci߇t1ޯќdR3ug=0 5[?#͏qcfH{ ?u=??ǯ}ZzhmΔBFTWPxs}G93 )gGR<>r h$'nchPBjJҧH -N1N?~}-q!=_2hcMlvY%UE@|vM2.Y[|y"EïKZF,ɯ?,q?vM 80jx";9vk+ ֧ ȺU?%vcVmA6Qg^MA}3nl QRNl8kkn'(M7m9وq%ޟ*h$Zk"$9: ?U8Sl,,|ɒxH(ѷGn/Q4PG%Ա8N! &7;eKM749R/%lc>x;>C:th?aKXbheᜋ^$Iհ hr7%F$EFdt5+(M6tÜUU|zW=aTsTgdqPQb'm1{|YXNb P~F^F:k6"j! Ir`1&-$Bevk:y#ywI0x=D4tUPZHڠ底taP6b>xaQ# WeFŮNjpJ* mQN*I-*ȩFg3 5Vʊɮa5FO@{NX?H]31Ri_uѕ 0 F~:60p͈SqX#a5>`o&+<2D: ڝ$nP*)N|yEjF5ټeihyZ >kbHavh-#!Po=@k̆IEN@}Ll?jO߭ʞQ|A07xwt!xfI2?Z<ץTcUj]陎Ltl }5ϓ$,Omˊ;@OjEj(ا,LXLOЦ90O .anA7j4 W_ٓzWjcBy՗+EM)dNg6y1_xp$Lv:9"zpʙ$^JԼ*ϭo=xLj6Ju82AH3$ٕ@=Vv]'qEz;I˼)=ɯx /W(Vp$ mu񶤑OqˎTr㠚xsrGCbypG1ߠw e8$⿄/M{*}W]˷.CK\ުx/$WPwr |i&}{X >$-l?-zglΆ(FhvS*b߲ڡn,|)mrH[a3ר[13o_U3TC$(=)0kgP u^=4 WYCҸ:vQרXàtkm,t*^,}D* "(I9R>``[~Q]#afi6l86:,ssN6j"A4IuQ6E,GnHzSHOuk5$I4ؤQ9@CwpBGv[]uOv0I4\yQѸ~>Z8Taqޣ;za/SI:ܫ_|>=Z8:SUIJ"IY8%b8H:QO6;7ISJҌAά3>cE+&jf$eC+z;V rʺmyeaQf&6ND.:NTvm<- uǝ\MvZYNNT-A>jr!SnO 13Ns%3D@`ܟ 1^c< aɽ̲Xë#w|ycW=9I*H8p^(4՗karOcWtO\ƍR8'KIQ?5>[}yUײ -h=% qThG2)"ו3]!kB*pFDlA,eEiHfPs5H:Փ~H0DتDIhF3c2E9H5zԑʚiX=:mxghd(v׊9iSOd@0ڽ:p5h-t&Xqӕ,ie|7A2O%PEhtjY1wЃ!  ࢽMy7\a@ţJ 4ȻF@o̒?4wx)]P~u57X 9^ܩU;Iꭆ 5 eK27({|Y׎ V\"Z1 Z}(Ǝ"1S_vE30>p; ΝD%xW?W?vo^Vidr[/&>~`9Why;R ;;ɮT?r$g1KACcKl:'3 cﳯ*"t8~l)m+U,z`(>yJ?h>]vЍG*{`;y]IT ;cNUfo¾h/$|NS1S"HVT4uhǜ]v;5͠x'C\SBplh}N ABx%ޭl/Twʽ]D=Kžr㻠l4SO?=k M: cCa#ha)ѐxcsgPiG{+xQI= zԫ+ 8"kñj=|c yCF/*9жh{ ?4o kmQNx;Y4膚aw?6>e]Qr:g,i"ԩA*M7qB?ӕFhV25r[7 Y }LR}*sg+xr2U=*'WSZDW]WǞ<叓{$9Ou4y90-1'*D`c^o?(9uݐ'PI& fJݮ:wSjfP1F:X H9dԯ˝[_54 }*;@ܨ ðynT?ןd#4rGͨH1|-#MrS3G3).᧏3vz֑r$G"`j 1tx0<ƆWh6y6,œGagAyb)hDß_mü gG;evݝnQ C-*oyaMI><]obD":GA-\%LT8c)+y76oQ#*{(F⽕y=rW\p۩cA^e6KʐcVf5$'->ՉN"F"UQ@fGb~#&M=8טJNu9D[̤so~ G9TtW^g5y$bY'سǴ=U-2 #MCt(i lj@Q 5̣i*OsxKf}\M{EV{υƇ);HIfeLȣr2>WIȂ6ik 5YOxȺ>Yf5'|H+98pjn.OyjY~iw'l;s2Y:'lgꥴ)o#'SaaKZ m}`169n"xI *+ }FP"l45'ZgE8?[X7(.Q-*ތL@̲v.5[=t\+CNܛ,gSQnH}*FG16&:t4ُ"Ạ$b |#rsaT ]ӽDP7ո0y)e$ٕvIh'QEAm*HRI=: 4牢) %_iNݧl] NtGHL ɱg<1V,J~ٹ"KQ 9HS9?@kr;we݁]I!{ @G["`J:n]{cAEVʆ#U96j#Ym\qe4hB7Cdv\MNgmAyQL4uLjj9#44tl^}LnR!t±]rh6ٍ>yҏNfU  Fm@8}/ujb9he:AyծwGpΧh5l}3p468)Udc;Us/֔YX1O2uqs`hwgr~{ RmhN؎*q 42*th>#E#HvOq}6e\,Wk#Xb>p}դ3T5†6[@Py*n|'f֧>lư΂̺SU'*qp_SM 'c6m ySʨ;MrƋmKxo,GmPAG:iw9}M(^V$ǒѽ9| aJSQarB;}ٻ֢2%Uc#gNaݕ'v[OY'3L3;,p]@S{lsX'cjwk'a.}}& dP*bK=ɍ!;3ngΊUߴmt'*{,=SzfD Ako~Gaoq_mi}#mPXhύmxǍ΂巿zfQc|kc?WY$_Lvl߶c`?ljݲˏ!V6UЂ(A4y)HpZ_x>eR$/`^'3qˏ-&Q=?CFVR DfV9{8gnh(P"6[D< E~0<@`G6Hгcc cK.5DdB`?XQ2ٿyqo&+1^ DW0ꊩG#QnL3c/x 11[yxპCWCcUĨ80me4.{muI=f0QRls9f9~fǨa"@8ȁQ#cicG$Gr/$W(WV"m7[mAmboD j۳ l^kh׽ # iXnveTka^Y4BNĕ0 !01@Q"2AaPq3BR?@4QT3,㺠W[=JKϞ2r^7vc:9 EߴwS#dIxu:Hp9E! V 2;73|F9Y*ʬFDu&y؟^EAA(ɩ^GV:ݜDy`Jr29ܾ㝉[E;FzxYGUeYC v-txIsםĘqEb+P\ :>iC';k|zرny]#ǿbQw(r|ӹs[D2v-%@;8<a[\o[ϧwI!*0krs)[J9^ʜp1) "/_>o<1AEy^C`x1'ܣnps`lfQ):lb>MejH^?kl3(z:1ŠK&?Q~{ٺhy/[V|6}KbXmn[-75q94dmc^h X5G-}دBޟ |rtMV+]c?-#ڛ^ǂ}LkrOu>-Dry D?:ޞUǜ7V?瓮"#rչģVR;n/_ ؉vݶe5db9/O009G5nWJpA*r9>1.[tsFnQ V 77R]ɫ8_0<՜IFu(v4Fk3E)N:yڮeP`1}$WSJSQNjٺ޵#lј(5=5lǏmoWv-1v,Wmn߀$x_DȬ0¤#QR[Vkzmw"9ZG7'[=Qj8R?zf\a=OU*oBA|G254 p.w7  &ξxGHp B%$gtЏ򤵍zHNuЯ-'40;_3 !01"@AQa2Pq#3BR?ʩcaen^8F<7;EA{EÖ1U/#d1an.1ě0ʾRh|RAo3m3 % 28Q yφHTo7lW>#i`qca m,B-j݋'mR1Ήt>Vps0IbIC.1Rea]H64B>o]($Bma!=?B KǾ+Ծ"nK*+[T#{EJSQs5:U\wĐf3܆&)IԆwE TlrTf6Q|Rh:[K zc֧GC%\_a84HcObiؖV7H )*ģK~Xhչ04?0 E<}3#u? |gS6ꊤ|I#Hڛ աwX97Ŀ%SLy6č|Fa 8b$sקhb9RAu7˨pČ_\*w묦F 4D~f|("mNKiS>$d7SlA/²SL|6N}S˯g]6; #. 403WebShell
403Webshell
Server IP : 45.32.152.128  /  Your IP : 216.73.216.91
Web Server : nginx/1.24.0
System : Linux stage-vultr 5.4.0-216-generic #236-Ubuntu SMP Fri Apr 11 19:53:21 UTC 2025 x86_64
User : forge ( 1000)
PHP Version : 8.2.14
Disable Function : NONE
MySQL : OFF  |  cURL : ON  |  WGET : ON  |  Perl : ON  |  Python : ON  |  Sudo : ON  |  Pkexec : ON
Directory :  /home/forge/spin-robotics.com/resources/js/Pages/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Command :


[ Back ]     

Current File : /home/forge/spin-robotics.com/resources/js/Pages/products.tsx
import Button from '@/Components/Buttons/Button'
import Checkbox from '@/Components/Forms/Checkbox'
import Form from '@/Components/Forms/Form'
import TextField from '@/Components/Forms/TextField'
import FourCards from '@/Components/FourCards'
import FourCardsMobile from '@/Components/FourCardsMobile'
import Icon from '@/Components/Icon'
import Img from '@/Components/Image'
import SelectCarousel from '@/Components/SelectCarousel'
import SubscribeComponent from '@/Components/SubscribeComponent'
import usePageProps from '@/Components/hooks/usePageProps'
import Layout from '@/Layouts/Layout'
import { MODALS, ModalsContext } from '@/Layouts/ModalsContext'
import { ScreenContext } from '@/contexts/ScreenContext'
import { ProductType } from '@/types/ProductType'
import { Link, router, useForm } from '@inertiajs/react'
import { limit } from 'app/utils/utils'
import React, { useContext, useEffect, useRef, useState } from 'react'



const cardData = [
    {
        id: 1,
        title: "Truly Collaborative",
        description: "We connect humans and cobots through seamless integration of robots and screwdriving applications, all while ensuring Universal Robots’ safety software is not compromised.",
        iconName: "01"
    },
    {
        id: 2,
        title: "Automatic bit changer",
        description: "With the ability to change up to three bits faster than an individual manual exchange, the automatic bit changer increases productivity, allowing you to insert up to six screws in under a minute.",
        iconName: "02"
    },
    {
        id: 3,
        title: "Slim Design",
        description: "Our Slim Design allows our solution to reach narrow spaces with a torque range of 0.4 – 7.0 Nm. This makes it easier to operate in confined areas without compromising performance.",
        iconName: "03"
    },
    {
        id: 4,
        title: "SpinBridge Software",
        description: "Industry 4.0 and the SpinBridge Software track past and present insertion data, detecting errors to reduce scrap and promote eco-friendly production.",
        iconName: "04"
    }
]




interface Props {
    
}


interface ProductProps {
    id: number
    name: string
    sub: string
    images: Array<string>
    description: string
    slug: string
}

function ProductCard(props: ProductProps) {
    const { id, name, sub, images, description, slug, } = props
    let [textsOpen, setTextsOpen] = useState(false)
    let { t } = useContext(ScreenContext)
    return (
        <div className="border border-lightGray p-24px w-10/12 justify-between mobile:w-full flex mt-24px mobile:mt-70px mobile:flex-col rounded-sm">
            <div className="mobile:text-center mobile:order-2">
                <div className="text-14">Product no. {name}</div>
                <div className="text-18 font-semibold ">{sub}</div>
                <div className="mt-8px mb-16px" dangerouslySetInnerHTML={{ __html: ` ${textsOpen ? description : (description.slice(0, 45))} ${description?.length > 45 && (textsOpen ? "" : "...")}` }}></div>
                {
                    description?.length > 45 &&
                    <Button className="mobile:w-full" onClick={(e) => { e.preventDefault(); setTextsOpen((p) => !p) }} reverse href="#">{textsOpen ? t("Read less") : t("Read more")}</Button>
                }
            </div>
            <Img className="w-130px h-125px mobile:order-1 mobile:mx-auto mobile:-mt-70px" src={( images[0])} alt="product photo" />
        </div>
    )
}

interface SpinBridgeItemProps {
    icon: string
    name: string
    text: string
}

function SpinBridgeItem(props: SpinBridgeItemProps) {
    const { icon, name, text } = props

    return (
        <div className="mt-24px mobile:border-t border-lightGray mobile:pt-24px">
            {/* <div className="mobile:block hidden w-70px h-70px mx-auto mb-32px">
                <Icon name={icon} className="w-70px h-70px" />
            </div> */}
            <div className="text-18 font-semibold mobile:text-center">{name}</div>
            <div className="flex  mt-16px">
                {/* <div className="w-32px h-32px mobile:hidden">
                    <Icon className="w-32px h-32px" name={icon} />
                </div> */}
                <div className="text-16">{text}</div>
            </div>
        </div>
    )
}

let lastScroll = 0


export function ReadyToSayGoodbye() {

    const { open } = useContext(ModalsContext)
    let { isMobile, t } = useContext(ScreenContext)
    const { products = [] } = usePageProps<{ products?: Array<ProductType> }>();

    const form = useForm({});
    const { data, post, reset } = form;

    const submit = (e) => {
        e.preventDefault();
        post(route('contact-newsletter'), {
            preserveScroll: true,
            preserveState: true,
            onSuccess: (res) => { reset(); }
        })
    }


    return (
        <>
            <div className=" flex justify-center">
                <div className="flex w-full  mobile:flex-col">
                    <div className="w-full mobile:pl-0 pl-160px mobile:py-0 py-60px background-half">
                        <Img className="w-full min-h-1/2vh object-cover" src="/assets/img/working-dude.png" alt="robotic arm" />
                    </div>
                    <div className="w-full mobile:pr-0 pr-160px mobile:py-0 py-60px">
                        <div className="bg-darkBrandColor w-full h-full flex justify-center items-center text-white">
                            <div className="w-2/3 mobile:w-full mobile:flex mobile:flex-col mobile:px-16px mobile:py-24px">
                                <h3 className="text-24 font-semibold mobile:text-center">{t("Ready to say goodbye to returned orders from customers?")}</h3>
                                <Button reverse className="mx-auto mobile:w-full my-24px bg-white" onClick={(e) => { e.preventDefault(); open(MODALS.QUOTE) }} href="#">{t("Get a Quote")}</Button>
                                <div className="flex items-center">
                                    <Icon className="w-24px h-24px" name="info" />
                                    <div className="text-14 ml-16px">{t("Need more info? Just ")}<Link href="/demo"><span className="underline font-medium">{t("Book a Live Demo.")}</span></Link></div>
                                </div>
                            </div>
                        </div>
                    </div>
                </div>
            </div>

            <div className="flex mobile:flex-col ">
                <div className="bg-pink w-full mobile:px-16px pl-160px  mobile:pt-24px pt-30px overflow-y-hidden">
                    <div className="w-5/6 mobile:w-full grid">
                        <div className="w-full pr-30px mobile:w-full mobile:flex mobile:flex-col row-start-1 col-start-1">
                            <h3 className="text-24 mb-24px font-semibold mobile:text-center">{t("Are you interested in the return of your investment?")}</h3>
                            <div className="text-16 mb-16px text-center nMob:text-left">
                                {t("Every investment needs to provide a solid return. Calculate your return on investment on the collaborative screwdriver products with our simple ROI calculator.")}
                            </div>
                            <Button reverse className="mx-auto mobile:w-full bg-pink border-black text-black hover:text-black hover:border-black" onClick={(e) => { e.preventDefault(); }} href={route('calculator')}>{t("Get started")}</Button>
                            <div className="flex items-center text-darkBrandColor my-24px">
                                <Icon className="w-24px h-24px" name="info" />
                                <div className="text-14 ml-16px">{t('Without any obligation to provide your e-mail adress.')}</div>
                            </div>
                        </div>

                    </div>
                </div>
                <SubscribeComponent />
            </div>
        </>
    )

}


function Products(props: Props) {
    
    const form = useForm({});
    const { data, post, reset } = form;
    const { open } = useContext(ModalsContext)

    let vh = 0
    let vw = 0
    try {
        vh = Math.max(document.documentElement.clientHeight || 0, window.innerHeight || 0)
        vw = Math.max(document.documentElement.clientWidth || 0, window.innerWidth || 0)
    } catch (error) {

    }



    let [scrolled, setScrolled] = useState(0)
    let { isMobile, t } = useContext(ScreenContext)

    const scrollTop = useRef(0)

    const scrollDirection = useRef("down")

    let [deviceHeight, setDeviceHeight] = useState(0)

    let [introduction, setIntroduction] = useState(0)
    const intro = useRef(0)
    let [features, setFeatures] = useState(0)
    const feat = useRef(0)
    let [specifications, setSpecifications] = useState(0)
    const spec = useRef(0)
    let [software, setSoftware] = useState(0)
    const soft = useRef(0)
    let [easy, setEasy] = useState(0)
    const eas = useRef(0)
    let [stories, setStories] = useState(0)
    const stor = useRef(0)
    let [popular, setPopular] = useState(0)
    const pop = useRef(0)
    let [industries, setIndustries] = useState(0)
    const indu = useRef(0)

    function dummy() {
        try {
            scrollTop.current = window.scrollY
            // const vh = Math.max(document.documentElement.clientHeight || 0, window.innerHeight || 0)
            // const vw = Math.max(document.documentElement.clientWidth || 0, window.innerWidth || 0)
            setScrolled(window.scrollY)

            let scrollBar = document.getElementById("scrollingBar")
            // if(window.scrollY >= introduction && window.scrollY < features){
            //     scrollBar?scrollBar.scrollLeft = 170:()=>{};
            // } else if(window.scrollY >= features && window.scrollY < specifications){
            //     scrollBar?scrollBar.scrollLeft = 340:()=>{};
            // }else if(window.scrollY >= specifications && window.scrollY < software){
            //     scrollBar?scrollBar.scrollLeft = 510:()=>{};
            // }
            if (!scrollBar)
                return;

            if (window.scrollY >= pop.current) {
                scrollBar.scrollLeft = 1190

            }
            else if (window.scrollY >= stor.current) {
                scrollBar.scrollLeft = 1020

            } else if (window.scrollY >= eas.current) {

                scrollBar.scrollLeft = 850
            }
            else if (window.scrollY >= soft.current) {

                scrollBar.scrollLeft = 680
            }
            else if (window.scrollY >= spec.current) {

                scrollBar.scrollLeft = 510
            }
            else if (window.scrollY >= feat.current) {

                scrollBar.scrollLeft = 340
            }
            else if (window.scrollY >= intro.current) {

                scrollBar.scrollLeft = 170
            }
            else {
                scrollBar.scrollLeft = 0;
            }

        } catch (error) {

        }
    }

    useEffect(() => {

        try {
            const vh = Math.max(document.documentElement.clientHeight || 0, window.innerHeight || 0)
            setDeviceHeight(vh)
            let landing = document.getElementById("introduction")
            setIntroduction(landing ? (landing.offsetTop + landing.offsetHeight) : 0)
            intro.current = (landing ? (landing.offsetTop + landing.offsetHeight) : 0)

            let f = document.getElementById("featuresContainer")
            setFeatures(f ? (f.offsetTop + f.offsetHeight) : 0)
            feat.current = (f ? (f.offsetTop + f.offsetHeight) : 0)

            let s = document.getElementById("specifications")
            setSpecifications(s ? (s.offsetTop + s.offsetHeight) : 0)
            spec.current = (s ? (s.offsetTop + s.offsetHeight) : 0)

            let so = document.getElementById("software")
            setSoftware(so ? (so.offsetTop + so.offsetHeight) : 0)
            soft.current = (so ? (so.offsetTop + so.offsetHeight) : 0)

            let ea = document.getElementById("easy")
            setEasy(ea ? (ea.offsetTop + ea.offsetHeight) : 0)
            eas.current = (ea ? (ea.offsetTop + ea.offsetHeight) : 0)

            let ca = document.getElementById("case")
            setStories(ca ? (ca.offsetTop + ca.offsetHeight) : 0)
            stor.current = (ca ? (ca.offsetTop + ca.offsetHeight) : 0)

            let po = document.getElementById("popular")
            setPopular(po ? (po.offsetTop + po.offsetHeight) : 0)
            pop.current = (po ? (po.offsetTop + po.offsetHeight) : 0)

            let ind = document.getElementById("industries")
            setIndustries(ind ? (ind.offsetTop + ind.offsetHeight) : 0)
            indu.current = (ind ? (ind.offsetTop + ind.offsetHeight) : 0)

            setInterval(() => {
                if (lastScroll >= scrollTop.current) {
                    scrollDirection.current = ("up")
                } else {
                    scrollDirection.current = ("down")
                }
                lastScroll = scrollTop.current
            }, 500)

            document.addEventListener("scroll", dummy)
        } catch (error) {

        }

        return () => {
            try {
                document.removeEventListener("scroll", dummy)
            } catch (error) {

            }
        }


    }, [])







    let [txt, setTexts] = useState(0)
    let texts = [
        <div className="">
            <div>{t("Do more with less! Meet SD35")}
                <div className="text-16 mt-32px mb-24px">{t("Slim to reach narrow spaces")}</div>
            </div>
            <div className="flex justify-center items-center"><Icon name="universal-robots" /></div>
        </div>,
        <span className=" text-transition text-64 mobile:text-30 font-bold leading-relaxed w-full min-w-300px">{t("Easy and safe to use, inserts up to 6 screws a minute")}</span>,
        <span className=" text-transition text-64 mobile:text-30 font-bold leading-relaxed w-full min-w-300px">{t("Replaces 3 bits faster than any single manual exchange")}</span>,
        <span className=" text-transition text-64 mobile:text-30 font-bold leading-relaxed w-full min-w-300px">{t("Minimizes scrap, helps the environment")}</span>,
        <span className=" text-transition text-64 mobile:text-30 font-bold leading-relaxed w-full min-w-300px">{t("Our customers appreciate its numerous features")}</span>,
        <span className=" text-transition text-52 mobile:text-30 font-bold leading-relaxed w-full min-w-300px">{t("Multicolor and audible signaling informs about the status of the screwdriver and screw insertion")}</span>,
        <span className=" text-transition text-64 mobile:text-30 font-bold leading-relaxed w-full min-w-300px">{t("Start the robot with just a single push!")}</span>,
        <span className=" text-transition text-64 mobile:text-30 font-bold leading-relaxed w-full min-w-300px">{t("The screw is covered from pick-up to insertion. Hands stay free and safe.")}</span>,
        <span className=" text-transition text-64 mobile:text-30 font-bold leading-relaxed w-full min-w-300px">{t("Easy to set up and program with an ergonomic pistol grip")}</span>]


    let imgs = [
        { src: "/assets/img/imgM2.jpg" },
        { src: "/assets/img/imgM3.jpg" },
        { src: "/assets/img/imgM4.jpg" },
        { src: "/assets/img/imgM5.jpg" },
        { src: "/assets/img/imgM1.jpg" },
        { src: "/assets/img/imgM2.jpg" },
        { src: "/assets/img/imgM3.jpg" },
        { src: "/assets/img/imgM4.jpg" },
        { src: "/assets/img/imgM5.jpg" },
        { src: "/assets/img/imgM1.jpg" },
    ]

    const video = useRef<HTMLVideoElement>(null)


    let intervalId = useRef<any>(null)

    function changeTexts() {
        let id = setInterval(() => {
            setTexts(t => {
                let p = t + 1
                // sconsole.log(p);
                if (p > texts?.length - 1) {
                    p = 0;
                }

                return p;
            })

        }, 3000)
        intervalId.current = id

    }

    let [isPlaying, setPlaying] = useState(false)
    let [videoHidden, setVideoHidden] = useState(true)

    const ytvideo = useRef<HTMLIFrameElement | null>(null)

    function playVideo() {
        if (ytvideo.current) {
            setVideoHidden(false)
            // ytvideo.current.setAttribute("src", "https://www.youtube.com/embed/ZbOV2kLgl7k")
        }
    }

    const scrollpos = useRef(0)
    let [unimport, setUnimport] = useState(0)

    function scrollMinimal(e) {
        try {
            scrollpos.current = window.scrollY
            setUnimport(scrollpos.current)
        } catch (error) {

        }
    }

    useEffect(() => {

        if (isMobile) {
            changeTexts();
        }

        try {
            document.addEventListener("scroll", scrollMinimal)
        } catch (error) {

        }
        // const textAnim = TweenMax.fromTo(text.current, 3, {opacity:1}, {opacity:0})

        return () => {
            try {
                document.removeEventListener("scroll", scrollMinimal)
            } catch (error) {

            }
        }


    }, [])



    const { info_texts } = usePageProps<{ info_texts: Array<any> }>();
    const ReadMoreReadLess = ({ limit, children }) => {

        const [isReadMoreShown, setReadMoreShown] = useState(false)
        // const toggleBtn = () => {
        //     setReadMoreShown(prevState => !prevState)
        // }

        return (
            <div className="read-more-read-less w-300px mt-8px mb-16px mobile:text-center mobile:mx-15px mobile:order-2">
                <div>{isReadMoreShown ? children : children.substr(0, limit)}</div>
                <div className='h-50px cursor-pointer transform text-16 mt-15px duration-300 border hover:text-lightBlue bg-white hover:border-lightBlue border-darkBrandColor text-darkBrandColor rounded-sm px-22px inline-flex items-center justify-center font-normal mobile:w-full' onClick={() => { setReadMoreShown((p) => !p) }}> {isReadMoreShown ? 'Read Less' : 'Read More'}</div>
            </div>
        );
    };


    return (
        <Layout fixed  direction={scrollDirection.current} movingHeader={true} >
            <div id="scrollingBar" className={("w-full sticky transform duration-300 z-99999 bg-white flex border-b border-t border-lightGray  mobile:overflow-x-scroll ") /* + (scrollDirection.current=="down"?"top-0":(isMobile?"top-85px":"top-125px")) */}

                style={{
                    top: scrollDirection.current == "down" ? (0) : (isMobile ? 85 : (info_texts?.length < 1 ? 85 : 85 + limit(40 - unimport, 0, 40)))
                }}
            >
                <a className="w-full text-center" href="#introduction"><div className={("py-16px px-24 duration-300 whitespace-nowrap mobile:w-170px flex items-center text-lightBlue " + ((scrolled >= 0) && "border-b border-lightBlue") + " " + ((scrolled >= 0 && scrolled < introduction) && "font-bold"))}> <div className="w-24px"></div>{t("Introduction")}</div></a>
                <a className="w-full text-center" href="#features"><div className={("py-16px px-24px duration-300 mobile:w-170px  whitespace-nowrap text-lightBlue " + ((scrolled > introduction) && " border-b border-lightBlue ") + " " + ((scrolled >= introduction && scrolled < features) && " font-bold"))}>{t("Features")}</div></a>
                <a className="w-full text-center" href="#specifications"><div className={("py-16px px-24px duration-300 mobile:w-170px whitespace-nowrap text-lightBlue " + ((scrolled >= features) && " border-b border-lightBlue") + " " + ((scrolled >= features && scrolled < (specifications)) && " font-bold"))}>{t("Specification")}</div></a>
                <a className="w-full text-center" href="#software"><div className={("py-16px px-24px duration-300 mobile:w-170px whitespace-nowrap text-lightBlue " + ((scrolled >= specifications) && " border-b border-lightBlue") + " " + ((scrolled >= specifications && scrolled < software) && "font-bold"))}>{t("Software")}</div></a>
                <a className="w-full text-center" href="#easy"><div className={("py-16px px-24px duration-300 mobile:w-170px whitespace-nowrap text-lightBlue " + ((scrolled >= software) && " border-b border-lightBlue") + " " + ((scrolled >= software && scrolled < easy) && "font-bold"))}>{t("Easy Setup")}</div></a>
                <a className="w-full text-center" href="#case"><div className={("py-16px px-24px duration-300 mobile:w-170px whitespace-nowrap text-lightBlue " + ((scrolled >= easy) && " border-b border-lightBlue") + " " + ((scrolled >= easy && scrolled < stories) && "font-bold"))}>{t("Case Stories")}</div></a>
                <a className="w-full text-center" href="#popular"><div className={("py-16px px-24px duration-300 mobile:w-235px whitespace-nowrap text-lightBlue " + ((scrolled >= stories) && " border-b border-lightBlue") + " " + ((scrolled >= stories && scrolled < popular) && "font-bold"))}>{t("Popular Accessories")}</div></a>
                <a className="w-full text-center" href="#industries"><div className={("py-16px px-24px duration-300 mobile:w-170px  whitespace-nowrap text-lightBlue " + ((scrolled >= popular) && " border-b border-lightBlue") + " " + ((scrolled >= popular) && "font-bold"))}>{t("Industries")}</div></a>
            </div>

            <div id="introduction" className="h-screen min-h-screen mobile:min-h-noHeader140px mobile:h-noHeader w-full flex items-center justify-center bg-black relative">

                {
                    isMobile ?
                        <div className="w-full h-screen min-h-screen mobile:min-h-noHeader140px mobile:h-noHeader">

                            {
                                imgs.map((im, i) =>
                                    <Img key={i} className={`w-full absolute h-screen min-h-screen mobile:min-h-noHeader140px mobile:h-noHeader object-cover ${txt == i ? "opacity-100 duration-2200 delay-1000" : "opacity-0 duration-1000"}`} src={im.src} alt="imgM" />
                                )
                            }
                            <div className="w-full h-noHeader min-h-noHeader140px bg-black bg-opacity-40 absolute"></div>
                        </div>
                        :
                        <div>
                            <video ref={video} onCanPlayThrough={() => {
                                if (!isPlaying) {
                                    video!.current!.play(); changeTexts(); setPlaying(true);
                                }

                            }} onEnded={() => { clearInterval(intervalId.current); changeTexts(); video.current!.play() }} className="w-full h-screen min-h-screen object-cover" preload="auto" muted src="/assets/SD35_70BG.mp4" />
                        </div>

                }


                {
                    texts.map((t, i) =>
                        <div key={i + "text"} className={`top-50% left-50% transform -translate-x-50% -translate-y-50% mobile:-translate-y-50% absolute text-64 mobile:text-h32 font-extrabold text-center text-white min-w-300px flex ${txt == i ? "opacity-100 duration-2900 delay-1000" : "opacity-0 duration-1000"}`}>{t}</div>
                    )
                }


            </div>


            {/* <div id="featuresContainer" className="w-full relative text-center bg-fullHeightImg bg-fixed bg-cover bg-no-repeat flex flex-col bg-center" >
                <div className="w-full h-full absolute top-0 left-0 bg-white pointer-events-none bg-opacity-50"></div>
                <div id="introduction" className="col-start-1 row-start-1 w-full min-h-noHeader flex justify-center items-center z-50">
                    <div className="text-64 font-bold w-6/12 mobile:w-full mx-auto">
                        MEET SD35
                    </div>
                </div>
                <div id="features" className="col-start-1 row-start-2 w-full min-h-noHeader flex justify-center items-center z-50 mobile:px-16px">
                    <div className="text-h32 font-bold w-6/12 mobile:w-full mx-auto">A robotic tool designed to drive up to 4 screws a minute</div>
                </div>
                <div className="col-start-1 row-start-3 w-full min-h-noHeader flex justify-center items-center z-50 mobile:px-16px">
                    <div className="text-h32 font-bold w-6/12 mobile:w-full mx-auto">Affordable, easy to setup and safe to use by humans</div>
                </div>
                <div className="col-start-1 row-start-4 w-full min-h-noHeader flex justify-center items-center z-50 mobile:px-16px">
                    <div className="text-h32 font-bold w-6/12 mobile:w-full mx-auto">Works as an extension to robotic arms</div>
                </div>
                <div className="col-start-1 row-start-5 w-full min-h-noHeader flex justify-center items-center z-50 mobile:px-16px">
                    <div className="text-h32 font-bold w-6/12 mobile:w-full mx-auto">Our customers appreciate its numerous features</div>
                </div>
                <div className="col-start-1 row-start-6 w-full min-h-noHeader flex justify-center items-center z-50 mobile:px-16px">
                    <div className="w-6/12 mx-auto mobile:w-full">
                        <div className="text-h32 font-bold">Light signalling</div>
                        <div className="mt-16px">Etiam egestas wisi a erat. Nullam sit amet magna in magna gravida vehicula. Curabitur ligula sapien, pulvinar a vestibulum quis, facilisis vel sapien.</div>

                    </div>
                </div>
                <div className="col-start-1 row-start-7 w-full min-h-noHeader flex justify-center items-center z-50 mobile:px-16px">
                    <div className="w-6/12 mx-auto mobile:w-full">
                        <div className="text-h32 font-bold">Configurable push button</div>
                        <div className="mt-16px">Etiam egestas wisi a erat. Nullam sit amet magna in magna gravida vehicula. Curabitur ligula sapien, pulvinar a vestibulum quis, facilisis vel sapien.</div>

                    </div>
                </div>
                <div className="col-start-1 row-start-8 w-full min-h-noHeader flex justify-center items-center z-50 mobile:px-16px">
                    <div className="w-6/12 mx-auto mobile:w-full">
                        <div className="text-h32 font-bold">Safety shield</div>
                        <div className="mt-16px">Etiam egestas wisi a erat. Nullam sit amet magna in magna gravida vehicula. Curabitur ligula sapien, pulvinar a vestibulum quis, facilisis vel sapien.</div>

                    </div>
                </div>
                <div className="col-start-1 row-start-9 w-full min-h-noHeader flex justify-center items-center z-50 mobile:px-16px">
                    <div className="w-6/12 mx-auto mobile:w-full">
                        <div className="text-h32 font-bold">Quick change coupling</div>
                        <div className="mt-16px">Etiam egestas wisi a erat. Nullam sit amet magna in magna gravida vehicula. Curabitur ligula sapien, pulvinar a vestibulum quis, facilisis vel sapien.</div>

                    </div>
                </div>
                <div className="col-start-1 row-start-10 w-full min-h-noHeader flex justify-center items-center z-50 mobile:px-16px">
                    <div className="w-6/12 mx-auto mobile:w-full">
                        <div className="text-h32 font-bold">Magnetic screw holder</div>
                        <div className="mt-16px">Etiam egestas wisi a erat. Nullam sit amet magna in magna gravida vehicula. Curabitur ligula sapien, pulvinar a vestibulum quis, facilisis vel sapien.</div>

                    </div>
                </div>
                <div className="col-start-1 row-start-10 w-full min-h-noHeader flex justify-center items-center z-50 mobile:px-16px">
                    <div className="w-6/12 mx-auto mobile:w-full">
                        <div className="text-h32 font-bold">Nová sekce</div>
                        <div className="mt-16px">Etiam egestas wisi a erat. Nullam sit amet magna in magna gravida vehicula. Curabitur ligula sapien, pulvinar a vestibulum quis, facilisis vel sapien.</div>

                    </div>
                </div>
            </div> */}

            {/* <div id="featuresContainer">
                <ScrollAnimationSectionProducts />
            </div> */}

            <div id="specifications" className="px-16px text-center py-85px relative">
                <h2 className="text-24 font-semibold w-5/12 mb-24px mobile:w-full mx-auto">{t("Would you like to see the full specification?")}</h2>
                <Button className="flex mobile:flex-col gap-24px justify-center" href="/assets/Data sheet-SpinRoboticsSD35-12122022.pdf" isDownload download target="_blank">
                    <Icon className="w-24px h-24px" name="download" />
                    <span className="ml-12px mobile:mb-20px">{t("Download datasheet (.pdf)")}</span>
                </Button>
            </div>

            <div id="software" className="mobile:block grid mobile:grid-cols-1 grid-cols-2 border-t border-lightGray ">
                <div className="h-full relative mobile:row-start-1 mobile:min-h-1/2vh mobile:max-h-1/2vh min-h-screen">
                    <video className=" object-contain object-center sticky top-125px mobile:row-start-1 mobile:min-h-1/2vh mobile:max-h-1/2vh" src="/assets/live/monitor.mp4" autoPlay muted loop></video>
                </div>
                <div className="pt-85px mobile:pt-24px pr-160px pl-100px mobile:px-16px pb-85px mobile:pb-40px">
                    <div className="mobile:row-start-2 ">
                        <h2 className="text-24 font-semibold">{t("SD35 comes together with an exceptional software: Spin Interface")}</h2>
                        <div className="text-16 mt-24px mobile:border-none border-b border-lightGray pb-45px mb-48px">{t("Visualise and check your production quality on a screen. No more missing screws and returned batches.")}</div>
                        <SpinBridgeItem icon="placeholder" name={t("Storage of process data for optimization")} text={t("Spin Interface saves and visualizes the torque curve and final torque for each screw insertion.")} />
                        <SpinBridgeItem icon="placeholder" name={t("Unique connectivity")} text={t("Connect and control SD35 no matter which robotic arm you use. Define your product in the interface and duplicate it throughout your assembly.")} />
                        <SpinBridgeItem icon="placeholder" name={t("High precision")} text={t("Define and track all parameters that are important in your production: final torque, final motor rotations, time outs, screw lengths, screw types and more.")} />
                        <SpinBridgeItem icon="placeholder" name={t("Retrieve and save your data")} text={t("Back up your production data in case you need them in the future by using the industrial communication protocol - OPC-UA.")} />
                    </div>
                </div>

            </div>
            <div id="easy" className="w-full min-h-screen mobile:min-h-1/2vh mobile:px-16px px-160px mobile:py-40px py-85px background-half-reverse text-center">
                <h2 className="mb-24px mx-auto w-4/12 mobile:w-full text-center text-24 font-semibold">{t("Our tools are easy to set-up")}</h2>
                <div className="flex items-center justify-center">
                    <div className="mx-auto mb-48px relative">
                        <div onClick={() => { setVideoHidden(false) }} className={("videoplaceholder top-0 left-0 flex items-center justify-center " + (videoHidden ? "absolute" : "hidden"))} style={{ width: isMobile ? 0.8 * vw : (vw * 0.8), height: isMobile ? 0.4 * vh : vh * 0.8 }}>
                            <div className="text-20 text-white p-12px border border-white rounded-sm">{t("Play the video")}</div>
                        </div>
                        {/* <iframe ref={ytvideo} className="" width={isMobile?0.8*vw:(vw*0.8)} height={isMobile?0.4*vh:vh*0.8}
                            src="https://www.youtube.com/embed/ZbOV2kLgl7k?autoplay=1">
                        </iframe> */}
                        <iframe width={isMobile ? 0.8 * vw : (vw * 0.8)} height={isMobile ? 0.4 * vh : vh * 0.8} src="https://www.youtube.com/embed/0IKEaW-WVdk" title="YouTube video player" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture"></iframe>
                    </div>
                </div>
                {/* <Button className="mx-auto mt-24px mobile:w-full" reverse href="/">Learn more</Button> */}
            </div>
            <div id="case" className="px-160px mobile:px-0 mobile:py-24px py-80px border-t border-lightGray">
                <h2 className="text-center text-24 font-semibold w-6/12 mobile:w-full mx-auto mobile:px-16px mobile:mt-32px">{t("See how other companies thrive thanks to our products")}</h2>
                <div className="grid mobile:block grid-cols-2 mt-24px mobile:mt-32px mobile:gap-0 gap-32px mobile:grid-cols-1">
                    <div className="border-lightGray hover:shadow-xl border mobile:border-none rounded-sm flex mobile:flex-col">
                        <div className="w-full  border-lightGray py-60px px-24px mobile:order-2">
                            <div className="bg-pink px-12px py-8px text-darkBrandColor rounded-lg font-medium text-14 w-auto text-center">{t("Industrial Electronics")}</div>
                            <h3 className="my-8px font-semibold text-18">Danfoss</h3>
                            <div>{t("Danfoss teamed up with us to revolutionize frequency converters.")}</div>
                        </div>
                        <div className="w-full flex items-center justify-center mobile:order-1">
                            <Img className="w-50% mobile:my-80px" src="/assets/icons/danfoss.svg" alt="spaceX" />
                        </div>
                    </div>
                    <div className="border-lightGray hover:shadow-xl border mobile:border-none rounded-sm flex mobile:flex-col">
                        <div className="w-full  border-lightGray py-60px px-24px mobile:order-2">
                            <div className="bg-pink px-12px py-8px text-darkBrandColor rounded-lg font-medium text-14 w-auto text-center">{t("Automotive")}</div>
                            <h3 className="my-8px font-semibold text-18">ELVEZ</h3>
                            <div>{t("ELVEZ uses SD35 for versatile car parts assembly.")}</div>
                        </div>
                        <div className="w-full flex items-center justify-center mobile:order-1">
                            <Img className="w-50% mobile:my-80px" style={{ filter: "invert(1)" }} src="/assets/icons/elvez.svg" alt="spaceX" />
                        </div>
                    </div>
                    <div className="border-lightGray hover:shadow-xl border mobile:border-none rounded-sm flex mobile:flex-col">
                        <div className="w-full border-lightGray py-60px px-24px mobile:order-2">
                            <div className="bg-pink px-12px py-8px text-darkBrandColor rounded-lg font-medium text-14 w-auto text-center">{t("Home Appliances")}</div>
                            <h3 className="my-8px font-semibold text-18">Innovation is invented for life with the future of assembly</h3>
                            <div>{t("Bosch Thermotechnik GmbH")}</div>
                        </div>
                        <div className="w-full flex justify-center items-center mobile:order-1">
                            <Img className="w-50% mobile:my-80px" src="/assets/icons/boschBlack.svg" alt="bosch" />
                        </div>
                    </div>
                </div>
            </div>

            <FourCards cardData={cardData} />
            <FourCardsMobile cardData={cardData} />


            <div id="popular" className="grid mobile:grid-cols-1 grid-cols-2 border-t border-b mobile:pb-24px border-lightGray mobile:">
                <div className="pt-85px mobile:pt-24px pl-160px mobile:px-16px">
                    <div className="mobile:row-start-2 pb-30px mobile:pb-10px">
                        <h2 className="text-24 font-semibold">{t("Popular Accessories")}</h2>
                        <div className="border border-lightGray p-24px w-10/12 justify-between mobile:w-full flex mt-24px mobile:mt-70px mobile:flex-col rounded-sm">
                            <div className="mobile:text-center mobile:order-2">
                                <div className="text-14">
                                    SF26
                                </div>
                                <h3 className="text-18 font-semibold">
                                    Screw feeder OM-26R
                                </h3>
                                <ReadMoreReadLess
                                    limit={60}>
                                    Compatible with a wide range of screw types:Totam tempora pariatur illum alias, harum numquam earum possimus. Lorem ipsum, dolor sit amet consectetur adipisicing elit. Necessitatibus corporis laboriosam, vero at rem laborum nulla.
                                </ReadMoreReadLess>
                            </div>
                            <Img className='w-130px h-125px mobile:order-1 mobile:mx-auto mobile:mt-70px' src='/assets/img/rameno.png' alt="" />
                        </div>

                        <div className="border border-lightGray p-24px w-10/12 justify-between mobile:w-full flex mt-24px mobile:mt-70px mobile:flex-col rounded-sm">
                            <div className="mobile:text-center mobile:order-2">
                                <div className="text-14">
                                    SM-RTT
                                </div>
                                <h3 className="text-18 font-semibold">
                                    SpinMount flexi
                                </h3>
                                <ReadMoreReadLess
                                    limit={60}>
                                    Lock SD35 in position with a simple twist and lock movement.Totam tempora pariatur illum alias, harum numquam earum possimus.
                                </ReadMoreReadLess>
                            </div>
                            <Img className='w-130px h-125px mobile:order-1 mobile:mx-auto mobile:mt-70px' src='/assets/img/rameno.png' alt="" />
                        </div>



                        {/* {
                            products.filter((p) => p.name == "ABC3").map((p) =>
                                <ProductCard key={p.id} {...p} />
                            )
                        }
                        {
                            products.filter((p) => p.name == "SF26").map((p) =>
                                <ProductCard key={p.id} {...p} />
                            )
                        }
                        {
                            products.filter((p) => p.name == "SM-RTT").map((p) =>
                                <ProductCard key={p.id} {...p} />
                            )
                        } */}
                    </div>
                </div>
                <div className="h-full relative mobile:row-start-1 min-h-screen mobile:min-h-1/2vh">
                    <Img className="sticky w-full top-0 min-h-screen mobile:min-h-1/2vh object-cover" src="/assets/img/indexPlaceholder.png" alt="accessories" />
                </div>
            </div>
            <SelectCarousel />
            <ReadyToSayGoodbye />
        </Layout>
    )
}

export default Products

Youez - 2016 - github.com/yon3zu
LinuXploit