Rev 2573 | Rev 2894 | Ir a la última revisión | Autoría | Comparar con el anterior | Ultima modificación | Ver Log |
import React, { useEffect, useRef } from "react";import { useState } from "react";import { connect } from "react-redux";import styled from "styled-components";import { axios } from "../../../utils";import CompanyFollowersHelper from "../../../shared/helpers/company-followers-helper/CompanyFollowers";import parse from "html-react-parser";import { addNotification } from "../../../redux/notification/notification.actions";import Spinner from "../../../shared/loading-spinner/Spinner";import { setTimelineUrl } from "../../../redux/feed/feed.actions";import FeedSection from "../../../dashboard/components/feed-section/FeedSection";const TABS = {FEEDS: "FEEDS",INFO: "INFO",};const View = (props) => {// backendVars destructuringconst {companyId,cover,image,totalFollowers,facebook,twitter,instagram,companyName,overview,locations,industry,companySize,foundationYear,website,timeline,} = props.backendVars;// redux destructuringconst { addNotification, setTimelineUrl } = props;// const [isFollower, setIsFollower] = useState(!!+follower);const [authorizedLinks, setAuthorizedLinks] = useState(null);const [loading, setLoading] = useState(false);const [followers, setFollowers] = useState(totalFollowers);const [initialLoading, setInitialLoading] = useState(true);const [isFollower, setIsFollower] = useState(false);const [currentTab, setCurrentTab] = useState(TABS.INFO);const [suggestionCompanies, setSuggestionCompanies] = useState([])const [lookMore, setLookMore] = useState(false);const shouldSetInitialTab = useRef(true);useEffect(() => {setTimelineUrl(timeline);fetchAuthorizedLinks();shouldSetInitialTab.current = false;setInitialLoading(false);getSuggestionCompanies()}, []);const getSuggestionCompanies = async () => {try {setLoading(true);const response = await axios.get(`/helpers/company-suggestion/${companyId}`);if (response.data.success)setSuggestionCompanies(response.data.data)} catch (error) {console.log('>>: error > ', error)} finally {setLoading(false)}}useEffect(() => {isFollower? setCurrentTab(TABS.FEEDS): setCurrentTab(TABS.INFO)}, [isFollower]);const fetchAuthorizedLinks = async () => {setLoading(true);const response = await axios.get(`/company/view/${companyId}`);const resData = response.data;(resData);if (resData.success) {setAuthorizedLinks(resData.data);setFollowers(resData.data.total_followers);if (resData.data.link_unfollow) {setIsFollower(true);if (shouldSetInitialTab.current) setCurrentTab(TABS.FEEDS);} else {setIsFollower(false);}}return setLoading(false);};const handleButtonAction = async (link) => {setLoading(true);const response = await axios.post(link);const resData = response.data;if (resData.success) {addNotification({style: "success",msg: resData.data,});fetchAuthorizedLinks();} else {setLoading(false);addNotification({style: "danger",msg: "ha ocurrido un error",});}};const changeCurrentTab = (tab) => {setCurrentTab(tab)}const getData = () => {let infoFollows = [...suggestionCompanies]if (!lookMore) {infoFollows = infoFollows.slice(0, 5);}return infoFollows}return (<React.Fragment><section className="cover-sec"><imgid="user-cover-img"src={`/storage/type/company-cover/code/${companyId}/${cover ? `filename/${cover}` : ""}`}alt="cover-image"/></section><main><div className="main-section"><div className="ph-5"><div className="main-section-data"><div className="main-left-sidebar"><div className="user_profile border-gray border-radius pb-5"><div className="user-pro-img"><imgid="company-img"src={`/storage/type/company/code/${companyId}/${image ? `filename/${image}` : ""}`}alt="profile-image"/></div><div className="user_pro_status horizontal-list"><h1>{companyName}</h1><div className="row px-5" style={{ marginTop: '10px' }}>{facebook &&<ionClick={() => window.location.href = facebook}className="cursor-pointer fa fa-facebook"style={{ fontSize: '1.4rem' }}/>}{twitter &&<ionClick={() => window.location.href = twitter}className="cursor-pointer fa fa-twitter"style={{ fontSize: '1.4rem' }}/>}{instagram &&<ionClick={() => window.location.href = instagram}className="fa fa-instagram cursor-pointer"style={{ fontSize: '1.4rem' }}/>}</div><div className="container horizontal-list"><div className="row "><div className="members_count"><b style={{ fontSize: '1rem' }} id="total-followers">{followers}</b><p style={{ fontSize: '1rem' }} className="ellipsis">Seguidores</p></div>{authorizedLinks?.link_unfollow &&<buttonclassName="btn btn-primary"onClick={() => handleButtonAction(authorizedLinks?.link_unfollow)}><span className="ellipsis w-100">Dejar de seguir</span></button>}{authorizedLinks?.link_follow &&<buttonclassName="btn btn-primary"onClick={() => handleButtonAction(authorizedLinks?.link_follow)}><span className="ellipsis">Seguir</span></button>}{authorizedLinks?.link_request &&<buttonclassName="btn btn-primary"onClick={() => handleButtonAction(authorizedLinks?.link_request)}><span className="ellipsis">Trabaja en esta empresa?</span></button>}{authorizedLinks?.link_accept &&<buttonclassName="btn btn-primary"onClick={() => handleButtonAction(authorizedLinks?.link_accept)}><span className="ellipsis">Aceptar</span></button>}{authorizedLinks?.link_cancel &&<buttontitle=""className="btn btn-primary"onClick={() => handleButtonAction(authorizedLinks?.link_cancel)}><span className="ellipsis">Cancelar</span></button>}{authorizedLinks?.link_reject &&<buttontitle=""className="btn btn-primary"onClick={() => handleButtonAction(authorizedLinks?.link_reject)}><span className="ellipsis">Rechazar</span></button>}{authorizedLinks?.link_leave &&<buttondata-link="{{>link_leave}}"title=""className="btn btn-primary"onClick={() => handleButtonAction(authorizedLinks?.link_leave)}><span className="ellipsis">Abandonar esta empresa</span></button>}{authorizedLinks?.link_contact &&<ahref={authorizedLinks?.link_contact}className="btn btn-primary"><span className="ellipsis">Mensaje</span></a>}</div></div></div></div><CompanyFollowersHelper companyId={companyId} /></div><div className="main-ws-sec"><div className="user-tab-sec rewivew">{!initialLoading&&<divclassName="row">{isFollower&&<divclassName="col text-left pl-0"><buttonclassName="btn btn-link p-0 text-decoration-none"onClick={() => changeCurrentTab(TABS.FEEDS)}style={{ padding: '0 !important' }}><span className="p-0 default-link font-weight-bold text-dark">Ver Publicaciones</span></button></div>}<divclassName="col text-right pl-0"><buttonclassName="btn btn-link p-0 text-decoration-none"onClick={() => changeCurrentTab(TABS.INFO)}style={{ padding: '0 !important' }}><span className="p-0 default-link font-weight-bold text-dark">Ver Información</span></button></div></div>}{/* <!-- tab-feed end--> */}</div>{currentTab === TABS.FEEDS&&<divclassName="product-feed-tab animated fadeIn"id="feed-dd feed"style={{ display: 'block' }}><div className="posts-section"><FeedSection routeTimeline={timeline} /></div></div>}{currentTab === TABS.INFO&&< divclassName="product-feed-tab animated fadeIn"id="feed-dd info"style={{ display: 'block' }}>{overview&&<div className="user-profile-extended-ov"><h3>Visión general</h3><span>{parse(overview)}</span></div>}{locations&&<div className="user-profile-extended-ov st2"><h3>Ubicación</h3><span>{locations.map(({ formatted_address, is_main }, index) => (<React.Fragment key={index}>{index >= 0 ? <hr /> : ""}<p>{`${formatted_address} ${is_main === "y" ? "(Principal)" : ""}`}</p></React.Fragment>))}</span></div>}{industry&&<div className="user-profile-ov"><h3>Industria</h3><span>{industry}</span></div>}{companySize&&<div className="user-profile-ov"><h3>Tamaño de la empresa</h3><span>{companySize}</span></div>}{foundationYear&&<div className="user-profile-ov"><h3>Año de fundación</h3><span>{foundationYear}</span></div>}{website&&<div className="user-profile-ov"><h3>Página web</h3><span>{website}</span></div>}</div>}{initialLoading&&<divstyle={{display: "flex",justifyContent: "center",alignItems: "center",}}><Spinner /></div>}</div><div className="right-sidebar" style={{ maxHeight: '450px' }}>{loading &&<div className="spinner-container"><Spinner /></div>}<divclassName="widget suggestions full-width d-none d-md-block d-lg-block border-gray border-radius"style={{ height: "auto", overflowY: "auto" }}><div className="sd-title"><h3>Empresas similares</h3></div><div className="mb-2" id="suggestions-similar-groups" style={{ height: '80%', overflowY: 'auto' }}>{suggestionCompanies.length? getData().map(element => {return (<div className="suggestion-usd d-flex justify-content-start align-items-center " key={element.id}><imgstyle={{ width: "10%", height: "auto" }}src={element.image}alt=""/><divclassName="sgt-text"><a href={element.profile} target="_blank"><h4 className="text-dark">{element.name}</h4></a></div></div>)}): <div className="view-more">Sin empresas similares</div>}</div>{suggestionCompanies.length >= 5&&<div className="w-100 text-center"><button className="btn btn-primary" onClick={() => setLookMore(!lookMore)}>{lookMore ? 'Ver menos' : 'Ver mas'}</button></div>}</div></div></div></div></div></main ></React.Fragment >);};// const mapStateToProps = (state) => ({// })const mapDispatchToProps = {addNotification: (notification) => addNotification(notification),setTimelineUrl: (url) => setTimelineUrl(url),};export default connect(null, mapDispatchToProps)(View);