{"version":3,"sources":["components/Login/auth.js","components/Login/Login.js","components/SaldoIndividual/SaldoIndividual.js","components/NotasVtaEmitidas/NotasVtaEmitidas.js","components/CuentaCorriente/CuentaCorriente.js","components/EstadoAvance/EstadoAvance.js","components/Home/Home.js","components/Login/protectedRoute.js","App.js","serviceWorker.js","index.js","img/logo_image_crucia.jpg","img/Logo Horizontal Blanco transparente.png"],"names":["this","authenticated","usuario","nombre","cod_concesionario","cb","Login","props","useState","setUsuario","pass","setPass","nuevoPass","setNuevoPass","incorrecto","setIncorrecto","passNuevo","setPassNuevo","passNuevoConfirm","setPassNuevoConfirm","e","a","preventDefault","url","console","log","fetch","response","json","data","length","user","items","table","auth","login","history","push","cod_cli","undefined","alert","method","headers","body","JSON","stringify","password_nuevo","Grid","textAlign","style","height","verticalAlign","Column","maxWidth","Image","src","logo","centered","Form","size","onSubmit","Segment","stacked","Input","fluid","icon","iconPosition","placeholder","name","onChange","value","type","Button","color","Message","negative","Header","Modal","as","handlePassChange","open","defaultColumnProperties","filterable","NumberFormatter","toString","replace","columns","key","width","formatter","map","c","selectors","Data","Selectors","SaldoIndividual","dataSaldo","setDataSaldo","filters","setFilters","filteredRows","rows","getRows","groupedRows","saldo","forEach","row","nro_comp","fecha","vence","debe","haber","saldo_cbte","toFixed","agregarTotalesPorGrupo","useEffect","mounted","getData","then","Menu","inverted","MenuItem","position","rowGetter","i","rowsCount","minHeight","enableCellAutoFocus","toolbar","enableFilter","filterRowsButtonText","onAddFilter","filter","newFilters","filterTerm","column","handleFilterChange","onClearFilters","warning","filename","Date","now","toLocaleString","split","NotasVtaEmitidas","fechaDesde","setFechaDesde","fechaHasta","setFechaHasta","mensajeFechas","setMensajeFechas","dataNV","setDataNV","fechaFiltro","desde","date","day","getDate","month","getMonth","year","getFullYear","Container","Group","widths","Field","label","control","event","compact","CuentaCorriente","dataCtaCte","setDataCtaCte","trim","cta_cte","basic","active","EstadoAvance","Home","renderTab","setRenderTab","handleClick","Sidebar","visible","vertical","animation","item","Item","nombre_pagina","onClick","Icon","icono","desc_item","logout","SidebarPusher","tabName","RenderedContent","About","ProtectedRoute","Component","component","rest","render","isAuthenticated","to","pathname","state","from","location","App","className","exact","path","Boolean","window","hostname","match","ReactDOM","document","getElementById","navigator","serviceWorker","ready","registration","unregister","catch","error","message","module","exports"],"mappings":"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","file":"static/js/main.334c4511.chunk.js","sourcesContent":["class Auth{\r\n constructor(){\r\n this.authenticated = false;\r\n this.usuario = [];\r\n this.nombre = '';\r\n this.cod_concesionario = 0;\r\n }\r\n\r\n login(cb){\r\n this.authenticated = true;\r\n cb();\r\n }\r\n\r\n logout(cb){\r\n this.authenticated = false;\r\n cb();\r\n }\r\n\r\n isAuthenticated(){\r\n return this.authenticated;\r\n }\r\n}\r\n\r\nexport default new Auth();","import React, { useState } from 'react';\r\nimport { Form, Grid, Image, Segment, Message, Modal } from 'semantic-ui-react';\r\nimport logo from './../../img/logo_image_crucia.jpg';\r\nimport auth from './auth';\r\n\r\nexport const Login = props => {\r\n const [usuario, setUsuario] = useState(0);\r\n const [pass, setPass] = useState(0);\r\n const [nuevoPass, setNuevoPass] = useState(0);\r\n const [incorrecto, setIncorrecto] = useState();\r\n const [passNuevo, setPassNuevo] = useState(0);\r\n const [passNuevoConfirm, setPassNuevoConfirm] = useState(0);\r\n\r\n \r\n async function onSubmit(e) {\r\n e.preventDefault();\r\n \r\n //const url = `http://192.168.87.41:8000/login/${usuario}/${pass}/`;\r\n const url = `http://webservices.crucianelli.com:8000//login/${usuario}/${pass}/`;\r\n \r\n console.log(url);\r\n\r\n //query con fetch api asincronica\r\n let response = await fetch(url, {\r\n\t 'mode': 'cors',\r\n\t 'headers': {\r\n \t'Access-Control-Allow-Origin': '*',\r\n \t}\r\n });\r\n \r\n let data = await response.json();\r\n \r\n console.log(data.length);\r\n\r\n if (data.length !== 0) {\r\n const {user, items} = data;\r\n\r\n console.log(user);\r\n console.table(items);\r\n \r\n auth.usuario = data;\r\n auth.nombre = data.user[0]['nombre'];\r\n auth.cod_concesionario = data.user[0]['cod_concesionario'];\r\n\r\n if (data.user[0]['primer_ingreso'] === 1){\r\n setNuevoPass(1);\r\n }else{\r\n auth.login(() => {\r\n props.history.push('/');\r\n });\r\n }\r\n \r\n }else{\r\n setIncorrecto(1);\r\n }\r\n \r\n }\r\n\r\n async function handlePassChange(e){\r\n \r\n e.preventDefault();\r\n\r\n var cod_cli = auth.usuario.user[0]['cod_cli'];\r\n\r\n if (passNuevo === '' || passNuevo === 0 || passNuevo === undefined) return \r\n\r\n if (passNuevo !== passNuevoConfirm){\r\n alert(\"La contraseña ingresada no coincide con su confirmación.\")\r\n }else{\r\n\r\n //const url = \"http://webservices.crucianelli.com:8000//actualizarPassword/\"\r\n const url = \"http://webservices.crucianelli.com:8000//actualizarPassword/\"\r\n\r\n //Actualizo contraseña en BD. \r\n fetch(url, {\r\n method: 'post',\r\n headers: {\r\n 'Accept': 'application/json, text/plain, */*',\r\n 'Content-Type': 'application/json'\r\n },\r\n body: JSON.stringify({\r\n cod_cli: cod_cli,\r\n password_nuevo: passNuevo\r\n })\r\n });\r\n\r\n //Actualizo state para cerrar modal\r\n setNuevoPass(0);\r\n\r\n auth.login(() => {\r\n props.history.push('/');\r\n });\r\n } \r\n }\r\n \r\n function handleChangeUsuario(e, { value }){\r\n setUsuario(value);\r\n }\r\n \r\n function handleChangePass(e, { value }){\r\n setPass(value);\r\n }\r\n\r\n function handlePassNuevo(e, { value }){\r\n setPassNuevo(value);\r\n }\r\n\r\n function handlePassNuevoConfirm(e, { value }){\r\n setPassNuevoConfirm(value);\r\n }\r\n\r\n return (\r\n
\r\n \r\n \r\n \r\n

\r\n

\r\n
\r\n \r\n \r\n \r\n \r\n Acceder\r\n \r\n \r\n
\r\n {incorrecto ? \r\n Error al intentar ingresar\r\n

Usuario y/o contraseña invalidos.

\r\n
:
}\r\n
\r\n handlePassChange(e)}\r\n open={nuevoPass}\r\n size=\"small\">\r\n \r\n \r\n \r\n

Bienvenido, antes de continuar deberá cambiar la contraseña enviada por correo.

\r\n \r\n \r\n \r\n Cambiar contraseña\r\n \r\n
\r\n
\r\n
\r\n
\r\n
\r\n );\r\n}\r\n","import React, { useState, useEffect, useReducer } from 'react';\r\nimport { Container, Message, Image, Menu, MenuItem } from 'semantic-ui-react';\r\nimport auth from './../Login/auth';\r\nimport ReactDataGrid from 'react-data-grid';\r\nimport {Toolbar, Data} from \"react-data-grid-addons\";\r\nimport { CSVLink, CSVDownload } from \"react-csv\";\r\nimport logo from '../../img/Logo Horizontal Blanco transparente.png';\r\n\r\n//Propiedades de las columnas\r\nconst defaultColumnProperties = {\r\n filterable: true\r\n };\r\n\r\n const NumberFormatter = ({ value }) => {\r\n return

