R/check_ranges_12.R

Defines functions check_ranges_12

check_ranges_12 <- function(d, v) {
  lex <- bdsreader::bds_lexicon

  e <- catch_cnd({
    dob <- ymd(extract_field2(d, 20L, v = v))
  })
  if (!is.null(e) || !length(dob)) {
    message("BDS  20 (",
            lex[lex$bdsnummer == 20, "description_EN"],
            ") Invalid birth date"
    )
    dob <- NA
  }

  e <- catch_cnd({
    dobm <- ymd(extract_field3(d, 63L, v = v))
  })
  if (!is.null(e)) {
    message("BDS  63 (",
            lex[lex$bdsnummer == 63, "description_EN"],
            ") Invalid format"
    )
    dobm <- NA
  }

  gad <- as.numeric(extract_field2(d, 82L, v = v))
  if (is.na(gad)) {
    message("BDS 82 (",
            lex[lex$bdsnummer == 82, "description_EN"],
            " in days) has no value"
    )
  }
  if (!is.na(gad) && (gad < 50 || gad > 350)) {
    message("BDS 82 (",
            lex[lex$bdsnummer == 82, "description_EN"],
            " in days): Outside range 50-350"
    )
    gad <- NA_real_
  }
  bw <- as.numeric(extract_field2(d, 110L, v = v))
  if (is.na(bw)) {
    message("BDS 110 (",
            lex[lex$bdsnummer == 110, "description_EN"],
            " in grammes): has no value"
    )
  }
  if (!is.na(bw) && (bw < 300 || bw > 8000)) {
    message("BDS 110 (",
            lex[lex$bdsnummer == 110, "description_EN"],
            " in grammes: Outside range 300-8000"
    )
  }

  hgtm <- as.numeric(extract_field2(d, 238L, v = v))
  if (is.na(hgtm)) {
    message("BDS 238 (",
            lex[lex$bdsnummer == 238, "description_EN"],
            " in mm): has no value"
    )
  }
  if (!is.na(hgtm) && (hgtm < 800 || hgtm > 3000)) {
    message("BDS 238 (",
            lex[lex$bdsnummer == 238, "description_EN"],
            " in mm): Outside range 800-3000"
    )
  }

  hgtf <- as.numeric(extract_field2(d, 240L, v = v))
  if (is.na(hgtm)) {
    message("BDS 240 (",
            lex[lex$bdsnummer == 240, "description_EN"],
            " in mm): has no value"
    )
  }
  if (!is.na(hgtf) && (hgtf < 800 || hgtf > 3000)) {
    message("BDS 240 (",
            lex[lex$bdsnummer == 240, "description_EN"],
            " in mm): Outside range 800-3000"
    )
  }

  hdc <- wgt <- hgt <- dom <- NULL

  if (length(d$Contactmomenten) == 0L &&
      length(d$ContactMomenten) == 0L) {
    switch(v,
           message("Missing 'Contactmomenten'"),
           message("Missing 'ContactMomenten'"))
  } else {
    if (v == 1) {
      e <- catch_cnd({
        dom <- ymd(d$Contactmomenten[[1L]])
      })
      if (!is.null(e)) warning("Measurement date: Invalid format: ",
                               as.character(d$Contactmomenten[[1L]]))
    } else if (v == 2) {
      e <- catch_cnd({
        dom <- ymd(d$ContactMomenten[[1L]])
      })
      if (!is.null(e)) warning("Measurement date: Invalid format: ",
                               as.character(d$ContactMomenten[[1L]]))
    }

    hgt <- extract_field(d, 235L, v = v)
    wgt <- extract_field(d, 245L, v = v)
    hdc <- extract_field(d, 252L, v = v)

    if (all(is.na(hgt))) {
      message("BDS 235 (",
              lex[lex$bdsnummer == 235, "description_EN"],
              " in mm): has no value"
      )
    }
    if (any(!is.na(hgt) & (hgt < 100 | hgt > 3000))) {
      message("BDS 235 (",
              lex[lex$bdsnummer == 235, "description_EN"],
              " in mm): Outside range 100-2500"
      )
    }
    if (all(is.na(wgt))) {
      message("BDS 245 (",
              lex[lex$bdsnummer == 245, "description_EN"],
              " in grammes): has no value"
      )
    }
    if (any(!is.na(wgt) & (wgt < 100 | wgt > 300000))) {
      message("BDS 245 (",
              lex[lex$bdsnummer == 245, "description_EN"],
              " in grammes): Outside range 100-300000"
      )
    }
    if (all(is.na(hdc))) {
      message("BDS 252 (",
              lex[lex$bdsnummer == 252, "description_EN"],
              " in mm): has no value"
      )
    }
    if (any(!is.na(hdc) & (hdc < 100 | hdc > 900))) {
      message("BDS 252 (",
              lex[lex$bdsnummer == 252, "description_EN"],
              " in mm): Outside range 100-900"
      )
    }
  }

  if (v == 1) {
    if (length(d$ClientGegevens$Groepen) == 0L) {
      message("Missing 'ClientGegevens$Groepen'")
    }
  } else if (v == 2) {
    if (all(unlist(lapply(d$ClientGegevens$GenesteElementen, is.null)))) {
      message("Missing 'ClientGegevens$GenesteElementen'")
    }
  }

  list(
    dob = dob,
    dobm = dobm,
    gad = gad,
    bw = bw,
    hgtm = hgtm,
    hgtf = hgtf,
    dom = dom,
    hgt = hgt,
    wgt = wgt,
    hdc = hdc
  )
}
growthcharts/bdsreader documentation built on March 26, 2024, 4:16 a.m.