Minderva is a cobblestone in the cobbled pathway of language study. It is a tool that uses flash cards, translation, text-to-speech and motivational cues to keep you learning. I hope it helps you get to where you’re going.
Minderva was created by Dwaine Best as the final project for the Summer 2020 UCSD Extension Applied Javascript Course. It was built using React, Chakra UI, the Firebase platform, Google Translate and Google Text-to-Speech.
Focus over Features
Version 0.12 - 7.01.2022
- Security Updates
- Domain updated to minderva.io
Version 0.01, 7.20.2020, 7.21.2020:
It should display cardsIt should add to cardsIt should delete cardsIt should edit cards
Notes:
When should the form become a controlled component? Right now!Store add from values first in state and then add to card database? all controlled by state for now
Version 0.02, 7.21.2020:
Display cards split into componentAdd Card Split into componentEdit Card Split into componentDelete Card Split into componentIt should have a non-functioning Quiz component
Version 0.03, 7.21.2020, 7.22.2020:
It should have a Home - Dashboard PageIt should have an Add Cards PageIt should have a Cards Collection PageIt should have a Quiz PageIt should have a Basic User Profile PageIt should have navigation split into a separate componentIt should have a delete button next to each card in collectionIt should have an edit button next to each card in the collectionIt should go to a page to edit the card if the edit button is pressedIt should delete the card if delete is pressed
Version 0.04, 7.23.2020, 7.24.2020, 7.25.2020, 7.26.2020:
It should change from Reach Router to React Router (didn't notice that React Router is updated with features from Reach Router)It should connect to firebaseIt should add a card to the databaseIt should delete a card from the databaseIt should allow editing of a card in the databaseit should subscribe to database changes
Version 0.05, 7.26.2020, 7.27.2020, 7.28.2020:
It should pull translations from the Google APIIt should have the ability to enter a word and have it translated into another languageIt should allow you to select translate 'to' languagesIt should allow you to select translate 'from' languagesIt should have names, not just codes, for languagesIt should have the ability to save the word and translation to the firebase database
Version 0.06, 7.28.2020:
It should have a working quiz section
Version 0.07:
It should allow users to sign-up/sign-in with Google AccountIt should allow users to sign outIt shoud allow users to view their card collectionIt should allow users to add cards to their collectionIt should allow users to delete cards from their collectionIt should allow user to edit cards in their collectionIt should allow users to quiz on cards in their collection
Notes:
- Data Structure: Going for the simplest form, collection:users -> document:user -> collection:cards -> document:card
Version 0.08:
- First UX Pass:
Overall: Remove the profile that's on every page, and just put it on user profile page for nowHomepage: If user is logged in, they should get main navigation, otherwise they should only see login/signup.Navigation: A sign out link should be provided if the user is logged inDisplay Cards: Cards should be shown in a table, with edit and delete buttons beside themDisplay Cards: Rename link to Card CollectionDisplay Cards: The page should refresh if the users signs in or out.Security: Are the paths blocked if the user is logged out? ie, the add card route?Edit Card: The page should flash message on edit.Edit card: After editing, it should return to card collectionEdit card: There should be a 'back to card collection" button, or cancel buttonEdit Card: The routing bug should be fixed (Tricky! Learn about subpage. )Delete Card: A confirmation alert should pop upDelete Card: A status message should flash inAdd Card: It should flash a status message on addQuiz Page: It should show the number of cards in the quiz, and what number you are on.Quiz Page: It should show whether you are on the front or back of a cardQuiz Page: At the end of the quiz, it should show a congratulations messageQuiz Page: The cards should be reviewed in random orderUser Profile: It should show the actual user profileUser Profile: It should remove the date element, that's just the current timeOverall: It should have a 404 page.
Version 0.09: 1st Data Integrity and Security Audit Pass
Add Card, Edit Card: It should have limit on the amount of characters you can translate per card.You should disconnect from the internet and apis and see how they handle failing, this is a way to start tackling all the error handling that needs to take placeIt should have protected api keys so you can deploy it (implement through Cloud Functions)Either the front-end or the database to make sure that the front and back of the cards are not null. BOTH
Version 0.10
Add Key Feature of Audio GenerationIt should take the translated front and send it to google translateGoogle translate should return an audio fileIt should provide the correct language to synthesizeIt should save the location of the audio file to the card entryIt should appear in card reviewIt should only allow audio generation of supported voice languagesThe onUpdate function version should be removed from functions
-
Goal: Implement visual framework to create a basic, coherent experience, Using Chakra UI, and finalizie functional elements
-
Collection cards, edit screen, login screen, user profile page, add card refine, dashboard(including quotes), messages, review queue(?)
-
Then another overall functional and visual refinement pass, then send it off to chris to test, responsive, refactor, submit
-
Clean your code (no console.logs, no warnings, componentize as much as possible)
-
clean your files
-
Review notes
If you still have time:
-
Fix after discovering Bootstrap! -
404 page -
About Page -
Quotes -
Reviews tracked (reset at midnight)
-
Finish responsive design -
Check accessability
-
audio gender preference
-
manual start preference
-
Generate audio preference
-
Email sign up (extra load of ux considerations)
Visual:
- Collection - Better style on cards, play around in figma first
- Display Cards - Have delete warning come up as modal instead of alert
- Font consistancy
- How easy to add some minor animations to ease UX
- Spinners instead of Loading...
- Play audio icon...
Functional:
- Quiz - Warning modal on exit?
- Add Card - disable adding card until audio is loaded
- Add Card - What if translation or audio never loads, will it give back an error? Perhaps timeout...?
- Review - How might we implement a review queue?
- Finish out responsive design
Maybe:
- Dashboard - It should show a breakdown of cards by language, up to six pairings (this is an algo!) Time consuming. Is it worth it?
- Quiz - Integrate reverse cards (maybe wait on this?)
Collection - Cards should be sorted by date addedAdd Card - Validate front and back are entered before sending manual generate audio requestDashboard - It should have a link to add cardsDashboard - It should have a link to card collectionOverall - It should have a Login Screen that aligns with everythingOverall - What conditions should be in place if there are no cards in the collection?Overall - Pages need titles, if you look in the history, holding the back button, you'll see it all says React AppAdd/Edit card refactor, since they both contain many of the same components, work on making it easier to update both at once.Collection - On search it should say showing 2 of 30 cards, for exampleEdit Card - Start bringing in line with add card screen, maybe you can reuse many of the componentsCard Collection - have a little x to clear out searchNext Big Thing - Get add card looking just how you want it, then break it into managable parts that you can reuse in edit card.Overall - Clean up messages...see Chakra Toast (part UX too, do the messages make sense)Overall - Change faviconDo you need edit and create dates for cards? Not really, since we won't be filtering by them...Edit should go straight to manual entry
Overall - Navebar needs some attention, looks nice static, but doesn't show active link and when links are clicked, they turn as ugly darkish.Collection - It should give the full name of the languagesDashboard - It should show available cards for reviewUser Profile - Add default languagesCollection - It should look like cardsQuiz - Build out better conditional logic so you don't get the flash when you reload
Menu - User Profile and Sign Out should move to the right and go under an Account Drop Down MenuQuiz - It should show what langugage you're expected to translate to...Dashboard - It should have a link to reviews under the number of cards to reviewDashboard - It should have a memory quote placeholder
Add Card (Overall) - Capitalize language namesAdd Card - Refine UX for manual entryAdd Card - Implement storing reverse study state in databaseAdd Card - The generate audio function needs to be updated to work with audio stateAdd Card - Audio should autogenerate after translate (nice to have, tough to pull off)Add Card - Smaller icon for audio playbackAdd Card - Audio Icons should have states (not loaded, greyed out)(loading icon)(loaded, playable icon)(when front or back changes, greyed out until audio generate on translate)Add Card - Manual Entry button UX needs workOverall - It shouldn't flash the login screen when first loading up (have loading animation)v2 of Gray Box is complete, now going to try to implement in Chakra UI.Menu - It should have some indication of being on an active pageMenu - It should remove the Dashboard link and just make that the Minderva title linkQuiz - It should modal to the QuizAdd Card - It should have an option to not generate audioREMOVE REACT HELMET, find another method of titles on page (It's using an UNSAFE method!) Replaced with react-helmet-async
Notes: Fonts: Playfair,
-
Roadmap to Version 1.0:
Firebase CRUD→Basic Quiz→Basic User Functions→First UX Pass→1st Data Integrity and Security Audit Pass->Start UI framework tie-in with Chakra-> Revisit UX -> Refine Visual -> Get feedback from users and hackers -> Review and implement notes on usability, accessibility and security -
Go out and find about 25 great quotes about memory, beauty, patience, motivation. And then give them the treatment like what's on the homepage now.
-
Implement a utility that mocks api calls so you can setup loading elements correctly, see here for ideas on how to do this: https://blog.logrocket.com/how-to-create-forms-with-chakra-ui-in-react-apps/
-
Need basic card review tracking, mark cards as reviewed, then if it's past midnight on the users computer, then the reviews reset. On exit of quiz, that's when you set cards to reviewed? They can quiz themselve again if they feel like it.
-
Clean out console logs from your files
-
Add Card - what other characters could cause problems, best to check the docs (https://cloud.google.com/storage/docs/naming-objects)
-
Review useEffect in depth, the components are all calling things 4 or more times, this may have to do with how you're sending props. If you send props that are updated in state, that will trickle down and rerender them. I think...check out anti-patterns to see if one of those is causing this.
-
NPM Security Vunerability surfaced See here for solution: facebook/create-react-app#9469
-
The Google Sign in with Pop up is giving a cross-site resource warning
-
The site shouldn't try to pull in data unless a user is logged in, see error on homepage. It's trying to pull from the database without verifying that the user is logged in first...
-
Dashboard, if there are no cards, give the user an option to prefill their database with Hello World in the 10 most popular languages...
Data integrity, security and Error Handling, non critical but should be looked into when you have the time:
- Delete audio when you delete a card!
- Dashboard if you're not logged in, you get this error: Error in onSnapshot: FirebaseError: Missing or insufficient permissions. Meaning it's trying to pull from the database before verifying that a user is logged in. It should first check user, and only if user, then database functions.
- If No internet, dashboard: local server keeps trying to access firestore (UX issue, or some kind of timeout?)
- Sign Up: Cross site Error
- What other failures could there be? Trying to add, edit or delete a card and they fail for some reason, you'll want the error on that
Finished Notes:
Currently in Test Mode!The page is not refreshing on user sign in or sign outAt some point, disconnect from the internet and see how the app behaves, it needs to gracefully fail.Set a character limit in the front card, mainly so someone doesn't go an past a whole novel and burn through your Translator api limit. So, short phrases and sentences okay, anything past that, nope...If you Build, your API Keys will be exposed! Don't forget to secure them somehowgit ignore firebase.js for the time being, until I find a better way to sercure my api (this is actually acceptable, since it can only be used from select ip addressess)Router Bug - When in Edit Page, if you click card collection it goes to root/edit-card/card-collection, whereas it should just go back to root/card-collectionQuiz Bug - It doesn't stop when you reach the end of the cards, it just keeps saying loading if you click next card...DISABLED STRICT MODE Semantic UI is giving an error in strict mode. You can learn more about it and the progress on the error here: Semantic-Org/Semantic-UI-React#3819. Before deploying, I'll reenable strictmode and just accept the error for now. It should be near the top of my fix list though.No internet card collection: blank table (UX issue)No internet review cards: blank quiz, reads quiz complete (UX issue)
- Add Card - Test for focus, be aware of what you expect to happen
- User Profile - Add default gender
-
- Full feature card filtering and sorting, think of larger collections!
KEY - It should have an options to regenerate audio in the edit screenKEY - It should have a play button in the table- KEY - Reverse card study, I think this just be included as an option in the review section? -
KEY - User Profile: User should be able to select default to-from languages- User Profile - User should be able to select default voice gender
KEY - Quiz and Collection: If the card database is empty, it should say 'add a card' or that it can't connect to the database...
KEY - Edit Page: Add translation api to edit screen- KEY - Alphabatize Languages (also capitalize Chinese in tradtional Chinese)?
- KEY - - Allow users to sign-in/sign-up with other services, especially email (See FEM video starting at 31)
- KEY - Have a dummy account, so that you can share the site (you can create this in firebase directly, but you'll need to create a login page)
- Dark Mode - if you have the time...
Also, what if someone brings a japanese phrase and wants to generate its audio to study, that's where flipping the translation comes in. See main google translate for usability considerations here...- It should provide options for the user to select voice choice (maybe later), this would require more mapping, ie time consuming
- It should use the Forvo Api to add pronunciations (up to 500 a day). This will be an experimental mode for retrieving audio. The benefit is that you get audio spoken by native speakers, but it's only for single words and not so much phrases, so your hit success is limited. You could put this alongside the google generated version?
- Let the user know when internet is lost and you can't contact database
- After Quiz: See you tomorrow! Let’s schedule a review time now. (and link out to calendar)
UX - Add Card: Add a loading animation to the translate function, because it takes a second or two to fire up from cold start, then it seems to be speedier.
-
The sign in and sign up pages should be seperate
-
Add Card: It should have a little better seperation of functions (ie, translate not right next to add card) (visual pass)
-
Add Card: It should have the option to study the reverse(? maybe)
-
Add Card: Better organization of languages
-
Add Card: It should add the created date to the database (for SRS algorithm) -
Delete Card: consider flash message with undo function (like gmail undo)
-
Quiz Page: It should have better seperation of flip card from next card
-
Should it have a translate button in the edit screen?
-
It should be moved to its own github location (wait until final is graded)
-
It should have the five most popular languages up top of language selection
-
It should have the users most frequently used languages up top of language selection
-
It should give native language equivalent pronunciation guides. Start Here or with International Phonetic Alphabet (IPA) (maybe an api exists?) Also, see this
-
Can you just pass the front and back values to the edit component to prefill in the forms, instead of querying the database again for them?
-
How do I simplify all this prop passing??????!!??? (Refactoring)
-
Delete button should be in edit screen also, or only. Just thinking if the user wants to delete a slew of cards. (UX)
-
Forms validation (UX and Data Persistence)
-
Add Warning to Delete (UX)
-
Add confirmation Flashes to various actions (UX)
-
Edit should pop up as modal instead of at top of display card screen (UX)
-
Wouldn't you also add cards from the card collection screen? (UX)
-
Check out NavLink for React Router (Cole lecture) for nav styling...
-
Test speaking with speech commands...for instance, you'll see Hello World, then you speak the equivalent Spanish phrase and it tests to see how right you got it...
-
Languages listed are all out of order, etc, because of the map you're using, I would like this to be more user friendly...
-
Build your own implementation of the Google Translate API module, allowing for more robust use of its features
-
Implement SRS algorithm for quiz
-
It should pull supported languages only once per session, right now it's calling it every time the add card screen is loaded.
-
The quiz cards should be in random order...
-
It should track right and wrong answers with a fluency score
-
Take the user's google photo and apply filters to it, like outline, or flip around, or invert colors, you get it from the google user object...when they upload a photo, instead use some other photo of a goofy looking animal.
-
What kind of data do you need to have a working quiz?
-
UX, work on making things smoother, because SPAs are just so abrupt, it can be jarring...
-
Edit card: There should be a disable button
-
How do I protect users privacy from me, at the moment I can see all users cards, that is not the scenario I want. Apprently this would take end-to-end encryption, and if the user would want to sort/filter data, it would need to be done on the client side, since the database wouldn't have access to the data. Just something to consider.
-
Display Cards: User should be able to sort cards by front, back, date created, last date reviewed
-
Display Cards: User should be able to search for cards -
Add card page should have a flip to and from languages button -
Add card should have a study reverse option -
Better slow-internet connection experience...some kind of pwa, or some way to indicate loading or working...
-
It should check for duplicate cards??
-
implement Context API for better state management
-
I would like to store the available languages in the database, and only refresh them once a month with cloud functions. Otherwise just select the ones that are available now and call it good.
-
My current map of language to code is static, and causes lots of issues with name sorting, and localized names for languages, this should be addressed in a later version
Obsolete:
Roadmap: Basics → Split into Components → Routing → Firebase → Refine Functionality → Design
Current Security Rules, check against best practices. Basic idea is that a user can edit card in their cards collection:
rules_version = '2';
service cloud.firestore {
match /databases/{database}/documents {
match /users/{uid}/cards/{id} {
allow read, write, update, delete: if request.auth.uid != null && request.auth.uid == uid;
}
}
}