Skip to content
30 changes: 26 additions & 4 deletions src/App.css
Original file line number Diff line number Diff line change
@@ -1,17 +1,39 @@
.App-header, footer {
background-color: rgb(57, 56, 56);
color:white
}

.App-header {
background-color: #222;
padding-bottom: 0.5rem;
color: white;
position: fixed;
height: 100px;
display: inline-block;
/* position: fixed; */
width: 100%;
}

.App-title {
text-align: center;
font-size: 1.5em;
display: inline-block;
padding-top: 20px;
padding-left: 20px;
}

.App-main {
padding-top: 7rem;
background-color: #E6ECF0;
background-color: rgba(249, 177, 89, 0.913);
}

img {
max-width: 150px;
border: white solid 3px;
border-radius: 50%;
margin: 20px 0px 0px 100px;
float: left;


}

footer {
padding: 10px;
}
16 changes: 12 additions & 4 deletions src/App.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,18 +4,26 @@ import timelineData from './data/timeline.json';

import Timeline from './components/Timeline';


class App extends Component {
render() {
console.log(timelineData);


// Customize the code below
render() {
return (
<div className="App">
<header className="App-header">
<h1 className="App-title">Application title</h1>
<img
src='https://www.biography.com/.image/ar_1:1%2Cc_fill%2Ccs_srgb%2Cg_face%2Cq_auto:good%2Cw_300/MTE4MDAzNDEwODQwOTQ2MTkw/ada-lovelace-20825279-1-402.jpg'
alt="Ada Lovelace\'s avatar" />
<h1 className="App-title">Ada Lovelace's Social Media Feed</h1>
</header>
<main className="App-main">
<Timeline events={timelineData.events} />
</main>

<footer>
kimbook, LLC
</footer>
</div>
);
}
Expand Down
4 changes: 3 additions & 1 deletion src/components/Timeline.css
Original file line number Diff line number Diff line change
@@ -1,5 +1,7 @@
.timeline {
width: 30%;
width: 800px;
margin: auto;
text-align: left;
word-wrap: break-word;
padding-bottom: 50px;
}
24 changes: 21 additions & 3 deletions src/components/Timeline.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,9 +2,27 @@ import React from 'react';
import './Timeline.css';
import TimelineEvent from './TimelineEvent';

const Timeline = () => {
// Fill in your code here
return;
const Timeline = (props) => {

const timelineEvents = props.events

const timelineEventComponents = timelineEvents.map ((timelineEvent, i) => {

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Good descriptive variable name!

return (
<div key={i} >
<TimelineEvent
person={timelineEvent.person}
timestamp={timelineEvent.timeStamp}
status={timelineEvent.status}
photo={timelineEvent.photo} />

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nice job adding the image.

</div>
);
});

return (
<div className='timeline'>
{timelineEventComponents}
</div>
);
}

export default Timeline;
37 changes: 35 additions & 2 deletions src/components/TimelineEvent.css
Original file line number Diff line number Diff line change
@@ -1,9 +1,11 @@
.timeline-event {
display: grid;
grid-template: 2rem auto 2rem / 1fr 1fr;
padding: 0.5rem;
border-bottom: 1px solid #E6ECF0;
padding: 1rem;
border-bottom: 5px solid rgba(249, 177, 89, 0.913);
background-color: #FFF;
min-height: 200px;

}

.timeline-event:hover {
Expand All @@ -17,6 +19,7 @@
}

.event-status {
margin-top: 60px;
grid-area: 2 / 1 / span 1 / -1;
}

Expand All @@ -25,3 +28,33 @@
margin-top: 0.5rem;
text-align: right;
}

.status-interactions {
padding-top: 10px;
border-top: 1px solid grey;
grid-area: 3 / 1 / span 1 / span 2;
display: inline;
text-align: right;

}

.status-interactions a {
padding: 20px;
}

a {
text-decoration: none;
}

a:hover {
color: tomato;
}

.avatar {
width: 70px;
height: 70px;
border: none;
border-radius: 50px;
margin: auto 10px auto auto;
float: left;
}
25 changes: 21 additions & 4 deletions src/components/TimelineEvent.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,9 +2,26 @@ import React from 'react';
import './TimelineEvent.css';
import Timestamp from './Timestamp';

const TimelineEvent = () => {
// Fill in your code here
return;
}
const TimelineEvent = (props) => {


return (
<section className='timeline-event'>
<div className='event-person'>
<img className='avatar' src={props.photo} alt='avatar' />
<h3> {props.person} </h3>
</div>
<p className='event-time' >
<Timestamp time={props.timestamp} />
</p>
<p className='event-status' > {props.status} </p>
<div className="status-interactions">
<a href="https://en.wikipedia.org/wiki/Nicolas_Cage">Like</a>
<a href="https://en.wikipedia.org/wiki/Nicolas_Cage">Comment</a>
<a href="https://en.wikipedia.org/wiki/Nicolas_Cage">Share</a>
</div>

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Good idea adding Like, Comment and Share!

</section>
);
};

export default TimelineEvent;
30 changes: 18 additions & 12 deletions src/data/timeline.json
Original file line number Diff line number Diff line change
Expand Up @@ -2,34 +2,40 @@
"person": "Ada Lovelace",
"events": [
{
"person": "Adele Goldberg",
"person": "Rosie 'the' Riveter",
"status": "In Smalltalk, everything happens somewhere else.",
"timeStamp": "2018-05-18T22:12:03Z"
"timeStamp": "2019-06-10T23:05:03Z",
"photo": ""
},

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Wow! Such a huge link!

{
"person": "Erica Baker",
"person": "Grace Hopper",
"status": "Every once in a while, life affords you the opportunity to have real, authentic, genuine happiness. It's up to you to see it. Pay attention.",
"timeStamp": "2018-05-18T22:19:40Z"
"timeStamp": "2019-06-10T22:12:03Z",
"photo": "https://upload.wikimedia.org/wikipedia/commons/thumb/a/ad/Commodore_Grace_M._Hopper%2C_USN_%28covered%29.jpg/220px-Commodore_Grace_M._Hopper%2C_USN_%28covered%29.jpg"
},
{
"person": "Aubrey Tang",
"person": "Katherine Johnson",
"status": "The art of computer programming is a blend of mathematics and poetry.",
"timeStamp": "2018-05-18T22:41:19Z"
"timeStamp": "2019-05-30T22:41:19Z",
"photo": "https://www.virginiahumanities.org/wp-content/uploads/2015/01/Katherine-Johnson-825x550.jpg"
},
{
"person": "Julia Evans",
"person": "Ellen DeGeneres",
"status": "no seriously what if we replaced tech books with informative concise 30 page zines though",
"timeStamp": "2018-05-18T23:02:44Z"
"timeStamp": "2019-05-18T22:19:40Z",
"photo": "https://www.thewrap.com/wp-content/uploads/2019/05/Ellens-Greatest-Night-of-Giveaways-1.jpg"
},
{
"person": "Stephanie Hurlburt",
"person": "Stay Golden",
"status": "I don’t think you can do good work if you’re not at least occasionally talking to a person you’re building for.",
"timeStamp": "2018-05-18T23:09:38Z"
"timeStamp": "2019-01-09T22:41:19Z",
"photo": "https://pmcdeadline2.files.wordpress.com/2018/10/bd2xz1v9eejud0ryymv8.jpg?w=681&h=383&crop=1"
},
{
"person": "Yan Zhu",
"person": "Amelia",
"status": "//for a good time, paste this into twitter page console: c=new AudioContext;n=setInterval(\"for(n+=7,i=k,P='\u25b2.\\\n';i-=1/k;P+=P[i%2?(i%2*j-j+n/k^j)&1:2])j=k/i;doc.innerHTML=P;with(c.createOscillator())frequency.value=200*(j+n/k^j),connect(c.destination),start(),stop(n/k)\",k=64)",
"timeStamp": "2018-05-18T23:51:01Z"
"timeStamp": "2018-09-18T23:51:01Z",
"photo": "https://upload.wikimedia.org/wikipedia/commons/b/b2/Amelia_Earhart_standing_under_nose_of_her_Lockheed_Model_10-E_Electra%2C_small.jpg"
}
]
}