Difference between revisions of "IS480 Team wiki: 2015T2 Tinkers MidTermWiki"
(33 intermediate revisions by 3 users not shown) | |||
Line 51: | Line 51: | ||
==Project Progress Summary== | ==Project Progress Summary== | ||
− | * | + | *View our Midterm slides [[Media:Tinkers_Midterm_Final.pdf |here]] |
*View our deployed application in Google Play:[https://play.google.com/store/apps/details?id=com.ionicframework.pytracker944743&hl=en Platinum Yoga] | *View our deployed application in Google Play:[https://play.google.com/store/apps/details?id=com.ionicframework.pytracker944743&hl=en Platinum Yoga] | ||
Line 60: | Line 60: | ||
**1 feature was removed (Lucky Draw System due to incompatibility with the MindBodyOnline internal point system) | **1 feature was removed (Lucky Draw System due to incompatibility with the MindBodyOnline internal point system) | ||
**2 features were renamed (Events to Special Events, Yoga Pose-Tree to Yogapedia) | **2 features were renamed (Events to Special Events, Yoga Pose-Tree to Yogapedia) | ||
− | *Completed a user testing with | + | *Completed a user testing with 10 Platinum Yoga students |
*Steep learning curve for front-end technologies (Ionic platform, Angular JS) | *Steep learning curve for front-end technologies (Ionic platform, Angular JS) | ||
*Postpone the deployment of iOS app in Apple store | *Postpone the deployment of iOS app in Apple store | ||
Line 82: | Line 82: | ||
===Milestones Remaining:=== | ===Milestones Remaining:=== | ||
− | |||
* User Test 2 | * User Test 2 | ||
* Poster Submission | * Poster Submission | ||
− | |||
* Final Presentation | * Final Presentation | ||
* Poster Day | * Poster Day | ||
Line 336: | Line 334: | ||
|| View Contact Us | || View Contact Us | ||
+ | *<span style="color:#33ee88"><b>NEW module</b></span> | ||
|| Fully deployed and tested 100% | || Fully deployed and tested 100% | ||
|align="center"| 1 | |align="center"| 1 | ||
Line 350: | Line 349: | ||
|| Special Events Module | || Special Events Module | ||
+ | *<span style="color:#33ee88"><b>NEW module</b></span> | ||
|| View Special Events | || View Special Events | ||
|| Fully deployed and tested 100% | || Fully deployed and tested 100% | ||
Line 357: | Line 357: | ||
|| PY Privileges Module | || PY Privileges Module | ||
− | || View PY Privileges | + | *<span style="color:#33ee88"><b>NEW module</b></span> |
+ | || View PY Privileges | ||
|| Fully deployed and tested 100% | || Fully deployed and tested 100% | ||
|align="center"| 1 | |align="center"| 1 | ||
Line 401: | Line 402: | ||
|| Yogapedia Analytics Management | || Yogapedia Analytics Management | ||
− | *database | + | *database |
+ | *<span style="color:#33ee88"><b>NEW module</b></span> | ||
|| To be completed in iteration 7 | || To be completed in iteration 7 | ||
|align="center"| 0.5 | |align="center"| 0.5 | ||
Line 501: | Line 503: | ||
====Actual Schedule==== | ====Actual Schedule==== | ||
− | [[Image:Tinkers | + | [[Image:Tinkers midterm repost.PNG|850px|Left|Tinkers Goals]] |
===Schedule Comparison=== | ===Schedule Comparison=== | ||
Line 527: | Line 529: | ||
===Project Metrics:=== | ===Project Metrics:=== | ||
− | + | ====Schedule Metrics==== | |
+ | |||
+ | [[File:TinkersScheduleMetrics.jpeg]] | ||
+ | |||
+ | ====Bug Metrics==== | ||
+ | |||
+ | [[File:TinkersBugMetrics.jpeg]] | ||
===Future Project Risks:=== | ===Future Project Risks:=== | ||
Line 560: | Line 568: | ||
===Technical Complexity:=== | ===Technical Complexity:=== | ||
+ | |||
+ | ====Using MindbodyOnline API==== | ||
+ | |||
+ | [[Image:Mindbodyonline complex2.jpg|center|500px]] | ||
+ | <br/> | ||
+ | [[Image:Mindbodyonline complex1.jpg|center|700px]] | ||
+ | *As we cannot directly send requests from our mobile application to the MindBodyOnline API, we need to use a web server and php scripts to act as a middleman to do that | ||
+ | *Soap Client function in the php is used to communicate with the MindBodyOnline API | ||
+ | |||
+ | |||
+ | [[Image:MindBodyOnline complexity.JPG|center|500px]] | ||
+ | *The execute tag is not in the documentation. Have to trial and error to work with the API. | ||
+ | *Mindbody also took quite some time to reply which slowed down our development. | ||
+ | |||
====Ionic Platform:==== | ====Ionic Platform:==== | ||
[[Image:Learning the tricks of Ionic Framework updated.jpg|center|700px]] | [[Image:Learning the tricks of Ionic Framework updated.jpg|center|700px]] | ||
[[Image:Slide2.JPG|center|700px]] | [[Image:Slide2.JPG|center|700px]] | ||
− | |||
− | |||
*Learning Ionic Platform as front-end for our project | *Learning Ionic Platform as front-end for our project | ||
Line 582: | Line 602: | ||
<b>Changes Made to Implement Phonegap Plugins for Ionic Project:</b> | <b>Changes Made to Implement Phonegap Plugins for Ionic Project:</b> | ||
[[Image:New config.JPG|center|500px]] | [[Image:New config.JPG|center|500px]] | ||
− | |||
<b>Phonegap Plugins used:</b> | <b>Phonegap Plugins used:</b> | ||
[[Image:Phonegap plugins.JPG|center|500px]] | [[Image:Phonegap plugins.JPG|center|500px]] | ||
<br/> | <br/> | ||
+ | |||
+ | ====Displaying Images in Firebase ==== | ||
+ | <b>Adding a particular pose for Yogapedia on the portal:</b> | ||
+ | [[Image:Yoga1.png|center|500px]] | ||
+ | <b>Retrieving the picture from Firebase (HTML Codes):</b> | ||
+ | [[Image:Yoga2.png|center|1000px]] | ||
+ | <b>Firebase Structure:</b> | ||
+ | [[Image:Yoga3.png|center|500px]] | ||
+ | *Firebase has limitation in uploading images and photos | ||
+ | *Backend developer conducted intensive research and trial & error using different alternatives to insert images into Firebase | ||
+ | *Base64 decoder was chosen to encode and decode images using text (compatible with Firebase) | ||
==Quality of product== | ==Quality of product== | ||
− | |||
− | |||
===Intermediate Deliverables:=== | ===Intermediate Deliverables:=== | ||
− | |||
− | |||
{| border="1" cellpadding="4" cellspacing="0" | {| border="1" cellpadding="4" cellspacing="0" | ||
Line 609: | Line 635: | ||
|| Metrics | || Metrics | ||
− | || | + | || [https://wiki.smu.edu.sg/is480/IS480_Team_wiki%3A_2015T2_Tinkers_Metrics Metrics] |
|- | |- | ||
|| Requirements | || Requirements | ||
− | || | + | || Storyboard & Motivation |
− | || [ | + | || [https://wiki.smu.edu.sg/is480/IS480_Team_wiki%3A_2015T2_Tinkers_Project_Motivation Storyboard & Motivation] |
|- | |- | ||
− | |rowspan=" | + | |rowspan="2"| Analysis |
|| Use case | || Use case | ||
− | || [https://wiki.smu.edu.sg/is480/IS480_Team_wiki%3A_2015T2_Tinkers_Project_Documentation Use Case | + | || [https://wiki.smu.edu.sg/is480/IS480_Team_wiki%3A_2015T2_Tinkers_Project_Documentation Use Case] |
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
|- | |- | ||
− | | | + | || Architectural Diagram |
− | || [ | + | || [https://wiki.smu.edu.sg/is480/IS480_Team_wiki%3A_2015T2_Tinkers_Project_Documentation Architectural Diagram] |
− | |||
|- | |- | ||
− | || | + | |rowspan="1"| Design |
− | || [ | + | || UI Prototype |
+ | || [[Media:Platinum Yoga Application Mockup UI.pdf | Mockups]] | ||
|- | |- | ||
− | |||
|| Testing | || Testing | ||
|| User test plan | || User test plan | ||
− | || [ | + | || [https://wiki.smu.edu.sg/is480/IS480_Team_wiki%3A_2015T2_Tinkers_Documentation_Usability_Test Testing] |
|} | |} | ||
− | |||
− | |||
===Deployment:=== | ===Deployment:=== | ||
Line 656: | Line 667: | ||
===Testing:=== | ===Testing:=== | ||
− | |||
− | |||
− | |||
{| border="1" cellpadding="4" cellspacing="0" | {| border="1" cellpadding="4" cellspacing="0" | ||
Line 670: | Line 678: | ||
|align="center"| User Test 1 <br/> (Existing Platinum Yoga users) | |align="center"| User Test 1 <br/> (Existing Platinum Yoga users) | ||
− | |align="center"| | + | |align="center"| 30th January 2015 |
|| | || | ||
− | * | + | *Allow users to try browsing & booking classes using the phone app |
− | * | + | *Receive feedback about the app’s UI |
− | + | *Receive feedback about what the users would like to see in the app | |
− | |||
− | |||
− | |align="center"| | + | |align="center"| 10 |
− | |align="center"| | + | |align="center"| [https://wiki.smu.edu.sg/is480/IS480_Team_wiki%3A_2015T2_Tinkers_Documentation_User_Testing1 User Test 1] |
− | |||
− | |||
− | |||
− | |||
− | |||
|- | |- | ||
Line 694: | Line 695: | ||
===Team Reflection:=== | ===Team Reflection:=== | ||
− | Over the past few months, our team | + | Over the past few months, our team have learnt that preparation, good communication and proper work delegation are the three essential pillars for any project to be managed well and succeed. Whenever we are in doubts, we always clarify them with each other or the client to ensure that the project is executed properly and proceeds in the right direction. We have also embraced learning to learn, a core learning outcome for many courses in SIS, as we learn new skills while doing the project. |
===Managing Client's Expectations:=== | ===Managing Client's Expectations:=== | ||
While working closely with our stakeholders, we have learnt that clear communication with our client and sponsor is very important to the success of the project especially when we are gathering all the necessary requirements for the project. Complex technical details are explained in simpler terms to our client to help him understand the project better and be part of the project. We also learn about negotiating and bringing the gap of customer's expectation and concerns and the team's technical ability. This is a very important skill for us as we aim to maintain a good relationship with our clients and deliver as much as we can with the limited resources we have. | While working closely with our stakeholders, we have learnt that clear communication with our client and sponsor is very important to the success of the project especially when we are gathering all the necessary requirements for the project. Complex technical details are explained in simpler terms to our client to help him understand the project better and be part of the project. We also learn about negotiating and bringing the gap of customer's expectation and concerns and the team's technical ability. This is a very important skill for us as we aim to maintain a good relationship with our clients and deliver as much as we can with the limited resources we have. |
Latest revision as of 17:16, 2 April 2015
Main Wiki | Midterm Wiki | Final Wiki |
______________________________________________________________________________________________________________________________________________
Contents
Project Progress Summary
- View our Midterm slides here
- View our deployed application in Google Play:Platinum Yoga
Project Highlights:
- Scope of the project has been updated:
- 5 features were added (Retreats/TT, Analytics for Yogapedia, Promotions, PY Privileges, Contact us)
- 1 feature was removed (Lucky Draw System due to incompatibility with the MindBodyOnline internal point system)
- 2 features were renamed (Events to Special Events, Yoga Pose-Tree to Yogapedia)
- Completed a user testing with 10 Platinum Yoga students
- Steep learning curve for front-end technologies (Ionic platform, Angular JS)
- Postpone the deployment of iOS app in Apple store
- Team decided to postpone the deployment of iOS app due to resource and time constraints after being advised by Supervisor (Chris Boesh) and discussing with our client.
- Client agreed with this as the review and testing process for iOS application is different than Android
- Client and team agreed to deploy a stable Android application first before releasing an iOS after poster day where he will provide the resources needed to deploy iOS application
- Mid-terms goals have been updated after discussion with client to a more realistic one(see images below)
Previous Goals
Updated Goals
Milestones Completed:
- Proposal Submission
- Acceptance Presentation
- User Test 1
- Release 1
Milestones Remaining:
- User Test 2
- Poster Submission
- Final Presentation
- Poster Day
Project Management
Project Status:
Module | Functionality | Status | Confident Level (0-1) | Comment |
User Account Module | Login/Logout | Fully deployed and tested 100% | 1 | David |
Auto login after 1st successful login | Fully deployed and tested 100% | 1 | David & Ricky | |
Register | Fully deployed and tested 100% | 1 | Hosanna | |
Edit Profile | Fully deployed and tested 100% | 1 | David & Ricky | |
Attendance Checking (barcode) | Fully deployed and tested 100% | 1 | Hosanna | |
View User's Schedule | Fully deployed and tested 100% | 1 | David & Ricky | |
Class Module | Browse Classes | Fully deployed and tested 100% | 1 | Hosanna & Ricky |
Book Classes | Fully deployed and tested 100% | 1 | David & Ricky | |
View Instructor's Information | Fully deployed and tested 100% | 1 | David & Ricky | |
Filter Classes | Fully deployed and tested 100% | 1 | Hosanna & Ricky | |
Waiting List | Fully deployed and tested 100% | 1 | David & Ricky | |
Pull to Refresh | Fully deployed and tested 100% | 1 | Hosanna | |
Workshop Module
|
Browse Workshops/Challenges | Fully deployed and tested 100% | 1 | Hosanna & Ricky |
Book Workshops/Challenges | Fully deployed and tested 100% | 1 | David & Ricky | |
View Instructor's Information | Fully deployed and tested 100% | 1 | David & Ricky | |
Filter Workshops/Challenges | Fully deployed and tested 100% | 1 | Hosanna & Ricky | |
Waiting List | Fully deployed and tested 100% | 1 | David & Ricky | |
Pull to Refresh | Fully deployed and tested 100% | 1 | Hosanna | |
Retreats/TT Module
|
Browse Retreats/TT | Fully deployed and tested 100% | 1 | Hosanna & Ricky |
Book Retreats/TT | Fully deployed and tested 100% | 1 | David & Ricky | |
View Instructor's Information | Fully deployed and tested 100% | 1 | David & Ricky | |
Filter Retreats/TT | Fully deployed and tested 100% | 1 | Hosanna & Ricky | |
Waiting List | Fully deployed and tested 100% | 1 | David & Ricky | |
Pull to Refresh | Fully deployed and tested 100% | 1 | Hosanna | |
Appointment Module | View Categories | Fully deployed and tested 100% | 1 | Hosanna & Ricky |
View Instructors | Fully deployed and tested 100% | 1 | Hosanna & Ricky | |
View Available Timeslots | Fully deployed and tested 100% | 1 | David & Ricky | |
Book Appointments | Fully deployed and tested 100% | 1 | David & Ricky | |
History Module | View Past Bookings | Fully deployed and tested 100% | 1 | David & Ricky |
View Past Purchases | Fully deployed and tested 100% | 1 | Hosanna & Ricky | |
Review Module | Write Reviews for Classes
|
Fully deployed and tested 100% | 1 | David & Johnathan |
Rate Classes
|
Fully deployed and tested 100% | 1 | David & Johnathan | |
Display Reviews for Classes
|
Fully deployed and tested 100% | 1 | Hosanna & Johnathan | |
View Health Tips
|
Fully deployed and tested 100% | 1 | Hosanna & Johnathan | |
FAQ Module | View Information/Etiquette
|
Fully deployed and tested 100% | 1 | David & Johnathan |
View About | Fully deployed and tested 100% | 1 | Hosanna | |
View Contact Us
|
Fully deployed and tested 100% | 1 | Hosanna | |
Promotions Module
|
View Promotions | Fully deployed and tested 100% | 1 | David |
Special Events Module
|
View Special Events | Fully deployed and tested 100% | 1 | Hosanna |
PY Privileges Module
|
View PY Privileges | Fully deployed and tested 100% | 1 | Hosanna |
Hall of Fame Module | Display Winners
|
Fully deployed and tested 100% | 1 | David & Johnathan |
Admin Portal | User Reviews Management
|
Fully deployed and tested 100% | 1 | David & Johnathan |
Hall of Fame Management
|
Fully deployed and tested 100% | 1 | David & Johnathan | |
Information & Etiquette Management
|
Fully deployed and tested 100% | 1 | Hosanna & Johnathan | |
Health Tips Management
|
Fully deployed and tested 100% | 1 | Hosanna & Johnathan | |
Yogapedia Analytics Management
|
To be completed in iteration 7 | 0.5 | David & Johnathan | |
Yogapedia Module | View Poses under Different Categories
|
To be completed in iteration 7 | 0.5 | Hosanna & Johnathan |
Record User's progress
|
To be completed in iteration 7 | 0.5 | David & Johnathan | |
Notification Module | Push Out Events | To be completed in iteration 7 | 0.5 | David & Ricky |
Push Out Reminders | To be completed in iteration 7 | 0.5 | David & Ricky | |
Social Media Module | Share Upcoming Classes | To be completed in iteration 7 | 0.5 | Hosanna & Johnathan |
Module(s) removed:
Module | Functionality | Status | Confident Level (0-1) | Comment |
Event Module
|
Browse Events | Completed | 1 | Hosanna & Ricky |
Book Events | Completed | 1 | David & Ricky | |
View Instructor's Information | Completed | 1 | David & Ricky | |
Filter Events | Completed | 1 | Hosanna & Ricky | |
Waiting List | Completed | 1 | David & Ricky | |
Pull to Refresh | Completed | 1 | Hosanna & Ricky |
Project Schedule (Plan Vs Actual):
Planned Schedule
Actual Schedule
Schedule Comparison
Changes in scope:
Details of the changes made:
- Primary
- Client informed us to rename "Events" to "Special Events"
- Events module is changed to "Special Events" module which will redirect to Platinum Yoga's Special Events page
- Booking and filtering of "Retreats/TT" (TT stands for teacher training) has been added
- Secondary
- "Lucky Draw System" has been removed as MindBodyOnline API adds points to users' accounts internally automatically for referrals and there is no way for us to add points to users' accounts using the API. Furthermore, client find it a hassle if he has to manage 2 point systems.
- "Yoga Pose-Tree" is renamed to "Yogapedia"
- New module "Analytics for Yogapedia" has been added
- Waiting list for events is removed as of events module is changed to "Special Events" module
- Waiting list now shows "Retreats/TT"
- Tertiary
- "FAQ" is renamed to "Info/Etiquette"
- "Promotions", "PY Privileges" and "Contact us" has been added
Project Metrics:
Schedule Metrics
Bug Metrics
Future Project Risks:
Our Top 3 Risks:
Risk | Probability | Impact | Mitigation |
Problems encountered from third party vendor (MindBodyOnline) & unclear API instruction | Medium | High | Run frequent testing and alert MindBodyOnline immediately. Readjust project schedule to ensure that other tasks can be done while waiting for replies or MindBodyOnline to resolve the issue. |
Updates in scope from client | Medium | High | Establish a standard which is agreeable for client and readjust schedule and resources to attempt to deliver what the client needs. Establish constant communication with client to keep him in the development loop. |
With the usage of new technologies, we may run into trouble implementing certain complex functionality | Medium | Medium | Research and allocate more time for technology familiarization and consider alternative. |
Technical Complexity:
Using MindbodyOnline API
- As we cannot directly send requests from our mobile application to the MindBodyOnline API, we need to use a web server and php scripts to act as a middleman to do that
- Soap Client function in the php is used to communicate with the MindBodyOnline API
- The execute tag is not in the documentation. Have to trial and error to work with the API.
- Mindbody also took quite some time to reply which slowed down our development.
Ionic Platform:
- Learning Ionic Platform as front-end for our project
- Mastering the 2 way data binding (from front to back and vice versa)
- (first picture) Ionic method is called from the front-end to pass data to the controller which then passes the data to the factory before the data gets transferred to the MindBodyOnline API.
- (second picture)Data is retrieved using server from the MindBodyOnline API within the factory. Controller then use the same factory to get the data before iterating it through from the front.
- Loading Time Issues
- Developers realised that data from API need to be retrieved earlier in the factories (call these factories earlier), before pulling them from the controllers. This will enable the data to display on time if not the information will only show up after a longer time.
Using Phonegap Plugins for Ionic Project
- Developer has experience using Phonegap Build service to deploy Android application, however, support for deploying Ionic applications using Phonegap plugins on Phonegap Build service is limited
- Need to understand how to use Phonegap Plugins(eg. opening browser) work for Ionic projects.
Default Ionic Project config.xml Configurations:
Changes Made to Implement Phonegap Plugins for Ionic Project:
Phonegap Plugins used:
Displaying Images in Firebase
Adding a particular pose for Yogapedia on the portal:
Retrieving the picture from Firebase (HTML Codes):
Firebase Structure:
- Firebase has limitation in uploading images and photos
- Backend developer conducted intensive research and trial & error using different alternatives to insert images into Firebase
- Base64 decoder was chosen to encode and decode images using text (compatible with Firebase)
Quality of product
Intermediate Deliverables:
Stage | Specification | Modules |
Project Management | Minutes | Minutes |
Metrics | Metrics | |
Requirements | Storyboard & Motivation | Storyboard & Motivation |
Analysis | Use case | Use Case |
Architectural Diagram | Architectural Diagram | |
Design | UI Prototype | Mockups |
Testing | User test plan | Testing |
Deployment:
View our deployed application in Google Play:Platinum Yoga
Testing:
User Test | Date of User Test | Objectives | No of Participants | Link |
User Test 1 (Existing Platinum Yoga users) |
30th January 2015 |
|
10 | User Test 1 |
Reflection
Team Reflection:
Over the past few months, our team have learnt that preparation, good communication and proper work delegation are the three essential pillars for any project to be managed well and succeed. Whenever we are in doubts, we always clarify them with each other or the client to ensure that the project is executed properly and proceeds in the right direction. We have also embraced learning to learn, a core learning outcome for many courses in SIS, as we learn new skills while doing the project.
Managing Client's Expectations:
While working closely with our stakeholders, we have learnt that clear communication with our client and sponsor is very important to the success of the project especially when we are gathering all the necessary requirements for the project. Complex technical details are explained in simpler terms to our client to help him understand the project better and be part of the project. We also learn about negotiating and bringing the gap of customer's expectation and concerns and the team's technical ability. This is a very important skill for us as we aim to maintain a good relationship with our clients and deliver as much as we can with the limited resources we have.