123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547 |
- @extends('layouts.master_sin_semesterbar')
-
- @section('navigation')
- @include('local.managers.admins._new_navigation')
- @stop
-
- @section('main')
-
- <div>
- <div class="">
- <script type="text/javascript" src="https://www.gstatic.com/charts/loader.js"></script>
- <script type="text/javascript">
- function make_chart(outcomes_info, semesters) {
- //////// Get values ready for chart
- var target_line = {{ $target }};
- var x_label = 'Learning Outcomes';
- var y_label = 'Percent of students';
- var outcomes_labels = Array();
- var i = 0;
- outcomes_info.forEach(eachOutcome);
-
- function eachOutcome(outcome, index) {
- outcomes_labels.push({
- v: (index + 1),
- f: outcome.name
- });
- i = i + 1;
- }
-
- //
- var outcomes_data = Array();
-
- var legend = Array();
- legend.push('');
- legend.push('Target');
- $.each(semesters, function(index, semester) {
- var name = semester.name;
- name = name.split(' ');
- var semester_number = name[0];
- var semester_year = name[2];
-
- if (semester_number == 'First') {
- semester_number = '1';
- } else if (semester_number == 'Second') {
- semester_number = '2';
- }
-
- name = semester_year + " Sem " + semester_number;
- legend.push(name);
- });
- outcomes_data.push(legend);
-
- //
- var hidden_values = Array();
- hidden_values.push(0);
- hidden_values.push(target_line);
- var k = 0;
- while (k < semesters.length) {
- hidden_values.push(null);
- k = k + 1;
- }
-
- //
- outcomes_data.push(hidden_values);
- // console.log(semesters)
-
- $.each(outcomes_info, function(index, outcome) {
- var temp_outcome_grouping_info = Array();
- temp_outcome_grouping_info.push({
- v: (index + 1),
- f: "Students acheiving Learning Outcomes"
- });
- temp_outcome_grouping_info.push(target_line);
-
- // console.log(outcome.semesters)
- var i = 0;
- $.each(outcome.semesters, function(index, semester) {
-
- // if semester is not the same, insert null.
- // else, insert info from expected semester.
- if (semester.name != semesters[i].name) {
- while (semester.name != semesters[i].name && i < semesters.length) {
- temp_outcome_grouping_info.push(null);
- i = i + 1;
- }
- }
- i = i + 1;
-
- var total = semester.total_evaluated;
- var achievers = semester.total_achieved;
-
- var percentage = achievers / total;
- var display_percentage = percentage * 100;
- temp_outcome_grouping_info.push({
- v: percentage,
- f: '\nAchieved by ' + display_percentage.toFixed(2) + '%\n(' + achievers +
- ' achievers and ' + total + ' participants)'
- });
- });
-
- var i = temp_outcome_grouping_info.length;
- while (i < semesters.length + 2) {
- temp_outcome_grouping_info.push(null);
- i = i + 1;
- }
-
- outcomes_data.push(temp_outcome_grouping_info);
- });
- var last_hidden_values = [...hidden_values];
- last_hidden_values[0] = i + 1;
- outcomes_data.push(last_hidden_values);
-
- ////////
- google.charts.load('current', {
- packages: ['corechart']
- }).then(function() {
- var data = google.visualization.arrayToDataTable(outcomes_data);
- // var data = google.visualization.arrayToDataTable([
- // ['', 'Target', '2020-21 Sem 2', '2021-22 Sem 1', '2021-22 Sem 2'],
- // [0, 0.80, null, null, null],
- // [{v:1,f:"Students acheiving Learning Outcomes"}, 0.80, {v:0.8275,f:82.75}, {v:0.9075,f:'\nAchieved by '+(90.75).toString()+'%\n(60 achievers and 80 participants)'}, {v:0.8475,f:84.75}],
- // [{v:2,f:"Students acheiving Learning Outcomes"}, 0.80, {v:0.7475,f:74.75}, {v:0.8775,f:87.75}, {v:0.9975,f:60.75}],
- // [{v:3,f:"Students acheiving Learning Outcomes"}, 0.80, {v:0.6875,f:68.75}, {v:0.9175,f:91.75}, {v:0.8475,f:84.75}],
- // [4, 0.80, null, null, null]
- // ]);
-
- var chartDiv = document.getElementById('chart_div');
- var chart = new google.visualization.ColumnChart(chartDiv);
- chart.draw(data, {
- // colors: ['lime', 'magenta'],
- hAxis: {
- title: x_label,
- ticks: outcomes_labels,
- viewWindow: {
- min: 0.5,
- max: outcomes_info.length + 0.5 // el total de outcomes + 0.5
- },
- textStyle: {
- fontSize: 10,
- bold: true,
- }
- },
- legend: 'right',
- series: {
- 0: {
- type: 'line'
- }
- },
- title: ' ',
- chartArea: {
- width: '70%',
- // top: 10,
- // height: '50%'
- },
- vAxis: {
- title: y_label,
- format: 'percent',
- viewWindow: {
- min: 0,
- max: 1
- }
- }
- });
- });
- }
-
-
- // labels for each outcome grouping
- var outcomes_info = <?= json_encode($outcomes, JSON_HEX_TAG) ?>;
- var semesters = <?= json_encode($semesters, JSON_HEX_TAG) ?>;
-
- // console.log(outcomes_info);
- make_chart(outcomes_info, semesters);
- </script>
- <script src="https://www.gstatic.com/charts/loader.js"></script>
- <div class="">
- <div class="filters">
- <div class="row" style="display: flex;">
- <div class="category">
- <label for="is_graduate">Level</label>
- <div class="select">
- <select class="selectpicker" data-live-search='true' name="is_graduate" id="is_graduate">
- <option value="0" selected="selected">Undergradute</option>
- <option value="1">Graduate</option>
- </select>
- </div>
- </div>
- </div>
- <div class="row" style="display: flex;">
- <div class="category">
- <label for="school">School</label>
- <div class="select">
- <select multiple class="selectpicker" data-live-search="true" name="school" id="school">
- <option value="0" selected="selected">All</option>
- @foreach ($filters['school'] as $school)
- <option value="{{ $school->id }}">{{ $school->name }}</option>
- @endforeach
- </select>
- </div>
- </div>
- <div class="category">
- <label for="program">Academic Program</label>
- <div class="select">
- <select multiple class="selectpicker" data-live-search="true" name="program" id="program">
- <option value="0" selected="selected">All</option>
- @foreach ($filters['program'] as $program)
- <option value="{{ $program->id }}">{{ $program->name }}</option>
- @endforeach
- </select>
- </div>
- </div>
- </div>
- <div class="row" style="display: flex;">
- <div class="category">
- <label for="semester">Semester</label>
- <div class="select">
- <select multiple class="selectpicker" data-live-search="true" name="semester" id="semester">
- <option value="0" selected="selected">All</option>
- @foreach ($filters['semester'] as $semester)
- <option value="{{ $semester->id }}">{{ $semester->name }}</option>
- @endforeach
- </select>
- </div>
- </div>
- <div class="category">
- <label for="year">Academic Year</label>
- <div class="select">
- <select multiple class="selectpicker" data-live-search = 'true'name="year" id="year">
- <option value="0" selected="selected">All</option>
- @foreach ($filters['year'] as $year)
- <option value="{{ $year->id }}">{{ $year->start }}</option>
- @endforeach
- </select>
- </div>
- </div>
- <div class="category">
- <label for="outcome">Learning Outcomes</label>
- <div class="select">
- <select multiple class="selectpicker" data-live-search="true" name="outcome" id="outcome">
- <option value="0" selected="selected">All</option>
- @foreach ($filters['outcome'] as $outcome)
- <option value="{{ $outcome->id }}">{{ $outcome->name }}</option>
- @endforeach
- </select>
- </div>
- </div>
- </div>
- </div>
- <h4 class="container">
- <b>Percent of Students Achieving Learning Outcomes By Academic Session</b>
- </h4>
- <div class="container" style="height:500px; width:1300px;" id="chart_div"></div>
- <div class="" style="padding-left: 25px;">
- <h5>
- <b>Annotation</b>
- </h5>
- The target line represents the expected percent of students achieving the learning
- outcome({{ $target * 100 }}%).
- </div>
- </div>
- </div>
- </div>
-
- @stop
-
- @section('included-js')
-
- <!-- HighCharts -->
- <script src="{{ asset('vendor/highcharts/highcharts.js') }}"></script>
-
- @stop
-
- @section('javascript')
-
-
- $(document).ready(function()
- {
- $("#year").parent().parent().parent().hide();
-
-
-
- // when a filter is focused
- var previous;
- $(".category").find("button").focus(function() {
- previous = Array();
- $(this).parent().find("select option:selected").each(function() {
- previous.push(this.value);
- });
- });
-
- // when a filter is changed
- $(".category").find("select").change(function() {
- var new_value = Array();
- $(this).parent().find("select option:selected").each(function() {
- new_value.push(this.value);
- });
-
- //if statements so that "All" only can be selected alone and dont allow selecting no options
- if(jQuery.inArray("0",new_value) !== -1 && jQuery.inArray("0",previous) === -1){
- $(this).parent().find("select option:selected").each(function() {
- $(this).removeAttr('selected');
- $(this).parent().val(0);
- //$('.selectpicker').selectpicker('refresh');
- new_value = ["0"];
- });
- }else if(jQuery.inArray("0",new_value) !== -1 && jQuery.inArray("0",previous) !== -1 && new_value.length >
- previous.length){
- $(this).parent().find("select option:selected").each(function() {
- if(this.value == "0"){
- $(this).removeAttr('selected');
- //$('.selectpicker').selectpicker('refresh');
- new_value = Array(new_value[1]);
- }
- });
- }else if(new_value.length == 0){
- $(this).parent().find("select").val(0);
- //$('.selectpicker').selectpicker('refresh');
- new_value = ["0"];
- }
- previous = new_value;
-
-
- // get values from all selects
- var schools = $("#school").val();
- var programs = $("#program").val();
- var semesters = $("#semester").val();
- var years = $("#year").val();
- var outcomes = $("#outcome").val();
- var outcomes = $("#outcome").val();
- var is_graduate = $("#is_graduate").val();
-
- // query the values and get new data for chart
- $.post(
- "{{ URL::action('AdministratorsController@overview2_filter_results') }}",
- {
- schools: (schools),
- programs: (programs),
- semesters: (semesters),
- years: (years),
- outcomes: (outcomes),
- is_graduate: (is_graduate),
- },
- function(data)
- {
- var filters = data.filters;
- var outcomes_info = data.outcomes_info;
- var semesters = data.semesters;
-
- //////// update chart
- make_chart(outcomes_info,semesters);
-
-
- ////////update filters
- var new_all = $('
- <option />',{
- 'value': "0",
- 'html': "All",
- });;
-
- {{-- //update school filter
- var school_filter = $("#school");
- var new_school_options = filters.school;
- school_filter.find("option").remove();
- school_filter.append(new_all.clone(true));
- $.each(new_school_options, function(index, school)
- {
- var value = school.id;
- var html = school.name;
- var new_option = $('<option/>',{
- 'value': value,
- 'html': html,
- });;
- school_filter.append(new_option);
- }); --}}
-
- //update school filter
- var school_filter = $("#school");
- var school_selected_options = Array();
- school_filter.find("option:selected").each(function() {
- school_selected_options.push(this.value);
- });
- var new_school_options = filters.school;
- school_filter.find("option").remove();
- if(Array("0")[0] == school_selected_options[0]){
- school_filter.append(new_all.clone(true).attr("selected","selected"));
- } else{
- school_filter.append(new_all.clone(true));
- }
- $.each(new_school_options, function(index, school)
- {
- var value = school.id.toString();
- var html = school.name;
- var new_option;
- if(jQuery.inArray(value,school_selected_options) === -1){
- new_option = $('
- <option />',{
- 'value': value,
- 'html': html,
- });;
- }else{
- new_option = $('
- <option />',{
- 'value': value,
- 'html': html,
- 'selected': 'selected',
- });;
- }
- school_filter.append(new_option);
- });
-
- //update semester filter
- var semester_filter = $("#semester");
- var semester_selected_options = Array();
- semester_filter.find("option:selected").each(function() {
- semester_selected_options.push(this.value);
- });
- var new_semester_options = filters.semester;
- semester_filter.find("option").remove();
- if(Array("0")[0] == semester_selected_options[0]){
- semester_filter.append(new_all.clone(true).attr("selected","selected"));
- } else{
- semester_filter.append(new_all.clone(true));
- }
- $.each(new_semester_options, function(index, semester)
- {
- var value = semester.id.toString();
- var html = semester.name;
- var new_option;
- if(jQuery.inArray(value,semester_selected_options) === -1){
- new_option = $('
- <option />',{
- 'value': value,
- 'html': html,
- });;
- }else{
- new_option = $('
- <option />',{
- 'value': value,
- 'html': html,
- 'selected': 'selected',
- });;
- }
- semester_filter.append(new_option);
- });
-
- //update program filter
- var program_filter = $("#program");
- var program_selected_options = Array();
- program_filter.find("option:selected").each(function() {
- program_selected_options.push(this.value);
- });
- var new_program_options = filters.program;
- program_filter.find("option").remove();
- if(Array("0")[0] == program_selected_options[0]){
- program_filter.append(new_all.clone(true).attr("selected","selected"));
- } else{
- program_filter.append(new_all.clone(true));
- }
- $.each(new_program_options, function(index, program)
- {
- var value = program.id.toString();
- var html = program.name;
- var new_option;
- if(jQuery.inArray(value,program_selected_options) === -1){
- new_option = $('
- <option />',{
- 'value': value,
- 'html': html,
- });;
- }else{
- new_option = $('
- <option />',{
- 'value': value,
- 'html': html,
- 'selected': 'selected',
- });;
- }
- program_filter.append(new_option);
- });
-
-
- //update outcome filter
- var outcome_filter = $("#outcome");
- var outcome_selected_options = Array();
- outcome_filter.find("option:selected").each(function() {
- outcome_selected_options.push(this.value);
- });
- var new_outcome_options = filters.outcome;
- outcome_filter.find("option").remove();
- if(Array("0")[0] == outcome_selected_options[0]){
- outcome_filter.append(new_all.clone(true).attr("selected","selected"));
- } else{
- outcome_filter.append(new_all.clone(true));
- }
- $.each(new_outcome_options, function(index, outcome)
- {
- var value = outcome.id.toString();
- var html = outcome.name;
- var new_option;
- if(jQuery.inArray(value,outcome_selected_options) === -1){
- new_option = $('
- <option />',{
- 'value': value,
- 'html': html,
- });;
- }else{
- new_option = $('
- <option />',{
- 'value': value,
- 'html': html,
- 'selected': 'selected',
- });;
- }
- outcome_filter.append(new_option);
- });
-
-
- {{-- //update semester filter
- var semester_filter = $("#semester");
- var new_semester_options = filters.semester;
- semester_filter.find("option").remove();
- semester_filter.append(new_all.clone(true));
- $.each(new_semester_options, function(index, semester)
- {
- var value = semester.id;
- var html = semester.name;
- var new_option = $('<option/>',{
- 'value': value,
- 'html': html,
- });;
- semester_filter.append(new_option);
- }); --}}
-
-
- $('.selectpicker').selectpicker('refresh');
- }
- );
-
- });
-
- });
-
-
-
- {{-- @include('global.dummy-outcomes') --}}
-
- @stop
|