No Description

Datos.js 7.7KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296
  1. import React, {useState} from 'react';
  2. import { View, Text, Pressable, StyleSheet, Alert} from 'react-native';
  3. import DropDownPicker from 'react-native-dropdown-picker';
  4. import {styles} from "./styles"
  5. var table = ""
  6. var pueblo = ""
  7. //where data will be stored
  8. var information
  9. function Picker() {
  10. //table to pick from
  11. const [openTable, setOpenTable] = useState(false);
  12. const [valueTable, setValueTable] = useState(null);
  13. const [table, setTable] = useState([
  14. {label:'DP02PR', value: 'DP02PR'},
  15. {label:'DP03', value: 'DP03'},
  16. {label:'DP04', value: 'DP04'},
  17. {label:'DP05', value: 'DP05'},
  18. ]);
  19. //cambiar pueblo
  20. //pueblo
  21. const [openPueblo, setOpenPueblo] = useState(false);
  22. const [valuePueblo, setValuePueblo] = useState(null);
  23. const [pueblo, setPueblo] = useState([
  24. {label: 'Adjuntas', value: '001'},
  25. {label: 'Aguada', value: '003'},
  26. {label: 'Aguadillas', value: '005'},
  27. {label: 'Aguas Buenas', value: '007'},
  28. {label: 'Aibonito', value: '009'},
  29. {label: 'Añasco', value: '011'},
  30. {label: 'Arecibo', value: '013'},
  31. {label: 'Arroyo', value: '015'},
  32. {label: 'Barceloneta', value: '017'},
  33. {label: 'Barranquitas', value: '019'},
  34. {label: 'Bayamón', value: '021'},
  35. {label: 'Cabo Rojo', value: '023'},
  36. {label: 'Caguas', value: '025'},
  37. {label: 'Camuy', value: '027'},
  38. {label: 'Canóvanas', value: '029'},
  39. {label: 'Carolina', value: '031'},
  40. {label: 'Cataño', value: '033'},
  41. {label: 'Cayey', value: '035'},
  42. {label: 'Ceiba', value: '037'},
  43. {label: 'Ciales', value: '039'},
  44. {label: 'Cidra', value: '041'},
  45. {label: 'Coamo', value: '043'},
  46. {label: 'Comerío', value: '045'},
  47. {label: 'Corozal', value: '047'},
  48. {label: 'Culebra', value: '049'},
  49. {label: 'Dorado', value: '051'},
  50. {label: 'Fajardo', value: '053'},
  51. {label: 'Florida', value: '054'},
  52. {label: 'Guánica', value: '055'},
  53. {label: 'Guayama', value: '057'},
  54. {label: 'Guayanilla', value: '059'},
  55. {label: 'Guaynabo', value: '061'},
  56. {label: 'Gurabo', value: '063'},
  57. {label: 'Hatillo', value: '065'},
  58. {label: 'Hormigueros', value: '067'},
  59. {label: 'Humacao', value: '069'},
  60. {label: 'Isabela', value: '071'},
  61. {label: 'Jayuya', value: '073'},
  62. {label: 'Juana Díaz', value: '075'},
  63. {label: 'Juncos', value: '077'},
  64. {label: 'Lajas', value: '079'},
  65. {label: 'Lares', value: '081'},
  66. {label: 'Las Marías', value: '083'},
  67. {label: 'Las Piedras', value: '085'},
  68. {label: 'Loíza', value: '087'},
  69. {label: 'Luquillo', value: '089'},
  70. {label: 'Manatí', value: '091'},
  71. {label: 'Maricao', value: '093'},
  72. {label: 'Maunabo', value: '095'},
  73. {label: 'Mayagüez', value: '097'},
  74. {label: 'Moca', value: '099'},
  75. {label: 'Morovis', value: '101'},
  76. {label: 'Naguabo', value: '103'},
  77. {label: 'Naranjito', value: '105'},
  78. {label: 'Orocovis', value: '107'},
  79. {label: 'Patillas', value: '109'},
  80. {label: 'Peñuelas', value: '111'},
  81. {label: 'Ponce', value: '113'},
  82. {label: 'Quebradillas', value: '115'},
  83. {label: 'Rincón', value: '117'},
  84. {label: 'Río Grande', value: '119'},
  85. {label: 'Sabana Grande', value: '121'},
  86. {label: 'Salinas', value: '123'},
  87. {label: 'San Germán', value: '125'},
  88. {label: 'San Juan', value: '127'},
  89. {label: 'San Lorenzo', value: '129'},
  90. {label: 'San Sebastián', value: '131'},
  91. {label: 'Santa Isabel', value: '133'},
  92. {label: 'Toa Alta', value: '135'},
  93. {label: 'Toa Baja', value: '137'},
  94. {label: 'Trujillo Alto', value: '139'},
  95. {label: 'Utuado', value: '141'},
  96. {label: 'Vega Alta', value: '143'},
  97. {label: 'Vega Baja', value: '145'},
  98. {label: 'Vieques', value: '147'},
  99. {label: 'Villalba', value: '149'},
  100. {label: 'Yabucoa', value: '151'},
  101. {label: 'Yauco', value: '153'}
  102. ]);
  103. return (
  104. <View>
  105. <DropDownPicker
  106. open={openTable}
  107. value={valueTable}
  108. items={table}
  109. setOpen={setOpenTable}
  110. setValue={setValueTable}
  111. setItems={setTable}
  112. onChangeValue = {(valueTable) => {
  113. updateTable(valueTable);
  114. }}
  115. onOpen = {() => {setOpenPueblo(false)}}
  116. zIndex={3000}
  117. zIndexInverse={1000}
  118. placeholder="Tabla de Datos"
  119. />
  120. <DropDownPicker
  121. searchable={true}
  122. open={openPueblo}
  123. value={valuePueblo}
  124. items={pueblo}
  125. setOpen={setOpenPueblo}
  126. setValue={setValuePueblo}
  127. setItems={setPueblo}
  128. onChangeValue = {(valuePueblo) => {
  129. updatePueblo(valuePueblo);
  130. }}
  131. onOpen = {() => {setOpenTable(false)}}
  132. zIndex={1000}
  133. zIndexInverse={3000}
  134. placeholder="Pueblo"
  135. searchPlaceholder="Busqueda..."
  136. />
  137. </View>
  138. );
  139. }
  140. function updateTable(value){
  141. table = value
  142. }
  143. function updatePueblo(value){
  144. pueblo = value
  145. }
  146. //calls data query
  147. function loadDoc(query) {
  148. console.log("load")
  149. var xhttp = new XMLHttpRequest();
  150. xhttp.onreadystatechange = function() {
  151. if (this.readyState == 4) {
  152. information = this.responseText;
  153. if(this.status == 200){console.log("received response");organize()}
  154. }
  155. }
  156. xhttp.open("GET", query, true);
  157. xhttp.send(null);
  158. }
  159. function fetchData() {
  160. var query = "http://127.0.0.1:5378/table?table=" + table + "&municipality=" + pueblo
  161. if(pueblo && table)
  162. {loadDoc(query)}
  163. else
  164. {Alert.alert("Please fill every parameter before calling!")}
  165. }
  166. //organize data make it pretty
  167. //add loading thing while this organizes all the data !!!
  168. function organize(){
  169. console.log(information)
  170. let bigData = JSON.parse(information)
  171. /*
  172. var stringDiv = JSON.stringify(information)
  173. stringDiv = stringDiv.replace('[[', '');
  174. stringDiv = stringDiv.replace(']]', '');
  175. stringDiv = stringDiv.split(',')
  176. //create smaller array variables
  177. let variables = []
  178. let value = []
  179. let est = []
  180. //theres a better way to do this but im not fixing it rn
  181. for(let i = 0; i<stringDiv.length; i++){
  182. if(i<stringDiv.length/3)
  183. {variables.push(stringDiv[i])}
  184. else if(i<stringDiv.length/3*2)
  185. {value.push(stringDiv[i])}
  186. else
  187. {est.push(stringDiv[i])}
  188. }
  189. //anyways this to format it
  190. console.log("vars:",variables)
  191. console.log("val:",value)
  192. console.log("est:",est)
  193. */
  194. }
  195. function json_2_csv(information){
  196. const csv = parse(obj);
  197. console.log(csv);
  198. }
  199. //fix
  200. DropDownPicker.setListMode("SCROLLVIEW")
  201. //data parsing goes here
  202. function getInfo(){
  203. if(!information)
  204. {Alert.alert("Please try again later! Error retriving data")}
  205. else
  206. {return information}
  207. }
  208. //data display
  209. class DataButton extends React.Component{
  210. state = {
  211. updated: 1,
  212. notUpdated: 0
  213. }
  214. pullData = () => {fetchData(); this.setState({current: 1})}
  215. //the reason you need to press the button twice is bc the http request doesnt finish in time
  216. //for information to be updated before its rerendered
  217. componentDidUpdate(){
  218. console.log(this.state)
  219. if(this.state.current == 1){
  220. console.log("updating")
  221. this.setState({current: 0})
  222. }
  223. }
  224. state = {current: 0}
  225. render() {
  226. return(
  227. <View style = {styles.container}>
  228. <Pressable style={styles.buttons} onPress = {this.pullData}>
  229. <Text style={styles.text}> Fetch Data</Text>
  230. </Pressable>
  231. <Text style={styles.sub}>{information}</Text>
  232. </View>
  233. );
  234. }
  235. }
  236. export { Picker, updateTable, updatePueblo,loadDoc,fetchData,DataButton};