Nothing
#' species_list
#'
#' Return the a species list given a taxonomic group
#' @param SuperClass Request all species of this Superclass
#' @param Class Request all species in this taxonomic Class
#' @param Order Request all species in this taxonomic Order
#' @param Family Request all species in this taxonomic Family
#' @param Subfamily Request all species in this taxonomic SubFamily
#' @param Genus Request all species in this taxonomic Genus
#' @param Species Request all species in this taxonomic Species
#' @param SpecCode Request species name of species matching this SpecCode
#' @param server fishbase or sealifebase
#' @examplesIf interactive()
#' \donttest{
#' ## All species in the Family
#' species_list(Family = 'Scaridae')
#' ## All species in the Genus
#' species_list(Genus = 'Labroides')
#' }
#' @export
#' @importFrom dplyr enquo
#' @importFrom rlang !!
species_list <- function(Class = NULL,
Order = NULL,
Family = NULL,
Subfamily = NULL,
Genus = NULL,
Species = NULL,
SpecCode = NULL,
SuperClass = NULL,
server = getOption("FISHBASE_API", FISHBASE_API)){
## This is a terribly designed function, since it's design is
## ambiguous about how multiple non-null arguments should be treated!
class <- enquo(Class)
order <- enquo(Order)
family <- enquo(Family)
subfamily <- enquo(Subfamily)
genus <- enquo(Genus)
species <- enquo(Species)
superclass <- enquo(SuperClass)
spec_code <- enquo(SpecCode)
#if(!is.nullClass)
taxa <- load_taxa(server)
if(!is.null(SuperClass))
taxa <- taxa %>% filter(SuperClass %in% !!superclass)
if(!is.null(Class))
taxa <- taxa %>% filter(Class %in% !!class)
if(!is.null(Order))
taxa <- taxa %>% filter(Order %in% !!order)
if(!is.null(Family))
taxa <- taxa %>% filter(Family %in% !!family)
if(!is.null(Subfamily))
taxa <- taxa %>% filter(Subfamily %in% !!subfamily)
if(!is.null(Genus))
taxa <- taxa %>% filter(Genus %in% !!genus)
if(!is.null(Species))
taxa <- taxa %>% filter(Species %in% !!species)
if(!is.null(SpecCode))
taxa <- taxa %>% filter(SpecCode %in% !!spec_code)
taxa %>% pull(Species)
}
Any scripts or data that you put into this service are public.
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.