"Who is next?" sheet

gavcuk

New Member
Joined
Nov 30, 2023
Messages
7
Platform
  1. Windows
Hi,

I'm something of an excel novice so may be biting off more than I can chew but looking to have a simple spreadsheet to identify which adviser is next up for a lead.

Currently we have a magnetic wipe board where we move a counter from name to name for several lead categories but would prefer to use some simple tech if we can so that all staff can see who is next regardless of whether they are in the office.

I'd like it so that a button can be clicked to move the counter to the next adviser once I've allocated them a lead.

If an adviser has status "holiday" on the sheet then they would miss their turn.

Is this achievable or unnecessarily complicated?

1701363261159.png
 

Excel Facts

Select a hidden cell
Somehide hide payroll data in column G? Press F5. Type G1. Enter. Look in formula bar while you arrow down through G.
This macro will work with the following scenario. Create a standard module and paste this code. Assign the same macro to every button.
1701421200635.png

VBA Code:
Sub buttonClick()
  Dim lRow As Long, lCol As Long, r As Long, c As Long, buttonName As String, a As Object
  Set a = Application

  With Worksheets("Sheet1")
  lRow = .Cells(Rows.Count, "A").End(xlUp).Row
  lCol = .Cells(2, Columns.Count).End(xlToLeft).Column
  For r = 3 To lRow
    If .Cells(r, "B").Value = "Hols" Then
      For c = 3 To lCol Step 2
        .Cells(r, c).Value = "H"
      Next
    End If
  Next
  buttonName = .Shapes(Application.Caller).TextFrame.Characters.Text
  c = a.Match(buttonName, .Rows(2), 0)
  If Not IsError(a.Match("X", .Columns(c), 0)) Then
    r = a.Match("X", .Columns(c), 0)
  Else
    Exit Sub
  End If
  .Cells(r, c).Value = ""
  r = IIf(.Cells((r Mod lRow) + 1, c).Value = "H", ((r + 1) Mod lRow) + 1, (r Mod lRow) + 1)
  If r < 3 Then
    r = 3
  End If
  .Cells(r, c).Value = "X"
  End With
End Sub
 
Upvote 0
This macro will work with the following scenario. Create a standard module and paste this code. Assign the same macro to every button.View attachment 102799
VBA Code:
Sub buttonClick()
  Dim lRow As Long, lCol As Long, r As Long, c As Long, buttonName As String, a As Object
  Set a = Application

  With Worksheets("Sheet1")
  lRow = .Cells(Rows.Count, "A").End(xlUp).Row
  lCol = .Cells(2, Columns.Count).End(xlToLeft).Column
  For r = 3 To lRow
    If .Cells(r, "B").Value = "Hols" Then
      For c = 3 To lCol Step 2
        .Cells(r, c).Value = "H"
      Next
    End If
  Next
  buttonName = .Shapes(Application.Caller).TextFrame.Characters.Text
  c = a.Match(buttonName, .Rows(2), 0)
  If Not IsError(a.Match("X", .Columns(c), 0)) Then
    r = a.Match("X", .Columns(c), 0)
  Else
    Exit Sub
  End If
  .Cells(r, c).Value = ""
  r = IIf(.Cells((r Mod lRow) + 1, c).Value = "H", ((r + 1) Mod lRow) + 1, (r Mod lRow) + 1)
  If r < 3 Then
    r = 3
  End If
  .Cells(r, c).Value = "X"
  End With
End Sub
Amazing, I'll give that a go.

Thanks so much!
 
Upvote 0
Gald it did work :) Thanks for the feedback 👍

I did run into a problem if I marked two of the advisers as on hols. It works initially but then as the X advances to the bottom it fails.

Also, if I put Adviser 1 as on hols instead of 5, then once the X gets to the bottom i.e. Adviser 5 the X then moves to Adviser 1 instead of skipping them (as they are away) and moving to Adviser 2.

Any idea, what is causing that?
 
Upvote 0
I see.. Both problems are caused by the same reason. I tried to fix it. I am not in front of the computer. I had no chance to test. Please let me know if it works. I'll check later.
VBA Code:
Sub buttonClick()
  Dim lRow As Long, lCol As Long, r As Long, c As Long, buttonName As String, a As Object
  Set a = Application

  With Worksheets("Sheet1")
  lRow = .Cells(Rows.Count, "A").End(xlUp).Row
  lCol = .Cells(2, Columns.Count).End(xlToLeft).Column
  For r = 3 To lRow
    If .Cells(r, "B").Value = "Hols" Then
      For c = 3 To lCol Step 2
        .Cells(r, c).Value = "H"
      Next
    End If
  Next
  buttonName = .Shapes(Application.Caller).TextFrame.Characters.Text
  c = a.Match(buttonName, .Rows(2), 0)
  If Not IsError(a.Match("X", .Columns(c), 0)) Then
    r = a.Match("X", .Columns(c), 0)
  Else
    Exit Sub
  End If
  .Cells(r, c).Value = ""
  Do
    r = IIf((r Mod lRow) + 1 < 3, 3 ,(r Mod lRow) + 1)
  Loop While .Cells(r, c).Value = "H"
  .Cells(r, c).Value = "X"
  End With