$ {value.toString().replace(/\\B(?=(\\d{3})+(?!\\d))/g, \",\")}

;\r\n };\r\n \r\n //Columnas\r\n const columns = [\r\n {\r\n key: \"nro_comp\",\r\n name: \"Nro. Comp.\",\r\n width: 160\r\n },\r\n {\r\n key: \"cod\",\r\n name: \"Pto. Vta.\",\r\n width: 60\r\n },\r\n {\r\n key: \"cotizacion\",\r\n name: \"Cotiz.\",\r\n width: 60\r\n },\r\n {\r\n key: \"fecha\",\r\n name: \"Fecha\",\r\n width: 120\r\n },\r\n {\r\n key: \"vence\",\r\n name: \"Vence\",\r\n width: 120\r\n },\r\n {\r\n key: \"debe\",\r\n name: \"Debe\",\r\n width: 110,\r\n formatter: NumberFormatter\r\n },\r\n {\r\n key: \"haber\",\r\n name: \"Haber\",\r\n width: 110,\r\n formatter: NumberFormatter\r\n },\r\n {\r\n key: \"saldo_cbte\",\r\n name: \"Saldo\",\r\n width: 110,\r\n formatter: NumberFormatter\r\n }\r\n ].map(c => ({ ...c, ...defaultColumnProperties })); \r\n\r\nconst handleFilterChange = filter => filters => {\r\n const newFilters = { ...filters };\r\n if (filter.filterTerm) {\r\n newFilters[filter.column.key] = filter;\r\n } else {\r\n delete newFilters[filter.column.key];\r\n }\r\n return newFilters;\r\n};\r\n\r\nfunction agregarTotalesPorGrupo(groupedRows){\r\n var saldo = 0;\r\n\r\n groupedRows.forEach(row => {\r\n saldo += row['saldo_cbte'];\r\n })\r\n\r\n //Agrego subtotales\r\n groupedRows.push({ \r\n nro_comp: 'TOTAL',\r\n fecha: '',\r\n vence: '',\r\n debe: '',\r\n haber: '',\r\n saldo_cbte: saldo.toFixed(2) \r\n });\r\n\r\n return groupedRows;\r\n\r\n}\r\n\r\nfunction getRows(rows, filters) {\r\n return selectors.getRows({ rows, filters });\r\n} \r\n\r\nconst selectors = Data.Selectors;\r\n\r\nexport const SaldoIndividual = props => {\r\n const [dataSaldo, setDataSaldo] = useState([]);\r\n const [filters, setFilters] = useState({});\r\n \r\n const rows = dataSaldo;\r\n const rowsTotal = agregarTotalesPorGrupo(rows);\r\n const filteredRows = getRows(rowsTotal, filters); \r\n \r\n console.table(filteredRows);\r\n \r\n useEffect(() => {\r\n let mounted = true;\r\n getData()\r\n .then(items => {\r\n if(mounted) {\r\n setDataSaldo(items)\r\n }\r\n })\r\n return () => mounted = false;\r\n }, [])\r\n \r\n async function getData(){\r\n var cod_cli = auth.usuario.user[0]['cod_cli'];\r\n //var url = `http://192.168.87.41:8000/ctacte/${auth.db}/${cod_cli.trim()}?desde=${fechaDesde}&hasta=${fechaHasta}`; \r\n var url = `http://webservices.crucianelli.com:8000//saldoIndividual/${cod_cli}`; \r\n console.log(url);\r\n //query con fetch api asincronica\r\n let response = await fetch(url, {\r\n 'mode': 'cors',\r\n 'headers': {\r\n 'Access-Control-Allow-Origin': '*',\r\n }\r\n });\r\n \r\n let data = await response.json();\r\n \r\n if (data.length !== 0) {\r\n return data; \r\n }\r\n }\r\n\r\n return ( \r\n
\r\n \r\n

Saldo Individual

\r\n
{auth.nombre}
\r\n \r\n
\r\n filteredRows[i]}\r\n rowsCount={filteredRows.length}\r\n minHeight={500}\r\n enableCellAutoFocus={false}\r\n toolbar={}\r\n onAddFilter={filter => setFilters(handleFilterChange(filter))}\r\n onClearFilters={() => setFilters({})}\r\n />\r\n \r\n Punto de venta 0020 correspondiente a facturas en dolares expresadas en pesos. \r\n Para estas facturas se tomará la cotización del dólar del efectivo pago.\r\n \r\n Exportar a Excel.\r\n
)\r\n} ","\r\nimport React, { useState, useEffect, useReducer } from 'react';\r\nimport { Container, Form, Button, Menu, MenuItem, Message, Input, Image } from 'semantic-ui-react';\r\nimport auth from './../Login/auth';\r\nimport ReactDataGrid from 'react-data-grid';\r\nimport {Toolbar, Data} from \"react-data-grid-addons\";\r\nimport createRowData from \"./createRowData\";\r\nimport { CSVLink, CSVDownload } from \"react-csv\";\r\nimport logo from '../../img/Logo Horizontal Blanco transparente.png';\r\n\r\n //Propiedades de las columnas\r\n const defaultColumnProperties = {\r\n filterable: true\r\n };\r\n\r\n const NumberFormatter = ({ value, row }) => {\r\n \r\n return

