forked from theoschneider/AnnotTool
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsc-experiment.bas
64 lines (43 loc) · 2.08 KB
/
sc-experiment.bas
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
Private Sub Worksheet_Change(ByVal Modified As range)
Application.ScreenUpdating = False
Application.Calculation = xlCalculationManual
Application.EnableEvents = False
' --- GET ALL SHEETS ---
Dim exp_Sheet As Worksheet
Set exp_Sheet = Sheets("sc-experiment")
Dim lib_Sheet As Worksheet
Set lib_Sheet = Sheets("sc-library")
' --- GET ALL COLUMNS OF INTEREST ---
Dim expID_col As String
expID_col = Split(exp_Sheet.Cells(1, Application.Match("#experimentId", Rows(1), 0)).address, "$")(1)
Dim number_col As String
number_col = Split(exp_Sheet.Cells(1, Application.Match("numberOfAnnotatedLibraries", Rows(1), 0)).address, "$")(1)
Dim expStatus_col As String
expStatus_col = Split(exp_Sheet.Cells(1, Application.Match("experimentStatus", Rows(1), 0)).address, "$")(1)
' --- CHECK EVERY MODIFIED CELL (MAIN LOOP) ---
For Each Target In Modified
' --- GET COL AND ROW OF MODIFIED CELL ---
Dim col As String
col = Split(exp_Sheet.Cells(1, Target.Column).address, "$")(1)
Dim row As Long
row = Target.row
' --- DECLARE OTHER VALUES OF INTEREST ---
Dim numberOfLibs As Long
Dim exp_ID As String
exp_ID = exp_Sheet.range(expID_col & row).Value
If (col = expID_col) And (row > 1) Then
' --- COUNT LIBRARIES PART ---
' --- Run the libraries counter
numberOfLibs = Count_Libraries(exp_ID, exp_Sheet, lib_Sheet)
' --- Fill the cell with the number
exp_Sheet.range(number_col & row).Value = CStr(numberOfLibs) & " libraries"
End If
If (col = expID_col Or col = expStatus_col) And (row > 1) Then
' --- EXPERIMENT STATUS PART ---
ExperimentStatus exp_Sheet.range(expStatus_col & row)
End If
Next Target
Application.ScreenUpdating = True
Application.Calculation = xlCalculationAutomatic
Application.EnableEvents = True
End Sub