|
|
@ -2,7 +2,6 @@ library(shiny) |
|
|
|
library(rhandsontable) |
|
|
|
|
|
|
|
print(getwd()) |
|
|
|
print(file) |
|
|
|
source("../sqlFunctions.R", encoding = "UTF-8") |
|
|
|
|
|
|
|
DF<-data.frame("NHC"="","Samples"="") |
|
|
@ -28,7 +27,7 @@ ui <- fluidPage( |
|
|
|
hr(), |
|
|
|
fileInput(inputId = "file_query", label = "Plantilla", multiple = F), |
|
|
|
actionButton("impNHC", "Importa NHC"), |
|
|
|
actionButton("goButton", "Genera UMID"), |
|
|
|
actionButton("goButton", "Genera CodiID"), |
|
|
|
hr(), |
|
|
|
actionButton("filltemplate", "Plantilla"), |
|
|
|
hr(), |
|
|
@ -59,8 +58,17 @@ server <- function(input, output) { |
|
|
|
values[["Excel"]]<-"" |
|
|
|
|
|
|
|
observeEvent(input$butdbtype, { |
|
|
|
dta<<-odbcConnectAccess2007(access.file = file, |
|
|
|
pwd = .rs.askForPassword("Enter password:")) |
|
|
|
print(UMfile) |
|
|
|
print(OVfile) |
|
|
|
if (input$dbtype == "UM"){ |
|
|
|
dta<<-odbcConnectAccess2007(access.file = UMfile, |
|
|
|
pwd = .rs.askForPassword("Enter password:")) |
|
|
|
} |
|
|
|
if (input$dbtype == "OV"){ |
|
|
|
dta<<-odbcConnectAccess2007(access.file = OVfile, |
|
|
|
pwd = .rs.askForPassword("Enter password:")) |
|
|
|
} |
|
|
|
|
|
|
|
print(dta) |
|
|
|
if (input$backup == T){ |
|
|
|
sqlBackUp() |
|
|
@ -86,7 +94,7 @@ server <- function(input, output) { |
|
|
|
observeEvent(input$impNHC, { |
|
|
|
values[["DF"]]$NHC<-values[["Excel"]] |
|
|
|
}) |
|
|
|
|
|
|
|
|
|
|
|
## Handsontable |
|
|
|
observe({ |
|
|
|
if (!is.null(input$hot)) { |
|
|
@ -109,7 +117,6 @@ server <- function(input, output) { |
|
|
|
}) |
|
|
|
|
|
|
|
observe({ |
|
|
|
print(1) |
|
|
|
if (!is.null(input$samples)) { |
|
|
|
samples = hot_to_r(input$samples) |
|
|
|
} else { |
|
|
@ -190,145 +197,236 @@ server <- function(input, output) { |
|
|
|
}) |
|
|
|
|
|
|
|
observeEvent(input$goButton, { |
|
|
|
print(dta) |
|
|
|
sqlGenOVID(nhcs = values[["DF"]]$NHC, sinc=T) |
|
|
|
values[["DF"]]<-merge(values[["DF"]], sqlFetch(dta, "UMID")) |
|
|
|
|
|
|
|
sqlGenOVID(dta, nhcs = values[["DF"]]$NHC, sinc=T) |
|
|
|
|
|
|
|
if (input$dbtype == "UM"){ |
|
|
|
values[["DF"]]<-merge(values[["DF"]], sqlFetch(dta, "UMID")) |
|
|
|
} |
|
|
|
if (input$dbtype == "OV"){ |
|
|
|
values[["DF"]]<-merge(values[["DF"]], sqlFetch(dta, "OVID")) |
|
|
|
} |
|
|
|
print(values[["DF"]]) |
|
|
|
}) |
|
|
|
|
|
|
|
observeEvent(input$filltemplate,{ |
|
|
|
today=T |
|
|
|
|
|
|
|
upd.umid<-sqlFetch(dta, "UMID") %>% filter(NHC %in% values[["DF"]]$NHC) |
|
|
|
## Generar código para las nuevas muestras |
|
|
|
samples<-sqlFetch(dta, "MUESTRAS") |
|
|
|
if(sum(grepl(paste0("UM",Sys.time() %>% format("%y")), samples$CODIGO)) > 0){ |
|
|
|
next.samp<-gsub(paste0("UM",Sys.time() %>% format("%y")),"", samples$CODIGO) %>% as.numeric %>% max(na.rm=T)+1 |
|
|
|
}else{ |
|
|
|
next.samp<-1 |
|
|
|
} |
|
|
|
last.samp<-next.samp+(length(values[["DF"]]$NHC)-1) |
|
|
|
new.samp<-sprintf("UM%s%02d",Sys.time() %>% format("%y"),next.samp:last.samp) |
|
|
|
new.samp.df<-data.frame("NHC"=values[["DF"]]$NHC, "CODIGO"=new.samp) %>% merge(sqlFetch(dta,"UMID"), all.x=T) %>% arrange(CODIGO) |
|
|
|
samples.exp<-merge(samples %>% slice(0), new.samp.df %>% select(-NHC), all=T) %>% select(colnames(samples)) %>% arrange(CODIGO) |
|
|
|
if (today==TRUE){ |
|
|
|
samples.exp$FECHA_RECEPCION<-format(Sys.Date(), "%d/%m/%y") |
|
|
|
} |
|
|
|
|
|
|
|
nhc.table<-values[["DF"]] |
|
|
|
|
|
|
|
if (any(sapply(nhc.table$Samples, function(x) "cnag" %in% strsplit(x,",")[[1]]) == T)){ |
|
|
|
nhcs.cnag<-nhc.table[sapply(nhc.table$Samples, function(x) "cnag" %in% strsplit(x,",")[[1]]),"NHC"] |
|
|
|
umid.cnag<-sqlFetch(dta, "UMID") %>% filter(NHC %in% nhcs.cnag) %>% pull(UMID) |
|
|
|
sample.cnag<-samples.exp %>% filter(UMID %in% umid.cnag) %>% pull(CODIGO) |
|
|
|
cnag.exp<-merge(data.frame("UMID"=umid.cnag, "CODIGO"=sample.cnag), sqlFetch(dta, "CNAG") %>% slice(0), all=T) |
|
|
|
if (input$dbtype == "UM"){ |
|
|
|
upd.umid<-sqlFetch(dta, "UMID") %>% filter(NHC %in% values[["DF"]]$NHC) |
|
|
|
## Generar código para las nuevas muestras |
|
|
|
samples<-sqlFetch(dta, "MUESTRAS") |
|
|
|
if(sum(grepl(paste0("UM",Sys.time() %>% format("%y")), samples$CODIGO)) > 0){ |
|
|
|
next.samp<-gsub(paste0("UM",Sys.time() %>% format("%y")),"", samples$CODIGO) %>% as.numeric %>% max(na.rm=T)+1 |
|
|
|
}else{ |
|
|
|
next.samp<-1 |
|
|
|
} |
|
|
|
last.samp<-next.samp+(length(values[["DF"]]$NHC)-1) |
|
|
|
new.samp<-sprintf("UM%s%02d",Sys.time() %>% format("%y"),next.samp:last.samp) |
|
|
|
new.samp.df<-data.frame("NHC"=values[["DF"]]$NHC, "CODIGO"=new.samp) %>% merge(sqlFetch(dta,"UMID"), all.x=T) %>% arrange(CODIGO) |
|
|
|
samples.exp<-merge(samples %>% slice(0), new.samp.df %>% select(-NHC), all=T) %>% select(colnames(samples)) %>% arrange(CODIGO) |
|
|
|
if (today==TRUE){ |
|
|
|
cnag.exp$FECHA_ENVIO<-format(Sys.Date(), "%d/%m/%y") |
|
|
|
samples.exp$FECHA_RECEPCION<-format(Sys.Date(), "%d/%m/%y") |
|
|
|
} |
|
|
|
}else{ |
|
|
|
cnag.exp<-sqlFetch(dta, "CNAG") %>% slice(0) %>% |
|
|
|
mutate(across(lubridate::is.POSIXct, as.character)) |
|
|
|
|
|
|
|
nhc.table<-values[["DF"]] |
|
|
|
|
|
|
|
if (any(sapply(nhc.table$Samples, function(x) "cnag" %in% strsplit(x,",")[[1]]) == T)){ |
|
|
|
nhcs.cnag<-nhc.table[sapply(nhc.table$Samples, function(x) "cnag" %in% strsplit(x,",")[[1]]),"NHC"] |
|
|
|
umid.cnag<-sqlFetch(dta, "UMID") %>% filter(NHC %in% nhcs.cnag) %>% pull(UMID) |
|
|
|
sample.cnag<-samples.exp %>% filter(UMID %in% umid.cnag) %>% pull(CODIGO) |
|
|
|
cnag.exp<-merge(data.frame("UMID"=umid.cnag, "CODIGO"=sample.cnag), sqlFetch(dta, "CNAG") %>% slice(0), all=T) |
|
|
|
if (today==TRUE){ |
|
|
|
cnag.exp$FECHA_ENVIO<-format(Sys.Date(), "%d/%m/%y") |
|
|
|
} |
|
|
|
}else{ |
|
|
|
cnag.exp<-sqlFetch(dta, "CNAG") %>% slice(0) %>% |
|
|
|
mutate(across(lubridate::is.POSIXct, as.character)) |
|
|
|
} |
|
|
|
if (any(sapply(nhc.table$Samples, function(x) "rna" %in% strsplit(x,",")[[1]]) == T)){ |
|
|
|
nhcs.rna<-nhc.table[sapply(nhc.table$Samples, function(x) "rna" %in% strsplit(x,",")[[1]]),"NHC"] |
|
|
|
umid.rna<-sqlFetch(dta, "UMID") %>% filter(NHC %in% nhcs.rna) %>% pull(UMID) |
|
|
|
sample.rna<-samples.exp %>% filter(UMID %in% umid.rna) %>% pull(CODIGO) |
|
|
|
rna.exp<-merge(data.frame("UMID"=umid.rna, "CODIGO"=sample.rna), sqlFetch(dta, "RNADNA") %>% slice(0)%>% |
|
|
|
mutate(across(lubridate::is.POSIXct, as.character)), all=T) |
|
|
|
}else{ |
|
|
|
rna.exp<-sqlFetch(dta, "RNADNA") %>% slice(0) %>% |
|
|
|
mutate(across(lubridate::is.POSIXct, as.character)) |
|
|
|
} |
|
|
|
|
|
|
|
## Importar los datos clínicos de pacientes existentes y generar nueva entrada par los nuevos |
|
|
|
upd.clinics<-sqlFetch(dta, "CLINICOS") |
|
|
|
umid.new<-sqlFetch(dta, "UMID") %>% filter(NHC %in% values[["DF"]]$NHC) |
|
|
|
upd.clinics<-merge(umid.new,upd.clinics, all.x=T, by="UMID") |
|
|
|
upd.clinics$NHC<-as.character(upd.clinics$NHC) |
|
|
|
for (i in colnames(upd.clinics)[sapply(upd.clinics, lubridate::is.POSIXct)]){upd.clinics[,i]<-as.Date(upd.clinics[,i])} |
|
|
|
|
|
|
|
values[["samples"]]<-samples.exp |
|
|
|
values[["CLINICS"]]<-upd.clinics |
|
|
|
values[["cnag"]]<-cnag.exp |
|
|
|
values[["rna"]]<-rna.exp |
|
|
|
} |
|
|
|
if (input$dbtype == "OV"){ |
|
|
|
upd.umid<-sqlFetch(dta, "OVID") %>% filter(NHC %in% values[["DF"]]$NHC) |
|
|
|
## Generar código para las nuevas muestras |
|
|
|
samples<-sqlFetch(dta, "SAMPLES") |
|
|
|
if(sum(grepl(paste0("OV",Sys.time() %>% format("%y")), samples$samples)) > 0){ |
|
|
|
next.samp<-gsub(paste0("OV",Sys.time() %>% format("%y")),"", samples$samples) %>% as.numeric %>% max(na.rm=T)+1 |
|
|
|
}else{ |
|
|
|
next.samp<-1 |
|
|
|
} |
|
|
|
if (any(sapply(nhc.table$Samples, function(x) "rna" %in% strsplit(x,",")[[1]]) == T)){ |
|
|
|
nhcs.rna<-nhc.table[sapply(nhc.table$Samples, function(x) "rna" %in% strsplit(x,",")[[1]]),"NHC"] |
|
|
|
umid.rna<-sqlFetch(dta, "UMID") %>% filter(NHC %in% nhcs.rna) %>% pull(UMID) |
|
|
|
sample.rna<-samples.exp %>% filter(UMID %in% umid.rna) %>% pull(CODIGO) |
|
|
|
rna.exp<-merge(data.frame("UMID"=umid.rna, "CODIGO"=sample.rna), sqlFetch(dta, "RNADNA") %>% slice(0)%>% |
|
|
|
mutate(across(lubridate::is.POSIXct, as.character)), all=T) |
|
|
|
}else{ |
|
|
|
rna.exp<-sqlFetch(dta, "RNADNA") %>% slice(0) %>% |
|
|
|
mutate(across(lubridate::is.POSIXct, as.character)) |
|
|
|
last.samp<-next.samp+(length(values[["DF"]]$NHC)-1) |
|
|
|
new.samp<-sprintf("OV%s%02d",Sys.time() %>% format("%y"),next.samp:last.samp) |
|
|
|
new.samp.df<-data.frame("NHC"=values[["DF"]]$NHC, "samples"=new.samp) %>% merge(sqlFetch(dta,"OVID"), all.x=T) %>% arrange(samples) |
|
|
|
samples.exp<-merge(samples %>% slice(0), new.samp.df %>% select(-NHC), all=T) %>% select(colnames(samples)) %>% arrange(samples) |
|
|
|
if (today==TRUE){ |
|
|
|
samples.exp$IQ_date<-format(Sys.Date(), "%d/%m/%y") |
|
|
|
} |
|
|
|
|
|
|
|
## Importar los datos clínicos de pacientes existentes y generar nueva entrada par los nuevos |
|
|
|
upd.clinics<-sqlFetch(dta, "CLINICOS") |
|
|
|
umid.new<-sqlFetch(dta, "UMID") %>% filter(NHC %in% values[["DF"]]$NHC) |
|
|
|
upd.clinics<-merge(umid.new,upd.clinics, all.x=T, by="UMID") |
|
|
|
upd.clinics$NHC<-as.character(upd.clinics$NHC) |
|
|
|
for (i in colnames(upd.clinics)[sapply(upd.clinics, lubridate::is.POSIXct)]){upd.clinics[,i]<-as.Date(upd.clinics[,i])} |
|
|
|
|
|
|
|
values[["samples"]]<-samples.exp |
|
|
|
values[["CLINICS"]]<-upd.clinics |
|
|
|
values[["cnag"]]<-cnag.exp |
|
|
|
values[["rna"]]<-rna.exp |
|
|
|
|
|
|
|
print(values[["rna"]] %>% sapply(class)) |
|
|
|
|
|
|
|
nhc.table<-values[["DF"]] |
|
|
|
|
|
|
|
## Importar los datos clínicos de pacientes existentes y generar nueva entrada par los nuevos |
|
|
|
upd.clinics<-sqlFetch(dta, "CLINICS") |
|
|
|
umid.new<-sqlFetch(dta, "OVID") %>% filter(NHC %in% values[["DF"]]$NHC) |
|
|
|
upd.clinics<-merge(umid.new,upd.clinics, all.x=T, by="OVID") |
|
|
|
upd.clinics$NHC<-as.character(upd.clinics$NHC) |
|
|
|
for (i in colnames(upd.clinics)[sapply(upd.clinics, lubridate::is.POSIXct)]){upd.clinics[,i]<-as.Date(upd.clinics[,i])} |
|
|
|
|
|
|
|
values[["samples"]]<-samples.exp %>% mutate(across(lubridate::is.POSIXct, as.character)) |
|
|
|
values[["CLINICS"]]<-upd.clinics %>% mutate(across(lubridate::is.POSIXct, as.character)) |
|
|
|
} |
|
|
|
|
|
|
|
}) |
|
|
|
|
|
|
|
observeEvent(input$synctemplate,{ |
|
|
|
if (input$dbtype == "UM"){ |
|
|
|
# conn=dta, filetemp="queryOV.xlsx", sinc.samples=F, sinc.clinics=F, dbtype=NULL |
|
|
|
|
|
|
|
## Nuevas entradas en MUESTRAS |
|
|
|
nsamples<-values[["samples"]] %>% nrow |
|
|
|
upd.samples<-values[["samples"]] |
|
|
|
if (nrow(upd.samples) > 0){rownames(upd.samples)<-(nsamples+1):(nsamples+nrow(upd.samples)) %>% as.character} |
|
|
|
|
|
|
|
if (nrow(upd.samples) > 0){ |
|
|
|
upd.samples$FECHA_RECEPCION<-lubridate::parse_date_time(upd.samples$FECHA_RECEPCION, c("d/m/Y","d/m/y")) %>% as.Date() |
|
|
|
upd.samples$TIPO<-as.character(upd.samples$TIPO) |
|
|
|
upd.samples$OBS<-as.character(upd.samples$OBS) |
|
|
|
### !! Atención, esto cambia la base de datos: |
|
|
|
sqlSave(dta, upd.samples, tablename="MUESTRAS", append = T, varTypes = c("FECHA_RECEPCION"="Date"), rownames = F) |
|
|
|
print("Tabla MUESTRAS sincronizada.") |
|
|
|
} |
|
|
|
|
|
|
|
# conn=dta, filetemp="queryOV.xlsx", sinc.samples=F, sinc.clinics=F, dbtype=NULL |
|
|
|
|
|
|
|
## Nuevas entradas en MUESTRAS |
|
|
|
nsamples<-values[["samples"]] %>% nrow |
|
|
|
upd.samples<-values[["samples"]] |
|
|
|
if (nrow(upd.samples) > 0){rownames(upd.samples)<-(nsamples+1):(nsamples+nrow(upd.samples)) %>% as.character} |
|
|
|
|
|
|
|
if (nrow(upd.samples) > 0){ |
|
|
|
upd.samples$FECHA_RECEPCION<-lubridate::parse_date_time(upd.samples$FECHA_RECEPCION, c("d/m/Y","d/m/y")) %>% as.Date() |
|
|
|
upd.samples$TIPO<-as.character(upd.samples$TIPO) |
|
|
|
upd.samples$OBS<-as.character(upd.samples$OBS) |
|
|
|
## Entradas modificadas en CLINICOS |
|
|
|
upd.clinics<-values[["CLINICS"]] |
|
|
|
umid.mod<-upd.clinics$UMID[upd.clinics$UMID %in% (sqlFetch(dta, "CLINICOS") %>% pull(UMID))] |
|
|
|
rnames<-sqlFetch(dta, "CLINICOS") %>% filter(UMID %in% umid.mod) %>% rownames |
|
|
|
clinics.mod<-upd.clinics %>% filter(UMID %in% umid.mod) %>% select(-NHC) |
|
|
|
rownames(clinics.mod)<-rnames |
|
|
|
|
|
|
|
### !! Atención, esto cambia la base de datos: |
|
|
|
print(upd.samples) |
|
|
|
sqlSave(dta, upd.samples, tablename="MUESTRAS", append = T, varTypes = c("FECHA_RECEPCION"="Date"), rownames = F) |
|
|
|
print("Tabla MUESTRAS sincronizada.") |
|
|
|
} |
|
|
|
|
|
|
|
## Entradas modificadas en CLINICOS |
|
|
|
upd.clinics<-values[["CLINICS"]] |
|
|
|
umid.mod<-upd.clinics$UMID[upd.clinics$UMID %in% (sqlFetch(dta, "CLINICOS") %>% pull(UMID))] |
|
|
|
rnames<-sqlFetch(dta, "CLINICOS") %>% filter(UMID %in% umid.mod) %>% rownames |
|
|
|
clinics.mod<-upd.clinics %>% filter(UMID %in% umid.mod) %>% select(-NHC) |
|
|
|
rownames(clinics.mod)<-rnames |
|
|
|
|
|
|
|
### !! Atención, esto cambia la base de datos: |
|
|
|
fechas<-colnames(clinics.mod)[grepl("date|MET_DX|DoB", colnames(clinics.mod), ignore.case = T)] |
|
|
|
for (i in fechas){ |
|
|
|
clinics.mod[,i]<-lubridate::parse_date_time(clinics.mod[,i], c("d/m/Y","d/m/y")) %>% as.Date() |
|
|
|
} |
|
|
|
sqlUpdate(dta, clinics.mod,"CLINICOS", index="UMID") |
|
|
|
print("Tabla CLINICOS modificada.") |
|
|
|
|
|
|
|
## Nuevas entradas en CLINICOS |
|
|
|
nsamples.clin<-sqlFetch(dta, "CLINICOS") %>% nrow |
|
|
|
umid.new<-upd.clinics$UMID[!upd.clinics$UMID %in% (sqlFetch(dta, "CLINICOS") %>% pull(UMID))] |
|
|
|
clinics.new<-upd.clinics %>% filter(UMID %in% umid.new) %>% select(-NHC) |
|
|
|
if (length(umid.new) > 0){rownames(clinics.new)<-(nsamples.clin+1):(nsamples.clin+nrow(clinics.new)) %>% as.character} |
|
|
|
|
|
|
|
### !! Atención, esto cambia la base de datos: |
|
|
|
fechas<-colnames(clinics.new)[grepl("date|MET_DX|DoB", colnames(clinics.new), ignore.case = T)] |
|
|
|
varTypes<-rep("Date",length(fechas)) |
|
|
|
names(varTypes)<-fechas |
|
|
|
for (i in fechas){ |
|
|
|
clinics.new[,i]<-lubridate::parse_date_time(clinics.new[,i], c("d/m/Y","d/m/y")) %>% as.Date() |
|
|
|
} |
|
|
|
sqlSave(dta, clinics.new, tablename="CLINICOS", append = T, varTypes = varTypes, rownames = F) |
|
|
|
print("Tabla CLINICOS sincronizada.") |
|
|
|
|
|
|
|
## Nuevas entradas en CNAG |
|
|
|
if (nrow(values[["cnag"]]) > 0){ |
|
|
|
cnag.sync<-values[["cnag"]] |
|
|
|
fechas<-colnames(cnag.sync)[sqlFetch(dta, "CNAG") %>% sapply(lubridate::is.POSIXct)] |
|
|
|
fechas<-colnames(clinics.mod)[grepl("date|MET_DX|DoB", colnames(clinics.mod), ignore.case = T)] |
|
|
|
for (i in fechas){ |
|
|
|
clinics.mod[,i]<-lubridate::parse_date_time(clinics.mod[,i], c("d/m/Y","d/m/y")) %>% as.Date() |
|
|
|
} |
|
|
|
sqlUpdate(dta, clinics.mod,"CLINICOS", index="UMID") |
|
|
|
print("Tabla CLINICOS modificada.") |
|
|
|
|
|
|
|
## Nuevas entradas en CLINICOS |
|
|
|
nsamples.clin<-sqlFetch(dta, "CLINICOS") %>% nrow |
|
|
|
umid.new<-upd.clinics$UMID[!upd.clinics$UMID %in% (sqlFetch(dta, "CLINICOS") %>% pull(UMID))] |
|
|
|
clinics.new<-upd.clinics %>% filter(UMID %in% umid.new) %>% select(-NHC) |
|
|
|
if (length(umid.new) > 0){rownames(clinics.new)<-(nsamples.clin+1):(nsamples.clin+nrow(clinics.new)) %>% as.character} |
|
|
|
|
|
|
|
### !! Atención, esto cambia la base de datos: |
|
|
|
fechas<-colnames(clinics.new)[grepl("date|MET_DX|DoB", colnames(clinics.new), ignore.case = T)] |
|
|
|
varTypes<-rep("Date",length(fechas)) |
|
|
|
names(varTypes)<-fechas |
|
|
|
print(fechas) |
|
|
|
for (i in fechas){ |
|
|
|
cnag.sync[,i]<-lubridate::parse_date_time(cnag.sync[,i], c("d/m/Y","d/m/y")) %>% as.Date() |
|
|
|
clinics.new[,i]<-lubridate::parse_date_time(clinics.new[,i], c("d/m/Y","d/m/y","Y-m-d")) %>% as.Date() |
|
|
|
} |
|
|
|
sqlSave(dta, clinics.new, tablename="CLINICOS", append = T, varTypes = varTypes, rownames = F) |
|
|
|
print("Tabla CLINICOS sincronizada.") |
|
|
|
|
|
|
|
## Nuevas entradas en CNAG |
|
|
|
if (nrow(values[["cnag"]]) > 0){ |
|
|
|
cnag.sync<-values[["cnag"]] |
|
|
|
fechas<-colnames(cnag.sync)[sqlFetch(dta, "CNAG") %>% sapply(lubridate::is.POSIXct)] |
|
|
|
varTypes<-rep("Date",length(fechas)) |
|
|
|
names(varTypes)<-fechas |
|
|
|
print(fechas) |
|
|
|
for (i in fechas){ |
|
|
|
cnag.sync[,i]<-lubridate::parse_date_time(cnag.sync[,i], c("d/m/Y","d/m/y","Y-m-d")) %>% as.Date() |
|
|
|
} |
|
|
|
sqlSave(dta, cnag.sync, tablename="CNAG", append = T, varTypes = varTypes, rownames = F) |
|
|
|
} |
|
|
|
|
|
|
|
## Nuevas entradas en RNADNA |
|
|
|
if (nrow(values[["rna"]]) > 0){ |
|
|
|
rna.sync<-values[["rna"]] |
|
|
|
fechas<-colnames(rna.sync)[sqlFetch(dta, "RNADNA") %>% sapply(lubridate::is.POSIXct)] |
|
|
|
varTypes<-rep("Date",length(fechas)) |
|
|
|
names(varTypes)<-fechas |
|
|
|
for (i in fechas){ |
|
|
|
rna.sync[,i]<-lubridate::parse_date_time(rna.sync[,i], c("d/m/Y","d/m/y","Y-m-d")) %>% as.Date() |
|
|
|
} |
|
|
|
sqlSave(dta, rna.sync, tablename="RNADNA", append = T, varTypes = varTypes, rownames = F) |
|
|
|
} |
|
|
|
sqlSave(dta, cnag.sync, tablename="CNAG", append = T, varTypes = varTypes, rownames = F) |
|
|
|
} |
|
|
|
|
|
|
|
## Nuevas entradas en RNADNA |
|
|
|
if (nrow(values[["rna"]]) > 0){ |
|
|
|
rna.sync<-values[["rna"]] |
|
|
|
fechas<-colnames(rna.sync)[sqlFetch(dta, "RNADNA") %>% sapply(lubridate::is.POSIXct)] |
|
|
|
if (input$dbtype == "OV"){ |
|
|
|
## Nuevas entradas en SAMPLES |
|
|
|
nsamples<-values[["samples"]] %>% nrow |
|
|
|
upd.samples<-values[["samples"]] |
|
|
|
if (nrow(upd.samples) > 0){rownames(upd.samples)<-(nsamples+1):(nsamples+nrow(upd.samples)) %>% as.character} |
|
|
|
|
|
|
|
if (nrow(upd.samples) > 0){ |
|
|
|
fechas<-colnames(upd.samples)[sqlFetch(dta, "SAMPLES") %>% sapply(lubridate::is.POSIXct)] |
|
|
|
for (i in fechas){ |
|
|
|
upd.samples[,i]<-lubridate::parse_date_time(upd.samples[,i], c("d/m/Y","d/m/y","Y-m-d")) %>% as.Date() |
|
|
|
} |
|
|
|
varTypes<-rep("Date",length(fechas)) |
|
|
|
names(varTypes)<-fechas |
|
|
|
# upd.samples$TIPO<-as.character(upd.samples$TIPO) |
|
|
|
# upd.samples$OBS<-as.character(upd.samples$OBS) |
|
|
|
### !! Atención, esto cambia la base de datos: |
|
|
|
sqlSave(dta, upd.samples, tablename="SAMPLES", append = T, varTypes = varTypes, rownames = F) |
|
|
|
print("Tabla SAMPLES sincronizada.") |
|
|
|
} |
|
|
|
|
|
|
|
## Entradas modificadas en CLINICOS |
|
|
|
upd.clinics<-values[["CLINICS"]] |
|
|
|
umid.mod<-upd.clinics$OVID[upd.clinics$OVID %in% (sqlFetch(dta, "CLINICS") %>% pull(OVID))] |
|
|
|
rnames<-sqlFetch(dta, "CLINICS") %>% filter(OVID %in% umid.mod) %>% rownames |
|
|
|
clinics.mod<-upd.clinics %>% filter(OVID %in% umid.mod) %>% select(-NHC) |
|
|
|
rownames(clinics.mod)<-rnames |
|
|
|
|
|
|
|
### !! Atención, esto cambia la base de datos: |
|
|
|
print(clinics.mod) |
|
|
|
fechas<-colnames(clinics.mod)[sqlFetch(dta, "CLINICS") %>% sapply(lubridate::is.POSIXct)] |
|
|
|
for (i in fechas){ |
|
|
|
clinics.mod[,i]<-lubridate::parse_date_time(clinics.mod[,i], c("d/m/Y","d/m/y","Y-m-d")) %>% as.Date() |
|
|
|
} |
|
|
|
varTypes<-rep("Date",length(fechas)) |
|
|
|
names(varTypes)<-fechas |
|
|
|
print(clinics.mod) |
|
|
|
sqlUpdate(dta, clinics.mod,"CLINICS", index="OVID") |
|
|
|
print("Tabla CLINICS modificada.") |
|
|
|
|
|
|
|
## Nuevas entradas en CLINICOS |
|
|
|
nsamples.clin<-sqlFetch(dta, "CLINICS") %>% nrow |
|
|
|
umid.new<-upd.clinics$OVID[!upd.clinics$OVID %in% (sqlFetch(dta, "CLINICS") %>% pull(OVID))] |
|
|
|
clinics.new<-upd.clinics %>% filter(OVID %in% umid.new) %>% select(-NHC) |
|
|
|
if (length(umid.new) > 0){rownames(clinics.new)<-(nsamples.clin+1):(nsamples.clin+nrow(clinics.new)) %>% as.character} |
|
|
|
|
|
|
|
### !! Atención, esto cambia la base de datos: |
|
|
|
fechas<-colnames(clinics.new)[sqlFetch(dta, "CLINICS") %>% sapply(lubridate::is.POSIXct)] |
|
|
|
for (i in fechas){ |
|
|
|
rna.sync[,i]<-lubridate::parse_date_time(rna.sync[,i], c("d/m/Y","d/m/y")) %>% as.Date() |
|
|
|
clinics.new[,i]<-lubridate::parse_date_time(clinics.new[,i], c("d/m/Y","d/m/y","Y-m-d")) %>% as.Date() |
|
|
|
} |
|
|
|
sqlSave(dta, rna.sync, tablename="RNADNA", append = T, varTypes = varTypes, rownames = F) |
|
|
|
varTypes<-rep("Date",length(fechas)) |
|
|
|
names(varTypes)<-fechas |
|
|
|
print(varTypes) |
|
|
|
print(clinics.new) |
|
|
|
sqlSave(dta, clinics.new, tablename="CLINICS", append = T, varTypes = varTypes, rownames = F) |
|
|
|
print("Tabla CLINICS sincronizada.") |
|
|
|
} |
|
|
|
}) |
|
|
|
|
|
|
|