US$ {value.toString().replace(/\\B(?=(\\d{3})+(?!\\d))/g, \",\")}

;\r\n\r\n };\r\n\r\n const PorcentajeFormatter = ({ value, row }) => {\r\n \r\n return

{value.toString()} %

;\r\n\r\n };\r\n \r\n //Columnas\r\n const columns = [\r\n {\r\n key: \"nro_vta\",\r\n name: \"Nro. Vta.\",\r\n width: 100\r\n },\r\n {\r\n key: \"fecha\",\r\n name: \"Fecha\",\r\n width: 110\r\n },\r\n {\r\n key: \"cliente\",\r\n name: \"Cliente\"\r\n },\r\n {\r\n key: \"nom_maquina\",\r\n name: \"Maquina\"\r\n },\r\n {\r\n key: \"total\",\r\n name: \"Total\",\r\n width: 150,\r\n formatter: NumberFormatter\r\n },\r\n {\r\n key: \"pagado\",\r\n name: \"Pagado\",\r\n width: 150,\r\n formatter: NumberFormatter\r\n },\r\n {\r\n key: \"saldo\",\r\n name: \"Saldo\",\r\n width: 150,\r\n formatter: NumberFormatter\r\n },\r\n {\r\n key: \"porcentaje\",\r\n name: \"Porc.\",\r\n width: 60,\r\n formatter: PorcentajeFormatter\r\n }\r\n ].map(c => ({ ...c, ...defaultColumnProperties })); \r\n\r\nconst handleFilterChange = filter => filters => {\r\n const newFilters = { ...filters };\r\n if (filter.filterTerm) {\r\n newFilters[filter.column.key] = filter;\r\n } else {\r\n delete newFilters[filter.column.key];\r\n }\r\n return newFilters;\r\n};\r\n\r\nfunction getRows(rows, filters) {\r\n return selectors.getRows({ rows, filters });\r\n} \r\n\r\nconst selectors = Data.Selectors;\r\n\r\nexport const NotasVtaEmitidas = props => { \r\n const [fechaDesde, setFechaDesde] = useState();\r\n const [fechaHasta, setFechaHasta] = useState(); \r\n const [mensajeFechas, setMensajeFechas] = useState(0);\r\n const [dataNV, setDataNV] = useState([]);\r\n const [filters, setFilters] = useState({});\r\n \r\n const rows = dataNV;\r\n const filteredRows = getRows(dataNV, filters); \r\n \r\n console.table(filteredRows);\r\n\r\n useEffect(() => {\r\n setFechaDesde(fechaFiltro(true)); \r\n setFechaHasta(fechaFiltro(false)); \r\n }, [])\r\n\r\n function fechaFiltro(desde){\r\n let date = new Date()\r\n let day = date.getDate()\r\n let month = date.getMonth() + 1\r\n let year = date.getFullYear()\r\n\r\n if (desde) year --;\r\n\r\n if (day < 10) day = '0' + day\r\n if (month < 10) month = '0' + month\r\n\r\n return `${year}-${month}-${day}`\r\n\r\n }\r\n\r\n function handleFechaDesde(event, {name, value}){\r\n setFechaDesde(value);\r\n}\r\n\r\nfunction handleFechaHasta(event, {name, value}){\r\n setFechaHasta(value);\r\n}\r\n\r\nasync function onSubmit(e){\r\n e.preventDefault();\r\n var cod_cli = auth.usuario.user[0]['cod_cli'];\r\n\r\n if (fechaDesde === 0 || fechaHasta === 0){\r\n setMensajeFechas(1);\r\n return;\r\n }\r\n\r\n setMensajeFechas(0);\r\n \r\n //var url = `http://webservices.crucianelli.com:8000//notasVtaEmitidas/${auth.cod_concesionario}?desde=${fechaDesde}&hasta=${fechaHasta}`; \r\n var url = `http://webservices.crucianelli.com:8000//notasVtaEmitidas/${auth.cod_concesionario}?desde=${fechaDesde}&hasta=${fechaHasta}`; \r\n\r\n console.log(url);\r\n\r\n //query con fetch api asincronica\r\n let response = await fetch(url, {\r\n 'mode': 'cors',\r\n 'headers': {\r\n 'Access-Control-Allow-Origin': '*',\r\n }\r\n });\r\n \r\n let data = await response.json();\r\n \r\n if (data.length !== 0) {\r\n setDataNV(data);\r\n //console.table(data.cta_cte) \r\n }\r\n}\r\n \r\n return ( \r\n
\r\n \r\n

Notas de Venta Emitidas

\r\n
{auth.nombre}
\r\n \r\n
\r\n \r\n
\r\n \r\n \r\n \r\n \r\n \r\n
\r\n {mensajeFechas?\r\n Ingrese un rango de fechas válido\r\n :
}\r\n
\r\n filteredRows[i]}\r\n rowsCount={filteredRows.length}\r\n minHeight={500}\r\n enableCellAutoFocus={false}\r\n toolbar={}\r\n onAddFilter={filter => setFilters(handleFilterChange(filter))}\r\n onClearFilters={() => setFilters({})}\r\n />\r\n Exportar a Excel.\r\n
)\r\n} \r\n\r\n","import React, { useState, useEffect } from 'react';\r\nimport { Container, Form, Button, Menu, MenuItem, Input, Message, Image } from 'semantic-ui-react';\r\nimport auth from './../Login/auth';\r\nimport ReactDataGrid from 'react-data-grid';\r\nimport {Toolbar, Data} from \"react-data-grid-addons\";\r\nimport { CSVLink, CSVDownload } from \"react-csv\";\r\nimport logo from '../../img/Logo Horizontal Blanco transparente.png';\r\n\r\n//Propiedades de las columnas\r\nconst defaultColumnProperties = {\r\n filterable: true\r\n };\r\n \r\n const NumberFormatter = ({ value }) => {\r\n return

