123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917 |
- @extends('layouts.master')
-
- @section('navigation')
- @if(Auth::user()->role==1)
- @include('local.managers.admins._new_navigation')
- @elseif(Auth::user()->role==2)
- @include('local.managers.sCoords._new_navigation')
- @elseif(Auth::user()->role==3)
- @include('local.managers.pCoords._new_navigation')
- @elseif(Auth::user()->role==4)
- @include('local.professors._navigation')
- @endif
- @stop
-
- @section('main')
-
- <!-- Update Rubric Modal -->
- <div class="modal fade" id="modal-confirm-update">
- <div class="modal-dialog modal-sm">
- <div class="modal-content">
- <div class="modal-header">
- <button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">×</span></button>
- <h4 class="modal-title">Update Rubric</h4>
- </div>
- <div class="modal-body">
- <p>Speak to any coordinators and/or professors in your School or
- Program that may be affected when you update this rubric. <strong>Professors
- that have already used this rubric will keep a copy of it as
- they used it, not an updated one.</strong></p>
- <p>Do you want to update this rubric?</p>
- </div>
- <div class="modal-footer">
- <button type="button" class="btn btn-default" data-dismiss="modal">No</button>
- <button id="button-update-rubric" class="btn btn-primary save">Update</button>
- </div>
- </div><!-- /.modal-content -->
- </div><!-- /.modal-dialog -->
- </div><!-- /.modal -->
-
-
- <!-- Delete Rubric Modal -->
- <div class="modal fade" id="modal-confirm-delete">
- <div class="modal-dialog modal-sm">
- <div class="modal-content">
- <div class="modal-header">
- <button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">×</span></button>
- <h4 class="modal-title">Delete Rubric</h4>
- </div>
- <div class="modal-body">
- <p>Please note: By deleting this rubric, it will no longer be available
- to your school's or program's professors. However, professors that
- have already used it will keep a copy in their activities. Speak to
- any coordinators and/or professors in your School or Program that may be affected.</p>
- <p>Are you sure you want to delete this rubric?</p>
- </div>
- <div class="modal-footer">
- <button type="button" class="btn btn-default" data-dismiss="modal">No</button>
- <button id="button-delete-rubric" class="btn btn-primary">Delete</button>
- </div>
- </div><!-- /.modal-content -->
- </div><!-- /.modal-dialog -->
- </div><!-- /.modal -->
-
- <div class="row">
- <div class="col-md-12">
-
- <div class="panel panel-default ">
- <div class="panel-heading">
- <span class="glyphicon glyphicon-triangle-bottom"></span>
- General Information
- </div>
- <div class="panel-body">
- <form>
- <div class="form-group">
- <label>Select a template, or create your own rubric</label>
- <select id="select-template" class="form-control selectpicker" data-live-search='true' data-live-search='true'>
- <option data-template-id="0">Custom</option>
- @foreach ($templates_dentro as $template)
- @if($template->school_id==NULL && $template->program_id==NULL)
- <option
- data-template-id="{{ $template->id }}"
- data-template-program-id="{{ $template->program_id }}"
- data-admin="1"
- >
- {{{ $template->name }}}
- </option>
- @else
- <option
- data-template-id="{{ $template->id }}"
- data-template-program-id="{{ $template->program_id }}"
- >
- {{{ $template->name }}}
- </option>
- @endif
-
- @endforeach
- @foreach ($templates_fuera as $template)
- @if($template->school_id==NULL && $template->program_id==NULL)
- <option
- data-template-id="{{ $template->id }}"
- data-template-program-id="{{ $template->program_id }}"
- data-admin="1"
- data-unmatch-criteria="1"
-
- >
- ## {{{ $template->name }}}
- </option>
- @else
- <option
- data-template-id="{{ $template->id }}"
- data-template-program-id="{{ $template->program_id }}"
- data-unmatch-criteria="1"
- >
- ## {{{ $template->name }}}
- </option>
- @endif
-
- @endforeach
- </select>
- <!--
- <span style="color: red;">Rubrics with "##" at the beginning contain criteria that are not associated with your program or school. You will not be able to use them until your criteria is matched with your program or school.
- </span>
- -->
- </div>
-
- <!-- If user is admin s/he can pick which schools can view the rubric -->
- @if(Auth::user()->role==1)
- <div class="form-group">
- <label>Select the School this rubric will be visible from</label>
- <select id="select-school" class="form-control selectpicker" data-live-search='true' data-live-search="true">
- <option data-school-id="0">All</option>
- @foreach ($schools as $school)
- <option data-school-id="{{ $school->id }}">
- {{ $school->name }}
- </option>
- @endforeach
- </select>
- </div>
- @endif
-
- <!-- If user is admin or school coordinator, s/he can pick which programs -->
- @if(Auth::user()->role==1 || Auth::user()->role==2 || Auth::user()->role==3)
- <div class="form-group">
- <label>Select the Program this rubric belongs to</label>
- <select id="select-program" class="form-control selectpicker" data-live-search='true'>
- @if(Auth::user()->role != 3)
- <option data-program-id="0">All</option>
- @endif
- @foreach ($programs as $program)
- <option
- data-program-id="{{ $program->id }}"
- data-program-program-id="{{ $program->program_id }}"
- >
- {{ $program->name }}
- </option>
-
- @endforeach
- </select>
- </div>
- @endif
- </form>
-
-
-
- <label for="">Select the lower bound for passing criteria</label>
- <form class="form-inline">
- <div class="form-group">
- <!-- Select percentage. If there is a rubric, select the saved value -->
-
- <select id="expected_percentage" class="form-control selectpicker" data-live-search='true'>
- @for($i = 50; $i <= 100; $i++)
- @if($i==70)
- <option selected="selected" value="{{ $i }}">{{ $i }}</option>
- @else
- <option value="{{ $i }}">{{ $i }}</option>
- @endif
- @endfor
- </select>
- % of all students must score at least
-
-
-
-
- <!-- Select points. If there is a rubric, select the saved value -->
- <select id="expected_points" class="form-control selectpicker" data-live-search='true'>
- @for($i = 0; $i <= 8; $i++)
- @if($i==5)
- <option selected="selected" value="{{ $i }}">{{ $i }}</option>
- @else
- <option value="{{ $i }}">{{ $i }}</option>
- @endif
- @endfor
- </select>
- point(s) in a criterion for it to pass.
- </div>
- </form>
- <br>
- <form>
-
- <div class="form-group">
- <label>Select the Maximum Score</label>
- <select id="max_score" class="form-control selectpicker" data-live-search='true'>
- @for($i = 1; $i <= 100; $i++)
- @if($i==8)
- <option selected="selected" value="{{ $i }}">{{ $i }}</option>
- @else
- <option value="{{ $i }}">{{ $i }}</option>
- @endif
- @endfor
-
- </select>
-
- </div>
- <div class="form-group">
- <label>Select the Type of Rubric</label>
- <select id="number_of_scales" class="form-control selectpicker" data-live-search='true' >
- @for($i = 1; $i <= 20; $i++)
- @if(8%$i == 0)
- @if($i==1)
- <option value="{{ $i }}">Cuantitative Rubric</option>
-
- @elseif($i==4)
- <option selected="selected" value="{{ $i }}">{{ $i }}-Scale Rubric</option>
- @else
- <option value="{{ $i }}">{{ $i }}-Scale Rubric</option>
- @endif
- @endif
- @endfor
-
- </select>
-
- </div>
- </form>
- <br>
-
- <form>
- <div class="form-group">
- <label>Select Status (you can change this later)</label>
- <div class="radio">
- <label>
- <input type="radio" name="is_visible" id="is_visible0" value="0" checked>
- This rubric is <strong>not complete</strong> yet and will not be available to professors.
- </label>
- </div>
- <div class="radio">
- <label>
- <input type="radio" name="is_visible" id="is_visible1" value="1">
- This rubric is <strong>complete</strong> and will be available to professors.
- </label>
- </div>
- </div>
- </form>
- <div>
- <p class="small">Note: You can hide or show this section by clicking on its heading. You may want to hide it to have more space. </p>
- </div>
- </div>
- </div>
-
- <div class="panel panel-default">
- <div class="panel-heading panel-annual-plans">
- <span class="glyphicon glyphicon-triangle-bottom"></span>
- Import Criteria From Annual Plans
- </div>
- <div class="panel-body">
- <form>
- <div class="form-group">
- <label>Select Annual Plan to Import From</label>
- <select id="select-annual-plans" class="form-control selectpicker" onchange="fetchSemesters(this)" data-live-search='true' data-live-search='true'>
- <option value = '0'>Nothing Selected</option>
- @foreach($annual_plans as $annual_plan)
- <option value = "{{$annual_plan->annual_plan_id}}">Annual Plan for {{$annual_plan->program_name}} on {{$annual_plan->academic_year}}</option>
-
-
- @endforeach
- </select>
-
- </div>
-
- <!-- If user is admin s/he can pick which schools can view the rubric -->
-
-
-
- </form>
-
-
-
- <label for="">Select a Semester</label>
- <form >
- <div class="form-group">
- <!-- Select percentage. If there is a rubric, select the saved value -->
-
- <select id="select-semester-plans" class="form-control selectpicker" onchange = "fetchCourses('#select-annual-plans', '#select-semester-plans')" data-live-search='true'>
-
- </select>
-
-
-
-
-
- </div>
- </form>
- <br>
-
- <form>
- <div class="form-group">
- <label>Select Course</label>
- <select id="select-courses-plans" class="form-control selectpicker" onchange = " fetchCriteriaFromPlan('#select-courses-plans','#select-annual-plans', '#max_score', '#number_of_scales');" data-live-search='true'>
-
- </select>
-
-
-
-
-
- </div>
-
- </form>
- <form>
- <div class="form-group">
- <label>Select Criteria</label>
- <select id="select-criteria-plans" class="form-control selectpicker" onchange = "" data-live-search='true'>
-
- </select>
-
-
-
-
-
- </div>
-
- </form>
- <div class="text-center">
- <div class="btn-group" role="group" aria-label="...">
- <button id="button-add-criterion-plan" onclick = 'putToTemplateSingle("#select-criteria-plans")'class="btn btn-md btn-primary add-criterion-plan">
- <span class="glyphicon glyphicon-plus"></span>
- Add Criterion
- </button>
- <button id="button-add-all-criterion-plan" onclick = 'putToTemplateMultiple("#select-criteria-plans")'class="btn btn-md btn-primary add-criterion-plan">
- <span class="glyphicon glyphicon-plus"></span>
- Add All Criterion From Course
- </button>
-
- </div>
- </div>
-
-
- </div>
- </div>
-
-
-
- <div class="well">
- <form>
- <div class="form-group">
- <label>Select a Learning Outcome</label>
- <select id="select-outcome" class="form-control selectpicker" data-live-search='true' >
- @foreach ($outcomes as $outcome)
- <option data-outcome-id="{{ $outcome->id }}">{{ $outcome->name }}</option>
- @endforeach
- </select>
- </div>
- <div class="form-group">
- <label>Select an Objective</label>
- <select id="select-objective" class="form-control selectpicker" data-live-search='true' >
-
- </select>
- </div>
-
- @if(Auth::user()->role != '1')
-
- <label>Filter Criteria</label>
- <div class="form-group">
- <label class="radio-inline">
- <input type="radio" checked name="criteria-filter" id="criteria-all" value="all"> All Criteria
- </label>
- <label class="radio-inline">
- <input type="radio" name="criteria-filter" id="criteria-school" value="school"> Criteria from my School
- </label>
- @if(Auth::user()->role == '3')
- <label class="radio-inline">
- <input type="radio" name="criteria-filter" id="criteria-program" value="program"> Criteria from my Program(s)
- </label>
- @endif
- </div>
- @endif
-
- <div class="form-group">
- <label>Select a Criterion</label><span id="updated-text" class="text-success small"> updated</span>
- <select id="select-criterion" class="form-control selectpicker" data-live-search='true'>
- </select>
- </div>
-
- <button id="button-add-criterion" class="btn btn-md btn-primary center-block"> <span class="glyphicon glyphicon-plus"></span> Add Criterion to Rubric</button>
- </form>
- </div>
- </div>
- </div>
-
- <div id="rubric-container" class="row">
- <div class="col-md-12">
- <table class="table table-striped table-condensed" style="table-layout: fixed">
- <thead id="theHead"><tr><th colspan="7 "><input id="rubric-name" type="text" class="form-control input-lg" placeholder="Rubric Name"></th></tr></thead>
- <thead id = "theScaleTitles">
-
- </thead>
- <thead>
- <tr id ="criterion-header">
- <th></th>
- <th></th>
- </tr>
- </thead>
- <tbody id = "allCriteria">
- </tbody>
- </table>
-
- <div id="copyright-info">
- <hr>
- <p class="small"><strong>Copyright</strong></p>
- <ul id="copyright-list" class="list-unstyled small">
- </ul>
- <hr>
- </div>
-
- <div class="text-center">
- <div class="btn-group" role="group" aria-label="...">
- <button id="button-create-rubric" class="btn btn-lg btn-primary save">
- <span class="glyphicon glyphicon-floppy-disk"></span>
- Create
- </button>
- <button id="button-confirm-update-rubric" data-toggle="modal" data-target="#modal-confirm-update" class="btn btn-lg btn-primary">
- <span class="glyphicon glyphicon-pencil"></span>
- Update
- </button>
- <button id="button-confirm-delete-rubric" data-toggle="modal" data-target="#modal-confirm-delete" class="btn btn-lg btn-primary">
- <span class="glyphicon glyphicon-remove"></span>
- Delete
- </button>
- <button id="button-print-rubric" class="btn btn-lg btn-primary"><span class="glyphicon glyphicon-print"></span> Print <span class="small">(saved version)</span></button>
- <button id = "button-get-criteria-objectives" class = "btn btn-lg btn-primary" onclick = 'fetchObjectivesForTemplate("#allCriteria")'><span class='glyphicon glyphicon-eye-open'></span> View Objectives</button>
- </div>
- </div>
- </div>
- </div>
-
- <div class="modal fade" id="rubric-modal">
- <div class="modal-dialog modal-md">
- <div class="modal-content">
- <div class="modal-header">
- <button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">×</span></button>
- <h4 class="modal-title text-center" id ="modal-title-rubric">You are adding criteria to your program</h4>
- </div>
- <div class="modal-body" id ="modal-body-rubric">
-
-
-
-
-
-
-
- </div>
- <div class="modal-footer">
- <button type="button" class="btn btn-default" data-dismiss="modal">Close</button>
- <button type="button" class="btn btn-primary" id ="saveButton" data-button-id = '' value="Save" type="button" onclick = "saveTemplate()" >Save</button>
-
- </div>
- </div><!-- /.modal-content -->
- </div><!-- /.modal-dialog -->
- </div>
-
-
- <div class="modal fade" id="objectives-crit-modal">
- <div class="modal-dialog modal-md">
- <div class="modal-content">
- <div class="modal-header">
- <button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">×</span></button>
- <h4 class="modal-title text-center" id ="modal-title-rubric">These are the objectives in each Criterion in this Rubric</h4>
- </div>
- <div class="modal-body" id ="objectives-crit-modal-body">
-
-
-
-
-
-
-
- </div>
- <div class="modal-footer">
- <button type="button" class="btn btn-default" data-dismiss="modal">Close</button>
-
- </div>
- </div><!-- /.modal-content -->
- </div><!-- /.modal-dialog -->
- </div>
- <script>
-
- </script>
- @stop
-
- @section('included-js')
-
- <!-- jQuery Sortable Tables -->
-
- <script>
-
- function putToTemplateSingle(select){
- addCriterion(select);
-
-
- }
- function putToTemplateMultiple(select){
-
- options = $(select).children('option');
- $.each(options, function(ind, opt){
- $(select).val($(opt).data('criterion-id'))
- $('.selectpicker').selectpicker('refresh');
- putToTemplateSingle(select);
- })
- }
-
- function fetchSemesters(select){
-
- $.post("{{URL::action('AnnualPlansController@fetchSemestersFromPlan')}}",
- {
- annual_plan_id:$(select).val()
- },
- function(semesters){
- //console.log(semesters);
-
- options_for_semesters = makeOptionsForSemesters(semesters);
- $("#select-semester-plans").html(options_for_semesters);
- $('.selectpicker').selectpicker('refresh');
- fetchCourses('#select-annual-plans', '#select-semester-plans')
- }
- )
- }
-
- function makeOptionsForSemesters(semesters){
- options = '';
- $.each(semesters, function(ind, semesters){
- options += "<option value = '"+semesters.id+"'>"+semesters.name+" ("+semesters.code+")</option>";
- })
- return options;
- }
-
- function fetchCourses(annual_plan, semesters){
- annual_plan_id= $(annual_plan).val(),
- semester_id= $(semesters).val()
- $.post(
- "{{URL::action('AnnualPlansController@fetchCoursesFromPlanForTemplate')}}",
- {
- annual_plan_id:$(annual_plan).val(),
- semester_id:$(semesters).val()
- },
- function(courses){
- //console.log(courses);
- options = makeOptionsForCourses(courses);
- $("#select-courses-plans").html(options);
- $('.selectpicker').selectpicker('refresh');
- fetchCriteriaFromPlan("#select-courses-plans","#select-annual-plans", '#max_score', '#number_of_scales');
-
-
- }
- )
- }
-
- function makeOptionsForCourses(courses){
- options = '';
- $.each(courses, function(ind, courses){
- options += "<option value= '"+courses.id+"'>"+courses.code+"["+courses.number+"] "+courses.name+"</option>";
- })
- return options;
- }
-
- function fetchCriteriaFromPlan(courses, annual_plan, max_score, number_of_scales){
-
- $.post(
- "{{URL::action('AnnualPlansController@fetchCriteriaFromPlan')}}",
- {
- course_id: $(courses).val(),
- annual_plan:$(annual_plan).val(),
- max_score:$(max_score).val(),
- number_of_scales:$(number_of_scales).val()
- },
- function(criteria){
- //console.log(criteria);
- options_criteria = makeOptionsForCriteria(criteria)
-
- $('#select-criteria-plans').html(options);
- $('.selectpicker').selectpicker('refresh');
- //if options is empty, disable add button
- if(options == ''){
- $('.add-criterion-plan').prop('disabled',true)
-
- }
- //if options is empty, disable add button
- else{
- $('.add-criterion-plan').prop('disabled',false)
-
- }
-
- }
- )
-
- }
-
- function makeOptionsForCriteria(criteria){
- options = '';
-
- $.each(criteria, function (ind, cri){
- options +='<option value = "'+cri.id+'" data-criterion-id ="'+cri.id+'">'+cri.name+'</option>';
- })
- return options;
- }
-
-
-
- function fetchObjectivesForTemplate(tbody){
-
- allCriteria = [];
- $(tbody).children('tr').each(function (index){
- allCriteria.push($(this).data('criterion-id'));
- })
- program_id = $("#select-program").val();
- $.post(
- "{{URL::action('TemplatesController@fetchObjectivesForTemplate')}}",
- {
- allCriteria:allCriteria,
- program_id:program_id
- },
-
- function(crit){
-
- modal_name = '#objectives-crit-modal';
- $(modal_name+'-body').html(' ');
- ol_crit = $("<ol>")
- $(modal_name+'-body').append(ol_crit);
- $.each(crit, function(index, cri){
-
-
- li = $("<li>").html("<strong>"+cri.name+"</strong>");
-
- ul_for_ob = $("<ul>");
-
- $.each(cri.all_objectives, function(ind, obj){
- li2 = $("<li>").html(obj.text)
- ul_for_ob.append(li2);
- })
- li.append(ul_for_ob);
- ol_crit.append(li);
-
-
- })
- $(modal_name).modal('show');
-
- }
- )
- }
- options_for_select = '';
-
- function fetchOutcomes(annual_plan_id){
-
-
- $.post(
- "{{URL::action('AnnualPlansController@fetchOutcomesFromPlan')}}",
- {
- annual_plan_id:annual_plan_id
- },
- function(outcomes){
- //console.log(outcomes);
-
- options_for_select = makeOptionsForOutcomes(outcomes);
- $("#select-outcomes-plans").html(options_for_select);
- $('.selectpicker').selectpicker('refresh');
- $("#select-outcomes-plans").trigger('change');
-
- }
- );
- }
-
-
- function fetchObjectives(select_outcome){
- //console.log($(select_outcome).find('option:selected').html())
- option_selected = $(select_outcome).find('option:selected');
- //console.log($(select_outcome).find('option:selected').data('objectives'))
- //console.log($(select_outcome).val())
- //console.log(option_selected.val())
- $.post(
- "{{URL::action('AnnualPlansController@fetchObjectivesFromPlan')}}",
- {
- program_id: option_selected.data('program-id'),
- typ_semester_outcome_id: option_selected.data('typ-semester-outcome-id'),
- semester_id:option_selected.data('semester-id'),
- outcome_id: $(select_outcome).val()
- },
- function(objectives){
- options_for_objective = makeOptionsForObjectives(objectives)
-
- }
- )
- }
-
- function makeOptionsForObjectives(objectives){
- //console.log(objectives);
-
- option_selected = '';
-
- }
-
- function makeOptionsForOutcomes(outcomes){
-
- options_for_select = '<optgroup label ="First Semester">';
- semester_id = outcomes[0].semester_id
- $.each(outcomes, function(ind, out){
- if(semester_id != out.semester_id){
- semester_id = out.semester_id
- options_for_select += '<optgroup label ="Second Semester">';
- }
- options_for_select +="<option value= '"+out.id+"' data-typ-semester-outcome-id ='"+out.typ_semester_outcome_id+"' data-program-id= '"+out.program_id+"' data-semester-id = '"+out.semester_id+"'>"+out.name+"</option>";
- });
- return options_for_select;
- }
- function saveTemplate(){
- //Prevent page refresh
-
-
-
-
- var criterionObject = new Object();
- var criteriaArray = new Array();
-
- var criteria = [];
- var titles = [];
-
-
- var amount_of_scales =parseInt($('#number_of_scales').find(':selected').val())+2;
- var max = parseInt($('#max_score').find(':selected').val());
- // For each criterion in the rubric, get its value and put it into an array
- $('tbody tr').each(function( index )
- {
- criteria.push($(this).data('criterion-id'));
-
-
-
-
-
-
-
-
-
- });
-
- $('.editable').each(function(index){
- titles.push($(this).text());
- })
-
- button_id = $("#saveButton").data('button-id');
- //console.log('school', $('#select-school').find(':selected').data('school-id') );
- //console.log('program', $('#select-program').find(':selected').data('program-id') );
-
- if(button_id=='button-create-rubric')
- {
- // Create
- $.post
- (
- "{{ URL::to('saveTemplate') }}",
- {
- name: $('#rubric-name').val(),
-
- school_id: $('#select-school').find(':selected').data('school-id'),
- program_id: $('#select-program').find(':selected').data('program-id'),
- expected_percentage: $('#expected_percentage').find(':selected').val(),
- expected_points: $('#expected_points').find(':selected').val(),
- is_visible: $('input[name=is_visible]:checked').val(),
- criteria : criteria,
- //scales: scales,
- max_score : max,
- /*copyright : copyright,
- notes :notes*/
- titles: titles
-
- },
- function(data)
- {
- location.reload(true);
- }
- );
- }
- else
- {
- //console.log('school', $('#select-school').find(':selected').data('school-id') );
- //console.log('program', $('#select-program').find(':selected').data('program-id') );
-
- // Update database
- $.post
- (
- "{{ URL::to('updateTemplate') }}",
- {
- id: $('#select-template').find(':selected').data('template-id'),
- name: $('#rubric-name').val(),
-
- school_id: $('#select-school').find(':selected').data('school-id'),
- program_id: $('#select-program').find(':selected').data('program-id'),
- expected_percentage: $('#expected_percentage').find(':selected').val(),
- expected_points: $('#expected_points').find(':selected').val(),
- is_visible: $('input[name=is_visible]:checked').val(),
- criteria : criteria,
- //scales: scales,
- max_score : max,
- /*copyright : copyright,
- notes :notes*/
- titles: titles
- },
- function(data)
- {
- location.reload(true);
- }
- );
- }
-
- }
- // Add a new criterion to the rubric
- function addCriterion(select)
- {
-
- // Show the rubric container
- if(!$('tbody').children().length)
- {
- $('#rubric-container').show();
- }
-
- // Get the selected criterion's id
- var id= parseInt($(select).find(':selected').data('criterion-id'));
- var program_ids = $(select).find(':selected').data('program-ids');
- //var objectives = $(select).find(':selected').data('assoc-objectives');
- // Check for duplicates
- var duplicates=false;
- numberOfScale = $('#number_of_scales').find(':selected').val();
- $('tbody tr').each(function()
- {
- if ($(this).data('criterion-id') == id)
- {
- duplicates=true;
- }
- });
-
- // If there are any, display an error
- if(duplicates)
- {
- $('#js-error-row').show();
- $('#js-error-row').find('#error-message').text('Error: The selected criterion was already added.');
- return;
- }
-
- // Otherwise, hide the error container
- else
- {
- $('#js-error-row').hide();
- }
-
-
- // Fetch information of the criterion selected
- $.post
- (
- "{{ URL::route('fetchCriterionWithTemplate') }}",
- { id: id,
- },
- function(data)
- {
- // Append the fetched data
- copyright = null;
- notes = null;
- if(data.criterion.copyright){
- copyright = data.criterion.copyright;
- }
- if(data.criterion.notes){
- notes = data.criterion.notes;
- }
- //objectives = JSON.stringify(objectives);
- var str ='<tr data-criterion-name ="'+data.criterion.name+'" data-program-ids = "['+program_ids+']" data-criterion-id="'+data.criterion.id+'" data-criterion-copyright="'+copyright+'" data-criterion-notes="'+notes+'" data-outcomes = "'+data.outcomes+'"><th><span class="glyphicon glyphicon-move"></span></th><td>';
- // console.log(str);
- var subcriteria = '';
- if(data.criterion.subcriteria){
-
- var subcriteria_array = JSON.parse(data.criterion.subcriteria);
- subcriteria = '<ul class="subcriteria list-unstyled">';
- subcriteria_array.forEach(function (value) {
- subcriteria += '<li>'+value+'</li>';
- });
- subcriteria += '</ul>';
-
- }
-
- if(notes)
- {
- str+='<span><em data-toggle="tooltip" data-placement="top" title="'+notes+'">'+data.criterion.name+'</em></span><sup></sup>'+subcriteria+'</td>';
- }
- else
- {
- str+='<span>'+data.criterion.name+'</span><sup></sup>'+subcriteria+'</td>';
- }
- numberOfScale = $('#number_of_scales').find(':selected').val();
-
- for(i=0; i<numberOfScale; i++){
- str+='<td>'+data.scales[i].description+'</td>';
-
-
- }
-
-
- str+= '<td>'+data.outcomes+'</td>'
-
-
- str +='<th><span class="glyphicon glyphicon-remove icon-btn" aria-hidden="true"></span></th></tr>';
- //console.log(str);
-
- $('table tbody').append(str);
-
- // Build copyright list
- buildCopyrightList();
-
- // Enable X-Edtable on this new row
- $('.editable').editable({
- unsavedclass: null,
- rows: 4
- });
-
- // Turn on tooltips again (because content is dynamic)
- $('[data-toggle="tooltip"]').tooltip();
-
- // Sortable rows
- $('.table').sortable({
- handle: 'span.glyphicon.glyphicon-move',
- containerSelector: 'table',
- itemPath: '> tbody',
- itemSelector: 'tr',
- placeholder: '<tr class="placeholder"><th><span class="glyphicon glyphicon-arrow-right"></span></th></tr>'
- });
- },
- 'json',
- );
- }
- // Build list from copyright info in rubric
- function buildCopyrightList()
- {
- // Empty the copyright list
- $('#copyright-list').empty();
-
- $('tbody tr').each(function( index )
- {
- var criterion = $(this);
- // If there's copyright info
- if(criterion.data('criterion-copyright')!=null){
- var copyright = criterion.data('criterion-copyright');
- if($('#copyright-list li').length>0)
- {
- var found = false;
- $('#copyright-list li').each(function()
- {
- // If found, give the string its number
- if(copyright==$(this).find('span').text())
- {
-
- copyrightNumber = Number.parseInt($(this).find('sup').text());
-
- //console.log('a: '+copyrightNumber);
-
- criterion.children('td:nth-child(2)').find('sup').text(copyrightNumber);
- found =true;
-
- //to break
- return false;
- }
- });
-
- // Otherwise, give it the next number and append a new item to the
- // list
- if(!found)
- {
- var copyrightNumber = $('#copyright-list li').length+1;
-
- //console.log('b: '+copyrightNumber);
- //console.log(criterion.children('td:nth-child(2)').find('sup').length);
-
- criterion.children('td:nth-child(2)').find('sup').text(copyrightNumber);
- $('#copyright-list').append('<li><sup>'+copyrightNumber+' </sup><span>'+copyright+'<span></li>');
- }
- }
- else
- {
- criterion.children('td:nth-child(2)').find('sup').text('1');
- $('#copyright-list').append('<li><sup>1 </sup><span>'+copyright+'<span></li>');
- }
- }
- });
-
- if($('#copyright-info li').length>0)
- {
- $('#copyright-info').show();
- }
- else
- {
- $('#copyright-info').hide();
- }
- }
- </script>
- <!-- X-Editable js -->
- <script src="{{ asset('vendor/xeditable/bootstrap-editable.min.js') }}"></script>
-
- <script src="{{app_path().'/scripts/rubric_scripts/scripts_for_annual_plan_export.js'}}"></script>
-
- @stop
-
- @section('javascript')
- $('#select-outcome').on('change',function(){
- fetchObjective(this);
- })
- // --------------------------------------------------------------------------
- // Functions
- // --------------------------------------------------------------------------
-
- function fetchObjective(outcome){
- $.post(
- "{{URL::route('fetchObjectivesForSelect')}}",
- {
- outcomeID:$(outcome).find(':selected').data('outcome-id'),
- },
- function(data){
- options = '';
- for(objective_index in data){
- options += '<option value = "'+data[objective_index].objective_id+'">'+data[objective_index].text+'</option>';
-
- }
- $('#select-objective').html(options);
- $('#select-objective').selectpicker('refresh');
- fetchCriteria($('#select-outcome'), $('#select-objective'));
-
- }, 'json',
- );
-
- }
- // Fetch criteria associated to a specific learning outcome
-
- function fetchCriteria(outcome, objective)
- {
- amount_of_scales = parseInt($('#number_of_scales').find(':selected').val());
-
- maximum = parseInt($('#max_score').find(":selected").val());
- $.post
- (
- "{{ URL::route('fetchCriteria') }}",
- {
- outcome_id: outcome.find(':selected').data('outcome-id'),
- objective_id: objective.find(':selected').val(),
- num_scales: amount_of_scales,
- maximum: maximum,
- filter: $('input[name=criteria-filter]:checked').val()
- },
- function(data)
- {
- $('#select-criterion').empty();
- //console.log(data);
- // Append criteria
- data.forEach( function (arrayItem)
- {
- objectives = JSON.stringify(arrayItem.objectives);
- $('#select-criterion')
- .append('<option data-criterion-id="'+arrayItem.id+'" data-program-ids = '+"'"+arrayItem.program_ids+"'"+' data-assoc-objectives= '+"'"+objectives+"'"+'>'+arrayItem.name+'</option>');
- });
-
- // If there are no criteria assigned to the selected outcome, disable the
- // input and the button used to add criteria.
- if(!$('#select-criterion').children().length)
- {
-
- $('#select-criterion').prop('disabled', true);
- $('#button-add-criterion').prop('disabled', true);
- }
-
- // Otherwise, enable both the input and the button
- else
- {
- $('#select-criterion').prop('disabled', false);
- $('#button-add-criterion').prop('disabled', false);
- }
-
- $('#updated-text').fadeIn('slow').fadeOut('slow');
-
- refreshSelects();
-
-
- }
- );
- }
-
-
-
- // Fetch single criterion
- function fetchCriterion(criterion)
- {
- $.post
- (
- "{{ URL::route('fetchCriterion') }}",
- { id: outcome.find(':selected').data('outcome-id')},
- function(data)
- {
- $('#select-criterion').empty();
-
- data.forEach( function (arrayItem)
- {
- $('#select-criterion')
- .append('<option data-criterion-id="'+arrayItem.id+'" >'+arrayItem.name+'</option>');
- });
-
- $('#select-criterion').append('<option data-criterion-id="0">Custom</option>');
-
- refreshSelects();
-
- }
- );
- }
-
-
- /* if(criterion.data('criterion-copyright')!=null)
- {
- var copyright = criterion.data('criterion-copyright');
-
- // If there is anything in the copyright list
- if($('#copyright-list li').length>0)
- {
- // Check copyright list for the same copyright text
- var found = false;
- $('#copyright-list li').each(function()
- {
- // If found, give the string its number
- if(copyright==$(this).find('span').text())
- {
-
- copyrightNumber = Number.parseInt($(this).find('sup').text());
-
- //console.log('a: '+copyrightNumber);
-
- criterion.children('td:nth-child(2)').find('sup').text(copyrightNumber);
- found =true;
-
- //to break
- return false;
- }
- });
-
- // Otherwise, give it the next number and append a new item to the
- // list
- if(!found)
- {
- var copyrightNumber = $('#copyright-list li').length+1;
-
- //console.log('b: '+copyrightNumber);
- //console.log(criterion.children('td:nth-child(2)').find('sup').length);
-
- criterion.children('td:nth-child(2)').find('sup').text(copyrightNumber);
- $('#copyright-list').append('<li><sup>'+copyrightNumber+' </sup><span>'+copyright+'<span></li>');
- }
- }
- // Otherwise, give it number 1 and append it
- else
- {
- criterion.children('td:nth-child(2)').find('sup').text('1');
- $('#copyright-list').append('<li><sup>1 </sup><span>'+copyright+'<span></li>');
- }
- }
- });
-
- if($('#copyright-info li').length>0)
- {
- $('#copyright-info').show();
- }
- else
- {
- $('#copyright-info').hide();
- }
- }
- */
- function refreshSelects()
- {
- $('#select-template').selectpicker('refresh');
- $('#select-school').selectpicker('refresh');
- $('#select-program').selectpicker('refresh');
- $('#select-outcome').selectpicker('refresh');
- $('#select-criterion').selectpicker('refresh');
- $('#expected_percentage').selectpicker('refresh');
- $('#expected_points').selectpicker('refresh');
- $('#number_of_scales').selectpicker('refresh');
- $('#select-objective').selectpicker('refresh');
- }
-
- // Fetch programs associated to a specific school
- function fetchPrograms(school)
- {
- //console.log(school.find(':selected'));
- $.ajax({
- type: 'POST',
- url: "{{ URL::action('ProgramsController@fetch') }}",
- data: { id: school.find(':selected').data('school-id')},
- success: function(data)
- {
- $('#select-program').empty();
- $('#select-program').append('<option data-program-id="0">All</option>');
-
- data.forEach( function (program)
- {
- $('#select-program')
- .append('<option data-program-id="'+program.id+'" >'+program.name+'</option>');
- });
- },
- async:false
- });
-
- if($('#select-school').find(':selected').data('school-id')!=0)
- $('#select-program').prop('disabled', false);
- else
- $('#select-program').prop('disabled', true);
-
- refreshSelects();
-
- }
-
- // Load a template. This function is different from the one for professors
- function loadTemplate()
- {
- $.post
- (
- "{{ URL::to('loadTemplate') }}",
- { id: $('#select-template').find(':selected').data('template-id')},
- function(data)
- {
- // Show the container and empty all rows
- $('#rubric-container').show();
- $('tbody').empty();
-
- //Set the name of the rubric
- $('#rubric-name').val(data.template.name);
-
- //console.log($('#select-school'));
- // Set school id to 0, then to the saved value if it exists
- $('#select-school option[data-school-id="0"]').prop('selected', true);
- $('#select-school option[data-school-id="'+data.template.school_id+'"]').prop('selected', true);
- console.log("name"+data.template.name);
- console.log("school"+data.template.school_id);
- console.log("name"+data.template.name);
-
- // Fetch programs associated to that school
- fetchPrograms($('#select-school'));
- // fetchPrograms(data.template.school_id);
-
- // Set program id to 0, then to the saved value if it exists
- $('#select-program option[data-program-id="0"]').prop('selected', true);
- $('#select-program option[data-program-id="'+data.template.program_id+'"]').prop('selected', true);
-
- // Set expected values
- // console.log(data.template.expected_percentage);
-
- // console.log(data.template.expected_points);
- // console.log(data.template.max_score);
-
- $('#max_score').val(data.template.max_score);
-
- $('#max_score').trigger("change");
-
- $('#expected_percentage').val(data.template.expected_percentage);
-
- $('#expected_points').val(data.template.expected_points);
-
- $('#number_of_scales').val(data.template.num_scales);
- refreshSelects();
- changeTable();
- // Set visibility
- var is_visible = data.template.is_visible;
- console.log("is_visible",is_visible);
- if(is_visible==1)
- {
- console.log("entro?")
- $('#is_visible0').prop('checked', false);
- $('#is_visible1').prop('checked', true);
- }
- else
- {
- $('#is_visible0').prop('checked', true);
- $('#is_visible1').prop('checked', false);
- }
-
-
- // Set the contents of the rubric
- var temp_criterion = data.criterion;
- // console.log(temp_criterion);
- for(temp_c in temp_criterion){
- current_criterion = temp_criterion[temp_c]
- // console.log(current_criterion.program_ids);
- objectives = JSON.stringify(current_criterion.objectives);
- //var str = '<tr data-assoc-objectives= '+"'"+objectives+"'"+' data-program_ids = "'+current_criterion.program_ids+'" data-criterion-name = "'+current_criterion.name+'" data-criterion-id="'+temp_criterion[temp_c].criterion_id+'" data-criterion-copyright="'+temp_criterion[temp_c].copyright+'" data-criterion-notes="'+temp_criterion[temp_c].notes+'" data-outcomes = "'+temp_criterion[temp_c].outcomes+'"><th><span class="glyphicon glyphicon-move"></span></th><td>';
- var str = "<tr data-program_ids = '"+current_criterion.program_ids+"' data-criterion-name = '"+current_criterion.name+"' data-criterion-id='"+temp_criterion[temp_c].criterion_id+"' data-criterion-copyright='"+temp_criterion[temp_c].copyright+"' data-criterion-notes='"+temp_criterion[temp_c].notes+"' data-outcomes = '"+temp_criterion[temp_c].outcomes+"'><th><span class='glyphicon glyphicon-move'></span></th><td>";
- // console.log(str);
-
- var subcriteria ='';
- if(current_criterion.subcriteria){
- var subcriteria_array = JSON.parse(current_criterion.subcriteria);
- subcriteria = '<ul class="subcriteria list-unstyled">';
- subcriteria_array.forEach(function (value) {
- subcriteria += '<li>'+value+'</li>';
- });
- subcriteria += '</ul>';
- }
- if(current_criterion.notes)
- {
- str+='<span><em data-toggle="tooltip" data-placement="top" title="'+current_criterion.notes+'">'+current_criterion.name+'</em></span><sup></sup>'+subcriteria;
- }
- else
- {
- str+='<span>'+current_criterion.name+'</span><sup></sup>'+subcriteria;
- }
- str+= '</td>';
-
- for(scaleIndex in current_criterion.scales){
-
- scale = current_criterion.scales[scaleIndex];
-
- str+='<td>'+scale.description+'</td>';
-
- }
- str+= '<td>'+current_criterion.outcomes+'</td>'
-
- str+='<th><span class="glyphicon glyphicon-remove" aria-hidden="true"></span></th></tr>';
- // console.log(str);
-
- $('table tbody').append(str);
-
-
-
-
-
- // Enable X-Edtable on this new row
- $('.editable').editable({
- unsavedclass: null,
- rows: 4
- });
-
- // Turn on tooltips again (because content is dynamic)
- $('[data-toggle="tooltip"]').tooltip();
-
-
- refreshSelects();
-
-
-
- }
-
- /*
- var contents = JSON.parse(data.contents);
- contents.forEach(function (data)
- {
- // Append the fetched data
- var str ='<tr data-criterion-id="'+data.id+'" data-criterion-copyright="'+data.copyright+'" data-criterion-notes="'+data.notes+'"><th><span class="glyphicon glyphicon-move"></span></th><td>';
-
-
- var subcriteria = '';
- if(data.subcriteria){
-
- var subcriteria_array = data.subcriteria;
- subcriteria = '<ul class="subcriteria list-unstyled">';
- subcriteria_array.forEach(function (value) {
- subcriteria += '<li>'+value+'</li>';
- });
- subcriteria += '</ul>';
-
- }
-
- if(data.notes)
- {
- str+='<span><em data-toggle="tooltip" data-placement="top" title="'+data.notes+'">'+data.name+'</em></span><sup></sup>'+subcriteria;
- }
- else
- {
- str+='<span>'+data.name+'</span><sup></sup>'+subcriteria;
- }
-
- str+='</td><td class="editable" data-type="textarea">'+data.description12+'</td>'
- +'<td class="editable" data-type="textarea">'+data.description34+'</td>'
- +'<td class="editable" data-type="textarea">'+data.description56+'</td>'
- +'<td class="editable" data-type="textarea">'+data.description78+'</td>'
- +'<th><span class="glyphicon glyphicon-remove" aria-hidden="true"></span></th></tr>';
-
- $('table tbody').append(str);
-
- // Build copyright list
- buildCopyrightList();
-
- // Enable X-Edtable on this new row
- $('.editable').editable({
- unsavedclass: null,
- rows: 4
- });
-
- // Turn on tooltips again (because content is dynamic)
- $('[data-toggle="tooltip"]').tooltip();
-
-
- refreshSelects();
- }); */
-
- // Sortable rows
- $('.table').sortable({
- handle: 'span.glyphicon.glyphicon-move',
- containerSelector: 'table',
- itemPath: '> tbody',
- itemSelector: 'tr',
- placeholder: '<tr class="placeholder"><th><span class="glyphicon glyphicon-arrow-right"></span></th></tr>'
- });
-
- // Build Copyright List
- buildCopyrightList();
-
- $('.editable').each(function (index){
- $(this).text(data.titles[index].text);
- })
-
- var selected = $('#select-template').find(':selected');
- var programs = {{ json_encode(Auth::user()->programs->lists('id')) }};
-
- var template_program = selected.data('template-program-id');
- // console.log(selected.data('template-program-id'));
- console.log("**"+programs.indexOf(selected.data('template-program-id').toString()));
-
- if(
- {{ Auth::user()->role }}==1
- || ({{ Auth::user()->role }}==2 && selected.data('admin')!=1)
- || ({{ Auth::user()->role }}==3
- && programs.indexOf(selected.data('template-program-id'))
- && selected.data('admin')!=1
- )
- )
- {
- $('#button-confirm-delete-rubric').prop('disabled', false);
- $('#button-confirm-update-rubric').prop('disabled', false);
- }
- else
- {
- // Disable update and edit
- $('#button-confirm-delete-rubric').prop('disabled', true);
- $('#button-confirm-update-rubric').prop('disabled', true);
- }
-
- // Enable print button
- $('#button-print-rubric').prop('disabled', false);
-
- fetchCriteria($('#select-outcome'), $('#select-objective'));
-
-
- },
- 'json',
- );
- }
-
-
- // Checks whether the user wants to save a rubric with a name that already exists
- function nameExists()
- {
- var duplicates = false;
- $('#select-template option').each(function()
- {
- var optionName = $(this).text().trim();
- if($('#rubric-name').val().trim()===optionName)
- {
- duplicates = true;
- }
- });
-
- refreshSelects();
-
- return duplicates;
- }
-
- //Enable disable program select
- function toggleProgramSelect(school)
- {
- if(school.find(':selected').data('school-id') <1)
- {
- $('#select-program option[data-program-id="0"]').prop('selected', true);
- $('#select-program').prop('disabled', true);
- }
- else
- {
- console.log(school);
- fetchPrograms(school);
- $('#select-program').prop('disabled', false);
- }
-
- refreshSelects();
-
- }
-
- fetchObjective($('#select-outcome'));
- // --------------------------------------------------------------------------
- // Events
- // --------------------------------------------------------------------------
-
- // Toggle visibility for accordion panels
- $('.panel-heading').on('click', function()
- {
- if($(this).find('.glyphicon').hasClass('glyphicon-triangle-right'))
- {
- $(this).find('.glyphicon').removeClass('glyphicon-triangle-right');
- $(this).find('.glyphicon').addClass('glyphicon-triangle-bottom');
- }
- else if($(this).find('.glyphicon').hasClass('glyphicon-triangle-bottom'))
- {
- $(this).find('.glyphicon').removeClass('glyphicon-triangle-bottom');
- $(this).find('.glyphicon').addClass('glyphicon-triangle-right');
- }
-
- $(this).siblings('.panel-body').stop().slideToggle();
- });
-
- $('.panel-annual-plans').trigger('click');
- $('.add-criterion-plan').prop('disabled',true)
-
- // Fetch criteria everytime something changes
- $('#select-objective').on('change', function(){
- fetchCriteria($('#select-outcome'), $('#select-objective'));
- })
-
- $("#number_of_scales").on('change', function(){
- fetchCriteria($('#select-outcome'), $('#select-objective'));
- })
-
-
- // When trying to change the template, ask the user to confirm and reset the
- // rubric if s/he does
- $('#select-template').on('change', function()
- {
- // If changing to custom template, reset
- if($('#select-template').find(':selected').data('template-id')=='0')
- {
- $('#rubric-container').hide();
- $('#rubric-name').val('');
- $('tbody').empty();
-
- // Disable delete, update and print buttons
- $('#button-confirm-delete-rubric').prop('disabled', true);
- $('#button-confirm-update-rubric').prop('disabled', true);
- $('#button-print-rubric').prop('disabled', true);
- }
- // Otherwise, load the selected template
- else
- {
- loadTemplate();
-
- //If user is admin, or the templates id matches user's, or the template
- // id's school matches user, allow editing
- var selected = $('#select-template').find(':selected');
- var programs = {{ json_encode(Auth::user()->programs->lists('id')) }};
-
- var template_program = selected.data('template-program-id');
- <!-- var dataset = selected.dataSet.templateProgramId; -->
- // console.log("***"+({{ Auth::user()->role }}==3
- // && programs.indexOf(selected.data('template-program-id'))
- // && selected.data('admin')!=1
- // )+programs+template_program+{{ json_encode(Auth::user()->programs->lists('id')) }});
-
- if(
- {{ Auth::user()->role }}==1
- || ({{ Auth::user()->role }}==2 && selected.data('admin')!=1)
- || ({{ Auth::user()->role }}==3
- && programs.indexOf(selected.data('template-program-id'))
- && selected.data('admin')!=1
- )
- )
- {
- $('#button-confirm-delete-rubric').prop('disabled', false);
- $('#button-confirm-update-rubric').prop('disabled', false);
- }
- else
- {
- // Disable update and edit
- $('#button-confirm-delete-rubric').prop('disabled', true);
- $('#button-confirm-update-rubric').prop('disabled', true);
- }
- if($('#select-template').find(':selected').data('unmatch-criteria')=='1')
- {
- $('#button-confirm-delete-rubric').prop('disabled', true);
- $('#button-confirm-update-rubric').prop('disabled', true);
- $('#button-create-rubric').prop('disabled', true);
-
- }
- else
- {
- $('#button-create-rubric').prop('disabled', false);
-
- }
-
- // Enable print button
- $('#button-print-rubric').prop('disabled', false);
-
- }
-
- });
-
- function changeTable(){
-
-
- amount_of_scales = parseInt($('#number_of_scales').find(':selected').val());
- counter2 = 0;
- maximum = parseInt($('#max_score').find(":selected").val());
-
-
- newScaleHeaders = '<th></th><th>Criterion</th>';
- editableTitles = '<th></th><th></th>';
- counter = 0;
- division = maximum/amount_of_scales;
- if(amount_of_scales==1){
- newScaleHeaders+= "<th>Score (1 - "+maximum+")</th>";
- editableTitles += "<th class = 'editable' data-type = 'textarea'>Click to edit Title </th>"
- }
- else if(maximum!= amount_of_scales){
- while(counter <amount_of_scales){
-
- minimumScore = 1+(counter*division);
- maximumScore = (1+counter)*division;
- newScaleHeaders+= "<th>Scale "+ (counter +1) + " ("+minimumScore+" - "+maximumScore+")</th>";
- editableTitles+="<th class = 'editable' data-type = 'textarea'>Click to edit Title "+(counter+1)+"</th>"
- counter++;
- }
- }else{
- while(counter <amount_of_scales){
-
-
- newScaleHeaders+= "<th>Scale "+ (counter +1) + " </th>";
- editableTitles+="<th class = 'editable' data-type = 'textarea'>Click to edit Title "+(counter+1)+"</th>"
-
- counter++;
- }
- }
- newScaleHeaders += '<th>Outcomes</th><th></th>';
- editableTitles += '<th></th><th></th>';
-
-
- $('#theScaleTitles').html(editableTitles);
- $("#criterion-header").html(newScaleHeaders);
- $('#allCriteria').html(' ');
- }
-
-
- // When a school changes, update its programs. If all is selected, disable
- $('#select-school').on('change', function()
- {
- toggleProgramSelect($(this));
- });
-
- $('#max_score').on('change', function(){
- var max = parseInt($('#max_score').find(':selected').val());
- var stringToScales = "<option value= '1'>Cuantitative Rubric </option>";
- selectedValue = 1;
- valueBefore = 0;
-
- for(i=2; i<=20; i++){
- if(max%i==0){
- stringToScales += "<option value= '"+i+"'>"+i+"-Scale Rubric</option>";
- selectedValue = i - valueBefore;
- valueBefore = i;
- }
- }
- $('#number_of_scales').html(stringToScales);
-
- $('#number_of_scales').selectpicker('refresh');
- $('#number_of_scales').val(selectedValue);
- $('#number_of_scales').selectpicker('refresh');
- var expected_points = Math.floor(max *0.7);
- var expected_points_html = '';
- for(i=1; i<max; i++){
- expected_points_html += '<option value="'+i+'"> '+i+'</option>';
- }
- $('#expected_points').html(expected_points_html);
- refreshSelects();
- $('#expected_points').val(expected_points);
- refreshSelects();
- changeTable();
- fetchCriteria($('#select-outcome'), $('#select-objective'))
- fetchCriteriaFromPlan('#select-courses-plans','#select-annual-plans', '#max_score', '#number_of_scales');
- })
- $('#number_of_scales').on('change', function(){
- changeTable();
- fetchCriteria($('#select-outcome'), $('#select-objective'))
- fetchCriteriaFromPlan('#select-courses-plans','#select-annual-plans', '#max_score', '#number_of_scales');
-
- $('#rubric-container').hide();
- $('#rubric-name').val('');
- $('tbody').empty();
-
- })
- // When a learning outcome changes, update its criteria
- /*$('#select-outcome, input[name=criteria-filter]').on('change', function()
- {
- fetchCriteria($('#select-outcome'));
- });
- */
- // When the add button is clicked
- $('#button-add-criterion').on('click', function(e)
- {
- //Prevent page refresh
- e.preventDefault();
-
- //Add new criterion
- addCriterion("#select-criterion");
- });
-
- // When the create or update buttons are clicked (.save)
- $('.save').on('click', function(e)
- {
- //Prevent page refresh
- e.preventDefault();
- var emptyFields=false;
-
- $('#allCriteria').children('td').each(function()
- {
- if (($(this).text() == "" || $(this).text() == "Empty") && !($(this).hasClass('nullable')) )
- {
- emptyFields=true;
- }
- });
-
-
- // If any fields are empty, display error
- if(emptyFields || $.trim($('#rubric-name').val())=='')
- {
- $('#js-error-row').show();
- $('#js-error-row').find('#error-message').text('Error: Please fill all the fields. Make sure your rubric has a name and all scale scores are filled.');
- return;
- }
- else
- {
- $('#js-error-row').hide();
- }
-
- // Check whether a rubric with the written name already exists
- if($(this).attr('id')=='button-create-rubric' && nameExists())
- {
- $('#js-error-row').show();
- $('#js-error-row').find('#error-message').text('Error: A template with that name already exists.');
- return;
- }
- else
- {
- $('#js-error-row').hide();
- }
- /*
- program_id = $('#select-program').find(':selected').data('program-id')
- if(program_id == 0){
- $('#modal-title-rubric').html("All criteria will be associated with this school's programs");
- htmlString = "<h5>The following criteria and objectives will be matched with all programs</h5>"
- htmlString += "<ol style='list-style-position: inside'>"
-
- $('tbody tr').each(function( index )
- {
- objectives = $(this).data('assoc-objectives');
-
- htmlString += "<li>" +$(this).data('criterion-name');
- htmlString += "<br><h5>This criterion is associated with these objectives</h5>"
- htmlString +="<ul style='padding-left: 5%; list-style-position: inside'>"
- for(index in objectives){
-
- objective_string = objectives[index];
- htmlString +="<li>"+objective_string+"</li>";
-
- }
- htmlString += "</ul>"
-
- htmlString +="</li>"
- htmlString+= "<br>";
- });
- htmlString +='</ol>';
- $("#modal-body-rubric").html(htmlString);
-
-
- }
- else{
- $('#modal-title-rubric').html('Some criteria will be associated with this program');
- $('tbody tr').each(function( index )
- {
- htmlString = '';
- console.log($(this));
- if(typeof $(this).data('program_ids')!== 'undefined')
- {
- program_ids = $(this).data('program_ids');
- console.log("ids"+program_ids);
- console.log("ids"+$(this).data('program_ids'));
- }
- else if(typeof $(this).data('program-ids')!== 'undefined')
- {
- program_ids = $(this).data('program-ids')
- console.log("Ids"+program_ids);
- }
- else
- {
- program_ids = [];
- console.log(" "+program_ids);
- }
- console.log(program_ids);
-
- // program_ids = $(this).data('program_ids')
- if(!program_ids.indexOf(program_id) ){
- title = "<h6>The following criteria and objectives will be matched with this program</h6>"
- htmlString += "<ol style='list-style-position: inside'>"
-
- objectives = $(this).data('assoc-objectives');
- //objectives = objectives.split(',');
- htmlString += "<li>" +$(this).data('criterion-name');
- htmlString += "<br><h6>This criterion is associated with these objectives</h6>"
- htmlString +="<ul style='padding-left: 5%; list-style-position: inside'>"
- for(index in objectives){
-
- objective_string = objectives[index];
- htmlString +="<li>"+objective_string+"</li>";
-
- }
- htmlString += "</ul>"
-
- htmlString +="</li>"
- htmlString+= "<br>";
-
- }
- if(htmlString != ''){
- $("#modal-body-rubric").html(title);
-
- $("#modal-body-rubric").append(htmlString);
-
- }
- });
- }
-
- $('#rubric-modal').modal('toggle');*/
- $('#saveButton').data('button-id',$(this).attr('id'));
-
-
- saveTemplate();
- });
-
- // When the confirm delete button is clicked
- $('#button-delete-rubric').on('click', function(e)
- {
- $('#modal-confirm-delete').modal('hide');
-
- // Delete from database
- $.post
- (
- "{{ URL::to('deleteTemplate') }}",
- {
- id: $('#select-template').find(':selected').data('template-id')
- },
- function(data)
- {
- location.reload();
- }
- );
- });
-
- // Remove a criterion and hide the table if it was the only one
- $('table').on('click', 'span.glyphicon-remove', function(e)
- {
- $(this).closest('tr').remove();
-
- if(!$('tbody').children().length)
- {
- $('#rubric-container').hide();
- }
-
- buildCopyrightList();
- });
-
- // When print button is clicked, redirect to print page
- $('#button-print-rubric').on('click', function(e)
- {
- e.preventDefault();
- window.location = "printRubric/"+$('#select-template').find(':selected').data('template-id');
-
- });
-
- // --------------------------------------------------------------------------
- // Page load
- // --------------------------------------------------------------------------
- $('#updated-text').hide();
-
- // Enable/disable program selection depending on school selection if user is
- // admin
- if({{Auth::user()->role}}==1)
- toggleProgramSelect($('#select-school'));
-
- // Fetch criteria of first outcome
- fetchCriteria($('#select-outcome'), $('#select-objective'));
- changeTable();
-
- // Hide table
- $('#rubric-container').hide();
-
- // Disable Update and Delete Buttons by default
- $('#button-confirm-update-rubric').prop('disabled', true);
- $('#button-confirm-delete-rubric').prop('disabled', true);
- $('#button-print-rubric').prop('disabled', true);
-
-
- // Sortable rows
- $('.table').sortable({
- handle: 'span.glyphicon.glyphicon-move',
- containerSelector: 'table',
- itemPath: '> tbody',
- itemSelector: 'tr',
- placeholder: '<tr class="placeholder"><th><span class="glyphicon glyphicon-arrow-right"></span></th></tr>'
- });
-
-
- @stop
|