Proyectos de Subversion Moodle

Rev

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

Rev Autor Línea Nro. Línea
1 efrain 1
<?php
2
defined('MOODLE_INTERNAL') || die();
3
 
4
use core_completion\progress;
5
 
6
global $CFG;
7
require_once $CFG->libdir  . '/externallib.php';
8
require_once $CFG->dirroot . '/course/classes/category.php';
9
require_once $CFG->dirroot . '/blocks/moodleblock.class.php';
10
require_once $CFG->dirroot . '/blocks/course_list/block_course_list.php';
11
 
12
 
13
 
14
class block_cursos_catalogo_ajax_external extends \external_api
15
{
1052 ariadna 16
 
1 efrain 17
    public static function enrolar_usuario_cursos_catalogo_parameters()
18
    {
19
        return new \external_function_parameters([
20
            'courseid' => new \external_value(PARAM_INT, 'ID del curso', VALUE_DEFAULT, 0),
21
        ]);
22
    }
1052 ariadna 23
 
1 efrain 24
    public static function enrolar_usuario_cursos_catalogo($courseid)
25
    {
26
        global $USER, $DB, $CFG;
1052 ariadna 27
 
28
 
1 efrain 29
        $userid = $USER->id;
30
        $course = get_course($courseid);
31
        $enrol = false;
1052 ariadna 32
 
33
        if (!$course) {
1 efrain 34
            return json_encode(['success' => false, 'data' => 'No existe el curso']);
35
        }
1052 ariadna 36
 
37
 
1 efrain 38
        $enrolmethod = 'self';
1052 ariadna 39
 
1 efrain 40
        $instance = $DB->get_record('enrol', ['courseid' => $course->id, 'enrol' => $enrolmethod, 'status' => 0]);
1052 ariadna 41
        if (!$instance) {
1 efrain 42
            return json_encode(['success' => false, 'data' => 'El curso no permite auto inscribirse']);
43
        }
44
 
1052 ariadna 45
        try {
46
            $user = $DB->get_record('user', ['id' => $userid]);
47
            $role = $DB->get_record('role', array('archetype' => 'student'));
48
            $context = context_course::instance($course->id);
49
 
50
            $context = context_course::instance($course->id);
51
            if (is_enrolled($context, $user)) {
52
                return json_encode(['success' => true]);
53
            } else {
54
                $enrol = enrol_get_plugin($enrolmethod);
55
                if ($enrol === null) {
56
                    return false;
1 efrain 57
                }
1052 ariadna 58
                $instances = enrol_get_instances($course->id, true);
59
                $manualinstance = null;
60
                foreach ($instances as $instance) {
61
                    if ($instance->name == $enrolmethod) {
62
                        $manualinstance = $instance;
63
                        break;
64
                    }
1 efrain 65
                }
1052 ariadna 66
                if ($manualinstance !== null) {
67
                    $instanceid = $enrol->add_default_instance($course);
68
                    if ($instanceid === null) {
69
                        $instanceid = $enrol->add_instance($course);
70
                    }
71
                    $instance = $DB->get_record('enrol', array('id' => $instanceid));
72
                }
73
                $enrol->enrol_user($instance, $user->id, $role->id);
1 efrain 74
            }
1052 ariadna 75
 
76
            return json_encode(['success' => true]);
77
        } catch (\Exception $e) {
1 efrain 78
            error_log($e->getTraceAsString());
1052 ariadna 79
 
1 efrain 80
            return json_encode(['success' => false, 'data' => $e->getMessage()]);
81
        }
82
    }
1052 ariadna 83
 
1060 ariadna 84
 
1 efrain 85
    public static function enrolar_usuario_cursos_catalogo_returns()
86
    {
87
        return new \external_value(PARAM_RAW, 'The updated JSON output');
88
    }
1052 ariadna 89
 
1060 ariadna 90
 
91
 
1 efrain 92
    public static function get_cursos_catalogo_parameters()
93
    {
94
        return new \external_function_parameters([
95
            'category_id' => new \external_value(PARAM_INT, 'Categoría de los Cursos', VALUE_DEFAULT, 0),
1060 ariadna 96
            'search_text' => new \external_value(PARAM_ALPHANUM, 'Palabra de busqueda', VALUE_DEFAULT, ' '),
1061 ariadna 97
            'page' => new \external_value(PARAM_INT, 'Número de página', VALUE_DEFAULT, 1),
98
            'perpage' => new \external_value(PARAM_INT, 'Cursos por página', VALUE_DEFAULT, 10),
1 efrain 99
        ]);
100
    }
101
 
1062 ariadna 102
    public static function get_cursos_catalogo($category_id, $search_text, $page = 1, $perpage = 10)
1 efrain 103
    {
104
 
1060 ariadna 105
        global $USER, $DB, $CFG, $OUTPUT, $PAGE;
1 efrain 106
 
1061 ariadna 107
        $params = self::validate_parameters(
108
            self::get_cursos_catalogo_parameters(),
109
            compact('category_id', 'search_text', 'page', 'perpage')
110
        );
1060 ariadna 111
 
1061 ariadna 112
        $page = max(1, $params['page']);
1127 efrain 113
        $perpage = max(10, $params['perpage']);
1060 ariadna 114
 
1 efrain 115
        $userid = $USER->id;
1060 ariadna 116
        $url_noimage =  $CFG->wwwroot . '/theme/' . $PAGE->theme->name . '/pix/coursenoimage.jpg';
1 efrain 117
 
1060 ariadna 118
        $is_admin = false;
119
        $admins = get_admins();
120
        foreach ($admins as $admin) {
121
            if ($USER->id == $admin->id) {
122
                $is_admin = true;
123
                break;
124
            }
125
        }
1052 ariadna 126
 
1060 ariadna 127
        $all_categories = [];
128
        $records = $DB->get_records('course_categories', ['visible' => 1], 'sortorder, name');
129
        foreach ($records as $record) {
130
            $all_categories[$record->id] = $record;
1 efrain 131
        }
1052 ariadna 132
 
1060 ariadna 133
        $categories_ids = [];
134
        $category_filter_active = false;
135
        if ($category_id) {
136
            $category_filter_active = true;
137
 
138
            $recordLevel0 = $DB->get_record('course_categories', ['id' => $category_id]);
139
 
140
            if ($recordLevel0) {
141
                array_push($categories_ids, $recordLevel0->id);
142
 
143
                $recordsLevel1 = $DB->get_records('course_categories', ['visible' => 1, 'parent' => $recordLevel0->id]);
144
 
145
                foreach ($recordsLevel1 as $recordLevel1) {
146
 
147
                    array_push($categories_ids, $recordLevel1->id);
148
 
149
                    $recordsLevel2 = $DB->get_records('course_categories', ['visible' => 1, 'parent' => $recordLevel1->id]);
150
                    foreach ($recordsLevel2 as $recordLevel2) {
151
                        array_push($categories_ids, $recordLevel2->id);
152
 
153
                        $recordsLevel3 = $DB->get_records('course_categories', ['visible' => 2, 'parent' => $recordLevel2->id]);
154
                        foreach ($recordsLevel3 as $recordLevel3) {
155
                            array_push($categories_ids, $recordLevel3->id);
156
                        }
157
                    }
158
                }
159
            }
1 efrain 160
        }
161
 
1060 ariadna 162
        $course_ids                 = [];
163
        $course_category_ids        = [];
164
        $courseAvailableForAutoRol  = [];
165
 
1113 ariadna 166
 
1129 efrain 167
 
1113 ariadna 168
 
1060 ariadna 169
        if ($is_admin) {
1127 efrain 170
            $mycourses = get_courses();// get_courses_search($searchterms, $sort, $page, $perpage, $total_courses);
1060 ariadna 171
        } else {
172
            $mycourses  = enrol_get_users_courses($USER->id);
1127 efrain 173
            $courses_with_autoenrol  = $DB->get_records('enrol', ['enrol' => 'self', 'status' => 0]);
174
            foreach ($courses_with_autoenrol as $course_with_autoenrol)
175
            {
176
                $course = get_course($course_with_autoenrol->courseid);
177
                array_push($mycourses, $course);
178
 
179
                array_push($courseAvailableForAutoRol, $course->id);
180
            }
1 efrain 181
        }
1127 efrain 182
 
183
        $mycourses = array_filter($mycourses, function($course) use ($search_text, $category_filter_active, $categories_ids) {
1060 ariadna 184
            if (!$course->visible) {
1127 efrain 185
                return false;
1060 ariadna 186
            }
1127 efrain 187
 
1060 ariadna 188
            if ($search_text) {
189
                if (stripos($course->fullname, $search_text) === false) {
1127 efrain 190
                    return false;
1060 ariadna 191
                }
192
            }
1127 efrain 193
 
1060 ariadna 194
            if ($category_filter_active) {
195
                if (!in_array($course->category, $categories_ids)) {
1127 efrain 196
                    return false;
1060 ariadna 197
                }
198
            }
1127 efrain 199
 
200
            return true;
201
        });
202
 
1129 efrain 203
        /*
204
         $searchterms = array();
205
         $sort = "c.sortorder DESC";
206
         */
1127 efrain 207
 
1129 efrain 208
        $total_courses = count($mycourses);
209
        $total_pages = ceil($total_courses / $perpage);
210
        if($total_pages * $perpage < $total_courses) {
211
            $total_pages++;
212
        }
1127 efrain 213
 
1129 efrain 214
        $page = isset($page) ? max(1, min($page, $total_pages)) : 1;
215
 
216
        $max_links = 3;
217
        $start_page = max(1, $page - floor($max_links / 2));
218
        $end_page = min($total_pages, $start_page + $max_links - 1);
219
 
220
        if ($end_page - $start_page + 1 < $max_links) {
221
            $start_page = max(1, $end_page - $max_links + 1);
222
        }
223
 
224
 
225
        $start  = $page == 1 ? 0 : ($page - 1) * $perpage;
226
        $mycourses = array_slice($mycourses, $start, $perpage);
227
 
228
 
1060 ariadna 229
 
230
        $courses = [];
1128 efrain 231
        /*
1060 ariadna 232
        foreach ($course_ids as $course_id) {
233
            $course = get_course($course_id);
1128 efrain 234
          */
235
 
236
            foreach( $mycourses as $course) {
1060 ariadna 237
 
238
            if ($course instanceof stdClass) {
239
                $coreCourseList = new core_course_list_element($course);
240
            }
241
 
242
            if (!in_array($course->category, $course_category_ids)) {
243
                array_push($course_category_ids, $course->category);
244
            }
245
 
246
            $image = $url_noimage;
247
            foreach ($coreCourseList->get_course_overviewfiles() as $file) {
248
                $isimage = $file->is_valid_image();
249
                $image = file_encode_url("{$CFG->wwwroot}/pluginfile.php", '/' . $file->get_contextid() . '/' . $file->get_component() . '/' . $file->get_filearea() . $file->get_filepath() . $file->get_filename(), !$isimage);
250
                if (!$isimage) {
251
                    $image = $url_noimage;
252
                }
253
            }
254
 
255
            $lastaccess = null;
1078 ariadna 256
            $sql = "select timecreated from {logstore_standard_log} where courseid = :courseid and userid = :userid order by id limit {$perpage}";
1074 ariadna 257
            $params_a = ['courseid' => $course->id, 'userid' => $userid];
1072 ariadna 258
            $timecreated = $DB->get_field_sql($sql,  $params_a);
1060 ariadna 259
            if ($timecreated) {
260
 
261
                $lastaccess = date('d/m/Y h:i a', $timecreated);
262
            }
263
 
264
            $first_section = 0;
1075 ariadna 265
            $sections = $DB->get_records('course_sections', ['course' => $course->id], 'section desc', 'id,name,section,sequence,visible');
1060 ariadna 266
 
267
            foreach ($sections as $section) {
268
                if (!empty($section->section)) {
269
                    $first_section = $section->id;
270
                    break;
271
                }
272
            }
273
 
274
            $course_context = context_course::instance($course->id);
275
            $roles = get_user_roles($course_context, $USER->id, true);
276
 
277
            $completion_edit_curso = false;
278
            foreach ($roles as $role) {
279
                if ($role->shortname == 'companydepartmentmanager' || $role->shortname == 'companycoursenoneditor') {
280
                    $completion_edit_curso  = true;
281
                    break;
282
                }
283
            }
284
 
285
            if (has_capability('moodle/course:manageactivities', $course_context, $USER->id) || has_capability('moodle/course:viewhiddenactivities', $course_context, $USER->id) || $completion_edit_curso) {
286
                $editurl = $CFG->wwwroot . '/course/view.php?id=' . $course->id . '&notifyeditingon=1';
287
            } else {
288
                $editurl = '';
289
            }
290
 
291
            $modules = get_fast_modinfo($course->id)->get_cms();
292
 
293
            $linkurl = '';
294
            foreach ($modules as $module) {
295
                if (!$module->uservisible || $module->is_stealth() || empty($module->url) || empty($module->section)) {
296
                    continue;
297
                }
298
 
299
                if ($module->section == $first_section || $completion_edit_curso) {
300
                    $linkurl =  new moodle_url($module->url, array('forceview' => 1));
301
                    break;
302
                }
303
            }
304
 
305
            $summary = trim(strip_tags($course->summary));
306
 
307
            if (empty($summary)) {
308
                $summary = '<p></p>';
309
            } else if (strlen($summary) > 80) {
310
 
311
                $summary =  substr($summary, 0, 80) . '...';
312
            }
313
 
314
            if (empty($editurl) && in_array($course->id, $courseAvailableForAutoRol)) {
315
                $autoenrol = 'yes';
316
            } else {
317
                $autoenrol = '';
318
            }
319
 
320
            $category = $all_categories[$course->category];
321
            if ($category->parent) {
322
                $categoryParent = $all_categories[$category->parent];
323
                if ($categoryParent) {
324
                    $categoryName = $categoryParent->name . ' / ' . $category->name;
325
                } else {
326
                    $categoryName = $category->name;
327
                }
328
            } else {
329
                $categoryName =  $category->name;
330
            }
331
            if (strlen($categoryName) > 40) {
332
 
333
                $categoryName =  substr($categoryName, 0, 40) . '...';
334
            }
335
 
336
            // echo '<pre>';
337
            // echo '$categoryName = ' . $categoryName . ' $course->category = ' . $course->category;
338
            // echo '</pre>';
339
 
340
            array_push($courses, [
341
                'courseid' => $course->id,
342
                'coursecategory' => $categoryName,
343
                'courseimage' => $image,
344
                'enddate' => $course->enddate,
345
                'fullname' => $course->fullname,
346
                'fullnamedisplay' => get_course_display_name_for_list($course),
347
                'hidden' => false,
1059 ariadna 348
                'id' => $course->id,
1060 ariadna 349
                'idnumber' => $course->idnumber,
350
                'isfavourite' => false,
1058 ariadna 351
                'shortname' => $course->shortname,
1060 ariadna 352
                'showshortname' => false,
1058 ariadna 353
                'startdate' => $course->startdate,
1060 ariadna 354
                'summary' =>  $summary,
355
                'summaryformat' => $course->summaryformat,
356
                'timeaccess' => $lastaccess,
357
                'viewurl' => $linkurl,
358
                'editurl' => $editurl,
359
                'autoenrol' => $autoenrol,
360
                'visible' => true,
361
            ]);
1 efrain 362
        }
363
 
1113 ariadna 364
        $categories = [];
1061 ariadna 365
 
1060 ariadna 366
        foreach ($course_category_ids as $course_category_id) {
367
            $category = $all_categories[$course_category_id];
368
            if ($category) {
369
                array_push($categories, ['id' => $category->id, 'name' => $category->name]);
370
            }
371
        }
372
 
1084 ariadna 373
        // Crear el array de navegación con el rango dinámico
1061 ariadna 374
        $pagination = [
375
            'current_page' => $page,
376
            'total_pages' => $total_pages,
377
            'has_previous' => $page > 1,
378
            'has_next' => $page < $total_pages,
379
            'previous_page' => $page > 1 ? $page - 1 : null,
1084 ariadna 380
            'next_page' => $page < $total_pages ? $page + 1 : null,
381
            'pages' => array_map(function ($p) use ($page) {
382
                return [
383
                    'number' => $p,
384
                    'is_current' => $p === $page
385
                ];
386
            }, range($start_page, $end_page))
1061 ariadna 387
        ];
1060 ariadna 388
 
1084 ariadna 389
        // Preparar los datos para la plantilla
1061 ariadna 390
        $data = [
1113 ariadna 391
            'courses' => $courses,
1061 ariadna 392
            'pagination' => $pagination
1058 ariadna 393
        ];
1060 ariadna 394
 
395
        $cards = $OUTPUT->render_from_template('block_cursos_catalogo_ajax/cards', $data);
396
 
397
        $data = [
398
            'categories' => $categories
399
        ];
400
 
401
        $badges = $OUTPUT->render_from_template('block_cursos_catalogo_ajax/badges', $data);
402
 
403
 
1061 ariadna 404
        return json_encode(
405
            [
406
                'success' => true,
407
                'search_text' => $search_text,
408
                'category_id' => $category_id,
409
                'cards' => $cards,
410
                'badges' => $badges
411
            ]
412
        );
1 efrain 413
    }
414
 
1060 ariadna 415
 
1 efrain 416
    public static function get_cursos_catalogo_returns()
417
    {
1060 ariadna 418
        return new \external_value(PARAM_RAW, 'The updated JSON output');
1 efrain 419
    }
420
}