Proyectos de Subversion LeadersLinked - SPA

Rev

Rev 3519 | Rev 3521 | Ir a la última revisión | | Comparar con el anterior | Ultima modificación | Ver Log |

Rev Autor Línea Nro. Línea
3482 stevensc 1
import React from 'react';
3481 stevensc 2
import { useParams } from 'react-router-dom';
3
 
3520 stevensc 4
import { useFetch, useModal } from '@shared/hooks';
3481 stevensc 5
 
3482 stevensc 6
import { Grid, PageHeader, Spinner } from '@shared/components';
7
import { SlideCard } from '@microlearning/components';
3520 stevensc 8
import { SlideForm } from '@microlearning/components/slides/slides-carousel';
3481 stevensc 9
 
3505 stevensc 10
export function SlidesPage() {
3482 stevensc 11
  const { uuid } = useParams();
12
  const { data: capsule, loading } = useFetch(`/microlearning/capsules/${uuid}`);
3481 stevensc 13
 
3520 stevensc 14
  const { showModal } = useModal();
15
 
16
  const showSlide = (slideName) => {
17
    showModal({
18
      title: slideName,
19
      content: <SlideForm slideUuid={uuid} />
20
    });
3482 stevensc 21
  };
3481 stevensc 22
 
3482 stevensc 23
  if (loading || !capsule) return <Spinner />;
24
 
3481 stevensc 25
  return (
3482 stevensc 26
    <>
27
      <PageHeader title={capsule.name} goBack />
28
      <Grid
29
        items={capsule.slides}
3520 stevensc 30
        emptyMessage='No hay contenidos para mostrar'
31
        renderItem={(slide) => <SlideCard slide={slide} onClick={() => showSlide(slide.name)} />}
3519 stevensc 32
        keyExtractor={(slide) => slide.uuid}
3482 stevensc 33
      />
34
    </>
3481 stevensc 35
  );
3482 stevensc 36
}