Giter VIP home page Giter VIP logo

project_basket_players's Introduction

My Basketball Player's All-Time Wish List

Basketball is a 5*5 team-spirit worldwide known sport. All players have different individual attributes relative to the position they play, whether this could be the height (i.e. being a guard vs center) or skills (ex. scoring lots of points, making lots of rebounds etc). As generations pass, players across all continents change but some remain memorable for you even if they do not play currently. In addition, one would in some place (ex. whether on street or to a coffee place) be able to meet/see them, spend time and both sides share knowledge, ideas and emotions. The site provides you to insert your players, the top three disciplines on each one you admire and how much virtually one would spend relative to the place you choose (brunch, coffee, street) to see your top five favorites.

UX

  • The strategy plane: Aim to achieve a website about Basketball sport. Target audience :

    • People surrounded by the sport business and those who enjoy playing and/or watching the sport.
  • The scope plane:

    • Features :
      • A SignUp / Login / Logout Form
      • Add Player Form - Edit / Delete Player Form
      • List Summary Charts and Table Information of your players
  • The structure plane:

    • Info is structured in a standard way. First page are input fields and buttons to SignUp - Login/Logout to your account.
    • A Show List Summary and Add Player button
    • Two aspects (piechart, barcharts and table). Grouped displayed first (birth region and virtual spend charts), displayed second (table players whole summary) accompanied by an edit/delete individual player button
  • The skeleton plane:

    • Page info represented from left to right (or top to bottom) concept :
      • Minimal header text written with lots of indicative icons, option and select lists.
      • Five buttons (SignUp, Login/Logout, show players, add a player, edit/deleting a player)
      • Two d3.js graphs (pie chart, horizontal bar chart)
      • One Horizontal and vertical auto scrollable table
  • The surface plane:

    • Colours : darker navbar and fixed background image. Show brightness in input fields (for ex. radio buttons circle stroke in light blue to contrast). Linear-gradient for td "spark lines".
    • Semantic : header, nav, section, form, materialize (row, column grid, color, buttons), i tags
    • Typography : roboto google font and materialize libraries like table highlight class to demonstrate description. Material icons to highlight the input field meaning.
    • Jinja helper to loop through html objects and also to pass info to JS. JS and JQuery for materialize js, show players existence and actions when document is loaded, graph creation and table scrolling. Python for Backend-in-the-frontend.
User Stories list:
  • As a developer :

    • I insert a summary table of existing players so that I can achieve
      • scrolling for responsive design
      • edit button at the end of each row per player, to easily adjust values to obtain user flexibility
    • Main two chart types (barchart and piechart) and attributes (birth region and virtual spend) chosen are distinct to achieve diversity
    • Modal insert on edit and delete player to achieve a cross-check decision.
    • Enabled caption Choose Discipline on Edit Player form select, to achieve a user being flexible to reset his decision to null and/or decide later. Adding an NA row at the select list on this occasion could cause disruption.
  • As a user :

    • Having several players registered, I would like the top five players willing to spend more to meet in person, to be displayed on a chart above my table.
    • On Player forms, since there are several fields, I like the idea of having less fields to insert text/number and having more fields to choose from a list.
    • As the rating is ranged from 1 to 10 on disciplines and 1 to 20 on virtual times, I like the idea of beeing able to insert a decimal and distinct any close preference among disciplines, virtuals and players.

A mockup frame of the website, one could find it at the attached pdf file at the directory mockup_frame. noSQL schema on page 1 and 2 inside the pdf file.

Features

Existing Features

  • Above mentioned on the structure and skeleton plane

Additional plans to be implemented in the future would be :

  • Login Form EmailJS forgot password.
  • Horizontal bar chart group by player's position also rather than existing overall.
  • Make deleting a player more flexible rather than having to go to the edit player to achieve it.
  • Insert table pagination, displaying fifteen players per page.
  • More python data scientific
    • Insert a text area field for a guest to comment per individual player, if interested. Extract most common words with various players and plot categorical charts.
    • Make virtual spend calculation more algorithmic and use category birth region, discipline and virtual spend fo anything regressed or classified.

Features Left to Implement

  • Reorder the Table Summary for name to be at the first column and in absolute position. Therefore when one scrolls horizontally, it has a clearer picture of the focused player. Currently the row is highlighted in beight green and is a helper.
  • Add a category list for people to be able to add more favorite disciplines from the already existing ones.
  • Highlight number percentage when hovering on each arc at the pie chart, possibility of two decimal points on rating and virtual times at player forms (currently fits a decimal).

Technologies Used

  • Flask Python

    • The project uses Flask Python and Jinja for web development.
  • [HTML5]

    • The project uses HTML5 to structure the webpages.
  • CSS3

    • The project uses CSS3 to style the webpages.
  • Materialize CSS JS

    • The project uses Materialize CSS JS 0.100.2 to create navigation bar, forms, styles, text and display classes.
  • Material Icons

    • The project uses Material Icons to insert icons for a user friendly visualisation and navigation.
  • MongoDB

    • The project uses MongoDB to archive guest account players data.
  • JQuery

    • The project uses JQuery to enable interactivity of slider and dropdown buttons.
  • D3 JS

    • The project uses D3 JS for charts, data type, formats, selecting elements and functions.

Testing

  • Used Python unittest module framework to test :
    • flask insert_login view succesfully signed up, logged in and logout
    • custom functions for checking input fields (check values are correct and adjust) and select columns (for no duplicated selections and inserting defaults if intentional field(s) are empty)
    • Name field inserted is a single one rather than two (First Name, Surname), thus we test assumptions of a user entering the name by either inserting only the surname or inserting both name and surname.
      • A sub function is to check the MongoDB whether a current Name field written the same way it exists or not with max having one spelling error

Encountered issues:

  • python to js transfer data, ensuring that will account for all records listed
  • d3.js chart and labels orientation
  • Dealing with horizontal-vertical table scrolling and adjust to its window size

Deployment

I deployed the project on Heroku.

Worked on Google Chrome and Safari Version.

One could run locally by executing the app.py file and retrieve the URL to login.

Credits

Content

  • The minimal text content is self-inspired.

Media

  • The background_img photo in this section was obtained from clipart.

Acknowledgements

  • I received inspiration for this project from networking apps (i.e. make a wish) and myself having a passion for sports and basketball.

project_basket_players's People

Contributors

feddieminas avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.