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/spin_mount.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 FourCardsMobileSpin from '@/Components/FourCardsMobileSpin'
import FourCardsSpin from '@/Components/FourCardsSpin'
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, useForm } from '@inertiajs/react'
import { limit } from 'app/utils/utils'
import React, { useContext, useEffect, useRef, useState } from 'react'

// 






const cardDataSpin = [
    {
        id: 1,
        title: "Easy to install",
        description: "With the SpinMount from Spin Robotics you can easily switch between End-Of-Arm Tools and optimize your assembly processes. With an easy twist, the changeover between EOAT’s and tasks is made efficient.",
        iconName: "01"
    },
    {
        id: 2,
        title: "Twist and Lock system",
        description: "With the SpinMount from Spin Robotics you can easily switch between End-Of-Arm Tools and optimize your assembly processes. With an easy twist, the changeover between EOAT’s and tasks is made efficient.",
        iconName: "02"
    },
    {
        id: 3,
        title: "Increase production time",
        description: "Maximize your output and boost efficiency with our time-saving tool. Increase production time and get more done in less time, without compromising quality.",
        iconName: "03"
    },
    {
        id: 4,
        title: "Safe Changeover",
        description: "Its main function is to ensure stable and safe mounting when fixing tools to the robot. SpinMount makes the tool work without excessive movements that could potentially be dangerous or damaging.",
        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)
    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 ? "Read less" : "Read more"}</Button>
                }
            </div>
            <Img className="w-130px h-125px mobile:order-1 mobile:mx-auto mobile:-mt-70px" src={( images[0])} alt="product" />
        </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



