Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Extensions #121

Open
wants to merge 33 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
33 commits
Select commit Hold shift + click to select a range
155d328
Use HTTPS in production
whois-jon-peterson Jul 24, 2019
616f511
Remove errant console.log
whois-jon-peterson Jul 25, 2019
ec8d00c
Add readme and associated screenshots.
lynnerang Jul 25, 2019
04c28a1
Move screenshots folder.
lynnerang Jul 25, 2019
4c735e4
Update title.
lynnerang Jul 25, 2019
50a7e7e
Fix failing tests for card component.
lynnerang Jul 25, 2019
12b9b15
Fix all but one failing tests.
lynnerang Jul 25, 2019
dce380e
Update README.md
SiimonStark Jul 25, 2019
eb2545d
change JoinGame tests
rdren0 Jul 25, 2019
d680b3e
add coverage ignore file variables
rdren0 Jul 25, 2019
cbf10e0
update Join Game tests
rdren0 Jul 25, 2019
aa66547
Update main and board tests
rdren0 Jul 25, 2019
cf01eeb
update App and Card tests
rdren0 Jul 25, 2019
21e3c6b
Add fixes for Main component tests by adding more props.
lynnerang Jul 25, 2019
f7ec6cd
Update index.test.js
rdren0 Jul 25, 2019
dc509ae
Add final tests.
lynnerang Jul 25, 2019
eb94e85
Remove main snap
lynnerang Jul 25, 2019
bc592f7
Add main snapshot again.
lynnerang Jul 25, 2019
bb0f2cf
Rebase: [remote]Master -> [local]Feature
SiimonStark Jul 28, 2019
7c3150e
Merge w/ remote Master
SiimonStark Aug 8, 2019
fc35451
Invite code now shows for all players
SiimonStark Aug 13, 2019
cc1b81f
Call handlePlayAgain() to fetch & inst player
SiimonStark Aug 13, 2019
e518162
Pass necessary props to ReplayScreen, Erase Game state on New game.
SiimonStark Aug 13, 2019
6a5cd35
Create component for AboutDevs, Render info card per dev (Random order)
SiimonStark Aug 13, 2019
12674d4
Import AboutDev Component
SiimonStark Aug 13, 2019
faf2c87
Create NavLink for AboutDevs component
SiimonStark Aug 13, 2019
cbeb856
Change style of buttons in Header
SiimonStark Aug 13, 2019
f6b74ce
Whole card links to dev's Github, remove green border
SiimonStark Aug 13, 2019
c6c3aa7
Added custom back button to necessary components
SiimonStark Aug 14, 2019
903f346
Styled back button globally.
SiimonStark Aug 15, 2019
0bd62fd
Added custom back button
SiimonStark Aug 15, 2019
acf9e87
Increased Z-index, added Copy feature for Title
SiimonStark Aug 15, 2019
52168da
Added [Description, Links, Styling]
SiimonStark Aug 15, 2019
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
18 changes: 10 additions & 8 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,14 +1,16 @@


