“One Shade At A Time” (OSAAT) is a management system website I built for SWSunControl, a company based in Arizona that builds sunshades. This system is designed to make things easier for the team by keeping everything in one place—customers, calendar events, orders, workstation processes, etc.
In March 2023, we held meetings on Microsoft Teams where we discussed the project’s goals, initial requirements, all the different tools that can be used, and how we could align our efforts in building the new system that aligns with the old one while being able to implement new features, incorporating improvements to address the already existing problems.
My role in this project was to look into the requirements and the workings of the features and build them into the new system accordingly. My work involved building the front end and back end of the whole project based on the designs that were given to me. The designs were PDF files to visually reflect how each page should look after the implementation.
We held meetings every week, usually on Tuesday noons, where I showed them a quick presentation of everything I built based on the meeting held the previous week. While I do that, my colleague, James Sullivant, would bring up any change that was necessary in the implementation based on his meetings with the project owner.
Once that was done, we discussed the how works of the old site and ended the meeting after deciding on the parts of the site that should be worked on for that week.
I would like to thank James and his team for their exceptional problem-solving skills and collaborative spirit, and I should say, that he played a crucial role in keeping everything smooth and efficient throughout the project.
During the research phase, it was decided that the project would be built on .NET, a C# web app development framework using HTML, CSS, JavaScript, and MSSQL for the backend. The old system was built using the .NET framework, and it seemed natural to stick with that. But it was not until later down the road (around 2 weeks before we started with the build) that we decided to use Django, a Python web framework along with MSSQL for the development.
The reason for this was that, after exploring all the requirements and features of the new system, it was apparent that the new system needed integration with various third-party services and provide enough security within the site (which wasn’t the best in the old system), and moving with Django seemed to me like the best option. We thought using MSSQL for Django was fine, so there was no change on that part.
The project was expected to make use of HTML, and CSS along with JavaScript for the front end. TailwindCSS was used, to give the whole thing a more responsive and robust look.
In my weekly meetings with James, I spent a fair amount of time trying to understand all the different features within the old system. Along with this, I also spent time understanding the overall workflow in sunshade manufacturing. In this post, will quickly go through everything that would be necessary to know how things work for the later parts of this series.
Like most management websites, this one starts with a login page, where you can enter your username and password if you have a user account created under your name to get into the website. There is also an option where you can hit “Forgot password” and receive the password reset link mailed to your email. Once you get in, depending on the type of user you are, you see two different dashboards.
Firstly, if you are a Dealer User, you will see the buttons linked to pages that allow you to get into the Dealer resources (A directory of all the pdf files that explain the products available for manufacturing), order entry, orders list, and so on.
If you are an Admin User, you will see the buttons linked to pages that allow you admin access depending on the permissions set for you. Meaning, that you could be a staff responsible for creating and keeping track of customers, in this case, you will see “Add Customer” on your dashboard, but not “Calendars“.
Among admin users, you have internal staff and main admins, depending on which you will be able to access the Django Administration Page, but that access is only granted to a handful of people.
This page will be accessible based on the customer’s unique code (which would be a mandatory unique 13-lettered alphanumeric code for each customer). A customer’s unique code would be the first 3 letters of their last name followed by their phone number. Within this page, you will see 4 tabs containing information related to the customer, which an admin user can view/change.
The Info tab contains all the details about the customer, along with a button that pops up a frame that allows the admin to schedule a visit based on the type of visit (Technician, or Sales).
The Gallery tab contains all images related to the customer, usually the ones that were uploaded into the timeline. The Timeline tab is a section where the admins communicate by posting issues or statuses.
Finally, the Orders tab is a frame that is connected to a Wasabi-hosted bucket with all the folders named as the order’s job number under a folder named as the customer’s unique code, within each, you will see the Confirmation pdf named based on the order’s job number (a unique 7 digit number given to all finalized Orders), for every order that was placed for/by that customer. For example, if the customer with a unique code CUS1234567890 placed an order with the job number 1000012, you will see a folder structure like CUS1234567890/1000012/1000012_Order_Confirmation.pdf
Every time a customer wants to place an order (or sometimes, when an admin wants to place an order for a customer without a user account) they get into this page where they can go through the processes to place the order. We will get into the details of how units and orders come together, but for now, think of it as an order containing multiple units, and each unit is sort of like its own product, all shipped under a single order.
Once you enter all the details, you will be taken to the respective pages based on where you are in the order entry process, and in the end, you end up with an Order Info Page that contains all the details about the particular order. Based on where you are in the order entry process, your order will be editable, or locked. The order summary page shows the total cost based on the products and their measurements that were selected on the Order Wizard page. The process is a bit different when you enter as an admin placing the order for the dealer(customer), compared to if you were the dealer placing the order for yourself. But in the end, it’s where you create an order, add units to it, and save it for the customer, all signed and finalized. The how works might be a bit confusing, but everything is covered in the post where I explain from scratch how I built the order entry feature into the website.
When we talked about the customer’s page, we also discussed the schedule button and its functions. Every time a customer schedules a visit, they create an event (either Technician or Sales) and the event is linked to a job number(Order). There is also a third type of visit that can only be created by the admins, called a Delivery Event. Administrators assign technician and sales events to certain crews, which also appear on the event details with a filter option. Each of these event types is displayed in 3 calendars – Technician, Sales, and Delivery, depending on their type.
The calendar page is only accessible to those internal staff users that have permission. Events can be edited using the pen icon on the right, which pulls out a movable popup window. Events can be deleted using the trash icon on the left of each event. Confirmed events have a little green checked icon on the top right corner, the colour of the event div depends on the type of visit (Installation, Warranty Service and so on).
The production workstation is a crucial part of the system, and it is where production workers can keep track of their work in sunshade manufacturing. The reason why these pages are on the portrait is because they are used on a large portrait screen inside a room, where the employees can collectively work and check/uncheck work items.
To get into a workstation job (orders that are released for production by the admins), you would have to click the button to get into the appropriate workstation. Then you would need to enter the job number of the order you want to open the workstation job for. This will take you to the workstation page for the job you entered.
On most workstations, you have tabs that show certain buttons depending on the tab you are on. Each button represents a work that needs to be done to complete the job (sort of like a to-do list). These buttons have values based on the measurements and product type that were entered when placing the order. By default, these work items are incomplete (represented by an orange border with grey text). When you click on a button, they are marked complete (represented by a solid green background and white text). Once you mark all the work items in a tab as complete, the whole tab turns from orange-bordered to a green background. On the bottom, there are 2 buttons. The “Save and Close” button would save everything and take you back to the dashboard. The “Complete” button would mark the whole job as complete, and all the work inside the job would be considered completed.
UI-wise they all look similar to the third image above. There are 8 types of workstation pages, most of them similar to each other, and some of them quite different.
Lastly, a feature that works along with the calendars we looked at previously, is the map navigations for Technician and Sales Visits. Every time an event is added to the calendar, it appears on the “My Visits” schedule page for the appropriate crew number. The “My Schedule” page allows the crew user to select their crew number to get into the page that shows their visits. Here, they will see the events that were scheduled previously as a Visit Job. They also have an option to expand and navigate to any date, in case they have to search for a very old job. Clicking on a job redirects them to the Technician/Sales job’s map navigation page.
This page uses Google’s map API to show the directions from the crew user’s current location to the address given when scheduling the visit (customer’s address). The page also displays the very next step as text. Each visit job has a boolean status that indicates if the crew is at the site or left it. This page allows them to toggle this status based on where they are and what they are doing. The crew member has the option to complete the job. In case they run into a situation, say, the visit specified some problem with the shade and the crew member who got there realises there is a problem with the motor and now they need to go back to bring the necessary tools. This is a pretty common scenario, and in such cases, the crew member can mark the job as incomplete and add the appointment note that specifies what is needed and submit it, so it can be sorted out during their next visit.
There is also one additional feature that was planned to be built, but it hasn’t really taken a proper shape in terms of design and implementation. This is the analytics page, and due to the fact that the organisation isn’t in immediate need of this to be implemented into their new system, it is still under planning. But in case this was decided to be built, that would be another interesting challenge to be tackled, and I will be sure to write a post about that too.
The whole project has taken around 8-9 months, which includes meetings, domain research, site development, testing and changes. As of today, the project is approaching completion, which just minor changes and testings left to be done. In the upcoming articles (the 7 other parts of the project series), I will go through each of these features in detail, along with all the challenges I had to face and how I approached the problems. The links for the ones I’m done with are down below.
Welcome to the third part of the eight-part series documented on the web app project…
For those of you who are new to stocks and investing, you might be wondering…
Introduction Explainable AI, or XAI, as the name suggests, is a tool that can be…
Startup failure can be really painful for the team that put so much work into…
You might be wondering why anyone would bring up the mechanics of the Mafia as…