End Sub
 
Last edited by a moderator:
Upvote 0
I see.. Both problems are because of the same reason. I tried to fix it. I am not in front of the computer. I had no chance to test. Please let me know if it works. I'll check later.
VBA Code:
Sub buttonClick()
  Dim lRow As Long, lCol As Long, r As Long, c As Long, buttonName As String, a As Object
  Set a = Application

  With Worksheets("Sheet1")
  lRow = .Cells(Rows.Count, "A").End(xlUp).Row
  lCol = .Cells(2, Columns.Count).End(xlToLeft).Column
  For r = 3 To lRow
    If .Cells(r, "B").Value = "Hols" Then
      For c = 3 To lCol Step 2
        .Cells(r, c).Value = "H"
      Next
    End If
  Next
  buttonName = .Shapes(Application.Caller).TextFrame.Characters.Text
  c = a.Match(buttonName, .Rows(2), 0)
  If Not IsError(a.Match("X", .Columns(c), 0)) Then
    r = a.Match("X", .Columns(c), 0)
  Else
    Exit Sub
  End If
  .Cells(r, c).Value = ""
  Do
    r = IIf((r Mod lRow) + 1 < 3, 3 ,(r Mod lRow) + 1)
  Loop While .Cells(r, c).Value = "H"
  .Cells(r, c).Value = "X"
  End With
End Sub
Working like a charm!

Thank you! 🙌
 
Upvote 0
You are welcome :) Thanks for the feedback 👍 Also you can use the code below. Basically it the same code but a bit cleaner:
VBA Code:
Sub buttonClick()
  Dim lRow As Long, lCol As Long, r As Long, c As Long, buttonName As String, a As Object
  Set a = Application

  With Worksheets("Sheet1")
  lRow = .Cells(Rows.Count, "A").End(xlUp).Row
  lCol = .Cells(2, Columns.Count).End(xlToLeft).Column
  For r = 3 To lRow
    If .Cells(r, "B").Value = "Hols" Then
      For c = 3 To lCol Step 2
        .Cells(r, c).Value = "H"
      Next
    End If
  Next
  buttonName = .Shapes(Application.Caller).TextFrame.Characters.Text
  c = a.Match(buttonName, .Rows(2), 0)
  If Not IsError(a.Match("X", .Columns(c), 0)) Then
    r = a.Match("X", .Columns(c), 0)
    .Cells(r, c).Value = ""
    Do
      r = IIf((r Mod lRow) + 1 < 3, 3 ,(r Mod lRow) + 1)
    Loop While .Cells(r, c).Value = "H"
    .Cells(r, c).Value = "X"
  End If
  End With
End Sub
 
Upvote 0
You are welcome :) Thanks for the feedback 👍 Also you can use the code below. Basically it the same code but a bit cleaner:
VBA Code:
Sub buttonClick()
  Dim lRow As Long, lCol As Long, r As Long, c As Long, buttonName As String, a As Object
  Set a = Application

  With Worksheets("Sheet1")
  lRow = .Cells(Rows.Count, "A").End(xlUp).Row
  lCol = .Cells(2, Columns.Count).End(xlToLeft).Column
  For r = 3 To lRow
    If .Cells(r, "B").Value = "Hols" Then
      For c = 3 To lCol Step 2
        .Cells(r, c).Value = "H"
      Next
    End If
  Next
  buttonName = .Shapes(Application.Caller).TextFrame.Characters.Text
  c = a.Match(buttonName, .Rows(2), 0)
  If Not IsError(a.Match("X", .Columns(c), 0)) Then
    r = a.Match("X", .Columns(c), 0)
    .Cells(r, c).Value = ""
    Do
      r = IIf((r Mod lRow) + 1 < 3, 3 ,(r Mod lRow) + 1)
    Loop While .Cells(r, c).Value = "H"
    .Cells(r, c).Value = "X"
  End If
  End With
End Sub

That also seems to work so thank you.

One thing I've noticed is that when someone is marked as Hols in the status column, clicking a button also puts a H in the submitted column. Can that be prevented?

Feel bad for asking tbh
 
Upvote 0

Forum statistics

Threads
1,223,910
Messages
6,175,318
Members
452,634
Latest member
cpostell

We've detected that you are using an adblocker.

We have a great community of people providing Excel help here, but the hosting costs are enormous. You can help keep this site running by allowing ads on MrExcel.com.
Allow Ads at MrExcel

Which adblocker are you using?

Disable AdBlock

Follow these easy steps to disable AdBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the icon in the browser’s toolbar.
2)Click on the "Pause on this site" option.
Go back

Disable AdBlock Plus

Follow these easy steps to disable AdBlock Plus

1)Click on the icon in the browser’s toolbar.
2)Click on the toggle to disable it for "mrexcel.com".
Go back

Disable uBlock Origin

Follow these easy steps to disable uBlock Origin

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back

Disable uBlock

Follow these easy steps to disable uBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back
Back
Top