File size: 14,414 Bytes
048b5c0
ad9c16f
 
 
ecc03a1
ad9c16f
 
 
be0149f
27d0fdd
be0149f
ad9c16f
be0149f
ad9c16f
be0149f
 
ad9c16f
ecc03a1
 
 
 
 
 
 
 
 
ad9c16f
 
ecc03a1
 
 
48cad96
ecc03a1
ad9c16f
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
b4422a0
 
 
ad9c16f
 
 
ecc03a1
 
ac22a6e
8525cb0
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
c71535a
ecc03a1
 
ad9c16f
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
ecc03a1
 
 
ad9c16f
7e43be1
ad9c16f
 
 
 
 
d067404
24f3242
 
d067404
ad9c16f
 
24f3242
ad9c16f
 
 
24f3242
ad9c16f
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
ecc03a1
 
 
ad9c16f
 
 
 
efa130c
ecc03a1
 
2f781c2
 
34c1a1e
c81a870
a7c709b
 
34c1a1e
a7c709b
2f781c2
 
34c1a1e
c81a870
 
d4eb025
 
 
 
 
4cff43c
 
 
 
22c7f60
 
4cff43c
82330ec
22c7f60
c81a870
22c7f60
 
85be22c
a7c709b
2f781c2
 
1c6153b
2f781c2
 
 
 
 
 
 
 
 
 
 
 
 
 
3389dd9
7ec3192
 
 
 
 
 
572d1b0
 
7ec3192
 
34c1a1e
 
572d1b0
 
7ec3192
34c1a1e
 
7ec3192
572d1b0
34c1a1e
 
572d1b0
 
 
7ec3192
572d1b0
34c1a1e
572d1b0
 
 
 
34c1a1e
7ec3192
572d1b0
 
34c1a1e
572d1b0
 
 
34c1a1e
572d1b0
 
 
7ec3192
34c1a1e
 
7ec3192
572d1b0
 
7ec3192
2f781c2
34c1a1e
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
2f781c2
 
 
 
 
 
 
 
 
 
ad9c16f
 
 
 
 
 
c58df45
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
# modules/ui/ui.py
import streamlit as st
from streamlit_player import st_player
import logging
from datetime import datetime
from dateutil.parser import parse

# Importaciones locales
#
from session_state import initialize_session_state, logout
#
from translations import get_translations
#
from ..auth.auth import authenticate_user, authenticate_student, authenticate_admin
#
from ..database.sql_db import store_application_request

#from .user_page import user_page
try:
    from .user_page import user_page
except ImportError:
    logger.error("No se pudo importar user_page. Aseg煤rate de que el archivo existe.")
    # Definir una funci贸n de respaldo
    def user_page(lang_code, t):
        st.error("La p谩gina de usuario no est谩 disponible. Por favor, contacta al administrador.")

from ..admin.admin_ui import admin_page

# Configuraci贸n del logger
logging.basicConfig(level=logging.INFO)
logger = logging.getLogger(__name__)

#############################################################
def main():
    logger.info(f"Entrando en main() - P谩gina actual: {st.session_state.page}")

    if 'nlp_models' not in st.session_state:
        logger.error("Los modelos NLP no est谩n inicializados.")
        st.error("Los modelos NLP no est谩n inicializados. Por favor, reinicie la aplicaci贸n.")
        return

    lang_code = st.session_state.get('lang_code', 'es')
    t = get_translations(lang_code)

    logger.info(f"P谩gina actual antes de la l贸gica de enrutamiento: {st.session_state.page}")

    if st.session_state.get('logged_out', False):
        st.session_state.logged_out = False
        st.session_state.page = 'login'
        st.rerun()

    if not st.session_state.get('logged_in', False):
        logger.info("Usuario no ha iniciado sesi贸n. Mostrando p谩gina de login/registro")
        login_register_page(lang_code, t)
    elif st.session_state.page == 'user':
        if st.session_state.role == 'Administrador':
            logger.info("Redirigiendo a la p谩gina de administrador")
            st.session_state.page = 'Admin'
            st.rerun()
        else:
            logger.info("Renderizando p谩gina de usuario")
            user_page(lang_code, t)
    elif st.session_state.page == "Admin":
        logger.info("Renderizando p谩gina de administrador")
        admin_page()
    else:
        logger.error(f"P谩gina no reconocida: {st.session_state.page}")
        st.error(t.get('unrecognized_page', 'P谩gina no reconocida'))
        # Redirigir a la p谩gina de usuario en caso de error
        st.session_state.page = 'user'
        st.rerun()

    logger.info(f"Saliendo de main() - Estado final de la sesi贸n: {st.session_state}")