function Spin_mount(props: Props) {
    
    const form = useForm({});
    const { data, post, reset } = form;
    const { open } = useContext(ModalsContext)
    let vh = 0
    let vw = 0
    try {
        let vh = Math.max(document.documentElement.clientHeight || 0, window.innerHeight || 0)
        let 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 = 680

            // }
            if (window.scrollY >= stor.current) {
                scrollBar.scrollLeft = 680

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

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

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

                scrollBar.scrollLeft = 340
            }
            // 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 s = document.getElementById("specifications")
            setSpecifications(s ? (s.offsetTop + s.offsetHeight) : 0)
            spec.current = (s ? (s.offsetTop + s.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 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) {

            }
        }


    }, [])


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


    // useEffect(() => {
    //     setScrolled(scrollTop.current)
    // }, [scrollTop])

    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")
        }
    }

    // let [text, setTexts] = useState(<div className=" text-transition"><div>Easy to install on most collaborative robots</div><div className="text-16 mt-32px mb-24px">For example</div> <div className="flex justify-center items-center"><Icon name="universal-robots" /> <Icon className="ml-24px" name="omron" /></div></div>)
    let [txt, setTexts] = useState(0)
    let texts = [<div className=""><div>{t("Easy to install")}</div><div className="text-16 mt-32px mb-24px">{t("Twist and Lock System")}</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 min-w-300px w-full leading-relaxed">{t("Switch easily between tools")}</span>, <span className=" text-transition text-64 mobile:text-30 font-bold min-w-300px w-full leading-relaxed">{t("Time saving")}</span>, <span className=" text-transition text-64 mobile:text-30 font-bold w-full min-w-300px leading-relaxed">{t("Increase production time")}</span>]

    // useEffect(() => {
    //     let i = 1;
    //     setInterval(() => {
    //         setTexts(texts[i])
    //         i++;
    //         if (i > texts.length - 1) {
    //             i = 0;
    //         }
    //     }, 4500)
    // }, [])

    let text = texts[txt];

    let imgs = [
        { src: "/assets/img/spinmount_1.jpg" },
        { src: "/assets/img/spinmount_2.jpg" },
        { src: "/assets/img/spinmount_3.jpg" },
    ]

    const video = useRef<HTMLVideoElement>(null)

    useEffect(() => {
        if (video.current) {
            video.current.play()
            changeTexts()
        } else {
            changeTexts()
        }
    }, [])

    useEffect(() => {
        if (video.current) {
            video.current.play()
        }
    }, [isMobile])

    let [isPlaying, setPlaying] = useState(false)

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

                    return p;
                })

            }, 4333)

            setPlaying(true)
        }

    }

    const scrollpos = useRef(0)

    let [unimport, setUnimport] = useState(0)

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

        }
    }

    useEffect(() => {

        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) {

            }
        }
    }, [])



    // function dataCard() {
    //     return (
    //         <div className=''>
    //             <FourCards cardData={cardDataSpinMount} />
    //         </div>
    //     )
    // }



    const { info_texts } = usePageProps<{ info_texts: Array<any> }>();




    function newCardData() {
        throw new Error('Function not implemented.')
    }

    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-85px")) */}
                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="#easy"><div className={("py-16px px-24px duration-300 mobile:w-170px whitespace-nowrap text-lightBlue " + ((scrolled >= introduction) && " border-b border-lightBlue") + " " + ((scrolled >= introduction && scrolled < easy) && "font-bold"))}>{t("Easy Setup")}</div></a>
                <a className="w-full text-center" href="#specificationsAnchor"><div className={("py-16px px-24px duration-300 mobile:w-170px whitespace-nowrap text-lightBlue " + ((scrolled >= easy) && " border-b border-lightBlue") + " " + ((scrolled >= easy && scrolled < (specifications)) && " font-bold"))}>{t("Specification")}</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 >= specifications) && " border-b border-lightBlue") + " " + ((scrolled >= specifications && scrolled < stories) && "font-bold"))}>{t("Case Stories")}</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 >= stories) && " border-b border-lightBlue") + " " + ((scrolled >= stories) && "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-2166 delay-1000" : "opacity-0 duration-700"}`} src={im.src} alt="spinmount" />
                                )
                            }
                            <div className="w-full h-noHeader min-h-noHeader140px bg-black bg-opacity-40 absolute"></div>
                        </div>
                        :
                        <div>
                            <video ref={video} className="w-full h-screen min-h-screen object-cover" preload="auto" muted loop src="/assets/spin_mount.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 flex ${txt == i ? "opacity-100 duration-2166 delay-1000" : "opacity-0 duration-700"}`}>{t}</div>
                    )
                }


            </div>
            <div className="w-full flex items-center">
                <div className="mx-200px mobile:ml-16px mobile:mr-16px">
                    <p className='text-left text-20 mobile:text-20
                      mx-auto my-20px'>With the SpinMount from Spin Robotics you can easily switch between End-Of-Arm Tools and optimize your assembly processes. With an easy twist the changeover between EOAT’s and tasks is made    efficient.
                        The SpinMount is a flexible tool changer made for easy and fast mounting of EOAT’s on collaborative robots. Its main function is to ensure stable and safe mounting when fixing tools to the robot. SpinMount makes the tool work without excessive movements that could potentially be dangerous or damaging.<br /><br />
                    </p>
                </div>

            </div>


            <div id="easy" className="w-full min-h-screen mobile:min-h-1/2vh mobile:px-16px px-160px mobile:py-40px pt-85px background-half-reverse text-center">
                <h1 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")}</h1>
                <div className="flex items-center justify-center">
                    <div className="mx-auto relative">
                        <div onClick={() => { setVideoHidden(false) }} className={("videoplaceholder-spin-mount 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 width={isMobile ? 0.8 * vw : (vw * 0.8)} height={isMobile ? 0.4 * vh : vh * 0.8} src="https://www.youtube.com/embed/N_H_wgEJiG4" title="YouTube video player" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture"></iframe>
                    </div>
                </div>
            </div>

            <div id="specifications" className="px-16px text-center py-85px relative">
                <div className="absolute top-0 left-0 -mt-130px" id="specificationsAnchor"></div>
                <div className="text-24 font-semibold w-5/12 mb-24px mobile:w-full mx-auto">{t("Download the documentation")}</div>
                <div className="flex mobile:flex-col gap-24px justify-center">
                    {/* <Button className="hover:bg-lightBlue hover:text-white hover:border-lightBlue" href="/assets/Data sheet-SpinRoboticsSD35-12122022.pdf" isDownload download target="_blank">
                        <Icon className="w-24px h-24px" name="download" />
                        <span className="ml-12px">{t("Technical Sheet (.pdf)")}</span>
                    </Button> */}
                    <Button className="hover:bg-lightBlue hover:text-white hover:border-lightBlue" href="/assets/UserManualSpinMount.pdf" isDownload download target="_blank">
                        <Icon className="w-24px h-24px" name="download" />
                        <span className="ml-12px">{t("User Manual (.pdf)")}</span>
                    </Button>
                </div>
            </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 SpinMount 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>


            <FourCardsSpin cardDataSpin={cardDataSpin} />
            <FourCardsMobileSpin cardDataSpin={cardDataSpin} />



            <SelectCarousel />

            <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/fotorameno.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>
        </Layout>
    )
}

export default Spin_mount

Youez - 2016 - github.com/yon3zu
LinuXploit