Jun 23 2024 11:36 PM
I have a design question, more so than coding:
I am trying to think of a way to create a timesheet in SharePoint lists that runs concurrently with someone in the field, while they are working, to capture their work hours with the following aspects: (I think these are essentially list column headers?)
I have started to build some lists which do kind of work, but I am not sure how to get the time stamp and new rows to generate?
Jun 24 2024 03:36 AM
@RShehan yes you would want a series of date/time columns to record each timestamp. But to make it easier for the worker to complete I would build a mobile app in Power Apps that saves the press of each button into the SharePoint list and in the app there would be a gallery showing all the worker's timesheets (or timesheets not yet marked as complete). The OnSelect property of each button would use the Now() function which records the current date & time in the user's local timezone.
There are quite a few videos on YouTube around creating Power Apps timesheet apps. There's also a series of blog posts by Matthew Devaney at https://www.matthewdevaney.com/make-a-power-apps-timesheets-app-part-1/
Or come back here if you have specific questions or would like a quick & dirty mockup of how it would work.
Rob
Los Gallardos
Microsoft Power Automate Community Super User.
Principal Consultant, SharePoint and Power Platform WSP Global (and classic 1967 Morris Traveller driver)
Jun 24 2024 04:00 PM - edited Jun 24 2024 04:23 PM
@Rob_Elliott I have this as my current header, which I don't believe will work, but need to start somewhere:
Hoping for each shift to complete a new row under the headings, with multiple start and stop times within each shift. The list entry won't be directly visible to the end user, only the app or form. I am thinking some kind of power BI output for the end user view.
Would each login be an individual list?
There will be thousands of these entries per year (hundreds per user and 50+ users), all of which will be retained as a permanent record of the times. Currently this is done on paper, which is an admin nightmare.
I imagine this will take some considerable time to design and test, if it actually works in the long run.
The idea is to use the existing power of SharePoint/lists/built in functions to capture this data, which essentially ends up in a database like this anyway, so it can be monitored 24/7 online, and be audited in the future.
Is there some kind of offline capability with SharePoint on a local device? The end users are mostly using a mobile device/cell phone.
If I explained the process flow from the users perspective, would that assist with the design?
Jun 25 2024 03:52 AM
@RShehan through list permissions you could allow the end user to see only the entries they created and not the others.
"I am thinking some kind of power BI output for the end user view." No, I recommend you use Power Apps for the front end with the SharePoint list as the backend.
"Would each login be an individual list?" No, but each user would save the data to a new item in the list.
"Is there some kind of offline capability with SharePoint on a local device? The end users are mostly using a mobile device/cell phone." No, but there is with Power Apps, so if a user loses connection it would save the data to the local device and upload it when the connection is restored.
It shouldn't take too long to build if you have someone in your organisation who know Power Apps. If not there is naturally a learning curve, but as I said in my previous post there are many Power Apps timesheet how-to videos on YouTube. But I can build a quick app for you that will demonstrate what I'v been talking about.
Rob
Los Gallardos
Microsoft Power Automate Community Super User.
Principal Consultant, SharePoint and Power Platform WSP Global (and classic 1967 Morris Traveller driver)
Jun 25 2024 05:55 PM
I found a YouTube channel video that shows a time tracking app that could form the basis of my idea. It is here PowerApps Time Tracking (youtube.com)
The concept would be to have multiple instances of a start time and stop time to complete rows in a SharePoint list up to 5 or more instances in one shift. So, one row per shift per login, that captures the entire shift work and break times. Ideally there would also be a signature box, checkboxes for various things, possibly a location via GPS.
"It shouldn't take too long to build if you have someone in your organisation who know Power Apps. If not there is naturally a learning curve, but as I said in my previous post there are many Power Apps timesheet how-to videos on YouTube. But I can build a quick app for you that will demonstrate what I'v been talking about."
I am the company developer, but have no experience with PowerApps etc, my history is with Excel and Access etc, old school stuff. I recently completed a sophisticated integrated rostering/time tracking/pay hours/auto overtime spreadsheet for our company. I understand the concepts of objects and coding, but not the PowerApp system.
The timesheet needs to be live / concurrent in terms of time, including if the user goes offline for some reason. It needs one row as a shift in Lists, which is something I am not fully understanding. I see that this is similar to a database design for Access, where the underlying design is important when it comes to the front-end development.
Where should I start the design aspect? With the SharePoint list headers, or the App? On some other projects, I have done both concurrently as I made sense of it.
At this point, I see multiple headers using a slightly different name to correlate with the PowerApp data outputs, such as "WorkTime1", "WorkTime2", "Break1", "Break2", and the corresponding data output from the PowerApp with these as the end reference?
Jun 25 2024 09:04 PM - edited Jun 25 2024 09:08 PM
Another update from this morning:
I have the structure, but now need to address some functions in the app itself. The app is limited to the prebuilt one from PowerApps itself, as follows:
And I am hoping to change the date and time selectors to a button that does a time stamp for the start and stop functions of the work and break times. Also, to be able to have an in app image panel to sign a name, like you would do for a post delivery etc.
Jun 26 2024 12:25 AM
@RShehan it will be a couple of days until I can show you my solution as I've caught COVID and can only work for a few minutes at a time
Rob
Los Gallardos
Microsoft Power Automate Community Super User.
Principal Consultant, SharePoint and Power Platform WSP Global (and classic 1967 Morris Traveller driver)