$ {value.toString().replace(/\\B(?=(\\d{3})+(?!\\d))/g, \",\")}

;\r\n };\r\n\r\n //Columnas\r\n const columns = [\r\n {\r\n key: \"nro_comp\",\r\n name: \"Nro. Comp.\",\r\n width: 160\r\n },\r\n {\r\n key: \"cod\",\r\n name: \"Pto. Vta.\",\r\n width: 70\r\n },\r\n {\r\n key: \"cotizacion\",\r\n name: \"Cotiz.\",\r\n width: 60\r\n },\r\n {\r\n key: \"fecha\",\r\n name: \"Fecha\",\r\n width: 120\r\n },\r\n {\r\n key: \"vence\",\r\n name: \"Vence\",\r\n width: 120\r\n },\r\n {\r\n key: \"debe\",\r\n name: \"Debe\",\r\n width: 110,\r\n formatter: NumberFormatter\r\n },\r\n {\r\n key: \"haber\",\r\n name: \"Haber\",\r\n width: 110,\r\n formatter: NumberFormatter\r\n },\r\n {\r\n key: \"saldo\",\r\n name: \"Saldo\",\r\n width: 110,\r\n formatter: NumberFormatter\r\n }\r\n ].map(c => ({ ...c, ...defaultColumnProperties })); \r\n\r\nconst handleFilterChange = filter => filters => {\r\n const newFilters = { ...filters };\r\n if (filter.filterTerm) {\r\n newFilters[filter.column.key] = filter;\r\n } else {\r\n delete newFilters[filter.column.key];\r\n }\r\n return newFilters;\r\n};\r\n\r\nconst selectors = Data.Selectors;\r\n\r\nfunction getRows(rows, filters) {\r\n return selectors.getRows({ rows, filters });\r\n} \r\n\r\nexport const CuentaCorriente = props => {\r\n const [fechaDesde, setFechaDesde] = useState();\r\n const [fechaHasta, setFechaHasta] = useState();\r\n const [dataCtaCte, setDataCtaCte] = useState([]);\r\n const [mensajeFechas, setMensajeFechas] = useState(0);\r\n const [filters, setFilters] = useState({});\r\n\r\n const rows = dataCtaCte;\r\n const filteredRows = getRows(dataCtaCte, filters); \r\n\r\n useEffect(() => {\r\n setFechaDesde(fechaFiltro(true)); \r\n setFechaHasta(fechaFiltro(false)); \r\n }, [])\r\n \r\n function fechaFiltro(desde){\r\n let date = new Date()\r\n let day = date.getDate()\r\n let month = date.getMonth() + 1\r\n let year = date.getFullYear()\r\n \r\n if (desde) year --;\r\n\r\n if (day < 10) day = '0' + day\r\n if (month < 10) month = '0' + month\r\n \r\n return `${year}-${month}-${day}`\r\n\r\n }\r\n\r\n function handleFechaDesde(event, {name, value}){\r\n setFechaDesde(value);\r\n }\r\n\r\n function handleFechaHasta(event, {name, value}){\r\n setFechaHasta(value);\r\n }\r\n\r\n async function onSubmit(e){\r\n e.preventDefault();\r\n var cod_cli = auth.usuario.user[0]['cod_cli'];\r\n\r\n if (fechaDesde === 0 || fechaHasta === 0){\r\n setMensajeFechas(1);\r\n return;\r\n }\r\n\r\n setMensajeFechas(0);\r\n \r\n //var url = `http://192.168.87.41:8000/ctacte/${auth.db}/${cod_cli.trim()}?desde=${fechaDesde}&hasta=${fechaHasta}`; \r\n var url = `http://webservices.crucianelli.com:8000//ctacte/${cod_cli.trim()}?desde=${fechaDesde}&hasta=${fechaHasta}`; \r\n\r\n console.log(url);\r\n\r\n //query con fetch api asincronica\r\n let response = await fetch(url, {\r\n\t 'mode': 'cors',\r\n\t 'headers': {\r\n \t'Access-Control-Allow-Origin': '*',\r\n \t}\r\n });\r\n \r\n let data = await response.json();\r\n \r\n if (data.length !== 0) {\r\n setDataCtaCte(data.cta_cte);\r\n //console.table(data.cta_cte) \r\n }\r\n }\r\n\r\n function numberWithCommas(x) {\r\n return x.toString().replace(/\\B(?=(\\d{3})+(?!\\d))/g, \",\");\r\n }\r\n\r\n return (\r\n
\r\n \r\n

Cuenta Corriente

\r\n
{auth.nombre}
\r\n \r\n
\r\n \r\n
\r\n \r\n \r\n \r\n \r\n \r\n
\r\n {mensajeFechas?\r\n Ingrese un rango de fechas válido\r\n :
}\r\n \r\n
\r\n filteredRows[i]}\r\n rowsCount={filteredRows.length}\r\n minHeight={500}\r\n enableCellAutoFocus={false}\r\n toolbar={}\r\n onAddFilter={filter => setFilters(handleFilterChange(filter))}\r\n onClearFilters={() => setFilters({})}\r\n />\r\n \r\n Punto de venta 0020 correspondiente a facturas en dolares expresadas en pesos. \r\n Para estas facturas se tomará la cotización del dólar del efectivo pago.\r\n \r\n Exportar a Excel.\r\n
\r\n );\r\n} ","import React, { useState, useEffect, useReducer } from 'react';\r\nimport { Image, Form, Button, Menu, MenuItem } from 'semantic-ui-react';\r\nimport auth from './../Login/auth';\r\nimport ReactDataGrid from 'react-data-grid';\r\nimport {Toolbar, Data} from \"react-data-grid-addons\";\r\nimport { CSVLink, CSVDownload } from \"react-csv\";\r\nimport logo from '../../img/Logo Horizontal Blanco transparente.png';\r\n\r\n//Propiedades de las columnas\r\nconst defaultColumnProperties = {\r\n filterable: true\r\n };\r\n \r\n const EstadoFormatter = ({ value }) => {\r\n return \r\n };\r\n\r\n //Columnas\r\n const columns = [\r\n {\r\n key: \"nro_vta\",\r\n name: \"Nro. Vta.\",\r\n width: 100\r\n },\r\n {\r\n key: \"fecha\",\r\n name: \"Fecha\",\r\n width: 110\r\n },\r\n {\r\n key: \"cliente\",\r\n name: \"Cliente\",\r\n width: 200\r\n },\r\n {\r\n key: \"orden_fab\",\r\n name: \"Orden Fab.\",\r\n width: 100\r\n },\r\n {\r\n key: \"maquina\",\r\n name: \"Maquina\",\r\n width: 150\r\n },\r\n {\r\n key: \"estado_chasis\",\r\n name: \"Estado\",\r\n width: 150,\r\n formatter: EstadoFormatter\r\n },\r\n {\r\n key: \"cod_vendedor\",\r\n name: \"Zona\",\r\n width: 100\r\n }\r\n ].map(c => ({ ...c, ...defaultColumnProperties })); \r\n\r\nconst handleFilterChange = filter => filters => {\r\n const newFilters = { ...filters };\r\n if (filter.filterTerm) {\r\n newFilters[filter.column.key] = filter;\r\n } else {\r\n delete newFilters[filter.column.key];\r\n }\r\n return newFilters;\r\n};\r\n\r\nfunction getRows(rows, filters) {\r\n return selectors.getRows({ rows, filters });\r\n} \r\n\r\nconst selectors = Data.Selectors;\r\n\r\nexport const EstadoAvance = props => {\r\n const [dataNV, setDataNV] = useState([]);\r\n const [filters, setFilters] = useState({});\r\n \r\n const rows = dataNV;\r\n const filteredRows = getRows(rows, filters); \r\n \r\n console.table(filteredRows);\r\n \r\n useEffect(() => {\r\n let mounted = true;\r\n getData()\r\n .then(items => {\r\n if(mounted) {\r\n setDataNV(items)\r\n }\r\n })\r\n return () => mounted = false;\r\n }, [])\r\n \r\n async function getData(){\r\n //var url = `http://192.168.87.41:8000/ctacte/${auth.db}/${cod_cli.trim()}?desde=${fechaDesde}&hasta=${fechaHasta}`; \r\n var url = `http://webservices.crucianelli.com:8000//estadoAvance/${auth.cod_concesionario}`; \r\n \r\n //query con fetch api asincronica\r\n let response = await fetch(url, {\r\n 'mode': 'cors',\r\n 'headers': {\r\n 'Access-Control-Allow-Origin': '*',\r\n }\r\n });\r\n \r\n let data = await response.json();\r\n \r\n if (data.length !== 0) {\r\n return data; \r\n }\r\n }\r\n\r\n return ( \r\n
\r\n \r\n

