140 lines
6.3 KiB
JavaScript
140 lines
6.3 KiB
JavaScript
import React, { Component } from 'react';
|
|
import blogOne from '../../assets/images/blog-1.jpg';
|
|
import blogTwo from '../../assets/images/blog-2.jpg';
|
|
import blogThree from '../../assets/images/blog-3.jpg';
|
|
import JobsData from '../../Services/JobsData';
|
|
import getConfig from './../../Config/config'
|
|
import CountDownTimer from '../Helper/CountDownTimer';
|
|
|
|
class RecentJobsOne extends Component {
|
|
|
|
constructor() {
|
|
// debugger;
|
|
super();
|
|
this.state = { jobsDataResults: [] };
|
|
}
|
|
|
|
async componentDidMount(){
|
|
// debugger;
|
|
JobsData().then(res => {
|
|
this.setState({jobsDataResults:res.data.result_list});
|
|
}).catch(err => {
|
|
console.log('startjoblist error', err)
|
|
})
|
|
}
|
|
|
|
titleLen(title){
|
|
let maxl = 45;
|
|
title.replace('/', ' ');
|
|
title.replace('www.', '');
|
|
title.replace('.com', '');
|
|
title.replace('http//', '');
|
|
|
|
return (title.length > maxl)? title.substring(0,maxl-2)+'...': title;
|
|
}
|
|
// if (jobsDataResults ()== null){
|
|
// return null;
|
|
// }
|
|
render() {
|
|
var site = getConfig()[0];
|
|
if ( this.state.jobsDataResults== undefined ){
|
|
return null;
|
|
}
|
|
var dashUrl = process.env.REACT_APP_DASH_URL;
|
|
|
|
if (this.state.jobsDataResults.length == 0){
|
|
return <></>;
|
|
}
|
|
|
|
return (
|
|
<>
|
|
<section className="appie-blog-area pt-90 pb-95">
|
|
<div className="container">
|
|
<div className="row">
|
|
<div className="col-lg-12">
|
|
<div className="appie-section-title text-center">
|
|
<h3 className="appie-title">Current Projects</h3>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div className="row">
|
|
|
|
{
|
|
this.state.jobsDataResults.map(i => {
|
|
var options = { weekday: 'long', year: 'numeric', month: 'long', day: 'numeric' };
|
|
var postDt = new Date(i.expire).toLocaleDateString("en-US", options);
|
|
|
|
return (<div className="col-md-6 col-xl-3">
|
|
<div
|
|
className="appie-single-service container-fluid mt-30 wow animated fadeInUp boxBorder d-flex align-items-center"
|
|
data-wow-duration="3000ms"
|
|
data-wow-delay="200ms"
|
|
>
|
|
<div className="content d-flex flex-column justify-content-between" style={{height: '200px', width: '100%'}}>
|
|
<div className="titleBox">
|
|
<h3 className="title">
|
|
<a href={dashUrl}>
|
|
<span className='font_black'>{this.titleLen(i.title)} </span>
|
|
</a>
|
|
</h3>
|
|
</div>
|
|
<div className='p-0 container-fluid'>
|
|
<div><hr /></div>
|
|
<div className="blog-meta">
|
|
<ul>
|
|
<li className="expire">
|
|
<a href={dashUrl} className='d-block'>
|
|
<div className='font_red d-flex align-items-start'>
|
|
<div className='pr-2'>Expires :</div>
|
|
<CountDownTimer targetDate={postDt}/>
|
|
</div>
|
|
</a>
|
|
</li>
|
|
</ul>
|
|
</div>
|
|
<div className='lmoreTxt d-flex justify-content-end align-items-center'>
|
|
<a href={dashUrl}>
|
|
Learn More <i className="fal fa-arrow-right" />
|
|
</a>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
</div>)
|
|
|
|
|
|
})
|
|
}
|
|
|
|
|
|
<div className="col-lg-3 col-md-6">
|
|
<div
|
|
className="appie-blog-item mt-30 wow animated fadeInUp"
|
|
data-wow-duration="3000ms"
|
|
data-wow-delay="600ms"
|
|
>
|
|
|
|
<div className="content">
|
|
|
|
<h3 className="title">
|
|
<a href={dashUrl}>
|
|
Find more opportunities at our marketplace.
|
|
</a>
|
|
</h3>
|
|
<a href="https://dashboard.wrenchboard.com/login">
|
|
Login now <i className="fal fa-arrow-right" />
|
|
</a>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
</div>
|
|
</div>
|
|
</section>
|
|
</>
|
|
);
|
|
}
|
|
}
|
|
|
|
export default RecentJobsOne; |