2021-01-14 23:24:55 +00:00
|
|
|
import { estilosGlobales } from "../Estilos";
|
|
|
|
import { StyleSheet, css } from "aphrodite";
|
2021-01-15 00:49:21 +00:00
|
|
|
import { Tabla } from "./Tabla";
|
2021-03-04 13:02:33 +00:00
|
|
|
import { mostrarDescansos } from "../Store";
|
2021-03-03 14:56:22 +00:00
|
|
|
import { EstadoLayout } from "./ContenedorHorarios";
|
2021-03-19 00:51:35 +00:00
|
|
|
import { Switch, Match, For, createMemo, createSignal, SetStateFunction } from "solid-js";
|
2021-03-04 13:02:33 +00:00
|
|
|
import { BotonMaxMin } from "./BotonMaxMin";
|
2021-03-11 16:25:02 +00:00
|
|
|
import { BotonIcono } from "./BotonIcono";
|
2021-03-18 00:03:10 +00:00
|
|
|
import { Curso, Cursos, ListaCursosUsuario } from "../types/DatosHorario";
|
|
|
|
import { CursosElem } from "./CursosElem";
|
2021-01-14 23:24:55 +00:00
|
|
|
|
2021-03-04 13:02:33 +00:00
|
|
|
interface MiHorarioProps {
|
|
|
|
estadoLayout: EstadoLayout,
|
2021-03-11 13:52:21 +00:00
|
|
|
setEstadoLayout: (v: EstadoLayout) => EstadoLayout,
|
2021-03-18 00:03:10 +00:00
|
|
|
cursosUsuario: ListaCursosUsuario,
|
|
|
|
fnAgregarCurso: (c: Curso) => void,
|
2021-03-19 00:51:35 +00:00
|
|
|
setCursosUsuarios: SetStateFunction<ListaCursosUsuario>
|
2021-03-11 13:52:21 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
const e = StyleSheet.create({
|
|
|
|
horario: {},
|
|
|
|
boton: {
|
|
|
|
textDecoration: "none",
|
|
|
|
// paddingRight: "0.5rem",
|
|
|
|
"::before": {
|
|
|
|
fontSize: "1rem",
|
|
|
|
// transform: "translateY(0.2rem)",
|
|
|
|
textDecoration: "none"
|
2021-01-15 13:34:24 +00:00
|
|
|
}
|
2021-03-11 13:52:21 +00:00
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
export function MiHorario(props: MiHorarioProps) {
|
2021-03-18 00:03:10 +00:00
|
|
|
const [idHover, setIdHover] = createSignal("");
|
2021-03-11 13:52:21 +00:00
|
|
|
|
|
|
|
const datosMiHorario = createMemo(() => {
|
2021-03-17 23:24:36 +00:00
|
|
|
const obj: Cursos = {};
|
2021-03-24 17:29:03 +00:00
|
|
|
props.cursosUsuario.cursos.forEach((x, i) => {
|
|
|
|
obj[i] = x;
|
2021-03-11 13:52:21 +00:00
|
|
|
});
|
|
|
|
return obj;
|
2021-01-14 23:24:55 +00:00
|
|
|
});
|
|
|
|
|
2021-03-04 13:02:33 +00:00
|
|
|
const fnMaximizar = () => props.setEstadoLayout("MaxPersonal");
|
|
|
|
const fnMinimizar = () => props.setEstadoLayout("Normal");
|
|
|
|
const estadoActualLayout = () => props.estadoLayout;
|
2021-03-03 14:56:22 +00:00
|
|
|
|
2021-03-16 18:33:12 +00:00
|
|
|
/* TODO: En barra superior colocar todos los horarios. En barra inferior el horario
|
|
|
|
actual.
|
|
|
|
Al hacer click en un horario de la barra superior, llevarlo al inicio de la lista.
|
|
|
|
*/
|
2021-03-04 13:02:33 +00:00
|
|
|
return <div>
|
2021-03-03 14:56:22 +00:00
|
|
|
<Switch>
|
2021-03-04 13:02:33 +00:00
|
|
|
<Match when={props.estadoLayout === "Normal" || props.estadoLayout === "MaxPersonal"}>
|
2021-03-11 16:25:02 +00:00
|
|
|
|
|
|
|
<div>
|
|
|
|
<div className={css(
|
|
|
|
estilosGlobales.inlineBlock,
|
|
|
|
estilosGlobales.contenedor
|
|
|
|
)}>
|
|
|
|
Mi horario
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
2021-03-03 14:56:22 +00:00
|
|
|
<div>
|
|
|
|
<div className={css(
|
|
|
|
estilosGlobales.inlineBlock,
|
|
|
|
estilosGlobales.contenedor
|
|
|
|
)}>
|
|
|
|
Mi horario
|
|
|
|
</div>
|
2021-03-04 13:02:33 +00:00
|
|
|
|
|
2021-03-17 23:24:36 +00:00
|
|
|
<BotonIcono titulo={"Nuevo horario en blanco"}
|
|
|
|
icono={"ph-plus"}
|
|
|
|
onClick={() => {
|
|
|
|
}}
|
|
|
|
/>
|
|
|
|
<BotonIcono titulo={"Reiniciar horario"}
|
|
|
|
icono={"ph-arrow-counter-clockwise"}
|
|
|
|
onClick={() => {
|
|
|
|
}}
|
|
|
|
/>
|
|
|
|
<BotonIcono titulo={"Duplicar horario"}
|
|
|
|
icono={"ph-copy"}
|
|
|
|
onClick={() => {
|
|
|
|
}}
|
|
|
|
/>
|
|
|
|
<BotonIcono titulo={"Eliminar horario"}
|
|
|
|
icono={"ph-trash"}
|
|
|
|
onClick={() => {
|
|
|
|
}}
|
|
|
|
/>
|
2021-03-11 16:25:02 +00:00
|
|
|
|
|
2021-03-04 13:02:33 +00:00
|
|
|
<BotonMaxMin
|
|
|
|
fnMaximizar={fnMaximizar}
|
|
|
|
fnMinimizar={fnMinimizar}
|
|
|
|
estadoActualLayout={estadoActualLayout}
|
|
|
|
estadoLayoutMax={"MaxPersonal"}
|
|
|
|
/>
|
2021-03-03 14:56:22 +00:00
|
|
|
</div>
|
|
|
|
|
|
|
|
<div className={css(
|
|
|
|
e.horario,
|
|
|
|
estilosGlobales.contenedor
|
|
|
|
)}>
|
2021-03-17 23:24:36 +00:00
|
|
|
<Tabla data={datosMiHorario()}
|
|
|
|
anio={"Mi horario"}
|
|
|
|
version={1}
|
2021-03-18 00:03:10 +00:00
|
|
|
idHover={idHover}
|
|
|
|
setIdHover={setIdHover}
|
2021-03-19 00:51:35 +00:00
|
|
|
setCursosUsuarios={props.setCursosUsuarios}
|
2021-03-17 23:24:36 +00:00
|
|
|
/>
|
2021-03-03 14:56:22 +00:00
|
|
|
</div>
|
2021-03-18 00:03:10 +00:00
|
|
|
|
|
|
|
<CursosElem anioActual={() => "Mi horario"}
|
|
|
|
dataAnio={datosMiHorario()}
|
|
|
|
fnAgregarCurso={props.fnAgregarCurso}
|
|
|
|
listaCursosUsuario={props.cursosUsuario}
|
|
|
|
idHover={idHover}
|
|
|
|
setIdHover={setIdHover}
|
|
|
|
esCursoMiHorario={true}
|
|
|
|
/>
|
2021-03-03 14:56:22 +00:00
|
|
|
</Match>
|
|
|
|
<Match when={props.estadoLayout === "MaxHorarios"}>
|
2021-03-04 13:02:33 +00:00
|
|
|
<BotonMaxMin
|
|
|
|
fnMaximizar={fnMaximizar}
|
|
|
|
fnMinimizar={fnMinimizar}
|
|
|
|
estadoActualLayout={estadoActualLayout}
|
|
|
|
estadoLayoutMax={"MaxPersonal"}
|
|
|
|
/>
|
2021-03-03 14:56:22 +00:00
|
|
|
</Match>
|
|
|
|
</Switch>
|
2021-01-14 23:24:55 +00:00
|
|
|
</div>;
|
|
|
|
}
|