R/widget-has-external-degree-from.R

Defines functions has_external_degree_from_ has_external_degree_from

Documented in has_external_degree_from

#' Non-UC academic widgets
#'
#' Find entities who graduated from a particular institution. By default, attendees are not included, use \code{attendees = TRUE}
#' to include attendees.
#'
#' @return A definition of type \code{entity_id}
#'
#' @param ... Institutions
#' @param undergraduates TRUE/FALSE: should include undergraduates? Default is TRUE
#' @param graduates TRUE/FALSE: should include graduates? Default is TRUE
#' @param attendees TRUE/FALSE: should include attendees? Default is FALSE
#' @param current_students TRUE/FALSE: should include current students? Default is FALSE
#' @param degreeholders TRUE/FALSE: should include degreeholders? Default is TRUE
#' @param from (optional) date range: look only for those who graduated between
#' these dates. Enter as an integer of the form YYYYMMDD (see details)
#' @param to (optional) date range: look only for those who graduated between
#' these dates. Enter as an integer of the form YYYYMMDD (see details)
#'
#' When using the daterange (\code{from} and/or \code{to}), the dates will be
#' based on the GRAD DATE for degreeholders and the STOP DATE for attendees
#' (who have no GRAD DATE). Both dates are visible in the Degrees screen in
#' Advance. An alum's "class year" is based on the GRAD DATE. For degreeholders,
#' the two dates are often the same, though they can differ. See examples below.
#' Date options are ignored when looking for current students
#'
#' @examples
#' ## graduated from University of Michigan Ann Arbor between 01/01/2001 and 12/31/2004
#' ## since attendees are not included by default, this only pulls
#' ## (undergrad and grad) degreeholders. Those with a GRAD DATE in the
#' ## daterange will be included
#' has_external_degree_from(001839, from = 20010101, to = 20041231)
#'
#' ## just grad degree holders from University of Michigan Ann Arbor
#' has_external_degree_from(001839, undergraduates = FALSE)
#'
#' @name non-uc-academic
#' @seealso \code{\link{academic}}
NULL

#' @rdname non-uc-academic
#' @export
has_external_degree_from <- function(..., undergraduates = TRUE,
                            graduates = TRUE, attendees= FALSE,
                            current_students = FALSE,
                            degreeholders = TRUE,
                            from = NULL, to = NULL) {
    institutions <- prep_dots(...)
    reroute(has_external_degree_from_(institutions, undergraduates = undergraduates,
                             graduates = graduates, attendees = attendees,
                             current_students = current_students,
                             degreeholders = degreeholders,
                             from = from, to = to))
}

has_external_degree_from_ <- function(institutions, undergraduates = TRUE,
                             graduates = TRUE, attendees = FALSE,
                             current_students = FALSE,
                             degreeholders = TRUE,
                             from = NULL, to = NULL) {

    nonuc_academic_widget(param = string_param("institution_code", institutions),
                    undergraduates = undergraduates,
                    graduates = graduates,
                    attendees = attendees,
                    current_students = current_students,
                    degreeholders = degreeholders,
                    from = from, to = to)
}
cwolfsonseeley/discoveryengine documentation built on Sept. 30, 2023, 2:07 p.m.