Estado Avance

\r\n
{auth.nombre}
\r\n \r\n
\r\n filteredRows[i]}\r\n rowsCount={filteredRows.length}\r\n minHeight={500}\r\n enableCellAutoFocus={false}\r\n toolbar={}\r\n onAddFilter={filter => setFilters(handleFilterChange(filter))}\r\n onClearFilters={() => setFilters({})}\r\n />\r\n Exportar a Excel.\r\n
)\r\n} ","import React, { useState, useEffect } from 'react';\r\nimport { Icon, Menu, Sidebar, SidebarPusher } from 'semantic-ui-react';\r\nimport 'semantic-ui-css/semantic.min.css';\r\nimport auth from './../Login/auth';\r\nimport { SaldoIndividual } from './../SaldoIndividual/SaldoIndividual';\r\nimport { NotasVtaEmitidas } from './../NotasVtaEmitidas/NotasVtaEmitidas';\r\nimport { CuentaCorriente } from './../CuentaCorriente/CuentaCorriente';\r\nimport { EstadoAvance } from '../EstadoAvance/EstadoAvance';\r\n\r\nexport const Home = props => {\r\n const [renderTab, setRenderTab] = useState('');\r\n //const [items, setItems] = useState(0);\r\n\r\n // De forma similar a componentDidMount y componentDidUpdate\r\n useEffect(() => {\r\n //setItems(auth.items);\r\n });\r\n\r\n function handleLogout(){\r\n auth.logout(() => {\r\n props.history.push(\"/\");\r\n });\r\n }\r\n\r\n function handleClick (e, { name }) {\r\n e.preventDefault();\r\n setRenderTab(name);\r\n };\r\n \r\n return(\r\n
\r\n \r\n \r\n
\r\n {auth.usuario.items.map((item) =>{ \r\n return(\r\n \r\n \r\n {item.desc_item}\r\n \r\n )})} \r\n
\r\n \r\n \r\n Cerrar Sesión\r\n \r\n
\r\n \r\n \r\n \r\n
\r\n );\r\n}\r\n\r\nconst RenderedContent = (tabName) => {\r\n \r\n if (tabName.tabName === 'ctacte') {\r\n return \r\n }\r\n if (tabName.tabName === 'avance') {\r\n return \r\n }\r\n if (tabName.tabName === 'nvemitidas') {\r\n return \r\n }if (tabName.tabName === 'saldo') {\r\n return \r\n }else {\r\n return \r\n }\r\n \r\n}\r\n\r\nconst About = () => (\r\n
\r\n Bienvenido
{auth.nombre}
\r\n
\r\n)","import React from 'react';\r\nimport { Route, Redirect } from 'react-router-dom';\r\nimport auth from './auth';\r\n\r\nexport const ProtectedRoute = ({component: Component, ...rest}) => {\r\n return (\r\n {\r\n if (auth.isAuthenticated()){\r\n return \r\n }else{\r\n return \r\n } \r\n }\r\n } />\r\n );\r\n};\r\n","import React from 'react';\nimport { Switch, Route } from 'react-router-dom';\nimport './App.css';\nimport {Login} from './components/Login/Login';\nimport {Home} from './components/Home/Home';\nimport { ProtectedRoute } from './components/Login/protectedRoute';\n\nfunction App() {\n return (\n
\n \n \n \n \n
\n );\n}\n\nexport default App;\n","// This optional code is used to register a service worker.\n// register() is not called by default.\n\n// This lets the app load faster on subsequent visits in production, and gives\n// it offline capabilities. However, it also means that developers (and users)\n// will only see deployed updates on subsequent visits to a page, after all the\n// existing tabs open on the page have been closed, since previously cached\n// resources are updated in the background.\n\n// To learn more about the benefits of this model and instructions on how to\n// opt-in, read https://bit.ly/CRA-PWA\n\nconst isLocalhost = Boolean(\n window.location.hostname === 'localhost' ||\n // [::1] is the IPv6 localhost address.\n window.location.hostname === '[::1]' ||\n // 127.0.0.0/8 are considered localhost for IPv4.\n window.location.hostname.match(\n /^127(?:\\.(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)){3}$/\n )\n);\n\nexport function register(config) {\n if (process.env.NODE_ENV === 'production' && 'serviceWorker' in navigator) {\n // The URL constructor is available in all browsers that support SW.\n const publicUrl = new URL(process.env.PUBLIC_URL, window.location.href);\n if (publicUrl.origin !== window.location.origin) {\n // Our service worker won't work if PUBLIC_URL is on a different origin\n // from what our page is served on. This might happen if a CDN is used to\n // serve assets; see https://github.com/facebook/create-react-app/issues/2374\n return;\n }\n\n window.addEventListener('load', () => {\n const swUrl = `${process.env.PUBLIC_URL}/service-worker.js`;\n\n if (isLocalhost) {\n // This is running on localhost. Let's check if a service worker still exists or not.\n checkValidServiceWorker(swUrl, config);\n\n // Add some additional logging to localhost, pointing developers to the\n // service worker/PWA documentation.\n navigator.serviceWorker.ready.then(() => {\n console.log(\n 'This web app is being served cache-first by a service ' +\n 'worker. To learn more, visit https://bit.ly/CRA-PWA'\n );\n });\n } else {\n // Is not localhost. Just register service worker\n registerValidSW(swUrl, config);\n }\n });\n }\n}\n\nfunction registerValidSW(swUrl, config) {\n navigator.serviceWorker\n .register(swUrl)\n .then(registration => {\n registration.onupdatefound = () => {\n const installingWorker = registration.installing;\n if (installingWorker == null) {\n return;\n }\n installingWorker.onstatechange = () => {\n if (installingWorker.state === 'installed') {\n if (navigator.serviceWorker.controller) {\n // At this point, the updated precached content has been fetched,\n // but the previous service worker will still serve the older\n // content until all client tabs are closed.\n console.log(\n 'New content is available and will be used when all ' +\n 'tabs for this page are closed. See https://bit.ly/CRA-PWA.'\n );\n\n // Execute callback\n if (config && config.onUpdate) {\n config.onUpdate(registration);\n }\n } else {\n // At this point, everything has been precached.\n // It's the perfect time to display a\n // \"Content is cached for offline use.\" message.\n console.log('Content is cached for offline use.');\n\n // Execute callback\n if (config && config.onSuccess) {\n config.onSuccess(registration);\n }\n }\n }\n };\n };\n })\n .catch(error => {\n console.error('Error during service worker registration:', error);\n });\n}\n\nfunction checkValidServiceWorker(swUrl, config) {\n // Check if the service worker can be found. If it can't reload the page.\n fetch(swUrl, {\n headers: { 'Service-Worker': 'script' },\n })\n .then(response => {\n // Ensure service worker exists, and that we really are getting a JS file.\n const contentType = response.headers.get('content-type');\n if (\n response.status === 404 ||\n (contentType != null && contentType.indexOf('javascript') === -1)\n ) {\n // No service worker found. Probably a different app. Reload the page.\n navigator.serviceWorker.ready.then(registration => {\n registration.unregister().then(() => {\n window.location.reload();\n });\n });\n } else {\n // Service worker found. Proceed as normal.\n registerValidSW(swUrl, config);\n }\n })\n .catch(() => {\n console.log(\n 'No internet connection found. App is running in offline mode.'\n );\n });\n}\n\nexport function unregister() {\n if ('serviceWorker' in navigator) {\n navigator.serviceWorker.ready\n .then(registration => {\n registration.unregister();\n })\n .catch(error => {\n console.error(error.message);\n });\n }\n}\n","import React from 'react';\nimport ReactDOM from 'react-dom';\nimport { BrowserRouter } from 'react-router-dom';\nimport './index.css';\nimport App from './App';\nimport * as serviceWorker from './serviceWorker';\nimport 'semantic-ui-css/semantic.min.css';\nimport 'bootstrap/dist/css/bootstrap.min.css';\n\n\nReactDOM.render(\n \n \n ,\n document.getElementById('root')\n);\n\n// If you want your app to work offline and load faster, you can change\n// unregister() to register() below. Note this comes with some pitfalls.\n// Learn more about service workers: https://bit.ly/CRA-PWA\nserviceWorker.unregister();\n","module.exports = \"\"","module.exports = __webpack_public_path__ + \"static/media/Logo Horizontal Blanco transparente.4ef5577c.png\";"],"sourceRoot":""}