#############################################################
#############################################################    
def login_register_page(lang_code, t):
    # st.title("AIdeaText")
    # st.write(t.get("welcome_message", "Bienvenido. Por favor, inicie sesi贸n o reg铆strese."))

    left_column, right_column = st.columns([1, 3])

    with left_column:
        tab1, tab2 = st.tabs([t.get("login", "Iniciar Sesi贸n"), 
                             t.get("register", "Registrarse")])

        with tab1:
            login_form(lang_code, t)

        with tab2:
            register_form(lang_code, t)

    with right_column:
        display_videos_and_info(lang_code, t)

#############################################################
#############################################################
def login_form(lang_code, t):
    with st.form("login_form"):
        username = st.text_input(t.get("email", "Correo electr贸nico"))
        password = st.text_input(t.get("password", "Contrase帽a"), type="password")
        submit_button = st.form_submit_button(t.get("login", "Iniciar Sesi贸n"))

    if submit_button:
        success, role = authenticate_user(username, password)
        if success:
            st.session_state.logged_in = True
            st.session_state.username = username
            st.session_state.role = role
            if role == 'Administrador':
                st.session_state.page = 'Admin'
            else:
                st.session_state.page = 'user'
            logger.info(f"Usuario autenticado: {username}, Rol: {role}")
            st.rerun()
        else:
            st.error(t.get("invalid_credentials", "Credenciales incorrectas"))


#############################################################
#############################################################
def register_form(lang_code, t):
    # st.header(t.get("request_trial", "Solicitar prueba de la aplicaci贸n"))
    name = st.text_input(t.get("name", "Nombre"))
    lastname = st.text_input(t.get("lastname", "Apellidos"))
    institution = st.text_input(t.get("institution", "Instituci贸n"))
    current_role = st.selectbox(t.get("current_role", "Rol en la instituci贸n donde labora"),
                                [t.get("professor", "Profesor"), t.get("student", "Estudiante"), t.get("administrative", "Administrativo")])
    
    # Definimos el rol por defecto como estudiante
    desired_role = t.get("student", "Estudiante")
    
    email = st.text_input(t.get("institutional_email", "Correo electr贸nico de su instituci贸n"))
    reason = st.text_area(t.get("interest_reason", "驴Por qu茅 est谩s interesado en probar AIdeaText?"))
    
    if st.button(t.get("submit_application", "Enviar solicitud")):
        logger.info(f"Attempting to submit application for {email}")
        logger.debug(f"Form data: name={name}, lastname={lastname}, email={email}, institution={institution}, current_role={current_role}, desired_role={desired_role}, reason={reason}")
        
        if not name or not lastname or not email or not institution or not reason:
            logger.warning("Incomplete form submission")
            st.error(t.get("complete_all_fields", "Por favor, completa todos los campos."))
        elif not is_institutional_email(email):
            logger.warning(f"Non-institutional email used: {email}")
            st.error(t.get("use_institutional_email", "Por favor, utiliza un correo electr贸nico institucional."))
        else:
            logger.info(f"Attempting to store application for {email}")
            success = store_application_request(name, lastname, email, institution, current_role, desired_role, reason)
            if success:
                st.success(t.get("application_sent", "Tu solicitud ha sido enviada. Te contactaremos pronto."))
                logger.info(f"Application request stored successfully for {email}")
            else:
                st.error(t.get("application_error", "Hubo un problema al enviar tu solicitud. Por favor, intenta de nuevo m谩s tarde."))
                logger.error(f"Failed to store application request for {email}")


