I have some example data below where I'm trying to conditionally format all numeric columns in my reactable table but only for row 1. For example, I'd like to use a traffic light system and assign the cell backgrounds in row 1 as green, red or orange if the value is more than that in row 2, within 10% of row 2 or more than 10% below the values in row 2, respectively.
library(reactable)
set.seed(1)
name <- c("Player A", "Player B", "Team")
var1 <- rnorm(3, 1000, 200)
var2 <- rnorm(3, 1000, 200)
var3 <- rnorm(3, 1000, 200)
d <- data.frame(name, var1, var2, var3)
reactable(d,
          defaultColDef = colDef(
            align = "center",
            format = colFormat(digits = 1)
          )
          )
I'm familiar with something like the below code, but I'm not sure how I can apply something like this to only specific rows and for multiple columns without repeating the function several times in colDef().
reactable(sleep[1:6, ], columns = list(
  extra = colDef(
    style = function(value) {
      if (value > 0) {
        color <- "#008000"
      } else if (value < 0) {
        color <- "#e00000"
      } else {
        color <- "#777"
      }
      list(color = color, fontWeight = "bold")
    }
  )
))
 
                        
Here is one option to achieve your desired result which uses the row
indexpassed to the style function as a second argument to access the value of the successor row. Additionally I uselapplyto create thecolDefs for a list of column names.