## Table of contents
* [Intro](#CodeWords)
* [Screenshots](#Screenshots)
* [Getting Started](#Getting-Started)
* [How to Use](#How-to-Use)
* [Project Emphasis](#Project-Emphasis)
* [UI Design](#UI-Design)
* [Future Plans](#Future-Plans)
* [License](#License)
- [CodeWords ![Build Status](https://travis-ci.com/code-words/codewords-ui)](#codewords-build-statushttpstravis-cicomcode-wordscodewords-ui)
- [Screenshots](#screenshots)
- [Getting Started](#getting-started)
- [How to Use](#how-to-use)
- [UI Design](#ui-design)
- [Future Plans](#future-plans)
- [Project Emphasis](#project-emphasis)
- [Front-End](#front-end)
- [Back-end](#back-end)
- [Licensing](#licensing)


# CodeWords [![Build Status](https://travis-ci.com/code-words/codewords-ui.svg?branch=master)](https://travis-ci.com/code-words/codewords-ui)
Expand Down
111 changes: 111 additions & 0 deletions src/components/AboutDevs/_AboutDevs.scss
Original file line number Diff line number Diff line change
@@ -0,0 +1,111 @@
// ** TEMP
// .dev-pic {
// content: "";
// background: $intel-assassin-accent;
// height: 75px;
// width: 75px;
// margin: 5px auto;
// border-radius: 50%;
// }

.AboutDevs {
display: flex;
flex-direction: column;
justify-content: center;
background: $intel-assassin;
position: absolute;
z-index: 3;
left: 10vw;
top: 10vh;
height: 70vh;
width: 75vw;
padding: 30px;
box-shadow: 8px 8px 12px $overlay-filter, 2px 2px 10px rgba(250, 250,250, .5);
border: $intel-assassin-accent .5px inset;
border-radius: 20px;

.divider {
content: "";
height: 2px;
width: 100%;
border: 1px inset gray;
}

.dev-pic {
margin: auto;
border-radius: 50%;
// border: $intel-assassin-accent 1px 1px ridge;
width: 12vh;
}

.dev-img {
width: 10vh;
border-radius: 50%;
border: silver ridge 2px;
}

a {
text-decoration: none;
}

h2 {
margin: 0 0 10px 30px;
text-shadow: 2px 2px 3px black;
}

h2, h4, h5 {
font-family: $header-font;
}
}

.devs {
display: flex;
align-items: center;
justify-content: center;
height: 85%;
width: 100%;
}

.dev {
display: grid;
grid-auto-flow: dense;
background: $button-default;
border-radius: 5px;
box-shadow: 3px 3px 5px $overlay-filter;
color: black;
padding: 20px;
margin: 30px;
height: 80%;
width: 25%;

p {
overflow: scroll;
min-height: 25vh;
max-height: 25vh;
}

h4 {
color: black;
}

.social {
display: flex;
font-size: 3vh;
justify-content: space-evenly;
align-items: flex-end;
position: relative;
left: 20%;
width: 60%;

a {
text-decoration: none;
color: $intel-assassin;
&:hover {
color: $player-active;
cursor: pointer;
text-shadow: 1px 1px 2px black;
}
}
}
}

116 changes: 116 additions & 0 deletions src/components/AboutDevs/index.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,116 @@
/* eslint-disable jsx-a11y/anchor-has-content */
import React from 'react';

const AboutDevs = (props) => {
const devs = [
{
name: "Jon Peterson",
gH_Link: "https://github.com/joequincy",
l_Link: "https://www.linkedin.com/in/joequincy/",
p_Link: "https://alumni.turing.io/alumni/jon-peterson",
role: "BE",
img:
"https://media.licdn.com/dms/image/C4E03AQEhILN-5s-jEw/profile-displayphoto-shrink_800_800/0?e=1571270400&v=beta&t=WBZ4ztxssw3W-PwaLADES30A7HvX-4anP6oPfkRLpYs",
summary:
"A tinkerer by nature, I enjoy hacking away on an interesting idea and learning new tricks along the way. I’m always looking for a new idea or technology to explore!"
},
{
name: "Justin Pyktel",
gH_Link: "https://github.com/SiimonStark",
l_Link: "https://www.linkedin.com/in/justinpyktel/",
p_Link: "https://alumni.turing.io/alumni/justin-pyktel",
role: "FE",
img:
"https://media.licdn.com/dms/image/C4E03AQGFJ9zu6O-7Zw/profile-displayphoto-shrink_200_200/0?e=1571270400&v=beta&t=KmObYjlcIRPiKy0wB2itsWgIJAwBNVyHPKoXlobY_0o",
summary:
"Transitioning into the tech field I intend to keep my audience at the forefront of design choices. Creating a more enjoyable and fun experience is certainly a win win!"
},
{
name: "Lynne Rang",
gH_Link: "https://github.com/lynnerang",
l_Link: "https://www.linkedin.com/in/lynne-rang/",
p_Link: "https://alumni.turing.io/alumni/lynne-rang",
role: "FE",
img:
"https://media.licdn.com/dms/image/C4E03AQFu8BraqA9MJA/profile-displayphoto-shrink_800_800/0?e=1571270400&v=beta&t=u4QsbYsdbK4CYp0MaKpv0I6Ky9jKs3h0b_lF_3VC8vY",
summary:
"My skills as a developer come together with a holistic understanding of what it takes to make a great product"
},
{
name: "Rachael Drennan",
gH_Link: "https://github.com/rdren0",
l_Link: "https://www.linkedin.com/in/rachael-drennan/",
p_Link: "https://alumni.turing.io/alumni/rachael-drennan",
role: "FE/BE",
img:
"https://media.licdn.com/dms/image/C4E03AQFmgk9OS5Z88Q/profile-displayphoto-shrink_800_800/0?e=1571270400&v=beta&t=A8lyTbvCZ7IxW1ctg19Oqw0EfVq06xUh1kMK14vybSI",
summary:
"As an artist and problem solver, I was drawn to software engineering because it allows me to be both creative and analytical in my approach to a project."
}
];

const randomizeDevs = () => {
// Resource:
// https://stackoverflow.com/questions/2450954/how-to-randomize-shuffle-a-javascript-array

for (let i = devs.length - 1; i > 0; i--) {
const j = Math.floor(Math.random() * (i + 1));
[devs[i], devs[j]] = [devs[j], devs[i]];
}
}

const renderDevs = () => {
randomizeDevs();

return devs.map(dev => {
return (
<div className="dev" key={dev.name}>
<div className="dev-pic">
<img
className="dev-img"
src={dev.img}
alt={`Pic of Dev: ${dev.name}`}
/>
</div>
<h4>{dev.name}</h4>
<h5>Role: {dev.role}</h5>
<div className="divider" />
<p>{dev.summary}</p>
<div className="social">
<a
className="fab fa-linkedin"
href={dev.l_Link}
target="blank"
/>
<a
className="fab fa-github-square"
href={dev.gH_Link}
target="blank"
/>
<a
className="fas fa-address-card"
href={dev.p_Link}
target="blank"
/>
</div>
</div>
);
})
}

return (
<div className="backdrop">
<div className="AboutDevs">
<i
id="back"
className="fas fa-arrow-alt-circle-left"
onClick={() => props.history.goBack()}
/>
<h2>Top Secret Case Files:</h2>
<section className="devs">{renderDevs()}</section>
</div>
</div>
);
}

export default AboutDevs;
Empty file.
48 changes: 40 additions & 8 deletions src/components/App/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ import { Route, Switch } from 'react-router-dom';
import Header from '../Header';
import StartScreen from '../StartScreen';
import RuleList from '../RuleList';
import AboutDevs from '../AboutDevs';
import NewGame from '../NewGame';
import JoinGame from '../JoinGame';
import Lobby from '../Lobby';
Expand Down Expand Up @@ -37,12 +38,12 @@ export class App extends Component {
};
}

handleUserInit = result => {
handleUserInit = (result, inviteCode) => {
const { id, name, token } = result;
localStorage.setItem("Token", token);
const user = { id, name, token }
if (result.invite_code) this.setState({ invite_code: result.invite_code });
this.setState({ user }, () => this.createCable(token));
// if (result.invite_code) this.setState({ invite_code: result.invite_code });
this.setState({ user, invite_code: inviteCode || result.invite_code }, () => this.createCable(token));
};

updateHintLogs = data => {
Expand Down Expand Up @@ -140,6 +141,31 @@ export class App extends Component {
}
}

closeReplay = () => {
this.setState({
user: {},
invite_code: '',
playerRoster: [],
hintLogs: [],
cardData: [],
cable: {},
isLobbyFull: false,
currentPlayerId: null,
remainingAttempts: null,
winner: "",
currentHint: {
hintWord: "",
relatedCards: null
},
showDialog: false,
confMsg: ""
});
}

finishGame = (code) => {
this.setState({invite_code: code});
}

dataSwitch = result => {
const { type, data } = result;
switch (type) {
Expand All @@ -156,9 +182,8 @@ export class App extends Component {
this.setGuess(data);
break;
case 'game-over':
console.log(data)
this.setGuess(data);
// add resetting of invite code from response and resetting of some state properties
this.finishGame(data.nextGame);
setTimeout(() => this.setState({ winner: data.winningTeam}), 2500);
break;
case 'illegal-action':
Expand Down Expand Up @@ -194,10 +219,16 @@ export class App extends Component {
};

render() {
const { showDialog, cardData, confMsg } = this.state;
const { showDialog, cardData, confMsg, user, invite_code } = this.state;

const replay = !this.state.winner ? null
: < ReplayScreen winner={this.state.winner} closeReplay={() => this.setState({winner: ''})}/>
const replay = !this.state.winner ? null : (
<ReplayScreen
winner={this.state.winner}
userData={{ name: user.name, inviteCode: invite_code }}
handleUserInit={this.handleUserInit}
closeReplay={this.closeReplay}
/>
);

const dialog = showDialog ? <ConfDialog
message={confMsg}
Expand All @@ -213,6 +244,7 @@ export class App extends Component {
<Switch>
<Route exact path="/" component={StartScreen} />
<Route exact path="/rules" component={RuleList} />
<Route path="/about" component={AboutDevs} />
<Route exact path="/new" render={
/* istanbul ignore next */
() => <NewGame handleUserInit={this.handleUserInit} />} />
Expand Down
14 changes: 14 additions & 0 deletions src/components/Header/_Header.scss
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,12 @@
justify-content: space-between;
align-items: center;
margin: 0 20px;
position: relative;
z-index: 99;

.header-left {
cursor: pointer;
}

.header-title {
color: white;
Expand All @@ -15,6 +21,8 @@
color: white;
align-items: center;



.new-game-btn {
margin-left: 30px;
padding: 5px 15px;
Expand All @@ -36,3 +44,9 @@
}
}
}

.label {
position: absolute;
left: 2%;
background: $button-default;
}
Loading