#############################################################
#############################################################
def is_institutional_email(email):
        forbidden_domains = ['gmail.com', 'hotmail.com', 'yahoo.com', 'outlook.com']
        return not any(domain in email.lower() for domain in forbidden_domains)


#############################################################
#############################################################
def display_videos_and_info(lang_code, t):
    # Crear tabs para cada secci贸n
    tab_use_case, tab_videos, tab_events, tab_gallery, tab_news = st.tabs([
        "Casos de uso", 
        "Videos de presentaciones", 
        "Ponencias acad茅micas",
        "Fotos de eventos",
        "Control de versiones"
    ])

# Tab de Casos de uso
    with tab_use_case:
        use_case_videos = {
            "English - Radar use chart": "https://youtu.be/fFbbtlIewgs",
            "English - Use AI Bot and arcs charts fuctions": "https://youtu.be/XjM-1oOl-ao",
            "English - Arcs use charts, example 1": "https://youtu.be/PdK_bgigVaM",
            "English - Arcs use charts, excample 2": "https://youtu.be/7uaV1njPOng",   
            "Espa帽ol - Uso del diagrama radar para verificar redacci贸n": "https://www.youtube.com/watch?v=nJP6xscPLBU",
            "Espa帽ol - Uso de los diagramas de arco, ejemplo 1": "https://www.youtube.com/watch?v=ApBIAr2S-bE",            
            "Espa帽ol - Uso de los diagramas de arco, ejemplo 2": "https://www.youtube.com/watch?v=JnP2U1Fm0rc",
            "Espa帽ol - Uso de los diagramas de arco, ejemplo 3": "https://www.youtube.com/watch?v=waWWwPTaI-Y",
            "Espa帽ol - Uso del bot para buscar respuestas" : "https://www.youtube.com/watch?v=GFKDS0K2s7E" 
        }
        
        selected_title = st.selectbox("Selecciona un caso de uso en espa帽ol o en ingl茅s:", list(use_case_videos.keys()))
        if selected_title in use_case_videos:
            try:
                st_player(use_case_videos[selected_title])
            except Exception as e:
                st.error(f"Error al cargar el video: {str(e)}")

    # Tab de Videos
    with tab_videos:
        videos = {
            "Reel AIdeaText": "https://youtu.be/hXnwUvN1Q9Q",
            "Presentaci贸n en SENDA, UNAM. Ciudad de M茅xico, M茅xico" : "https://www.youtube.com/watch?v=XFLvjST2cE0",        
            "Presentaci贸n en PyCon 2024. Colombia, Medell铆n": "https://www.youtube.com/watch?v=Jn545-IKx5Q",
            "Presentaci贸n en la Fundaci贸n Ser Maaestro. Lima, Per煤": "https://www.youtube.com/watch?v=imc4TI1q164",
            "Presentaci贸n en el programa de incubaci贸n Explora del IFE, TEC de Monterrey, Nuevo Le贸n, M茅xico": "https://www.youtube.com/watch?v=Fqi4Di_Rj_s",
            "Entrevista con el Dr. Guillermo Ru铆z. Lima, Per煤": "https://www.youtube.com/watch?v=_ch8cRja3oc",
            "Demo de la versi贸n de escritorio.": "https://www.youtube.com/watch?v=nP6eXbog-ZY"
        }

        selected_title = st.selectbox("Selecciona una conferencia:", list(videos.keys()))
        if selected_title in videos:
            try:
                st_player(videos[selected_title])
            except Exception as e:
                st.error(f"Error al cargar el video: {str(e)}")
                
    # Tab de Eventos
    with tab_events:
        st.markdown("""
        ## 2025
    
        **El Agente Cognitivo Vinculante como Innovaci贸n en el Aprendizaje Adaptativo: el caso de AIdeaText**  
        IFE CONFERENCE 2025. Organizado por el Instituto para el Futuro de la Educaci贸n del TEC de Monterrey. 
        Nuevo Le贸n, M茅xico. Del 28 al 30 enero 2025
    
        ## 2024
        [1]
        AIdeaText, AIdeaText, recurso digital que emplea la t茅cnica de An谩lisis de Resonancia Central para perfeccionar textos acad茅micos**  
        V Temporada SENDA - Organizado por el Seminario de Entornos y Narrativas Digitales en la Academia del 
        Instituto de Investigaciones Antropol贸gicas (IIA) de la Universidad Auton贸ma de M茅xico (UNAM). 22 noviembre 2024
    
        [2]
        Aproximaci贸n al Agente Cognitivo Vinculante (ACV) desde la Teor铆a del Actor Red (TAR)**  
        Congreso HeETI 2024: Horizontes Expandidos de la Educaci贸n, la Tecnolog铆a y la Innovaci贸n  
        Universidad el Claustro de Sor Juana. Del 25 al 27 septiembre 2024
        [3]
        AIdeaText, visualizaci贸n de mapas sem谩nticos**
        PyCon 2024, Organizado por el grupo de desarrolladores independientes de Python. 
        Universidad EAFIT, Medell铆n, Colombia. Del 7 al 9 de junio de 2024. 
        
        ## 2023
        **Aproximaci贸n al Agente Cognitivo Vinculante (ACV) desde la Teor铆a del Actor Red (TAR)**  
        [1]
        XVII Congreso Nacional de Investigaci贸n Educativa - VII Encuentro de Estudiantes de Posgrado Educaci贸n.
        Consejo Mexicano de Investigaci贸n Educativa (COMIE)  
        Villahermosa, Tabasco, M茅xico. 
        Del 4 al 8 de diciembre 2023
        [2]
        XXXI Encuentro Internacional de Educaci贸n a Distancia  
        Universidad de Guadalajara. Jalisco, M茅xico. 
        Del 27 al 30 noviembre 2023
        [3]
        IV Temporada SENDA - Seminario de Entornos y Narrativas Digitales en la Academia  
        Instituto de Investigaciones Antropol贸gicas (IIA), UNAM. 
        22 noviembre 2023
        [4]
        1er Congreso Internacional de Educaci贸n Digital  
        Instituto Polit茅cnico Nacional, sede Zacatecas. M茅xico. 
        Del 23 al 24 de noviembre de 2023
    
        [5]
        La cuesti贸n de la centralidad del maestro frente a las tecnolog铆as digitales generativas**  
        Innova F贸rum: Ecosistemas de Aprendizaje  
        Universidad de Guadalajara. Jalisco, M茅xico. 
        Del 16 al 18 de mayo 2023
        """)

    # Tab de Galer铆a
    with tab_gallery:
        # Contenedor con ancho m谩ximo
        with st.container():
            # Dividimos en dos columnas principales
            col_left, col_right = st.columns(2)
                        
            # Columna izquierda: Foto 1 grande
            with col_left:
                # Foto 2 arriba
                st.image("assets/img/socialmedia/_MG_2845.JPG", 
                        caption="MakerFaire CDMX 2024", 
                        width=480)  # Ajusta este valor seg煤n necesites
                        # use_column_width=True)
                
                # Foto 3 abajo
                st.image("assets/img/socialmedia/Facebook_CoverPhoto-1_820x312.jpg", 
                        caption="MakerFaire CDMX 2024", 
                        width=480)  # Ajusta este valor seg煤n necesites 
                        # use_column_width=True)

                            # Columna derecha: Fotos 2 y 3 una encima de otra
            with col_right:
                st.image("assets/img/socialmedia/_MG_2790.jpg", 
                        caption="MakerFaire CDMX 2024", 
                        width=540)  # Ajusta este valor seg煤n necesites

    
    # Tab de Novedades
    with tab_news:
        st.markdown("""
        ### Novedades de la versi贸n actual
        - Interfaz mejorada para una mejor experiencia de usuario
        - Optimizaci贸n del an谩lisis morfosint谩ctico
        - Soporte para m煤ltiples idiomas
        - Nuevo m贸dulo de an谩lisis del discurso
        - Sistema de chat integrado para soporte
        """)

# Definici贸n de __all__ para especificar qu茅 se exporta
__all__ = ['main', 'login_register_page', 'initialize_session_state']

# Bloque de ejecuci贸n condicional
if __name__ == "__main__":
    main()