aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorMichael Foiani <mfoiani2019@communityschoolnaples.org>2018-07-26 23:37:41 -0400
committerMichael Foiani <mfoiani2019@communityschoolnaples.org>2018-07-26 23:37:41 -0400
commit84e15b866786854073feefce2392b47a3d84d724 (patch)
tree03bc7098b30d547a021505813ba7f041f996b661 /src
parentfa52586a3fba954d037abdbc534c45e90f86f142 (diff)
Created styling and backend for users to sign up for competitions.
Diffstat (limited to 'src')
-rw-r--r--src/actions/firebase.js62
-rw-r--r--src/components/button-shared-styles.js12
-rw-r--r--src/components/competition-element.js38
-rw-r--r--src/components/mao-competitions.js134
-rw-r--r--src/components/test-element.js84
-rw-r--r--src/reducers/firebase.js12
6 files changed, 299 insertions, 43 deletions
diff --git a/src/actions/firebase.js b/src/actions/firebase.js
index 85ebe20..fe3ddb0 100644
--- a/src/actions/firebase.js
+++ b/src/actions/firebase.js
@@ -21,6 +21,7 @@ export const signIn = (_email, _password) => (dispatch) => {
*/
dispatch(authSuccess(user));
dispatch(getHours())
+ dispatch(pullRegisteredCompetitions());
})
.catch((error) => {
dispatch(authFail(error.code));
@@ -64,8 +65,8 @@ export const authSignOut = () => {
//End Firebase Auth
//Start Firebase Firestore
-export const GET_HOURS = 'GET_HOURS';
-export const UPDATE_HOURS = 'UPDATE_HOURS'
+export const GET_HOURS = 'GET_HOURS';
+export const UPDATE_HOURS = 'UPDATE_HOURS';
export const getHours = () => (dispatch, getState) => {
const currentState = getState().firebase;
@@ -87,4 +88,61 @@ export const updateHours = (hours) => {
}
}
+export const REGISTER_COMP = 'REGISTER_COMP';
+export const PULL_REGISTERED_COMPETITIONS = 'PULL_REGISTERED_COMPETITIONS';
+export const UPDATE_REGISTERED_COMPETITIONS = 'UPDATE_REGISTERED_COMPETITIONS';
+
+export const registerComp = (compName) => (dispatch, getState) => {
+ var docRef = firestore.collection('competitions').doc(compName);
+ var uid = getState().firebase.uid;
+
+ docRef.get().then((doc) => {
+ if(doc.exists) {
+ var uidArr = doc.data().uids;
+
+ uidArr.push(uid);
+
+ docRef.set({
+ uids: uidArr
+ });
+
+ dispatch(pullRegisteredCompetitions());
+ } else {
+ docRef.set({
+ uids : [uid]
+ }).then(() => {
+ dispatch(pullRegisteredCompetitions());
+ });
+ }
+ });
+}
+
+export const pullRegisteredCompetitions = () => (dispatch, getState) =>{
+ var registeredComps = [];
+
+ var docRef = firestore.collection('competitions');
+ docRef.get().then((query) => {
+ query.forEach((doc) => {
+ if(doc.data().uids.includes(getState().firebase.uid)) {
+ registeredComps.push(doc.id);
+ }
+ })
+ });
+
+ dispatch(updateRegisteredCompetitions(registeredComps));
+}
+
+
+
+
+export const updateRegisteredCompetitions = (registeredComps) => {
+ return {
+ type: UPDATE_REGISTERED_COMPETITIONS,
+ payload: registeredComps
+ }
+}
+
+
+
+
//End Firebase Firestore
diff --git a/src/components/button-shared-styles.js b/src/components/button-shared-styles.js
index 2f167e4..5f426a4 100644
--- a/src/components/button-shared-styles.js
+++ b/src/components/button-shared-styles.js
@@ -22,5 +22,17 @@ export const ButtonSharedStyles = html`
button:hover svg {
fill: var(--app-primary-color);
}
+
+ paper-button {
+ text-align: center;
+ }
+
+ paper-button.info {
+ background-color: #c9eaff;
+ }
+
+ paper-button.success {
+ background-color: #b7e1cd;
+ }
</style>
`;
diff --git a/src/components/competition-element.js b/src/components/competition-element.js
index 072f654..17381c9 100644
--- a/src/components/competition-element.js
+++ b/src/components/competition-element.js
@@ -10,12 +10,17 @@ subject to an additional IP rights grant found at http://polymer.github.io/PATEN
import { LitElement, html } from '@polymer/lit-element';
+// Import button styles
+import { ButtonSharedStyles } from './button-shared-styles.js';
+
// Import paper elements
import '@polymer/paper-card/paper-card.js';
class CompetitionElement extends LitElement {
_render(props) {
return html`
+ ${ButtonSharedStyles}
+
<style>
paper-card {
@@ -31,7 +36,23 @@ class CompetitionElement extends LitElement {
<div class="card-content">
<h3>${props.name}</h3>
<h4>${props.location}</h4>
- <p hidden="${!this.infoTabOpen}"> ${props.information}</p>
+ <p hidden="${!props.infoTabOpen}"> ${props.information}</p>
+ </div>
+ <div hidden="${!props.infoTabOpen}" class="card-actions">
+ <paper-button
+ class="info"
+ hidden="${props.isRegistered}"
+ raised
+ disabled= "${!props.initialized}"
+ on-tap= "${() => this.registerComp()}">
+ ${props.initialized? "Register" : "Sign In"}
+ </paper-button>
+
+ <paper-button class="success"
+ disabled
+ hidden="${!props.isRegistered}">
+ Already Registered
+ </paper-button>
</div>
</paper-card>
`;
@@ -41,7 +62,9 @@ class CompetitionElement extends LitElement {
name: String,
information: String,
location: String,
- infoTabOpen: Boolean
+ infoTabOpen: Boolean,
+ initialized: Boolean,
+ isRegistered: Boolean
}};
constructor() {
@@ -51,11 +74,20 @@ class CompetitionElement extends LitElement {
this.information = "Competition Information";
this.location = "Competition Location";
this.infoTabOpen = false;
+ this.initialized = false;
+ this.isRegistered = false;
}
toggleTab() {
- this.infoTabOpen = !this.infoTabOpen;
+ this.infoTabOpen = !this.infoTabOpen;
}
+
+ registerComp() {
+ this.dispatchEvent(new CustomEvent('register-comp'));
+ this.isRegistered = true;
+ }
+
+
}
window.customElements.define('competition-element', CompetitionElement);
diff --git a/src/components/mao-competitions.js b/src/components/mao-competitions.js
index 6a5ae44..53e0b29 100644
--- a/src/components/mao-competitions.js
+++ b/src/components/mao-competitions.js
@@ -16,7 +16,7 @@ import { connect } from 'pwa-helpers/connect-mixin.js';
import { store } from '../store.js';
//These are the actions needed by this element.
-import { } from '../actions/firebase.js';
+import { registerComp } from '../actions/firebase.js';
// We are lazy loading its reducer.
import firebase from '../reducers/firebase.js';
@@ -26,7 +26,8 @@ store.addReducers({
});
// These are the shared styles needed by this element.
-import { SharedStyles } from './shared-styles.js';
+import { SharedStyles } from './shared-styles.js';
+import { ButtonSharedStyles } from './button-shared-styles.js';
// Import paper elements
import '@polymer/paper-input/paper-input.js';
@@ -34,12 +35,14 @@ import '@polymer/paper-button/paper-button.js';
import '@polymer/paper-card/paper-card.js';
// Import custom elements
-import './competition-element.js'
+import './competition-element.js';
+import './test-element.js';
class MaoCompetitions extends connect(store)(PageViewElement) {
_render(props) {
return html`
${SharedStyles}
+ ${ButtonSharedStyles}
<style>
.underline {
border-bottom: 1px solid var(--app-primary-color);
@@ -112,12 +115,6 @@ class MaoCompetitions extends connect(store)(PageViewElement) {
--paper-card-background-color: #fff8e1;
}
-
-
- paper-button.info {
- background-color: #c9eaff;
- }
-
.card-actions {
vertical-align: bottom;
}
@@ -159,7 +156,21 @@ class MaoCompetitions extends connect(store)(PageViewElement) {
</div>
<div class="card-actions">
- <paper-button class="info" disabled>Registry Not Available</paper-button>
+ <paper-button
+ class = "info"
+ hidden = "${props.nationalRegistered}"
+ on-tap = "${() => this.registerNationals()}"
+ raised
+ disabled = "${!props.initialized}">
+ ${props.initialized ? "Register" : "Sign In to Register"}
+ </paper-button>
+
+ <paper-button
+ class = "success"
+ hidden = "${!props.nationalRegistered}"
+ disabled>
+ Already Registered
+ </paper-button>
</div>
</paper-card>
@@ -167,6 +178,7 @@ class MaoCompetitions extends connect(store)(PageViewElement) {
</section>
<section>
+
<paper-card
image="http://a57.foxnews.com/images.foxnews.com/content/fox-news/travel/2018/02/24/universal-theme-parks-hike-ticket-prices-following-disney-resorts/_jcr_content/par/featured_image/media-0.img.jpg/931/524/1519489441149.jpg?ve=1&tl=1&text=big-top-image"
heading="Orlando, Florida"
@@ -180,7 +192,21 @@ class MaoCompetitions extends connect(store)(PageViewElement) {
</div>
<div class="card-actions">
- <paper-button class="info" disabled>Registry Not Available</paper-button>
+ <paper-button
+ class = "info"
+ hidden = "${props.statesRegistered}"
+ on-tap = "${() => this.registerStates()}"
+ raised
+ disabled = "${!props.initialized}">
+ ${props.initialized ? "Register" : "Sign In to Register"}
+ </paper-button>
+
+ <paper-button
+ class = "success"
+ hidden = "${!props.statesRegistered}"
+ disabled>
+ Already Registered
+ </paper-button>
</div>
</paper-card>
@@ -197,25 +223,37 @@ class MaoCompetitions extends connect(store)(PageViewElement) {
<div class="regional-comp1">
<competition-element
+ id="dec-competition-element"
name="December"
information="Dank ass regional competition"
- location="Miami, American Heritage">
+ location="Miami, American Heritage"
+ initialized="${props.initialized}"
+ isRegistered="${props.registeredComps.includes('December')}"
+ on-register-comp="${() => store.dispatch(registerComp(this.shadowRoot.getElementById('dec-competition-element').name))}">
</competition-element>
</div>
<div class="regional-comp2">
<competition-element
+ id="jan-competition-element"
name="January"
information="Other dank comp"
- location="Immokalee, Cypress Bay">
+ location="Immokalee, Cypress Bay"
+ initialized="${props.initialized}"
+ isRegistered="${props.registeredComps.includes('January')}"
+ on-register-comp="${() => store.dispatch(registerComp(this.shadowRoot.getElementById('jan-competition-element').name))}">
</competition-element>
</div>
<div class="regional-comp3">
<competition-element
+ id="feb-competition-element"
name="February"
information="The dankest comp"
- location="Orlando, Science School">
+ location="Orlando, Science School"
+ initialized="${props.initialized}"
+ isRegistered="${props.registeredComps.includes('February')}"
+ on-register-comp="${() => store.dispatch(registerComp(this.shadowRoot.getElementById('feb-competition-element').name))}">
</competition-element>
</div>
@@ -232,37 +270,38 @@ class MaoCompetitions extends connect(store)(PageViewElement) {
<p>All students must register and complete two of the tests to be qualified for national and/or state competitions.</p>
</div>
- <paper-card
+ <test-element
+ id="amc-test-element"
+
class="amcComp"
image="https://www.maa.org/sites/default/files/AMC%20Logo.png"
- elevation="0">
- <div class="card-content">
- <p>The American Mathematics Exam is a difficult national exam;
- it is a 25 multiple-choice question,
- 40 minute test for middle schoolers designed to promote the development and enhancement of problem solving skills.</p>
- </div>
+ elevation="0"
- <div class="card-actions">
- <paper-button class="info" raised>Register</paper-button>
- </div>
- </paper-card>
+ name = "amc"
+ information = "The American Mathematics Exam is a difficult national exam;
+ it is a 25 multiple-choice question,
+ 40 minute test for middle schoolers designed to promote the development and enhancement of problem solving skills."
+ initialized="${props.initialized}"
+ isRegistered="${props.registeredComps.includes('amc')}"
+ on-register-comp="${() => store.dispatch(registerComp(this.shadowRoot.getElementById('amc-test-element').name))}">
+ </test-element>
+
+
+ <test-element
+ id="fml-test-element"
- <paper-card
class="fmlComp"
image=""
- elevation="0">
- <div class="card-content">
- <h3>FML</h3>
- <p>The Florida Math Leauge is a state-wide exam.
- It has three parts, each being 30 minutes long.</p>
- </div>
+ elevation="0"
- <div class="card-actions">
- <paper-button class="info" raised>Register</paper-button>
- </div>
- </paper-card>
+ name = "fml"
+ information = "The Florida Math Leauge is a state-wide exam.
+ It has three parts, each being 30 minutes long."
+ initialized="${props.initialized}"
+ isRegistered="${props.registeredComps.includes('fml')}"
+ on-register-comp="${() => store.dispatch(registerComp(this.shadowRoot.getElementById('fml-test-element').name))}">
</div>
</section>
@@ -271,9 +310,32 @@ class MaoCompetitions extends connect(store)(PageViewElement) {
static get properties() { return {
// This is the data from the store.
+ registeredComps : Array,
+ initialized : Boolean,
+
+ nationalRegistered : Boolean,
+ statesRegistered : Boolean
}}
_stateChanged(state) {
+ this.initialized = state.firebase.initialized;
+ this.registeredComps = state.firebase.registeredComps;
+ //console.log(this.registeredComps);
+
+ this.nationalRegistered = this.registeredComps.includes('nationals');
+ this.statesRegistered = this.registeredComps.includes('states');
+ }
+
+ registerNationals() {
+ this.nationalRegistered = true;
+
+ store.dispatch(registerComp('nationals'))
+ }
+
+ registerStates() {
+ this.statesRegistered = true;
+
+ store.dispatch(registerComp('states'))
}
}
diff --git a/src/components/test-element.js b/src/components/test-element.js
new file mode 100644
index 0000000..ec4797b
--- /dev/null
+++ b/src/components/test-element.js
@@ -0,0 +1,84 @@
+/**
+@license
+Copyright (c) 2018 The Polymer Project Authors. All rights reserved.
+This code may only be used under the BSD style license found at http://polymer.github.io/LICENSE.txt
+The complete set of authors may be found at http://polymer.github.io/AUTHORS.txt
+The complete set of contributors may be found at http://polymer.github.io/CONTRIBUTORS.txt
+Code distributed by Google as part of the polymer project is also
+subject to an additional IP rights grant found at http://polymer.github.io/PATENTS.txt
+*/
+
+import { LitElement, html } from '@polymer/lit-element';
+
+//import button styles
+import { ButtonSharedStyles } from './button-shared-styles.js';
+
+// Import paper elements
+import '@polymer/paper-card/paper-card.js';
+
+class TestElement extends LitElement {
+ _render(props) {
+ return html`
+ ${ButtonSharedStyles}
+
+ <style>
+
+ paper-card {
+ --paper-card-background-color: #ffffff;
+ width: 100%;
+ }
+
+ </style>
+ <paper-card
+ image = "${props.image}"
+ elevation = "0">
+ <div class="card-content">
+ <p>${props.information}</p>
+ </div>
+ <div class="card-actions">
+ <paper-button
+ class="info"
+ hidden="${props.isRegistered}"
+ raised
+ disabled= "${!props.initialized}"
+ on-tap= "${() => this.registerComp()}">
+ ${props.initialized? "Register" : "Sign In"}
+ </paper-button>
+
+ <paper-button class="success"
+ disabled
+ hidden="${!props.isRegistered}">
+ Already Registered
+ </paper-button>
+ </div>
+ </paper-card>
+ `;
+ }
+
+ static get properties() { return {
+ name: String,
+ information: String,
+ image: String,
+ initialized: Boolean,
+ isRegistered: Boolean
+ }};
+
+ constructor() {
+ super();
+
+ this.name = "Competition";
+ this.information = "Competition Information";
+ this.image = "Image Path";
+ this.initialized = false;
+ this.isRegistered = false;
+ }
+
+ registerComp() {
+ this.dispatchEvent(new CustomEvent('register-comp'));
+ this.isRegistered = true;
+ }
+
+
+}
+
+window.customElements.define('test-element', TestElement);
diff --git a/src/reducers/firebase.js b/src/reducers/firebase.js
index 6f02c69..4b0ed9a 100644
--- a/src/reducers/firebase.js
+++ b/src/reducers/firebase.js
@@ -12,11 +12,12 @@ import {
AUTH_FAIL,
AUTH_SUCCESS,
AUTH_SIGN_OUT,
- UPDATE_HOURS
+ UPDATE_HOURS,
+ UPDATE_REGISTERED_COMPETITIONS
}
from '../actions/firebase.js';
-const firebase = (state = {initialized: false, authMessage: "", hours: -1, uid: null}, action) => {
+const firebase = (state = {initialized: false, authMessage: "", hours: -1, uid: null, registeredComps: []}, action) => {
switch (action.type) {
case AUTH_SUCCESS:
return {
@@ -49,6 +50,13 @@ const firebase = (state = {initialized: false, authMessage: "", hours: -1, uid:
}
break;
+ case UPDATE_REGISTERED_COMPETITIONS:
+ return {
+ ...state,
+ registeredComps : action.payload
+ }
+ break;
+
default:
return state;
}