diff options
-rw-r--r-- | src/actions/firebase.js | 62 | ||||
-rw-r--r-- | src/components/button-shared-styles.js | 12 | ||||
-rw-r--r-- | src/components/competition-element.js | 38 | ||||
-rw-r--r-- | src/components/mao-competitions.js | 134 | ||||
-rw-r--r-- | src/components/test-element.js | 84 | ||||
-rw-r--r-- | src/reducers/firebase.js | 12 |
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; } |