diff --git a/notemyprogress/ajax.php b/notemyprogress/ajax.php index 6f2be358bfa312a5962bd5cfafa12c112f7313af..0ed7691410ffd51d3767c6aab06392b96592750d 100644 --- a/notemyprogress/ajax.php +++ b/notemyprogress/ajax.php @@ -27,11 +27,16 @@ define('AJAX_SCRIPT', true); require_once(dirname(__FILE__) . '/../../config.php'); require_once(dirname(__FILE__) . '/locallib.php'); +<<<<<<< HEAD global $USER, $COURSE, $DB; +======= +global $USER, $COURSE, $DB; + +>>>>>>> 42271d072b5508617432803ceb2659d2d3067682 -$userid = required_param('userid', PARAM_INT); $courseid = required_param('courseid', PARAM_INT); +$userid = required_param('userid', PARAM_INT); $COURSE = $DB->get_record('course', array('id' => $courseid), '*', MUST_EXIST); $USER = $DB->get_record('user', array('id' => $userid), '*', MUST_EXIST); @@ -39,8 +44,8 @@ $USER = $DB->get_record('user', array('id' => $userid), '*', MUST_EXIST); require_login($COURSE, false); $context = context_course::instance($courseid); require_capability('local/notemyprogress:ajax', $context); - -$beginDate = optional_param('beginDate', false, PARAM_TEXT); +/* Start the déclaration of all the optional parrameters */ +$beginDate = optional_param('beginDate', false, PARAM_TEXT); //optional_param('keyValue','DefaultValue','Type value'); $lastDate = optional_param('lastDate', false, PARAM_TEXT); $sectionname = optional_param('sectionname', false, PARAM_TEXT); @@ -83,20 +88,39 @@ $modulename = optional_param('modulename', false, PARAM_TEXT); $newinstance = optional_param('newinstance', false, PARAM_BOOL); +//gamification parameters +$rules = optional_param('rules', false ,PARAM_TEXT); +$levels = optional_param('levels', false ,PARAM_TEXT); +$settings= optional_param('settings', false ,PARAM_TEXT); +$url= optional_param('url', false ,PARAM_TEXT); +//$courseid = optional_param('modulename', false ,PARAM_TEXT); +$enable = optional_param('enable', false ,PARAM_BOOL); +$section = optional_param('section',false,PARAM_TEXT); -$params = array(); -$func = null; +/* */ +<<<<<<< HEAD //debug_text::print("Enter ajax file"); if ($action == 'saveconfigweek') { +======= +$params = array(); // Array containing the data +$func = null; // fuction which will be call at line 193 + +if($action == 'saveconfigweek') {//Exemple: if the action passed is saveconfigweek then my array contain (weeks,courseid,userid,newinstance) +>>>>>>> 42271d072b5508617432803ceb2659d2d3067682 array_push($params, $weeks); array_push($params, $courseid); array_push($params, $userid); array_push($params, $newinstance); +<<<<<<< HEAD if ($weeks && $courseid && $userid) { $func = "local_notemyprogress_save_weeks_config"; +======= + if($weeks && $courseid && $userid){ + $func = "local_notemyprogress_save_weeks_config"; //this function must be contained in localib.php +>>>>>>> 42271d072b5508617432803ceb2659d2d3067682 } } elseif ($action == 'changegroup') { array_push($params, $courseid); @@ -256,15 +280,54 @@ if ($action == 'saveconfigweek') { if ($courseid && $userid && $sectionname && $actiontype && $objectType && $objectName && $objectDescription && $currentUrl) { $func = "local_notemyprogress_addLogs"; } -} +}elseif($action =='savegamification'){ + array_push($params, $courseid); + array_push($params, $userid); + array_push($params, $rules); + array_push($params, $levels); + array_push($params, $settings); + array_push($params, $url); + array_push($params, $section); + if($courseid && $userid && $rules && $levels && $settings && $url) { + $func = "local_notemyprogress_save_gamification_config"; + } +}elseif($action =='rankable'){ + array_push($params, $courseid); + array_push($params, $userid); + array_push($params, $url); + if($courseid && $userid) { + $func = "local_notemyprogress_set_rankable_player"; + } +}elseif($action =='saveEnable'){ + array_push($params, $courseid); + array_push($params, $userid); + array_push($params,$enable); + array_push($params,$url); + if($courseid && $userid) { + $func = "local_notemyprogress_save_enable"; + } +}elseif($action =='studentGamificationViewed'){ + array_push($params, $courseid); + array_push($params, $userid); + array_push($params,$url); + if($courseid && $userid) { + $func = "local_notemyprogress_viewed_student_lvl"; + } +} if (isset($params) && isset($func)) { call_user_func_array($func, $params); +<<<<<<< HEAD } else { +======= + +}else{ +>>>>>>> 42271d072b5508617432803ceb2659d2d3067682 $message = get_string('api_invalid_data', 'local_notemyprogress'); - local_notemyprogress_ajax_response(array($message), 400); + local_notemyprogress_ajax_response(array($message));//,$action,$courseid, $userid ,$rules , $levels, $settings, $url,$func), 442); } +<<<<<<< HEAD function local_sr_metareflexion_get_week($weekcode, $courseid, $userid, $profile) { @@ -357,6 +420,9 @@ function local_sr_update_lastweek($courseid, $userid, $lastweekid, $classroom_ho function local_notemyprogress_logsNMP($beginDate, $lastDate, $courseid, $userid, $currentUrl) { +======= +function local_notemyprogress_logsNMP($beginDate, $lastDate, $courseid, $userid, $currentUrl) { +>>>>>>> 42271d072b5508617432803ceb2659d2d3067682 $logs = new \local_notemyprogress\logs($courseid, $userid); $logs->addLogsNMP("downloaded", "logfile", "LOGFILES", "nmp", $currentUrl, "File that contains all the activities performed on the moodle course in a time interval"); $jsonData = $logs->searchLogsNMP($beginDate, $lastDate); @@ -471,8 +537,13 @@ function local_notemyprogress_generate_dropout_data($courseid, $userid, $profile $dropout = new \local_notemyprogress\dropout($courseid, $userid); $dropout->generate_data(); local_notemyprogress_ajax_response([], "ok", true, 200); +<<<<<<< HEAD } else { local_notemyprogress_ajax_response([], "", false, 400); +======= + }else{ + local_notemyprogress_ajax_response([], "", false, 402); +>>>>>>> 42271d072b5508617432803ceb2659d2d3067682 } } @@ -490,7 +561,6 @@ function local_notemyprogress_get_student_sessions($weekcode, $courseid, $userid function local_notemyprogress_downloadMoodleLogs($beginDate, $lastDate, $courseid, $userid, $currentUrl) { $logs = new \local_notemyprogress\logs($courseid, $userid); - $logs->addLogsNMP("downloaded", "logfile", "LOGFILES", "moodle", $currentUrl, "File that contains all the activities performed on the Note My Progress plugin in a time interval"); $jsonData = $logs->searchLogsMoodle($beginDate, $lastDate); local_notemyprogress_ajax_response(array("jsonData" => $jsonData)); @@ -500,5 +570,49 @@ function local_notemyprogress_addLogs($sectionname, $actiontype, $courseid, $use { $logs = new \local_notemyprogress\logs($courseid, $userid); $logs->addLogsNMP($actiontype, $objectType, $sectionname, $objectName, $currentUrl, $objectDescription); +<<<<<<< HEAD local_notemyprogress_ajax_response(array("ok" => "ok")); } +======= + local_notemyprogress_ajax_response(array("ok"=>"ok")); +} +function local_notemyprogress_save_gamification_config($courseid, $userid, $rules, $levels, $settings, $url,$section){ + $logs = new \local_notemyprogress\logs($courseid, $userid); + $logs->addLogsNMP("Saved", $section, "CONFIGURATION_GAMIFICATION", "configuration_gamification", $url, "GamificationSaved"); + + $configLevels = new \local_notemyprogress\configgamification($courseid, $userid); + $configLevels->save_levels($levels, $settings, $rules); + //$configLevels->save_enable($enable); + $message = get_string('fml_api_save_successful', 'local_notemyprogress'); + local_notemyprogress_ajax_response($message); + } + +function local_notemyprogress_set_rankable_player($courseid, $userid,$url){ + $logs = new \local_notemyprogress\logs($courseid, $userid); + $logs->addLogsNMP("Saved", "section", "STUDENT_GAMIFICATION", "student_gamification", $url, "GamificationSaved"); + GLobal $DB; + $sql = "update {notemyprogress_xp} set rankable = ? where courseid = ? and userid = ?"; + $DB->execute($sql, array(1,$courseid, $userid)); + // $sql = "UPDATE {notemyprogress_xp} SET rankable = 1 WHERE courseid = 2 AND userid = 3"; + // $DB->execute($sql); + $message = get_string('fml_api_save_successful', 'local_notemyprogress'); + local_notemyprogress_ajax_response($message); +} + +function local_notemyprogress_save_enable($courseid, $userid, $enable,$url){ + $logs = new \local_notemyprogress\logs($courseid, $userid); + $logs->addLogsNMP("Saved", "section", "CONFIGURATION_GAMIFICATION", "configuration_gamification", $url, "GamificationSaved"); + $configLevels = new \local_notemyprogress\configgamification($courseid, $userid); + $configLevels->save_enable($enable); + $message = get_string('fml_api_save_successful', 'local_notemyprogress'); + local_notemyprogress_ajax_response($message); + } + function local_notemyprogress_viewed_student_lvl($courseid, $userid,$url){ + $logs = new \local_notemyprogress\logs($courseid, $userid); + $logs->addLogsNMP("Viewed", "section", "STUDENT_GAMIFICATION", "student_gamification", $url, "GamificationSaved");; + // $configLevels = new \local_notemyprogress\configgamification($courseid, $userid); + // $configLevels->save_enable($enable); + // $message = get_string('fml_api_save_successful', 'local_notemyprogress'); + // local_notemyprogress_ajax_response($message); + } +>>>>>>> 42271d072b5508617432803ceb2659d2d3067682 diff --git a/notemyprogress/amd/build/assignments.min.js b/notemyprogress/amd/build/assignments.min.js index 367c4202f79dc0c286675268acc2304b0acce2a3..93f13d0d59c0e2966aa4fc705294eb9327686454 100644 --- a/notemyprogress/amd/build/assignments.min.js +++ b/notemyprogress/amd/build/assignments.min.js @@ -1,3 +1,4 @@ +<<<<<<< HEAD define([ "local_notemyprogress/vue", "local_notemyprogress/vuetify", @@ -410,3 +411,7 @@ define([ }; }); //# sourceMappingURL=assignments.min.js.map +======= +define(["local_notemyprogress/vue","local_notemyprogress/vuetify","local_notemyprogress/axios","local_notemyprogress/moment","local_notemyprogress/pagination","local_notemyprogress/chartdynamic","local_notemyprogress/pageheader","local_notemyprogress/emailform","local_notemyprogress/helpdialog"],function(s,e,t,i,n,o,a,r,c){"use strict";return{init:function(i){s.use(e),s.component("pagination",n),s.component("chart",o),s.component("pageheader",a),s.component("emailform",r),s.component("helpdialog",c);let l=new s({delimiters:["[[","]]"],el:"#submissions",vuetify:new e,data:()=>({dialog:!1,selected_users:[],modulename:"",moduleid:!1,strings:i.strings,groups:i.groups,userid:i.userid,courseid:i.courseid,timezone:i.timezone,render_has:i.profile_render,scriptname:i.scriptname,loading:!1,errors:[],pages:i.pages,submissions:i.submissions,email_strings:i.strings.email_strings,access:i.access,assigns_submissions_colors:i.assigns_submissions_colors,access_content_colors:i.access_content_colors,access_chart_categories:[],access_chart_series:[],access_chart_users:[],help_dialog:!1,help_contents:[],email_object_name:""}),beforeMount(){this.generate_access_content_data()},mounted(){document.querySelector("#sessions-loader").style.display="none",document.querySelector("#submissions").style.display="block",setTimeout(function(){l.setGraphicsEventListeners()},1e3)},methods:{get_help_content(){let s=[];return s.push({title:this.strings.section_help_title,description:this.strings.section_help_description}),s},update_interactions(s){this.loading=!0,this.errors=[];let e={action:"assignments",userid:this.userid,courseid:this.courseid,weekcode:s.weekcode,profile:this.render_has};return t({method:"get",url:M.cfg.wwwroot+"/local/notemyprogress/ajax.php",params:e}).then(s=>{200==s.status&&s.data.ok?(this.submissions=s.data.data.submissions,this.access=s.data.data.access,this.generate_access_content_data()):this.error_messages.push(this.strings.error_network)}).catch(s=>{this.errors.push(this.strings.api_error_network)}).finally(()=>{this.loading=!1,l.addLogsIntoDB("viewed","week_"+s.weekcode,"week_section","Week section that allows you to obtain information on a specific week"),l.setGraphicsEventListeners()}),this.data},build_assigns_submissions_chart(){let s=new Object;return s.chart={type:"column",backgroundColor:null,style:{fontFamily:"poppins"}},s.title={text:null},s.colors=this.assigns_submissions_colors,s.xAxis={categories:this.submissions.categories,crosshair:!0},s.yAxis={min:0,title:{text:this.strings.assignsubs_chart_yaxis},allowDecimals:!1},s.tooltip={formatter:function(){let s=this.x.split("</b>");s=(s=(s=s[0]||"").split("<b>"))[1]||"";let e=this.series.name,t=this.y,i=l.strings.students_text,n=l.strings.send_mail;return 1==t&&(i=l.strings.student_text),"<b>"+s+"</b><br/><b>"+e+": </b>"+t+" "+i+"<br/>"+n}},s.plotOptions={series:{cursor:"pointer",point:{events:{click:function(){l.email_object_name="assigns_submissions";let s=this.category.split("</b>");s=(s=(s=s[0]||"").split("<b>"))[1]||"",l.email_strings.subject=l.email_strings.subject_prefix+" - "+s;let e=this.x,t=this.series.colorIndex;l.dialog=!0,l.selected_users=l.submissions.users[e][t],l.moduleid=l.submissions.modules[e],l.modulename="assign",l.scriptname="test"}}}}},s.series=this.submissions.data,s},build_access_content_chart(){let s=new Object;return s.chart={type:"bar",backgroundColor:null,style:{fontFamily:"poppins"}},s.title={text:null},s.colors=this.access_content_colors,s.xAxis={categories:this.access_chart_categories,title:{text:null},crosshair:!0},s.yAxis={min:0,title:{text:this.strings.access_chart_yaxis_label},labels:{overflow:"justify"},allowDecimals:!1},s.tooltip={formatter:function(){let s=this.x,e=this.series.name,t=this.y,i=l.strings.students_text,n=l.strings.send_mail;return 1==t&&(i=l.strings.student_text),"<b>"+s+"</b><br/><b>"+e+": </b>"+t+" "+i+"<br/>"+n}},s.plotOptions={bar:{dataLabels:{enabled:!1}},series:{cursor:"pointer",point:{events:{click:function(){l.email_object_name="access_content";let s=this.category;l.email_strings.subject=l.email_strings.subject_prefix+" - "+s;let e=this.x,t=this.series.colorIndex,i=l.get_users(l.access_chart_users[e][t]);l.selected_users=i;let n=l.get_moduletype(this.category);l.modulename=n.type,l.moduleid=n.id,l.dialog=!0,l.scriptname="test"}}}}},s.series=this.access_chart_series,s},update_dialog(s){this.dialog=s},generate_access_content_data(){let s=[];this.access.users.forEach(e=>{s.push(Number(e.id))});let e=[];this.access.types.forEach(s=>{s.show&&e.push(s.type)});let t=[];this.access.modules.forEach(s=>{e.includes(s.type)&&t.push(s)});let i=[],n=[],o=[],a=[];t.forEach(e=>{i.push(e.name);let t=e.users,r=s.filter(s=>!t.includes(s));o.push(t.length),a.push(r.length),n.push([t,r])});let r=[{name:this.strings.access,data:o},{name:this.strings.no_access,data:a}];this.access_chart_categories=i,this.access_chart_series=r,this.access_chart_users=n},get_users(s){let e=[];return this.access.users.forEach(t=>{let i=Number(t.id);s.includes(i)&&e.push(t)}),e},get_moduletype(s){let e;return this.access.modules.forEach(t=>{t.name===s&&(e=t)}),e},open_chart_help(s){let e=[];var t="",i="",n="",o="";"assigns_submissions"==s?(e.push({title:this.strings.assigns_submissions_help_title,description:this.strings.assigns_submissions_help_description_p1}),e.push({description:this.strings.assigns_submissions_help_description_p2}),t="viewed",n="help",i="assigns_submissions",o="Help section that provides information about the invested time chart",l.addLogsIntoDB(t,i,n,o)):"access_content"==s&&(e.push({title:this.strings.access_content_help_title,description:this.strings.access_content_help_description_p1}),e.push({description:this.strings.access_content_help_description_p2}),t="viewed",n="help",i="access_content",o="Help section that provides information about the sessions per hour chart",l.addLogsIntoDB(t,i,n,o)),this.help_contents=e,this.help_contents.length&&(this.help_dialog=!0)},update_help_dialog(s){this.help_dialog=s},get_timezone(){return`${this.strings.ss_change_timezone} ${this.timezone}`},setGraphicsEventListeners(){let s=document.querySelectorAll(".highcharts-container");s.length<1?setTimeout(l.setGraphicsEventListeners,500):(s[0].id="submissions",s[1].id="accessContent",s.forEach(s=>{s.addEventListener("mouseenter",l.addLogsViewGraphic)}))},addLogsViewGraphic(s){event.stopPropagation();var e="",t="",i="",n="";switch(s.target.id){case"submissions":e="viewed",t="assigns_submissions",i="chart",n="Chart showing the work submited by the students";break;case"accessContent":e="viewed",t="access_content",i="chart",n="Chart showing the course content accessed by the students";break;default:e="viewed",t="",i="chart",n="A chart"}l.addLogsIntoDB(e,t,i,n)},addLogsIntoDB(s,e,n,o){let a={courseid:i.courseid,userid:i.userid,action:"addLogs",sectionname:"TASKS_MONITORING",actiontype:s,objectType:n,objectName:e,currentUrl:document.location.href,objectDescription:o};t({method:"get",url:M.cfg.wwwroot+"/local/notemyprogress/ajax.php",params:a}).then(s=>{200==s.status&&s.data.ok}).catch(s=>{})}}})}}}); +//# sourceMappingURL=assignments.min.js.map +>>>>>>> 42271d072b5508617432803ceb2659d2d3067682 diff --git a/notemyprogress/amd/build/gamification.js b/notemyprogress/amd/build/gamification.js new file mode 100644 index 0000000000000000000000000000000000000000..5ba1ae7061ea5405269a932cd210be99e41a35be --- /dev/null +++ b/notemyprogress/amd/build/gamification.js @@ -0,0 +1,431 @@ +define([ + "local_notemyprogress/vue", + "local_notemyprogress/vuetify", + "local_notemyprogress/axios", + "local_notemyprogress/alertify", + "local_notemyprogress/pageheader", + "local_notemyprogress/chartdynamic", +], function (Vue, Vuetify, Axios, Alertify, PageHeader, ChartDynamic) { + "use strict"; + + function init(content) { + console.log(content); + Vue.use(Vuetify); + Vue.component("pageheader", PageHeader); + Vue.component("chart", ChartDynamic); + const app = new Vue({ + delimiters: ["[[", "]]"], + el: "#gamification", + vuetify: new Vuetify(), + data: { + strings: content.strings, + token: content.token, + render_has: content.profile_render, + ranking: content.ranking, + notifications: [], + loading: false, + tab: null, + levelsData: content.levels_data.levelsdata, + settings: content.levels_data.settings, + rulesData: content.levels_data.rules, + courseid: content.levels_data.courseid, + userid: content.levels_data.created_by, + enable: false, + events: content.events, + setPointsOption: "calculated", + pointsBase: 0, + pointsBaseOri: 0, + swDisableEnable: content.strings.swValue, + spreadData: [], + week_resources_categories: [], + week_resources_data: [], + week_resources_colors: "#FA4641", + indicators: content.indicators, + chartdata: content.chart_data, + }, + + beforeMount() {}, + mounted() { + this.pointsBase = +this.settings.pointsbase; + this.pointsBaseOri = +this.settings.pointsbase; + }, + computed: {}, + methods: { + get_help_content() { + let help_contents = []; + let help = new Object(); + help.title = this.strings.help_title; + help.description = this.strings.help_description; + help_contents.push(help); + return help_contents; + }, + update_dialog(value) { + this.dialog = value; + }, + update_help_dialog(value) { + this.help_dialog = value; + }, + openHelpSectionModalEvent() { + this.saveInteraction( + this.pluginSectionName, + "viewed", + "section_help_dialog", + 3 + ); + }, + get_timezone() { + let information = `${this.strings.change_timezone} ${this.timezone}`; + return information; + }, + saveInteraction(component, interaction, target, interactiontype) { + let data = { + action: "saveinteraction", + pluginsection: this.pluginSectionName, + component, + interaction, + target, + url: window.location.href, + interactiontype, + token: this.token, + }; + Axios({ + method: "post", + url: `${M.cfg.wwwroot}/local/notemyprogress/ajax.php`, + data: data, + }) + .then((r) => {}) + .catch((e) => {}); + }, + addLevel() { + let newLevel = this.levelsData.length + 1; + this.levelsData.push({ + lvl: newLevel, + nam: `${this.strings.level} ${newLevel}`, + des: ``, + points: this.pointsBase * (newLevel - 1), + }); + }, + removeLevel() { + if (this.levelsData.length > 2) { + this.levelsData.pop(); + } + }, + calculatePoints(index) { + let points = this.isNumber(this.pointsBase) * index; + this.levelsData[index].points = points; + return points; + }, + isNumber(x) { + if (x === "" || isNaN(x) || x == 0) { + return this.pointsBaseOri; + } + return parseInt(x); + }, + save_changes(logParam) { + this.notifications = ["Do you want to save the changes"]; + Alertify.confirm(this.strings.save_warning_content, () => { + this.saveGamificationConfig(logParam); + console.log(logParam); + }) // ON CONFIRM + .set({ title: this.strings.save_warning_title }) + .set({ + labels: { + cancel: this.strings.confirm_cancel, + ok: this.strings.confirm_ok, + }, + }); + }, + saveGamificationConfig(logParam) { + this.loading = true; + let settings = { + tit: this.settings.tit, + des: this.settings.des, + pointsbase: this.pointsBase, + }; + let data = { + courseid: this.courseid, + userid: this.userid, + action: "savegamification", + levels: JSON.stringify(this.levelsData), + settings: JSON.stringify(settings), + rules: JSON.stringify(this.rulesData), + token: this.token, + enable: this.enable, + section: logParam, + }; + let url = { url: window.location.href }; + Axios({ + method: "post", + url: + M.cfg.wwwroot + + "/local/notemyprogress/ajax.php?courseid=" + + this.courseid + + "&userid=" + + this.userid + + "&action=savegamification&levels=" + + data.levels + + "&settings=" + + data.settings + + "&rules=" + + data.rules + + "&url=" + + url.url + + "&enable=" + + data.enable + + "§ion=" + + data.section, + params: data, + }) + .then((response) => { + // console.log(response); + // console.log(response.status); + // console.log(url.url); + if (response.status == 200 && response.data.ok) { + this.showNotifications(response.data.data, "success"); + } else { + let message = + response.data.error || this.strings.api_error_network; + this.showNotifications(message, "error"); //in this line "error" define the kind of message send + } + }) + .catch((e) => { + let message = e.response.data || this.strings.api_error_network; + this.showNotifications(message, "error"); + }) + .finally(() => { + this.loading = false; + }); + }, + showNotifications(message, type, alert = true, notify = true) { + if (alert) this.notifications.push({ message, type }); + if (notify) Alertify.notify(message, type); + }, + table_headers() { + let headers = [ + { text: this.strings.ranking_text, value: "ranking" }, + { text: this.strings.level, value: "level" }, + { text: this.strings.student, value: "student" }, + { text: this.strings.total, value: "total" }, + { text: this.strings.progress, value: "progress_percentage" }, + ]; + return headers; + }, + addRule() { + this.rulesData.push({ + rule: "", + points: 0, + }); + }, + removeRule(index) { + if (this.rulesData.length > 2) { + this.rulesData.splice(index, 1); + } + }, + disableEnable(swDisableEnable) { + //traitement + this.enable = swDisableEnable; + let data = { + courseid: this.courseid, + userid: this.userid, + action: "saveEnable", + enable: this.enable, + }; + Axios({ + method: "get", + url: M.cfg.wwwroot + "/local/notemyprogress/ajax.php", + params: data, + }) + .then((response) => { + if (response.status == 200 && response.data.ok) { + this.showNotifications(response.data.data, "success"); + } else { + let message = + response.data.error || this.strings.api_error_network; + this.showNotifications(message, "error"); //in this line "error" define the kind of message send + } + }) + .catch((e) => { + let message = e.response.data || this.strings.api_error_network; + this.showNotifications(message, "error"); + }) + .finally(() => { + this.loading = false; + }); + }, + //? ////////////////////////////////////////////////////////////////////// ?// + //? //////////////////////////// ChartPart /////////////////////////////// ?// + //? ////////////////////////////////////////////////////////////////////// ?// + chart_spread() { + let chart = new Object(); + chart.chart = { + type: "column", + backgroundColor: null, + }; + chart.title = { + text: this.strings.chartTitle, + }; + chart.colors = ["#118AB2"]; + (chart.xAxis = { + type: "category", + labels: { + rotation: -45, + style: { + fontSize: "13px", + fontFamily: "Verdana, sans-serif", + }, + }, + }), + (chart.yAxis = { + min: 0, + title: { + text: this.strings.chartYaxis, + }, + }); + chart.legend = { + enabled: false, + }; + (chart.series = [ + { + name: null, + data: this.chartdata, //[["level : 1", 1]], + dataLabels: { + enabled: true, + rotation: -90, + color: "#FFFFFF", + align: "right", + format: "{point.y:.1f}", // one decimal + y: 10, // 10 pixels down from the top + style: { + fontSize: "13px", + fontFamily: "Verdana, sans-serif", + }, + }, + }, + ]), + console.log("series: "); + console.log(chart.series); + return chart; + }, + /* + build_inverted_time_chart() { + console.log("enter build_inverted_time_chart "); + //console.log(this.students_planification); + //console.log("this.data_report_meta_hours = "); + //console.log(this.data_report_meta_hours); + let chart = new Object(); + let meta = new Object(); + meta = this.chartdata_hours_week_dedication(); + console.log("meta = "); + console.log(meta); + let invest = [ + { + name: meta.labels[0], + y: meta.datasets[0].data[0], + }, + { + name: meta.labels[1], + y: meta.datasets[0].data[1], + }, + { + name: meta.labels[2], + y: meta.datasets[0].data[2], + }, + ]; + console.log("invest = "); + console.log(invest); + chart.chart = { + type: "bar", + backgroundColor: null, + style: { fontFamily: "poppins" }, + }; + chart.title = { text: null }; + chart.colors = this.inverted_time_colors; + chart.xAxis = { + type: "category", + crosshair: true, + }; + chart.yAxis = { + title: { + text: "Framboise", + }, + }; + chart.tooltip = { + shared: true, + useHTML: true, + formatter: function () { + let category_name = this.points[0].key; + let time = vue.convert_time(this.y); + return `<b>${category_name}: </b>${time}`; + }, + }; + chart.legend = { + enabled: false, + }; + chart.series = [ + { + colorByPoint: true, + data: invest, + }, + ]; + //console.log("this.inverted_time.data = "); + //console.log(this.inverted_time.data); + + // console.log("invest = "); + // console.log(invest); + return chart; + }, + chartdata_hours_week_dedication() { + var data = new Object(); + data.datasets = []; + + let inverted = + this.render_has == "teacher" + ? this.strings.inverted_time + : `${this.strings.myself} ${this.strings.inverted_time}`; + let planified = + this.render_has == "teacher" + ? this.strings.planified_time + : `${this.strings.myself} ${this.strings.planified_time}`; + data.labels = [inverted, planified]; + var dataset = new Object(); + dataset.label = "Horas"; + //console.log("data_report_meta_hours in chartdata_hours_week_dedication = "); + //console.log(this.data_report_meta_hours); + dataset.data = [ + parseFloat(this.data_report_meta_hours.horas_trabajadas), + parseInt(this.data_report_meta_hours.horas_planificadas), + ]; + dataset.backgroundColor = ["#ffa700", "#a0c2fa"]; + dataset.borderWidth = 0; + data.datasets.push(dataset); + + //if (this.render_has == "student" && this.compare_with_course) { + data.labels.splice(1, 0, this.strings.inverted_time_course); + //data.labels.splice(3, 0, this.strings.planified_time_course); + dataset.data.splice( + 1, + 0, + parseFloat(this.course_report_hours.horas_trabajadas) + ); + // dataset.data.splice( + // 3, + // 0, + // parseFloat(this.course_report_hours.horas_planificadas) + // ); + dataset.backgroundColor.splice(1, 0, "#ffa700"); + //dataset.backgroundColor.splice(3, 0, "#a0c2fa"); + //} + //console.log("data_report_meta_hours = "); + //console.log(this.data_report_meta_hours); + + //console.log("data = "); + //console.log(data); + return data; + },*/ + }, + }); + } + return { + init: init, + }; +}); diff --git a/notemyprogress/amd/build/listener.min.js b/notemyprogress/amd/build/listener.min.js index 39c3b1a9a90cc0385a9174e8eddfc89de14df846..ebc131aa87cd97b1cd55b6ba818e52d66d6268f1 100644 --- a/notemyprogress/amd/build/listener.min.js +++ b/notemyprogress/amd/build/listener.min.js @@ -4,7 +4,11 @@ define([], function () { document .querySelector("#downloadButton") .addEventListener("click", function () { +<<<<<<< HEAD //console.log("clicked !"); +======= + console.log("clicked !"); +>>>>>>> 42271d072b5508617432803ceb2659d2d3067682 }); }, }; diff --git a/notemyprogress/amd/build/student_gamification.js b/notemyprogress/amd/build/student_gamification.js new file mode 100644 index 0000000000000000000000000000000000000000..d7fb47847300386cc9b36ae99c5382f37b04e6d9 --- /dev/null +++ b/notemyprogress/amd/build/student_gamification.js @@ -0,0 +1,135 @@ +define([ + "local_notemyprogress/vue", + "local_notemyprogress/vuetify", + "local_notemyprogress/axios", + "local_notemyprogress/alertify", + "local_notemyprogress/pageheader", +], function (Vue, Vuetify, Axios, Alertify, PageHeader) { + "use strict"; + + function init(content) { + // console.log(content); + Vue.use(Vuetify); + Vue.component("pageheader", PageHeader); + const app = new Vue({ + delimiters: ["[[", "]]"], + el: "#student_gamification", + vuetify: new Vuetify(), + data: { + strings: content.strings, + token: content.token, + render_has: content.profile_render, + indicators: content.indicators, + levelInfo: content.indicators.levelInfo, + activity: content.indicators.activity, + courseid: content.indicators.cid, + userid: content.indicators.uid, + ranking: content.ranking, + tab: null, + levelsData: content.levels_data.levelsdata, + settings: content.levels_data.settings, + error_messages: [], + save_successful: false, + }, + beforeMount() { + let data = { + courseid: this.courseid, + userid: this.userid, + action: "studentGamificationViewed", + }; + Axios({ + method: "get", + url: M.cfg.wwwroot + "/local/notemyprogress/ajax.php", + params: data, + }); + }, + computed: {}, + methods: { + get_help_content() { + let help_contents = []; + let help = new Object(); + help.title = this.strings.help_title; + help.description = this.strings.help_description; + help_contents.push(help); + return help_contents; + }, + update_dialog(value) { + this.dialog = value; + }, + update_help_dialog(value) { + this.help_dialog = value; + }, + openHelpSectionModalEvent() { + this.saveInteraction( + this.pluginSectionName, + "viewed", + "section_help_dialog", + 3 + ); + }, + get_timezone() { + let information = `${this.strings.change_timezone} ${this.timezone}`; + return information; + }, + saveInteraction(component, interaction, target, interactiontype) { + let data = { + action: "saveinteraction", + pluginsection: this.pluginSectionName, + component, + interaction, + target, + url: window.location.href, + interactiontype, + token: content.token, + }; + Axios({ + method: "post", + url: `${M.cfg.wwwroot}/local/notemyprogress/ajax.php`, + data: data, + }) + .then((r) => {}) + .catch((e) => {}); + }, + table_headers() { + let headers = [ + { text: this.strings.ranking_text, value: "ranking" }, + { text: this.strings.level, value: "level" }, + { text: this.strings.student, value: "student" }, + { text: this.strings.total, value: "total" }, + { text: this.strings.progress, value: "progress_percentage" }, + ]; + return headers; + }, + + activateRanking() { + location.reload(); + //console.log(" cid : " + this.courseid + " UID : " + this.userid); + let data = { + action: "rankable", + pluginsection: this.pluginSectionName, + url: window.location.href, + token: content.token, + courseid: this.courseid, + userid: this.userid, + }; + Axios({ + method: "post", + url: + `${M.cfg.wwwroot}/local/notemyprogress/ajax.php?courseid=` + + this.courseid + + "&userid=" + + this.userid, + params: data, + }) + .then((r) => { + // console.log(r); + }) + .catch((e) => {}); + }, + }, + }); + } + return { + init: init, + }; +}); diff --git a/notemyprogress/amd/build/teacher.js b/notemyprogress/amd/build/teacher.js new file mode 100644 index 0000000000000000000000000000000000000000..59e8e40d2f52b57d58a94dc6da977a237f792f03 --- /dev/null +++ b/notemyprogress/amd/build/teacher.js @@ -0,0 +1,305 @@ +define([ + "local_notemyprogress/vue", + "local_notemyprogress/vuetify", + "local_notemyprogress/axios", + "local_notemyprogress/pagination", + "local_notemyprogress/chartstatic", + "local_notemyprogress/pageheader", + "local_notemyprogress/helpdialog", +], function ( + Vue, + Vuetify, + Axios, + Pagination, + ChartStatic, + PageHeader, + HelpDialog +) { + "use strict"; + + function init(content) { + // console.log(content); + Vue.use(Vuetify); + Vue.component("pagination", Pagination); + Vue.component("chart", ChartStatic); + Vue.component("pageheader", PageHeader); + Vue.component("helpdialog", HelpDialog); + let vue = new Vue({ + delimiters: ["[[", "]]"], + el: "#teacher", + vuetify: new Vuetify(), + data() { + return { + strings: content.strings, + groups: content.groups, + userid: content.userid, + courseid: content.courseid, + timezone: content.timezone, + render_has: content.profile_render, + + indicators: content.indicators, + week_resources_colors: content.week_resources_colors, + search: null, + week_resources_categories: [], + week_resources_data: [], + + help_dialog: false, + help_contents: [], + }; + }, + beforeMount() { + this.calculate_week_resources(); + }, + mounted() { + document.querySelector("#sessions-loader").style.display = "none"; + document.querySelector("#teacher").style.display = "block"; + }, + methods: { + get_help_content() { + let contents = []; + contents.push({ + title: this.strings.section_help_title, + description: this.strings.section_help_description, + }); + return contents; + }, + + get_course_grade() { + let grade = Number(this.indicators.course.grademax); + return this.isInt(grade) ? grade : grade.toFixed(2); + }, + + calculate_week_resources() { + let categories = [], + data = []; + let week_name; + this.indicators.weeks.forEach((week) => { + week_name = `${week.name} ${week.position + 1}`; + categories.push(week_name); + data.push(week.cms); + }); + let name = this.capitalizeFirstLetter( + this.strings.teacher_indicators_modules + ); + this.week_resources_categories = categories; + this.week_resources_data = [{ name, data }]; + }, + + build_week_resources_chart() { + let chart = new Object(); + chart.chart = { + type: "bar", + backgroundColor: null, + style: { fontFamily: "poppins" }, + }; + chart.title = { + text: null, + }; + chart.colors = this.week_resources_colors; + chart.xAxis = { + categories: this.week_resources_categories, + }; + chart.yAxis = { + min: 0, + title: { + text: this.strings.teacher_indicators_week_resources_yaxis_title, + }, + }; + chart.legend = { + enabled: false, + }; + chart.series = this.week_resources_data; + console.log(chart.series); + return chart; + }, + + build_weeks_sessions_chart() { + let chart = new Object(); + chart.chart = { + type: "heatmap", + backgroundColor: null, + style: { fontFamily: "poppins" }, + }; + chart.title = { + text: null, + }; + chart.xAxis = { + categories: this.strings.weeks, + }; + chart.yAxis = { + categories: this.indicators.sessions.categories, + title: null, + reversed: true, + }; + chart.colorAxis = { + min: 0, + minColor: "#E0E0E0", + maxColor: "#118AB2", + }; + chart.legend = { + layout: "horizontal", + verticalAlign: "bottom", + }; + chart.tooltip = { + formatter: function () { + let days = + vue.indicators.sessions.weeks[this.point.y][this.point.x] || ""; + let xCategoryName = vue.get_point_category_name(this.point, "x"); + let yCategoryName = vue.get_point_category_name(this.point, "y"); + let label = vue.strings.teacher_indicators_sessions; + if (this.point.value == 1) { + label = vue.strings.teacher_indicators_session; + } + return ( + "<b>" + + yCategoryName + + " " + + xCategoryName + + "</b>: " + + this.point.value + + " " + + label + + "<br/>" + + days + ); + }, + }; + chart.series = [ + { + borderWidth: 2, + borderColor: "#FAFAFA", + data: this.indicators.sessions.data, + }, + ]; + return chart; + }, + + table_headers() { + let headers = [ + { text: "", value: "id", align: "center", sortable: false }, + { text: this.strings.thead_name, value: "firstname" }, + { text: this.strings.thead_lastname, value: "lastname" }, + { text: this.strings.thead_email, value: "email" }, + { + text: this.strings.thead_progress, + value: "progress_percentage", + align: "center", + }, + { + text: this.strings.thead_sessions, + value: "sessions_number", + align: "center", + }, + { + text: this.strings.thead_time, + value: "inverted_time", + align: "center", + }, + ]; + return headers; + }, + + get_picture_url(userid) { + let url = `${M.cfg.wwwroot}/user/pix.php?file=/${userid}/f1.jpg`; + return url; + }, + + get_percentage_progress(value) { + return `${value} %`; + }, + + get_progress_tooltip(item) { + let module_label = this.strings.teacher_indicators_modules; + let finished_label = this.strings.teacher_indicators_finished; + if (item.cms.complete == 1) { + module_label = this.strings.teacher_indicators_module; + finished_label = this.strings.teacher_indicators_finalized; + } + return `${item.cms.complete} ${module_label} ${finished_label} ${this.strings.of_conector} ${item.cms.total}`; + }, + + get_point_category_name(point, dimension) { + let series = point.series, + isY = dimension === "y", + axis = series[isY ? "yAxis" : "xAxis"]; + return axis.categories[point[isY ? "y" : "x"]]; + }, + + capitalizeFirstLetter(string) { + return string.charAt(0).toUpperCase() + string.slice(1); + }, + + isInt(n) { + return n % 1 === 0; + }, + + open_chart_help(chart) { + let contents = []; + if (chart == "week_resources") { + contents.push({ + title: this.strings.week_resources_help_title, + description: this.strings.week_resources_help_description_p1, + }); + contents.push({ + description: this.strings.week_resources_help_description_p2, + }); + } else if (chart == "weeks_sessions") { + contents.push({ + title: this.strings.weeks_sessions_help_title, + description: this.strings.week_sessions_help_description_p1, + }); + contents.push({ + description: this.strings.week_sessions_help_description_p2, + }); + } else if (chart == "progress_table") { + contents.push({ + title: this.strings.progress_table_help_title, + description: this.strings.progress_table_help_description, + }); + } + this.help_contents = contents; + if (this.help_contents.length) { + this.help_dialog = true; + } + }, + + update_help_dialog(value) { + this.help_dialog = value; + }, + + get_timezone() { + let information = `${this.strings.ss_change_timezone} ${this.timezone}`; + return information; + }, + + addLogsIntoDB(action, objectName, objectType, objectDescription) { + let data = { + courseid: content.courseid, + userid: content.userid, + action: "addLogs", + sectionname: "TEACHER_GENERAL_INDICATORS", + actiontype: action, + objectType: objectType, + objectName: objectName, + currentUrl: document.location.href, + objectDescription: objectDescription, + }; + Axios({ + method: "get", + url: M.cfg.wwwroot + "/local/notemyprogress/ajax.php", + params: data, + }) + .then((response) => { + if (response.status == 200 && response.data.ok) { + } + }) + .catch((e) => {}); + }, + }, + }); + } + + return { + init: init, + }; +}); diff --git a/notemyprogress/amd/build/teacher.min.js b/notemyprogress/amd/build/teacher.min.js deleted file mode 100644 index 7b49e25001efbe51976e1ee2eb2274b2f88de329..0000000000000000000000000000000000000000 --- a/notemyprogress/amd/build/teacher.min.js +++ /dev/null @@ -1,2 +0,0 @@ -define(["local_notemyprogress/vue","local_notemyprogress/vuetify","local_notemyprogress/axios","local_notemyprogress/pagination","local_notemyprogress/chartstatic","local_notemyprogress/pageheader","local_notemyprogress/helpdialog"],function(e,t,s,i,r,o,n){"use strict";return{init:function(a){e.use(t),e.component("pagination",i),e.component("chart",r),e.component("pageheader",o),e.component("helpdialog",n);let l=new e({delimiters:["[[","]]"],el:"#teacher",vuetify:new t,data:()=>({strings:a.strings,groups:a.groups,userid:a.userid,courseid:a.courseid,timezone:a.timezone,render_has:a.profile_render,indicators:a.indicators,week_resources_colors:a.week_resources_colors,search:null,week_resources_categories:[],week_resources_data:[],help_dialog:!1,help_contents:[]}),beforeMount(){this.calculate_week_resources()},mounted(){document.querySelector("#sessions-loader").style.display="none",document.querySelector("#teacher").style.display="block"},methods:{get_help_content(){let e=[];return e.push({title:this.strings.section_help_title,description:this.strings.section_help_description}),e},get_course_grade(){let e=Number(this.indicators.course.grademax);return this.isInt(e)?e:e.toFixed(2)},calculate_week_resources(){let e,t=[],s=[];this.indicators.weeks.forEach(i=>{e=`${i.name} ${i.position+1}`,t.push(e),s.push(i.cms)});let i=this.capitalizeFirstLetter(this.strings.teacher_indicators_modules);this.week_resources_categories=t,this.week_resources_data=[{name:i,data:s}]},build_week_resources_chart(){let e=new Object;return e.chart={type:"bar",backgroundColor:null,style:{fontFamily:"poppins"}},e.title={text:null},e.colors=this.week_resources_colors,e.xAxis={categories:this.week_resources_categories},e.yAxis={min:0,title:{text:this.strings.teacher_indicators_week_resources_yaxis_title}},e.legend={enabled:!1},e.series=this.week_resources_data,e},build_weeks_sessions_chart(){let e=new Object;return e.chart={type:"heatmap",backgroundColor:null,style:{fontFamily:"poppins"}},e.title={text:null},e.xAxis={categories:this.strings.weeks},e.yAxis={categories:this.indicators.sessions.categories,title:null,reversed:!0},e.colorAxis={min:0,minColor:"#E0E0E0",maxColor:"#118AB2"},e.legend={layout:"horizontal",verticalAlign:"bottom"},e.tooltip={formatter:function(){let e=l.indicators.sessions.weeks[this.point.y][this.point.x]||"",t=l.get_point_category_name(this.point,"x"),s=l.get_point_category_name(this.point,"y"),i=l.strings.teacher_indicators_sessions;return 1==this.point.value&&(i=l.strings.teacher_indicators_session),"<b>"+s+" "+t+"</b>: "+this.point.value+" "+i+"<br/>"+e}},e.series=[{borderWidth:2,borderColor:"#FAFAFA",data:this.indicators.sessions.data}],e},table_headers(){return[{text:"",value:"id",align:"center",sortable:!1},{text:this.strings.thead_name,value:"firstname"},{text:this.strings.thead_lastname,value:"lastname"},{text:this.strings.thead_email,value:"email"},{text:this.strings.thead_progress,value:"progress_percentage",align:"center"},{text:this.strings.thead_sessions,value:"sessions_number",align:"center"},{text:this.strings.thead_time,value:"inverted_time",align:"center"}]},get_picture_url:e=>`${M.cfg.wwwroot}/user/pix.php?file=/${e}/f1.jpg`,get_percentage_progress:e=>`${e} %`,get_progress_tooltip(e){let t=this.strings.teacher_indicators_modules,s=this.strings.teacher_indicators_finished;return 1==e.cms.complete&&(t=this.strings.teacher_indicators_module,s=this.strings.teacher_indicators_finalized),`${e.cms.complete} ${t} ${s} ${this.strings.of_conector} ${e.cms.total}`},get_point_category_name(e,t){let s="y"===t;return e.series[s?"yAxis":"xAxis"].categories[e[s?"y":"x"]]},capitalizeFirstLetter:e=>e.charAt(0).toUpperCase()+e.slice(1),isInt:e=>e%1==0,open_chart_help(e){let t=[];"week_resources"==e?(t.push({title:this.strings.week_resources_help_title,description:this.strings.week_resources_help_description_p1}),t.push({description:this.strings.week_resources_help_description_p2})):"weeks_sessions"==e?(t.push({title:this.strings.weeks_sessions_help_title,description:this.strings.week_sessions_help_description_p1}),t.push({description:this.strings.week_sessions_help_description_p2})):"progress_table"==e&&t.push({title:this.strings.progress_table_help_title,description:this.strings.progress_table_help_description}),this.help_contents=t,this.help_contents.length&&(this.help_dialog=!0)},update_help_dialog(e){this.help_dialog=e},get_timezone(){return`${this.strings.ss_change_timezone} ${this.timezone}`},addLogsIntoDB(e,t,i,r){let o={courseid:a.courseid,userid:a.userid,action:"addLogs",sectionname:"TEACHER_GENERAL_INDICATORS",actiontype:e,objectType:i,objectName:t,currentUrl:document.location.href,objectDescription:r};s({method:"get",url:M.cfg.wwwroot+"/local/notemyprogress/ajax.php",params:o}).then(e=>{200==e.status&&e.data.ok}).catch(e=>{})}}})}}}); -//# sourceMappingURL=teacher.min.js.map diff --git a/notemyprogress/amd/src/logs.js b/notemyprogress/amd/src/logs.js index 11f3883b60293bf7ae8fb7f7e14bb168c131588f..edc81115e83e526f5c3d83be4a402cbbe5afa8ca 100644 --- a/notemyprogress/amd/src/logs.js +++ b/notemyprogress/amd/src/logs.js @@ -2,305 +2,379 @@ @author 2021 Éric Bart <bart.eric@hotmail.com> */ -define(["local_notemyprogress/vue", - "local_notemyprogress/vuetify", - "local_notemyprogress/axios", - "local_notemyprogress/moment", - "local_notemyprogress/pagination", - "local_notemyprogress/pageheader", - "local_notemyprogress/helpdialog", - "local_notemyprogress/alertify", - -], - function (Vue, Vuetify, Axios, Moment, Pagination, Pageheader, HelpDialog, Alertify) { - "use strict"; - - function init(content) { - const timeout = 60 * 120 * 1000 - Axios.defaults.timeout = timeout - Vue.use(Vuetify); - Vue.component('pagination', Pagination); - Vue.component('pageheader', Pageheader); - Vue.component('helpdialog', HelpDialog); - let vue = new Vue({ - delimiters: ["[[", "]]"], - el: "#logs", - vuetify: new Vuetify(), - data() { - return { - calendarData: {}, - strings: content.strings, - groups: content.groups, - userid: content.userid, - courseid: content.courseid, - timezone: content.timezone, - render_has: content.profile_render, - courseRole: content.courseRole, - loading: false, - errors: [], - pages: content.pages, - help_dialog: false, - help_contents: [], - dateRules: [ - v => !!v || this.strings.logs_invalid_date - ] +define([ + "local_notemyprogress/vue", + "local_notemyprogress/vuetify", + "local_notemyprogress/axios", + "local_notemyprogress/moment", + "local_notemyprogress/pagination", + "local_notemyprogress/pageheader", + "local_notemyprogress/helpdialog", + "local_notemyprogress/alertify", +], function ( + Vue, + Vuetify, + Axios, + Moment, + Pagination, + Pageheader, + HelpDialog, + Alertify +) { + "use strict"; + function init(content) { + const timeout = 60 * 120 * 1000; + Axios.defaults.timeout = timeout; + Vue.use(Vuetify); + Vue.component("pagination", Pagination); + Vue.component("pageheader", Pageheader); + Vue.component("helpdialog", HelpDialog); + let vue = new Vue({ + delimiters: ["[[", "]]"], + el: "#logs", + vuetify: new Vuetify(), + data() { + return { + calendarData: {}, + strings: content.strings, + groups: content.groups, + userid: content.userid, + courseid: content.courseid, + timezone: content.timezone, + render_has: content.profile_render, + courseRole: content.courseRole, + loading: false, + errors: [], + pages: content.pages, + help_dialog: false, + help_contents: [], + dateRules: [(v) => !!v || this.strings.logs_invalid_date], + }; + }, + beforeMount() { + document.querySelector("#downloadButtonMoodle").style.display = "none"; + document.querySelector("#downloadButtonNMP").style.display = "none"; + }, + mounted() { + document.querySelector(".v-application--wrap").style.minHeight = "60vh"; + document.querySelector("#sessions-loader").style.display = "none"; + document.querySelector("#helpMoodle").style.display = "block"; + document.querySelector("#helpNMP").style.display = "block"; + document.querySelector("#downloadButtonMoodle").style.display = "block"; + document.querySelector("#downloadButtonNMP").style.display = "block"; + }, + methods: { + get_Moodlefile() { + let lastDate = document.querySelector("#lastDateMoodle"); + let beginDate = document.querySelector("#beginDateMoodle"); + let timestampBeginDate = 0; + let timestampLastDate = 0; + let parsedBeginDate = []; + let parsedLastDate = []; + this.url = false; + this.loading = true; + var data = { + action: "downloadMOODLElogs", + courseid: this.courseid, + userid: this.userid, + beginDate: beginDate.value, + lastDate: lastDate.value, + currentUrl: window.location.href, + }; + if (beginDate.value != "" && lastDate.value != "") { + parsedBeginDate = beginDate.value.split("-"); + timestampBeginDate = new Date( + parsedBeginDate[0], + parsedBeginDate[1] - 1, + parsedBeginDate[2] + ); + parsedLastDate = lastDate.value.split("-"); + timestampLastDate = new Date( + parsedLastDate[0], + parsedLastDate[1] - 1, + parsedLastDate[2] + ); + if (timestampBeginDate.getTime() <= timestampLastDate.getTime()) { + if (timestampBeginDate.getTime() <= Date.now()) { + document.querySelector("#downloadButtonMoodle").innerHTML = + this.strings.logs_download_btn; + document.getElementById("downloadButtonMoodle").disabled = true; + Axios({ + method: "get", + url: M.cfg.wwwroot + "/local/notemyprogress/ajax.php", + timeout: timeout, + params: data, + }) + .then((response) => { + this.loading = false; + if (response.status == 200 && response.data.ok) { + let jsonData = response.data.data.jsonData; + jsonData = jsonData.map((row) => ({ + Role: row.user.role, + Email: row.user.email, + Fullname: row.user.firstname + " " + row.user.lastname, + Date: row.time.date, + Hour: row.time.hour, + ACTION_VERB: row.action.actionverb, + CourseID: row.course.courseid, + CourseName: row.course.coursename, + OBJECT_ID: row.action.objectid, + OBJECT_NAME: row.action.objectname, + OBJECT_TYPE: row.action.objecttype, + })); + let csvData = vue.objectToCSV(jsonData); + vue.downloadCSV(csvData, "Activity_Moodle"); + document.querySelector( + "#downloadButtonMoodle" + ).innerHTML = this.strings.logs_valid_Moodlebtn; + document.getElementById( + "downloadButtonMoodle" + ).disabled = false; + Alertify.success( + this.strings.logs_success_file_downloaded + ); + } else { + Alertify.error( + this.strings.logs_error_problem_encountered + ); + document.querySelector( + "#downloadButtonMoodle" + ).innerHTML = this.strings.logs_valid_Moodlebtn; + document.getElementById( + "downloadButtonMoodle" + ).disabled = false; } - }, - beforeMount() { - document.querySelector("#downloadButtonMoodle").style.display = "none"; - document.querySelector("#downloadButtonNMP").style.display = "none"; - }, - mounted() { - document.querySelector(".v-application--wrap").style.minHeight = "60vh"; - document.querySelector("#sessions-loader").style.display = "none"; - document.querySelector("#helpMoodle").style.display = "block"; - document.querySelector("#helpNMP").style.display = "block"; - document.querySelector("#downloadButtonMoodle").style.display = "block"; - document.querySelector("#downloadButtonNMP").style.display = "block"; - }, - methods: { - get_Moodlefile() { - let lastDate = document.querySelector("#lastDateMoodle"); - let beginDate = document.querySelector("#beginDateMoodle"); - let timestampBeginDate = 0; - let timestampLastDate = 0; - let parsedBeginDate = []; - let parsedLastDate = []; - this.url = false; - this.loading = true; - var data = { - action: "downloadMOODLElogs", - courseid: this.courseid, - userid: this.userid, - beginDate: beginDate.value, - lastDate: lastDate.value, - currentUrl: window.location.href, - } - if (beginDate.value != "" && lastDate.value != "") { - parsedBeginDate = beginDate.value.split("-"); - timestampBeginDate = new Date(parsedBeginDate[0], parsedBeginDate[1] - 1, parsedBeginDate[2]); - parsedLastDate = lastDate.value.split("-"); - timestampLastDate = new Date(parsedLastDate[0], parsedLastDate[1] - 1, parsedLastDate[2]); - if (timestampBeginDate.getTime() <= timestampLastDate.getTime()) { - if (timestampBeginDate.getTime() <= Date.now()) { - document.querySelector('#downloadButtonMoodle').innerHTML = this.strings.logs_download_btn; - document.getElementById('downloadButtonMoodle').disabled = true; - Axios({ - method: 'get', - url: M.cfg.wwwroot + "/local/notemyprogress/ajax.php", - timeout: timeout, - params: data, - }).then((response) => { - this.loading = false - if (response.status == 200 && response.data.ok) { - let jsonData = response.data.data.jsonData; - jsonData = jsonData.map(row => ({ - Role: row.user.role, - Email: row.user.email, - Fullname: row.user.firstname + ' ' + row.user.lastname, - Date: row.time.date, - Hour: row.time.hour, - ACTION_VERB: row.action.actionverb, - CourseID: row.course.courseid, - CourseName: row.course.coursename, - OBJECT_ID: row.action.objectid, - OBJECT_NAME: row.action.objectname, - OBJECT_TYPE: row.action.objecttype - })); - let csvData = vue.objectToCSV(jsonData); - vue.downloadCSV(csvData, "Activity_Moodle"); - document.querySelector('#downloadButtonMoodle').innerHTML = this.strings.logs_valid_Moodlebtn; - document.getElementById('downloadButtonMoodle').disabled = false; - Alertify.success(this.strings.logs_success_file_downloaded); - } else { - Alertify.error(this.strings.logs_error_problem_encountered); - document.querySelector('#downloadButtonMoodle').innerHTML = this.strings.logs_valid_Moodlebtn; - document.getElementById('downloadButtonMoodle').disabled = false; - } - }).catch((e) => { - Alertify.error(this.strings.logs_error_problem_encountered); - this.loading = false; - document.querySelector('#downloadButtonMoodle').innerHTML = this.strings.logs_valid_Moodlebtn; - document.getElementById('downloadButtonMoodle').disabled = false; - }).finally(() => { - this.loading = false; - document.querySelector('#downloadButtonMoodle').innerHTML = this.strings.logs_valid_Moodlebtn; - document.getElementById('downloadButtonMoodle').disabled = false; - }); - } else { - Alertify.error(this.strings.logs_error_begin_date_superior); - } - } else { - Alertify.error(this.strings.logs_error_begin_date_inferior); - } - } else { - Alertify.error(this.strings.logs_error_empty_dates); - } - }, - - objectToCSV(jsonData) { - let csvRows = []; + }) + .catch((e) => { + Alertify.error(this.strings.logs_error_problem_encountered); + this.loading = false; + document.querySelector("#downloadButtonMoodle").innerHTML = + this.strings.logs_valid_Moodlebtn; + document.getElementById( + "downloadButtonMoodle" + ).disabled = false; + }) + .finally(() => { + this.loading = false; + document.querySelector("#downloadButtonMoodle").innerHTML = + this.strings.logs_valid_Moodlebtn; + document.getElementById( + "downloadButtonMoodle" + ).disabled = false; + }); + } else { + Alertify.error(this.strings.logs_error_begin_date_superior); + } + } else { + Alertify.error(this.strings.logs_error_begin_date_inferior); + } + } else { + Alertify.error(this.strings.logs_error_empty_dates); + } + }, - let headers = Object.keys(jsonData[0]); - csvRows.push(headers.join(';')); + objectToCSV(jsonData) { + let csvRows = []; - for (const row of jsonData) { - const values = headers.map(header => { - const escaped = ('' + row[header]).replace(/"/g, '\\"'); - return `"${escaped}"`; - }) - csvRows.push(values.join(';')); - } + let headers = Object.keys(jsonData[0]); + csvRows.push(headers.join(";")); - return csvRows.join('\n'); - }, + for (const row of jsonData) { + const values = headers.map((header) => { + const escaped = ("" + row[header]).replace(/"/g, '\\"'); + return `"${escaped}"`; + }); + csvRows.push(values.join(";")); + } - downloadCSV(data, documentName) { - let blob = new Blob([data], { type: 'text/csv' }); - let url = window.URL.createObjectURL(blob); - const a = document.createElement('a'); - a.setAttribute('hidden', ''); - a.setAttribute('href', url); - a.setAttribute('download', documentName + '.csv'); - document.body.appendChild(a); - a.click(); - document.body.removeChild(a); - }, + return csvRows.join("\n"); + }, - getRapport() { - Alertify.confirm(this.strings.logs_download_details_description, - () => { - let path = M.cfg.wwwroot + "/local/notemyprogress/downloads/Details_Informations_LogsNMP.pdf"; - var link = document.createElement('a'); - link.href = path; - link.download = "Details_Informations_LogsNMP.pdf"; - link.click(); - Alertify.success(this.strings.logs_download_details_validation); - }).set({ title: this.strings.logs_download_details_title }) - .set({ labels: { cancel: this.strings.logs_download_details_cancel, ok: this.strings.logs_download_details_ok } }); - }, + downloadCSV(data, documentName) { + let blob = new Blob([data], { type: "text/csv" }); + let url = window.URL.createObjectURL(blob); + const a = document.createElement("a"); + a.setAttribute("hidden", ""); + a.setAttribute("href", url); + a.setAttribute("download", documentName + ".csv"); + document.body.appendChild(a); + a.click(); + document.body.removeChild(a); + }, - get_NMPfile() { - let lastDate = document.querySelector("#lastDateNMP"); - let beginDate = document.querySelector("#beginDateNMP"); - let timestampBeginDate = 0; - let timestampLastDate = 0; - let parsedBeginDate = []; - let parsedLastDate = []; - this.url = false; - this.loading = true; - var data = { - action: "downloadNMPlogs", - courseid: this.courseid, - userid: this.userid, - beginDate: beginDate.value, - lastDate: lastDate.value, - currentUrl: window.location.href, - } - if (beginDate.value != "" && lastDate.value != "") { - parsedBeginDate = beginDate.value.split("-"); - timestampBeginDate = new Date(parsedBeginDate[0], parsedBeginDate[1] - 1, parsedBeginDate[2]); - parsedLastDate = lastDate.value.split("-"); - timestampLastDate = new Date(parsedLastDate[0], parsedLastDate[1] - 1, parsedLastDate[2]); - if (timestampBeginDate.getTime() <= timestampLastDate.getTime()) { - if (timestampBeginDate.getTime() <= Date.now()) { - document.querySelector('#downloadButtonNMP').innerHTML = this.strings.logs_download_btn; - document.getElementById('downloadButtonNMP').disabled = true; - Axios({ - method: 'get', - url: M.cfg.wwwroot + "/local/notemyprogress/ajax.php", - timeout: timeout, - params: data, - }).then((response) => { - this.loading = false - if (response.status == 200 && response.data.ok) { - if (beginDate.value != "" || lastDate.value != "") { - let jsonData = response.data.data.jsonData; - jsonData = jsonData.map(row => ({ - Role: row.user.role, - Email: row.user.email, - Username: row.user.username, - Fullname: row.user.fullname, - Date: row.time.date, - Hour: row.time.hour, - CourseID: row.course.courseid, - SECTION_NAME: row.action.sectionname, - ACTION_TYPE: row.action.actiontype - })); - let csvData = vue.objectToCSV(jsonData); - vue.downloadCSV(csvData, "Activity_NoteMyProgress"); - document.querySelector('#downloadButtonNMP').innerHTML = this.strings.logs_valid_NMPbtn; - document.getElementById('downloadButtonNMP').disabled = false; - Alertify.success(this.strings.logs_success_file_downloaded); - } - } else { - Alertify.error(this.strings.logs_error_problem_encountered); - document.querySelector('#downloadButtonNMP').innerHTML = this.strings.logs_valid_NMPbtn; - document.getElementById('downloadButtonNMP').disabled = false; - } - }).catch((e) => { - Alertify.error(this.strings.logs_error_problem_encountered); - this.loading = false; - document.querySelector('#downloadButtonNMP').innerHTML = this.strings.logs_valid_NMPbtn; - document.getElementById('downloadButtonNMP').disabled = false; - }).finally(() => { - this.loading = false; - document.querySelector('#downloadButtonNMP').innerHTML = this.strings.logs_valid_NMPbtn; - document.getElementById('downloadButtonNMP').disabled = false; - }); - } else { //Si la date de début est supérieure à la date de fin - Alertify.error(this.strings.logs_error_begin_date_superior); - } - } else { //Si la date de début est inférieure à la date du jour - Alertify.error(this.strings.logs_error_begin_date_inferior); - } - } else { //Si les dates ne sont pas remplies - Alertify.error(this.strings.logs_error_empty_dates); - } - }, + getRapport() { + Alertify.confirm( + this.strings.logs_download_details_description, + () => { + let path = + M.cfg.wwwroot + + "/local/notemyprogress/downloads/Details_Informations_LogsNMP.pdf"; + var link = document.createElement("a"); + link.href = path; + link.download = "Details_Informations_LogsNMP.pdf"; + link.click(); + Alertify.success(this.strings.logs_download_details_validation); + } + ) + .set({ title: this.strings.logs_download_details_title }) + .set({ + labels: { + cancel: this.strings.logs_download_details_cancel, + ok: this.strings.logs_download_details_ok, + }, + }); + }, - get_help_content() { - var help_contents = []; - var help = new Object(); - help.title = this.strings.title; - help.description = this.strings.description; - help_contents.push(help); - return help_contents; - }, - - open_chart_help(chart) { - let contents = []; - if (chart == 'download_moodle') { - contents.push({ - title: this.strings.logs_download_moodle_help_title, - description: this.strings.logs_download_moodle_help_description, - }); - } else if (chart == "download_nmp") { - contents.push({ - title: this.strings.logs_download_nmp_help_title, - description: this.strings.logs_download_nmp_help_description, - }); - } - this.help_contents = contents; - if (this.help_contents.length) { - this.help_dialog = true; - } - }, + get_NMPfile() { + let lastDate = document.querySelector("#lastDateNMP"); + let beginDate = document.querySelector("#beginDateNMP"); + let timestampBeginDate = 0; + let timestampLastDate = 0; + let parsedBeginDate = []; + let parsedLastDate = []; + this.url = false; + this.loading = true; + var data = { + action: "downloadNMPlogs", + courseid: this.courseid, + userid: this.userid, + beginDate: beginDate.value, + lastDate: lastDate.value, + currentUrl: window.location.href, + }; + if (beginDate.value != "" && lastDate.value != "") { + parsedBeginDate = beginDate.value.split("-"); + timestampBeginDate = new Date( + parsedBeginDate[0], + parsedBeginDate[1] - 1, + parsedBeginDate[2] + ); + parsedLastDate = lastDate.value.split("-"); + timestampLastDate = new Date( + parsedLastDate[0], + parsedLastDate[1] - 1, + parsedLastDate[2] + ); + if (timestampBeginDate.getTime() <= timestampLastDate.getTime()) { + if (timestampBeginDate.getTime() <= Date.now()) { + document.querySelector("#downloadButtonNMP").innerHTML = + this.strings.logs_download_btn; + document.getElementById("downloadButtonNMP").disabled = true; + Axios({ + method: "get", + url: M.cfg.wwwroot + "/local/notemyprogress/ajax.php", + timeout: timeout, + params: data, + }) + .then((response) => { + this.loading = false; + if (response.status == 200 && response.data.ok) { + if (beginDate.value != "" || lastDate.value != "") { + let jsonData = response.data.data.jsonData; + jsonData = jsonData.map((row) => ({ + Role: row.user.role, + Email: row.user.email, + Username: row.user.username, + Fullname: row.user.fullname, + Date: row.time.date, + Hour: row.time.hour, + CourseID: row.course.courseid, + SECTION_NAME: row.action.sectionname, + ACTION_TYPE: row.action.actiontype, + })); + let csvData = vue.objectToCSV(jsonData); + vue.downloadCSV(csvData, "Activity_NoteMyProgress"); + document.querySelector("#downloadButtonNMP").innerHTML = + this.strings.logs_valid_NMPbtn; + document.getElementById( + "downloadButtonNMP" + ).disabled = false; + Alertify.success( + this.strings.logs_success_file_downloaded + ); + } + } else { + Alertify.error( + this.strings.logs_error_problem_encountered + ); + document.querySelector("#downloadButtonNMP").innerHTML = + this.strings.logs_valid_NMPbtn; + document.getElementById( + "downloadButtonNMP" + ).disabled = false; + } + }) + .catch((e) => { + Alertify.error(this.strings.logs_error_problem_encountered); + this.loading = false; + document.querySelector("#downloadButtonNMP").innerHTML = + this.strings.logs_valid_NMPbtn; + document.getElementById( + "downloadButtonNMP" + ).disabled = false; + }) + .finally(() => { + this.loading = false; + document.querySelector("#downloadButtonNMP").innerHTML = + this.strings.logs_valid_NMPbtn; + document.getElementById( + "downloadButtonNMP" + ).disabled = false; + }); + } else { + //Si la date de début est supérieure à la date de fin + Alertify.error(this.strings.logs_error_begin_date_superior); + } + } else { + //Si la date de début est inférieure à la date du jour + Alertify.error(this.strings.logs_error_begin_date_inferior); + } + } else { + //Si les dates ne sont pas remplies + Alertify.error(this.strings.logs_error_empty_dates); + } + }, - update_help_dialog(value) { - this.help_dialog = value; - }, + get_help_content() { + var help_contents = []; + var help = new Object(); + help.title = this.strings.title; + help.description = this.strings.description; + help_contents.push(help); + return help_contents; + }, - get_timezone() { - let information = `${this.strings.ss_change_timezone} ${this.timezone}` - return information; - }, - } - }) - } + open_chart_help(chart) { + let contents = []; + if (chart == "download_moodle") { + contents.push({ + title: this.strings.logs_download_moodle_help_title, + description: this.strings.logs_download_moodle_help_description, + }); + } else if (chart == "download_nmp") { + contents.push({ + title: this.strings.logs_download_nmp_help_title, + description: this.strings.logs_download_nmp_help_description, + }); + } + this.help_contents = contents; + if (this.help_contents.length) { + this.help_dialog = true; + } + }, - return { - init: init - }; - }); \ No newline at end of file + update_help_dialog(value) { + this.help_dialog = value; + }, + get_timezone() { + let information = `${this.strings.ss_change_timezone} ${this.timezone}`; + return information; + }, + }, + }); + } + return { + init: init, + }; +}); diff --git a/notemyprogress/amd/src/quiz.js b/notemyprogress/amd/src/quiz.js index 48a2e3a4c3d51862f5f53fc9d12955d2ebf639d2..de13aa346f84541c5b9065f5ba8c0cee1e4bb84b 100644 --- a/notemyprogress/amd/src/quiz.js +++ b/notemyprogress/amd/src/quiz.js @@ -20,7 +20,11 @@ define([ "use strict"; function init(content) { +<<<<<<< HEAD // //console.log(content); +======= + // console.log(content); +>>>>>>> 42271d072b5508617432803ceb2659d2d3067682 Vue.use(Vuetify); Vue.component("pagination", Pagination); Vue.component("chart", ChartDynamic); @@ -467,7 +471,11 @@ define([ Axios({ method: "get", url: M.cfg.wwwroot + "/local/notemyprogress/ajax.php", +<<<<<<< HEAD params: data, +======= + data: data, +>>>>>>> 42271d072b5508617432803ceb2659d2d3067682 }) .then((response) => { if (response.status == 200 && response.data.ok) { diff --git a/notemyprogress/amd/src/sessions.js b/notemyprogress/amd/src/sessions.js index 25ddde416e4391e2e78ec1295f5bff694cdc97b1..24fdc255e386a3d1fbc508d503a1fce7b75c8a20 100644 --- a/notemyprogress/amd/src/sessions.js +++ b/notemyprogress/amd/src/sessions.js @@ -20,7 +20,11 @@ define([ "use strict"; function init(content) { +<<<<<<< HEAD // //console.log(content); +======= + // console.log(content); +>>>>>>> 42271d072b5508617432803ceb2659d2d3067682 Vue.use(Vuetify); Vue.component("pagination", Pagination); Vue.component("chart", ChartStatic); @@ -183,7 +187,13 @@ define([ backgroundColor: null, style: { fontFamily: "poppins" }, }; +<<<<<<< HEAD chart.title = { text: null }; +======= + chart.title = { + text: null, + }; +>>>>>>> 42271d072b5508617432803ceb2659d2d3067682 chart.colors = this.inverted_time_colors; chart.xAxis = { type: "category", diff --git a/notemyprogress/amd/src/setweeks.js b/notemyprogress/amd/src/setweeks.js index 1b41697c4d5c776c641ae34c508a22ea31e7e940..a8af46c654737e45cb335d0cc66b281ec25eacb0 100644 --- a/notemyprogress/amd/src/setweeks.js +++ b/notemyprogress/amd/src/setweeks.js @@ -218,6 +218,7 @@ define([ params: data, }) .then((response) => { +<<<<<<< HEAD //console.log("then1"); if (response.status == 200 && response.data.ok) { //console.log("then1.2"); @@ -246,6 +247,36 @@ define([ //console.log("finally1"); this.saving_loader = false; //console.log("finally2"); +======= + console.log("then1"); + if (response.status == 200 && response.data.ok) { + console.log("then1.2"); + this.settings = response.data.data.settings; + console.log("then1.3"); + Alertify.success(this.strings.save_successful); + console.log("then1.4"); + this.save_successful = true; + console.log("then1.5"); + } else { + console.log("then1.6"); + Alertify.error(this.strings.error_network); + console.log("then1.7"); + this.error_messages.push(this.strings.error_network); + console.log("then1.8"); + } + }) + .catch((e) => { + console.log("catch1"); + Alertify.error(this.strings.error_network); + console.log("catch2"); + this.error_messages.push(this.strings.error_network); + console.log("catch3"); + }) + .finally(() => { + console.log("finally1"); + this.saving_loader = false; + console.log("finally2"); +>>>>>>> 42271d072b5508617432803ceb2659d2d3067682 //this.addLogsIntoDB("saved", "configuration", "weeks", "Saved a new configuration for the weeks !"); }); }, diff --git a/notemyprogress/classes/configgamification.php b/notemyprogress/classes/configgamification.php new file mode 100644 index 0000000000000000000000000000000000000000..3fb9d502f2dcd001c6e220e6eddce06380f743c5 --- /dev/null +++ b/notemyprogress/classes/configgamification.php @@ -0,0 +1,409 @@ +<?php + +// This file is part of Moodle - http://moodle.org/ +// +// Moodle is free software: you can redistribute it and/or modify +// it under the terms of the GNU General Public License as published by +// the Free Software Foundation, either version 3 of the License, or +// (at your option) any later version. +// +// Moodle is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +// GNU General Public License for more details. +// +// You should have received a copy of the GNU General Public License +// along with Moodle. If not, see <http://www.gnu.org/licenses/>. + +/** + * Config Gamification + * + * @package local_notemyprogress + * @autor Edisson Sigua, Bryan Aguilar + * @copyright 2020 Edisson Sigua <edissonf.sigua@gmail.com>, Bryan Aguilar <bryan.aguilar6174@gmail.com> + * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later + */ + +namespace local_notemyprogress; + +require_once("lib_trait.php"); + +use stdClass; +use DirectoryIterator; +use core_collator; +use core_component; +use core_plugin_manager; + +class configgamification { + + use \lib_trait; + + public $course; + public $user; + public $levelsData; + + function __construct($course, $userid){ + $this->course = self::get_course($course); + $this->user = self::get_user($userid); + $this->levelsData = self::get_levels_data(); + $this->levelsData = self::get_first_levels(); + } + + /** + *verify That There Are Levels,If There Are No Creation ByDefault + * + * @return array A list with gaming levels of the course + * @throws coding_exception | dml_exception + */ + public function get_first_levels(){ + $levelsData = $this->levelsData; + + if(!$levelsData){ + $levelsData = self::create_first_levels(); + $this->levelsData = $levelsData; + } + return $levelsData; + } + + /** + * Create the first two levels (default levels) of NoteMyProgress in a course.This function is executed + * automatically for each course. + * + * @return stdClass An object with the levels created + * @throws dml_exception + */ + private function create_first_levels(){ + global $DB; + + $levelsInfo[] = array('lvl' => 1, 'name' => 'Level 1', 'des' => '', 'points' => 0); + $levelsInfo[] = array('lvl' => 2, 'name' => 'Level 2', 'des' => '', 'points' => 120); + + $settings = array( + 'pointsbase' => 120, + 'tit' => 'Raise your level while learning', + 'des' => 'Interact with your course make you stronger' + ); + + $levelsData = new stdClass(); + $levelsData->levelsdata = json_encode($levelsInfo); + $levelsData->settings = json_encode($settings); + $levelsData->rules = json_encode(self::default_rules()); + $levelsData->courseid = $this->course->id; + $levelsData->created_by = $this->user->id; + $levelsData->modified_by = $this->user->id; + $levelsData->timecreated = self::now_timestamp(); + $levelsData->timemodified = self::now_timestamp(); + + $id = $DB->insert_record("notemyprogress_levels_data", $levelsData, true); + $levelsData->id = $id; + return $levelsData; + } + + /** + * Gets information about the level configuration + * + * @return array a list with the weeks configured in a course + */ + public function get_levels_data(){ + global $DB; + $levelsData = $DB->get_record_select( + "notemyprogress_levels_data", + 'courseid = ? AND timedeleted IS NULL', + array($this->course->id)); + + if($levelsData){ + $levelsData->levelsdata = json_decode($levelsData->levelsdata); + $levelsData->settings = json_decode($levelsData->settings); + $levelsData->rules = json_decode($levelsData->rules); + + + + } + $sql = "SELECT enablegamification from {notemyprogress_gamification} where courseid=? AND timecreated=? "; + $value = $DB->get_record_sql($sql, array("courseid="=>($courseid),"timecreated="=>$timecrated->maximum)); + + return $levelsData; + } + + /** + * Save the Gaming Levels of NotemyProgress configured in a course + * + * @param array $ Levels Levels to Save + * + * @return void + * @throws Exception + */ + public function save_levels($levelsInfo, $settings, $rules){ + global $DB; + self::delete_levels(); + $levelsData = new stdClass(); + $levelsData->levelsdata = ($levelsInfo); + $levelsData->settings = ($settings); + $levelsData->rules = ($rules); + $levelsData->courseid = $this->course->id; + $levelsData->created_by = $this->user->id; + $levelsData->modified_by = $this->user->id; + $levelsData->timecreated = self::now_timestamp(); + $levelsData->timemodified = self::now_timestamp(); + $id = $DB->insert_record("notemyprogress_levels_data", $levelsData, true); + $levelsData->id = $id; + return $levelsData; + } + + public function save_enable($enable){ + global $DB; + $param = new stdClass(); + $param->courseid = $this->course->id; + $param->userid = $this->user->id; + if ($enable){ $param->enablegamification =1;}else{ $param->enablegamification =0;} + $param->timecreated = self::now_timestamp(); + //if ($timecreated == null){$result = 1;} + //if ($timecreated === null){$result = 2;} + //if ($timecreated == 'null'){$result = 3;} + //if ($timecreated->maximum == null){$result = 9;} + //if ($timecreated->maximum === null){$result = 10;} + $DB->insert_record("notemyprogress_gamification", $param,true); + } + /** + * Eliminates the Gaming Levels of NoteMyProgress configured in a course + * + * @return void + * @throws dml_exception + */ + public function delete_levels(){ + global $DB; + $levelsData = $this->levelsData; + $id = $levelsData->id; + $sql = "update {notemyprogress_levels_data} set timedeleted = ? where id = ?"; + $DB->execute($sql, array(self::now_timestamp() , $id)); + } + + /** + * Get the default gamification rules + * + * @return array a list of rules configured in a course + */ + public function default_rules() { + $ruleset[] = array('rule' => '\mod_book\event\course_module_viewed', 'points' => 5); + $ruleset[] = array('rule' => '\mod_page\event\course_module_viewed', 'points' => 10); + $ruleset[] = array('rule' => '\mod_forum\event\discussion_subscription_created', 'points' => 20); + $ruleset[] = array('rule' => '\core\event\course_viewed', 'points' => 2); + return $ruleset; + } + + /** + * Get a list of events. + */ + public final function events_list() { + $list = []; + + $coreevents = $this->get_core_events(); + $coreevents = [get_string('coresystem') => array_reduce(array_keys($coreevents), function($carry, $prefix) use ($coreevents) { + return array_merge($carry, array_reduce($coreevents[$prefix], function($carry, $eventclass) use ($prefix) { + $infos = self::get_event_infos($eventclass); + if ($infos) { + $name = get_string('tg_colon', 'local_notemyprogress', [ + 'a' => $prefix, + 'b' => $infos['name'] + ]); + $carry = array('name' => $name, 'event' => $infos['eventname']); + } + return $carry; + }, [])); + }, [])]; + + foreach ($coreevents as $event) { + $list[] = $event; + } + + // Get module events. + $list = array_merge($list, self::get_events_list_from_plugintype('mod')); + + return $list; + } + + /** + * Get the core events. + * + * @return array The keys are translated subsystem names, the values are the classes. + */ + protected function get_core_events() { + // Add some system events. + return [get_string('course') => [ + '\\core\\event\\course_viewed', + ]]; + } + + + /** + * Return the info about an event. + * + * The key 'name' is added to contain the readable name of the event. + * It is done here because debugging is turned off and some events use + * deprecated strings. + * + * We also add the key 'isdeprecated' which indicates whether the event + * is obsolete or not. + * + * @param string $class The name of the event class. + * @return array|false + */ + public static function get_event_infos($class) { + global $CFG; + $infos = false; + + // We need to disable debugging as some events can be deprecated. + $debuglevel = $CFG->debug; + $debugdisplay = $CFG->debugdisplay; + set_debugging(0, false); + + // Check that the event exists, and is not an abstract event. + if (method_exists($class, 'get_static_info')) { + $ref = new \ReflectionClass($class); + if (!$ref->isAbstract()) { + $infos = $class::get_static_info(); + $infos['name'] = method_exists($class, 'get_name_with_info') ? $class::get_name_with_info() : $class::get_name(); + $infos['isdeprecated'] = method_exists($class, 'is_deprecated') ? $class::is_deprecated() : false; + } + } + + // Restore debugging. + set_debugging($debuglevel, $debugdisplay); + + return $infos; + } + + /** + * Get events from plugin type. + * + * @param string $plugintype Plugin type. + * @return array + */ + protected static function get_events_list_from_plugintype($plugintype) { + $list = []; + + // Loop over each plugin of the type. + $pluginlist = core_component::get_plugin_list($plugintype); + foreach ($pluginlist as $plugin => $directory) { + $component = $plugintype . '_' . $plugin; + $events = self::get_events_list_from_plugin($component); + + // If we found events for this plugin, we add them to the list. + if (!empty($events)) { + //$pluginmanager = core_plugin_manager::instance(); + //$plugininfo = $pluginmanager->get_plugin_info($component); + foreach ($events as $event) { + $list[] = $event; + } + } + } + + return $list; + } + + /** + * Get the events list from a plugin. + * + * From 3.1 we could be using core_component::get_component_classes_in_namespace(). + * + * @param string $component The plugin's component name. + * @return array + */ + protected static function get_events_list_from_plugin($component) { + $directory = core_component::get_component_directory($component); + $plugindirectory = $directory . '/classes/event'; + if (!is_dir($plugindirectory)) { + return []; + } + + // Get the plugin's events. + $eventclasses = static::get_event_classes_from_component($component); + + $pluginmanager = core_plugin_manager::instance(); + $plugininfo = $pluginmanager->get_plugin_info($component); + + // Reduce to the participating, non-deprecated event. + $events = array_reduce($eventclasses, function($carry, $class) use ($plugininfo) { + $infos = self::get_event_infos($class); + if (empty($infos)) { + // Skip rare case where infos aren't found. + return $carry; + } else if ($infos['edulevel'] != \core\event\base::LEVEL_PARTICIPATING) { + // Skip events that are not of level 'participating'. + return $carry; + } + +// $carry[$infos['eventname']] = get_string('tg_colon', 'local_notemyprogress', [ +// 'a' => $plugininfo->displayname, +// 'b' => $infos['name'] +// ]); + + $name = get_string('tg_colon', 'local_notemyprogress', [ + 'a' => $plugininfo->displayname, + 'b' => $infos['name'] + ]); + + $carry[] = array('name' => $name, 'event' => $infos['eventname']); + + return $carry; + }, []); + + // Order alphabetically. + //core_collator::asort($events, core_collator::SORT_NATURAL); + + return $events; + } + + /** + * Get the events classes from a component. + * + * @param string $component The component. + * @return Array of classes. Those may not be relevant (abstract, invalid, ...) + */ + public static function get_event_classes_from_component($component) { + $directory = core_component::get_component_directory($component); + $plugindirectory = $directory . '/classes/event'; + if (!is_dir($plugindirectory)) { + return []; + } + + $eventclasses = []; + $diriter = new DirectoryIterator($plugindirectory); + foreach ($diriter as $file) { + if ($file->isDot() || $file->isDir()) { + continue; + } + + // It's a good idea to use the leading slashes because the event's property + // 'eventname' includes them as well, so for consistency sake... Also we do + // not check if the class exists because that would cause the class to be + // autoloaded which would potentially trigger debugging messages when + // it is deprecated. + $name = substr($file->getFileName(), 0, -4); + $classname = '\\' . $component . '\\event\\' . $name; + $eventclasses[] = $classname; + } + return $eventclasses; + } + /** + * Get the data needed to complete the graph. + * + * @param int $courseid the course id. + * @return array an array containing the apropriate data well formated + */ + public static function get_spread_chart($courseid){ + Global $DB; + $resultat = []; + $levelsData = "SELECT MAX(level) as lvl from {notemyprogress_xp} where courseid=?"; + $lvl = $DB->get_record_sql($levelsData, array("courseid="=>($courseid))); + $i = 1; + while($i<=$lvl->lvl){ + $levelCount = "SELECT COUNT(*) as cpt from {notemyprogress_xp} where courseid=? and level=?"; + $cpt = $DB->get_record_sql($levelCount, array("courseid="=>($courseid),"level="=>($i))); + $string = "level {$i} :"; + array_push( $resultat,[$string,intval($cpt->cpt)]); + $i = $i+1; + } + return $resultat; + } +} \ No newline at end of file diff --git a/notemyprogress/classes/configweeks.php b/notemyprogress/classes/configweeks.php index a5dbb940edb9b0055e9a23676e0f19b6fc76917f..5da7c22393306fd3a63ba6d269faad2624feb46f 100644 --- a/notemyprogress/classes/configweeks.php +++ b/notemyprogress/classes/configweeks.php @@ -53,10 +53,17 @@ class configweeks } /** +<<<<<<< HEAD * Gets the last instance configured for Fliplearning weeks. If no weeks have been * configured in a course yet, the last instance is the one created by default by the plugin. * * @return mixed a fieldset object that contains the first record that matches the query. +======= + * Gets the last instance configured for the weeks of Note My Progress.If you have not yet been + * Configured weeks in a course, the last instance is the one that creates the plugin by default. + * + * @return mixed A FieldSet object that contains the first record that Match makes with the query +>>>>>>> 42271d072b5508617432803ceb2659d2d3067682 */ public function last_instance() { @@ -70,10 +77,15 @@ class configweeks } /** +<<<<<<< HEAD * Crea una nueva instancia para la configuración de semanas de Fliplearning. Esta es la instancia * que se crea por defecto. +======= + * Create a new instance for the setting of weeks of Note My Progress.This is the instance + * That is created by default. +>>>>>>> 42271d072b5508617432803ceb2659d2d3067682 * - * @return mixed un objeto fieldset que contiene el registro creado + * @return mixed A FieldSet object that contains the created record */ public function create_instance() { @@ -88,10 +100,15 @@ class configweeks } /** +<<<<<<< HEAD * Gets the weeks configured in Fliplearning based on the ids of the class attributes * $course e $intance. You can specify. +======= + * Obtain the weeks configured in Note My progress based on the IDs of class attributes + * $ Course and $ INTANCE.It can be specified +>>>>>>> 42271d072b5508617432803ceb2659d2d3067682 * - * @return array una lista con las semanas configuradas en un curso + * @return Array a list with the weeks configured in a course */ public function get_weeks() { @@ -104,10 +121,17 @@ class configweeks } /** +<<<<<<< HEAD * Adds the sections field to the weeks class variable to store the sections assigned to each week. * * @return array a list with the weeks of the course and the sections assigned to each one. * @throws coding_exception | dml_exception +======= + * Add the Sections field to the class variable weeks to store the sections assigned to each week. + * + * @return Array a list with the weeks of the course and sections assigned to each + * @throws Coding_Exception |DML_EXCEPTION. +>>>>>>> 42271d072b5508617432803ceb2659d2d3067682 */ public function get_weeks_with_sections() { @@ -145,10 +169,15 @@ class configweeks } /** +<<<<<<< HEAD * Crea la primera semana (semana por defecto) de Fliplearning en un curso. Esta funcion se ejecuta * de manera automática para cada curso. +======= + * Create the first week (default week) of Note My progress in a course.This function is executed + * automatically for each course. +>>>>>>> 42271d072b5508617432803ceb2659d2d3067682 * - * @return stdClass un objeto con la semana creada + * @return stdClass An object with the week created * @throws dml_exception */ private function create_first_week() @@ -352,7 +381,11 @@ class configweeks } /** +<<<<<<< HEAD * Elimina las semanas de Fliplearning configuradas en un curso +======= + * Eliminates the weeks of Note My Progress configured in a course +>>>>>>> 42271d072b5508617432803ceb2659d2d3067682 * * @return void * @throws dml_exception @@ -369,9 +402,13 @@ class configweeks } /** +<<<<<<< HEAD * Elimina las secciones asignadas a una semana de Fliplearning +======= + * Eliminates sections assigned to a week of Note My Progress +>>>>>>> 42271d072b5508617432803ceb2659d2d3067682 * - * @param string $weekcode id de la semana a eliminar + * @param string $weekcode ID of the week to eliminate * * @return void * @throws dml_exception @@ -384,10 +421,14 @@ class configweeks } /** +<<<<<<< HEAD * Guarda una semana de Fliplearning configurada en un curso +======= + * Save a week of Note My Progress configured in a course +>>>>>>> 42271d072b5508617432803ceb2659d2d3067682 * - * @param object $week semana a guardar - * @param int $position posicion de la semana + * @param Object $Week week to save + * @param int $Position position of the week * * @return void * @throws Exception @@ -412,10 +453,14 @@ class configweeks } /** +<<<<<<< HEAD * Guarda las secciones asignadas a una semana de Fliplearning +======= + * Save the sections assigned to a week of Note My Progress +>>>>>>> 42271d072b5508617432803ceb2659d2d3067682 * - * @param string $weekcode id de la semana a la que pertenece las secciones - * @param array $sections lista de secciones a guardar + * @param string $Weekcode ID of the week to which the sections belong + * @param array $sections List of Sections to Save * * @return void * @throws dml_exception @@ -429,11 +474,15 @@ class configweeks } /** +<<<<<<< HEAD * Guarda una seccion asignada a una semana de Fliplearning +======= + * Save a SECTION ASSIGNED A A WEEK OF NOTE MY PROGRAMS +>>>>>>> 42271d072b5508617432803ceb2659d2d3067682 * - * @param object $section sección a guardar - * @param int $weekcode id de la semana a la que pertenece la sección - * @param int $position posición de la sección + * @param object $section Save section + * @param int $weekcode ID of the week to which the section belongs + * @param int $position Position of the section * * @return void */ @@ -452,10 +501,10 @@ class configweeks } /** - * Obtiene el nombre de una sección dado su id + * Gets the name of a given section your ID * - * @param int $sectionid id de sección - * @param int $position posición de la sección + * @param int $sectionid Section ID. + * @param int $position Position of the section * * @return void */ @@ -468,13 +517,18 @@ class configweeks } /** +<<<<<<< HEAD * Returns the current week of the configured Fliplearning weeks. In case the query * is made after the course has ended, the last configured week is returned. +======= + * Returns the current week of the scheduled weeks of Note My progress.In case the consultation + * It is done after the course is over, the last week is returned +>>>>>>> 42271d072b5508617432803ceb2659d2d3067682 * - * @param int $last_if_course_finished parámetro entero opcional para devolver la última semana configurada - * en caso de que el curso haya terminado + * @param int $last_if_course_finished Optional whole parameter to return the last week configured + * In case the course has finished * - * @return object objeto con la semana actual a la última semana + * @return Object object with the current week at the last week */ public function get_current_week($last_if_course_finished = true) { @@ -495,12 +549,18 @@ class configweeks } /** +<<<<<<< HEAD * Toma la fecha actual al momento de hacer la llamada a la funcion y le resta 7 días para obtener * el día de la peticion de la semana pasada. Si el día obtenido esta dentro de alguna de las semanas * configuradas de Fliplearning entonces se retorna esa semana, de lo contratio se retorna null - * - * @return object objeto con la semana a la que corresponde la fecha actual menos 7 días. En caso de - * no encontrarlo se retorna null +======= + * Take the current date at the time of making the call to the function and it has 7 days to get + * On the day of the past week.If the day obtained is within some of the weeks + * Configured Note My Progress then returns that week, of the contracted Null returns +>>>>>>> 42271d072b5508617432803ceb2659d2d3067682 + * + * @return object Object with the week to which the current date corresponds less 7 days.In case of + * Do not find it Returns NULL */ public function get_past_week() { diff --git a/notemyprogress/classes/event_strategy.php b/notemyprogress/classes/event_strategy.php new file mode 100644 index 0000000000000000000000000000000000000000..134b9aee5171eefbb2ab689e68ed484daf01eec2 --- /dev/null +++ b/notemyprogress/classes/event_strategy.php @@ -0,0 +1,494 @@ +<?php +// This file is part of Moodle - http://moodle.org/ +// +// Moodle is free software: you can redistribute it and/or modify +// it under the terms of the GNU General Public License as published by +// the Free Software Foundation, either version 3 of the License, or +// (at your option) any later version. +// +// Moodle is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +// GNU General Public License for more details. +// +// You should have received a copy of the GNU General Public License +// along with Moodle. If not, see <http://www.gnu.org/licenses/>. + +/** + * Event Collector Observer + * + * @package local_notemyprogress + * @autor Edisson Sigua, Bryan Aguilar + * @copyright 2020 Edisson Sigua <edissonf.sigua@gmail.com>, Bryan Aguilar <bryan.aguilar6174@gmail.com> + * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later + */ + +namespace local_notemyprogress; + +defined('MOODLE_INTERNAL') || die(); + +require_once("lib_trait.php"); + +use stdClass; +use DateTime; +use dml_exception; +use lang_string; + +class event_strategy { + + use \lib_trait; + + protected $table_xp = 'notemyprogress_xp'; + protected $table_log = 'notemyprogress_xp_log'; + public $course; + public $user; + public $configgamification; + + public function __construct($course, $userid) { + $this->course = self::get_course($course); + $this->user = self::get_user($userid); + $this->configgamification = new \local_notemyprogress\configgamification($course, $userid); + } + + /** + * Manejador de eventos. + * + * @param \core\event\base $event The event. + * @return void + */ + public function collect_event(\core\event\base $event) { + + if (!self::can_capture_event($event)) { + return; + } + + $points = self::get_points_for_event($event); + if ($points === null) { + return; + } + + if ($points > 0) { + self::increase($this->user->id, $this->course->id, $points); + self::save_log($this->user->id, $this->course->id, $points, $event->eventname); + } + } + + /** + * Compruebe si el usuario puede capturar este evento. + * + * @param \core\event\base $event El evento. + * @return bool True cuando el evento es permitido. + */ + protected function can_capture_event(\core\event\base $event) { + global $SESSION; + + $now = time(); + $maxcount = 64; + + /* + * El número máximo de acciones que contarán como puntos durante el período de tiempo dado. + * Cualquier acción posterior será ignorada. Cuando este valor está vacío o es igual a cero, no se aplica.*/ + $maxactions = 10; + + /* El período de tiempo (segundos) durante el cual el usuario no debe exceder un número máximo de acciones.*/ + $maxtime = 60; + + /* + * Se acepta nuevamente el tiempo mínimo requerido antes de que una acción que ya sucedió anteriormente. + * Una acción se considera idéntica si se colocó en el mismo contexto y objeto. + * Cuando este valor está vacío o es igual a cero, no se aplica.*/ + $actiontime = 180; + + $actionkey = $event->eventname . ':' . $event->contextid . ':' . $event->objectid . ':' . $event->relateduserid; + + if (!isset($SESSION->local_notemyprogress_cheatguard)) { + // Init the session variable. + $SESSION->local_notemyprogress_cheatguard = []; + } else { + // Ensure that all entries are arrays, they may not be when we just upgraded the plugin. + $SESSION->local_notemyprogress_cheatguard = array_map(function($entry) { + return is_array($entry) ? $entry : [$entry]; + }, $SESSION->local_notemyprogress_cheatguard); + } + + // Perform the check. + if (!static::is_action_accepted($actionkey, $now, $SESSION->local_notemyprogress_cheatguard, $maxactions, $maxtime, $actiontime)) { + return false; + } + + // Move the action at the end of the array. + $times = isset($SESSION->local_notemyprogress_cheatguard[$actionkey]) ? $SESSION->local_notemyprogress_cheatguard[$actionkey] : []; + unset($SESSION->local_notemyprogress_cheatguard[$actionkey]); + $SESSION->local_notemyprogress_cheatguard[$actionkey] = $times; + + // Log the time at which this event happened. + $SESSION->local_notemyprogress_cheatguard[$actionkey][] = time(); + + // Limit the timestamps of each action to a maximum of $maxcount within the timeframe desired or + // the last 15min. We want to keep at least 15 min so that when teachers are testing changes, + // they do not get confused because actions they had just performed no longer gets blocked. + $timethreshold = $now - max([$maxtime, $actiontime, 900]); + $SESSION->local_notemyprogress_cheatguard = array_filter(array_map(function($times) use ($maxcount, $timethreshold) { + return array_slice(array_filter($times, function($time) use ($timethreshold) { + return $time > $timethreshold; + }), -$maxcount); + }, $SESSION->local_notemyprogress_cheatguard)); + + // Limit the array of events to $maxcount, we do not want to flood the session for no reason. + $SESSION->local_notemyprogress_cheatguard = array_slice($SESSION->local_notemyprogress_cheatguard, -$maxcount, null, true); + + return true; + } + + /** + * Comprueba si la acción es aceptada. + * + * @param string $action Clave de la acción. + * @param int $now Timestamp. + * @param array $log Array where keys are actions, and values are timestamp arrays. + * @param int $maxactions El máximo número de acciones. + * @param int $maxintime Tiempo durante el cual el máximo número de acciones es permitido. + * @param int $timebetweenrepeats Tiempo entre acciones repetidas. + * @return bool + */ + public static function is_action_accepted($action, $now, array $log, $maxactions, $maxintime, $timebetweenrepeats) { + + if ($maxactions > 0 && $maxintime > 0) { + $timethreshold = $now - $maxintime; + $actionsintimeframe = array_reduce($log, function($carry, $times) use ($timethreshold) { + return $carry + array_reduce($times, function($carry, $time) use ($timethreshold) { + return $carry + ($time > $timethreshold ? 1 : 0); + }); + }, 0); + if ($actionsintimeframe >= $maxactions) { + return false; + } + } + + if ($timebetweenrepeats > 0) { + $timethreshold = $now - $timebetweenrepeats; + $times = isset($log[$action]) ? $log[$action] : []; + if (!empty($times) && max($times) > $timethreshold) { + return false; + } + } + + return true; + } + + /** + * Obtiene los puntos para un evento. + * + * @param \core\event\base $event event. + * @return int Points, or null. + */ + public function get_points_for_event(\core\event\base $event) { + $ruleset = $this->configgamification->get_levels_data()->rules; + foreach ($ruleset as $rule) { + if ($rule->rule == $event->eventname) { + return $rule->points; + } + } + return null; + } + + /** + * Agregar puntos de experiencia. + * + * @param int $id The receiver. + * @param int $amount The amount. + */ + public function increase($userid, $courseid, $amount) { + global $DB; + $prexp = 0; + $postxp = $amount; + + if ($record = self::get_user_data($userid, $courseid)) { + $prexp = (int)$record->points; + $postxp = $prexp + $amount; + + $sql = "UPDATE {{$this->table_xp}} + SET points = points + :points + WHERE courseid = :courseid + AND userid = :userid"; + $params = [ + 'points' => $amount, + 'courseid' => $courseid, + 'userid' => $userid + ]; + $DB->execute($sql, $params); + + $newxp = (int)$record->points + $amount; + $newlevel = self::get_level_from_xp($newxp)->lvl; + if ($record->level != $newlevel) { + $DB->set_field($this->table_xp, 'level', $newlevel, ['courseid' => $courseid, 'userid' => $userid]); + } + } else { + self::insert($userid, $courseid, $amount); + } + } + + /** + * Log a thing. + * + * @param int $userid The target. + * @param int $courseid The target. + * @param int $points The points. + * @param reason $reason The reason. + * @param DateTime|null $time When that happened. + * @return void + */ + public function save_log($userid, $courseid, $points, $eventName) { + global $DB; + $time = new DateTime(); + $record = new stdClass(); + $record->courseid = $courseid; + $record->userid = $userid; + $record->event = $eventName; + $record->points = $points; + $record->timecreated = $time->getTimestamp(); + try { + $DB->insert_record($this->table_log, $record); + } catch (dml_exception $e) {} + + } + + /** + * Agregar puntos de experiencia a un usuario en la tabla notemyprogress_xp. + * + * @param int $id The receiver. + * @param int $amount The amount. + */ + public function insert($userid, $courseid, $amount) { + global $DB; + $record = new stdClass(); + $record->courseid = $courseid; + $record->userid = $userid; + $record->points = $amount; + $record->level = self::get_level_from_xp($amount)->lvl; + try { + $DB->insert_record($this->table_xp, $record); //* + } catch (dml_exception $e) {} + } + + /** + * Give the level from the xp points. + * + * @param int $xp The xp points. + * @return level + */ + public function get_level_from_xp($points) { + $levels = $this->configgamification->get_levels_data()->levelsdata; + for ($i = count($levels)-1; $i >= 0; $i--) { + $level = $levels[$i]; + if ($level->points <= $points) { + return $level; + } + } + return $level; + } + + /** + * Obtiene el próximo nivel de un usuario + * + * @return null|level + */ + public function get_next_level($userid) { + $configgamification = $this->configgamification->get_levels_data(); + $levels = $configgamification->levelsdata; + $userData = self::get_user_data($userid, $this->course->id); + $levelnum = $userData->level; + + if ($levelnum > count($levels)-1) { + $nextlevel = false; + } else { + $nextlevel = $levels[$levelnum]; + } + + // TODO: validar que pasa cuando supera el ultimo nivel + if ($nextlevel === false) { + return null; + } + + return $nextlevel; + } + + /** + * Obtiene la información de puntos de experiencia de un usuario + * + * @return null|response + */ + public function get_user_info() { + + $response = new stdClass(); + $recentCount = 3; + if (self::get_user_data($this->user->id, $this->course->id)) { + + $userData = self::get_user_data($this->user->id, $this->course->id); + $nextlevel = self::get_next_level($this->user->id); + $activity = self::get_user_recent_activity($this->user->id, $this->course->id, $recentCount); + $levelInfo = self::get_level_from_xp($userData->points); + + $response->points = $userData->points; + $response->level = $userData->level; + $response->activity = $activity; + $response->levelInfo = $levelInfo; + $response->uid=$this->user->id; + $response->cid=$this->course->id; + + // $response->points = 1; + // $response->level = 2; + // $response->activity = 3; + // $response->levelInfo = $userData->points; + + if(is_null($nextlevel)) { + // Si no existe un siguiente nivel + $response->pointsToNext = 0; + $response->progress = 100; + }else{ + $response->pointsToNext = $nextlevel->points - $userData->points; + $response->progress = ($userData->points*100)/$nextlevel->points; + } + }else{return self::get_user_data($this->user->id, $this->course->id);} + return $response; + } + + /** + * Obtiene un ranking con los puntos de experiencia de los usuarios + * + * @return users + */ + public function get_ranking($int) { + global $DB; + + $users = array(); + if ($int==1){ + $sql = "SELECT * FROM {{$this->table_xp}} WHERE courseid = {$this->course->id} and rankable = 1 ORDER BY points DESC"; + }else{ + $sql = "SELECT * FROM {{$this->table_xp}} WHERE courseid = {$this->course->id} ORDER BY points DESC"; + } + + $rank = $DB->get_recordset_sql($sql); + $index = 1; + + foreach($rank as $user){ + + $completeUser = self::get_user_from_id($user->userid); + $nextlevel = self::get_next_level($user->userid); + + $aux = new stdClass(); + $aux->ranking = $index; + $aux->level = $user->level; + $aux->student = $completeUser->firstname.' '.$completeUser->lastname; + $aux->total = $user->points; + + if(is_null($nextlevel)) { + // Si no existe un siguiente nivel + $aux->progress_percentage = 100; + }else{ + $aux->progress_percentage = ($user->points*100)/$nextlevel->points; + } + + $users[] = $aux; + + $index++; + } + $rank->close(); + return $users; + } + + /** + * Verifica si el usuario existe en la tabla de puntos de experiencia. + * + * @param int $id The receiver. + * @return stdClass|false + */ + public function get_user_data($userid, $courseid) { + global $DB; + $params = []; + $params['userid'] = $userid; + $params['courseid'] = $courseid; + return $DB->get_record($this->table_xp, array("userid"=>$userid,"courseid"=>$courseid)); + } + + /** + * Obtener la actividad reciente del usuario de la tabla notemyprogress_xp_log. + * + * @param int $userid El identificador del usuario. + * @param int $courseid El identificador del curso. + * @param int $count El número de registros a recuperar. + * @return activity + */ + public function get_user_recent_activity($userid, $courseid, $count = 0) { + global $DB; + $results = $DB->get_records_select($this->table_log, 'courseid = :courseid AND userid = :userid AND points > 0', [ + 'courseid' => $courseid, + 'userid' => $userid, + ], 'timecreated DESC, id DESC', '*', 0, $count); + + $activities = array(); + foreach($results as $row){ + $desc = ''; + $class = $row->event; + if (class_exists($class) && is_subclass_of($class, 'core\event\base')) { + $desc = $class::get_name(); + } else { + $desc = new lang_string('somethinghappened', 'local_notemyprogress'); + } + $activity = new stdClass(); + $activity->timeago = self::time_ago(new DateTime('@' . $row->timecreated)); + $activity->description = $desc; + $activity->points = $row->points; + $activities[] = $activity; + } + +// return array_map(function($row) { +// $desc = ''; +// $class = $row->event; +// if (class_exists($class) && is_subclass_of($class, 'core\event\base')) { +// $desc = $class::get_name(); +// } else { +// $desc = new lang_string('somethinghappened', 'local_notemyprogress'); +// } +// $activity = new stdClass(); +// $activity->timeago = self::time_ago(new DateTime('@' . $row->timecreated)); +// $activity->description = $desc; +// $activity->points = $row->points; +// return $activity; +// }, $results); + + return $activities; + } + + /** + * Obtener un timestamp de la forma hace 5 min. + * + * @param DateTime $dt Objeto de tipo DateTime. + * @return string + */ + public function time_ago(DateTime $dt) { + $now = new \DateTime(); + $diff = $now->getTimestamp() - $dt->getTimestamp(); + $ago = '?'; + + if ($diff < 15) { + $ago = get_string('tg_timenow', 'local_notemyprogress'); + } else if ($diff < 45) { + $ago = get_string('tg_timeseconds', 'local_notemyprogress', $diff); + } else if ($diff < HOURSECS * 0.7) { + $ago = get_string('tg_timeminutes', 'local_notemyprogress', round($diff / 60)); + } else if ($diff < DAYSECS * 0.7) { + $ago = get_string('tg_timehours', 'local_notemyprogress', round($diff / HOURSECS)); + } else if ($diff < DAYSECS * 7 * 0.7) { + $ago = get_string('tg_timedays', 'local_notemyprogress', round($diff / DAYSECS)); + } else if ($diff < DAYSECS * 30 * 0.7) { + $ago = get_string('tg_timeweeks', 'local_notemyprogress', round($diff / (DAYSECS * 7))); + } else if ($diff < DAYSECS * 365) { + $ago = userdate($dt->getTimestamp(), get_string('tg_timewithinayearformat', 'local_notemyprogress')); + } else { + $ago = userdate($dt->getTimestamp(), get_string('tg_timeolderyearformat', 'local_notemyprogress')); + } + + return $ago; + } +} \ No newline at end of file diff --git a/notemyprogress/classes/external/external.php b/notemyprogress/classes/external/external.php new file mode 100644 index 0000000000000000000000000000000000000000..009182f43543c082660691198c8aee37b05bfd51 --- /dev/null +++ b/notemyprogress/classes/external/external.php @@ -0,0 +1,93 @@ +<?php +// This file is part of Moodle - http://moodle.org/ +// +// Moodle is free software: you can redistribute it and/or modify +// it under the terms of the GNU General Public License as published by +// the Free Software Foundation, either version 3 of the License, or +// (at your option) any later version. +// +// Moodle is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +// GNU General Public License for more details. +// +// You should have received a copy of the GNU General Public License +// along with Moodle. If not, see <http://www.gnu.org/licenses/>. + +namespace local_notemyprogress\external; + +use coding_exception; +use dml_exception; +use function end; +use external_api; +use external_function_parameters; +use external_multiple_structure; +use external_single_structure; +use external_value; +use invalid_parameter_exception; +use moodle_exception; +use restricted_context_exception; +use stdClass; + +defined('MOODLE_INTERNAL') || die(); + +/** + * Class levels + * + * @package mod_millionaire\external + * @copyright 2019 Benedikt Kulmann <b@kulmann.biz> + * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later + */ +class external extends external_api { + + /** + * Definition of parameters for {@see get_levels}. + * + * @return external_function_parameters + */ + public static function get_levels_parameters() { + return new external_function_parameters([ + 'courseid' => new external_value(PARAM_INT, 'course id'), + ]); + } + + /** + * Definition of return type for {@see get_levels}. + * + * @return external_multiple_structure + */ + public static function get_levels_returns() { + return new external_multiple_structure( + level_dto::get_read_structure() + ); + } + + /** + * Get all levels. + * + * @param int $courseid + * + * @return array + * @throws coding_exception + * @throws dml_exception + * @throws invalid_parameter_exception + * @throws moodle_exception + * @throws restricted_context_exception + */ + public static function get_levels($courseid) { + $params = ['courseid' => $courseid]; + self::validate_parameters(self::get_levels_parameters(), $params); + global $DB; + $levelsData = $DB->get_record_select( + "notemyprogress_levels_data", + 'courseid = ? AND timedeleted IS NULL', $params); + + if($levelsData){ + $levelsData->levelsdata = json_decode($levelsData->levelsdata); + $levelsData->settings = json_decode($levelsData->settings); + $levelsData->rules = json_decode($levelsData->rules); + } + + return $levelsData; + } +} \ No newline at end of file diff --git a/notemyprogress/classes/jwt/BeforeValidException.php b/notemyprogress/classes/jwt/BeforeValidException.php new file mode 100644 index 0000000000000000000000000000000000000000..e71d2bfc09e2cc0e6315cc59ebb81669bf69cabd --- /dev/null +++ b/notemyprogress/classes/jwt/BeforeValidException.php @@ -0,0 +1,7 @@ +<?php + +namespace local_notemyprogress\jwt; + +class BeforeValidException extends \UnexpectedValueException +{ +} diff --git a/notemyprogress/classes/jwt/ExpiredException.php b/notemyprogress/classes/jwt/ExpiredException.php new file mode 100644 index 0000000000000000000000000000000000000000..90347ca97d421883a37536c0463e622433f8183c --- /dev/null +++ b/notemyprogress/classes/jwt/ExpiredException.php @@ -0,0 +1,7 @@ +<?php + +namespace local_notemyprogress\jwt; + +class ExpiredException extends \UnexpectedValueException +{ +} diff --git a/notemyprogress/classes/jwt/JWK.php b/notemyprogress/classes/jwt/JWK.php new file mode 100644 index 0000000000000000000000000000000000000000..831e6b70d42d74e4608aefeca650192e691150c9 --- /dev/null +++ b/notemyprogress/classes/jwt/JWK.php @@ -0,0 +1,172 @@ +<?php + +namespace local_notemyprogress\jwt; + +use DomainException; +use InvalidArgumentException; +use UnexpectedValueException; + +/** + * JSON Web Key implementation, based on this spec: + * https://tools.ietf.org/html/draft-ietf-jose-json-web-key-41 + * + * PHP version 5 + * + * @category Authentication + * @package Authentication_JWT + * @author Bui Sy Nguyen <nguyenbs@gmail.com> + * @license http://opensource.org/licenses/BSD-3-Clause 3-clause BSD + * @link https://github.com/firebase/php-jwt + */ +class JWK +{ + /** + * Parse a set of JWK keys + * + * @param array $jwks The JSON Web Key Set as an associative array + * + * @return array An associative array that represents the set of keys + * + * @throws InvalidArgumentException Provided JWK Set is empty + * @throws UnexpectedValueException Provided JWK Set was invalid + * @throws DomainException OpenSSL failure + * + * @uses parseKey + */ + public static function parseKeySet(array $jwks) + { + $keys = array(); + + if (!isset($jwks['keys'])) { + throw new UnexpectedValueException('"keys" member must exist in the JWK Set'); + } + if (empty($jwks['keys'])) { + throw new InvalidArgumentException('JWK Set did not contain any keys'); + } + + foreach ($jwks['keys'] as $k => $v) { + $kid = isset($v['kid']) ? $v['kid'] : $k; + if ($key = self::parseKey($v)) { + $keys[$kid] = $key; + } + } + + if (0 === \count($keys)) { + throw new UnexpectedValueException('No supported algorithms found in JWK Set'); + } + + return $keys; + } + + /** + * Parse a JWK key + * + * @param array $jwk An individual JWK + * + * @return resource|array An associative array that represents the key + * + * @throws InvalidArgumentException Provided JWK is empty + * @throws UnexpectedValueException Provided JWK was invalid + * @throws DomainException OpenSSL failure + * + * @uses createPemFromModulusAndExponent + */ + public static function parseKey(array $jwk) + { + if (empty($jwk)) { + throw new InvalidArgumentException('JWK must not be empty'); + } + if (!isset($jwk['kty'])) { + throw new UnexpectedValueException('JWK must contain a "kty" parameter'); + } + + switch ($jwk['kty']) { + case 'RSA': + if (!empty($jwk['d'])) { + throw new UnexpectedValueException('RSA private keys are not supported'); + } + if (!isset($jwk['n']) || !isset($jwk['e'])) { + throw new UnexpectedValueException('RSA keys must contain values for both "n" and "e"'); + } + + $pem = self::createPemFromModulusAndExponent($jwk['n'], $jwk['e']); + $publicKey = \openssl_pkey_get_public($pem); + if (false === $publicKey) { + throw new DomainException( + 'OpenSSL error: ' . \openssl_error_string() + ); + } + return $publicKey; + default: + // Currently only RSA is supported + break; + } + } + + /** + * Create a public key represented in PEM format from RSA modulus and exponent information + * + * @param string $n The RSA modulus encoded in Base64 + * @param string $e The RSA exponent encoded in Base64 + * + * @return string The RSA public key represented in PEM format + * + * @uses encodeLength + */ + private static function createPemFromModulusAndExponent($n, $e) + { + $modulus = JWT::urlsafeB64Decode($n); + $publicExponent = JWT::urlsafeB64Decode($e); + + $components = array( + 'modulus' => \pack('Ca*a*', 2, self::encodeLength(\strlen($modulus)), $modulus), + 'publicExponent' => \pack('Ca*a*', 2, self::encodeLength(\strlen($publicExponent)), $publicExponent) + ); + + $rsaPublicKey = \pack( + 'Ca*a*a*', + 48, + self::encodeLength(\strlen($components['modulus']) + \strlen($components['publicExponent'])), + $components['modulus'], + $components['publicExponent'] + ); + + // sequence(oid(1.2.840.113549.1.1.1), null)) = rsaEncryption. + $rsaOID = \pack('H*', '300d06092a864886f70d0101010500'); // hex version of MA0GCSqGSIb3DQEBAQUA + $rsaPublicKey = \chr(0) . $rsaPublicKey; + $rsaPublicKey = \chr(3) . self::encodeLength(\strlen($rsaPublicKey)) . $rsaPublicKey; + + $rsaPublicKey = \pack( + 'Ca*a*', + 48, + self::encodeLength(\strlen($rsaOID . $rsaPublicKey)), + $rsaOID . $rsaPublicKey + ); + + $rsaPublicKey = "-----BEGIN PUBLIC KEY-----\r\n" . + \chunk_split(\base64_encode($rsaPublicKey), 64) . + '-----END PUBLIC KEY-----'; + + return $rsaPublicKey; + } + + /** + * DER-encode the length + * + * DER supports lengths up to (2**8)**127, however, we'll only support lengths up to (2**8)**4. See + * {@link http://itu.int/ITU-T/studygroups/com17/languages/X.690-0207.pdf#p=13 X.690 paragraph 8.1.3} for more information. + * + * @param int $length + * @return string + */ + private static function encodeLength($length) + { + if ($length <= 0x7F) { + return \chr($length); + } + + $temp = \ltrim(\pack('N', $length), \chr(0)); + + return \pack('Ca*', 0x80 | \strlen($temp), $temp); + } +} diff --git a/notemyprogress/classes/jwt/JWT.php b/notemyprogress/classes/jwt/JWT.php new file mode 100644 index 0000000000000000000000000000000000000000..41b06de07c179aad27e84560b9f3b0db4b60f5a8 --- /dev/null +++ b/notemyprogress/classes/jwt/JWT.php @@ -0,0 +1,547 @@ +<?php + +namespace local_notemyprogress\jwt; + + + +use DomainException; +use Exception; +use InvalidArgumentException; +use UnexpectedValueException; +use DateTime; + + +/** + * JSON Web Token implementation, based on this spec: + * https://tools.ietf.org/html/rfc7519 + * + * PHP version 5 + * + * @category Authentication + * @package Authentication_JWT + * @author Neuman Vong <neuman@twilio.com> + * @author Anant Narayanan <anant@php.net> + * @license http://opensource.org/licenses/BSD-3-Clause 3-clause BSD + * @link https://github.com/firebase/php-jwt + */ +class JWT +{ + const ASN1_INTEGER = 0x02; + const ASN1_SEQUENCE = 0x10; + const ASN1_BIT_STRING = 0x03; + + /** + * When checking nbf, iat or expiration times, + * we want to provide some extra leeway time to + * account for clock skew. + */ + public static $leeway = 0; + + /** + * Allow the current timestamp to be specified. + * Useful for fixing a value within unit testing. + * + * Will default to PHP time() value if null. + */ + public static $timestamp = null; + + public static $supported_algs = array( + 'ES384' => array('openssl', 'SHA384'), + 'ES256' => array('openssl', 'SHA256'), + 'HS256' => array('hash_hmac', 'SHA256'), + 'HS384' => array('hash_hmac', 'SHA384'), + 'HS512' => array('hash_hmac', 'SHA512'), + 'RS256' => array('openssl', 'SHA256'), + 'RS384' => array('openssl', 'SHA384'), + 'RS512' => array('openssl', 'SHA512'), + 'EdDSA' => array('sodium_crypto', 'EdDSA'), + ); + + /** + * Decodes a JWT string into a PHP object. + * + * @param string $jwt The JWT + * @param string|array|resource $key The key, or map of keys. + * If the algorithm used is asymmetric, this is the public key + * @param array $allowed_algs List of supported verification algorithms + * Supported algorithms are 'ES384','ES256', 'HS256', 'HS384', + * 'HS512', 'RS256', 'RS384', and 'RS512' + * + * @return object The JWT's payload as a PHP object + * + * @throws InvalidArgumentException Provided JWT was empty + * @throws UnexpectedValueException Provided JWT was invalid + * @throws SignatureInvalidException Provided JWT was invalid because the signature verification failed + * @throws BeforeValidException Provided JWT is trying to be used before it's eligible as defined by 'nbf' + * @throws BeforeValidException Provided JWT is trying to be used before it's been created as defined by 'iat' + * @throws ExpiredException Provided JWT has since expired, as defined by the 'exp' claim + * + * @uses jsonDecode + * @uses urlsafeB64Decode + */ + public static function decode($jwt, $key, array $allowed_algs = array()) + { + $timestamp = \is_null(static::$timestamp) ? \time() : static::$timestamp; + + if (empty($key)) { + throw new InvalidArgumentException('Key may not be empty'); + } + $tks = \explode('.', $jwt); + if (\count($tks) != 3) { + throw new UnexpectedValueException('Wrong number of segments'); + } + list($headb64, $bodyb64, $cryptob64) = $tks; + if (null === ($header = static::jsonDecode(static::urlsafeB64Decode($headb64)))) { + throw new UnexpectedValueException('Invalid header encoding'); + } + if (null === $payload = static::jsonDecode(static::urlsafeB64Decode($bodyb64))) { + throw new UnexpectedValueException('Invalid claims encoding'); + } + if (false === ($sig = static::urlsafeB64Decode($cryptob64))) { + throw new UnexpectedValueException('Invalid signature encoding'); + } + if (empty($header->alg)) { + throw new UnexpectedValueException('Empty algorithm'); + } + if (empty(static::$supported_algs[$header->alg])) { + throw new UnexpectedValueException('Algorithm not supported'); + } + if (!\in_array($header->alg, $allowed_algs)) { + throw new UnexpectedValueException('Algorithm not allowed'); + } + if ($header->alg === 'ES256' || $header->alg === 'ES384') { + // OpenSSL expects an ASN.1 DER sequence for ES256/ES384 signatures + $sig = self::signatureToDER($sig); + } + + if (\is_array($key) || $key instanceof \ArrayAccess) { + if (isset($header->kid)) { + if (!isset($key[$header->kid])) { + throw new UnexpectedValueException('"kid" invalid, unable to lookup correct key'); + } + $key = $key[$header->kid]; + } else { + throw new UnexpectedValueException('"kid" empty, unable to lookup correct key'); + } + } + + // Check the signature + if (!static::verify("$headb64.$bodyb64", $sig, $key, $header->alg)) { + throw new SignatureInvalidException('Signature verification failed'); + } + + // Check the nbf if it is defined. This is the time that the + // token can actually be used. If it's not yet that time, abort. + if (isset($payload->nbf) && $payload->nbf > ($timestamp + static::$leeway)) { + throw new BeforeValidException( + 'Cannot handle token prior to ' . \date(DateTime::ISO8601, $payload->nbf) + ); + } + + // Check that this token has been created before 'now'. This prevents + // using tokens that have been created for later use (and haven't + // correctly used the nbf claim). + if (isset($payload->iat) && $payload->iat > ($timestamp + static::$leeway)) { + throw new BeforeValidException( + 'Cannot handle token prior to ' . \date(DateTime::ISO8601, $payload->iat) + ); + } + + // Check if this token has expired. + if (isset($payload->exp) && ($timestamp - static::$leeway) >= $payload->exp) { + throw new ExpiredException('Expired token'); + } + + return $payload; + } + + /** + * Converts and signs a PHP object or array into a JWT string. + * + * @param object|array $payload PHP object or array + * @param string|resource $key The secret key. + * If the algorithm used is asymmetric, this is the private key + * @param string $alg The signing algorithm. + * Supported algorithms are 'ES384','ES256', 'HS256', 'HS384', + * 'HS512', 'RS256', 'RS384', and 'RS512' + * @param mixed $keyId + * @param array $head An array with header elements to attach + * + * @return string A signed JWT + * + * @uses jsonEncode + * @uses urlsafeB64Encode + */ + public static function encode($payload, $key, $alg = 'HS256', $keyId = null, $head = null) + { + $header = array('typ' => 'JWT', 'alg' => $alg); + if ($keyId !== null) { + $header['kid'] = $keyId; + } + if (isset($head) && \is_array($head)) { + $header = \array_merge($head, $header); + } + $segments = array(); + $segments[] = static::urlsafeB64Encode(static::jsonEncode($header)); + $segments[] = static::urlsafeB64Encode(static::jsonEncode($payload)); + $signing_input = \implode('.', $segments); + + $signature = static::sign($signing_input, $key, $alg); + $segments[] = static::urlsafeB64Encode($signature); + + return \implode('.', $segments); + } + + /** + * Sign a string with a given key and algorithm. + * + * @param string $msg The message to sign + * @param string|resource $key The secret key + * @param string $alg The signing algorithm. + * Supported algorithms are 'ES384','ES256', 'HS256', 'HS384', + * 'HS512', 'RS256', 'RS384', and 'RS512' + * + * @return string An encrypted message + * + * @throws DomainException Unsupported algorithm or bad key was specified + */ + public static function sign($msg, $key, $alg = 'HS256') + { + if (empty(static::$supported_algs[$alg])) { + throw new DomainException('Algorithm not supported'); + } + list($function, $algorithm) = static::$supported_algs[$alg]; + switch ($function) { + case 'hash_hmac': + return \hash_hmac($algorithm, $msg, $key, true); + case 'openssl': + $signature = ''; + $success = \openssl_sign($msg, $signature, $key, $algorithm); + if (!$success) { + throw new DomainException("OpenSSL unable to sign data"); + } + if ($alg === 'ES256') { + $signature = self::signatureFromDER($signature, 256); + } elseif ($alg === 'ES384') { + $signature = self::signatureFromDER($signature, 384); + } + return $signature; + case 'sodium_crypto': + if (!function_exists('sodium_crypto_sign_detached')) { + throw new DomainException('libsodium is not available'); + } + try { + // The last non-empty line is used as the key. + $lines = array_filter(explode("\n", $key)); + $key = base64_decode(end($lines)); + return sodium_crypto_sign_detached($msg, $key); + } catch (Exception $e) { + throw new DomainException($e->getMessage(), 0, $e); + } + } + } + + /** + * Verify a signature with the message, key and method. Not all methods + * are symmetric, so we must have a separate verify and sign method. + * + * @param string $msg The original message (header and body) + * @param string $signature The original signature + * @param string|resource $key For HS*, a string key works. for RS*, must be a resource of an openssl public key + * @param string $alg The algorithm + * + * @return bool + * + * @throws DomainException Invalid Algorithm, bad key, or OpenSSL failure + */ + private static function verify($msg, $signature, $key, $alg) + { + if (empty(static::$supported_algs[$alg])) { + throw new DomainException('Algorithm not supported'); + } + + list($function, $algorithm) = static::$supported_algs[$alg]; + switch ($function) { + case 'openssl': + $success = \openssl_verify($msg, $signature, $key, $algorithm); + if ($success === 1) { + return true; + } elseif ($success === 0) { + return false; + } + // returns 1 on success, 0 on failure, -1 on error. + throw new DomainException( + 'OpenSSL error: ' . \openssl_error_string() + ); + case 'sodium_crypto': + if (!function_exists('sodium_crypto_sign_verify_detached')) { + throw new DomainException('libsodium is not available'); + } + try { + // The last non-empty line is used as the key. + $lines = array_filter(explode("\n", $key)); + $key = base64_decode(end($lines)); + return sodium_crypto_sign_verify_detached($signature, $msg, $key); + } catch (Exception $e) { + throw new DomainException($e->getMessage(), 0, $e); + } + case 'hash_hmac': + default: + $hash = \hash_hmac($algorithm, $msg, $key, true); + if (\function_exists('hash_equals')) { + return \hash_equals($signature, $hash); + } + $len = \min(static::safeStrlen($signature), static::safeStrlen($hash)); + + $status = 0; + for ($i = 0; $i < $len; $i++) { + $status |= (\ord($signature[$i]) ^ \ord($hash[$i])); + } + $status |= (static::safeStrlen($signature) ^ static::safeStrlen($hash)); + + return ($status === 0); + } + } + + /** + * Decode a JSON string into a PHP object. + * + * @param string $input JSON string + * + * @return object Object representation of JSON string + * + * @throws DomainException Provided string was invalid JSON + */ + public static function jsonDecode($input) + { + if (\version_compare(PHP_VERSION, '5.4.0', '>=') && !(\defined('JSON_C_VERSION') && PHP_INT_SIZE > 4)) { + /** In PHP >=5.4.0, json_decode() accepts an options parameter, that allows you + * to specify that large ints (like Steam Transaction IDs) should be treated as + * strings, rather than the PHP default behaviour of converting them to floats. + */ + $obj = \json_decode($input, false, 512, JSON_BIGINT_AS_STRING); + } else { + /** Not all servers will support that, however, so for older versions we must + * manually detect large ints in the JSON string and quote them (thus converting + *them to strings) before decoding, hence the preg_replace() call. + */ + $max_int_length = \strlen((string) PHP_INT_MAX) - 1; + $json_without_bigints = \preg_replace('/:\s*(-?\d{'.$max_int_length.',})/', ': "$1"', $input); + $obj = \json_decode($json_without_bigints); + } + + if ($errno = \json_last_error()) { + static::handleJsonError($errno); + } elseif ($obj === null && $input !== 'null') { + throw new DomainException('Null result with non-null input'); + } + return $obj; + } + + /** + * Encode a PHP object into a JSON string. + * + * @param object|array $input A PHP object or array + * + * @return string JSON representation of the PHP object or array + * + * @throws DomainException Provided object could not be encoded to valid JSON + */ + public static function jsonEncode($input) + { + $json = \json_encode($input); + if ($errno = \json_last_error()) { + static::handleJsonError($errno); + } elseif ($json === 'null' && $input !== null) { + throw new DomainException('Null result with non-null input'); + } + return $json; + } + + /** + * Decode a string with URL-safe Base64. + * + * @param string $input A Base64 encoded string + * + * @return string A decoded string + */ + public static function urlsafeB64Decode($input) + { + $remainder = \strlen($input) % 4; + if ($remainder) { + $padlen = 4 - $remainder; + $input .= \str_repeat('=', $padlen); + } + return \base64_decode(\strtr($input, '-_', '+/')); + } + + /** + * Encode a string with URL-safe Base64. + * + * @param string $input The string you want encoded + * + * @return string The base64 encode of what you passed in + */ + public static function urlsafeB64Encode($input) + { + return \str_replace('=', '', \strtr(\base64_encode($input), '+/', '-_')); + } + + /** + * Helper method to create a JSON error. + * + * @param int $errno An error number from json_last_error() + * + * @return void + */ + private static function handleJsonError($errno) + { + $messages = array( + JSON_ERROR_DEPTH => 'Maximum stack depth exceeded', + JSON_ERROR_STATE_MISMATCH => 'Invalid or malformed JSON', + JSON_ERROR_CTRL_CHAR => 'Unexpected control character found', + JSON_ERROR_SYNTAX => 'Syntax error, malformed JSON', + JSON_ERROR_UTF8 => 'Malformed UTF-8 characters' //PHP >= 5.3.3 + ); + throw new DomainException( + isset($messages[$errno]) + ? $messages[$errno] + : 'Unknown JSON error: ' . $errno + ); + } + + /** + * Get the number of bytes in cryptographic strings. + * + * @param string $str + * + * @return int + */ + private static function safeStrlen($str) + { + if (\function_exists('mb_strlen')) { + return \mb_strlen($str, '8bit'); + } + return \strlen($str); + } + + /** + * Convert an ECDSA signature to an ASN.1 DER sequence + * + * @param string $sig The ECDSA signature to convert + * @return string The encoded DER object + */ + private static function signatureToDER($sig) + { + // Separate the signature into r-value and s-value + list($r, $s) = \str_split($sig, (int) (\strlen($sig) / 2)); + + // Trim leading zeros + $r = \ltrim($r, "\x00"); + $s = \ltrim($s, "\x00"); + + // Convert r-value and s-value from unsigned big-endian integers to + // signed two's complement + if (\ord($r[0]) > 0x7f) { + $r = "\x00" . $r; + } + if (\ord($s[0]) > 0x7f) { + $s = "\x00" . $s; + } + + return self::encodeDER( + self::ASN1_SEQUENCE, + self::encodeDER(self::ASN1_INTEGER, $r) . + self::encodeDER(self::ASN1_INTEGER, $s) + ); + } + + /** + * Encodes a value into a DER object. + * + * @param int $type DER tag + * @param string $value the value to encode + * @return string the encoded object + */ + private static function encodeDER($type, $value) + { + $tag_header = 0; + if ($type === self::ASN1_SEQUENCE) { + $tag_header |= 0x20; + } + + // Type + $der = \chr($tag_header | $type); + + // Length + $der .= \chr(\strlen($value)); + + return $der . $value; + } + + /** + * Encodes signature from a DER object. + * + * @param string $der binary signature in DER format + * @param int $keySize the number of bits in the key + * @return string the signature + */ + private static function signatureFromDER($der, $keySize) + { + // OpenSSL returns the ECDSA signatures as a binary ASN.1 DER SEQUENCE + list($offset, $_) = self::readDER($der); + list($offset, $r) = self::readDER($der, $offset); + list($offset, $s) = self::readDER($der, $offset); + + // Convert r-value and s-value from signed two's compliment to unsigned + // big-endian integers + $r = \ltrim($r, "\x00"); + $s = \ltrim($s, "\x00"); + + // Pad out r and s so that they are $keySize bits long + $r = \str_pad($r, $keySize / 8, "\x00", STR_PAD_LEFT); + $s = \str_pad($s, $keySize / 8, "\x00", STR_PAD_LEFT); + + return $r . $s; + } + + /** + * Reads binary DER-encoded data and decodes into a single object + * + * @param string $der the binary data in DER format + * @param int $offset the offset of the data stream containing the object + * to decode + * @return array [$offset, $data] the new offset and the decoded object + */ + private static function readDER($der, $offset = 0) + { + $pos = $offset; + $size = \strlen($der); + $constructed = (\ord($der[$pos]) >> 5) & 0x01; + $type = \ord($der[$pos++]) & 0x1f; + + // Length + $len = \ord($der[$pos++]); + if ($len & 0x80) { + $n = $len & 0x1f; + $len = 0; + while ($n-- && $pos < $size) { + $len = ($len << 8) | \ord($der[$pos++]); + } + } + + // Value + if ($type == self::ASN1_BIT_STRING) { + $pos++; // Skip the first contents octet (padding indicator) + $data = \substr($der, $pos, $len - 1); + $pos += $len - 1; + } elseif (!$constructed) { + $data = \substr($der, $pos, $len); + $pos += $len; + } else { + $data = null; + } + + return array($pos, $data); + } +} diff --git a/notemyprogress/classes/jwt/SignatureInvalidException.php b/notemyprogress/classes/jwt/SignatureInvalidException.php new file mode 100644 index 0000000000000000000000000000000000000000..bbf4bdb9b12eab65cfc55a27e18c45fb626a6ff9 --- /dev/null +++ b/notemyprogress/classes/jwt/SignatureInvalidException.php @@ -0,0 +1,7 @@ +<?php + +namespace local_notemyprogress\jwt; + +class SignatureInvalidException extends \UnexpectedValueException +{ +} diff --git a/notemyprogress/classes/lib_trait.php b/notemyprogress/classes/lib_trait.php index 7ee3262c10e479da086e20d9a6c54b21637da34e..6cf0537022a54ce834b8e0a3ee1ee08ec7e3f7d7 100644 --- a/notemyprogress/classes/lib_trait.php +++ b/notemyprogress/classes/lib_trait.php @@ -68,14 +68,14 @@ trait lib_trait } /** - * Obtiene el registro de un usuario en base al parámetro $user. + * Obtain the registration of a user based on the $ User parameter. * - * Si el parámetro $user no es string ni entero, se retorma el mismo valor del - * parámetro recibido + * If the $ User parameter is not string or whole, the same value of the + * Parameter received * - * @param string $user id del curso que se desea buscar en formato string, entero u objeto + * @Param String $ User Id of the course you want to search in String format, whole or object * - * @return mixed un objeto fieldset que contiene el primer registro que hace match a la consulta + * @RETURN MIXED An Fieldset object containing the first record that matches the consultation */ public function get_user($user) { @@ -278,13 +278,13 @@ trait lib_trait } /** - * Retorna un string que representa la fecha ($timestamp) Unix formateada usando el parámetro $format - * y tomando como referencia la zona horaria obtenida con la función 'get_timezone' + * Returns a string that represents the date ($ Timestamp) formatted using the $ format parameter + * And taking as reference the time zone obtained with the 'Get_timezone' function * - * @param $format string objeto que representa una sección de un curso - * @param $timestamp int entero que representa una marca temporal de Unix + * @param $ format string object represents a section of a course + * @param $ Timestamp INTRO that represents a temporary brand of UNIX * - * @return string cadena de texto con la fecha formateada + * @return string text chain with the formatted date */ public function to_format($format, $timestamp) { @@ -298,9 +298,9 @@ trait lib_trait } /** - * Retorna un entero que representa la cantidad de segundos desde la Época Unix (January 1 1970 00:00:00 GMT) - * hasta la fecha actual. La fecha actual se calcula en base a la zona horaria obtenida con la función - * 'get_timezone'. + * A integer returns that represents the amount of seconds since the UNIX era (January 1 1970 00:00:00 GMT) + * Until now.The current date is calculated based on the time zone obtained with the function + * 'Get_timezone'. * * @return int entero que representa la cantidad de segundos desde la Época Unix hasta la fecha actual */ diff --git a/notemyprogress/classes/observer/observer.php b/notemyprogress/classes/observer/observer.php new file mode 100644 index 0000000000000000000000000000000000000000..e4caea72c4787a8df619230e20419b4620508335 --- /dev/null +++ b/notemyprogress/classes/observer/observer.php @@ -0,0 +1,122 @@ +<?php +// This file is part of Moodle - http://moodle.org/ +// +// Moodle is free software: you can redistribute it and/or modify +// it under the terms of the GNU General Public License as published by +// the Free Software Foundation, either version 3 of the License, or +// (at your option) any later version. +// +// Moodle is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +// GNU General Public License for more details. +// +// You should have received a copy of the GNU General Public License +// along with Moodle. If not, see <http://www.gnu.org/licenses/>. + +/** + * notemyprogress Observer + * + * @package local_notemyprogress + * @autor Edisson Sigua, Bryan Aguilar + * @copyright 2020 Edisson Sigua <edissonf.sigua@gmail.com>, Bryan Aguilar <bryan.aguilar6174@gmail.com> + * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later + */ + +namespace local_notemyprogress\observer; +defined('MOODLE_INTERNAL') || die(); + +/** + * notemyprogress observer class. + * + * @package local_notemyprogress + * @autor Edisson Sigua, Bryan Aguilar + * @copyright 2020 Edisson Sigua <edissonf.sigua@gmail.com>, Bryan Aguilar <bryan.aguilar6174@gmail.com> + * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later + */ +class observer +{ + + /** + * When a course is deleted. + * + * @param \core\event\course_deleted $event The event. + * @return void + */ + public static function course_deleted(\core\event\course_deleted $event) + { + global $DB; + + $courseid = $event->objectid; + + // Clean up the data that could be left behind. + $conditions = array('courseid' => $courseid); +// $DB->delete_records('block_xp', $conditions); +// $DB->delete_records('block_xp_config', $conditions); +// $DB->delete_records('block_xp_filters', $conditions); +// $DB->delete_records('block_xp_log', $conditions); + + // Flags. Note that this is based on the actually implementation. +// $sql = $DB->sql_like('name', ':name'); +// $DB->delete_records_select('user_preferences', $sql, [ +// 'name' => 'block_xp-notice-block_intro_' . $courseid +// ]); +// $DB->delete_records_select('user_preferences', $sql, [ +// 'name' => 'block_xp_notify_level_up_' . $courseid +// ]); + + // Delete the files. +// $fs = get_file_storage(); +// $fs->delete_area_files($event->contextid, 'block_xp', 'badges'); + } + + /** + * Observe all events. + * + * @param \core\event\base $event The event. + * @return void + */ + public static function catch_all(\core\event\base $event) { + + global $COURSE, $USER; + $userid = $event->userid; + + if ($event->component === 'local_notemyprogress') { + // omit your own events. + return; + } else if (!$userid || isguestuser($userid) || is_siteadmin($userid)) { + // Omitting users and invited that in Hayan started Sesión. + return; + } + else if ($event->anonymous) { + // Omit all events marked as anonymous. + return; + } + else if (!in_array($event->contextlevel, array(CONTEXT_COURSE, CONTEXT_MODULE))) { + // Omit events that are not in the right context. + return; + } else if ($event->edulevel !== \core\event\base::LEVEL_PARTICIPATING) { + // Ignore events that are not participating. + return; + } else if (!$event->get_context()) { + // If for some reason the context does not exist ... + return; + } + + try { + // It has been reported that this can generate an exception when the context is missing ... + $canearn = has_capability('local/notemyprogress:earnxp', $event->get_context(), $userid); + } catch (moodle_exception $e) { + return; + } + + // Omit events if the user does not have the ability to earn points. + if (!$canearn) { + return; + } + + $cs = new \local_notemyprogress\event_strategy($COURSE, $USER); + $cs->collect_event($event); + } + +} \ No newline at end of file diff --git a/notemyprogress/css/materialdesignicons.css b/notemyprogress/css/materialdesignicons.css index 9954f8f7029dea12ba5b5b28ca094175db4b2ab1..9946b6be69608d3d74bd6d3cf1935215fe9e6543 100644 --- a/notemyprogress/css/materialdesignicons.css +++ b/notemyprogress/css/materialdesignicons.css @@ -1,3 +1,12121 @@ +<<<<<<< HEAD @font-face{font-family:"Material Design Icons";src:url("../fonts/materialdesignicons-webfont.eot?v=3.9.97");src:url("../fonts/materialdesignicons-webfont.eot?#iefix&v=3.9.97") format("embedded-opentype"),url("../fonts/materialdesignicons-webfont.woff2?v=3.9.97") format("woff2"),url("../fonts/materialdesignicons-webfont.woff?v=3.9.97") format("woff"),url("../fonts/materialdesignicons-webfont.ttf?v=3.9.97") format("truetype");font-weight:normal;font-style:normal}.mdi:before,.mdi-set{display:inline-block;font:normal normal normal 24px/1 "Material Design Icons";font-size:inherit;text-rendering:auto;line-height:inherit;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.mdi-access-point::before{content:"\F002"}.mdi-access-point-network::before{content:"\F003"}.mdi-access-point-network-off::before{content:"\FBBD"}.mdi-account::before{content:"\F004"}.mdi-account-alert::before{content:"\F005"}.mdi-account-alert-outline::before{content:"\FB2C"}.mdi-account-arrow-left::before{content:"\FB2D"}.mdi-account-arrow-left-outline::before{content:"\FB2E"}.mdi-account-arrow-right::before{content:"\FB2F"}.mdi-account-arrow-right-outline::before{content:"\FB30"}.mdi-account-badge::before{content:"\FD83"}.mdi-account-badge-alert::before{content:"\FD84"}.mdi-account-badge-alert-outline::before{content:"\FD85"}.mdi-account-badge-horizontal::before{content:"\FDF0"}.mdi-account-badge-horizontal-outline::before{content:"\FDF1"}.mdi-account-badge-outline::before{content:"\FD86"}.mdi-account-box::before{content:"\F006"}.mdi-account-box-multiple::before{content:"\F933"}.mdi-account-box-outline::before{content:"\F007"}.mdi-account-card-details::before{content:"\F5D2"}.mdi-account-card-details-outline::before{content:"\FD87"}.mdi-account-check::before{content:"\F008"}.mdi-account-check-outline::before{content:"\FBBE"}.mdi-account-child::before{content:"\FA88"}.mdi-account-child-circle::before{content:"\FA89"}.mdi-account-circle::before{content:"\F009"}.mdi-account-circle-outline::before{content:"\FB31"}.mdi-account-clock::before{content:"\FB32"}.mdi-account-clock-outline::before{content:"\FB33"}.mdi-account-convert::before{content:"\F00A"}.mdi-account-details::before{content:"\F631"}.mdi-account-edit::before{content:"\F6BB"}.mdi-account-group::before{content:"\F848"}.mdi-account-group-outline::before{content:"\FB34"}.mdi-account-heart::before{content:"\F898"}.mdi-account-heart-outline::before{content:"\FBBF"}.mdi-account-key::before{content:"\F00B"}.mdi-account-key-outline::before{content:"\FBC0"}.mdi-account-minus::before{content:"\F00D"}.mdi-account-minus-outline::before{content:"\FAEB"}.mdi-account-multiple::before{content:"\F00E"}.mdi-account-multiple-check::before{content:"\F8C4"}.mdi-account-multiple-minus::before{content:"\F5D3"}.mdi-account-multiple-minus-outline::before{content:"\FBC1"}.mdi-account-multiple-outline::before{content:"\F00F"}.mdi-account-multiple-plus::before{content:"\F010"}.mdi-account-multiple-plus-outline::before{content:"\F7FF"}.mdi-account-network::before{content:"\F011"}.mdi-account-network-outline::before{content:"\FBC2"}.mdi-account-off::before{content:"\F012"}.mdi-account-off-outline::before{content:"\FBC3"}.mdi-account-outline::before{content:"\F013"}.mdi-account-plus::before{content:"\F014"}.mdi-account-plus-outline::before{content:"\F800"}.mdi-account-question::before{content:"\FB35"}.mdi-account-question-outline::before{content:"\FB36"}.mdi-account-remove::before{content:"\F015"}.mdi-account-remove-outline::before{content:"\FAEC"}.mdi-account-search::before{content:"\F016"}.mdi-account-search-outline::before{content:"\F934"}.mdi-account-settings::before{content:"\F630"}.mdi-account-star::before{content:"\F017"}.mdi-account-star-outline::before{content:"\FBC4"}.mdi-account-supervisor::before{content:"\FA8A"}.mdi-account-supervisor-circle::before{content:"\FA8B"}.mdi-account-switch::before{content:"\F019"}.mdi-account-tie::before{content:"\FCBF"}.mdi-accusoft::before{content:"\F849"}.mdi-adchoices::before{content:"\FD1E"}.mdi-adjust::before{content:"\F01A"}.mdi-adobe::before{content:"\F935"}.mdi-air-conditioner::before{content:"\F01B"}.mdi-air-filter::before{content:"\FD1F"}.mdi-air-horn::before{content:"\FD88"}.mdi-air-purifier::before{content:"\FD20"}.mdi-airbag::before{content:"\FBC5"}.mdi-airballoon::before{content:"\F01C"}.mdi-airplane::before{content:"\F01D"}.mdi-airplane-landing::before{content:"\F5D4"}.mdi-airplane-off::before{content:"\F01E"}.mdi-airplane-takeoff::before{content:"\F5D5"}.mdi-airplay::before{content:"\F01F"}.mdi-airport::before{content:"\F84A"}.mdi-alarm::before{content:"\F020"}.mdi-alarm-bell::before{content:"\F78D"}.mdi-alarm-check::before{content:"\F021"}.mdi-alarm-light::before{content:"\F78E"}.mdi-alarm-light-outline::before{content:"\FBC6"}.mdi-alarm-multiple::before{content:"\F022"}.mdi-alarm-note::before{content:"\FE8E"}.mdi-alarm-note-off::before{content:"\FE8F"}.mdi-alarm-off::before{content:"\F023"}.mdi-alarm-plus::before{content:"\F024"}.mdi-alarm-snooze::before{content:"\F68D"}.mdi-album::before{content:"\F025"}.mdi-alert::before{content:"\F026"}.mdi-alert-box::before{content:"\F027"}.mdi-alert-box-outline::before{content:"\FCC0"}.mdi-alert-circle::before{content:"\F028"}.mdi-alert-circle-outline::before{content:"\F5D6"}.mdi-alert-decagram::before{content:"\F6BC"}.mdi-alert-decagram-outline::before{content:"\FCC1"}.mdi-alert-octagon::before{content:"\F029"}.mdi-alert-octagon-outline::before{content:"\FCC2"}.mdi-alert-octagram::before{content:"\F766"}.mdi-alert-octagram-outline::before{content:"\FCC3"}.mdi-alert-outline::before{content:"\F02A"}.mdi-alien::before{content:"\F899"}.mdi-all-inclusive::before{content:"\F6BD"}.mdi-alpha::before{content:"\F02B"}.mdi-alpha-a::before{content:"\41"}.mdi-alpha-a-box::before{content:"\FAED"}.mdi-alpha-a-box-outline::before{content:"\FBC7"}.mdi-alpha-a-circle::before{content:"\FBC8"}.mdi-alpha-a-circle-outline::before{content:"\FBC9"}.mdi-alpha-b::before{content:"\42"}.mdi-alpha-b-box::before{content:"\FAEE"}.mdi-alpha-b-box-outline::before{content:"\FBCA"}.mdi-alpha-b-circle::before{content:"\FBCB"}.mdi-alpha-b-circle-outline::before{content:"\FBCC"}.mdi-alpha-c::before{content:"\43"}.mdi-alpha-c-box::before{content:"\FAEF"}.mdi-alpha-c-box-outline::before{content:"\FBCD"}.mdi-alpha-c-circle::before{content:"\FBCE"}.mdi-alpha-c-circle-outline::before{content:"\FBCF"}.mdi-alpha-d::before{content:"\44"}.mdi-alpha-d-box::before{content:"\FAF0"}.mdi-alpha-d-box-outline::before{content:"\FBD0"}.mdi-alpha-d-circle::before{content:"\FBD1"}.mdi-alpha-d-circle-outline::before{content:"\FBD2"}.mdi-alpha-e::before{content:"\45"}.mdi-alpha-e-box::before{content:"\FAF1"}.mdi-alpha-e-box-outline::before{content:"\FBD3"}.mdi-alpha-e-circle::before{content:"\FBD4"}.mdi-alpha-e-circle-outline::before{content:"\FBD5"}.mdi-alpha-f::before{content:"\46"}.mdi-alpha-f-box::before{content:"\FAF2"}.mdi-alpha-f-box-outline::before{content:"\FBD6"}.mdi-alpha-f-circle::before{content:"\FBD7"}.mdi-alpha-f-circle-outline::before{content:"\FBD8"}.mdi-alpha-g::before{content:"\47"}.mdi-alpha-g-box::before{content:"\FAF3"}.mdi-alpha-g-box-outline::before{content:"\FBD9"}.mdi-alpha-g-circle::before{content:"\FBDA"}.mdi-alpha-g-circle-outline::before{content:"\FBDB"}.mdi-alpha-h::before{content:"\48"}.mdi-alpha-h-box::before{content:"\FAF4"}.mdi-alpha-h-box-outline::before{content:"\FBDC"}.mdi-alpha-h-circle::before{content:"\FBDD"}.mdi-alpha-h-circle-outline::before{content:"\FBDE"}.mdi-alpha-i::before{content:"\49"}.mdi-alpha-i-box::before{content:"\FAF5"}.mdi-alpha-i-box-outline::before{content:"\FBDF"}.mdi-alpha-i-circle::before{content:"\FBE0"}.mdi-alpha-i-circle-outline::before{content:"\FBE1"}.mdi-alpha-j::before{content:"\4A"}.mdi-alpha-j-box::before{content:"\FAF6"}.mdi-alpha-j-box-outline::before{content:"\FBE2"}.mdi-alpha-j-circle::before{content:"\FBE3"}.mdi-alpha-j-circle-outline::before{content:"\FBE4"}.mdi-alpha-k::before{content:"\4B"}.mdi-alpha-k-box::before{content:"\FAF7"}.mdi-alpha-k-box-outline::before{content:"\FBE5"}.mdi-alpha-k-circle::before{content:"\FBE6"}.mdi-alpha-k-circle-outline::before{content:"\FBE7"}.mdi-alpha-l::before{content:"\4C"}.mdi-alpha-l-box::before{content:"\FAF8"}.mdi-alpha-l-box-outline::before{content:"\FBE8"}.mdi-alpha-l-circle::before{content:"\FBE9"}.mdi-alpha-l-circle-outline::before{content:"\FBEA"}.mdi-alpha-m::before{content:"\4D"}.mdi-alpha-m-box::before{content:"\FAF9"}.mdi-alpha-m-box-outline::before{content:"\FBEB"}.mdi-alpha-m-circle::before{content:"\FBEC"}.mdi-alpha-m-circle-outline::before{content:"\FBED"}.mdi-alpha-n::before{content:"\4E"}.mdi-alpha-n-box::before{content:"\FAFA"}.mdi-alpha-n-box-outline::before{content:"\FBEE"}.mdi-alpha-n-circle::before{content:"\FBEF"}.mdi-alpha-n-circle-outline::before{content:"\FBF0"}.mdi-alpha-o::before{content:"\4F"}.mdi-alpha-o-box::before{content:"\FAFB"}.mdi-alpha-o-box-outline::before{content:"\FBF1"}.mdi-alpha-o-circle::before{content:"\FBF2"}.mdi-alpha-o-circle-outline::before{content:"\FBF3"}.mdi-alpha-p::before{content:"\50"}.mdi-alpha-p-box::before{content:"\FAFC"}.mdi-alpha-p-box-outline::before{content:"\FBF4"}.mdi-alpha-p-circle::before{content:"\FBF5"}.mdi-alpha-p-circle-outline::before{content:"\FBF6"}.mdi-alpha-q::before{content:"\51"}.mdi-alpha-q-box::before{content:"\FAFD"}.mdi-alpha-q-box-outline::before{content:"\FBF7"}.mdi-alpha-q-circle::before{content:"\FBF8"}.mdi-alpha-q-circle-outline::before{content:"\FBF9"}.mdi-alpha-r::before{content:"\52"}.mdi-alpha-r-box::before{content:"\FAFE"}.mdi-alpha-r-box-outline::before{content:"\FBFA"}.mdi-alpha-r-circle::before{content:"\FBFB"}.mdi-alpha-r-circle-outline::before{content:"\FBFC"}.mdi-alpha-s::before{content:"\53"}.mdi-alpha-s-box::before{content:"\FAFF"}.mdi-alpha-s-box-outline::before{content:"\FBFD"}.mdi-alpha-s-circle::before{content:"\FBFE"}.mdi-alpha-s-circle-outline::before{content:"\FBFF"}.mdi-alpha-t::before{content:"\54"}.mdi-alpha-t-box::before{content:"\FB00"}.mdi-alpha-t-box-outline::before{content:"\FC00"}.mdi-alpha-t-circle::before{content:"\FC01"}.mdi-alpha-t-circle-outline::before{content:"\FC02"}.mdi-alpha-u::before{content:"\55"}.mdi-alpha-u-box::before{content:"\FB01"}.mdi-alpha-u-box-outline::before{content:"\FC03"}.mdi-alpha-u-circle::before{content:"\FC04"}.mdi-alpha-u-circle-outline::before{content:"\FC05"}.mdi-alpha-v::before{content:"\56"}.mdi-alpha-v-box::before{content:"\FB02"}.mdi-alpha-v-box-outline::before{content:"\FC06"}.mdi-alpha-v-circle::before{content:"\FC07"}.mdi-alpha-v-circle-outline::before{content:"\FC08"}.mdi-alpha-w::before{content:"\57"}.mdi-alpha-w-box::before{content:"\FB03"}.mdi-alpha-w-box-outline::before{content:"\FC09"}.mdi-alpha-w-circle::before{content:"\FC0A"}.mdi-alpha-w-circle-outline::before{content:"\FC0B"}.mdi-alpha-x::before{content:"\58"}.mdi-alpha-x-box::before{content:"\FB04"}.mdi-alpha-x-box-outline::before{content:"\FC0C"}.mdi-alpha-x-circle::before{content:"\FC0D"}.mdi-alpha-x-circle-outline::before{content:"\FC0E"}.mdi-alpha-y::before{content:"\59"}.mdi-alpha-y-box::before{content:"\FB05"}.mdi-alpha-y-box-outline::before{content:"\FC0F"}.mdi-alpha-y-circle::before{content:"\FC10"}.mdi-alpha-y-circle-outline::before{content:"\FC11"}.mdi-alpha-z::before{content:"\5A"}.mdi-alpha-z-box::before{content:"\FB06"}.mdi-alpha-z-box-outline::before{content:"\FC12"}.mdi-alpha-z-circle::before{content:"\FC13"}.mdi-alpha-z-circle-outline::before{content:"\FC14"}.mdi-alphabetical::before{content:"\F02C"}.mdi-altimeter::before{content:"\F5D7"}.mdi-amazon::before{content:"\F02D"}.mdi-amazon-alexa::before{content:"\F8C5"}.mdi-amazon-drive::before{content:"\F02E"}.mdi-ambulance::before{content:"\F02F"}.mdi-ammunition::before{content:"\FCC4"}.mdi-ampersand::before{content:"\FA8C"}.mdi-amplifier::before{content:"\F030"}.mdi-anchor::before{content:"\F031"}.mdi-android::before{content:"\F032"}.mdi-android-auto::before{content:"\FA8D"}.mdi-android-debug-bridge::before{content:"\F033"}.mdi-android-head::before{content:"\F78F"}.mdi-android-messages::before{content:"\FD21"}.mdi-android-studio::before{content:"\F034"}.mdi-angle-acute::before{content:"\F936"}.mdi-angle-obtuse::before{content:"\F937"}.mdi-angle-right::before{content:"\F938"}.mdi-angular::before{content:"\F6B1"}.mdi-angularjs::before{content:"\F6BE"}.mdi-animation::before{content:"\F5D8"}.mdi-animation-outline::before{content:"\FA8E"}.mdi-animation-play::before{content:"\F939"}.mdi-animation-play-outline::before{content:"\FA8F"}.mdi-anvil::before{content:"\F89A"}.mdi-apple::before{content:"\F035"}.mdi-apple-finder::before{content:"\F036"}.mdi-apple-icloud::before{content:"\F038"}.mdi-apple-ios::before{content:"\F037"}.mdi-apple-keyboard-caps::before{content:"\F632"}.mdi-apple-keyboard-command::before{content:"\F633"}.mdi-apple-keyboard-control::before{content:"\F634"}.mdi-apple-keyboard-option::before{content:"\F635"}.mdi-apple-keyboard-shift::before{content:"\F636"}.mdi-apple-safari::before{content:"\F039"}.mdi-application::before{content:"\F614"}.mdi-application-export::before{content:"\FD89"}.mdi-application-import::before{content:"\FD8A"}.mdi-apps::before{content:"\F03B"}.mdi-apps-box::before{content:"\FD22"}.mdi-arch::before{content:"\F8C6"}.mdi-archive::before{content:"\F03C"}.mdi-arrange-bring-forward::before{content:"\F03D"}.mdi-arrange-bring-to-front::before{content:"\F03E"}.mdi-arrange-send-backward::before{content:"\F03F"}.mdi-arrange-send-to-back::before{content:"\F040"}.mdi-arrow-all::before{content:"\F041"}.mdi-arrow-bottom-left::before{content:"\F042"}.mdi-arrow-bottom-left-bold-outline::before{content:"\F9B6"}.mdi-arrow-bottom-left-thick::before{content:"\F9B7"}.mdi-arrow-bottom-right::before{content:"\F043"}.mdi-arrow-bottom-right-bold-outline::before{content:"\F9B8"}.mdi-arrow-bottom-right-thick::before{content:"\F9B9"}.mdi-arrow-collapse::before{content:"\F615"}.mdi-arrow-collapse-all::before{content:"\F044"}.mdi-arrow-collapse-down::before{content:"\F791"}.mdi-arrow-collapse-horizontal::before{content:"\F84B"}.mdi-arrow-collapse-left::before{content:"\F792"}.mdi-arrow-collapse-right::before{content:"\F793"}.mdi-arrow-collapse-up::before{content:"\F794"}.mdi-arrow-collapse-vertical::before{content:"\F84C"}.mdi-arrow-decision::before{content:"\F9BA"}.mdi-arrow-decision-auto::before{content:"\F9BB"}.mdi-arrow-decision-auto-outline::before{content:"\F9BC"}.mdi-arrow-decision-outline::before{content:"\F9BD"}.mdi-arrow-down::before{content:"\F045"}.mdi-arrow-down-bold::before{content:"\F72D"}.mdi-arrow-down-bold-box::before{content:"\F72E"}.mdi-arrow-down-bold-box-outline::before{content:"\F72F"}.mdi-arrow-down-bold-circle::before{content:"\F047"}.mdi-arrow-down-bold-circle-outline::before{content:"\F048"}.mdi-arrow-down-bold-hexagon-outline::before{content:"\F049"}.mdi-arrow-down-bold-outline::before{content:"\F9BE"}.mdi-arrow-down-box::before{content:"\F6BF"}.mdi-arrow-down-circle::before{content:"\FCB7"}.mdi-arrow-down-circle-outline::before{content:"\FCB8"}.mdi-arrow-down-drop-circle::before{content:"\F04A"}.mdi-arrow-down-drop-circle-outline::before{content:"\F04B"}.mdi-arrow-down-thick::before{content:"\F046"}.mdi-arrow-expand::before{content:"\F616"}.mdi-arrow-expand-all::before{content:"\F04C"}.mdi-arrow-expand-down::before{content:"\F795"}.mdi-arrow-expand-horizontal::before{content:"\F84D"}.mdi-arrow-expand-left::before{content:"\F796"}.mdi-arrow-expand-right::before{content:"\F797"}.mdi-arrow-expand-up::before{content:"\F798"}.mdi-arrow-expand-vertical::before{content:"\F84E"}.mdi-arrow-left::before{content:"\F04D"}.mdi-arrow-left-bold::before{content:"\F730"}.mdi-arrow-left-bold-box::before{content:"\F731"}.mdi-arrow-left-bold-box-outline::before{content:"\F732"}.mdi-arrow-left-bold-circle::before{content:"\F04F"}.mdi-arrow-left-bold-circle-outline::before{content:"\F050"}.mdi-arrow-left-bold-hexagon-outline::before{content:"\F051"}.mdi-arrow-left-bold-outline::before{content:"\F9BF"}.mdi-arrow-left-box::before{content:"\F6C0"}.mdi-arrow-left-circle::before{content:"\FCB9"}.mdi-arrow-left-circle-outline::before{content:"\FCBA"}.mdi-arrow-left-drop-circle::before{content:"\F052"}.mdi-arrow-left-drop-circle-outline::before{content:"\F053"}.mdi-arrow-left-right::before{content:"\FE90"}.mdi-arrow-left-right-bold::before{content:"\FE91"}.mdi-arrow-left-right-bold-outline::before{content:"\F9C0"}.mdi-arrow-left-thick::before{content:"\F04E"}.mdi-arrow-right::before{content:"\F054"}.mdi-arrow-right-bold::before{content:"\F733"}.mdi-arrow-right-bold-box::before{content:"\F734"}.mdi-arrow-right-bold-box-outline::before{content:"\F735"}.mdi-arrow-right-bold-circle::before{content:"\F056"}.mdi-arrow-right-bold-circle-outline::before{content:"\F057"}.mdi-arrow-right-bold-hexagon-outline::before{content:"\F058"}.mdi-arrow-right-bold-outline::before{content:"\F9C1"}.mdi-arrow-right-box::before{content:"\F6C1"}.mdi-arrow-right-circle::before{content:"\FCBB"}.mdi-arrow-right-circle-outline::before{content:"\FCBC"}.mdi-arrow-right-drop-circle::before{content:"\F059"}.mdi-arrow-right-drop-circle-outline::before{content:"\F05A"}.mdi-arrow-right-thick::before{content:"\F055"}.mdi-arrow-split-horizontal::before{content:"\F93A"}.mdi-arrow-split-vertical::before{content:"\F93B"}.mdi-arrow-top-left::before{content:"\F05B"}.mdi-arrow-top-left-bold-outline::before{content:"\F9C2"}.mdi-arrow-top-left-bottom-right::before{content:"\FE92"}.mdi-arrow-top-left-bottom-right-bold::before{content:"\FE93"}.mdi-arrow-top-left-thick::before{content:"\F9C3"}.mdi-arrow-top-right::before{content:"\F05C"}.mdi-arrow-top-right-bold-outline::before{content:"\F9C4"}.mdi-arrow-top-right-bottom-left::before{content:"\FE94"}.mdi-arrow-top-right-bottom-left-bold::before{content:"\FE95"}.mdi-arrow-top-right-thick::before{content:"\F9C5"}.mdi-arrow-up::before{content:"\F05D"}.mdi-arrow-up-bold::before{content:"\F736"}.mdi-arrow-up-bold-box::before{content:"\F737"}.mdi-arrow-up-bold-box-outline::before{content:"\F738"}.mdi-arrow-up-bold-circle::before{content:"\F05F"}.mdi-arrow-up-bold-circle-outline::before{content:"\F060"}.mdi-arrow-up-bold-hexagon-outline::before{content:"\F061"}.mdi-arrow-up-bold-outline::before{content:"\F9C6"}.mdi-arrow-up-box::before{content:"\F6C2"}.mdi-arrow-up-circle::before{content:"\FCBD"}.mdi-arrow-up-circle-outline::before{content:"\FCBE"}.mdi-arrow-up-down::before{content:"\FE96"}.mdi-arrow-up-down-bold::before{content:"\FE97"}.mdi-arrow-up-down-bold-outline::before{content:"\F9C7"}.mdi-arrow-up-drop-circle::before{content:"\F062"}.mdi-arrow-up-drop-circle-outline::before{content:"\F063"}.mdi-arrow-up-thick::before{content:"\F05E"}.mdi-artist::before{content:"\F802"}.mdi-artist-outline::before{content:"\FCC5"}.mdi-artstation::before{content:"\FB37"}.mdi-aspect-ratio::before{content:"\FA23"}.mdi-assistant::before{content:"\F064"}.mdi-asterisk::before{content:"\F6C3"}.mdi-at::before{content:"\F065"}.mdi-atlassian::before{content:"\F803"}.mdi-atm::before{content:"\FD23"}.mdi-atom::before{content:"\F767"}.mdi-atom-variant::before{content:"\FE98"}.mdi-attachment::before{content:"\F066"}.mdi-audio-video::before{content:"\F93C"}.mdi-audiobook::before{content:"\F067"}.mdi-augmented-reality::before{content:"\F84F"}.mdi-auto-fix::before{content:"\F068"}.mdi-auto-upload::before{content:"\F069"}.mdi-autorenew::before{content:"\F06A"}.mdi-av-timer::before{content:"\F06B"}.mdi-aws::before{content:"\FDF2"}.mdi-axe::before{content:"\F8C7"}.mdi-axis::before{content:"\FD24"}.mdi-axis-arrow::before{content:"\FD25"}.mdi-axis-arrow-lock::before{content:"\FD26"}.mdi-axis-lock::before{content:"\FD27"}.mdi-axis-x-arrow::before{content:"\FD28"}.mdi-axis-x-arrow-lock::before{content:"\FD29"}.mdi-axis-x-rotate-clockwise::before{content:"\FD2A"}.mdi-axis-x-rotate-counterclockwise::before{content:"\FD2B"}.mdi-axis-x-y-arrow-lock::before{content:"\FD2C"}.mdi-axis-y-arrow::before{content:"\FD2D"}.mdi-axis-y-arrow-lock::before{content:"\FD2E"}.mdi-axis-y-rotate-clockwise::before{content:"\FD2F"}.mdi-axis-y-rotate-counterclockwise::before{content:"\FD30"}.mdi-axis-z-arrow::before{content:"\FD31"}.mdi-axis-z-arrow-lock::before{content:"\FD32"}.mdi-axis-z-rotate-clockwise::before{content:"\FD33"}.mdi-axis-z-rotate-counterclockwise::before{content:"\FD34"}.mdi-azure::before{content:"\F804"}.mdi-babel::before{content:"\FA24"}.mdi-baby::before{content:"\F06C"}.mdi-baby-bottle::before{content:"\FF56"}.mdi-baby-bottle-outline::before{content:"\FF57"}.mdi-baby-buggy::before{content:"\F68E"}.mdi-baby-face::before{content:"\FE99"}.mdi-baby-face-outline::before{content:"\FE9A"}.mdi-backburger::before{content:"\F06D"}.mdi-backspace::before{content:"\F06E"}.mdi-backspace-outline::before{content:"\FB38"}.mdi-backspace-reverse::before{content:"\FE9B"}.mdi-backspace-reverse-outline::before{content:"\FE9C"}.mdi-backup-restore::before{content:"\F06F"}.mdi-bacteria::before{content:"\FEF2"}.mdi-bacteria-outline::before{content:"\FEF3"}.mdi-badminton::before{content:"\F850"}.mdi-bag-carry-on::before{content:"\FF58"}.mdi-bag-carry-on-check::before{content:"\FD41"}.mdi-bag-carry-on-off::before{content:"\FF59"}.mdi-bag-checked::before{content:"\FF5A"}.mdi-bag-personal::before{content:"\FDF3"}.mdi-bag-personal-off::before{content:"\FDF4"}.mdi-bag-personal-off-outline::before{content:"\FDF5"}.mdi-bag-personal-outline::before{content:"\FDF6"}.mdi-baguette::before{content:"\FF5B"}.mdi-balloon::before{content:"\FA25"}.mdi-ballot::before{content:"\F9C8"}.mdi-ballot-outline::before{content:"\F9C9"}.mdi-ballot-recount::before{content:"\FC15"}.mdi-ballot-recount-outline::before{content:"\FC16"}.mdi-bandage::before{content:"\FD8B"}.mdi-bandcamp::before{content:"\F674"}.mdi-bank::before{content:"\F070"}.mdi-bank-minus::before{content:"\FD8C"}.mdi-bank-outline::before{content:"\FE9D"}.mdi-bank-plus::before{content:"\FD8D"}.mdi-bank-remove::before{content:"\FD8E"}.mdi-bank-transfer::before{content:"\FA26"}.mdi-bank-transfer-in::before{content:"\FA27"}.mdi-bank-transfer-out::before{content:"\FA28"}.mdi-barcode::before{content:"\F071"}.mdi-barcode-scan::before{content:"\F072"}.mdi-barley::before{content:"\F073"}.mdi-barley-off::before{content:"\FB39"}.mdi-barn::before{content:"\FB3A"}.mdi-barrel::before{content:"\F074"}.mdi-baseball::before{content:"\F851"}.mdi-baseball-bat::before{content:"\F852"}.mdi-basecamp::before{content:"\F075"}.mdi-basket::before{content:"\F076"}.mdi-basket-fill::before{content:"\F077"}.mdi-basket-unfill::before{content:"\F078"}.mdi-basketball::before{content:"\F805"}.mdi-basketball-hoop::before{content:"\FC17"}.mdi-basketball-hoop-outline::before{content:"\FC18"}.mdi-bat::before{content:"\FB3B"}.mdi-battery::before{content:"\F079"}.mdi-battery-10::before{content:"\F07A"}.mdi-battery-10-bluetooth::before{content:"\F93D"}.mdi-battery-20::before{content:"\F07B"}.mdi-battery-20-bluetooth::before{content:"\F93E"}.mdi-battery-30::before{content:"\F07C"}.mdi-battery-30-bluetooth::before{content:"\F93F"}.mdi-battery-40::before{content:"\F07D"}.mdi-battery-40-bluetooth::before{content:"\F940"}.mdi-battery-50::before{content:"\F07E"}.mdi-battery-50-bluetooth::before{content:"\F941"}.mdi-battery-60::before{content:"\F07F"}.mdi-battery-60-bluetooth::before{content:"\F942"}.mdi-battery-70::before{content:"\F080"}.mdi-battery-70-bluetooth::before{content:"\F943"}.mdi-battery-80::before{content:"\F081"}.mdi-battery-80-bluetooth::before{content:"\F944"}.mdi-battery-90::before{content:"\F082"}.mdi-battery-90-bluetooth::before{content:"\F945"}.mdi-battery-alert::before{content:"\F083"}.mdi-battery-alert-bluetooth::before{content:"\F946"}.mdi-battery-bluetooth::before{content:"\F947"}.mdi-battery-bluetooth-variant::before{content:"\F948"}.mdi-battery-charging::before{content:"\F084"}.mdi-battery-charging-10::before{content:"\F89B"}.mdi-battery-charging-100::before{content:"\F085"}.mdi-battery-charging-20::before{content:"\F086"}.mdi-battery-charging-30::before{content:"\F087"}.mdi-battery-charging-40::before{content:"\F088"}.mdi-battery-charging-50::before{content:"\F89C"}.mdi-battery-charging-60::before{content:"\F089"}.mdi-battery-charging-70::before{content:"\F89D"}.mdi-battery-charging-80::before{content:"\F08A"}.mdi-battery-charging-90::before{content:"\F08B"}.mdi-battery-charging-outline::before{content:"\F89E"}.mdi-battery-charging-wireless::before{content:"\F806"}.mdi-battery-charging-wireless-10::before{content:"\F807"}.mdi-battery-charging-wireless-20::before{content:"\F808"}.mdi-battery-charging-wireless-30::before{content:"\F809"}.mdi-battery-charging-wireless-40::before{content:"\F80A"}.mdi-battery-charging-wireless-50::before{content:"\F80B"}.mdi-battery-charging-wireless-60::before{content:"\F80C"}.mdi-battery-charging-wireless-70::before{content:"\F80D"}.mdi-battery-charging-wireless-80::before{content:"\F80E"}.mdi-battery-charging-wireless-90::before{content:"\F80F"}.mdi-battery-charging-wireless-alert::before{content:"\F810"}.mdi-battery-charging-wireless-outline::before{content:"\F811"}.mdi-battery-minus::before{content:"\F08C"}.mdi-battery-negative::before{content:"\F08D"}.mdi-battery-outline::before{content:"\F08E"}.mdi-battery-plus::before{content:"\F08F"}.mdi-battery-positive::before{content:"\F090"}.mdi-battery-unknown::before{content:"\F091"}.mdi-battery-unknown-bluetooth::before{content:"\F949"}.mdi-battlenet::before{content:"\FB3C"}.mdi-beach::before{content:"\F092"}.mdi-beaker::before{content:"\FCC6"}.mdi-beaker-outline::before{content:"\F68F"}.mdi-beats::before{content:"\F097"}.mdi-bed-empty::before{content:"\F89F"}.mdi-beer::before{content:"\F098"}.mdi-behance::before{content:"\F099"}.mdi-bell::before{content:"\F09A"}.mdi-bell-alert::before{content:"\FD35"}.mdi-bell-alert-outline::before{content:"\FE9E"}.mdi-bell-circle::before{content:"\FD36"}.mdi-bell-circle-outline::before{content:"\FD37"}.mdi-bell-off::before{content:"\F09B"}.mdi-bell-off-outline::before{content:"\FA90"}.mdi-bell-outline::before{content:"\F09C"}.mdi-bell-plus::before{content:"\F09D"}.mdi-bell-plus-outline::before{content:"\FA91"}.mdi-bell-ring::before{content:"\F09E"}.mdi-bell-ring-outline::before{content:"\F09F"}.mdi-bell-sleep::before{content:"\F0A0"}.mdi-bell-sleep-outline::before{content:"\FA92"}.mdi-beta::before{content:"\F0A1"}.mdi-betamax::before{content:"\F9CA"}.mdi-biathlon::before{content:"\FDF7"}.mdi-bible::before{content:"\F0A2"}.mdi-bike::before{content:"\F0A3"}.mdi-billiards::before{content:"\FB3D"}.mdi-billiards-rack::before{content:"\FB3E"}.mdi-bing::before{content:"\F0A4"}.mdi-binoculars::before{content:"\F0A5"}.mdi-bio::before{content:"\F0A6"}.mdi-biohazard::before{content:"\F0A7"}.mdi-bitbucket::before{content:"\F0A8"}.mdi-bitcoin::before{content:"\F812"}.mdi-black-mesa::before{content:"\F0A9"}.mdi-blackberry::before{content:"\F0AA"}.mdi-blender::before{content:"\FCC7"}.mdi-blender-software::before{content:"\F0AB"}.mdi-blinds::before{content:"\F0AC"}.mdi-block-helper::before{content:"\F0AD"}.mdi-blogger::before{content:"\F0AE"}.mdi-blood-bag::before{content:"\FCC8"}.mdi-bluetooth::before{content:"\F0AF"}.mdi-bluetooth-audio::before{content:"\F0B0"}.mdi-bluetooth-connect::before{content:"\F0B1"}.mdi-bluetooth-off::before{content:"\F0B2"}.mdi-bluetooth-settings::before{content:"\F0B3"}.mdi-bluetooth-transfer::before{content:"\F0B4"}.mdi-blur::before{content:"\F0B5"}.mdi-blur-linear::before{content:"\F0B6"}.mdi-blur-off::before{content:"\F0B7"}.mdi-blur-radial::before{content:"\F0B8"}.mdi-bolnisi-cross::before{content:"\FCC9"}.mdi-bolt::before{content:"\FD8F"}.mdi-bomb::before{content:"\F690"}.mdi-bomb-off::before{content:"\F6C4"}.mdi-bone::before{content:"\F0B9"}.mdi-book::before{content:"\F0BA"}.mdi-book-lock::before{content:"\F799"}.mdi-book-lock-open::before{content:"\F79A"}.mdi-book-minus::before{content:"\F5D9"}.mdi-book-minus-multiple::before{content:"\FA93"}.mdi-book-multiple::before{content:"\F0BB"}.mdi-book-open::before{content:"\F0BD"}.mdi-book-open-outline::before{content:"\FB3F"}.mdi-book-open-page-variant::before{content:"\F5DA"}.mdi-book-open-variant::before{content:"\F0BE"}.mdi-book-outline::before{content:"\FB40"}.mdi-book-play::before{content:"\FE9F"}.mdi-book-play-outline::before{content:"\FEA0"}.mdi-book-plus::before{content:"\F5DB"}.mdi-book-plus-multiple::before{content:"\FA94"}.mdi-book-remove::before{content:"\FA96"}.mdi-book-remove-multiple::before{content:"\FA95"}.mdi-book-search::before{content:"\FEA1"}.mdi-book-search-outline::before{content:"\FEA2"}.mdi-book-variant::before{content:"\F0BF"}.mdi-book-variant-multiple::before{content:"\F0BC"}.mdi-bookmark::before{content:"\F0C0"}.mdi-bookmark-check::before{content:"\F0C1"}.mdi-bookmark-minus::before{content:"\F9CB"}.mdi-bookmark-minus-outline::before{content:"\F9CC"}.mdi-bookmark-multiple::before{content:"\FDF8"}.mdi-bookmark-multiple-outline::before{content:"\FDF9"}.mdi-bookmark-music::before{content:"\F0C2"}.mdi-bookmark-off::before{content:"\F9CD"}.mdi-bookmark-off-outline::before{content:"\F9CE"}.mdi-bookmark-outline::before{content:"\F0C3"}.mdi-bookmark-plus::before{content:"\F0C5"}.mdi-bookmark-plus-outline::before{content:"\F0C4"}.mdi-bookmark-remove::before{content:"\F0C6"}.mdi-boom-gate::before{content:"\FEA3"}.mdi-boom-gate-alert::before{content:"\FEA4"}.mdi-boom-gate-alert-outline::before{content:"\FEA5"}.mdi-boom-gate-down::before{content:"\FEA6"}.mdi-boom-gate-down-outline::before{content:"\FEA7"}.mdi-boom-gate-outline::before{content:"\FEA8"}.mdi-boom-gate-up::before{content:"\FEA9"}.mdi-boom-gate-up-outline::before{content:"\FEAA"}.mdi-boombox::before{content:"\F5DC"}.mdi-bootstrap::before{content:"\F6C5"}.mdi-border-all::before{content:"\F0C7"}.mdi-border-all-variant::before{content:"\F8A0"}.mdi-border-bottom::before{content:"\F0C8"}.mdi-border-bottom-variant::before{content:"\F8A1"}.mdi-border-color::before{content:"\F0C9"}.mdi-border-horizontal::before{content:"\F0CA"}.mdi-border-inside::before{content:"\F0CB"}.mdi-border-left::before{content:"\F0CC"}.mdi-border-left-variant::before{content:"\F8A2"}.mdi-border-none::before{content:"\F0CD"}.mdi-border-none-variant::before{content:"\F8A3"}.mdi-border-outside::before{content:"\F0CE"}.mdi-border-right::before{content:"\F0CF"}.mdi-border-right-variant::before{content:"\F8A4"}.mdi-border-style::before{content:"\F0D0"}.mdi-border-top::before{content:"\F0D1"}.mdi-border-top-variant::before{content:"\F8A5"}.mdi-border-vertical::before{content:"\F0D2"}.mdi-bottle-wine::before{content:"\F853"}.mdi-bow-tie::before{content:"\F677"}.mdi-bowl::before{content:"\F617"}.mdi-bowling::before{content:"\F0D3"}.mdi-box::before{content:"\F0D4"}.mdi-box-cutter::before{content:"\F0D5"}.mdi-box-shadow::before{content:"\F637"}.mdi-boxing-glove::before{content:"\FB41"}.mdi-braille::before{content:"\F9CF"}.mdi-brain::before{content:"\F9D0"}.mdi-bread-slice::before{content:"\FCCA"}.mdi-bread-slice-outline::before{content:"\FCCB"}.mdi-bridge::before{content:"\F618"}.mdi-briefcase::before{content:"\F0D6"}.mdi-briefcase-account::before{content:"\FCCC"}.mdi-briefcase-account-outline::before{content:"\FCCD"}.mdi-briefcase-check::before{content:"\F0D7"}.mdi-briefcase-download::before{content:"\F0D8"}.mdi-briefcase-download-outline::before{content:"\FC19"}.mdi-briefcase-edit::before{content:"\FA97"}.mdi-briefcase-edit-outline::before{content:"\FC1A"}.mdi-briefcase-minus::before{content:"\FA29"}.mdi-briefcase-minus-outline::before{content:"\FC1B"}.mdi-briefcase-outline::before{content:"\F813"}.mdi-briefcase-plus::before{content:"\FA2A"}.mdi-briefcase-plus-outline::before{content:"\FC1C"}.mdi-briefcase-remove::before{content:"\FA2B"}.mdi-briefcase-remove-outline::before{content:"\FC1D"}.mdi-briefcase-search::before{content:"\FA2C"}.mdi-briefcase-search-outline::before{content:"\FC1E"}.mdi-briefcase-upload::before{content:"\F0D9"}.mdi-briefcase-upload-outline::before{content:"\FC1F"}.mdi-brightness-1::before{content:"\F0DA"}.mdi-brightness-2::before{content:"\F0DB"}.mdi-brightness-3::before{content:"\F0DC"}.mdi-brightness-4::before{content:"\F0DD"}.mdi-brightness-5::before{content:"\F0DE"}.mdi-brightness-6::before{content:"\F0DF"}.mdi-brightness-7::before{content:"\F0E0"}.mdi-brightness-auto::before{content:"\F0E1"}.mdi-brightness-percent::before{content:"\FCCE"}.mdi-broom::before{content:"\F0E2"}.mdi-brush::before{content:"\F0E3"}.mdi-buddhism::before{content:"\F94A"}.mdi-buffer::before{content:"\F619"}.mdi-bug::before{content:"\F0E4"}.mdi-bug-check::before{content:"\FA2D"}.mdi-bug-check-outline::before{content:"\FA2E"}.mdi-bug-outline::before{content:"\FA2F"}.mdi-bugle::before{content:"\FD90"}.mdi-bulldozer::before{content:"\FB07"}.mdi-bullet::before{content:"\FCCF"}.mdi-bulletin-board::before{content:"\F0E5"}.mdi-bullhorn::before{content:"\F0E6"}.mdi-bullhorn-outline::before{content:"\FB08"}.mdi-bullseye::before{content:"\F5DD"}.mdi-bullseye-arrow::before{content:"\F8C8"}.mdi-bus::before{content:"\F0E7"}.mdi-bus-alert::before{content:"\FA98"}.mdi-bus-articulated-end::before{content:"\F79B"}.mdi-bus-articulated-front::before{content:"\F79C"}.mdi-bus-clock::before{content:"\F8C9"}.mdi-bus-double-decker::before{content:"\F79D"}.mdi-bus-multiple::before{content:"\FF5C"}.mdi-bus-school::before{content:"\F79E"}.mdi-bus-side::before{content:"\F79F"}.mdi-cached::before{content:"\F0E8"}.mdi-cactus::before{content:"\FD91"}.mdi-cake::before{content:"\F0E9"}.mdi-cake-layered::before{content:"\F0EA"}.mdi-cake-variant::before{content:"\F0EB"}.mdi-calculator::before{content:"\F0EC"}.mdi-calculator-variant::before{content:"\FA99"}.mdi-calendar::before{content:"\F0ED"}.mdi-calendar-account::before{content:"\FEF4"}.mdi-calendar-account-outline::before{content:"\FEF5"}.mdi-calendar-alert::before{content:"\FA30"}.mdi-calendar-blank::before{content:"\F0EE"}.mdi-calendar-blank-outline::before{content:"\FB42"}.mdi-calendar-check::before{content:"\F0EF"}.mdi-calendar-check-outline::before{content:"\FC20"}.mdi-calendar-clock::before{content:"\F0F0"}.mdi-calendar-edit::before{content:"\F8A6"}.mdi-calendar-export::before{content:"\FB09"}.mdi-calendar-heart::before{content:"\F9D1"}.mdi-calendar-import::before{content:"\FB0A"}.mdi-calendar-minus::before{content:"\FD38"}.mdi-calendar-month::before{content:"\FDFA"}.mdi-calendar-month-outline::before{content:"\FDFB"}.mdi-calendar-multiple::before{content:"\F0F1"}.mdi-calendar-multiple-check::before{content:"\F0F2"}.mdi-calendar-multiselect::before{content:"\FA31"}.mdi-calendar-outline::before{content:"\FB43"}.mdi-calendar-plus::before{content:"\F0F3"}.mdi-calendar-question::before{content:"\F691"}.mdi-calendar-range::before{content:"\F678"}.mdi-calendar-range-outline::before{content:"\FB44"}.mdi-calendar-remove::before{content:"\F0F4"}.mdi-calendar-remove-outline::before{content:"\FC21"}.mdi-calendar-repeat::before{content:"\FEAB"}.mdi-calendar-repeat-outline::before{content:"\FEAC"}.mdi-calendar-search::before{content:"\F94B"}.mdi-calendar-star::before{content:"\F9D2"}.mdi-calendar-text::before{content:"\F0F5"}.mdi-calendar-text-outline::before{content:"\FC22"}.mdi-calendar-today::before{content:"\F0F6"}.mdi-calendar-week::before{content:"\FA32"}.mdi-calendar-week-begin::before{content:"\FA33"}.mdi-calendar-weekend::before{content:"\FEF6"}.mdi-calendar-weekend-outline::before{content:"\FEF7"}.mdi-call-made::before{content:"\F0F7"}.mdi-call-merge::before{content:"\F0F8"}.mdi-call-missed::before{content:"\F0F9"}.mdi-call-received::before{content:"\F0FA"}.mdi-call-split::before{content:"\F0FB"}.mdi-camcorder::before{content:"\F0FC"}.mdi-camcorder-box::before{content:"\F0FD"}.mdi-camcorder-box-off::before{content:"\F0FE"}.mdi-camcorder-off::before{content:"\F0FF"}.mdi-camera::before{content:"\F100"}.mdi-camera-account::before{content:"\F8CA"}.mdi-camera-burst::before{content:"\F692"}.mdi-camera-control::before{content:"\FB45"}.mdi-camera-enhance::before{content:"\F101"}.mdi-camera-enhance-outline::before{content:"\FB46"}.mdi-camera-front::before{content:"\F102"}.mdi-camera-front-variant::before{content:"\F103"}.mdi-camera-gopro::before{content:"\F7A0"}.mdi-camera-image::before{content:"\F8CB"}.mdi-camera-iris::before{content:"\F104"}.mdi-camera-metering-center::before{content:"\F7A1"}.mdi-camera-metering-matrix::before{content:"\F7A2"}.mdi-camera-metering-partial::before{content:"\F7A3"}.mdi-camera-metering-spot::before{content:"\F7A4"}.mdi-camera-off::before{content:"\F5DF"}.mdi-camera-outline::before{content:"\FD39"}.mdi-camera-party-mode::before{content:"\F105"}.mdi-camera-plus::before{content:"\FEF8"}.mdi-camera-plus-outline::before{content:"\FEF9"}.mdi-camera-rear::before{content:"\F106"}.mdi-camera-rear-variant::before{content:"\F107"}.mdi-camera-retake::before{content:"\FDFC"}.mdi-camera-retake-outline::before{content:"\FDFD"}.mdi-camera-switch::before{content:"\F108"}.mdi-camera-timer::before{content:"\F109"}.mdi-camera-wireless::before{content:"\FD92"}.mdi-camera-wireless-outline::before{content:"\FD93"}.mdi-campfire::before{content:"\FEFA"}.mdi-cancel::before{content:"\F739"}.mdi-candle::before{content:"\F5E2"}.mdi-candycane::before{content:"\F10A"}.mdi-cannabis::before{content:"\F7A5"}.mdi-caps-lock::before{content:"\FA9A"}.mdi-car::before{content:"\F10B"}.mdi-car-back::before{content:"\FDFE"}.mdi-car-battery::before{content:"\F10C"}.mdi-car-brake-abs::before{content:"\FC23"}.mdi-car-brake-alert::before{content:"\FC24"}.mdi-car-brake-hold::before{content:"\FD3A"}.mdi-car-brake-parking::before{content:"\FD3B"}.mdi-car-connected::before{content:"\F10D"}.mdi-car-convertible::before{content:"\F7A6"}.mdi-car-cruise-control::before{content:"\FD3C"}.mdi-car-defrost-front::before{content:"\FD3D"}.mdi-car-defrost-rear::before{content:"\FD3E"}.mdi-car-door::before{content:"\FB47"}.mdi-car-electric::before{content:"\FB48"}.mdi-car-esp::before{content:"\FC25"}.mdi-car-estate::before{content:"\F7A7"}.mdi-car-hatchback::before{content:"\F7A8"}.mdi-car-key::before{content:"\FB49"}.mdi-car-light-dimmed::before{content:"\FC26"}.mdi-car-light-fog::before{content:"\FC27"}.mdi-car-light-high::before{content:"\FC28"}.mdi-car-limousine::before{content:"\F8CC"}.mdi-car-multiple::before{content:"\FB4A"}.mdi-car-off::before{content:"\FDFF"}.mdi-car-parking-lights::before{content:"\FD3F"}.mdi-car-pickup::before{content:"\F7A9"}.mdi-car-shift-pattern::before{content:"\FF5D"}.mdi-car-side::before{content:"\F7AA"}.mdi-car-sports::before{content:"\F7AB"}.mdi-car-tire-alert::before{content:"\FC29"}.mdi-car-traction-control::before{content:"\FD40"}.mdi-car-wash::before{content:"\F10E"}.mdi-caravan::before{content:"\F7AC"}.mdi-card::before{content:"\FB4B"}.mdi-card-bulleted::before{content:"\FB4C"}.mdi-card-bulleted-off::before{content:"\FB4D"}.mdi-card-bulleted-off-outline::before{content:"\FB4E"}.mdi-card-bulleted-outline::before{content:"\FB4F"}.mdi-card-bulleted-settings::before{content:"\FB50"}.mdi-card-bulleted-settings-outline::before{content:"\FB51"}.mdi-card-outline::before{content:"\FB52"}.mdi-card-text::before{content:"\FB53"}.mdi-card-text-outline::before{content:"\FB54"}.mdi-cards::before{content:"\F638"}.mdi-cards-club::before{content:"\F8CD"}.mdi-cards-diamond::before{content:"\F8CE"}.mdi-cards-heart::before{content:"\F8CF"}.mdi-cards-outline::before{content:"\F639"}.mdi-cards-playing-outline::before{content:"\F63A"}.mdi-cards-spade::before{content:"\F8D0"}.mdi-cards-variant::before{content:"\F6C6"}.mdi-carrot::before{content:"\F10F"}.mdi-cart::before{content:"\F110"}.mdi-cart-arrow-down::before{content:"\FD42"}.mdi-cart-arrow-right::before{content:"\FC2A"}.mdi-cart-arrow-up::before{content:"\FD43"}.mdi-cart-minus::before{content:"\FD44"}.mdi-cart-off::before{content:"\F66B"}.mdi-cart-outline::before{content:"\F111"}.mdi-cart-plus::before{content:"\F112"}.mdi-cart-remove::before{content:"\FD45"}.mdi-case-sensitive-alt::before{content:"\F113"}.mdi-cash::before{content:"\F114"}.mdi-cash-100::before{content:"\F115"}.mdi-cash-marker::before{content:"\FD94"}.mdi-cash-multiple::before{content:"\F116"}.mdi-cash-refund::before{content:"\FA9B"}.mdi-cash-register::before{content:"\FCD0"}.mdi-cash-usd::before{content:"\F117"}.mdi-cassette::before{content:"\F9D3"}.mdi-cast::before{content:"\F118"}.mdi-cast-connected::before{content:"\F119"}.mdi-cast-education::before{content:"\FE6D"}.mdi-cast-off::before{content:"\F789"}.mdi-castle::before{content:"\F11A"}.mdi-cat::before{content:"\F11B"}.mdi-cctv::before{content:"\F7AD"}.mdi-ceiling-light::before{content:"\F768"}.mdi-cellphone::before{content:"\F11C"}.mdi-cellphone-android::before{content:"\F11D"}.mdi-cellphone-arrow-down::before{content:"\F9D4"}.mdi-cellphone-basic::before{content:"\F11E"}.mdi-cellphone-dock::before{content:"\F11F"}.mdi-cellphone-erase::before{content:"\F94C"}.mdi-cellphone-information::before{content:"\FF5E"}.mdi-cellphone-iphone::before{content:"\F120"}.mdi-cellphone-key::before{content:"\F94D"}.mdi-cellphone-link::before{content:"\F121"}.mdi-cellphone-link-off::before{content:"\F122"}.mdi-cellphone-lock::before{content:"\F94E"}.mdi-cellphone-message::before{content:"\F8D2"}.mdi-cellphone-nfc::before{content:"\FEAD"}.mdi-cellphone-off::before{content:"\F94F"}.mdi-cellphone-screenshot::before{content:"\FA34"}.mdi-cellphone-settings::before{content:"\F123"}.mdi-cellphone-settings-variant::before{content:"\F950"}.mdi-cellphone-sound::before{content:"\F951"}.mdi-cellphone-text::before{content:"\F8D1"}.mdi-cellphone-wireless::before{content:"\F814"}.mdi-celtic-cross::before{content:"\FCD1"}.mdi-certificate::before{content:"\F124"}.mdi-chair-rolling::before{content:"\FFBA"}.mdi-chair-school::before{content:"\F125"}.mdi-charity::before{content:"\FC2B"}.mdi-chart-arc::before{content:"\F126"}.mdi-chart-areaspline::before{content:"\F127"}.mdi-chart-areaspline-variant::before{content:"\FEAE"}.mdi-chart-bar::before{content:"\F128"}.mdi-chart-bar-stacked::before{content:"\F769"}.mdi-chart-bell-curve::before{content:"\FC2C"}.mdi-chart-bubble::before{content:"\F5E3"}.mdi-chart-donut::before{content:"\F7AE"}.mdi-chart-donut-variant::before{content:"\F7AF"}.mdi-chart-gantt::before{content:"\F66C"}.mdi-chart-histogram::before{content:"\F129"}.mdi-chart-line::before{content:"\F12A"}.mdi-chart-line-stacked::before{content:"\F76A"}.mdi-chart-line-variant::before{content:"\F7B0"}.mdi-chart-multiline::before{content:"\F8D3"}.mdi-chart-pie::before{content:"\F12B"}.mdi-chart-scatter-plot::before{content:"\FEAF"}.mdi-chart-scatter-plot-hexbin::before{content:"\F66D"}.mdi-chart-timeline::before{content:"\F66E"}.mdi-chart-timeline-variant::before{content:"\FEB0"}.mdi-chart-tree::before{content:"\FEB1"}.mdi-chat::before{content:"\FB55"}.mdi-chat-alert::before{content:"\FB56"}.mdi-chat-outline::before{content:"\FEFB"}.mdi-chat-processing::before{content:"\FB57"}.mdi-check::before{content:"\F12C"}.mdi-check-all::before{content:"\F12D"}.mdi-check-bold::before{content:"\FE6E"}.mdi-check-box-multiple-outline::before{content:"\FC2D"}.mdi-check-box-outline::before{content:"\FC2E"}.mdi-check-circle::before{content:"\F5E0"}.mdi-check-circle-outline::before{content:"\F5E1"}.mdi-check-decagram::before{content:"\F790"}.mdi-check-network::before{content:"\FC2F"}.mdi-check-network-outline::before{content:"\FC30"}.mdi-check-outline::before{content:"\F854"}.mdi-check-underline::before{content:"\FE70"}.mdi-check-underline-circle::before{content:"\FE71"}.mdi-check-underline-circle-outline::before{content:"\FE72"}.mdi-checkbook::before{content:"\FA9C"}.mdi-checkbox-blank::before{content:"\F12E"}.mdi-checkbox-blank-circle::before{content:"\F12F"}.mdi-checkbox-blank-circle-outline::before{content:"\F130"}.mdi-checkbox-blank-outline::before{content:"\F131"}.mdi-checkbox-intermediate::before{content:"\F855"}.mdi-checkbox-marked::before{content:"\F132"}.mdi-checkbox-marked-circle::before{content:"\F133"}.mdi-checkbox-marked-circle-outline::before{content:"\F134"}.mdi-checkbox-marked-outline::before{content:"\F135"}.mdi-checkbox-multiple-blank::before{content:"\F136"}.mdi-checkbox-multiple-blank-circle::before{content:"\F63B"}.mdi-checkbox-multiple-blank-circle-outline::before{content:"\F63C"}.mdi-checkbox-multiple-blank-outline::before{content:"\F137"}.mdi-checkbox-multiple-marked::before{content:"\F138"}.mdi-checkbox-multiple-marked-circle::before{content:"\F63D"}.mdi-checkbox-multiple-marked-circle-outline::before{content:"\F63E"}.mdi-checkbox-multiple-marked-outline::before{content:"\F139"}.mdi-checkerboard::before{content:"\F13A"}.mdi-chef-hat::before{content:"\FB58"}.mdi-chemical-weapon::before{content:"\F13B"}.mdi-chess-bishop::before{content:"\F85B"}.mdi-chess-king::before{content:"\F856"}.mdi-chess-knight::before{content:"\F857"}.mdi-chess-pawn::before{content:"\F858"}.mdi-chess-queen::before{content:"\F859"}.mdi-chess-rook::before{content:"\F85A"}.mdi-chevron-double-down::before{content:"\F13C"}.mdi-chevron-double-left::before{content:"\F13D"}.mdi-chevron-double-right::before{content:"\F13E"}.mdi-chevron-double-up::before{content:"\F13F"}.mdi-chevron-down::before{content:"\F140"}.mdi-chevron-down-box::before{content:"\F9D5"}.mdi-chevron-down-box-outline::before{content:"\F9D6"}.mdi-chevron-down-circle::before{content:"\FB0B"}.mdi-chevron-down-circle-outline::before{content:"\FB0C"}.mdi-chevron-left::before{content:"\F141"}.mdi-chevron-left-box::before{content:"\F9D7"}.mdi-chevron-left-box-outline::before{content:"\F9D8"}.mdi-chevron-left-circle::before{content:"\FB0D"}.mdi-chevron-left-circle-outline::before{content:"\FB0E"}.mdi-chevron-right::before{content:"\F142"}.mdi-chevron-right-box::before{content:"\F9D9"}.mdi-chevron-right-box-outline::before{content:"\F9DA"}.mdi-chevron-right-circle::before{content:"\FB0F"}.mdi-chevron-right-circle-outline::before{content:"\FB10"}.mdi-chevron-triple-down::before{content:"\FD95"}.mdi-chevron-triple-left::before{content:"\FD96"}.mdi-chevron-triple-right::before{content:"\FD97"}.mdi-chevron-triple-up::before{content:"\FD98"}.mdi-chevron-up::before{content:"\F143"}.mdi-chevron-up-box::before{content:"\F9DB"}.mdi-chevron-up-box-outline::before{content:"\F9DC"}.mdi-chevron-up-circle::before{content:"\FB11"}.mdi-chevron-up-circle-outline::before{content:"\FB12"}.mdi-chili-hot::before{content:"\F7B1"}.mdi-chili-medium::before{content:"\F7B2"}.mdi-chili-mild::before{content:"\F7B3"}.mdi-chip::before{content:"\F61A"}.mdi-christianity::before{content:"\F952"}.mdi-christianity-outline::before{content:"\FCD2"}.mdi-church::before{content:"\F144"}.mdi-circle::before{content:"\F764"}.mdi-circle-double::before{content:"\FEB2"}.mdi-circle-edit-outline::before{content:"\F8D4"}.mdi-circle-expand::before{content:"\FEB3"}.mdi-circle-medium::before{content:"\F9DD"}.mdi-circle-outline::before{content:"\F765"}.mdi-circle-slice-1::before{content:"\FA9D"}.mdi-circle-slice-2::before{content:"\FA9E"}.mdi-circle-slice-3::before{content:"\FA9F"}.mdi-circle-slice-4::before{content:"\FAA0"}.mdi-circle-slice-5::before{content:"\FAA1"}.mdi-circle-slice-6::before{content:"\FAA2"}.mdi-circle-slice-7::before{content:"\FAA3"}.mdi-circle-slice-8::before{content:"\FAA4"}.mdi-circle-small::before{content:"\F9DE"}.mdi-circular-saw::before{content:"\FE73"}.mdi-cisco-webex::before{content:"\F145"}.mdi-city::before{content:"\F146"}.mdi-city-variant::before{content:"\FA35"}.mdi-city-variant-outline::before{content:"\FA36"}.mdi-clipboard::before{content:"\F147"}.mdi-clipboard-account::before{content:"\F148"}.mdi-clipboard-account-outline::before{content:"\FC31"}.mdi-clipboard-alert::before{content:"\F149"}.mdi-clipboard-alert-outline::before{content:"\FCD3"}.mdi-clipboard-arrow-down::before{content:"\F14A"}.mdi-clipboard-arrow-down-outline::before{content:"\FC32"}.mdi-clipboard-arrow-left::before{content:"\F14B"}.mdi-clipboard-arrow-left-outline::before{content:"\FCD4"}.mdi-clipboard-arrow-right::before{content:"\FCD5"}.mdi-clipboard-arrow-right-outline::before{content:"\FCD6"}.mdi-clipboard-arrow-up::before{content:"\FC33"}.mdi-clipboard-arrow-up-outline::before{content:"\FC34"}.mdi-clipboard-check::before{content:"\F14C"}.mdi-clipboard-check-outline::before{content:"\F8A7"}.mdi-clipboard-flow::before{content:"\F6C7"}.mdi-clipboard-outline::before{content:"\F14D"}.mdi-clipboard-play::before{content:"\FC35"}.mdi-clipboard-play-outline::before{content:"\FC36"}.mdi-clipboard-plus::before{content:"\F750"}.mdi-clipboard-pulse::before{content:"\F85C"}.mdi-clipboard-pulse-outline::before{content:"\F85D"}.mdi-clipboard-text::before{content:"\F14E"}.mdi-clipboard-text-outline::before{content:"\FA37"}.mdi-clipboard-text-play::before{content:"\FC37"}.mdi-clipboard-text-play-outline::before{content:"\FC38"}.mdi-clippy::before{content:"\F14F"}.mdi-clock::before{content:"\F953"}.mdi-clock-alert::before{content:"\F954"}.mdi-clock-alert-outline::before{content:"\F5CE"}.mdi-clock-digital::before{content:"\FEB4"}.mdi-clock-end::before{content:"\F151"}.mdi-clock-fast::before{content:"\F152"}.mdi-clock-in::before{content:"\F153"}.mdi-clock-out::before{content:"\F154"}.mdi-clock-outline::before{content:"\F150"}.mdi-clock-start::before{content:"\F155"}.mdi-close::before{content:"\F156"}.mdi-close-box::before{content:"\F157"}.mdi-close-box-multiple::before{content:"\FC39"}.mdi-close-box-multiple-outline::before{content:"\FC3A"}.mdi-close-box-outline::before{content:"\F158"}.mdi-close-circle::before{content:"\F159"}.mdi-close-circle-outline::before{content:"\F15A"}.mdi-close-network::before{content:"\F15B"}.mdi-close-network-outline::before{content:"\FC3B"}.mdi-close-octagon::before{content:"\F15C"}.mdi-close-octagon-outline::before{content:"\F15D"}.mdi-close-outline::before{content:"\F6C8"}.mdi-closed-caption::before{content:"\F15E"}.mdi-closed-caption-outline::before{content:"\FD99"}.mdi-cloud::before{content:"\F15F"}.mdi-cloud-alert::before{content:"\F9DF"}.mdi-cloud-braces::before{content:"\F7B4"}.mdi-cloud-check::before{content:"\F160"}.mdi-cloud-circle::before{content:"\F161"}.mdi-cloud-download::before{content:"\F162"}.mdi-cloud-download-outline::before{content:"\FB59"}.mdi-cloud-off-outline::before{content:"\F164"}.mdi-cloud-outline::before{content:"\F163"}.mdi-cloud-print::before{content:"\F165"}.mdi-cloud-print-outline::before{content:"\F166"}.mdi-cloud-question::before{content:"\FA38"}.mdi-cloud-search::before{content:"\F955"}.mdi-cloud-search-outline::before{content:"\F956"}.mdi-cloud-sync::before{content:"\F63F"}.mdi-cloud-tags::before{content:"\F7B5"}.mdi-cloud-upload::before{content:"\F167"}.mdi-cloud-upload-outline::before{content:"\FB5A"}.mdi-clover::before{content:"\F815"}.mdi-code-array::before{content:"\F168"}.mdi-code-braces::before{content:"\F169"}.mdi-code-brackets::before{content:"\F16A"}.mdi-code-equal::before{content:"\F16B"}.mdi-code-greater-than::before{content:"\F16C"}.mdi-code-greater-than-or-equal::before{content:"\F16D"}.mdi-code-less-than::before{content:"\F16E"}.mdi-code-less-than-or-equal::before{content:"\F16F"}.mdi-code-not-equal::before{content:"\F170"}.mdi-code-not-equal-variant::before{content:"\F171"}.mdi-code-parentheses::before{content:"\F172"}.mdi-code-string::before{content:"\F173"}.mdi-code-tags::before{content:"\F174"}.mdi-code-tags-check::before{content:"\F693"}.mdi-codepen::before{content:"\F175"}.mdi-coffee::before{content:"\F176"}.mdi-coffee-off::before{content:"\FFCA"}.mdi-coffee-off-outline::before{content:"\FFCB"}.mdi-coffee-outline::before{content:"\F6C9"}.mdi-coffee-to-go::before{content:"\F177"}.mdi-coffin::before{content:"\FB5B"}.mdi-cogs::before{content:"\F8D5"}.mdi-coin::before{content:"\F178"}.mdi-coins::before{content:"\F694"}.mdi-collage::before{content:"\F640"}.mdi-collapse-all::before{content:"\FAA5"}.mdi-collapse-all-outline::before{content:"\FAA6"}.mdi-color-helper::before{content:"\F179"}.mdi-comma::before{content:"\FE74"}.mdi-comma-box::before{content:"\FE75"}.mdi-comma-box-outline::before{content:"\FE76"}.mdi-comma-circle::before{content:"\FE77"}.mdi-comma-circle-outline::before{content:"\FE78"}.mdi-comment::before{content:"\F17A"}.mdi-comment-account::before{content:"\F17B"}.mdi-comment-account-outline::before{content:"\F17C"}.mdi-comment-alert::before{content:"\F17D"}.mdi-comment-alert-outline::before{content:"\F17E"}.mdi-comment-arrow-left::before{content:"\F9E0"}.mdi-comment-arrow-left-outline::before{content:"\F9E1"}.mdi-comment-arrow-right::before{content:"\F9E2"}.mdi-comment-arrow-right-outline::before{content:"\F9E3"}.mdi-comment-check::before{content:"\F17F"}.mdi-comment-check-outline::before{content:"\F180"}.mdi-comment-eye::before{content:"\FA39"}.mdi-comment-eye-outline::before{content:"\FA3A"}.mdi-comment-multiple::before{content:"\F85E"}.mdi-comment-multiple-outline::before{content:"\F181"}.mdi-comment-outline::before{content:"\F182"}.mdi-comment-plus::before{content:"\F9E4"}.mdi-comment-plus-outline::before{content:"\F183"}.mdi-comment-processing::before{content:"\F184"}.mdi-comment-processing-outline::before{content:"\F185"}.mdi-comment-question::before{content:"\F816"}.mdi-comment-question-outline::before{content:"\F186"}.mdi-comment-remove::before{content:"\F5DE"}.mdi-comment-remove-outline::before{content:"\F187"}.mdi-comment-search::before{content:"\FA3B"}.mdi-comment-search-outline::before{content:"\FA3C"}.mdi-comment-text::before{content:"\F188"}.mdi-comment-text-multiple::before{content:"\F85F"}.mdi-comment-text-multiple-outline::before{content:"\F860"}.mdi-comment-text-outline::before{content:"\F189"}.mdi-compare::before{content:"\F18A"}.mdi-compass::before{content:"\F18B"}.mdi-compass-off::before{content:"\FB5C"}.mdi-compass-off-outline::before{content:"\FB5D"}.mdi-compass-outline::before{content:"\F18C"}.mdi-console::before{content:"\F18D"}.mdi-console-line::before{content:"\F7B6"}.mdi-console-network::before{content:"\F8A8"}.mdi-console-network-outline::before{content:"\FC3C"}.mdi-contact-mail::before{content:"\F18E"}.mdi-contact-mail-outline::before{content:"\FEB5"}.mdi-contact-phone::before{content:"\FEB6"}.mdi-contact-phone-outline::before{content:"\FEB7"}.mdi-contactless-payment::before{content:"\FD46"}.mdi-contacts::before{content:"\F6CA"}.mdi-contain::before{content:"\FA3D"}.mdi-contain-end::before{content:"\FA3E"}.mdi-contain-start::before{content:"\FA3F"}.mdi-content-copy::before{content:"\F18F"}.mdi-content-cut::before{content:"\F190"}.mdi-content-duplicate::before{content:"\F191"}.mdi-content-paste::before{content:"\F192"}.mdi-content-save::before{content:"\F193"}.mdi-content-save-alert::before{content:"\FF5F"}.mdi-content-save-alert-outline::before{content:"\FF60"}.mdi-content-save-all::before{content:"\F194"}.mdi-content-save-all-outline::before{content:"\FF61"}.mdi-content-save-edit::before{content:"\FCD7"}.mdi-content-save-edit-outline::before{content:"\FCD8"}.mdi-content-save-move::before{content:"\FE79"}.mdi-content-save-move-outline::before{content:"\FE7A"}.mdi-content-save-outline::before{content:"\F817"}.mdi-content-save-settings::before{content:"\F61B"}.mdi-content-save-settings-outline::before{content:"\FB13"}.mdi-contrast::before{content:"\F195"}.mdi-contrast-box::before{content:"\F196"}.mdi-contrast-circle::before{content:"\F197"}.mdi-controller-classic::before{content:"\FB5E"}.mdi-controller-classic-outline::before{content:"\FB5F"}.mdi-cookie::before{content:"\F198"}.mdi-copyright::before{content:"\F5E6"}.mdi-cordova::before{content:"\F957"}.mdi-corn::before{content:"\F7B7"}.mdi-counter::before{content:"\F199"}.mdi-cow::before{content:"\F19A"}.mdi-cowboy::before{content:"\FEB8"}.mdi-cpu-32-bit::before{content:"\FEFC"}.mdi-cpu-64-bit::before{content:"\FEFD"}.mdi-crane::before{content:"\F861"}.mdi-creation::before{content:"\F1C9"}.mdi-creative-commons::before{content:"\FD47"}.mdi-credit-card::before{content:"\F19B"}.mdi-credit-card-clock::before{content:"\FEFE"}.mdi-credit-card-clock-outline::before{content:"\FFBC"}.mdi-credit-card-marker::before{content:"\FD9A"}.mdi-credit-card-multiple::before{content:"\F19C"}.mdi-credit-card-off::before{content:"\F5E4"}.mdi-credit-card-plus::before{content:"\F675"}.mdi-credit-card-refund::before{content:"\FAA7"}.mdi-credit-card-scan::before{content:"\F19D"}.mdi-credit-card-settings::before{content:"\F8D6"}.mdi-credit-card-wireless::before{content:"\FD48"}.mdi-cricket::before{content:"\FD49"}.mdi-crop::before{content:"\F19E"}.mdi-crop-free::before{content:"\F19F"}.mdi-crop-landscape::before{content:"\F1A0"}.mdi-crop-portrait::before{content:"\F1A1"}.mdi-crop-rotate::before{content:"\F695"}.mdi-crop-square::before{content:"\F1A2"}.mdi-crosshairs::before{content:"\F1A3"}.mdi-crosshairs-gps::before{content:"\F1A4"}.mdi-crosshairs-off::before{content:"\FF62"}.mdi-crown::before{content:"\F1A5"}.mdi-cryengine::before{content:"\F958"}.mdi-crystal-ball::before{content:"\FB14"}.mdi-cube::before{content:"\F1A6"}.mdi-cube-outline::before{content:"\F1A7"}.mdi-cube-scan::before{content:"\FB60"}.mdi-cube-send::before{content:"\F1A8"}.mdi-cube-unfolded::before{content:"\F1A9"}.mdi-cup::before{content:"\F1AA"}.mdi-cup-off::before{content:"\F5E5"}.mdi-cup-water::before{content:"\F1AB"}.mdi-cupboard::before{content:"\FF63"}.mdi-cupboard-outline::before{content:"\FF64"}.mdi-cupcake::before{content:"\F959"}.mdi-curling::before{content:"\F862"}.mdi-currency-bdt::before{content:"\F863"}.mdi-currency-brl::before{content:"\FB61"}.mdi-currency-btc::before{content:"\F1AC"}.mdi-currency-chf::before{content:"\F7B8"}.mdi-currency-cny::before{content:"\F7B9"}.mdi-currency-eth::before{content:"\F7BA"}.mdi-currency-eur::before{content:"\F1AD"}.mdi-currency-gbp::before{content:"\F1AE"}.mdi-currency-ils::before{content:"\FC3D"}.mdi-currency-inr::before{content:"\F1AF"}.mdi-currency-jpy::before{content:"\F7BB"}.mdi-currency-krw::before{content:"\F7BC"}.mdi-currency-kzt::before{content:"\F864"}.mdi-currency-ngn::before{content:"\F1B0"}.mdi-currency-php::before{content:"\F9E5"}.mdi-currency-rial::before{content:"\FEB9"}.mdi-currency-rub::before{content:"\F1B1"}.mdi-currency-sign::before{content:"\F7BD"}.mdi-currency-try::before{content:"\F1B2"}.mdi-currency-twd::before{content:"\F7BE"}.mdi-currency-usd::before{content:"\F1B3"}.mdi-currency-usd-off::before{content:"\F679"}.mdi-current-ac::before{content:"\F95A"}.mdi-current-dc::before{content:"\F95B"}.mdi-cursor-default::before{content:"\F1B4"}.mdi-cursor-default-click::before{content:"\FCD9"}.mdi-cursor-default-click-outline::before{content:"\FCDA"}.mdi-cursor-default-outline::before{content:"\F1B5"}.mdi-cursor-move::before{content:"\F1B6"}.mdi-cursor-pointer::before{content:"\F1B7"}.mdi-cursor-text::before{content:"\F5E7"}.mdi-database::before{content:"\F1B8"}.mdi-database-check::before{content:"\FAA8"}.mdi-database-edit::before{content:"\FB62"}.mdi-database-export::before{content:"\F95D"}.mdi-database-import::before{content:"\F95C"}.mdi-database-lock::before{content:"\FAA9"}.mdi-database-minus::before{content:"\F1B9"}.mdi-database-plus::before{content:"\F1BA"}.mdi-database-refresh::before{content:"\FCDB"}.mdi-database-remove::before{content:"\FCDC"}.mdi-database-search::before{content:"\F865"}.mdi-database-settings::before{content:"\FCDD"}.mdi-death-star::before{content:"\F8D7"}.mdi-death-star-variant::before{content:"\F8D8"}.mdi-deathly-hallows::before{content:"\FB63"}.mdi-debian::before{content:"\F8D9"}.mdi-debug-step-into::before{content:"\F1BB"}.mdi-debug-step-out::before{content:"\F1BC"}.mdi-debug-step-over::before{content:"\F1BD"}.mdi-decagram::before{content:"\F76B"}.mdi-decagram-outline::before{content:"\F76C"}.mdi-decimal-decrease::before{content:"\F1BE"}.mdi-decimal-increase::before{content:"\F1BF"}.mdi-delete::before{content:"\F1C0"}.mdi-delete-circle::before{content:"\F682"}.mdi-delete-circle-outline::before{content:"\FB64"}.mdi-delete-empty::before{content:"\F6CB"}.mdi-delete-empty-outline::before{content:"\FEBA"}.mdi-delete-forever::before{content:"\F5E8"}.mdi-delete-forever-outline::before{content:"\FB65"}.mdi-delete-outline::before{content:"\F9E6"}.mdi-delete-restore::before{content:"\F818"}.mdi-delete-sweep::before{content:"\F5E9"}.mdi-delete-sweep-outline::before{content:"\FC3E"}.mdi-delete-variant::before{content:"\F1C1"}.mdi-delta::before{content:"\F1C2"}.mdi-desk-lamp::before{content:"\F95E"}.mdi-deskphone::before{content:"\F1C3"}.mdi-desktop-classic::before{content:"\F7BF"}.mdi-desktop-mac::before{content:"\F1C4"}.mdi-desktop-mac-dashboard::before{content:"\F9E7"}.mdi-desktop-tower::before{content:"\F1C5"}.mdi-desktop-tower-monitor::before{content:"\FAAA"}.mdi-details::before{content:"\F1C6"}.mdi-dev-to::before{content:"\FD4A"}.mdi-developer-board::before{content:"\F696"}.mdi-deviantart::before{content:"\F1C7"}.mdi-dialpad::before{content:"\F61C"}.mdi-diameter::before{content:"\FC3F"}.mdi-diameter-outline::before{content:"\FC40"}.mdi-diameter-variant::before{content:"\FC41"}.mdi-diamond::before{content:"\FB66"}.mdi-diamond-outline::before{content:"\FB67"}.mdi-diamond-stone::before{content:"\F1C8"}.mdi-dice-1::before{content:"\F1CA"}.mdi-dice-2::before{content:"\F1CB"}.mdi-dice-3::before{content:"\F1CC"}.mdi-dice-4::before{content:"\F1CD"}.mdi-dice-5::before{content:"\F1CE"}.mdi-dice-6::before{content:"\F1CF"}.mdi-dice-d10::before{content:"\F76E"}.mdi-dice-d12::before{content:"\F866"}.mdi-dice-d20::before{content:"\F5EA"}.mdi-dice-d4::before{content:"\F5EB"}.mdi-dice-d6::before{content:"\F5EC"}.mdi-dice-d8::before{content:"\F5ED"}.mdi-dice-multiple::before{content:"\F76D"}.mdi-dictionary::before{content:"\F61D"}.mdi-dip-switch::before{content:"\F7C0"}.mdi-directions::before{content:"\F1D0"}.mdi-directions-fork::before{content:"\F641"}.mdi-disc::before{content:"\F5EE"}.mdi-disc-alert::before{content:"\F1D1"}.mdi-disc-player::before{content:"\F95F"}.mdi-discord::before{content:"\F66F"}.mdi-dishwasher::before{content:"\FAAB"}.mdi-disqus::before{content:"\F1D2"}.mdi-disqus-outline::before{content:"\F1D3"}.mdi-diving-flippers::before{content:"\FD9B"}.mdi-diving-helmet::before{content:"\FD9C"}.mdi-diving-scuba::before{content:"\FD9D"}.mdi-diving-scuba-flag::before{content:"\FD9E"}.mdi-diving-scuba-tank::before{content:"\FD9F"}.mdi-diving-scuba-tank-multiple::before{content:"\FDA0"}.mdi-diving-snorkel::before{content:"\FDA1"}.mdi-division::before{content:"\F1D4"}.mdi-division-box::before{content:"\F1D5"}.mdi-dlna::before{content:"\FA40"}.mdi-dna::before{content:"\F683"}.mdi-dns::before{content:"\F1D6"}.mdi-dns-outline::before{content:"\FB68"}.mdi-do-not-disturb::before{content:"\F697"}.mdi-do-not-disturb-off::before{content:"\F698"}.mdi-docker::before{content:"\F867"}.mdi-doctor::before{content:"\FA41"}.mdi-dog::before{content:"\FA42"}.mdi-dog-service::before{content:"\FAAC"}.mdi-dog-side::before{content:"\FA43"}.mdi-dolby::before{content:"\F6B2"}.mdi-dolly::before{content:"\FEBB"}.mdi-domain::before{content:"\F1D7"}.mdi-domain-off::before{content:"\FD4B"}.mdi-donkey::before{content:"\F7C1"}.mdi-door::before{content:"\F819"}.mdi-door-closed::before{content:"\F81A"}.mdi-door-open::before{content:"\F81B"}.mdi-doorbell-video::before{content:"\F868"}.mdi-dot-net::before{content:"\FAAD"}.mdi-dots-horizontal::before{content:"\F1D8"}.mdi-dots-horizontal-circle::before{content:"\F7C2"}.mdi-dots-horizontal-circle-outline::before{content:"\FB69"}.mdi-dots-vertical::before{content:"\F1D9"}.mdi-dots-vertical-circle::before{content:"\F7C3"}.mdi-dots-vertical-circle-outline::before{content:"\FB6A"}.mdi-douban::before{content:"\F699"}.mdi-download::before{content:"\F1DA"}.mdi-download-multiple::before{content:"\F9E8"}.mdi-download-network::before{content:"\F6F3"}.mdi-download-network-outline::before{content:"\FC42"}.mdi-download-outline::before{content:"\FB6B"}.mdi-drag::before{content:"\F1DB"}.mdi-drag-horizontal::before{content:"\F1DC"}.mdi-drag-variant::before{content:"\FB6C"}.mdi-drag-vertical::before{content:"\F1DD"}.mdi-drama-masks::before{content:"\FCDE"}.mdi-draw::before{content:"\FF66"}.mdi-drawing::before{content:"\F1DE"}.mdi-drawing-box::before{content:"\F1DF"}.mdi-dresser::before{content:"\FF67"}.mdi-dresser-outline::before{content:"\FF68"}.mdi-dribbble::before{content:"\F1E0"}.mdi-dribbble-box::before{content:"\F1E1"}.mdi-drone::before{content:"\F1E2"}.mdi-dropbox::before{content:"\F1E3"}.mdi-drupal::before{content:"\F1E4"}.mdi-duck::before{content:"\F1E5"}.mdi-dumbbell::before{content:"\F1E6"}.mdi-dump-truck::before{content:"\FC43"}.mdi-ear-hearing::before{content:"\F7C4"}.mdi-ear-hearing-off::before{content:"\FA44"}.mdi-earth::before{content:"\F1E7"}.mdi-earth-box::before{content:"\F6CC"}.mdi-earth-box-off::before{content:"\F6CD"}.mdi-earth-off::before{content:"\F1E8"}.mdi-edge::before{content:"\F1E9"}.mdi-egg::before{content:"\FAAE"}.mdi-egg-easter::before{content:"\FAAF"}.mdi-eight-track::before{content:"\F9E9"}.mdi-eject::before{content:"\F1EA"}.mdi-eject-outline::before{content:"\FB6D"}.mdi-electric-switch::before{content:"\FEBC"}.mdi-elephant::before{content:"\F7C5"}.mdi-elevation-decline::before{content:"\F1EB"}.mdi-elevation-rise::before{content:"\F1EC"}.mdi-elevator::before{content:"\F1ED"}.mdi-ellipse::before{content:"\FEBD"}.mdi-ellipse-outline::before{content:"\FEBE"}.mdi-email::before{content:"\F1EE"}.mdi-email-alert::before{content:"\F6CE"}.mdi-email-box::before{content:"\FCDF"}.mdi-email-check::before{content:"\FAB0"}.mdi-email-check-outline::before{content:"\FAB1"}.mdi-email-edit::before{content:"\FF00"}.mdi-email-edit-outline::before{content:"\FF01"}.mdi-email-lock::before{content:"\F1F1"}.mdi-email-mark-as-unread::before{content:"\FB6E"}.mdi-email-minus::before{content:"\FF02"}.mdi-email-minus-outline::before{content:"\FF03"}.mdi-email-multiple::before{content:"\FF04"}.mdi-email-multiple-outline::before{content:"\FF05"}.mdi-email-open::before{content:"\F1EF"}.mdi-email-open-multiple::before{content:"\FF06"}.mdi-email-open-multiple-outline::before{content:"\FF07"}.mdi-email-open-outline::before{content:"\F5EF"}.mdi-email-outline::before{content:"\F1F0"}.mdi-email-plus::before{content:"\F9EA"}.mdi-email-plus-outline::before{content:"\F9EB"}.mdi-email-search::before{content:"\F960"}.mdi-email-search-outline::before{content:"\F961"}.mdi-email-variant::before{content:"\F5F0"}.mdi-ember::before{content:"\FB15"}.mdi-emby::before{content:"\F6B3"}.mdi-emoticon::before{content:"\FC44"}.mdi-emoticon-angry::before{content:"\FC45"}.mdi-emoticon-angry-outline::before{content:"\FC46"}.mdi-emoticon-cool::before{content:"\FC47"}.mdi-emoticon-cool-outline::before{content:"\F1F3"}.mdi-emoticon-cry::before{content:"\FC48"}.mdi-emoticon-cry-outline::before{content:"\FC49"}.mdi-emoticon-dead::before{content:"\FC4A"}.mdi-emoticon-dead-outline::before{content:"\F69A"}.mdi-emoticon-devil::before{content:"\FC4B"}.mdi-emoticon-devil-outline::before{content:"\F1F4"}.mdi-emoticon-excited::before{content:"\FC4C"}.mdi-emoticon-excited-outline::before{content:"\F69B"}.mdi-emoticon-frown::before{content:"\FF69"}.mdi-emoticon-frown-outline::before{content:"\FF6A"}.mdi-emoticon-happy::before{content:"\FC4D"}.mdi-emoticon-happy-outline::before{content:"\F1F5"}.mdi-emoticon-kiss::before{content:"\FC4E"}.mdi-emoticon-kiss-outline::before{content:"\FC4F"}.mdi-emoticon-neutral::before{content:"\FC50"}.mdi-emoticon-neutral-outline::before{content:"\F1F6"}.mdi-emoticon-outline::before{content:"\F1F2"}.mdi-emoticon-poop::before{content:"\F1F7"}.mdi-emoticon-poop-outline::before{content:"\FC51"}.mdi-emoticon-sad::before{content:"\FC52"}.mdi-emoticon-sad-outline::before{content:"\F1F8"}.mdi-emoticon-tongue::before{content:"\F1F9"}.mdi-emoticon-tongue-outline::before{content:"\FC53"}.mdi-emoticon-wink::before{content:"\FC54"}.mdi-emoticon-wink-outline::before{content:"\FC55"}.mdi-engine::before{content:"\F1FA"}.mdi-engine-off::before{content:"\FA45"}.mdi-engine-off-outline::before{content:"\FA46"}.mdi-engine-outline::before{content:"\F1FB"}.mdi-equal::before{content:"\F1FC"}.mdi-equal-box::before{content:"\F1FD"}.mdi-equalizer::before{content:"\FEBF"}.mdi-equalizer-outline::before{content:"\FEC0"}.mdi-eraser::before{content:"\F1FE"}.mdi-eraser-variant::before{content:"\F642"}.mdi-escalator::before{content:"\F1FF"}.mdi-eslint::before{content:"\FC56"}.mdi-et::before{content:"\FAB2"}.mdi-ethereum::before{content:"\F869"}.mdi-ethernet::before{content:"\F200"}.mdi-ethernet-cable::before{content:"\F201"}.mdi-ethernet-cable-off::before{content:"\F202"}.mdi-etsy::before{content:"\F203"}.mdi-ev-station::before{content:"\F5F1"}.mdi-eventbrite::before{content:"\F7C6"}.mdi-evernote::before{content:"\F204"}.mdi-exclamation::before{content:"\F205"}.mdi-exit-run::before{content:"\FA47"}.mdi-exit-to-app::before{content:"\F206"}.mdi-expand-all::before{content:"\FAB3"}.mdi-expand-all-outline::before{content:"\FAB4"}.mdi-exponent::before{content:"\F962"}.mdi-exponent-box::before{content:"\F963"}.mdi-export::before{content:"\F207"}.mdi-export-variant::before{content:"\FB6F"}.mdi-eye::before{content:"\F208"}.mdi-eye-check::before{content:"\FCE0"}.mdi-eye-check-outline::before{content:"\FCE1"}.mdi-eye-circle::before{content:"\FB70"}.mdi-eye-circle-outline::before{content:"\FB71"}.mdi-eye-off::before{content:"\F209"}.mdi-eye-off-outline::before{content:"\F6D0"}.mdi-eye-outline::before{content:"\F6CF"}.mdi-eye-plus::before{content:"\F86A"}.mdi-eye-plus-outline::before{content:"\F86B"}.mdi-eye-settings::before{content:"\F86C"}.mdi-eye-settings-outline::before{content:"\F86D"}.mdi-eyedropper::before{content:"\F20A"}.mdi-eyedropper-variant::before{content:"\F20B"}.mdi-face::before{content:"\F643"}.mdi-face-agent::before{content:"\FD4C"}.mdi-face-outline::before{content:"\FB72"}.mdi-face-profile::before{content:"\F644"}.mdi-face-recognition::before{content:"\FC57"}.mdi-facebook::before{content:"\F20C"}.mdi-facebook-box::before{content:"\F20D"}.mdi-facebook-messenger::before{content:"\F20E"}.mdi-facebook-workplace::before{content:"\FB16"}.mdi-factory::before{content:"\F20F"}.mdi-fan::before{content:"\F210"}.mdi-fan-off::before{content:"\F81C"}.mdi-fast-forward::before{content:"\F211"}.mdi-fast-forward-10::before{content:"\FD4D"}.mdi-fast-forward-30::before{content:"\FCE2"}.mdi-fast-forward-outline::before{content:"\F6D1"}.mdi-fax::before{content:"\F212"}.mdi-feather::before{content:"\F6D2"}.mdi-feature-search::before{content:"\FA48"}.mdi-feature-search-outline::before{content:"\FA49"}.mdi-fedora::before{content:"\F8DA"}.mdi-ferris-wheel::before{content:"\FEC1"}.mdi-ferry::before{content:"\F213"}.mdi-file::before{content:"\F214"}.mdi-file-account::before{content:"\F73A"}.mdi-file-alert::before{content:"\FA4A"}.mdi-file-alert-outline::before{content:"\FA4B"}.mdi-file-cabinet::before{content:"\FAB5"}.mdi-file-cad::before{content:"\FF08"}.mdi-file-cad-box::before{content:"\FF09"}.mdi-file-cancel::before{content:"\FDA2"}.mdi-file-cancel-outline::before{content:"\FDA3"}.mdi-file-chart::before{content:"\F215"}.mdi-file-check::before{content:"\F216"}.mdi-file-check-outline::before{content:"\FE7B"}.mdi-file-cloud::before{content:"\F217"}.mdi-file-compare::before{content:"\F8A9"}.mdi-file-delimited::before{content:"\F218"}.mdi-file-delimited-outline::before{content:"\FEC2"}.mdi-file-document::before{content:"\F219"}.mdi-file-document-box::before{content:"\F21A"}.mdi-file-document-box-check::before{content:"\FEC3"}.mdi-file-document-box-check-outline::before{content:"\FEC4"}.mdi-file-document-box-minus::before{content:"\FEC5"}.mdi-file-document-box-minus-outline::before{content:"\FEC6"}.mdi-file-document-box-multiple::before{content:"\FAB6"}.mdi-file-document-box-multiple-outline::before{content:"\FAB7"}.mdi-file-document-box-outline::before{content:"\F9EC"}.mdi-file-document-box-plus::before{content:"\FEC7"}.mdi-file-document-box-plus-outline::before{content:"\FEC8"}.mdi-file-document-box-remove::before{content:"\FEC9"}.mdi-file-document-box-remove-outline::before{content:"\FECA"}.mdi-file-document-box-search::before{content:"\FECB"}.mdi-file-document-box-search-outline::before{content:"\FECC"}.mdi-file-document-edit::before{content:"\FDA4"}.mdi-file-document-edit-outline::before{content:"\FDA5"}.mdi-file-document-outline::before{content:"\F9ED"}.mdi-file-download::before{content:"\F964"}.mdi-file-download-outline::before{content:"\F965"}.mdi-file-excel::before{content:"\F21B"}.mdi-file-excel-box::before{content:"\F21C"}.mdi-file-export::before{content:"\F21D"}.mdi-file-eye::before{content:"\FDA6"}.mdi-file-eye-outline::before{content:"\FDA7"}.mdi-file-find::before{content:"\F21E"}.mdi-file-find-outline::before{content:"\FB73"}.mdi-file-hidden::before{content:"\F613"}.mdi-file-image::before{content:"\F21F"}.mdi-file-image-outline::before{content:"\FECD"}.mdi-file-import::before{content:"\F220"}.mdi-file-lock::before{content:"\F221"}.mdi-file-move::before{content:"\FAB8"}.mdi-file-multiple::before{content:"\F222"}.mdi-file-music::before{content:"\F223"}.mdi-file-music-outline::before{content:"\FE7C"}.mdi-file-outline::before{content:"\F224"}.mdi-file-pdf::before{content:"\F225"}.mdi-file-pdf-box::before{content:"\F226"}.mdi-file-pdf-outline::before{content:"\FE7D"}.mdi-file-percent::before{content:"\F81D"}.mdi-file-plus::before{content:"\F751"}.mdi-file-plus-outline::before{content:"\FF0A"}.mdi-file-powerpoint::before{content:"\F227"}.mdi-file-powerpoint-box::before{content:"\F228"}.mdi-file-presentation-box::before{content:"\F229"}.mdi-file-question::before{content:"\F86E"}.mdi-file-remove::before{content:"\FB74"}.mdi-file-replace::before{content:"\FB17"}.mdi-file-replace-outline::before{content:"\FB18"}.mdi-file-restore::before{content:"\F670"}.mdi-file-search::before{content:"\FC58"}.mdi-file-search-outline::before{content:"\FC59"}.mdi-file-send::before{content:"\F22A"}.mdi-file-table::before{content:"\FC5A"}.mdi-file-table-outline::before{content:"\FC5B"}.mdi-file-tree::before{content:"\F645"}.mdi-file-undo::before{content:"\F8DB"}.mdi-file-upload::before{content:"\FA4C"}.mdi-file-upload-outline::before{content:"\FA4D"}.mdi-file-video::before{content:"\F22B"}.mdi-file-video-outline::before{content:"\FE10"}.mdi-file-word::before{content:"\F22C"}.mdi-file-word-box::before{content:"\F22D"}.mdi-file-xml::before{content:"\F22E"}.mdi-film::before{content:"\F22F"}.mdi-filmstrip::before{content:"\F230"}.mdi-filmstrip-off::before{content:"\F231"}.mdi-filter::before{content:"\F232"}.mdi-filter-minus::before{content:"\FF0B"}.mdi-filter-minus-outline::before{content:"\FF0C"}.mdi-filter-outline::before{content:"\F233"}.mdi-filter-plus::before{content:"\FF0D"}.mdi-filter-plus-outline::before{content:"\FF0E"}.mdi-filter-remove::before{content:"\F234"}.mdi-filter-remove-outline::before{content:"\F235"}.mdi-filter-variant::before{content:"\F236"}.mdi-finance::before{content:"\F81E"}.mdi-find-replace::before{content:"\F6D3"}.mdi-fingerprint::before{content:"\F237"}.mdi-fingerprint-off::before{content:"\FECE"}.mdi-fire::before{content:"\F238"}.mdi-fire-extinguisher::before{content:"\FF0F"}.mdi-fire-truck::before{content:"\F8AA"}.mdi-firebase::before{content:"\F966"}.mdi-firefox::before{content:"\F239"}.mdi-fireplace::before{content:"\FE11"}.mdi-fireplace-off::before{content:"\FE12"}.mdi-firework::before{content:"\FE13"}.mdi-fish::before{content:"\F23A"}.mdi-fishbowl::before{content:"\FF10"}.mdi-fishbowl-outline::before{content:"\FF11"}.mdi-fit-to-page::before{content:"\FF12"}.mdi-fit-to-page-outline::before{content:"\FF13"}.mdi-flag::before{content:"\F23B"}.mdi-flag-checkered::before{content:"\F23C"}.mdi-flag-minus::before{content:"\FB75"}.mdi-flag-outline::before{content:"\F23D"}.mdi-flag-plus::before{content:"\FB76"}.mdi-flag-remove::before{content:"\FB77"}.mdi-flag-triangle::before{content:"\F23F"}.mdi-flag-variant::before{content:"\F240"}.mdi-flag-variant-outline::before{content:"\F23E"}.mdi-flare::before{content:"\FD4E"}.mdi-flash::before{content:"\F241"}.mdi-flash-alert::before{content:"\FF14"}.mdi-flash-alert-outline::before{content:"\FF15"}.mdi-flash-auto::before{content:"\F242"}.mdi-flash-circle::before{content:"\F81F"}.mdi-flash-off::before{content:"\F243"}.mdi-flash-outline::before{content:"\F6D4"}.mdi-flash-red-eye::before{content:"\F67A"}.mdi-flashlight::before{content:"\F244"}.mdi-flashlight-off::before{content:"\F245"}.mdi-flask::before{content:"\F093"}.mdi-flask-empty::before{content:"\F094"}.mdi-flask-empty-outline::before{content:"\F095"}.mdi-flask-outline::before{content:"\F096"}.mdi-flattr::before{content:"\F246"}.mdi-flickr::before{content:"\FCE3"}.mdi-flip-to-back::before{content:"\F247"}.mdi-flip-to-front::before{content:"\F248"}.mdi-floor-lamp::before{content:"\F8DC"}.mdi-floor-plan::before{content:"\F820"}.mdi-floppy::before{content:"\F249"}.mdi-floppy-variant::before{content:"\F9EE"}.mdi-flower::before{content:"\F24A"}.mdi-flower-outline::before{content:"\F9EF"}.mdi-flower-poppy::before{content:"\FCE4"}.mdi-flower-tulip::before{content:"\F9F0"}.mdi-flower-tulip-outline::before{content:"\F9F1"}.mdi-focus-auto::before{content:"\FF6B"}.mdi-focus-field::before{content:"\FF6C"}.mdi-focus-field-horizontal::before{content:"\FF6D"}.mdi-focus-field-vertical::before{content:"\FF6E"}.mdi-folder::before{content:"\F24B"}.mdi-folder-account::before{content:"\F24C"}.mdi-folder-account-outline::before{content:"\FB78"}.mdi-folder-alert::before{content:"\FDA8"}.mdi-folder-alert-outline::before{content:"\FDA9"}.mdi-folder-clock::before{content:"\FAB9"}.mdi-folder-clock-outline::before{content:"\FABA"}.mdi-folder-download::before{content:"\F24D"}.mdi-folder-edit::before{content:"\F8DD"}.mdi-folder-edit-outline::before{content:"\FDAA"}.mdi-folder-google-drive::before{content:"\F24E"}.mdi-folder-image::before{content:"\F24F"}.mdi-folder-key::before{content:"\F8AB"}.mdi-folder-key-network::before{content:"\F8AC"}.mdi-folder-key-network-outline::before{content:"\FC5C"}.mdi-folder-lock::before{content:"\F250"}.mdi-folder-lock-open::before{content:"\F251"}.mdi-folder-move::before{content:"\F252"}.mdi-folder-multiple::before{content:"\F253"}.mdi-folder-multiple-image::before{content:"\F254"}.mdi-folder-multiple-outline::before{content:"\F255"}.mdi-folder-network::before{content:"\F86F"}.mdi-folder-network-outline::before{content:"\FC5D"}.mdi-folder-open::before{content:"\F76F"}.mdi-folder-open-outline::before{content:"\FDAB"}.mdi-folder-outline::before{content:"\F256"}.mdi-folder-plus::before{content:"\F257"}.mdi-folder-plus-outline::before{content:"\FB79"}.mdi-folder-pound::before{content:"\FCE5"}.mdi-folder-pound-outline::before{content:"\FCE6"}.mdi-folder-remove::before{content:"\F258"}.mdi-folder-remove-outline::before{content:"\FB7A"}.mdi-folder-search::before{content:"\F967"}.mdi-folder-search-outline::before{content:"\F968"}.mdi-folder-star::before{content:"\F69C"}.mdi-folder-star-outline::before{content:"\FB7B"}.mdi-folder-sync::before{content:"\FCE7"}.mdi-folder-sync-outline::before{content:"\FCE8"}.mdi-folder-text::before{content:"\FC5E"}.mdi-folder-text-outline::before{content:"\FC5F"}.mdi-folder-upload::before{content:"\F259"}.mdi-font-awesome::before{content:"\F03A"}.mdi-food::before{content:"\F25A"}.mdi-food-apple::before{content:"\F25B"}.mdi-food-apple-outline::before{content:"\FC60"}.mdi-food-croissant::before{content:"\F7C7"}.mdi-food-fork-drink::before{content:"\F5F2"}.mdi-food-off::before{content:"\F5F3"}.mdi-food-variant::before{content:"\F25C"}.mdi-foot-print::before{content:"\FF6F"}.mdi-football::before{content:"\F25D"}.mdi-football-australian::before{content:"\F25E"}.mdi-football-helmet::before{content:"\F25F"}.mdi-forklift::before{content:"\F7C8"}.mdi-format-align-bottom::before{content:"\F752"}.mdi-format-align-center::before{content:"\F260"}.mdi-format-align-justify::before{content:"\F261"}.mdi-format-align-left::before{content:"\F262"}.mdi-format-align-middle::before{content:"\F753"}.mdi-format-align-right::before{content:"\F263"}.mdi-format-align-top::before{content:"\F754"}.mdi-format-annotation-minus::before{content:"\FABB"}.mdi-format-annotation-plus::before{content:"\F646"}.mdi-format-bold::before{content:"\F264"}.mdi-format-clear::before{content:"\F265"}.mdi-format-color-fill::before{content:"\F266"}.mdi-format-color-highlight::before{content:"\FE14"}.mdi-format-color-text::before{content:"\F69D"}.mdi-format-columns::before{content:"\F8DE"}.mdi-format-float-center::before{content:"\F267"}.mdi-format-float-left::before{content:"\F268"}.mdi-format-float-none::before{content:"\F269"}.mdi-format-float-right::before{content:"\F26A"}.mdi-format-font::before{content:"\F6D5"}.mdi-format-font-size-decrease::before{content:"\F9F2"}.mdi-format-font-size-increase::before{content:"\F9F3"}.mdi-format-header-1::before{content:"\F26B"}.mdi-format-header-2::before{content:"\F26C"}.mdi-format-header-3::before{content:"\F26D"}.mdi-format-header-4::before{content:"\F26E"}.mdi-format-header-5::before{content:"\F26F"}.mdi-format-header-6::before{content:"\F270"}.mdi-format-header-decrease::before{content:"\F271"}.mdi-format-header-equal::before{content:"\F272"}.mdi-format-header-increase::before{content:"\F273"}.mdi-format-header-pound::before{content:"\F274"}.mdi-format-horizontal-align-center::before{content:"\F61E"}.mdi-format-horizontal-align-left::before{content:"\F61F"}.mdi-format-horizontal-align-right::before{content:"\F620"}.mdi-format-indent-decrease::before{content:"\F275"}.mdi-format-indent-increase::before{content:"\F276"}.mdi-format-italic::before{content:"\F277"}.mdi-format-letter-case::before{content:"\FB19"}.mdi-format-letter-case-lower::before{content:"\FB1A"}.mdi-format-letter-case-upper::before{content:"\FB1B"}.mdi-format-line-spacing::before{content:"\F278"}.mdi-format-line-style::before{content:"\F5C8"}.mdi-format-line-weight::before{content:"\F5C9"}.mdi-format-list-bulleted::before{content:"\F279"}.mdi-format-list-bulleted-square::before{content:"\FDAC"}.mdi-format-list-bulleted-type::before{content:"\F27A"}.mdi-format-list-checkbox::before{content:"\F969"}.mdi-format-list-checks::before{content:"\F755"}.mdi-format-list-numbered::before{content:"\F27B"}.mdi-format-list-numbered-rtl::before{content:"\FCE9"}.mdi-format-list-triangle::before{content:"\FECF"}.mdi-format-overline::before{content:"\FED0"}.mdi-format-page-break::before{content:"\F6D6"}.mdi-format-paint::before{content:"\F27C"}.mdi-format-paragraph::before{content:"\F27D"}.mdi-format-pilcrow::before{content:"\F6D7"}.mdi-format-quote-close::before{content:"\F27E"}.mdi-format-quote-open::before{content:"\F756"}.mdi-format-rotate-90::before{content:"\F6A9"}.mdi-format-section::before{content:"\F69E"}.mdi-format-size::before{content:"\F27F"}.mdi-format-strikethrough::before{content:"\F280"}.mdi-format-strikethrough-variant::before{content:"\F281"}.mdi-format-subscript::before{content:"\F282"}.mdi-format-superscript::before{content:"\F283"}.mdi-format-text::before{content:"\F284"}.mdi-format-text-rotation-down::before{content:"\FD4F"}.mdi-format-text-rotation-none::before{content:"\FD50"}.mdi-format-text-variant::before{content:"\FE15"}.mdi-format-text-wrapping-clip::before{content:"\FCEA"}.mdi-format-text-wrapping-overflow::before{content:"\FCEB"}.mdi-format-text-wrapping-wrap::before{content:"\FCEC"}.mdi-format-textbox::before{content:"\FCED"}.mdi-format-textdirection-l-to-r::before{content:"\F285"}.mdi-format-textdirection-r-to-l::before{content:"\F286"}.mdi-format-title::before{content:"\F5F4"}.mdi-format-underline::before{content:"\F287"}.mdi-format-vertical-align-bottom::before{content:"\F621"}.mdi-format-vertical-align-center::before{content:"\F622"}.mdi-format-vertical-align-top::before{content:"\F623"}.mdi-format-wrap-inline::before{content:"\F288"}.mdi-format-wrap-square::before{content:"\F289"}.mdi-format-wrap-tight::before{content:"\F28A"}.mdi-format-wrap-top-bottom::before{content:"\F28B"}.mdi-forum::before{content:"\F28C"}.mdi-forum-outline::before{content:"\F821"}.mdi-forward::before{content:"\F28D"}.mdi-forwardburger::before{content:"\FD51"}.mdi-fountain::before{content:"\F96A"}.mdi-fountain-pen::before{content:"\FCEE"}.mdi-fountain-pen-tip::before{content:"\FCEF"}.mdi-foursquare::before{content:"\F28E"}.mdi-freebsd::before{content:"\F8DF"}.mdi-frequently-asked-questions::before{content:"\FED1"}.mdi-fridge::before{content:"\F290"}.mdi-fridge-bottom::before{content:"\F292"}.mdi-fridge-outline::before{content:"\F28F"}.mdi-fridge-top::before{content:"\F291"}.mdi-fuel::before{content:"\F7C9"}.mdi-fullscreen::before{content:"\F293"}.mdi-fullscreen-exit::before{content:"\F294"}.mdi-function::before{content:"\F295"}.mdi-function-variant::before{content:"\F870"}.mdi-fuse::before{content:"\FC61"}.mdi-fuse-blade::before{content:"\FC62"}.mdi-gamepad::before{content:"\F296"}.mdi-gamepad-circle::before{content:"\FE16"}.mdi-gamepad-circle-down::before{content:"\FE17"}.mdi-gamepad-circle-left::before{content:"\FE18"}.mdi-gamepad-circle-outline::before{content:"\FE19"}.mdi-gamepad-circle-right::before{content:"\FE1A"}.mdi-gamepad-circle-up::before{content:"\FE1B"}.mdi-gamepad-down::before{content:"\FE1C"}.mdi-gamepad-left::before{content:"\FE1D"}.mdi-gamepad-right::before{content:"\FE1E"}.mdi-gamepad-round::before{content:"\FE1F"}.mdi-gamepad-round-down::before{content:"\FE7E"}.mdi-gamepad-round-left::before{content:"\FE7F"}.mdi-gamepad-round-outline::before{content:"\FE80"}.mdi-gamepad-round-right::before{content:"\FE81"}.mdi-gamepad-round-up::before{content:"\FE82"}.mdi-gamepad-square::before{content:"\FED2"}.mdi-gamepad-square-outline::before{content:"\FED3"}.mdi-gamepad-up::before{content:"\FE83"}.mdi-gamepad-variant::before{content:"\F297"}.mdi-gamepad-variant-outline::before{content:"\FED4"}.mdi-gantry-crane::before{content:"\FDAD"}.mdi-garage::before{content:"\F6D8"}.mdi-garage-alert::before{content:"\F871"}.mdi-garage-open::before{content:"\F6D9"}.mdi-gas-cylinder::before{content:"\F647"}.mdi-gas-station::before{content:"\F298"}.mdi-gas-station-outline::before{content:"\FED5"}.mdi-gate::before{content:"\F299"}.mdi-gate-and::before{content:"\F8E0"}.mdi-gate-nand::before{content:"\F8E1"}.mdi-gate-nor::before{content:"\F8E2"}.mdi-gate-not::before{content:"\F8E3"}.mdi-gate-or::before{content:"\F8E4"}.mdi-gate-xnor::before{content:"\F8E5"}.mdi-gate-xor::before{content:"\F8E6"}.mdi-gatsby::before{content:"\FE84"}.mdi-gauge::before{content:"\F29A"}.mdi-gauge-empty::before{content:"\F872"}.mdi-gauge-full::before{content:"\F873"}.mdi-gauge-low::before{content:"\F874"}.mdi-gavel::before{content:"\F29B"}.mdi-gender-female::before{content:"\F29C"}.mdi-gender-male::before{content:"\F29D"}.mdi-gender-male-female::before{content:"\F29E"}.mdi-gender-transgender::before{content:"\F29F"}.mdi-gentoo::before{content:"\F8E7"}.mdi-gesture::before{content:"\F7CA"}.mdi-gesture-double-tap::before{content:"\F73B"}.mdi-gesture-pinch::before{content:"\FABC"}.mdi-gesture-spread::before{content:"\FABD"}.mdi-gesture-swipe::before{content:"\FD52"}.mdi-gesture-swipe-down::before{content:"\F73C"}.mdi-gesture-swipe-horizontal::before{content:"\FABE"}.mdi-gesture-swipe-left::before{content:"\F73D"}.mdi-gesture-swipe-right::before{content:"\F73E"}.mdi-gesture-swipe-up::before{content:"\F73F"}.mdi-gesture-swipe-vertical::before{content:"\FABF"}.mdi-gesture-tap::before{content:"\F740"}.mdi-gesture-tap-hold::before{content:"\FD53"}.mdi-gesture-two-double-tap::before{content:"\F741"}.mdi-gesture-two-tap::before{content:"\F742"}.mdi-ghost::before{content:"\F2A0"}.mdi-ghost-off::before{content:"\F9F4"}.mdi-gif::before{content:"\FD54"}.mdi-gift::before{content:"\FE85"}.mdi-gift-outline::before{content:"\F2A1"}.mdi-git::before{content:"\F2A2"}.mdi-github-box::before{content:"\F2A3"}.mdi-github-circle::before{content:"\F2A4"}.mdi-github-face::before{content:"\F6DA"}.mdi-gitlab::before{content:"\FB7C"}.mdi-glass-cocktail::before{content:"\F356"}.mdi-glass-flute::before{content:"\F2A5"}.mdi-glass-mug::before{content:"\F2A6"}.mdi-glass-stange::before{content:"\F2A7"}.mdi-glass-tulip::before{content:"\F2A8"}.mdi-glass-wine::before{content:"\F875"}.mdi-glassdoor::before{content:"\F2A9"}.mdi-glasses::before{content:"\F2AA"}.mdi-globe-model::before{content:"\F8E8"}.mdi-gmail::before{content:"\F2AB"}.mdi-gnome::before{content:"\F2AC"}.mdi-go-kart::before{content:"\FD55"}.mdi-go-kart-track::before{content:"\FD56"}.mdi-gog::before{content:"\FB7D"}.mdi-golf::before{content:"\F822"}.mdi-gondola::before{content:"\F685"}.mdi-goodreads::before{content:"\FD57"}.mdi-google::before{content:"\F2AD"}.mdi-google-adwords::before{content:"\FC63"}.mdi-google-allo::before{content:"\F801"}.mdi-google-analytics::before{content:"\F7CB"}.mdi-google-assistant::before{content:"\F7CC"}.mdi-google-cardboard::before{content:"\F2AE"}.mdi-google-chrome::before{content:"\F2AF"}.mdi-google-circles::before{content:"\F2B0"}.mdi-google-circles-communities::before{content:"\F2B1"}.mdi-google-circles-extended::before{content:"\F2B2"}.mdi-google-circles-group::before{content:"\F2B3"}.mdi-google-classroom::before{content:"\F2C0"}.mdi-google-controller::before{content:"\F2B4"}.mdi-google-controller-off::before{content:"\F2B5"}.mdi-google-drive::before{content:"\F2B6"}.mdi-google-earth::before{content:"\F2B7"}.mdi-google-fit::before{content:"\F96B"}.mdi-google-glass::before{content:"\F2B8"}.mdi-google-hangouts::before{content:"\F2C9"}.mdi-google-home::before{content:"\F823"}.mdi-google-keep::before{content:"\F6DB"}.mdi-google-lens::before{content:"\F9F5"}.mdi-google-maps::before{content:"\F5F5"}.mdi-google-nearby::before{content:"\F2B9"}.mdi-google-pages::before{content:"\F2BA"}.mdi-google-photos::before{content:"\F6DC"}.mdi-google-physical-web::before{content:"\F2BB"}.mdi-google-play::before{content:"\F2BC"}.mdi-google-plus::before{content:"\F2BD"}.mdi-google-plus-box::before{content:"\F2BE"}.mdi-google-podcast::before{content:"\FED6"}.mdi-google-spreadsheet::before{content:"\F9F6"}.mdi-google-street-view::before{content:"\FC64"}.mdi-google-translate::before{content:"\F2BF"}.mdi-gpu::before{content:"\F8AD"}.mdi-gradient::before{content:"\F69F"}.mdi-grain::before{content:"\FD58"}.mdi-graphql::before{content:"\F876"}.mdi-grave-stone::before{content:"\FB7E"}.mdi-grease-pencil::before{content:"\F648"}.mdi-greater-than::before{content:"\F96C"}.mdi-greater-than-or-equal::before{content:"\F96D"}.mdi-grid::before{content:"\F2C1"}.mdi-grid-large::before{content:"\F757"}.mdi-grid-off::before{content:"\F2C2"}.mdi-grill::before{content:"\FE86"}.mdi-group::before{content:"\F2C3"}.mdi-guitar-acoustic::before{content:"\F770"}.mdi-guitar-electric::before{content:"\F2C4"}.mdi-guitar-pick::before{content:"\F2C5"}.mdi-guitar-pick-outline::before{content:"\F2C6"}.mdi-guy-fawkes-mask::before{content:"\F824"}.mdi-hackernews::before{content:"\F624"}.mdi-hail::before{content:"\FAC0"}.mdi-halloween::before{content:"\FB7F"}.mdi-hamburger::before{content:"\F684"}.mdi-hammer::before{content:"\F8E9"}.mdi-hand::before{content:"\FA4E"}.mdi-hand-left::before{content:"\FE87"}.mdi-hand-okay::before{content:"\FA4F"}.mdi-hand-peace::before{content:"\FA50"}.mdi-hand-peace-variant::before{content:"\FA51"}.mdi-hand-pointing-down::before{content:"\FA52"}.mdi-hand-pointing-left::before{content:"\FA53"}.mdi-hand-pointing-right::before{content:"\F2C7"}.mdi-hand-pointing-up::before{content:"\FA54"}.mdi-hand-right::before{content:"\FE88"}.mdi-hand-saw::before{content:"\FE89"}.mdi-handball::before{content:"\FF70"}.mdi-hanger::before{content:"\F2C8"}.mdi-hard-hat::before{content:"\F96E"}.mdi-harddisk::before{content:"\F2CA"}.mdi-hat-fedora::before{content:"\FB80"}.mdi-hazard-lights::before{content:"\FC65"}.mdi-hdr::before{content:"\FD59"}.mdi-hdr-off::before{content:"\FD5A"}.mdi-headphones::before{content:"\F2CB"}.mdi-headphones-bluetooth::before{content:"\F96F"}.mdi-headphones-box::before{content:"\F2CC"}.mdi-headphones-off::before{content:"\F7CD"}.mdi-headphones-settings::before{content:"\F2CD"}.mdi-headset::before{content:"\F2CE"}.mdi-headset-dock::before{content:"\F2CF"}.mdi-headset-off::before{content:"\F2D0"}.mdi-heart::before{content:"\F2D1"}.mdi-heart-box::before{content:"\F2D2"}.mdi-heart-box-outline::before{content:"\F2D3"}.mdi-heart-broken::before{content:"\F2D4"}.mdi-heart-broken-outline::before{content:"\FCF0"}.mdi-heart-circle::before{content:"\F970"}.mdi-heart-circle-outline::before{content:"\F971"}.mdi-heart-flash::before{content:"\FF16"}.mdi-heart-half::before{content:"\F6DE"}.mdi-heart-half-full::before{content:"\F6DD"}.mdi-heart-half-outline::before{content:"\F6DF"}.mdi-heart-multiple::before{content:"\FA55"}.mdi-heart-multiple-outline::before{content:"\FA56"}.mdi-heart-off::before{content:"\F758"}.mdi-heart-outline::before{content:"\F2D5"}.mdi-heart-pulse::before{content:"\F5F6"}.mdi-helicopter::before{content:"\FAC1"}.mdi-help::before{content:"\F2D6"}.mdi-help-box::before{content:"\F78A"}.mdi-help-circle::before{content:"\F2D7"}.mdi-help-circle-outline::before{content:"\F625"}.mdi-help-network::before{content:"\F6F4"}.mdi-help-network-outline::before{content:"\FC66"}.mdi-help-rhombus::before{content:"\FB81"}.mdi-help-rhombus-outline::before{content:"\FB82"}.mdi-hexagon::before{content:"\F2D8"}.mdi-hexagon-multiple::before{content:"\F6E0"}.mdi-hexagon-outline::before{content:"\F2D9"}.mdi-hexagon-slice-1::before{content:"\FAC2"}.mdi-hexagon-slice-2::before{content:"\FAC3"}.mdi-hexagon-slice-3::before{content:"\FAC4"}.mdi-hexagon-slice-4::before{content:"\FAC5"}.mdi-hexagon-slice-5::before{content:"\FAC6"}.mdi-hexagon-slice-6::before{content:"\FAC7"}.mdi-hexagram::before{content:"\FAC8"}.mdi-hexagram-outline::before{content:"\FAC9"}.mdi-high-definition::before{content:"\F7CE"}.mdi-high-definition-box::before{content:"\F877"}.mdi-highway::before{content:"\F5F7"}.mdi-hiking::before{content:"\FD5B"}.mdi-hinduism::before{content:"\F972"}.mdi-history::before{content:"\F2DA"}.mdi-hockey-puck::before{content:"\F878"}.mdi-hockey-sticks::before{content:"\F879"}.mdi-hololens::before{content:"\F2DB"}.mdi-home::before{content:"\F2DC"}.mdi-home-account::before{content:"\F825"}.mdi-home-alert::before{content:"\F87A"}.mdi-home-analytics::before{content:"\FED7"}.mdi-home-assistant::before{content:"\F7CF"}.mdi-home-automation::before{content:"\F7D0"}.mdi-home-circle::before{content:"\F7D1"}.mdi-home-city::before{content:"\FCF1"}.mdi-home-city-outline::before{content:"\FCF2"}.mdi-home-currency-usd::before{content:"\F8AE"}.mdi-home-export-outline::before{content:"\FFB8"}.mdi-home-flood::before{content:"\FF17"}.mdi-home-floor-0::before{content:"\FDAE"}.mdi-home-floor-1::before{content:"\FD5C"}.mdi-home-floor-2::before{content:"\FD5D"}.mdi-home-floor-3::before{content:"\FD5E"}.mdi-home-floor-a::before{content:"\FD5F"}.mdi-home-floor-b::before{content:"\FD60"}.mdi-home-floor-g::before{content:"\FD61"}.mdi-home-floor-l::before{content:"\FD62"}.mdi-home-floor-negative-1::before{content:"\FDAF"}.mdi-home-group::before{content:"\FDB0"}.mdi-home-heart::before{content:"\F826"}.mdi-home-import-outline::before{content:"\FFB9"}.mdi-home-lock::before{content:"\F8EA"}.mdi-home-lock-open::before{content:"\F8EB"}.mdi-home-map-marker::before{content:"\F5F8"}.mdi-home-minus::before{content:"\F973"}.mdi-home-modern::before{content:"\F2DD"}.mdi-home-outline::before{content:"\F6A0"}.mdi-home-plus::before{content:"\F974"}.mdi-home-thermometer::before{content:"\FF71"}.mdi-home-thermometer-outline::before{content:"\FF72"}.mdi-home-variant::before{content:"\F2DE"}.mdi-home-variant-outline::before{content:"\FB83"}.mdi-hook::before{content:"\F6E1"}.mdi-hook-off::before{content:"\F6E2"}.mdi-hops::before{content:"\F2DF"}.mdi-horseshoe::before{content:"\FA57"}.mdi-hospital::before{content:"\F2E0"}.mdi-hospital-building::before{content:"\F2E1"}.mdi-hospital-marker::before{content:"\F2E2"}.mdi-hot-tub::before{content:"\F827"}.mdi-hotel::before{content:"\F2E3"}.mdi-houzz::before{content:"\F2E4"}.mdi-houzz-box::before{content:"\F2E5"}.mdi-hubspot::before{content:"\FCF3"}.mdi-hulu::before{content:"\F828"}.mdi-human::before{content:"\F2E6"}.mdi-human-child::before{content:"\F2E7"}.mdi-human-female::before{content:"\F649"}.mdi-human-female-boy::before{content:"\FA58"}.mdi-human-female-female::before{content:"\FA59"}.mdi-human-female-girl::before{content:"\FA5A"}.mdi-human-greeting::before{content:"\F64A"}.mdi-human-handsdown::before{content:"\F64B"}.mdi-human-handsup::before{content:"\F64C"}.mdi-human-male::before{content:"\F64D"}.mdi-human-male-boy::before{content:"\FA5B"}.mdi-human-male-female::before{content:"\F2E8"}.mdi-human-male-girl::before{content:"\FA5C"}.mdi-human-male-height::before{content:"\FF18"}.mdi-human-male-height-variant::before{content:"\FF19"}.mdi-human-male-male::before{content:"\FA5D"}.mdi-human-pregnant::before{content:"\F5CF"}.mdi-humble-bundle::before{content:"\F743"}.mdi-ice-cream::before{content:"\F829"}.mdi-ice-pop::before{content:"\FF1A"}.mdi-identifier::before{content:"\FF1B"}.mdi-iframe::before{content:"\FC67"}.mdi-iframe-outline::before{content:"\FC68"}.mdi-image::before{content:"\F2E9"}.mdi-image-album::before{content:"\F2EA"}.mdi-image-area::before{content:"\F2EB"}.mdi-image-area-close::before{content:"\F2EC"}.mdi-image-broken::before{content:"\F2ED"}.mdi-image-broken-variant::before{content:"\F2EE"}.mdi-image-filter::before{content:"\F2EF"}.mdi-image-filter-black-white::before{content:"\F2F0"}.mdi-image-filter-center-focus::before{content:"\F2F1"}.mdi-image-filter-center-focus-strong::before{content:"\FF1C"}.mdi-image-filter-center-focus-strong-outline::before{content:"\FF1D"}.mdi-image-filter-center-focus-weak::before{content:"\F2F2"}.mdi-image-filter-drama::before{content:"\F2F3"}.mdi-image-filter-frames::before{content:"\F2F4"}.mdi-image-filter-hdr::before{content:"\F2F5"}.mdi-image-filter-none::before{content:"\F2F6"}.mdi-image-filter-tilt-shift::before{content:"\F2F7"}.mdi-image-filter-vintage::before{content:"\F2F8"}.mdi-image-frame::before{content:"\FE8A"}.mdi-image-move::before{content:"\F9F7"}.mdi-image-multiple::before{content:"\F2F9"}.mdi-image-off::before{content:"\F82A"}.mdi-image-outline::before{content:"\F975"}.mdi-image-plus::before{content:"\F87B"}.mdi-image-search::before{content:"\F976"}.mdi-image-search-outline::before{content:"\F977"}.mdi-image-size-select-actual::before{content:"\FC69"}.mdi-image-size-select-large::before{content:"\FC6A"}.mdi-image-size-select-small::before{content:"\FC6B"}.mdi-import::before{content:"\F2FA"}.mdi-inbox::before{content:"\F686"}.mdi-inbox-arrow-down::before{content:"\F2FB"}.mdi-inbox-arrow-up::before{content:"\F3D1"}.mdi-inbox-multiple::before{content:"\F8AF"}.mdi-inbox-multiple-outline::before{content:"\FB84"}.mdi-incognito::before{content:"\F5F9"}.mdi-infinity::before{content:"\F6E3"}.mdi-information::before{content:"\F2FC"}.mdi-information-outline::before{content:"\F2FD"}.mdi-information-variant::before{content:"\F64E"}.mdi-instagram::before{content:"\F2FE"}.mdi-instapaper::before{content:"\F2FF"}.mdi-internet-explorer::before{content:"\F300"}.mdi-invert-colors::before{content:"\F301"}.mdi-invert-colors-off::before{content:"\FE8B"}.mdi-ip::before{content:"\FA5E"}.mdi-ip-network::before{content:"\FA5F"}.mdi-ip-network-outline::before{content:"\FC6C"}.mdi-ipod::before{content:"\FC6D"}.mdi-islam::before{content:"\F978"}.mdi-itunes::before{content:"\F676"}.mdi-jabber::before{content:"\FDB1"}.mdi-jeepney::before{content:"\F302"}.mdi-jellyfish::before{content:"\FF1E"}.mdi-jellyfish-outline::before{content:"\FF1F"}.mdi-jira::before{content:"\F303"}.mdi-jquery::before{content:"\F87C"}.mdi-jsfiddle::before{content:"\F304"}.mdi-json::before{content:"\F626"}.mdi-judaism::before{content:"\F979"}.mdi-kabaddi::before{content:"\FD63"}.mdi-karate::before{content:"\F82B"}.mdi-keg::before{content:"\F305"}.mdi-kettle::before{content:"\F5FA"}.mdi-kettle-outline::before{content:"\FF73"}.mdi-key::before{content:"\F306"}.mdi-key-change::before{content:"\F307"}.mdi-key-minus::before{content:"\F308"}.mdi-key-outline::before{content:"\FDB2"}.mdi-key-plus::before{content:"\F309"}.mdi-key-remove::before{content:"\F30A"}.mdi-key-variant::before{content:"\F30B"}.mdi-keyboard::before{content:"\F30C"}.mdi-keyboard-backspace::before{content:"\F30D"}.mdi-keyboard-caps::before{content:"\F30E"}.mdi-keyboard-close::before{content:"\F30F"}.mdi-keyboard-off::before{content:"\F310"}.mdi-keyboard-off-outline::before{content:"\FE8C"}.mdi-keyboard-outline::before{content:"\F97A"}.mdi-keyboard-return::before{content:"\F311"}.mdi-keyboard-settings::before{content:"\F9F8"}.mdi-keyboard-settings-outline::before{content:"\F9F9"}.mdi-keyboard-tab::before{content:"\F312"}.mdi-keyboard-variant::before{content:"\F313"}.mdi-kickstarter::before{content:"\F744"}.mdi-knife::before{content:"\F9FA"}.mdi-knife-military::before{content:"\F9FB"}.mdi-kodi::before{content:"\F314"}.mdi-label::before{content:"\F315"}.mdi-label-off::before{content:"\FACA"}.mdi-label-off-outline::before{content:"\FACB"}.mdi-label-outline::before{content:"\F316"}.mdi-label-variant::before{content:"\FACC"}.mdi-label-variant-outline::before{content:"\FACD"}.mdi-ladybug::before{content:"\F82C"}.mdi-lambda::before{content:"\F627"}.mdi-lamp::before{content:"\F6B4"}.mdi-lan::before{content:"\F317"}.mdi-lan-connect::before{content:"\F318"}.mdi-lan-disconnect::before{content:"\F319"}.mdi-lan-pending::before{content:"\F31A"}.mdi-language-c::before{content:"\F671"}.mdi-language-cpp::before{content:"\F672"}.mdi-language-csharp::before{content:"\F31B"}.mdi-language-css3::before{content:"\F31C"}.mdi-language-go::before{content:"\F7D2"}.mdi-language-haskell::before{content:"\FC6E"}.mdi-language-html5::before{content:"\F31D"}.mdi-language-java::before{content:"\FB1C"}.mdi-language-javascript::before{content:"\F31E"}.mdi-language-lua::before{content:"\F8B0"}.mdi-language-php::before{content:"\F31F"}.mdi-language-python::before{content:"\F320"}.mdi-language-python-text::before{content:"\F321"}.mdi-language-r::before{content:"\F7D3"}.mdi-language-ruby-on-rails::before{content:"\FACE"}.mdi-language-swift::before{content:"\F6E4"}.mdi-language-typescript::before{content:"\F6E5"}.mdi-laptop::before{content:"\F322"}.mdi-laptop-chromebook::before{content:"\F323"}.mdi-laptop-mac::before{content:"\F324"}.mdi-laptop-off::before{content:"\F6E6"}.mdi-laptop-windows::before{content:"\F325"}.mdi-laravel::before{content:"\FACF"}.mdi-lasso::before{content:"\FF20"}.mdi-lastfm::before{content:"\F326"}.mdi-lastpass::before{content:"\F446"}.mdi-latitude::before{content:"\FF74"}.mdi-launch::before{content:"\F327"}.mdi-lava-lamp::before{content:"\F7D4"}.mdi-layers::before{content:"\F328"}.mdi-layers-minus::before{content:"\FE8D"}.mdi-layers-off::before{content:"\F329"}.mdi-layers-off-outline::before{content:"\F9FC"}.mdi-layers-outline::before{content:"\F9FD"}.mdi-layers-plus::before{content:"\FE30"}.mdi-layers-remove::before{content:"\FE31"}.mdi-layers-triple::before{content:"\FF75"}.mdi-layers-triple-outline::before{content:"\FF76"}.mdi-lead-pencil::before{content:"\F64F"}.mdi-leaf::before{content:"\F32A"}.mdi-leaf-maple::before{content:"\FC6F"}.mdi-leak::before{content:"\FDB3"}.mdi-leak-off::before{content:"\FDB4"}.mdi-led-off::before{content:"\F32B"}.mdi-led-on::before{content:"\F32C"}.mdi-led-outline::before{content:"\F32D"}.mdi-led-strip::before{content:"\F7D5"}.mdi-led-variant-off::before{content:"\F32E"}.mdi-led-variant-on::before{content:"\F32F"}.mdi-led-variant-outline::before{content:"\F330"}.mdi-less-than::before{content:"\F97B"}.mdi-less-than-or-equal::before{content:"\F97C"}.mdi-library::before{content:"\F331"}.mdi-library-books::before{content:"\F332"}.mdi-library-movie::before{content:"\FCF4"}.mdi-library-music::before{content:"\F333"}.mdi-library-music-outline::before{content:"\FF21"}.mdi-library-plus::before{content:"\F334"}.mdi-library-shelves::before{content:"\FB85"}.mdi-library-video::before{content:"\FCF5"}.mdi-lifebuoy::before{content:"\F87D"}.mdi-light-switch::before{content:"\F97D"}.mdi-lightbulb::before{content:"\F335"}.mdi-lightbulb-off::before{content:"\FE32"}.mdi-lightbulb-off-outline::before{content:"\FE33"}.mdi-lightbulb-on::before{content:"\F6E7"}.mdi-lightbulb-on-outline::before{content:"\F6E8"}.mdi-lightbulb-outline::before{content:"\F336"}.mdi-lighthouse::before{content:"\F9FE"}.mdi-lighthouse-on::before{content:"\F9FF"}.mdi-link::before{content:"\F337"}.mdi-link-box::before{content:"\FCF6"}.mdi-link-box-outline::before{content:"\FCF7"}.mdi-link-box-variant::before{content:"\FCF8"}.mdi-link-box-variant-outline::before{content:"\FCF9"}.mdi-link-off::before{content:"\F338"}.mdi-link-plus::before{content:"\FC70"}.mdi-link-variant::before{content:"\F339"}.mdi-link-variant-off::before{content:"\F33A"}.mdi-linkedin::before{content:"\F33B"}.mdi-linkedin-box::before{content:"\F33C"}.mdi-linux::before{content:"\F33D"}.mdi-linux-mint::before{content:"\F8EC"}.mdi-litecoin::before{content:"\FA60"}.mdi-loading::before{content:"\F771"}.mdi-lock::before{content:"\F33E"}.mdi-lock-alert::before{content:"\F8ED"}.mdi-lock-clock::before{content:"\F97E"}.mdi-lock-open::before{content:"\F33F"}.mdi-lock-open-outline::before{content:"\F340"}.mdi-lock-outline::before{content:"\F341"}.mdi-lock-pattern::before{content:"\F6E9"}.mdi-lock-plus::before{content:"\F5FB"}.mdi-lock-question::before{content:"\F8EE"}.mdi-lock-reset::before{content:"\F772"}.mdi-lock-smart::before{content:"\F8B1"}.mdi-locker::before{content:"\F7D6"}.mdi-locker-multiple::before{content:"\F7D7"}.mdi-login::before{content:"\F342"}.mdi-login-variant::before{content:"\F5FC"}.mdi-logout::before{content:"\F343"}.mdi-logout-variant::before{content:"\F5FD"}.mdi-longitude::before{content:"\FF77"}.mdi-looks::before{content:"\F344"}.mdi-loop::before{content:"\F6EA"}.mdi-loupe::before{content:"\F345"}.mdi-lumx::before{content:"\F346"}.mdi-lyft::before{content:"\FB1D"}.mdi-magnet::before{content:"\F347"}.mdi-magnet-on::before{content:"\F348"}.mdi-magnify::before{content:"\F349"}.mdi-magnify-close::before{content:"\F97F"}.mdi-magnify-minus::before{content:"\F34A"}.mdi-magnify-minus-cursor::before{content:"\FA61"}.mdi-magnify-minus-outline::before{content:"\F6EB"}.mdi-magnify-plus::before{content:"\F34B"}.mdi-magnify-plus-cursor::before{content:"\FA62"}.mdi-magnify-plus-outline::before{content:"\F6EC"}.mdi-mail::before{content:"\FED8"}.mdi-mail-ru::before{content:"\F34C"}.mdi-mailbox::before{content:"\F6ED"}.mdi-mailbox-open::before{content:"\FD64"}.mdi-mailbox-open-outline::before{content:"\FD65"}.mdi-mailbox-open-up::before{content:"\FD66"}.mdi-mailbox-open-up-outline::before{content:"\FD67"}.mdi-mailbox-outline::before{content:"\FD68"}.mdi-mailbox-up::before{content:"\FD69"}.mdi-mailbox-up-outline::before{content:"\FD6A"}.mdi-map::before{content:"\F34D"}.mdi-map-check::before{content:"\FED9"}.mdi-map-check-outline::before{content:"\FEDA"}.mdi-map-clock::before{content:"\FCFA"}.mdi-map-clock-outline::before{content:"\FCFB"}.mdi-map-legend::before{content:"\FA00"}.mdi-map-marker::before{content:"\F34E"}.mdi-map-marker-alert::before{content:"\FF22"}.mdi-map-marker-alert-outline::before{content:"\FF23"}.mdi-map-marker-check::before{content:"\FC71"}.mdi-map-marker-circle::before{content:"\F34F"}.mdi-map-marker-distance::before{content:"\F8EF"}.mdi-map-marker-minus::before{content:"\F650"}.mdi-map-marker-multiple::before{content:"\F350"}.mdi-map-marker-off::before{content:"\F351"}.mdi-map-marker-outline::before{content:"\F7D8"}.mdi-map-marker-path::before{content:"\FCFC"}.mdi-map-marker-plus::before{content:"\F651"}.mdi-map-marker-question::before{content:"\FF24"}.mdi-map-marker-question-outline::before{content:"\FF25"}.mdi-map-marker-radius::before{content:"\F352"}.mdi-map-marker-remove::before{content:"\FF26"}.mdi-map-marker-remove-variant::before{content:"\FF27"}.mdi-map-minus::before{content:"\F980"}.mdi-map-outline::before{content:"\F981"}.mdi-map-plus::before{content:"\F982"}.mdi-map-search::before{content:"\F983"}.mdi-map-search-outline::before{content:"\F984"}.mdi-mapbox::before{content:"\FB86"}.mdi-margin::before{content:"\F353"}.mdi-markdown::before{content:"\F354"}.mdi-markdown-outline::before{content:"\FF78"}.mdi-marker::before{content:"\F652"}.mdi-marker-cancel::before{content:"\FDB5"}.mdi-marker-check::before{content:"\F355"}.mdi-mastodon::before{content:"\FAD0"}.mdi-mastodon-variant::before{content:"\FAD1"}.mdi-material-design::before{content:"\F985"}.mdi-material-ui::before{content:"\F357"}.mdi-math-compass::before{content:"\F358"}.mdi-math-cos::before{content:"\FC72"}.mdi-math-sin::before{content:"\FC73"}.mdi-math-tan::before{content:"\FC74"}.mdi-matrix::before{content:"\F628"}.mdi-maxcdn::before{content:"\F359"}.mdi-medal::before{content:"\F986"}.mdi-medical-bag::before{content:"\F6EE"}.mdi-medium::before{content:"\F35A"}.mdi-meetup::before{content:"\FAD2"}.mdi-memory::before{content:"\F35B"}.mdi-menu::before{content:"\F35C"}.mdi-menu-down::before{content:"\F35D"}.mdi-menu-down-outline::before{content:"\F6B5"}.mdi-menu-left::before{content:"\F35E"}.mdi-menu-left-outline::before{content:"\FA01"}.mdi-menu-open::before{content:"\FB87"}.mdi-menu-right::before{content:"\F35F"}.mdi-menu-right-outline::before{content:"\FA02"}.mdi-menu-swap::before{content:"\FA63"}.mdi-menu-swap-outline::before{content:"\FA64"}.mdi-menu-up::before{content:"\F360"}.mdi-menu-up-outline::before{content:"\F6B6"}.mdi-merge::before{content:"\FF79"}.mdi-message::before{content:"\F361"}.mdi-message-alert::before{content:"\F362"}.mdi-message-alert-outline::before{content:"\FA03"}.mdi-message-bulleted::before{content:"\F6A1"}.mdi-message-bulleted-off::before{content:"\F6A2"}.mdi-message-draw::before{content:"\F363"}.mdi-message-image::before{content:"\F364"}.mdi-message-outline::before{content:"\F365"}.mdi-message-plus::before{content:"\F653"}.mdi-message-processing::before{content:"\F366"}.mdi-message-reply::before{content:"\F367"}.mdi-message-reply-text::before{content:"\F368"}.mdi-message-settings::before{content:"\F6EF"}.mdi-message-settings-variant::before{content:"\F6F0"}.mdi-message-text::before{content:"\F369"}.mdi-message-text-outline::before{content:"\F36A"}.mdi-message-video::before{content:"\F36B"}.mdi-meteor::before{content:"\F629"}.mdi-metronome::before{content:"\F7D9"}.mdi-metronome-tick::before{content:"\F7DA"}.mdi-micro-sd::before{content:"\F7DB"}.mdi-microphone::before{content:"\F36C"}.mdi-microphone-minus::before{content:"\F8B2"}.mdi-microphone-off::before{content:"\F36D"}.mdi-microphone-outline::before{content:"\F36E"}.mdi-microphone-plus::before{content:"\F8B3"}.mdi-microphone-settings::before{content:"\F36F"}.mdi-microphone-variant::before{content:"\F370"}.mdi-microphone-variant-off::before{content:"\F371"}.mdi-microscope::before{content:"\F654"}.mdi-microsoft::before{content:"\F372"}.mdi-microsoft-dynamics::before{content:"\F987"}.mdi-microwave::before{content:"\FC75"}.mdi-middleware::before{content:"\FF7A"}.mdi-middleware-outline::before{content:"\FF7B"}.mdi-midi::before{content:"\F8F0"}.mdi-midi-port::before{content:"\F8F1"}.mdi-mine::before{content:"\FDB6"}.mdi-minecraft::before{content:"\F373"}.mdi-mini-sd::before{content:"\FA04"}.mdi-minidisc::before{content:"\FA05"}.mdi-minus::before{content:"\F374"}.mdi-minus-box::before{content:"\F375"}.mdi-minus-box-outline::before{content:"\F6F1"}.mdi-minus-circle::before{content:"\F376"}.mdi-minus-circle-outline::before{content:"\F377"}.mdi-minus-network::before{content:"\F378"}.mdi-minus-network-outline::before{content:"\FC76"}.mdi-mixcloud::before{content:"\F62A"}.mdi-mixed-martial-arts::before{content:"\FD6B"}.mdi-mixed-reality::before{content:"\F87E"}.mdi-mixer::before{content:"\F7DC"}.mdi-molecule::before{content:"\FB88"}.mdi-monitor::before{content:"\F379"}.mdi-monitor-cellphone::before{content:"\F988"}.mdi-monitor-cellphone-star::before{content:"\F989"}.mdi-monitor-dashboard::before{content:"\FA06"}.mdi-monitor-lock::before{content:"\FDB7"}.mdi-monitor-multiple::before{content:"\F37A"}.mdi-monitor-off::before{content:"\FD6C"}.mdi-monitor-screenshot::before{content:"\FE34"}.mdi-monitor-speaker::before{content:"\FF7C"}.mdi-monitor-speaker-off::before{content:"\FF7D"}.mdi-monitor-star::before{content:"\FDB8"}.mdi-moon-first-quarter::before{content:"\FF7E"}.mdi-moon-full::before{content:"\FF7F"}.mdi-moon-last-quarter::before{content:"\FF80"}.mdi-moon-new::before{content:"\FF81"}.mdi-moon-waning-crescent::before{content:"\FF82"}.mdi-moon-waning-gibbous::before{content:"\FF83"}.mdi-moon-waxing-crescent::before{content:"\FF84"}.mdi-moon-waxing-gibbous::before{content:"\FF85"}.mdi-more::before{content:"\F37B"}.mdi-mother-nurse::before{content:"\FCFD"}.mdi-motion-sensor::before{content:"\FD6D"}.mdi-motorbike::before{content:"\F37C"}.mdi-mouse::before{content:"\F37D"}.mdi-mouse-bluetooth::before{content:"\F98A"}.mdi-mouse-off::before{content:"\F37E"}.mdi-mouse-variant::before{content:"\F37F"}.mdi-mouse-variant-off::before{content:"\F380"}.mdi-move-resize::before{content:"\F655"}.mdi-move-resize-variant::before{content:"\F656"}.mdi-movie::before{content:"\F381"}.mdi-movie-outline::before{content:"\FDB9"}.mdi-movie-roll::before{content:"\F7DD"}.mdi-muffin::before{content:"\F98B"}.mdi-multiplication::before{content:"\F382"}.mdi-multiplication-box::before{content:"\F383"}.mdi-mushroom::before{content:"\F7DE"}.mdi-mushroom-outline::before{content:"\F7DF"}.mdi-music::before{content:"\F759"}.mdi-music-accidental-double-flat::before{content:"\FF86"}.mdi-music-accidental-double-sharp::before{content:"\FF87"}.mdi-music-accidental-flat::before{content:"\FF88"}.mdi-music-accidental-natural::before{content:"\FF89"}.mdi-music-accidental-sharp::before{content:"\FF8A"}.mdi-music-box::before{content:"\F384"}.mdi-music-box-outline::before{content:"\F385"}.mdi-music-circle::before{content:"\F386"}.mdi-music-circle-outline::before{content:"\FAD3"}.mdi-music-clef-alto::before{content:"\FF8B"}.mdi-music-clef-bass::before{content:"\FF8C"}.mdi-music-clef-treble::before{content:"\FF8D"}.mdi-music-note::before{content:"\F387"}.mdi-music-note-bluetooth::before{content:"\F5FE"}.mdi-music-note-bluetooth-off::before{content:"\F5FF"}.mdi-music-note-eighth::before{content:"\F388"}.mdi-music-note-eighth-dotted::before{content:"\FF8E"}.mdi-music-note-half::before{content:"\F389"}.mdi-music-note-half-dotted::before{content:"\FF8F"}.mdi-music-note-off::before{content:"\F38A"}.mdi-music-note-off-outline::before{content:"\FF90"}.mdi-music-note-outline::before{content:"\FF91"}.mdi-music-note-plus::before{content:"\FDBA"}.mdi-music-note-quarter::before{content:"\F38B"}.mdi-music-note-quarter-dotted::before{content:"\FF92"}.mdi-music-note-sixteenth::before{content:"\F38C"}.mdi-music-note-sixteenth-dotted::before{content:"\FF93"}.mdi-music-note-whole::before{content:"\F38D"}.mdi-music-note-whole-dotted::before{content:"\FF94"}.mdi-music-off::before{content:"\F75A"}.mdi-music-rest-eighth::before{content:"\FF95"}.mdi-music-rest-half::before{content:"\FF96"}.mdi-music-rest-quarter::before{content:"\FF97"}.mdi-music-rest-sixteenth::before{content:"\FF98"}.mdi-music-rest-whole::before{content:"\FF99"}.mdi-nail::before{content:"\FDBB"}.mdi-nas::before{content:"\F8F2"}.mdi-nativescript::before{content:"\F87F"}.mdi-nature::before{content:"\F38E"}.mdi-nature-people::before{content:"\F38F"}.mdi-navigation::before{content:"\F390"}.mdi-near-me::before{content:"\F5CD"}.mdi-necklace::before{content:"\FF28"}.mdi-needle::before{content:"\F391"}.mdi-netflix::before{content:"\F745"}.mdi-network::before{content:"\F6F2"}.mdi-network-off::before{content:"\FC77"}.mdi-network-off-outline::before{content:"\FC78"}.mdi-network-outline::before{content:"\FC79"}.mdi-network-strength-1::before{content:"\F8F3"}.mdi-network-strength-1-alert::before{content:"\F8F4"}.mdi-network-strength-2::before{content:"\F8F5"}.mdi-network-strength-2-alert::before{content:"\F8F6"}.mdi-network-strength-3::before{content:"\F8F7"}.mdi-network-strength-3-alert::before{content:"\F8F8"}.mdi-network-strength-4::before{content:"\F8F9"}.mdi-network-strength-4-alert::before{content:"\F8FA"}.mdi-network-strength-off::before{content:"\F8FB"}.mdi-network-strength-off-outline::before{content:"\F8FC"}.mdi-network-strength-outline::before{content:"\F8FD"}.mdi-new-box::before{content:"\F394"}.mdi-newspaper::before{content:"\F395"}.mdi-newspaper-minus::before{content:"\FF29"}.mdi-newspaper-plus::before{content:"\FF2A"}.mdi-nfc::before{content:"\F396"}.mdi-nfc-off::before{content:"\FE35"}.mdi-nfc-search-variant::before{content:"\FE36"}.mdi-nfc-tap::before{content:"\F397"}.mdi-nfc-variant::before{content:"\F398"}.mdi-nfc-variant-off::before{content:"\FE37"}.mdi-ninja::before{content:"\F773"}.mdi-nintendo-switch::before{content:"\F7E0"}.mdi-nodejs::before{content:"\F399"}.mdi-not-equal::before{content:"\F98C"}.mdi-not-equal-variant::before{content:"\F98D"}.mdi-note::before{content:"\F39A"}.mdi-note-circle::before{content:"\FEDB"}.mdi-note-multiple::before{content:"\F6B7"}.mdi-note-multiple-outline::before{content:"\F6B8"}.mdi-note-outline::before{content:"\F39B"}.mdi-note-plus::before{content:"\F39C"}.mdi-note-plus-outline::before{content:"\F39D"}.mdi-note-text::before{content:"\F39E"}.mdi-notebook::before{content:"\F82D"}.mdi-notebook-multiple::before{content:"\FE38"}.mdi-notebook-outline::before{content:"\FEDC"}.mdi-notification-clear-all::before{content:"\F39F"}.mdi-npm::before{content:"\F6F6"}.mdi-npm-variant::before{content:"\F98E"}.mdi-npm-variant-outline::before{content:"\F98F"}.mdi-nuke::before{content:"\F6A3"}.mdi-null::before{content:"\F7E1"}.mdi-numeric::before{content:"\F3A0"}.mdi-numeric-0::before{content:"\30"}.mdi-numeric-0-box::before{content:"\F3A1"}.mdi-numeric-0-box-multiple::before{content:"\FF2B"}.mdi-numeric-0-box-multiple-outline::before{content:"\F3A2"}.mdi-numeric-0-box-outline::before{content:"\F3A3"}.mdi-numeric-0-circle::before{content:"\FC7A"}.mdi-numeric-0-circle-outline::before{content:"\FC7B"}.mdi-numeric-1::before{content:"\31"}.mdi-numeric-1-box::before{content:"\F3A4"}.mdi-numeric-1-box-multiple::before{content:"\FF2C"}.mdi-numeric-1-box-multiple-outline::before{content:"\F3A5"}.mdi-numeric-1-box-outline::before{content:"\F3A6"}.mdi-numeric-1-circle::before{content:"\FC7C"}.mdi-numeric-1-circle-outline::before{content:"\FC7D"}.mdi-numeric-10-box::before{content:"\FF9A"}.mdi-numeric-10-box-outline::before{content:"\FF9B"}.mdi-numeric-2::before{content:"\32"}.mdi-numeric-2-box::before{content:"\F3A7"}.mdi-numeric-2-box-multiple::before{content:"\FF2D"}.mdi-numeric-2-box-multiple-outline::before{content:"\F3A8"}.mdi-numeric-2-box-outline::before{content:"\F3A9"}.mdi-numeric-2-circle::before{content:"\FC7E"}.mdi-numeric-2-circle-outline::before{content:"\FC7F"}.mdi-numeric-3::before{content:"\33"}.mdi-numeric-3-box::before{content:"\F3AA"}.mdi-numeric-3-box-multiple::before{content:"\FF2E"}.mdi-numeric-3-box-multiple-outline::before{content:"\F3AB"}.mdi-numeric-3-box-outline::before{content:"\F3AC"}.mdi-numeric-3-circle::before{content:"\FC80"}.mdi-numeric-3-circle-outline::before{content:"\FC81"}.mdi-numeric-4::before{content:"\34"}.mdi-numeric-4-box::before{content:"\F3AD"}.mdi-numeric-4-box-multiple::before{content:"\FF2F"}.mdi-numeric-4-box-multiple-outline::before{content:"\F3AE"}.mdi-numeric-4-box-outline::before{content:"\F3AF"}.mdi-numeric-4-circle::before{content:"\FC82"}.mdi-numeric-4-circle-outline::before{content:"\FC83"}.mdi-numeric-5::before{content:"\35"}.mdi-numeric-5-box::before{content:"\F3B0"}.mdi-numeric-5-box-multiple::before{content:"\FF30"}.mdi-numeric-5-box-multiple-outline::before{content:"\F3B1"}.mdi-numeric-5-box-outline::before{content:"\F3B2"}.mdi-numeric-5-circle::before{content:"\FC84"}.mdi-numeric-5-circle-outline::before{content:"\FC85"}.mdi-numeric-6::before{content:"\36"}.mdi-numeric-6-box::before{content:"\F3B3"}.mdi-numeric-6-box-multiple::before{content:"\FF31"}.mdi-numeric-6-box-multiple-outline::before{content:"\F3B4"}.mdi-numeric-6-box-outline::before{content:"\F3B5"}.mdi-numeric-6-circle::before{content:"\FC86"}.mdi-numeric-6-circle-outline::before{content:"\FC87"}.mdi-numeric-7::before{content:"\37"}.mdi-numeric-7-box::before{content:"\F3B6"}.mdi-numeric-7-box-multiple::before{content:"\FF32"}.mdi-numeric-7-box-multiple-outline::before{content:"\F3B7"}.mdi-numeric-7-box-outline::before{content:"\F3B8"}.mdi-numeric-7-circle::before{content:"\FC88"}.mdi-numeric-7-circle-outline::before{content:"\FC89"}.mdi-numeric-8::before{content:"\38"}.mdi-numeric-8-box::before{content:"\F3B9"}.mdi-numeric-8-box-multiple::before{content:"\FF33"}.mdi-numeric-8-box-multiple-outline::before{content:"\F3BA"}.mdi-numeric-8-box-outline::before{content:"\F3BB"}.mdi-numeric-8-circle::before{content:"\FC8A"}.mdi-numeric-8-circle-outline::before{content:"\FC8B"}.mdi-numeric-9::before{content:"\39"}.mdi-numeric-9-box::before{content:"\F3BC"}.mdi-numeric-9-box-multiple::before{content:"\FF34"}.mdi-numeric-9-box-multiple-outline::before{content:"\F3BD"}.mdi-numeric-9-box-outline::before{content:"\F3BE"}.mdi-numeric-9-circle::before{content:"\FC8C"}.mdi-numeric-9-circle-outline::before{content:"\FC8D"}.mdi-numeric-9-plus-box::before{content:"\F3BF"}.mdi-numeric-9-plus-box-multiple::before{content:"\FF35"}.mdi-numeric-9-plus-box-multiple-outline::before{content:"\F3C0"}.mdi-numeric-9-plus-box-outline::before{content:"\F3C1"}.mdi-numeric-9-plus-circle::before{content:"\FC8E"}.mdi-numeric-9-plus-circle-outline::before{content:"\FC8F"}.mdi-nut::before{content:"\F6F7"}.mdi-nutrition::before{content:"\F3C2"}.mdi-oar::before{content:"\F67B"}.mdi-ocarina::before{content:"\FDBC"}.mdi-octagon::before{content:"\F3C3"}.mdi-octagon-outline::before{content:"\F3C4"}.mdi-octagram::before{content:"\F6F8"}.mdi-octagram-outline::before{content:"\F774"}.mdi-odnoklassniki::before{content:"\F3C5"}.mdi-office::before{content:"\F3C6"}.mdi-office-building::before{content:"\F990"}.mdi-oil::before{content:"\F3C7"}.mdi-oil-lamp::before{content:"\FF36"}.mdi-oil-temperature::before{content:"\F3C8"}.mdi-omega::before{content:"\F3C9"}.mdi-one-up::before{content:"\FB89"}.mdi-onedrive::before{content:"\F3CA"}.mdi-onenote::before{content:"\F746"}.mdi-onepassword::before{content:"\F880"}.mdi-opacity::before{content:"\F5CC"}.mdi-open-in-app::before{content:"\F3CB"}.mdi-open-in-new::before{content:"\F3CC"}.mdi-open-source-initiative::before{content:"\FB8A"}.mdi-openid::before{content:"\F3CD"}.mdi-opera::before{content:"\F3CE"}.mdi-orbit::before{content:"\F018"}.mdi-origin::before{content:"\FB2B"}.mdi-ornament::before{content:"\F3CF"}.mdi-ornament-variant::before{content:"\F3D0"}.mdi-outlook::before{content:"\FCFE"}.mdi-owl::before{content:"\F3D2"}.mdi-pac-man::before{content:"\FB8B"}.mdi-package::before{content:"\F3D3"}.mdi-package-down::before{content:"\F3D4"}.mdi-package-up::before{content:"\F3D5"}.mdi-package-variant::before{content:"\F3D6"}.mdi-package-variant-closed::before{content:"\F3D7"}.mdi-page-first::before{content:"\F600"}.mdi-page-last::before{content:"\F601"}.mdi-page-layout-body::before{content:"\F6F9"}.mdi-page-layout-footer::before{content:"\F6FA"}.mdi-page-layout-header::before{content:"\F6FB"}.mdi-page-layout-header-footer::before{content:"\FF9C"}.mdi-page-layout-sidebar-left::before{content:"\F6FC"}.mdi-page-layout-sidebar-right::before{content:"\F6FD"}.mdi-page-next::before{content:"\FB8C"}.mdi-page-next-outline::before{content:"\FB8D"}.mdi-page-previous::before{content:"\FB8E"}.mdi-page-previous-outline::before{content:"\FB8F"}.mdi-palette::before{content:"\F3D8"}.mdi-palette-advanced::before{content:"\F3D9"}.mdi-palette-outline::before{content:"\FE6C"}.mdi-palette-swatch::before{content:"\F8B4"}.mdi-pan::before{content:"\FB90"}.mdi-pan-bottom-left::before{content:"\FB91"}.mdi-pan-bottom-right::before{content:"\FB92"}.mdi-pan-down::before{content:"\FB93"}.mdi-pan-horizontal::before{content:"\FB94"}.mdi-pan-left::before{content:"\FB95"}.mdi-pan-right::before{content:"\FB96"}.mdi-pan-top-left::before{content:"\FB97"}.mdi-pan-top-right::before{content:"\FB98"}.mdi-pan-up::before{content:"\FB99"}.mdi-pan-vertical::before{content:"\FB9A"}.mdi-panda::before{content:"\F3DA"}.mdi-pandora::before{content:"\F3DB"}.mdi-panorama::before{content:"\F3DC"}.mdi-panorama-fisheye::before{content:"\F3DD"}.mdi-panorama-horizontal::before{content:"\F3DE"}.mdi-panorama-vertical::before{content:"\F3DF"}.mdi-panorama-wide-angle::before{content:"\F3E0"}.mdi-paper-cut-vertical::before{content:"\F3E1"}.mdi-paperclip::before{content:"\F3E2"}.mdi-parachute::before{content:"\FC90"}.mdi-parachute-outline::before{content:"\FC91"}.mdi-parking::before{content:"\F3E3"}.mdi-passport::before{content:"\F7E2"}.mdi-passport-biometric::before{content:"\FDBD"}.mdi-patio-heater::before{content:"\FF9D"}.mdi-patreon::before{content:"\F881"}.mdi-pause::before{content:"\F3E4"}.mdi-pause-circle::before{content:"\F3E5"}.mdi-pause-circle-outline::before{content:"\F3E6"}.mdi-pause-octagon::before{content:"\F3E7"}.mdi-pause-octagon-outline::before{content:"\F3E8"}.mdi-paw::before{content:"\F3E9"}.mdi-paw-off::before{content:"\F657"}.mdi-paypal::before{content:"\F882"}.mdi-pdf-box::before{content:"\FE39"}.mdi-peace::before{content:"\F883"}.mdi-pen::before{content:"\F3EA"}.mdi-pen-lock::before{content:"\FDBE"}.mdi-pen-minus::before{content:"\FDBF"}.mdi-pen-off::before{content:"\FDC0"}.mdi-pen-plus::before{content:"\FDC1"}.mdi-pen-remove::before{content:"\FDC2"}.mdi-pencil::before{content:"\F3EB"}.mdi-pencil-box::before{content:"\F3EC"}.mdi-pencil-box-outline::before{content:"\F3ED"}.mdi-pencil-circle::before{content:"\F6FE"}.mdi-pencil-circle-outline::before{content:"\F775"}.mdi-pencil-lock::before{content:"\F3EE"}.mdi-pencil-lock-outline::before{content:"\FDC3"}.mdi-pencil-minus::before{content:"\FDC4"}.mdi-pencil-minus-outline::before{content:"\FDC5"}.mdi-pencil-off::before{content:"\F3EF"}.mdi-pencil-off-outline::before{content:"\FDC6"}.mdi-pencil-outline::before{content:"\FC92"}.mdi-pencil-plus::before{content:"\FDC7"}.mdi-pencil-plus-outline::before{content:"\FDC8"}.mdi-pencil-remove::before{content:"\FDC9"}.mdi-pencil-remove-outline::before{content:"\FDCA"}.mdi-penguin::before{content:"\FEDD"}.mdi-pentagon::before{content:"\F6FF"}.mdi-pentagon-outline::before{content:"\F700"}.mdi-percent::before{content:"\F3F0"}.mdi-periodic-table::before{content:"\F8B5"}.mdi-periodic-table-co2::before{content:"\F7E3"}.mdi-periscope::before{content:"\F747"}.mdi-perspective-less::before{content:"\FCFF"}.mdi-perspective-more::before{content:"\FD00"}.mdi-pharmacy::before{content:"\F3F1"}.mdi-phone::before{content:"\F3F2"}.mdi-phone-alert::before{content:"\FF37"}.mdi-phone-bluetooth::before{content:"\F3F3"}.mdi-phone-classic::before{content:"\F602"}.mdi-phone-forward::before{content:"\F3F4"}.mdi-phone-hangup::before{content:"\F3F5"}.mdi-phone-in-talk::before{content:"\F3F6"}.mdi-phone-incoming::before{content:"\F3F7"}.mdi-phone-lock::before{content:"\F3F8"}.mdi-phone-log::before{content:"\F3F9"}.mdi-phone-minus::before{content:"\F658"}.mdi-phone-missed::before{content:"\F3FA"}.mdi-phone-off::before{content:"\FDCB"}.mdi-phone-outgoing::before{content:"\F3FB"}.mdi-phone-outline::before{content:"\FDCC"}.mdi-phone-paused::before{content:"\F3FC"}.mdi-phone-plus::before{content:"\F659"}.mdi-phone-return::before{content:"\F82E"}.mdi-phone-rotate-landscape::before{content:"\F884"}.mdi-phone-rotate-portrait::before{content:"\F885"}.mdi-phone-settings::before{content:"\F3FD"}.mdi-phone-voip::before{content:"\F3FE"}.mdi-pi::before{content:"\F3FF"}.mdi-pi-box::before{content:"\F400"}.mdi-pi-hole::before{content:"\FDCD"}.mdi-piano::before{content:"\F67C"}.mdi-pickaxe::before{content:"\F8B6"}.mdi-picture-in-picture-bottom-right::before{content:"\FE3A"}.mdi-picture-in-picture-bottom-right-outline::before{content:"\FE3B"}.mdi-picture-in-picture-top-right::before{content:"\FE3C"}.mdi-picture-in-picture-top-right-outline::before{content:"\FE3D"}.mdi-pier::before{content:"\F886"}.mdi-pier-crane::before{content:"\F887"}.mdi-pig::before{content:"\F401"}.mdi-pill::before{content:"\F402"}.mdi-pillar::before{content:"\F701"}.mdi-pin::before{content:"\F403"}.mdi-pin-off::before{content:"\F404"}.mdi-pin-off-outline::before{content:"\F92F"}.mdi-pin-outline::before{content:"\F930"}.mdi-pine-tree::before{content:"\F405"}.mdi-pine-tree-box::before{content:"\F406"}.mdi-pinterest::before{content:"\F407"}.mdi-pinterest-box::before{content:"\F408"}.mdi-pinwheel::before{content:"\FAD4"}.mdi-pinwheel-outline::before{content:"\FAD5"}.mdi-pipe::before{content:"\F7E4"}.mdi-pipe-disconnected::before{content:"\F7E5"}.mdi-pipe-leak::before{content:"\F888"}.mdi-pirate::before{content:"\FA07"}.mdi-pistol::before{content:"\F702"}.mdi-piston::before{content:"\F889"}.mdi-pizza::before{content:"\F409"}.mdi-play::before{content:"\F40A"}.mdi-play-box-outline::before{content:"\F40B"}.mdi-play-circle::before{content:"\F40C"}.mdi-play-circle-outline::before{content:"\F40D"}.mdi-play-network::before{content:"\F88A"}.mdi-play-network-outline::before{content:"\FC93"}.mdi-play-outline::before{content:"\FF38"}.mdi-play-pause::before{content:"\F40E"}.mdi-play-protected-content::before{content:"\F40F"}.mdi-play-speed::before{content:"\F8FE"}.mdi-playlist-check::before{content:"\F5C7"}.mdi-playlist-edit::before{content:"\F8FF"}.mdi-playlist-minus::before{content:"\F410"}.mdi-playlist-music::before{content:"\FC94"}.mdi-playlist-music-outline::before{content:"\FC95"}.mdi-playlist-play::before{content:"\F411"}.mdi-playlist-plus::before{content:"\F412"}.mdi-playlist-remove::before{content:"\F413"}.mdi-playlist-star::before{content:"\FDCE"}.mdi-playstation::before{content:"\F414"}.mdi-plex::before{content:"\F6B9"}.mdi-plus::before{content:"\F415"}.mdi-plus-box::before{content:"\F416"}.mdi-plus-box-outline::before{content:"\F703"}.mdi-plus-circle::before{content:"\F417"}.mdi-plus-circle-multiple-outline::before{content:"\F418"}.mdi-plus-circle-outline::before{content:"\F419"}.mdi-plus-minus::before{content:"\F991"}.mdi-plus-minus-box::before{content:"\F992"}.mdi-plus-network::before{content:"\F41A"}.mdi-plus-network-outline::before{content:"\FC96"}.mdi-plus-one::before{content:"\F41B"}.mdi-plus-outline::before{content:"\F704"}.mdi-pocket::before{content:"\F41C"}.mdi-podcast::before{content:"\F993"}.mdi-podium::before{content:"\FD01"}.mdi-podium-bronze::before{content:"\FD02"}.mdi-podium-gold::before{content:"\FD03"}.mdi-podium-silver::before{content:"\FD04"}.mdi-point-of-sale::before{content:"\FD6E"}.mdi-pokeball::before{content:"\F41D"}.mdi-pokemon-go::before{content:"\FA08"}.mdi-poker-chip::before{content:"\F82F"}.mdi-polaroid::before{content:"\F41E"}.mdi-poll::before{content:"\F41F"}.mdi-poll-box::before{content:"\F420"}.mdi-polymer::before{content:"\F421"}.mdi-pool::before{content:"\F606"}.mdi-popcorn::before{content:"\F422"}.mdi-postage-stamp::before{content:"\FC97"}.mdi-pot::before{content:"\F65A"}.mdi-pot-mix::before{content:"\F65B"}.mdi-pound::before{content:"\F423"}.mdi-pound-box::before{content:"\F424"}.mdi-power::before{content:"\F425"}.mdi-power-cycle::before{content:"\F900"}.mdi-power-off::before{content:"\F901"}.mdi-power-on::before{content:"\F902"}.mdi-power-plug::before{content:"\F6A4"}.mdi-power-plug-off::before{content:"\F6A5"}.mdi-power-settings::before{content:"\F426"}.mdi-power-sleep::before{content:"\F903"}.mdi-power-socket::before{content:"\F427"}.mdi-power-socket-au::before{content:"\F904"}.mdi-power-socket-eu::before{content:"\F7E6"}.mdi-power-socket-uk::before{content:"\F7E7"}.mdi-power-socket-us::before{content:"\F7E8"}.mdi-power-standby::before{content:"\F905"}.mdi-powershell::before{content:"\FA09"}.mdi-prescription::before{content:"\F705"}.mdi-presentation::before{content:"\F428"}.mdi-presentation-play::before{content:"\F429"}.mdi-printer::before{content:"\F42A"}.mdi-printer-3d::before{content:"\F42B"}.mdi-printer-3d-nozzle::before{content:"\FE3E"}.mdi-printer-3d-nozzle-outline::before{content:"\FE3F"}.mdi-printer-alert::before{content:"\F42C"}.mdi-printer-off::before{content:"\FE40"}.mdi-printer-settings::before{content:"\F706"}.mdi-printer-wireless::before{content:"\FA0A"}.mdi-priority-high::before{content:"\F603"}.mdi-priority-low::before{content:"\F604"}.mdi-professional-hexagon::before{content:"\F42D"}.mdi-progress-alert::before{content:"\FC98"}.mdi-progress-check::before{content:"\F994"}.mdi-progress-clock::before{content:"\F995"}.mdi-progress-download::before{content:"\F996"}.mdi-progress-upload::before{content:"\F997"}.mdi-progress-wrench::before{content:"\FC99"}.mdi-projector::before{content:"\F42E"}.mdi-projector-screen::before{content:"\F42F"}.mdi-publish::before{content:"\F6A6"}.mdi-pulse::before{content:"\F430"}.mdi-pumpkin::before{content:"\FB9B"}.mdi-purse::before{content:"\FF39"}.mdi-purse-outline::before{content:"\FF3A"}.mdi-puzzle::before{content:"\F431"}.mdi-puzzle-outline::before{content:"\FA65"}.mdi-qi::before{content:"\F998"}.mdi-qqchat::before{content:"\F605"}.mdi-qrcode::before{content:"\F432"}.mdi-qrcode-edit::before{content:"\F8B7"}.mdi-qrcode-scan::before{content:"\F433"}.mdi-quadcopter::before{content:"\F434"}.mdi-quality-high::before{content:"\F435"}.mdi-quality-low::before{content:"\FA0B"}.mdi-quality-medium::before{content:"\FA0C"}.mdi-quicktime::before{content:"\F436"}.mdi-quora::before{content:"\FD05"}.mdi-rabbit::before{content:"\F906"}.mdi-racing-helmet::before{content:"\FD6F"}.mdi-racquetball::before{content:"\FD70"}.mdi-radar::before{content:"\F437"}.mdi-radiator::before{content:"\F438"}.mdi-radiator-disabled::before{content:"\FAD6"}.mdi-radiator-off::before{content:"\FAD7"}.mdi-radio::before{content:"\F439"}.mdi-radio-am::before{content:"\FC9A"}.mdi-radio-fm::before{content:"\FC9B"}.mdi-radio-handheld::before{content:"\F43A"}.mdi-radio-tower::before{content:"\F43B"}.mdi-radioactive::before{content:"\F43C"}.mdi-radioactive-off::before{content:"\FEDE"}.mdi-radiobox-blank::before{content:"\F43D"}.mdi-radiobox-marked::before{content:"\F43E"}.mdi-radius::before{content:"\FC9C"}.mdi-radius-outline::before{content:"\FC9D"}.mdi-railroad-light::before{content:"\FF3B"}.mdi-raspberry-pi::before{content:"\F43F"}.mdi-ray-end::before{content:"\F440"}.mdi-ray-end-arrow::before{content:"\F441"}.mdi-ray-start::before{content:"\F442"}.mdi-ray-start-arrow::before{content:"\F443"}.mdi-ray-start-end::before{content:"\F444"}.mdi-ray-vertex::before{content:"\F445"}.mdi-react::before{content:"\F707"}.mdi-read::before{content:"\F447"}.mdi-receipt::before{content:"\F449"}.mdi-record::before{content:"\F44A"}.mdi-record-circle::before{content:"\FEDF"}.mdi-record-circle-outline::before{content:"\FEE0"}.mdi-record-player::before{content:"\F999"}.mdi-record-rec::before{content:"\F44B"}.mdi-rectangle::before{content:"\FE41"}.mdi-rectangle-outline::before{content:"\FE42"}.mdi-recycle::before{content:"\F44C"}.mdi-reddit::before{content:"\F44D"}.mdi-redo::before{content:"\F44E"}.mdi-redo-variant::before{content:"\F44F"}.mdi-reflect-horizontal::before{content:"\FA0D"}.mdi-reflect-vertical::before{content:"\FA0E"}.mdi-refresh::before{content:"\F450"}.mdi-regex::before{content:"\F451"}.mdi-registered-trademark::before{content:"\FA66"}.mdi-relative-scale::before{content:"\F452"}.mdi-reload::before{content:"\F453"}.mdi-reminder::before{content:"\F88B"}.mdi-remote::before{content:"\F454"}.mdi-remote-desktop::before{content:"\F8B8"}.mdi-remote-off::before{content:"\FEE1"}.mdi-remote-tv::before{content:"\FEE2"}.mdi-remote-tv-off::before{content:"\FEE3"}.mdi-rename-box::before{content:"\F455"}.mdi-reorder-horizontal::before{content:"\F687"}.mdi-reorder-vertical::before{content:"\F688"}.mdi-repeat::before{content:"\F456"}.mdi-repeat-off::before{content:"\F457"}.mdi-repeat-once::before{content:"\F458"}.mdi-replay::before{content:"\F459"}.mdi-reply::before{content:"\F45A"}.mdi-reply-all::before{content:"\F45B"}.mdi-reply-all-outline::before{content:"\FF3C"}.mdi-reply-outline::before{content:"\FF3D"}.mdi-reproduction::before{content:"\F45C"}.mdi-resistor::before{content:"\FB1F"}.mdi-resistor-nodes::before{content:"\FB20"}.mdi-resize::before{content:"\FA67"}.mdi-resize-bottom-right::before{content:"\F45D"}.mdi-responsive::before{content:"\F45E"}.mdi-restart::before{content:"\F708"}.mdi-restart-off::before{content:"\FD71"}.mdi-restore::before{content:"\F99A"}.mdi-restore-clock::before{content:"\F6A7"}.mdi-rewind::before{content:"\F45F"}.mdi-rewind-10::before{content:"\FD06"}.mdi-rewind-30::before{content:"\FD72"}.mdi-rewind-outline::before{content:"\F709"}.mdi-rhombus::before{content:"\F70A"}.mdi-rhombus-medium::before{content:"\FA0F"}.mdi-rhombus-outline::before{content:"\F70B"}.mdi-rhombus-split::before{content:"\FA10"}.mdi-ribbon::before{content:"\F460"}.mdi-rice::before{content:"\F7E9"}.mdi-ring::before{content:"\F7EA"}.mdi-rivet::before{content:"\FE43"}.mdi-road::before{content:"\F461"}.mdi-road-variant::before{content:"\F462"}.mdi-robot::before{content:"\F6A8"}.mdi-robot-industrial::before{content:"\FB21"}.mdi-robot-vacuum::before{content:"\F70C"}.mdi-robot-vacuum-variant::before{content:"\F907"}.mdi-rocket::before{content:"\F463"}.mdi-roller-skate::before{content:"\FD07"}.mdi-rollerblade::before{content:"\FD08"}.mdi-rollupjs::before{content:"\FB9C"}.mdi-room-service::before{content:"\F88C"}.mdi-room-service-outline::before{content:"\FD73"}.mdi-rotate-3d::before{content:"\FEE4"}.mdi-rotate-3d-variant::before{content:"\F464"}.mdi-rotate-left::before{content:"\F465"}.mdi-rotate-left-variant::before{content:"\F466"}.mdi-rotate-orbit::before{content:"\FD74"}.mdi-rotate-right::before{content:"\F467"}.mdi-rotate-right-variant::before{content:"\F468"}.mdi-rounded-corner::before{content:"\F607"}.mdi-router-wireless::before{content:"\F469"}.mdi-router-wireless-settings::before{content:"\FA68"}.mdi-routes::before{content:"\F46A"}.mdi-rowing::before{content:"\F608"}.mdi-rss::before{content:"\F46B"}.mdi-rss-box::before{content:"\F46C"}.mdi-rss-off::before{content:"\FF3E"}.mdi-ruby::before{content:"\FD09"}.mdi-rugby::before{content:"\FD75"}.mdi-ruler::before{content:"\F46D"}.mdi-ruler-square::before{content:"\FC9E"}.mdi-run::before{content:"\F70D"}.mdi-run-fast::before{content:"\F46E"}.mdi-sack::before{content:"\FD0A"}.mdi-sack-percent::before{content:"\FD0B"}.mdi-safe::before{content:"\FA69"}.mdi-safety-goggles::before{content:"\FD0C"}.mdi-sailing::before{content:"\FEE5"}.mdi-sale::before{content:"\F46F"}.mdi-salesforce::before{content:"\F88D"}.mdi-sass::before{content:"\F7EB"}.mdi-satellite::before{content:"\F470"}.mdi-satellite-uplink::before{content:"\F908"}.mdi-satellite-variant::before{content:"\F471"}.mdi-sausage::before{content:"\F8B9"}.mdi-saw-blade::before{content:"\FE44"}.mdi-saxophone::before{content:"\F609"}.mdi-scale::before{content:"\F472"}.mdi-scale-balance::before{content:"\F5D1"}.mdi-scale-bathroom::before{content:"\F473"}.mdi-scanner::before{content:"\F6AA"}.mdi-scanner-off::before{content:"\F909"}.mdi-scatter-plot::before{content:"\FEE6"}.mdi-scatter-plot-outline::before{content:"\FEE7"}.mdi-school::before{content:"\F474"}.mdi-scissors-cutting::before{content:"\FA6A"}.mdi-screen-rotation::before{content:"\F475"}.mdi-screen-rotation-lock::before{content:"\F476"}.mdi-screw-flat-top::before{content:"\FDCF"}.mdi-screw-lag::before{content:"\FE54"}.mdi-screw-machine-flat-top::before{content:"\FE55"}.mdi-screw-machine-round-top::before{content:"\FE56"}.mdi-screw-round-top::before{content:"\FE57"}.mdi-screwdriver::before{content:"\F477"}.mdi-script::before{content:"\FB9D"}.mdi-script-outline::before{content:"\F478"}.mdi-script-text::before{content:"\FB9E"}.mdi-script-text-outline::before{content:"\FB9F"}.mdi-sd::before{content:"\F479"}.mdi-seal::before{content:"\F47A"}.mdi-search-web::before{content:"\F70E"}.mdi-seat::before{content:"\FC9F"}.mdi-seat-flat::before{content:"\F47B"}.mdi-seat-flat-angled::before{content:"\F47C"}.mdi-seat-individual-suite::before{content:"\F47D"}.mdi-seat-legroom-extra::before{content:"\F47E"}.mdi-seat-legroom-normal::before{content:"\F47F"}.mdi-seat-legroom-reduced::before{content:"\F480"}.mdi-seat-outline::before{content:"\FCA0"}.mdi-seat-recline-extra::before{content:"\F481"}.mdi-seat-recline-normal::before{content:"\F482"}.mdi-seatbelt::before{content:"\FCA1"}.mdi-security::before{content:"\F483"}.mdi-security-network::before{content:"\F484"}.mdi-seed::before{content:"\FE45"}.mdi-seed-outline::before{content:"\FE46"}.mdi-segment::before{content:"\FEE8"}.mdi-select::before{content:"\F485"}.mdi-select-all::before{content:"\F486"}.mdi-select-color::before{content:"\FD0D"}.mdi-select-compare::before{content:"\FAD8"}.mdi-select-drag::before{content:"\FA6B"}.mdi-select-group::before{content:"\FF9F"}.mdi-select-inverse::before{content:"\F487"}.mdi-select-off::before{content:"\F488"}.mdi-selection::before{content:"\F489"}.mdi-selection-drag::before{content:"\FA6C"}.mdi-selection-ellipse::before{content:"\FD0E"}.mdi-selection-ellipse-arrow-inside::before{content:"\FF3F"}.mdi-selection-off::before{content:"\F776"}.mdi-send::before{content:"\F48A"}.mdi-send-circle::before{content:"\FE58"}.mdi-send-circle-outline::before{content:"\FE59"}.mdi-send-lock::before{content:"\F7EC"}.mdi-serial-port::before{content:"\F65C"}.mdi-server::before{content:"\F48B"}.mdi-server-minus::before{content:"\F48C"}.mdi-server-network::before{content:"\F48D"}.mdi-server-network-off::before{content:"\F48E"}.mdi-server-off::before{content:"\F48F"}.mdi-server-plus::before{content:"\F490"}.mdi-server-remove::before{content:"\F491"}.mdi-server-security::before{content:"\F492"}.mdi-set-all::before{content:"\F777"}.mdi-set-center::before{content:"\F778"}.mdi-set-center-right::before{content:"\F779"}.mdi-set-left::before{content:"\F77A"}.mdi-set-left-center::before{content:"\F77B"}.mdi-set-left-right::before{content:"\F77C"}.mdi-set-none::before{content:"\F77D"}.mdi-set-right::before{content:"\F77E"}.mdi-set-top-box::before{content:"\F99E"}.mdi-settings::before{content:"\F493"}.mdi-settings-box::before{content:"\F494"}.mdi-settings-helper::before{content:"\FA6D"}.mdi-settings-outline::before{content:"\F8BA"}.mdi-shape::before{content:"\F830"}.mdi-shape-circle-plus::before{content:"\F65D"}.mdi-shape-outline::before{content:"\F831"}.mdi-shape-plus::before{content:"\F495"}.mdi-shape-polygon-plus::before{content:"\F65E"}.mdi-shape-rectangle-plus::before{content:"\F65F"}.mdi-shape-square-plus::before{content:"\F660"}.mdi-share::before{content:"\F496"}.mdi-share-off::before{content:"\FF40"}.mdi-share-off-outline::before{content:"\FF41"}.mdi-share-outline::before{content:"\F931"}.mdi-share-variant::before{content:"\F497"}.mdi-sheep::before{content:"\FCA2"}.mdi-shield::before{content:"\F498"}.mdi-shield-account::before{content:"\F88E"}.mdi-shield-account-outline::before{content:"\FA11"}.mdi-shield-airplane::before{content:"\F6BA"}.mdi-shield-airplane-outline::before{content:"\FCA3"}.mdi-shield-alert::before{content:"\FEE9"}.mdi-shield-alert-outline::before{content:"\FEEA"}.mdi-shield-car::before{content:"\FFA0"}.mdi-shield-check::before{content:"\F565"}.mdi-shield-check-outline::before{content:"\FCA4"}.mdi-shield-cross::before{content:"\FCA5"}.mdi-shield-cross-outline::before{content:"\FCA6"}.mdi-shield-half-full::before{content:"\F77F"}.mdi-shield-home::before{content:"\F689"}.mdi-shield-home-outline::before{content:"\FCA7"}.mdi-shield-key::before{content:"\FBA0"}.mdi-shield-key-outline::before{content:"\FBA1"}.mdi-shield-link-variant::before{content:"\FD0F"}.mdi-shield-link-variant-outline::before{content:"\FD10"}.mdi-shield-lock::before{content:"\F99C"}.mdi-shield-lock-outline::before{content:"\FCA8"}.mdi-shield-off::before{content:"\F99D"}.mdi-shield-off-outline::before{content:"\F99B"}.mdi-shield-outline::before{content:"\F499"}.mdi-shield-plus::before{content:"\FAD9"}.mdi-shield-plus-outline::before{content:"\FADA"}.mdi-shield-remove::before{content:"\FADB"}.mdi-shield-remove-outline::before{content:"\FADC"}.mdi-shield-search::before{content:"\FD76"}.mdi-ship-wheel::before{content:"\F832"}.mdi-shoe-formal::before{content:"\FB22"}.mdi-shoe-heel::before{content:"\FB23"}.mdi-shoe-print::before{content:"\FE5A"}.mdi-shopify::before{content:"\FADD"}.mdi-shopping::before{content:"\F49A"}.mdi-shopping-music::before{content:"\F49B"}.mdi-shopping-search::before{content:"\FFA1"}.mdi-shovel::before{content:"\F70F"}.mdi-shovel-off::before{content:"\F710"}.mdi-shower::before{content:"\F99F"}.mdi-shower-head::before{content:"\F9A0"}.mdi-shredder::before{content:"\F49C"}.mdi-shuffle::before{content:"\F49D"}.mdi-shuffle-disabled::before{content:"\F49E"}.mdi-shuffle-variant::before{content:"\F49F"}.mdi-sigma::before{content:"\F4A0"}.mdi-sigma-lower::before{content:"\F62B"}.mdi-sign-caution::before{content:"\F4A1"}.mdi-sign-direction::before{content:"\F780"}.mdi-sign-text::before{content:"\F781"}.mdi-signal::before{content:"\F4A2"}.mdi-signal-2g::before{content:"\F711"}.mdi-signal-3g::before{content:"\F712"}.mdi-signal-4g::before{content:"\F713"}.mdi-signal-5g::before{content:"\FA6E"}.mdi-signal-cellular-1::before{content:"\F8BB"}.mdi-signal-cellular-2::before{content:"\F8BC"}.mdi-signal-cellular-3::before{content:"\F8BD"}.mdi-signal-cellular-outline::before{content:"\F8BE"}.mdi-signal-distance-variant::before{content:"\FE47"}.mdi-signal-hspa::before{content:"\F714"}.mdi-signal-hspa-plus::before{content:"\F715"}.mdi-signal-off::before{content:"\F782"}.mdi-signal-variant::before{content:"\F60A"}.mdi-signature::before{content:"\FE5B"}.mdi-signature-freehand::before{content:"\FE5C"}.mdi-signature-image::before{content:"\FE5D"}.mdi-signature-text::before{content:"\FE5E"}.mdi-silo::before{content:"\FB24"}.mdi-silverware::before{content:"\F4A3"}.mdi-silverware-fork::before{content:"\F4A4"}.mdi-silverware-fork-knife::before{content:"\FA6F"}.mdi-silverware-spoon::before{content:"\F4A5"}.mdi-silverware-variant::before{content:"\F4A6"}.mdi-sim::before{content:"\F4A7"}.mdi-sim-alert::before{content:"\F4A8"}.mdi-sim-off::before{content:"\F4A9"}.mdi-sina-weibo::before{content:"\FADE"}.mdi-sitemap::before{content:"\F4AA"}.mdi-skate::before{content:"\FD11"}.mdi-skew-less::before{content:"\FD12"}.mdi-skew-more::before{content:"\FD13"}.mdi-skip-backward::before{content:"\F4AB"}.mdi-skip-backward-outline::before{content:"\FF42"}.mdi-skip-forward::before{content:"\F4AC"}.mdi-skip-forward-outline::before{content:"\FF43"}.mdi-skip-next::before{content:"\F4AD"}.mdi-skip-next-circle::before{content:"\F661"}.mdi-skip-next-circle-outline::before{content:"\F662"}.mdi-skip-next-outline::before{content:"\FF44"}.mdi-skip-previous::before{content:"\F4AE"}.mdi-skip-previous-circle::before{content:"\F663"}.mdi-skip-previous-circle-outline::before{content:"\F664"}.mdi-skip-previous-outline::before{content:"\FF45"}.mdi-skull::before{content:"\F68B"}.mdi-skull-crossbones::before{content:"\FBA2"}.mdi-skull-crossbones-outline::before{content:"\FBA3"}.mdi-skull-outline::before{content:"\FBA4"}.mdi-skype::before{content:"\F4AF"}.mdi-skype-business::before{content:"\F4B0"}.mdi-slack::before{content:"\F4B1"}.mdi-slackware::before{content:"\F90A"}.mdi-sleep::before{content:"\F4B2"}.mdi-sleep-off::before{content:"\F4B3"}.mdi-slope-downhill::before{content:"\FE5F"}.mdi-slope-uphill::before{content:"\FE60"}.mdi-smog::before{content:"\FA70"}.mdi-smoke-detector::before{content:"\F392"}.mdi-smoking::before{content:"\F4B4"}.mdi-smoking-off::before{content:"\F4B5"}.mdi-snapchat::before{content:"\F4B6"}.mdi-snowflake::before{content:"\F716"}.mdi-snowflake-alert::before{content:"\FF46"}.mdi-snowflake-variant::before{content:"\FF47"}.mdi-snowman::before{content:"\F4B7"}.mdi-soccer::before{content:"\F4B8"}.mdi-soccer-field::before{content:"\F833"}.mdi-sofa::before{content:"\F4B9"}.mdi-solar-panel::before{content:"\FD77"}.mdi-solar-panel-large::before{content:"\FD78"}.mdi-solar-power::before{content:"\FA71"}.mdi-solid::before{content:"\F68C"}.mdi-sort::before{content:"\F4BA"}.mdi-sort-alphabetical::before{content:"\F4BB"}.mdi-sort-ascending::before{content:"\F4BC"}.mdi-sort-descending::before{content:"\F4BD"}.mdi-sort-numeric::before{content:"\F4BE"}.mdi-sort-variant::before{content:"\F4BF"}.mdi-sort-variant-lock::before{content:"\FCA9"}.mdi-sort-variant-lock-open::before{content:"\FCAA"}.mdi-soundcloud::before{content:"\F4C0"}.mdi-source-branch::before{content:"\F62C"}.mdi-source-commit::before{content:"\F717"}.mdi-source-commit-end::before{content:"\F718"}.mdi-source-commit-end-local::before{content:"\F719"}.mdi-source-commit-local::before{content:"\F71A"}.mdi-source-commit-next-local::before{content:"\F71B"}.mdi-source-commit-start::before{content:"\F71C"}.mdi-source-commit-start-next-local::before{content:"\F71D"}.mdi-source-fork::before{content:"\F4C1"}.mdi-source-merge::before{content:"\F62D"}.mdi-source-pull::before{content:"\F4C2"}.mdi-source-repository::before{content:"\FCAB"}.mdi-source-repository-multiple::before{content:"\FCAC"}.mdi-soy-sauce::before{content:"\F7ED"}.mdi-spa::before{content:"\FCAD"}.mdi-spa-outline::before{content:"\FCAE"}.mdi-space-invaders::before{content:"\FBA5"}.mdi-spade::before{content:"\FE48"}.mdi-speaker::before{content:"\F4C3"}.mdi-speaker-bluetooth::before{content:"\F9A1"}.mdi-speaker-multiple::before{content:"\FD14"}.mdi-speaker-off::before{content:"\F4C4"}.mdi-speaker-wireless::before{content:"\F71E"}.mdi-speedometer::before{content:"\F4C5"}.mdi-speedometer-medium::before{content:"\FFA2"}.mdi-speedometer-slow::before{content:"\FFA3"}.mdi-spellcheck::before{content:"\F4C6"}.mdi-spider-web::before{content:"\FBA6"}.mdi-spotify::before{content:"\F4C7"}.mdi-spotlight::before{content:"\F4C8"}.mdi-spotlight-beam::before{content:"\F4C9"}.mdi-spray::before{content:"\F665"}.mdi-spray-bottle::before{content:"\FADF"}.mdi-sprout::before{content:"\FE49"}.mdi-sprout-outline::before{content:"\FE4A"}.mdi-square::before{content:"\F763"}.mdi-square-edit-outline::before{content:"\F90B"}.mdi-square-inc::before{content:"\F4CA"}.mdi-square-inc-cash::before{content:"\F4CB"}.mdi-square-medium::before{content:"\FA12"}.mdi-square-medium-outline::before{content:"\FA13"}.mdi-square-outline::before{content:"\F762"}.mdi-square-root::before{content:"\F783"}.mdi-square-root-box::before{content:"\F9A2"}.mdi-square-small::before{content:"\FA14"}.mdi-squeegee::before{content:"\FAE0"}.mdi-ssh::before{content:"\F8BF"}.mdi-stack-exchange::before{content:"\F60B"}.mdi-stack-overflow::before{content:"\F4CC"}.mdi-stadium::before{content:"\F71F"}.mdi-stairs::before{content:"\F4CD"}.mdi-stamper::before{content:"\FD15"}.mdi-standard-definition::before{content:"\F7EE"}.mdi-star::before{content:"\F4CE"}.mdi-star-box::before{content:"\FA72"}.mdi-star-box-outline::before{content:"\FA73"}.mdi-star-circle::before{content:"\F4CF"}.mdi-star-circle-outline::before{content:"\F9A3"}.mdi-star-face::before{content:"\F9A4"}.mdi-star-four-points::before{content:"\FAE1"}.mdi-star-four-points-outline::before{content:"\FAE2"}.mdi-star-half::before{content:"\F4D0"}.mdi-star-off::before{content:"\F4D1"}.mdi-star-outline::before{content:"\F4D2"}.mdi-star-three-points::before{content:"\FAE3"}.mdi-star-three-points-outline::before{content:"\FAE4"}.mdi-steam::before{content:"\F4D3"}.mdi-steam-box::before{content:"\F90C"}.mdi-steering::before{content:"\F4D4"}.mdi-steering-off::before{content:"\F90D"}.mdi-step-backward::before{content:"\F4D5"}.mdi-step-backward-2::before{content:"\F4D6"}.mdi-step-forward::before{content:"\F4D7"}.mdi-step-forward-2::before{content:"\F4D8"}.mdi-stethoscope::before{content:"\F4D9"}.mdi-sticker::before{content:"\F5D0"}.mdi-sticker-emoji::before{content:"\F784"}.mdi-stocking::before{content:"\F4DA"}.mdi-stop::before{content:"\F4DB"}.mdi-stop-circle::before{content:"\F666"}.mdi-stop-circle-outline::before{content:"\F667"}.mdi-store::before{content:"\F4DC"}.mdi-store-24-hour::before{content:"\F4DD"}.mdi-stove::before{content:"\F4DE"}.mdi-strava::before{content:"\FB25"}.mdi-stretch-to-page::before{content:"\FF48"}.mdi-stretch-to-page-outline::before{content:"\FF49"}.mdi-subdirectory-arrow-left::before{content:"\F60C"}.mdi-subdirectory-arrow-right::before{content:"\F60D"}.mdi-subtitles::before{content:"\FA15"}.mdi-subtitles-outline::before{content:"\FA16"}.mdi-subway::before{content:"\F6AB"}.mdi-subway-alert-variant::before{content:"\FD79"}.mdi-subway-variant::before{content:"\F4DF"}.mdi-summit::before{content:"\F785"}.mdi-sunglasses::before{content:"\F4E0"}.mdi-surround-sound::before{content:"\F5C5"}.mdi-surround-sound-2-0::before{content:"\F7EF"}.mdi-surround-sound-3-1::before{content:"\F7F0"}.mdi-surround-sound-5-1::before{content:"\F7F1"}.mdi-surround-sound-7-1::before{content:"\F7F2"}.mdi-svg::before{content:"\F720"}.mdi-swap-horizontal::before{content:"\F4E1"}.mdi-swap-horizontal-bold::before{content:"\FBA9"}.mdi-swap-horizontal-variant::before{content:"\F8C0"}.mdi-swap-vertical::before{content:"\F4E2"}.mdi-swap-vertical-bold::before{content:"\FBAA"}.mdi-swap-vertical-variant::before{content:"\F8C1"}.mdi-swim::before{content:"\F4E3"}.mdi-switch::before{content:"\F4E4"}.mdi-sword::before{content:"\F4E5"}.mdi-sword-cross::before{content:"\F786"}.mdi-symfony::before{content:"\FAE5"}.mdi-sync::before{content:"\F4E6"}.mdi-sync-alert::before{content:"\F4E7"}.mdi-sync-off::before{content:"\F4E8"}.mdi-tab::before{content:"\F4E9"}.mdi-tab-minus::before{content:"\FB26"}.mdi-tab-plus::before{content:"\F75B"}.mdi-tab-remove::before{content:"\FB27"}.mdi-tab-unselected::before{content:"\F4EA"}.mdi-table::before{content:"\F4EB"}.mdi-table-border::before{content:"\FA17"}.mdi-table-column::before{content:"\F834"}.mdi-table-column-plus-after::before{content:"\F4EC"}.mdi-table-column-plus-before::before{content:"\F4ED"}.mdi-table-column-remove::before{content:"\F4EE"}.mdi-table-column-width::before{content:"\F4EF"}.mdi-table-edit::before{content:"\F4F0"}.mdi-table-large::before{content:"\F4F1"}.mdi-table-large-plus::before{content:"\FFA4"}.mdi-table-large-remove::before{content:"\FFA5"}.mdi-table-merge-cells::before{content:"\F9A5"}.mdi-table-of-contents::before{content:"\F835"}.mdi-table-plus::before{content:"\FA74"}.mdi-table-remove::before{content:"\FA75"}.mdi-table-row::before{content:"\F836"}.mdi-table-row-height::before{content:"\F4F2"}.mdi-table-row-plus-after::before{content:"\F4F3"}.mdi-table-row-plus-before::before{content:"\F4F4"}.mdi-table-row-remove::before{content:"\F4F5"}.mdi-table-search::before{content:"\F90E"}.mdi-table-settings::before{content:"\F837"}.mdi-table-tennis::before{content:"\FE4B"}.mdi-tablet::before{content:"\F4F6"}.mdi-tablet-android::before{content:"\F4F7"}.mdi-tablet-cellphone::before{content:"\F9A6"}.mdi-tablet-dashboard::before{content:"\FEEB"}.mdi-tablet-ipad::before{content:"\F4F8"}.mdi-taco::before{content:"\F761"}.mdi-tag::before{content:"\F4F9"}.mdi-tag-faces::before{content:"\F4FA"}.mdi-tag-heart::before{content:"\F68A"}.mdi-tag-heart-outline::before{content:"\FBAB"}.mdi-tag-minus::before{content:"\F90F"}.mdi-tag-multiple::before{content:"\F4FB"}.mdi-tag-outline::before{content:"\F4FC"}.mdi-tag-plus::before{content:"\F721"}.mdi-tag-remove::before{content:"\F722"}.mdi-tag-text-outline::before{content:"\F4FD"}.mdi-tank::before{content:"\FD16"}.mdi-tape-measure::before{content:"\FB28"}.mdi-target::before{content:"\F4FE"}.mdi-target-account::before{content:"\FBAC"}.mdi-target-variant::before{content:"\FA76"}.mdi-taxi::before{content:"\F4FF"}.mdi-tea::before{content:"\FD7A"}.mdi-tea-outline::before{content:"\FD7B"}.mdi-teach::before{content:"\F88F"}.mdi-teamviewer::before{content:"\F500"}.mdi-telegram::before{content:"\F501"}.mdi-telescope::before{content:"\FB29"}.mdi-television::before{content:"\F502"}.mdi-television-box::before{content:"\F838"}.mdi-television-classic::before{content:"\F7F3"}.mdi-television-classic-off::before{content:"\F839"}.mdi-television-guide::before{content:"\F503"}.mdi-television-off::before{content:"\F83A"}.mdi-television-pause::before{content:"\FFA6"}.mdi-television-play::before{content:"\FEEC"}.mdi-television-stop::before{content:"\FFA7"}.mdi-temperature-celsius::before{content:"\F504"}.mdi-temperature-fahrenheit::before{content:"\F505"}.mdi-temperature-kelvin::before{content:"\F506"}.mdi-tennis::before{content:"\FD7C"}.mdi-tennis-ball::before{content:"\F507"}.mdi-tent::before{content:"\F508"}.mdi-terrain::before{content:"\F509"}.mdi-test-tube::before{content:"\F668"}.mdi-test-tube-empty::before{content:"\F910"}.mdi-test-tube-off::before{content:"\F911"}.mdi-text::before{content:"\F9A7"}.mdi-text-shadow::before{content:"\F669"}.mdi-text-short::before{content:"\F9A8"}.mdi-text-subject::before{content:"\F9A9"}.mdi-text-to-speech::before{content:"\F50A"}.mdi-text-to-speech-off::before{content:"\F50B"}.mdi-textbox::before{content:"\F60E"}.mdi-textbox-password::before{content:"\F7F4"}.mdi-texture::before{content:"\F50C"}.mdi-theater::before{content:"\F50D"}.mdi-theme-light-dark::before{content:"\F50E"}.mdi-thermometer::before{content:"\F50F"}.mdi-thermometer-alert::before{content:"\FE61"}.mdi-thermometer-chevron-down::before{content:"\FE62"}.mdi-thermometer-chevron-up::before{content:"\FE63"}.mdi-thermometer-lines::before{content:"\F510"}.mdi-thermometer-minus::before{content:"\FE64"}.mdi-thermometer-plus::before{content:"\FE65"}.mdi-thermostat::before{content:"\F393"}.mdi-thermostat-box::before{content:"\F890"}.mdi-thought-bubble::before{content:"\F7F5"}.mdi-thought-bubble-outline::before{content:"\F7F6"}.mdi-thumb-down::before{content:"\F511"}.mdi-mdi-thumb-down-outline::before{content:"\F512"}.mdi-thumb-up::before{content:"\F513"}.mdi-thumb-up-outline::before{content:"\F514"}.mdi-thumbs-up-down::before{content:"\F515"}.mdi-ticket::before{content:"\F516"}.mdi-ticket-account::before{content:"\F517"}.mdi-ticket-confirmation::before{content:"\F518"}.mdi-ticket-outline::before{content:"\F912"}.mdi-ticket-percent::before{content:"\F723"}.mdi-tie::before{content:"\F519"}.mdi-tilde::before{content:"\F724"}.mdi-timelapse::before{content:"\F51A"}.mdi-timeline::before{content:"\FBAD"}.mdi-timeline-alert::before{content:"\FFB2"}.mdi-timeline-alert-outline::before{content:"\FFB5"}.mdi-timeline-help::before{content:"\FFB6"}.mdi-timeline-help-outline::before{content:"\FFB7"}.mdi-timeline-outline::before{content:"\FBAE"}.mdi-timeline-plus::before{content:"\FFB3"}.mdi-timeline-plus-outline::before{content:"\FFB4"}.mdi-timeline-text::before{content:"\FBAF"}.mdi-timeline-text-outline::before{content:"\FBB0"}.mdi-timer::before{content:"\F51B"}.mdi-timer-10::before{content:"\F51C"}.mdi-timer-3::before{content:"\F51D"}.mdi-timer-off::before{content:"\F51E"}.mdi-timer-sand::before{content:"\F51F"}.mdi-timer-sand-empty::before{content:"\F6AC"}.mdi-timer-sand-full::before{content:"\F78B"}.mdi-timetable::before{content:"\F520"}.mdi-toaster-oven::before{content:"\FCAF"}.mdi-toggle-switch::before{content:"\F521"}.mdi-toggle-switch-off::before{content:"\F522"}.mdi-toggle-switch-off-outline::before{content:"\FA18"}.mdi-toggle-switch-outline::before{content:"\FA19"}.mdi-toilet::before{content:"\F9AA"}.mdi-toolbox::before{content:"\F9AB"}.mdi-toolbox-outline::before{content:"\F9AC"}.mdi-tooltip::before{content:"\F523"}.mdi-tooltip-account::before{content:"\F00C"}.mdi-tooltip-edit::before{content:"\F524"}.mdi-tooltip-image::before{content:"\F525"}.mdi-tooltip-image-outline::before{content:"\FBB1"}.mdi-tooltip-outline::before{content:"\F526"}.mdi-tooltip-plus::before{content:"\FBB2"}.mdi-tooltip-plus-outline::before{content:"\F527"}.mdi-tooltip-text::before{content:"\F528"}.mdi-tooltip-text-outline::before{content:"\FBB3"}.mdi-tooth::before{content:"\F8C2"}.mdi-tooth-outline::before{content:"\F529"}.mdi-tor::before{content:"\F52A"}.mdi-tortoise::before{content:"\FD17"}.mdi-tournament::before{content:"\F9AD"}.mdi-tower-beach::before{content:"\F680"}.mdi-tower-fire::before{content:"\F681"}.mdi-towing::before{content:"\F83B"}.mdi-track-light::before{content:"\F913"}.mdi-trackpad::before{content:"\F7F7"}.mdi-trackpad-lock::before{content:"\F932"}.mdi-tractor::before{content:"\F891"}.mdi-trademark::before{content:"\FA77"}.mdi-traffic-light::before{content:"\F52B"}.mdi-train::before{content:"\F52C"}.mdi-train-car::before{content:"\FBB4"}.mdi-train-variant::before{content:"\F8C3"}.mdi-tram::before{content:"\F52D"}.mdi-transcribe::before{content:"\F52E"}.mdi-transcribe-close::before{content:"\F52F"}.mdi-transfer-down::before{content:"\FD7D"}.mdi-transfer-left::before{content:"\FD7E"}.mdi-transfer-right::before{content:"\F530"}.mdi-transfer-up::before{content:"\FD7F"}.mdi-transit-connection::before{content:"\FD18"}.mdi-transit-connection-variant::before{content:"\FD19"}.mdi-transit-detour::before{content:"\FFA8"}.mdi-transit-transfer::before{content:"\F6AD"}.mdi-transition::before{content:"\F914"}.mdi-transition-masked::before{content:"\F915"}.mdi-translate::before{content:"\F5CA"}.mdi-translate-off::before{content:"\FE66"}.mdi-transmission-tower::before{content:"\FD1A"}.mdi-trash-can::before{content:"\FA78"}.mdi-trash-can-outline::before{content:"\FA79"}.mdi-treasure-chest::before{content:"\F725"}.mdi-tree::before{content:"\F531"}.mdi-tree-outline::before{content:"\FE4C"}.mdi-trello::before{content:"\F532"}.mdi-trending-down::before{content:"\F533"}.mdi-trending-neutral::before{content:"\F534"}.mdi-trending-up::before{content:"\F535"}.mdi-triangle::before{content:"\F536"}.mdi-triangle-outline::before{content:"\F537"}.mdi-triforce::before{content:"\FBB5"}.mdi-trophy::before{content:"\F538"}.mdi-trophy-award::before{content:"\F539"}.mdi-trophy-broken::before{content:"\FD80"}.mdi-trophy-outline::before{content:"\F53A"}.mdi-trophy-variant::before{content:"\F53B"}.mdi-trophy-variant-outline::before{content:"\F53C"}.mdi-truck::before{content:"\F53D"}.mdi-truck-check::before{content:"\FCB0"}.mdi-truck-delivery::before{content:"\F53E"}.mdi-truck-fast::before{content:"\F787"}.mdi-truck-trailer::before{content:"\F726"}.mdi-tshirt-crew::before{content:"\FA7A"}.mdi-tshirt-crew-outline::before{content:"\F53F"}.mdi-tshirt-v::before{content:"\FA7B"}.mdi-tshirt-v-outline::before{content:"\F540"}.mdi-tumble-dryer::before{content:"\F916"}.mdi-tumblr::before{content:"\F541"}.mdi-tumblr-box::before{content:"\F917"}.mdi-tumblr-reblog::before{content:"\F542"}.mdi-tune::before{content:"\F62E"}.mdi-tune-vertical::before{content:"\F66A"}.mdi-turnstile::before{content:"\FCB1"}.mdi-turnstile-outline::before{content:"\FCB2"}.mdi-turtle::before{content:"\FCB3"}.mdi-twitch::before{content:"\F543"}.mdi-twitter::before{content:"\F544"}.mdi-twitter-box::before{content:"\F545"}.mdi-twitter-circle::before{content:"\F546"}.mdi-twitter-retweet::before{content:"\F547"}.mdi-two-factor-authentication::before{content:"\F9AE"}.mdi-typewriter::before{content:"\FF4A"}.mdi-uber::before{content:"\F748"}.mdi-ubisoft::before{content:"\FBB6"}.mdi-ubuntu::before{content:"\F548"}.mdi-ultra-high-definition::before{content:"\F7F8"}.mdi-umbraco::before{content:"\F549"}.mdi-umbrella::before{content:"\F54A"}.mdi-umbrella-closed::before{content:"\F9AF"}.mdi-umbrella-outline::before{content:"\F54B"}.mdi-undo::before{content:"\F54C"}.mdi-undo-variant::before{content:"\F54D"}.mdi-unfold-less-horizontal::before{content:"\F54E"}.mdi-unfold-less-vertical::before{content:"\F75F"}.mdi-unfold-more-horizontal::before{content:"\F54F"}.mdi-unfold-more-vertical::before{content:"\F760"}.mdi-ungroup::before{content:"\F550"}.mdi-unicode::before{content:"\FEED"}.mdi-unity::before{content:"\F6AE"}.mdi-unreal::before{content:"\F9B0"}.mdi-untappd::before{content:"\F551"}.mdi-update::before{content:"\F6AF"}.mdi-upload::before{content:"\F552"}.mdi-upload-multiple::before{content:"\F83C"}.mdi-upload-network::before{content:"\F6F5"}.mdi-upload-network-outline::before{content:"\FCB4"}.mdi-upload-outline::before{content:"\FE67"}.mdi-usb::before{content:"\F553"}.mdi-van-passenger::before{content:"\F7F9"}.mdi-van-utility::before{content:"\F7FA"}.mdi-vanish::before{content:"\F7FB"}.mdi-variable::before{content:"\FAE6"}.mdi-vector-arrange-above::before{content:"\F554"}.mdi-vector-arrange-below::before{content:"\F555"}.mdi-vector-bezier::before{content:"\FAE7"}.mdi-vector-circle::before{content:"\F556"}.mdi-vector-circle-variant::before{content:"\F557"}.mdi-vector-combine::before{content:"\F558"}.mdi-vector-curve::before{content:"\F559"}.mdi-vector-difference::before{content:"\F55A"}.mdi-vector-difference-ab::before{content:"\F55B"}.mdi-vector-difference-ba::before{content:"\F55C"}.mdi-vector-ellipse::before{content:"\F892"}.mdi-vector-intersection::before{content:"\F55D"}.mdi-vector-line::before{content:"\F55E"}.mdi-vector-point::before{content:"\F55F"}.mdi-vector-polygon::before{content:"\F560"}.mdi-vector-polyline::before{content:"\F561"}.mdi-vector-radius::before{content:"\F749"}.mdi-vector-rectangle::before{content:"\F5C6"}.mdi-vector-selection::before{content:"\F562"}.mdi-vector-square::before{content:"\F001"}.mdi-vector-triangle::before{content:"\F563"}.mdi-vector-union::before{content:"\F564"}.mdi-venmo::before{content:"\F578"}.mdi-vhs::before{content:"\FA1A"}.mdi-vibrate::before{content:"\F566"}.mdi-vibrate-off::before{content:"\FCB5"}.mdi-video::before{content:"\F567"}.mdi-video-3d::before{content:"\F7FC"}.mdi-video-3d-variant::before{content:"\FEEE"}.mdi-video-4k-box::before{content:"\F83D"}.mdi-video-account::before{content:"\F918"}.mdi-video-image::before{content:"\F919"}.mdi-video-input-antenna::before{content:"\F83E"}.mdi-video-input-component::before{content:"\F83F"}.mdi-video-input-hdmi::before{content:"\F840"}.mdi-video-input-scart::before{content:"\FFA9"}.mdi-video-input-svideo::before{content:"\F841"}.mdi-video-minus::before{content:"\F9B1"}.mdi-video-off::before{content:"\F568"}.mdi-video-off-outline::before{content:"\FBB7"}.mdi-video-outline::before{content:"\FBB8"}.mdi-video-plus::before{content:"\F9B2"}.mdi-video-stabilization::before{content:"\F91A"}.mdi-video-switch::before{content:"\F569"}.mdi-video-vintage::before{content:"\FA1B"}.mdi-video-wireless::before{content:"\FEEF"}.mdi-video-wireless-outline::before{content:"\FEF0"}.mdi-view-agenda::before{content:"\F56A"}.mdi-view-array::before{content:"\F56B"}.mdi-view-carousel::before{content:"\F56C"}.mdi-view-column::before{content:"\F56D"}.mdi-view-comfy::before{content:"\FE4D"}.mdi-view-compact::before{content:"\FE4E"}.mdi-view-compact-outline::before{content:"\FE4F"}.mdi-view-dashboard::before{content:"\F56E"}.mdi-view-dashboard-outline::before{content:"\FA1C"}.mdi-view-dashboard-variant::before{content:"\F842"}.mdi-view-day::before{content:"\F56F"}.mdi-view-grid::before{content:"\F570"}.mdi-view-grid-plus::before{content:"\FFAA"}.mdi-view-headline::before{content:"\F571"}.mdi-view-list::before{content:"\F572"}.mdi-view-module::before{content:"\F573"}.mdi-view-parallel::before{content:"\F727"}.mdi-view-quilt::before{content:"\F574"}.mdi-view-sequential::before{content:"\F728"}.mdi-view-split-horizontal::before{content:"\FBA7"}.mdi-view-split-vertical::before{content:"\FBA8"}.mdi-view-stream::before{content:"\F575"}.mdi-view-week::before{content:"\F576"}.mdi-vimeo::before{content:"\F577"}.mdi-violin::before{content:"\F60F"}.mdi-virtual-reality::before{content:"\F893"}.mdi-visual-studio::before{content:"\F610"}.mdi-visual-studio-code::before{content:"\FA1D"}.mdi-vk::before{content:"\F579"}.mdi-vk-box::before{content:"\F57A"}.mdi-vk-circle::before{content:"\F57B"}.mdi-vlc::before{content:"\F57C"}.mdi-voice::before{content:"\F5CB"}.mdi-voice-off::before{content:"\FEF1"}.mdi-voicemail::before{content:"\F57D"}.mdi-volleyball::before{content:"\F9B3"}.mdi-volume-high::before{content:"\F57E"}.mdi-volume-low::before{content:"\F57F"}.mdi-volume-medium::before{content:"\F580"}.mdi-volume-minus::before{content:"\F75D"}.mdi-volume-mute::before{content:"\F75E"}.mdi-volume-off::before{content:"\F581"}.mdi-volume-plus::before{content:"\F75C"}.mdi-volume-variant-off::before{content:"\FE68"}.mdi-vote::before{content:"\FA1E"}.mdi-vote-outline::before{content:"\FA1F"}.mdi-vpn::before{content:"\F582"}.mdi-vuejs::before{content:"\F843"}.mdi-vuetify::before{content:"\FE50"}.mdi-walk::before{content:"\F583"}.mdi-wall::before{content:"\F7FD"}.mdi-wall-sconce::before{content:"\F91B"}.mdi-wall-sconce-flat::before{content:"\F91C"}.mdi-wall-sconce-variant::before{content:"\F91D"}.mdi-wallet::before{content:"\F584"}.mdi-wallet-giftcard::before{content:"\F585"}.mdi-wallet-membership::before{content:"\F586"}.mdi-wallet-outline::before{content:"\FBB9"}.mdi-wallet-plus::before{content:"\FFAB"}.mdi-wallet-plus-outline::before{content:"\FFAC"}.mdi-wallet-travel::before{content:"\F587"}.mdi-wallpaper::before{content:"\FE69"}.mdi-wan::before{content:"\F588"}.mdi-wardrobe::before{content:"\FFAD"}.mdi-wardrobe-outline::before{content:"\FFAE"}.mdi-warehouse::before{content:"\FFBB"}.mdi-washing-machine::before{content:"\F729"}.mdi-watch::before{content:"\F589"}.mdi-watch-export::before{content:"\F58A"}.mdi-watch-export-variant::before{content:"\F894"}.mdi-watch-import::before{content:"\F58B"}.mdi-watch-import-variant::before{content:"\F895"}.mdi-watch-variant::before{content:"\F896"}.mdi-watch-vibrate::before{content:"\F6B0"}.mdi-watch-vibrate-off::before{content:"\FCB6"}.mdi-water::before{content:"\F58C"}.mdi-water-boiler::before{content:"\FFAF"}.mdi-water-off::before{content:"\F58D"}.mdi-water-outline::before{content:"\FE6A"}.mdi-water-percent::before{content:"\F58E"}.mdi-water-pump::before{content:"\F58F"}.mdi-water-pump-off::before{content:"\FFB0"}.mdi-watermark::before{content:"\F612"}.mdi-wave::before{content:"\FF4B"}.mdi-waves::before{content:"\F78C"}.mdi-waze::before{content:"\FBBA"}.mdi-weather-cloudy::before{content:"\F590"}.mdi-weather-cloudy-alert::before{content:"\FF4C"}.mdi-weather-cloudy-arrow-right::before{content:"\FE51"}.mdi-weather-fog::before{content:"\F591"}.mdi-weather-hail::before{content:"\F592"}.mdi-weather-hazy::before{content:"\FF4D"}.mdi-weather-hurricane::before{content:"\F897"}.mdi-weather-lightning::before{content:"\F593"}.mdi-weather-lightning-rainy::before{content:"\F67D"}.mdi-weather-night::before{content:"\F594"}.mdi-weather-night-partly-cloudy::before{content:"\FF4E"}.mdi-weather-partly-cloudy::before{content:"\F595"}.mdi-weather-partly-lightning::before{content:"\FF4F"}.mdi-weather-partly-rainy::before{content:"\FF50"}.mdi-weather-partly-snowy::before{content:"\FF51"}.mdi-weather-partly-snowy-rainy::before{content:"\FF52"}.mdi-weather-pouring::before{content:"\F596"}.mdi-weather-rainy::before{content:"\F597"}.mdi-weather-snowy::before{content:"\F598"}.mdi-weather-snowy-heavy::before{content:"\FF53"}.mdi-weather-snowy-rainy::before{content:"\F67E"}.mdi-weather-sunny::before{content:"\F599"}.mdi-weather-sunny-alert::before{content:"\FF54"}.mdi-weather-sunset::before{content:"\F59A"}.mdi-weather-sunset-down::before{content:"\F59B"}.mdi-weather-sunset-up::before{content:"\F59C"}.mdi-weather-tornado::before{content:"\FF55"}.mdi-weather-windy::before{content:"\F59D"}.mdi-weather-windy-variant::before{content:"\F59E"}.mdi-web::before{content:"\F59F"}.mdi-web-box::before{content:"\FFB1"}.mdi-webcam::before{content:"\F5A0"}.mdi-webhook::before{content:"\F62F"}.mdi-webpack::before{content:"\F72A"}.mdi-wechat::before{content:"\F611"}.mdi-weight::before{content:"\F5A1"}.mdi-weight-gram::before{content:"\FD1B"}.mdi-weight-kilogram::before{content:"\F5A2"}.mdi-weight-pound::before{content:"\F9B4"}.mdi-whatsapp::before{content:"\F5A3"}.mdi-wheelchair-accessibility::before{content:"\F5A4"}.mdi-whistle::before{content:"\F9B5"}.mdi-white-balance-auto::before{content:"\F5A5"}.mdi-white-balance-incandescent::before{content:"\F5A6"}.mdi-white-balance-iridescent::before{content:"\F5A7"}.mdi-white-balance-sunny::before{content:"\F5A8"}.mdi-widgets::before{content:"\F72B"}.mdi-wifi::before{content:"\F5A9"}.mdi-wifi-off::before{content:"\F5AA"}.mdi-wifi-star::before{content:"\FE6B"}.mdi-wifi-strength-1::before{content:"\F91E"}.mdi-wifi-strength-1-alert::before{content:"\F91F"}.mdi-wifi-strength-1-lock::before{content:"\F920"}.mdi-wifi-strength-2::before{content:"\F921"}.mdi-wifi-strength-2-alert::before{content:"\F922"}.mdi-wifi-strength-2-lock::before{content:"\F923"}.mdi-wifi-strength-3::before{content:"\F924"}.mdi-wifi-strength-3-alert::before{content:"\F925"}.mdi-wifi-strength-3-lock::before{content:"\F926"}.mdi-wifi-strength-4::before{content:"\F927"}.mdi-wifi-strength-4-alert::before{content:"\F928"}.mdi-wifi-strength-4-lock::before{content:"\F929"}.mdi-wifi-strength-alert-outline::before{content:"\F92A"}.mdi-wifi-strength-lock-outline::before{content:"\F92B"}.mdi-wifi-strength-off::before{content:"\F92C"}.mdi-wifi-strength-off-outline::before{content:"\F92D"}.mdi-wifi-strength-outline::before{content:"\F92E"}.mdi-wii::before{content:"\F5AB"}.mdi-wiiu::before{content:"\F72C"}.mdi-wikipedia::before{content:"\F5AC"}.mdi-wind-turbine::before{content:"\FD81"}.mdi-window-close::before{content:"\F5AD"}.mdi-window-closed::before{content:"\F5AE"}.mdi-window-maximize::before{content:"\F5AF"}.mdi-window-minimize::before{content:"\F5B0"}.mdi-window-open::before{content:"\F5B1"}.mdi-window-restore::before{content:"\F5B2"}.mdi-windows::before{content:"\F5B3"}.mdi-windows-classic::before{content:"\FA20"}.mdi-wiper::before{content:"\FAE8"}.mdi-wiper-wash::before{content:"\FD82"}.mdi-wordpress::before{content:"\F5B4"}.mdi-worker::before{content:"\F5B5"}.mdi-wrap::before{content:"\F5B6"}.mdi-wrap-disabled::before{content:"\FBBB"}.mdi-wrench::before{content:"\F5B7"}.mdi-wrench-outline::before{content:"\FBBC"}.mdi-wunderlist::before{content:"\F5B8"}.mdi-xamarin::before{content:"\F844"}.mdi-xamarin-outline::before{content:"\F845"}.mdi-xaml::before{content:"\F673"}.mdi-xbox::before{content:"\F5B9"}.mdi-xbox-controller::before{content:"\F5BA"}.mdi-xbox-controller-battery-alert::before{content:"\F74A"}.mdi-xbox-controller-battery-charging::before{content:"\FA21"}.mdi-xbox-controller-battery-empty::before{content:"\F74B"}.mdi-xbox-controller-battery-full::before{content:"\F74C"}.mdi-xbox-controller-battery-low::before{content:"\F74D"}.mdi-xbox-controller-battery-medium::before{content:"\F74E"}.mdi-xbox-controller-battery-unknown::before{content:"\F74F"}.mdi-xbox-controller-menu::before{content:"\FE52"}.mdi-xbox-controller-off::before{content:"\F5BB"}.mdi-xbox-controller-view::before{content:"\FE53"}.mdi-xda::before{content:"\F5BC"}.mdi-xing::before{content:"\F5BD"}.mdi-xing-box::before{content:"\F5BE"}.mdi-xing-circle::before{content:"\F5BF"}.mdi-xml::before{content:"\F5C0"}.mdi-xmpp::before{content:"\F7FE"}.mdi-yahoo::before{content:"\FB2A"}.mdi-yammer::before{content:"\F788"}.mdi-yeast::before{content:"\F5C1"}.mdi-yelp::before{content:"\F5C2"}.mdi-yin-yang::before{content:"\F67F"}.mdi-youtube::before{content:"\F5C3"}.mdi-youtube-creator-studio::before{content:"\F846"}.mdi-youtube-gaming::before{content:"\F847"}.mdi-youtube-subscription::before{content:"\FD1C"}.mdi-youtube-tv::before{content:"\F448"}.mdi-z-wave::before{content:"\FAE9"}.mdi-zend::before{content:"\FAEA"}.mdi-zigbee::before{content:"\FD1D"}.mdi-zip-box::before{content:"\F5C4"}.mdi-zip-disk::before{content:"\FA22"}.mdi-zodiac-aquarius::before{content:"\FA7C"}.mdi-zodiac-aries::before{content:"\FA7D"}.mdi-zodiac-cancer::before{content:"\FA7E"}.mdi-zodiac-capricorn::before{content:"\FA7F"}.mdi-zodiac-gemini::before{content:"\FA80"}.mdi-zodiac-leo::before{content:"\FA81"}.mdi-zodiac-libra::before{content:"\FA82"}.mdi-zodiac-pisces::before{content:"\FA83"}.mdi-zodiac-sagittarius::before{content:"\FA84"}.mdi-zodiac-scorpio::before{content:"\FA85"}.mdi-zodiac-taurus::before{content:"\FA86"}.mdi-zodiac-virgo::before{content:"\FA87"}.mdi-blank::before{content:"\F68C";visibility:hidden}.mdi-18px.mdi-set,.mdi-18px.mdi:before{font-size:18px}.mdi-24px.mdi-set,.mdi-24px.mdi:before{font-size:24px}.mdi-36px.mdi-set,.mdi-36px.mdi:before{font-size:36px}.mdi-48px.mdi-set,.mdi-48px.mdi:before{font-size:48px}.mdi-dark:before{color:rgba(0,0,0,0.54)}.mdi-dark.mdi-inactive:before{color:rgba(0,0,0,0.26)}.mdi-light:before{color:#fff}.mdi-light.mdi-inactive:before{color:rgba(255,255,255,0.3)}.mdi-rotate-45:before{-webkit-transform:rotate(45deg);-ms-transform:rotate(45deg);transform:rotate(45deg)}.mdi-rotate-90:before{-webkit-transform:rotate(90deg);-ms-transform:rotate(90deg);transform:rotate(90deg)}.mdi-rotate-135:before{-webkit-transform:rotate(135deg);-ms-transform:rotate(135deg);transform:rotate(135deg)}.mdi-rotate-180:before{-webkit-transform:rotate(180deg);-ms-transform:rotate(180deg);transform:rotate(180deg)}.mdi-rotate-225:before{-webkit-transform:rotate(225deg);-ms-transform:rotate(225deg);transform:rotate(225deg)}.mdi-rotate-270:before{-webkit-transform:rotate(270deg);-ms-transform:rotate(270deg);transform:rotate(270deg)}.mdi-rotate-315:before{-webkit-transform:rotate(315deg);-ms-transform:rotate(315deg);transform:rotate(315deg)}.mdi-flip-h:before{-webkit-transform:scaleX(-1);transform:scaleX(-1);filter:FlipH;-ms-filter:"FlipH"}.mdi-flip-v:before{-webkit-transform:scaleY(-1);transform:scaleY(-1);filter:FlipV;-ms-filter:"FlipV"}.mdi-spin:before{-webkit-animation:mdi-spin 2s infinite linear;animation:mdi-spin 2s infinite linear}@-webkit-keyframes mdi-spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}100%{-webkit-transform:rotate(359deg);transform:rotate(359deg)}}@keyframes mdi-spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}100%{-webkit-transform:rotate(359deg);transform:rotate(359deg)}} +======= +@font-face { + font-family: "Material Design Icons"; + src: url("../fonts/materialdesignicons-webfont.eot?v=3.9.97"); + src: url("../fonts/materialdesignicons-webfont.eot?#iefix&v=3.9.97") + format("embedded-opentype"), + url("../fonts/materialdesignicons-webfont.woff2?v=3.9.97") format("woff2"), + url("../fonts/materialdesignicons-webfont.woff?v=3.9.97") format("woff"), + url("../fonts/materialdesignicons-webfont.ttf?v=3.9.97") format("truetype"); + font-weight: normal; + font-style: normal; +} +.mdi:before, +.mdi-set { + display: inline-block; + font: normal normal normal 24px/1 "Material Design Icons"; + font-size: inherit; + text-rendering: auto; + line-height: inherit; + -webkit-font-smoothing: antialiased; + -moz-osx-font-smoothing: grayscale; +} +.mdi-access-point::before { + content: "\F002"; +} +.mdi-access-point-network::before { + content: "\F003"; +} +.mdi-access-point-network-off::before { + content: "\FBBD"; +} +.mdi-account::before { + content: "\F004"; +} +.mdi-account-alert::before { + content: "\F005"; +} +.mdi-account-alert-outline::before { + content: "\FB2C"; +} +.mdi-account-arrow-left::before { + content: "\FB2D"; +} +.mdi-account-arrow-left-outline::before { + content: "\FB2E"; +} +.mdi-account-arrow-right::before { + content: "\FB2F"; +} +.mdi-account-arrow-right-outline::before { + content: "\FB30"; +} +.mdi-account-badge::before { + content: "\FD83"; +} +.mdi-account-badge-alert::before { + content: "\FD84"; +} +.mdi-account-badge-alert-outline::before { + content: "\FD85"; +} +.mdi-account-badge-horizontal::before { + content: "\FDF0"; +} +.mdi-account-badge-horizontal-outline::before { + content: "\FDF1"; +} +.mdi-account-badge-outline::before { + content: "\FD86"; +} +.mdi-account-box::before { + content: "\F006"; +} +.mdi-account-box-multiple::before { + content: "\F933"; +} +.mdi-account-box-outline::before { + content: "\F007"; +} +.mdi-account-card-details::before { + content: "\F5D2"; +} +.mdi-account-card-details-outline::before { + content: "\FD87"; +} +.mdi-account-check::before { + content: "\F008"; +} +.mdi-account-check-outline::before { + content: "\FBBE"; +} +.mdi-account-child::before { + content: "\FA88"; +} +.mdi-account-child-circle::before { + content: "\FA89"; +} +.mdi-account-circle::before { + content: "\F009"; +} +.mdi-account-circle-outline::before { + content: "\FB31"; +} +.mdi-account-clock::before { + content: "\FB32"; +} +.mdi-account-clock-outline::before { + content: "\FB33"; +} +.mdi-account-convert::before { + content: "\F00A"; +} +.mdi-account-details::before { + content: "\F631"; +} +.mdi-account-edit::before { + content: "\F6BB"; +} +.mdi-account-group::before { + content: "\F848"; +} +.mdi-account-group-outline::before { + content: "\FB34"; +} +.mdi-account-heart::before { + content: "\F898"; +} +.mdi-account-heart-outline::before { + content: "\FBBF"; +} +.mdi-account-key::before { + content: "\F00B"; +} +.mdi-account-key-outline::before { + content: "\FBC0"; +} +.mdi-account-minus::before { + content: "\F00D"; +} +.mdi-account-minus-outline::before { + content: "\FAEB"; +} +.mdi-account-multiple::before { + content: "\F00E"; +} +.mdi-account-multiple-check::before { + content: "\F8C4"; +} +.mdi-account-multiple-minus::before { + content: "\F5D3"; +} +.mdi-account-multiple-minus-outline::before { + content: "\FBC1"; +} +.mdi-account-multiple-outline::before { + content: "\F00F"; +} +.mdi-account-multiple-plus::before { + content: "\F010"; +} +.mdi-account-multiple-plus-outline::before { + content: "\F7FF"; +} +.mdi-account-network::before { + content: "\F011"; +} +.mdi-account-network-outline::before { + content: "\FBC2"; +} +.mdi-account-off::before { + content: "\F012"; +} +.mdi-account-off-outline::before { + content: "\FBC3"; +} +.mdi-account-outline::before { + content: "\F013"; +} +.mdi-account-plus::before { + content: "\F014"; +} +.mdi-account-plus-outline::before { + content: "\F800"; +} +.mdi-account-question::before { + content: "\FB35"; +} +.mdi-account-question-outline::before { + content: "\FB36"; +} +.mdi-account-remove::before { + content: "\F015"; +} +.mdi-account-remove-outline::before { + content: "\FAEC"; +} +.mdi-account-search::before { + content: "\F016"; +} +.mdi-account-search-outline::before { + content: "\F934"; +} +.mdi-account-settings::before { + content: "\F630"; +} +.mdi-account-star::before { + content: "\F017"; +} +.mdi-account-star-outline::before { + content: "\FBC4"; +} +.mdi-account-supervisor::before { + content: "\FA8A"; +} +.mdi-account-supervisor-circle::before { + content: "\FA8B"; +} +.mdi-account-switch::before { + content: "\F019"; +} +.mdi-account-tie::before { + content: "\FCBF"; +} +.mdi-accusoft::before { + content: "\F849"; +} +.mdi-adchoices::before { + content: "\FD1E"; +} +.mdi-adjust::before { + content: "\F01A"; +} +.mdi-adobe::before { + content: "\F935"; +} +.mdi-air-conditioner::before { + content: "\F01B"; +} +.mdi-air-filter::before { + content: "\FD1F"; +} +.mdi-air-horn::before { + content: "\FD88"; +} +.mdi-air-purifier::before { + content: "\FD20"; +} +.mdi-airbag::before { + content: "\FBC5"; +} +.mdi-airballoon::before { + content: "\F01C"; +} +.mdi-airplane::before { + content: "\F01D"; +} +.mdi-airplane-landing::before { + content: "\F5D4"; +} +.mdi-airplane-off::before { + content: "\F01E"; +} +.mdi-airplane-takeoff::before { + content: "\F5D5"; +} +.mdi-airplay::before { + content: "\F01F"; +} +.mdi-airport::before { + content: "\F84A"; +} +.mdi-alarm::before { + content: "\F020"; +} +.mdi-alarm-bell::before { + content: "\F78D"; +} +.mdi-alarm-check::before { + content: "\F021"; +} +.mdi-alarm-light::before { + content: "\F78E"; +} +.mdi-alarm-light-outline::before { + content: "\FBC6"; +} +.mdi-alarm-multiple::before { + content: "\F022"; +} +.mdi-alarm-note::before { + content: "\FE8E"; +} +.mdi-alarm-note-off::before { + content: "\FE8F"; +} +.mdi-alarm-off::before { + content: "\F023"; +} +.mdi-alarm-plus::before { + content: "\F024"; +} +.mdi-alarm-snooze::before { + content: "\F68D"; +} +.mdi-album::before { + content: "\F025"; +} +.mdi-alert::before { + content: "\F026"; +} +.mdi-alert-box::before { + content: "\F027"; +} +.mdi-alert-box-outline::before { + content: "\FCC0"; +} +.mdi-alert-circle::before { + content: "\F028"; +} +.mdi-alert-circle-outline::before { + content: "\F5D6"; +} +.mdi-alert-decagram::before { + content: "\F6BC"; +} +.mdi-alert-decagram-outline::before { + content: "\FCC1"; +} +.mdi-alert-octagon::before { + content: "\F029"; +} +.mdi-alert-octagon-outline::before { + content: "\FCC2"; +} +.mdi-alert-octagram::before { + content: "\F766"; +} +.mdi-alert-octagram-outline::before { + content: "\FCC3"; +} +.mdi-alert-outline::before { + content: "\F02A"; +} +.mdi-alien::before { + content: "\F899"; +} +.mdi-all-inclusive::before { + content: "\F6BD"; +} +.mdi-alpha::before { + content: "\F02B"; +} +.mdi-alpha-a::before { + content: "\41"; +} +.mdi-alpha-a-box::before { + content: "\FAED"; +} +.mdi-alpha-a-box-outline::before { + content: "\FBC7"; +} +.mdi-alpha-a-circle::before { + content: "\FBC8"; +} +.mdi-alpha-a-circle-outline::before { + content: "\FBC9"; +} +.mdi-alpha-b::before { + content: "\42"; +} +.mdi-alpha-b-box::before { + content: "\FAEE"; +} +.mdi-alpha-b-box-outline::before { + content: "\FBCA"; +} +.mdi-alpha-b-circle::before { + content: "\FBCB"; +} +.mdi-alpha-b-circle-outline::before { + content: "\FBCC"; +} +.mdi-alpha-c::before { + content: "\43"; +} +.mdi-alpha-c-box::before { + content: "\FAEF"; +} +.mdi-alpha-c-box-outline::before { + content: "\FBCD"; +} +.mdi-alpha-c-circle::before { + content: "\FBCE"; +} +.mdi-alpha-c-circle-outline::before { + content: "\FBCF"; +} +.mdi-alpha-d::before { + content: "\44"; +} +.mdi-alpha-d-box::before { + content: "\FAF0"; +} +.mdi-alpha-d-box-outline::before { + content: "\FBD0"; +} +.mdi-alpha-d-circle::before { + content: "\FBD1"; +} +.mdi-alpha-d-circle-outline::before { + content: "\FBD2"; +} +.mdi-alpha-e::before { + content: "\45"; +} +.mdi-alpha-e-box::before { + content: "\FAF1"; +} +.mdi-alpha-e-box-outline::before { + content: "\FBD3"; +} +.mdi-alpha-e-circle::before { + content: "\FBD4"; +} +.mdi-alpha-e-circle-outline::before { + content: "\FBD5"; +} +.mdi-alpha-f::before { + content: "\46"; +} +.mdi-alpha-f-box::before { + content: "\FAF2"; +} +.mdi-alpha-f-box-outline::before { + content: "\FBD6"; +} +.mdi-alpha-f-circle::before { + content: "\FBD7"; +} +.mdi-alpha-f-circle-outline::before { + content: "\FBD8"; +} +.mdi-alpha-g::before { + content: "\47"; +} +.mdi-alpha-g-box::before { + content: "\FAF3"; +} +.mdi-alpha-g-box-outline::before { + content: "\FBD9"; +} +.mdi-alpha-g-circle::before { + content: "\FBDA"; +} +.mdi-alpha-g-circle-outline::before { + content: "\FBDB"; +} +.mdi-alpha-h::before { + content: "\48"; +} +.mdi-alpha-h-box::before { + content: "\FAF4"; +} +.mdi-alpha-h-box-outline::before { + content: "\FBDC"; +} +.mdi-alpha-h-circle::before { + content: "\FBDD"; +} +.mdi-alpha-h-circle-outline::before { + content: "\FBDE"; +} +.mdi-alpha-i::before { + content: "\49"; +} +.mdi-alpha-i-box::before { + content: "\FAF5"; +} +.mdi-alpha-i-box-outline::before { + content: "\FBDF"; +} +.mdi-alpha-i-circle::before { + content: "\FBE0"; +} +.mdi-alpha-i-circle-outline::before { + content: "\FBE1"; +} +.mdi-alpha-j::before { + content: "\4A"; +} +.mdi-alpha-j-box::before { + content: "\FAF6"; +} +.mdi-alpha-j-box-outline::before { + content: "\FBE2"; +} +.mdi-alpha-j-circle::before { + content: "\FBE3"; +} +.mdi-alpha-j-circle-outline::before { + content: "\FBE4"; +} +.mdi-alpha-k::before { + content: "\4B"; +} +.mdi-alpha-k-box::before { + content: "\FAF7"; +} +.mdi-alpha-k-box-outline::before { + content: "\FBE5"; +} +.mdi-alpha-k-circle::before { + content: "\FBE6"; +} +.mdi-alpha-k-circle-outline::before { + content: "\FBE7"; +} +.mdi-alpha-l::before { + content: "\4C"; +} +.mdi-alpha-l-box::before { + content: "\FAF8"; +} +.mdi-alpha-l-box-outline::before { + content: "\FBE8"; +} +.mdi-alpha-l-circle::before { + content: "\FBE9"; +} +.mdi-alpha-l-circle-outline::before { + content: "\FBEA"; +} +.mdi-alpha-m::before { + content: "\4D"; +} +.mdi-alpha-m-box::before { + content: "\FAF9"; +} +.mdi-alpha-m-box-outline::before { + content: "\FBEB"; +} +.mdi-alpha-m-circle::before { + content: "\FBEC"; +} +.mdi-alpha-m-circle-outline::before { + content: "\FBED"; +} +.mdi-alpha-n::before { + content: "\4E"; +} +.mdi-alpha-n-box::before { + content: "\FAFA"; +} +.mdi-alpha-n-box-outline::before { + content: "\FBEE"; +} +.mdi-alpha-n-circle::before { + content: "\FBEF"; +} +.mdi-alpha-n-circle-outline::before { + content: "\FBF0"; +} +.mdi-alpha-o::before { + content: "\4F"; +} +.mdi-alpha-o-box::before { + content: "\FAFB"; +} +.mdi-alpha-o-box-outline::before { + content: "\FBF1"; +} +.mdi-alpha-o-circle::before { + content: "\FBF2"; +} +.mdi-alpha-o-circle-outline::before { + content: "\FBF3"; +} +.mdi-alpha-p::before { + content: "\50"; +} +.mdi-alpha-p-box::before { + content: "\FAFC"; +} +.mdi-alpha-p-box-outline::before { + content: "\FBF4"; +} +.mdi-alpha-p-circle::before { + content: "\FBF5"; +} +.mdi-alpha-p-circle-outline::before { + content: "\FBF6"; +} +.mdi-alpha-q::before { + content: "\51"; +} +.mdi-alpha-q-box::before { + content: "\FAFD"; +} +.mdi-alpha-q-box-outline::before { + content: "\FBF7"; +} +.mdi-alpha-q-circle::before { + content: "\FBF8"; +} +.mdi-alpha-q-circle-outline::before { + content: "\FBF9"; +} +.mdi-alpha-r::before { + content: "\52"; +} +.mdi-alpha-r-box::before { + content: "\FAFE"; +} +.mdi-alpha-r-box-outline::before { + content: "\FBFA"; +} +.mdi-alpha-r-circle::before { + content: "\FBFB"; +} +.mdi-alpha-r-circle-outline::before { + content: "\FBFC"; +} +.mdi-alpha-s::before { + content: "\53"; +} +.mdi-alpha-s-box::before { + content: "\FAFF"; +} +.mdi-alpha-s-box-outline::before { + content: "\FBFD"; +} +.mdi-alpha-s-circle::before { + content: "\FBFE"; +} +.mdi-alpha-s-circle-outline::before { + content: "\FBFF"; +} +.mdi-alpha-t::before { + content: "\54"; +} +.mdi-alpha-t-box::before { + content: "\FB00"; +} +.mdi-alpha-t-box-outline::before { + content: "\FC00"; +} +.mdi-alpha-t-circle::before { + content: "\FC01"; +} +.mdi-alpha-t-circle-outline::before { + content: "\FC02"; +} +.mdi-alpha-u::before { + content: "\55"; +} +.mdi-alpha-u-box::before { + content: "\FB01"; +} +.mdi-alpha-u-box-outline::before { + content: "\FC03"; +} +.mdi-alpha-u-circle::before { + content: "\FC04"; +} +.mdi-alpha-u-circle-outline::before { + content: "\FC05"; +} +.mdi-alpha-v::before { + content: "\56"; +} +.mdi-alpha-v-box::before { + content: "\FB02"; +} +.mdi-alpha-v-box-outline::before { + content: "\FC06"; +} +.mdi-alpha-v-circle::before { + content: "\FC07"; +} +.mdi-alpha-v-circle-outline::before { + content: "\FC08"; +} +.mdi-alpha-w::before { + content: "\57"; +} +.mdi-alpha-w-box::before { + content: "\FB03"; +} +.mdi-alpha-w-box-outline::before { + content: "\FC09"; +} +.mdi-alpha-w-circle::before { + content: "\FC0A"; +} +.mdi-alpha-w-circle-outline::before { + content: "\FC0B"; +} +.mdi-alpha-x::before { + content: "\58"; +} +.mdi-alpha-x-box::before { + content: "\FB04"; +} +.mdi-alpha-x-box-outline::before { + content: "\FC0C"; +} +.mdi-alpha-x-circle::before { + content: "\FC0D"; +} +.mdi-alpha-x-circle-outline::before { + content: "\FC0E"; +} +.mdi-alpha-y::before { + content: "\59"; +} +.mdi-alpha-y-box::before { + content: "\FB05"; +} +.mdi-alpha-y-box-outline::before { + content: "\FC0F"; +} +.mdi-alpha-y-circle::before { + content: "\FC10"; +} +.mdi-alpha-y-circle-outline::before { + content: "\FC11"; +} +.mdi-alpha-z::before { + content: "\5A"; +} +.mdi-alpha-z-box::before { + content: "\FB06"; +} +.mdi-alpha-z-box-outline::before { + content: "\FC12"; +} +.mdi-alpha-z-circle::before { + content: "\FC13"; +} +.mdi-alpha-z-circle-outline::before { + content: "\FC14"; +} +.mdi-alphabetical::before { + content: "\F02C"; +} +.mdi-altimeter::before { + content: "\F5D7"; +} +.mdi-amazon::before { + content: "\F02D"; +} +.mdi-amazon-alexa::before { + content: "\F8C5"; +} +.mdi-amazon-drive::before { + content: "\F02E"; +} +.mdi-ambulance::before { + content: "\F02F"; +} +.mdi-ammunition::before { + content: "\FCC4"; +} +.mdi-ampersand::before { + content: "\FA8C"; +} +.mdi-amplifier::before { + content: "\F030"; +} +.mdi-anchor::before { + content: "\F031"; +} +.mdi-android::before { + content: "\F032"; +} +.mdi-android-auto::before { + content: "\FA8D"; +} +.mdi-android-debug-bridge::before { + content: "\F033"; +} +.mdi-android-head::before { + content: "\F78F"; +} +.mdi-android-messages::before { + content: "\FD21"; +} +.mdi-android-studio::before { + content: "\F034"; +} +.mdi-angle-acute::before { + content: "\F936"; +} +.mdi-angle-obtuse::before { + content: "\F937"; +} +.mdi-angle-right::before { + content: "\F938"; +} +.mdi-angular::before { + content: "\F6B1"; +} +.mdi-angularjs::before { + content: "\F6BE"; +} +.mdi-animation::before { + content: "\F5D8"; +} +.mdi-animation-outline::before { + content: "\FA8E"; +} +.mdi-animation-play::before { + content: "\F939"; +} +.mdi-animation-play-outline::before { + content: "\FA8F"; +} +.mdi-anvil::before { + content: "\F89A"; +} +.mdi-apple::before { + content: "\F035"; +} +.mdi-apple-finder::before { + content: "\F036"; +} +.mdi-apple-icloud::before { + content: "\F038"; +} +.mdi-apple-ios::before { + content: "\F037"; +} +.mdi-apple-keyboard-caps::before { + content: "\F632"; +} +.mdi-apple-keyboard-command::before { + content: "\F633"; +} +.mdi-apple-keyboard-control::before { + content: "\F634"; +} +.mdi-apple-keyboard-option::before { + content: "\F635"; +} +.mdi-apple-keyboard-shift::before { + content: "\F636"; +} +.mdi-apple-safari::before { + content: "\F039"; +} +.mdi-application::before { + content: "\F614"; +} +.mdi-application-export::before { + content: "\FD89"; +} +.mdi-application-import::before { + content: "\FD8A"; +} +.mdi-apps::before { + content: "\F03B"; +} +.mdi-apps-box::before { + content: "\FD22"; +} +.mdi-arch::before { + content: "\F8C6"; +} +.mdi-archive::before { + content: "\F03C"; +} +.mdi-arrange-bring-forward::before { + content: "\F03D"; +} +.mdi-arrange-bring-to-front::before { + content: "\F03E"; +} +.mdi-arrange-send-backward::before { + content: "\F03F"; +} +.mdi-arrange-send-to-back::before { + content: "\F040"; +} +.mdi-arrow-all::before { + content: "\F041"; +} +.mdi-arrow-bottom-left::before { + content: "\F042"; +} +.mdi-arrow-bottom-left-bold-outline::before { + content: "\F9B6"; +} +.mdi-arrow-bottom-left-thick::before { + content: "\F9B7"; +} +.mdi-arrow-bottom-right::before { + content: "\F043"; +} +.mdi-arrow-bottom-right-bold-outline::before { + content: "\F9B8"; +} +.mdi-arrow-bottom-right-thick::before { + content: "\F9B9"; +} +.mdi-arrow-collapse::before { + content: "\F615"; +} +.mdi-arrow-collapse-all::before { + content: "\F044"; +} +.mdi-arrow-collapse-down::before { + content: "\F791"; +} +.mdi-arrow-collapse-horizontal::before { + content: "\F84B"; +} +.mdi-arrow-collapse-left::before { + content: "\F792"; +} +.mdi-arrow-collapse-right::before { + content: "\F793"; +} +.mdi-arrow-collapse-up::before { + content: "\F794"; +} +.mdi-arrow-collapse-vertical::before { + content: "\F84C"; +} +.mdi-arrow-decision::before { + content: "\F9BA"; +} +.mdi-arrow-decision-auto::before { + content: "\F9BB"; +} +.mdi-arrow-decision-auto-outline::before { + content: "\F9BC"; +} +.mdi-arrow-decision-outline::before { + content: "\F9BD"; +} +.mdi-arrow-down::before { + content: "\F045"; +} +.mdi-arrow-down-bold::before { + content: "\F72D"; +} +.mdi-arrow-down-bold-box::before { + content: "\F72E"; +} +.mdi-arrow-down-bold-box-outline::before { + content: "\F72F"; +} +.mdi-arrow-down-bold-circle::before { + content: "\F047"; +} +.mdi-arrow-down-bold-circle-outline::before { + content: "\F048"; +} +.mdi-arrow-down-bold-hexagon-outline::before { + content: "\F049"; +} +.mdi-arrow-down-bold-outline::before { + content: "\F9BE"; +} +.mdi-arrow-down-box::before { + content: "\F6BF"; +} +.mdi-arrow-down-circle::before { + content: "\FCB7"; +} +.mdi-arrow-down-circle-outline::before { + content: "\FCB8"; +} +.mdi-arrow-down-drop-circle::before { + content: "\F04A"; +} +.mdi-arrow-down-drop-circle-outline::before { + content: "\F04B"; +} +.mdi-arrow-down-thick::before { + content: "\F046"; +} +.mdi-arrow-expand::before { + content: "\F616"; +} +.mdi-arrow-expand-all::before { + content: "\F04C"; +} +.mdi-arrow-expand-down::before { + content: "\F795"; +} +.mdi-arrow-expand-horizontal::before { + content: "\F84D"; +} +.mdi-arrow-expand-left::before { + content: "\F796"; +} +.mdi-arrow-expand-right::before { + content: "\F797"; +} +.mdi-arrow-expand-up::before { + content: "\F798"; +} +.mdi-arrow-expand-vertical::before { + content: "\F84E"; +} +.mdi-arrow-left::before { + content: "\F04D"; +} +.mdi-arrow-left-bold::before { + content: "\F730"; +} +.mdi-arrow-left-bold-box::before { + content: "\F731"; +} +.mdi-arrow-left-bold-box-outline::before { + content: "\F732"; +} +.mdi-arrow-left-bold-circle::before { + content: "\F04F"; +} +.mdi-arrow-left-bold-circle-outline::before { + content: "\F050"; +} +.mdi-arrow-left-bold-hexagon-outline::before { + content: "\F051"; +} +.mdi-arrow-left-bold-outline::before { + content: "\F9BF"; +} +.mdi-arrow-left-box::before { + content: "\F6C0"; +} +.mdi-arrow-left-circle::before { + content: "\FCB9"; +} +.mdi-arrow-left-circle-outline::before { + content: "\FCBA"; +} +.mdi-arrow-left-drop-circle::before { + content: "\F052"; +} +.mdi-arrow-left-drop-circle-outline::before { + content: "\F053"; +} +.mdi-arrow-left-right::before { + content: "\FE90"; +} +.mdi-arrow-left-right-bold::before { + content: "\FE91"; +} +.mdi-arrow-left-right-bold-outline::before { + content: "\F9C0"; +} +.mdi-arrow-left-thick::before { + content: "\F04E"; +} +.mdi-arrow-right::before { + content: "\F054"; +} +.mdi-arrow-right-bold::before { + content: "\F733"; +} +.mdi-arrow-right-bold-box::before { + content: "\F734"; +} +.mdi-arrow-right-bold-box-outline::before { + content: "\F735"; +} +.mdi-arrow-right-bold-circle::before { + content: "\F056"; +} +.mdi-arrow-right-bold-circle-outline::before { + content: "\F057"; +} +.mdi-arrow-right-bold-hexagon-outline::before { + content: "\F058"; +} +.mdi-arrow-right-bold-outline::before { + content: "\F9C1"; +} +.mdi-arrow-right-box::before { + content: "\F6C1"; +} +.mdi-arrow-right-circle::before { + content: "\FCBB"; +} +.mdi-arrow-right-circle-outline::before { + content: "\FCBC"; +} +.mdi-arrow-right-drop-circle::before { + content: "\F059"; +} +.mdi-arrow-right-drop-circle-outline::before { + content: "\F05A"; +} +.mdi-arrow-right-thick::before { + content: "\F055"; +} +.mdi-arrow-split-horizontal::before { + content: "\F93A"; +} +.mdi-arrow-split-vertical::before { + content: "\F93B"; +} +.mdi-arrow-top-left::before { + content: "\F05B"; +} +.mdi-arrow-top-left-bold-outline::before { + content: "\F9C2"; +} +.mdi-arrow-top-left-bottom-right::before { + content: "\FE92"; +} +.mdi-arrow-top-left-bottom-right-bold::before { + content: "\FE93"; +} +.mdi-arrow-top-left-thick::before { + content: "\F9C3"; +} +.mdi-arrow-top-right::before { + content: "\F05C"; +} +.mdi-arrow-top-right-bold-outline::before { + content: "\F9C4"; +} +.mdi-arrow-top-right-bottom-left::before { + content: "\FE94"; +} +.mdi-arrow-top-right-bottom-left-bold::before { + content: "\FE95"; +} +.mdi-arrow-top-right-thick::before { + content: "\F9C5"; +} +.mdi-arrow-up::before { + content: "\F05D"; +} +.mdi-arrow-up-bold::before { + content: "\F736"; +} +.mdi-arrow-up-bold-box::before { + content: "\F737"; +} +.mdi-arrow-up-bold-box-outline::before { + content: "\F738"; +} +.mdi-arrow-up-bold-circle::before { + content: "\F05F"; +} +.mdi-arrow-up-bold-circle-outline::before { + content: "\F060"; +} +.mdi-arrow-up-bold-hexagon-outline::before { + content: "\F061"; +} +.mdi-arrow-up-bold-outline::before { + content: "\F9C6"; +} +.mdi-arrow-up-box::before { + content: "\F6C2"; +} +.mdi-arrow-up-circle::before { + content: "\FCBD"; +} +.mdi-arrow-up-circle-outline::before { + content: "\FCBE"; +} +.mdi-arrow-up-down::before { + content: "\FE96"; +} +.mdi-arrow-up-down-bold::before { + content: "\FE97"; +} +.mdi-arrow-up-down-bold-outline::before { + content: "\F9C7"; +} +.mdi-arrow-up-drop-circle::before { + content: "\F062"; +} +.mdi-arrow-up-drop-circle-outline::before { + content: "\F063"; +} +.mdi-arrow-up-thick::before { + content: "\F05E"; +} +.mdi-artist::before { + content: "\F802"; +} +.mdi-artist-outline::before { + content: "\FCC5"; +} +.mdi-artstation::before { + content: "\FB37"; +} +.mdi-aspect-ratio::before { + content: "\FA23"; +} +.mdi-assistant::before { + content: "\F064"; +} +.mdi-asterisk::before { + content: "\F6C3"; +} +.mdi-at::before { + content: "\F065"; +} +.mdi-atlassian::before { + content: "\F803"; +} +.mdi-atm::before { + content: "\FD23"; +} +.mdi-atom::before { + content: "\F767"; +} +.mdi-atom-variant::before { + content: "\FE98"; +} +.mdi-attachment::before { + content: "\F066"; +} +.mdi-audio-video::before { + content: "\F93C"; +} +.mdi-audiobook::before { + content: "\F067"; +} +.mdi-augmented-reality::before { + content: "\F84F"; +} +.mdi-auto-fix::before { + content: "\F068"; +} +.mdi-auto-upload::before { + content: "\F069"; +} +.mdi-autorenew::before { + content: "\F06A"; +} +.mdi-av-timer::before { + content: "\F06B"; +} +.mdi-aws::before { + content: "\FDF2"; +} +.mdi-axe::before { + content: "\F8C7"; +} +.mdi-axis::before { + content: "\FD24"; +} +.mdi-axis-arrow::before { + content: "\FD25"; +} +.mdi-axis-arrow-lock::before { + content: "\FD26"; +} +.mdi-axis-lock::before { + content: "\FD27"; +} +.mdi-axis-x-arrow::before { + content: "\FD28"; +} +.mdi-axis-x-arrow-lock::before { + content: "\FD29"; +} +.mdi-axis-x-rotate-clockwise::before { + content: "\FD2A"; +} +.mdi-axis-x-rotate-counterclockwise::before { + content: "\FD2B"; +} +.mdi-axis-x-y-arrow-lock::before { + content: "\FD2C"; +} +.mdi-axis-y-arrow::before { + content: "\FD2D"; +} +.mdi-axis-y-arrow-lock::before { + content: "\FD2E"; +} +.mdi-axis-y-rotate-clockwise::before { + content: "\FD2F"; +} +.mdi-axis-y-rotate-counterclockwise::before { + content: "\FD30"; +} +.mdi-axis-z-arrow::before { + content: "\FD31"; +} +.mdi-axis-z-arrow-lock::before { + content: "\FD32"; +} +.mdi-axis-z-rotate-clockwise::before { + content: "\FD33"; +} +.mdi-axis-z-rotate-counterclockwise::before { + content: "\FD34"; +} +.mdi-azure::before { + content: "\F804"; +} +.mdi-babel::before { + content: "\FA24"; +} +.mdi-baby::before { + content: "\F06C"; +} +.mdi-baby-bottle::before { + content: "\FF56"; +} +.mdi-baby-bottle-outline::before { + content: "\FF57"; +} +.mdi-baby-buggy::before { + content: "\F68E"; +} +.mdi-baby-face::before { + content: "\FE99"; +} +.mdi-baby-face-outline::before { + content: "\FE9A"; +} +.mdi-backburger::before { + content: "\F06D"; +} +.mdi-backspace::before { + content: "\F06E"; +} +.mdi-backspace-outline::before { + content: "\FB38"; +} +.mdi-backspace-reverse::before { + content: "\FE9B"; +} +.mdi-backspace-reverse-outline::before { + content: "\FE9C"; +} +.mdi-backup-restore::before { + content: "\F06F"; +} +.mdi-bacteria::before { + content: "\FEF2"; +} +.mdi-bacteria-outline::before { + content: "\FEF3"; +} +.mdi-badminton::before { + content: "\F850"; +} +.mdi-bag-carry-on::before { + content: "\FF58"; +} +.mdi-bag-carry-on-check::before { + content: "\FD41"; +} +.mdi-bag-carry-on-off::before { + content: "\FF59"; +} +.mdi-bag-checked::before { + content: "\FF5A"; +} +.mdi-bag-personal::before { + content: "\FDF3"; +} +.mdi-bag-personal-off::before { + content: "\FDF4"; +} +.mdi-bag-personal-off-outline::before { + content: "\FDF5"; +} +.mdi-bag-personal-outline::before { + content: "\FDF6"; +} +.mdi-baguette::before { + content: "\FF5B"; +} +.mdi-balloon::before { + content: "\FA25"; +} +.mdi-ballot::before { + content: "\F9C8"; +} +.mdi-ballot-outline::before { + content: "\F9C9"; +} +.mdi-ballot-recount::before { + content: "\FC15"; +} +.mdi-ballot-recount-outline::before { + content: "\FC16"; +} +.mdi-bandage::before { + content: "\FD8B"; +} +.mdi-bandcamp::before { + content: "\F674"; +} +.mdi-bank::before { + content: "\F070"; +} +.mdi-bank-minus::before { + content: "\FD8C"; +} +.mdi-bank-outline::before { + content: "\FE9D"; +} +.mdi-bank-plus::before { + content: "\FD8D"; +} +.mdi-bank-remove::before { + content: "\FD8E"; +} +.mdi-bank-transfer::before { + content: "\FA26"; +} +.mdi-bank-transfer-in::before { + content: "\FA27"; +} +.mdi-bank-transfer-out::before { + content: "\FA28"; +} +.mdi-barcode::before { + content: "\F071"; +} +.mdi-barcode-scan::before { + content: "\F072"; +} +.mdi-barley::before { + content: "\F073"; +} +.mdi-barley-off::before { + content: "\FB39"; +} +.mdi-barn::before { + content: "\FB3A"; +} +.mdi-barrel::before { + content: "\F074"; +} +.mdi-baseball::before { + content: "\F851"; +} +.mdi-baseball-bat::before { + content: "\F852"; +} +.mdi-basecamp::before { + content: "\F075"; +} +.mdi-basket::before { + content: "\F076"; +} +.mdi-basket-fill::before { + content: "\F077"; +} +.mdi-basket-unfill::before { + content: "\F078"; +} +.mdi-basketball::before { + content: "\F805"; +} +.mdi-basketball-hoop::before { + content: "\FC17"; +} +.mdi-basketball-hoop-outline::before { + content: "\FC18"; +} +.mdi-bat::before { + content: "\FB3B"; +} +.mdi-battery::before { + content: "\F079"; +} +.mdi-battery-10::before { + content: "\F07A"; +} +.mdi-battery-10-bluetooth::before { + content: "\F93D"; +} +.mdi-battery-20::before { + content: "\F07B"; +} +.mdi-battery-20-bluetooth::before { + content: "\F93E"; +} +.mdi-battery-30::before { + content: "\F07C"; +} +.mdi-battery-30-bluetooth::before { + content: "\F93F"; +} +.mdi-battery-40::before { + content: "\F07D"; +} +.mdi-battery-40-bluetooth::before { + content: "\F940"; +} +.mdi-battery-50::before { + content: "\F07E"; +} +.mdi-battery-50-bluetooth::before { + content: "\F941"; +} +.mdi-battery-60::before { + content: "\F07F"; +} +.mdi-battery-60-bluetooth::before { + content: "\F942"; +} +.mdi-battery-70::before { + content: "\F080"; +} +.mdi-battery-70-bluetooth::before { + content: "\F943"; +} +.mdi-battery-80::before { + content: "\F081"; +} +.mdi-battery-80-bluetooth::before { + content: "\F944"; +} +.mdi-battery-90::before { + content: "\F082"; +} +.mdi-battery-90-bluetooth::before { + content: "\F945"; +} +.mdi-battery-alert::before { + content: "\F083"; +} +.mdi-battery-alert-bluetooth::before { + content: "\F946"; +} +.mdi-battery-bluetooth::before { + content: "\F947"; +} +.mdi-battery-bluetooth-variant::before { + content: "\F948"; +} +.mdi-battery-charging::before { + content: "\F084"; +} +.mdi-battery-charging-10::before { + content: "\F89B"; +} +.mdi-battery-charging-100::before { + content: "\F085"; +} +.mdi-battery-charging-20::before { + content: "\F086"; +} +.mdi-battery-charging-30::before { + content: "\F087"; +} +.mdi-battery-charging-40::before { + content: "\F088"; +} +.mdi-battery-charging-50::before { + content: "\F89C"; +} +.mdi-battery-charging-60::before { + content: "\F089"; +} +.mdi-battery-charging-70::before { + content: "\F89D"; +} +.mdi-battery-charging-80::before { + content: "\F08A"; +} +.mdi-battery-charging-90::before { + content: "\F08B"; +} +.mdi-battery-charging-outline::before { + content: "\F89E"; +} +.mdi-battery-charging-wireless::before { + content: "\F806"; +} +.mdi-battery-charging-wireless-10::before { + content: "\F807"; +} +.mdi-battery-charging-wireless-20::before { + content: "\F808"; +} +.mdi-battery-charging-wireless-30::before { + content: "\F809"; +} +.mdi-battery-charging-wireless-40::before { + content: "\F80A"; +} +.mdi-battery-charging-wireless-50::before { + content: "\F80B"; +} +.mdi-battery-charging-wireless-60::before { + content: "\F80C"; +} +.mdi-battery-charging-wireless-70::before { + content: "\F80D"; +} +.mdi-battery-charging-wireless-80::before { + content: "\F80E"; +} +.mdi-battery-charging-wireless-90::before { + content: "\F80F"; +} +.mdi-battery-charging-wireless-alert::before { + content: "\F810"; +} +.mdi-battery-charging-wireless-outline::before { + content: "\F811"; +} +.mdi-battery-minus::before { + content: "\F08C"; +} +.mdi-battery-negative::before { + content: "\F08D"; +} +.mdi-battery-outline::before { + content: "\F08E"; +} +.mdi-battery-plus::before { + content: "\F08F"; +} +.mdi-battery-positive::before { + content: "\F090"; +} +.mdi-battery-unknown::before { + content: "\F091"; +} +.mdi-battery-unknown-bluetooth::before { + content: "\F949"; +} +.mdi-battlenet::before { + content: "\FB3C"; +} +.mdi-beach::before { + content: "\F092"; +} +.mdi-beaker::before { + content: "\FCC6"; +} +.mdi-beaker-outline::before { + content: "\F68F"; +} +.mdi-beats::before { + content: "\F097"; +} +.mdi-bed-empty::before { + content: "\F89F"; +} +.mdi-beer::before { + content: "\F098"; +} +.mdi-behance::before { + content: "\F099"; +} +.mdi-bell::before { + content: "\F09A"; +} +.mdi-bell-alert::before { + content: "\FD35"; +} +.mdi-bell-alert-outline::before { + content: "\FE9E"; +} +.mdi-bell-circle::before { + content: "\FD36"; +} +.mdi-bell-circle-outline::before { + content: "\FD37"; +} +.mdi-bell-off::before { + content: "\F09B"; +} +.mdi-bell-off-outline::before { + content: "\FA90"; +} +.mdi-bell-outline::before { + content: "\F09C"; +} +.mdi-bell-plus::before { + content: "\F09D"; +} +.mdi-bell-plus-outline::before { + content: "\FA91"; +} +.mdi-bell-ring::before { + content: "\F09E"; +} +.mdi-bell-ring-outline::before { + content: "\F09F"; +} +.mdi-bell-sleep::before { + content: "\F0A0"; +} +.mdi-bell-sleep-outline::before { + content: "\FA92"; +} +.mdi-beta::before { + content: "\F0A1"; +} +.mdi-betamax::before { + content: "\F9CA"; +} +.mdi-biathlon::before { + content: "\FDF7"; +} +.mdi-bible::before { + content: "\F0A2"; +} +.mdi-bike::before { + content: "\F0A3"; +} +.mdi-billiards::before { + content: "\FB3D"; +} +.mdi-billiards-rack::before { + content: "\FB3E"; +} +.mdi-bing::before { + content: "\F0A4"; +} +.mdi-binoculars::before { + content: "\F0A5"; +} +.mdi-bio::before { + content: "\F0A6"; +} +.mdi-biohazard::before { + content: "\F0A7"; +} +.mdi-bitbucket::before { + content: "\F0A8"; +} +.mdi-bitcoin::before { + content: "\F812"; +} +.mdi-black-mesa::before { + content: "\F0A9"; +} +.mdi-blackberry::before { + content: "\F0AA"; +} +.mdi-blender::before { + content: "\FCC7"; +} +.mdi-blender-software::before { + content: "\F0AB"; +} +.mdi-blinds::before { + content: "\F0AC"; +} +.mdi-block-helper::before { + content: "\F0AD"; +} +.mdi-blogger::before { + content: "\F0AE"; +} +.mdi-blood-bag::before { + content: "\FCC8"; +} +.mdi-bluetooth::before { + content: "\F0AF"; +} +.mdi-bluetooth-audio::before { + content: "\F0B0"; +} +.mdi-bluetooth-connect::before { + content: "\F0B1"; +} +.mdi-bluetooth-off::before { + content: "\F0B2"; +} +.mdi-bluetooth-settings::before { + content: "\F0B3"; +} +.mdi-bluetooth-transfer::before { + content: "\F0B4"; +} +.mdi-blur::before { + content: "\F0B5"; +} +.mdi-blur-linear::before { + content: "\F0B6"; +} +.mdi-blur-off::before { + content: "\F0B7"; +} +.mdi-blur-radial::before { + content: "\F0B8"; +} +.mdi-bolnisi-cross::before { + content: "\FCC9"; +} +.mdi-bolt::before { + content: "\FD8F"; +} +.mdi-bomb::before { + content: "\F690"; +} +.mdi-bomb-off::before { + content: "\F6C4"; +} +.mdi-bone::before { + content: "\F0B9"; +} +.mdi-book::before { + content: "\F0BA"; +} +.mdi-book-lock::before { + content: "\F799"; +} +.mdi-book-lock-open::before { + content: "\F79A"; +} +.mdi-book-minus::before { + content: "\F5D9"; +} +.mdi-book-minus-multiple::before { + content: "\FA93"; +} +.mdi-book-multiple::before { + content: "\F0BB"; +} +.mdi-book-open::before { + content: "\F0BD"; +} +.mdi-book-open-outline::before { + content: "\FB3F"; +} +.mdi-book-open-page-variant::before { + content: "\F5DA"; +} +.mdi-book-open-variant::before { + content: "\F0BE"; +} +.mdi-book-outline::before { + content: "\FB40"; +} +.mdi-book-play::before { + content: "\FE9F"; +} +.mdi-book-play-outline::before { + content: "\FEA0"; +} +.mdi-book-plus::before { + content: "\F5DB"; +} +.mdi-book-plus-multiple::before { + content: "\FA94"; +} +.mdi-book-remove::before { + content: "\FA96"; +} +.mdi-book-remove-multiple::before { + content: "\FA95"; +} +.mdi-book-search::before { + content: "\FEA1"; +} +.mdi-book-search-outline::before { + content: "\FEA2"; +} +.mdi-book-variant::before { + content: "\F0BF"; +} +.mdi-book-variant-multiple::before { + content: "\F0BC"; +} +.mdi-bookmark::before { + content: "\F0C0"; +} +.mdi-bookmark-check::before { + content: "\F0C1"; +} +.mdi-bookmark-minus::before { + content: "\F9CB"; +} +.mdi-bookmark-minus-outline::before { + content: "\F9CC"; +} +.mdi-bookmark-multiple::before { + content: "\FDF8"; +} +.mdi-bookmark-multiple-outline::before { + content: "\FDF9"; +} +.mdi-bookmark-music::before { + content: "\F0C2"; +} +.mdi-bookmark-off::before { + content: "\F9CD"; +} +.mdi-bookmark-off-outline::before { + content: "\F9CE"; +} +.mdi-bookmark-outline::before { + content: "\F0C3"; +} +.mdi-bookmark-plus::before { + content: "\F0C5"; +} +.mdi-bookmark-plus-outline::before { + content: "\F0C4"; +} +.mdi-bookmark-remove::before { + content: "\F0C6"; +} +.mdi-boom-gate::before { + content: "\FEA3"; +} +.mdi-boom-gate-alert::before { + content: "\FEA4"; +} +.mdi-boom-gate-alert-outline::before { + content: "\FEA5"; +} +.mdi-boom-gate-down::before { + content: "\FEA6"; +} +.mdi-boom-gate-down-outline::before { + content: "\FEA7"; +} +.mdi-boom-gate-outline::before { + content: "\FEA8"; +} +.mdi-boom-gate-up::before { + content: "\FEA9"; +} +.mdi-boom-gate-up-outline::before { + content: "\FEAA"; +} +.mdi-boombox::before { + content: "\F5DC"; +} +.mdi-bootstrap::before { + content: "\F6C5"; +} +.mdi-border-all::before { + content: "\F0C7"; +} +.mdi-border-all-variant::before { + content: "\F8A0"; +} +.mdi-border-bottom::before { + content: "\F0C8"; +} +.mdi-border-bottom-variant::before { + content: "\F8A1"; +} +.mdi-border-color::before { + content: "\F0C9"; +} +.mdi-border-horizontal::before { + content: "\F0CA"; +} +.mdi-border-inside::before { + content: "\F0CB"; +} +.mdi-border-left::before { + content: "\F0CC"; +} +.mdi-border-left-variant::before { + content: "\F8A2"; +} +.mdi-border-none::before { + content: "\F0CD"; +} +.mdi-border-none-variant::before { + content: "\F8A3"; +} +.mdi-border-outside::before { + content: "\F0CE"; +} +.mdi-border-right::before { + content: "\F0CF"; +} +.mdi-border-right-variant::before { + content: "\F8A4"; +} +.mdi-border-style::before { + content: "\F0D0"; +} +.mdi-border-top::before { + content: "\F0D1"; +} +.mdi-border-top-variant::before { + content: "\F8A5"; +} +.mdi-border-vertical::before { + content: "\F0D2"; +} +.mdi-bottle-wine::before { + content: "\F853"; +} +.mdi-bow-tie::before { + content: "\F677"; +} +.mdi-bowl::before { + content: "\F617"; +} +.mdi-bowling::before { + content: "\F0D3"; +} +.mdi-box::before { + content: "\F0D4"; +} +.mdi-box-cutter::before { + content: "\F0D5"; +} +.mdi-box-shadow::before { + content: "\F637"; +} +.mdi-boxing-glove::before { + content: "\FB41"; +} +.mdi-braille::before { + content: "\F9CF"; +} +.mdi-brain::before { + content: "\F9D0"; +} +.mdi-bread-slice::before { + content: "\FCCA"; +} +.mdi-bread-slice-outline::before { + content: "\FCCB"; +} +.mdi-bridge::before { + content: "\F618"; +} +.mdi-briefcase::before { + content: "\F0D6"; +} +.mdi-briefcase-account::before { + content: "\FCCC"; +} +.mdi-briefcase-account-outline::before { + content: "\FCCD"; +} +.mdi-briefcase-check::before { + content: "\F0D7"; +} +.mdi-briefcase-download::before { + content: "\F0D8"; +} +.mdi-briefcase-download-outline::before { + content: "\FC19"; +} +.mdi-briefcase-edit::before { + content: "\FA97"; +} +.mdi-briefcase-edit-outline::before { + content: "\FC1A"; +} +.mdi-briefcase-minus::before { + content: "\FA29"; +} +.mdi-briefcase-minus-outline::before { + content: "\FC1B"; +} +.mdi-briefcase-outline::before { + content: "\F813"; +} +.mdi-briefcase-plus::before { + content: "\FA2A"; +} +.mdi-briefcase-plus-outline::before { + content: "\FC1C"; +} +.mdi-briefcase-remove::before { + content: "\FA2B"; +} +.mdi-briefcase-remove-outline::before { + content: "\FC1D"; +} +.mdi-briefcase-search::before { + content: "\FA2C"; +} +.mdi-briefcase-search-outline::before { + content: "\FC1E"; +} +.mdi-briefcase-upload::before { + content: "\F0D9"; +} +.mdi-briefcase-upload-outline::before { + content: "\FC1F"; +} +.mdi-brightness-1::before { + content: "\F0DA"; +} +.mdi-brightness-2::before { + content: "\F0DB"; +} +.mdi-brightness-3::before { + content: "\F0DC"; +} +.mdi-brightness-4::before { + content: "\F0DD"; +} +.mdi-brightness-5::before { + content: "\F0DE"; +} +.mdi-brightness-6::before { + content: "\F0DF"; +} +.mdi-brightness-7::before { + content: "\F0E0"; +} +.mdi-brightness-auto::before { + content: "\F0E1"; +} +.mdi-brightness-percent::before { + content: "\FCCE"; +} +.mdi-broom::before { + content: "\F0E2"; +} +.mdi-brush::before { + content: "\F0E3"; +} +.mdi-buddhism::before { + content: "\F94A"; +} +.mdi-buffer::before { + content: "\F619"; +} +.mdi-bug::before { + content: "\F0E4"; +} +.mdi-bug-check::before { + content: "\FA2D"; +} +.mdi-bug-check-outline::before { + content: "\FA2E"; +} +.mdi-bug-outline::before { + content: "\FA2F"; +} +.mdi-bugle::before { + content: "\FD90"; +} +.mdi-bulldozer::before { + content: "\FB07"; +} +.mdi-bullet::before { + content: "\FCCF"; +} +.mdi-bulletin-board::before { + content: "\F0E5"; +} +.mdi-bullhorn::before { + content: "\F0E6"; +} +.mdi-bullhorn-outline::before { + content: "\FB08"; +} +.mdi-bullseye::before { + content: "\F5DD"; +} +.mdi-bullseye-arrow::before { + content: "\F8C8"; +} +.mdi-bus::before { + content: "\F0E7"; +} +.mdi-bus-alert::before { + content: "\FA98"; +} +.mdi-bus-articulated-end::before { + content: "\F79B"; +} +.mdi-bus-articulated-front::before { + content: "\F79C"; +} +.mdi-bus-clock::before { + content: "\F8C9"; +} +.mdi-bus-double-decker::before { + content: "\F79D"; +} +.mdi-bus-multiple::before { + content: "\FF5C"; +} +.mdi-bus-school::before { + content: "\F79E"; +} +.mdi-bus-side::before { + content: "\F79F"; +} +.mdi-cached::before { + content: "\F0E8"; +} +.mdi-cactus::before { + content: "\FD91"; +} +.mdi-cake::before { + content: "\F0E9"; +} +.mdi-cake-layered::before { + content: "\F0EA"; +} +.mdi-cake-variant::before { + content: "\F0EB"; +} +.mdi-calculator::before { + content: "\F0EC"; +} +.mdi-calculator-variant::before { + content: "\FA99"; +} +.mdi-calendar::before { + content: "\F0ED"; +} +.mdi-calendar-account::before { + content: "\FEF4"; +} +.mdi-calendar-account-outline::before { + content: "\FEF5"; +} +.mdi-calendar-alert::before { + content: "\FA30"; +} +.mdi-calendar-blank::before { + content: "\F0EE"; +} +.mdi-calendar-blank-outline::before { + content: "\FB42"; +} +.mdi-calendar-check::before { + content: "\F0EF"; +} +.mdi-calendar-check-outline::before { + content: "\FC20"; +} +.mdi-calendar-clock::before { + content: "\F0F0"; +} +.mdi-calendar-edit::before { + content: "\F8A6"; +} +.mdi-calendar-export::before { + content: "\FB09"; +} +.mdi-calendar-heart::before { + content: "\F9D1"; +} +.mdi-calendar-import::before { + content: "\FB0A"; +} +.mdi-calendar-minus::before { + content: "\FD38"; +} +.mdi-calendar-month::before { + content: "\FDFA"; +} +.mdi-calendar-month-outline::before { + content: "\FDFB"; +} +.mdi-calendar-multiple::before { + content: "\F0F1"; +} +.mdi-calendar-multiple-check::before { + content: "\F0F2"; +} +.mdi-calendar-multiselect::before { + content: "\FA31"; +} +.mdi-calendar-outline::before { + content: "\FB43"; +} +.mdi-calendar-plus::before { + content: "\F0F3"; +} +.mdi-calendar-question::before { + content: "\F691"; +} +.mdi-calendar-range::before { + content: "\F678"; +} +.mdi-calendar-range-outline::before { + content: "\FB44"; +} +.mdi-calendar-remove::before { + content: "\F0F4"; +} +.mdi-calendar-remove-outline::before { + content: "\FC21"; +} +.mdi-calendar-repeat::before { + content: "\FEAB"; +} +.mdi-calendar-repeat-outline::before { + content: "\FEAC"; +} +.mdi-calendar-search::before { + content: "\F94B"; +} +.mdi-calendar-star::before { + content: "\F9D2"; +} +.mdi-calendar-text::before { + content: "\F0F5"; +} +.mdi-calendar-text-outline::before { + content: "\FC22"; +} +.mdi-calendar-today::before { + content: "\F0F6"; +} +.mdi-calendar-week::before { + content: "\FA32"; +} +.mdi-calendar-week-begin::before { + content: "\FA33"; +} +.mdi-calendar-weekend::before { + content: "\FEF6"; +} +.mdi-calendar-weekend-outline::before { + content: "\FEF7"; +} +.mdi-call-made::before { + content: "\F0F7"; +} +.mdi-call-merge::before { + content: "\F0F8"; +} +.mdi-call-missed::before { + content: "\F0F9"; +} +.mdi-call-received::before { + content: "\F0FA"; +} +.mdi-call-split::before { + content: "\F0FB"; +} +.mdi-camcorder::before { + content: "\F0FC"; +} +.mdi-camcorder-box::before { + content: "\F0FD"; +} +.mdi-camcorder-box-off::before { + content: "\F0FE"; +} +.mdi-camcorder-off::before { + content: "\F0FF"; +} +.mdi-camera::before { + content: "\F100"; +} +.mdi-camera-account::before { + content: "\F8CA"; +} +.mdi-camera-burst::before { + content: "\F692"; +} +.mdi-camera-control::before { + content: "\FB45"; +} +.mdi-camera-enhance::before { + content: "\F101"; +} +.mdi-camera-enhance-outline::before { + content: "\FB46"; +} +.mdi-camera-front::before { + content: "\F102"; +} +.mdi-camera-front-variant::before { + content: "\F103"; +} +.mdi-camera-gopro::before { + content: "\F7A0"; +} +.mdi-camera-image::before { + content: "\F8CB"; +} +.mdi-camera-iris::before { + content: "\F104"; +} +.mdi-camera-metering-center::before { + content: "\F7A1"; +} +.mdi-camera-metering-matrix::before { + content: "\F7A2"; +} +.mdi-camera-metering-partial::before { + content: "\F7A3"; +} +.mdi-camera-metering-spot::before { + content: "\F7A4"; +} +.mdi-camera-off::before { + content: "\F5DF"; +} +.mdi-camera-outline::before { + content: "\FD39"; +} +.mdi-camera-party-mode::before { + content: "\F105"; +} +.mdi-camera-plus::before { + content: "\FEF8"; +} +.mdi-camera-plus-outline::before { + content: "\FEF9"; +} +.mdi-camera-rear::before { + content: "\F106"; +} +.mdi-camera-rear-variant::before { + content: "\F107"; +} +.mdi-camera-retake::before { + content: "\FDFC"; +} +.mdi-camera-retake-outline::before { + content: "\FDFD"; +} +.mdi-camera-switch::before { + content: "\F108"; +} +.mdi-camera-timer::before { + content: "\F109"; +} +.mdi-camera-wireless::before { + content: "\FD92"; +} +.mdi-camera-wireless-outline::before { + content: "\FD93"; +} +.mdi-campfire::before { + content: "\FEFA"; +} +.mdi-cancel::before { + content: "\F739"; +} +.mdi-candle::before { + content: "\F5E2"; +} +.mdi-candycane::before { + content: "\F10A"; +} +.mdi-cannabis::before { + content: "\F7A5"; +} +.mdi-caps-lock::before { + content: "\FA9A"; +} +.mdi-car::before { + content: "\F10B"; +} +.mdi-car-back::before { + content: "\FDFE"; +} +.mdi-car-battery::before { + content: "\F10C"; +} +.mdi-car-brake-abs::before { + content: "\FC23"; +} +.mdi-car-brake-alert::before { + content: "\FC24"; +} +.mdi-car-brake-hold::before { + content: "\FD3A"; +} +.mdi-car-brake-parking::before { + content: "\FD3B"; +} +.mdi-car-connected::before { + content: "\F10D"; +} +.mdi-car-convertible::before { + content: "\F7A6"; +} +.mdi-car-cruise-control::before { + content: "\FD3C"; +} +.mdi-car-defrost-front::before { + content: "\FD3D"; +} +.mdi-car-defrost-rear::before { + content: "\FD3E"; +} +.mdi-car-door::before { + content: "\FB47"; +} +.mdi-car-electric::before { + content: "\FB48"; +} +.mdi-car-esp::before { + content: "\FC25"; +} +.mdi-car-estate::before { + content: "\F7A7"; +} +.mdi-car-hatchback::before { + content: "\F7A8"; +} +.mdi-car-key::before { + content: "\FB49"; +} +.mdi-car-light-dimmed::before { + content: "\FC26"; +} +.mdi-car-light-fog::before { + content: "\FC27"; +} +.mdi-car-light-high::before { + content: "\FC28"; +} +.mdi-car-limousine::before { + content: "\F8CC"; +} +.mdi-car-multiple::before { + content: "\FB4A"; +} +.mdi-car-off::before { + content: "\FDFF"; +} +.mdi-car-parking-lights::before { + content: "\FD3F"; +} +.mdi-car-pickup::before { + content: "\F7A9"; +} +.mdi-car-shift-pattern::before { + content: "\FF5D"; +} +.mdi-car-side::before { + content: "\F7AA"; +} +.mdi-car-sports::before { + content: "\F7AB"; +} +.mdi-car-tire-alert::before { + content: "\FC29"; +} +.mdi-car-traction-control::before { + content: "\FD40"; +} +.mdi-car-wash::before { + content: "\F10E"; +} +.mdi-caravan::before { + content: "\F7AC"; +} +.mdi-card::before { + content: "\FB4B"; +} +.mdi-card-bulleted::before { + content: "\FB4C"; +} +.mdi-card-bulleted-off::before { + content: "\FB4D"; +} +.mdi-card-bulleted-off-outline::before { + content: "\FB4E"; +} +.mdi-card-bulleted-outline::before { + content: "\FB4F"; +} +.mdi-card-bulleted-settings::before { + content: "\FB50"; +} +.mdi-card-bulleted-settings-outline::before { + content: "\FB51"; +} +.mdi-card-outline::before { + content: "\FB52"; +} +.mdi-card-text::before { + content: "\FB53"; +} +.mdi-card-text-outline::before { + content: "\FB54"; +} +.mdi-cards::before { + content: "\F638"; +} +.mdi-cards-club::before { + content: "\F8CD"; +} +.mdi-cards-diamond::before { + content: "\F8CE"; +} +.mdi-cards-heart::before { + content: "\F8CF"; +} +.mdi-cards-outline::before { + content: "\F639"; +} +.mdi-cards-playing-outline::before { + content: "\F63A"; +} +.mdi-cards-spade::before { + content: "\F8D0"; +} +.mdi-cards-variant::before { + content: "\F6C6"; +} +.mdi-carrot::before { + content: "\F10F"; +} +.mdi-cart::before { + content: "\F110"; +} +.mdi-cart-arrow-down::before { + content: "\FD42"; +} +.mdi-cart-arrow-right::before { + content: "\FC2A"; +} +.mdi-cart-arrow-up::before { + content: "\FD43"; +} +.mdi-cart-minus::before { + content: "\FD44"; +} +.mdi-cart-off::before { + content: "\F66B"; +} +.mdi-cart-outline::before { + content: "\F111"; +} +.mdi-cart-plus::before { + content: "\F112"; +} +.mdi-cart-remove::before { + content: "\FD45"; +} +.mdi-case-sensitive-alt::before { + content: "\F113"; +} +.mdi-cash::before { + content: "\F114"; +} +.mdi-cash-100::before { + content: "\F115"; +} +.mdi-cash-marker::before { + content: "\FD94"; +} +.mdi-cash-multiple::before { + content: "\F116"; +} +.mdi-cash-refund::before { + content: "\FA9B"; +} +.mdi-cash-register::before { + content: "\FCD0"; +} +.mdi-cash-usd::before { + content: "\F117"; +} +.mdi-cassette::before { + content: "\F9D3"; +} +.mdi-cast::before { + content: "\F118"; +} +.mdi-cast-connected::before { + content: "\F119"; +} +.mdi-cast-education::before { + content: "\FE6D"; +} +.mdi-cast-off::before { + content: "\F789"; +} +.mdi-castle::before { + content: "\F11A"; +} +.mdi-cat::before { + content: "\F11B"; +} +.mdi-cctv::before { + content: "\F7AD"; +} +.mdi-ceiling-light::before { + content: "\F768"; +} +.mdi-cellphone::before { + content: "\F11C"; +} +.mdi-cellphone-android::before { + content: "\F11D"; +} +.mdi-cellphone-arrow-down::before { + content: "\F9D4"; +} +.mdi-cellphone-basic::before { + content: "\F11E"; +} +.mdi-cellphone-dock::before { + content: "\F11F"; +} +.mdi-cellphone-erase::before { + content: "\F94C"; +} +.mdi-cellphone-information::before { + content: "\FF5E"; +} +.mdi-cellphone-iphone::before { + content: "\F120"; +} +.mdi-cellphone-key::before { + content: "\F94D"; +} +.mdi-cellphone-link::before { + content: "\F121"; +} +.mdi-cellphone-link-off::before { + content: "\F122"; +} +.mdi-cellphone-lock::before { + content: "\F94E"; +} +.mdi-cellphone-message::before { + content: "\F8D2"; +} +.mdi-cellphone-nfc::before { + content: "\FEAD"; +} +.mdi-cellphone-off::before { + content: "\F94F"; +} +.mdi-cellphone-screenshot::before { + content: "\FA34"; +} +.mdi-cellphone-settings::before { + content: "\F123"; +} +.mdi-cellphone-settings-variant::before { + content: "\F950"; +} +.mdi-cellphone-sound::before { + content: "\F951"; +} +.mdi-cellphone-text::before { + content: "\F8D1"; +} +.mdi-cellphone-wireless::before { + content: "\F814"; +} +.mdi-celtic-cross::before { + content: "\FCD1"; +} +.mdi-certificate::before { + content: "\F124"; +} +.mdi-chair-rolling::before { + content: "\FFBA"; +} +.mdi-chair-school::before { + content: "\F125"; +} +.mdi-charity::before { + content: "\FC2B"; +} +.mdi-chart-arc::before { + content: "\F126"; +} +.mdi-chart-areaspline::before { + content: "\F127"; +} +.mdi-chart-areaspline-variant::before { + content: "\FEAE"; +} +.mdi-chart-bar::before { + content: "\F128"; +} +.mdi-chart-bar-stacked::before { + content: "\F769"; +} +.mdi-chart-bell-curve::before { + content: "\FC2C"; +} +.mdi-chart-bubble::before { + content: "\F5E3"; +} +.mdi-chart-donut::before { + content: "\F7AE"; +} +.mdi-chart-donut-variant::before { + content: "\F7AF"; +} +.mdi-chart-gantt::before { + content: "\F66C"; +} +.mdi-chart-histogram::before { + content: "\F129"; +} +.mdi-chart-line::before { + content: "\F12A"; +} +.mdi-chart-line-stacked::before { + content: "\F76A"; +} +.mdi-chart-line-variant::before { + content: "\F7B0"; +} +.mdi-chart-multiline::before { + content: "\F8D3"; +} +.mdi-chart-pie::before { + content: "\F12B"; +} +.mdi-chart-scatter-plot::before { + content: "\FEAF"; +} +.mdi-chart-scatter-plot-hexbin::before { + content: "\F66D"; +} +.mdi-chart-timeline::before { + content: "\F66E"; +} +.mdi-chart-timeline-variant::before { + content: "\FEB0"; +} +.mdi-chart-tree::before { + content: "\FEB1"; +} +.mdi-chat::before { + content: "\FB55"; +} +.mdi-chat-alert::before { + content: "\FB56"; +} +.mdi-chat-outline::before { + content: "\FEFB"; +} +.mdi-chat-processing::before { + content: "\FB57"; +} +.mdi-check::before { + content: "\F12C"; +} +.mdi-check-all::before { + content: "\F12D"; +} +.mdi-check-bold::before { + content: "\FE6E"; +} +.mdi-check-box-multiple-outline::before { + content: "\FC2D"; +} +.mdi-check-box-outline::before { + content: "\FC2E"; +} +.mdi-check-circle::before { + content: "\F5E0"; +} +.mdi-check-circle-outline::before { + content: "\F5E1"; +} +.mdi-check-decagram::before { + content: "\F790"; +} +.mdi-check-network::before { + content: "\FC2F"; +} +.mdi-check-network-outline::before { + content: "\FC30"; +} +.mdi-check-outline::before { + content: "\F854"; +} +.mdi-check-underline::before { + content: "\FE70"; +} +.mdi-check-underline-circle::before { + content: "\FE71"; +} +.mdi-check-underline-circle-outline::before { + content: "\FE72"; +} +.mdi-checkbook::before { + content: "\FA9C"; +} +.mdi-checkbox-blank::before { + content: "\F12E"; +} +.mdi-checkbox-blank-circle::before { + content: "\F12F"; +} +.mdi-checkbox-blank-circle-outline::before { + content: "\F130"; +} +.mdi-checkbox-blank-outline::before { + content: "\F131"; +} +.mdi-checkbox-intermediate::before { + content: "\F855"; +} +.mdi-checkbox-marked::before { + content: "\F132"; +} +.mdi-checkbox-marked-circle::before { + content: "\F133"; +} +.mdi-checkbox-marked-circle-outline::before { + content: "\F134"; +} +.mdi-checkbox-marked-outline::before { + content: "\F135"; +} +.mdi-checkbox-multiple-blank::before { + content: "\F136"; +} +.mdi-checkbox-multiple-blank-circle::before { + content: "\F63B"; +} +.mdi-checkbox-multiple-blank-circle-outline::before { + content: "\F63C"; +} +.mdi-checkbox-multiple-blank-outline::before { + content: "\F137"; +} +.mdi-checkbox-multiple-marked::before { + content: "\F138"; +} +.mdi-checkbox-multiple-marked-circle::before { + content: "\F63D"; +} +.mdi-checkbox-multiple-marked-circle-outline::before { + content: "\F63E"; +} +.mdi-checkbox-multiple-marked-outline::before { + content: "\F139"; +} +.mdi-checkerboard::before { + content: "\F13A"; +} +.mdi-chef-hat::before { + content: "\FB58"; +} +.mdi-chemical-weapon::before { + content: "\F13B"; +} +.mdi-chess-bishop::before { + content: "\F85B"; +} +.mdi-chess-king::before { + content: "\F856"; +} +.mdi-chess-knight::before { + content: "\F857"; +} +.mdi-chess-pawn::before { + content: "\F858"; +} +.mdi-chess-queen::before { + content: "\F859"; +} +.mdi-chess-rook::before { + content: "\F85A"; +} +.mdi-chevron-double-down::before { + content: "\F13C"; +} +.mdi-chevron-double-left::before { + content: "\F13D"; +} +.mdi-chevron-double-right::before { + content: "\F13E"; +} +.mdi-chevron-double-up::before { + content: "\F13F"; +} +.mdi-chevron-down::before { + content: "\F140"; +} +.mdi-chevron-down-box::before { + content: "\F9D5"; +} +.mdi-chevron-down-box-outline::before { + content: "\F9D6"; +} +.mdi-chevron-down-circle::before { + content: "\FB0B"; +} +.mdi-chevron-down-circle-outline::before { + content: "\FB0C"; +} +.mdi-chevron-left::before { + content: "\F141"; +} +.mdi-chevron-left-box::before { + content: "\F9D7"; +} +.mdi-chevron-left-box-outline::before { + content: "\F9D8"; +} +.mdi-chevron-left-circle::before { + content: "\FB0D"; +} +.mdi-chevron-left-circle-outline::before { + content: "\FB0E"; +} +.mdi-chevron-right::before { + content: "\F142"; +} +.mdi-chevron-right-box::before { + content: "\F9D9"; +} +.mdi-chevron-right-box-outline::before { + content: "\F9DA"; +} +.mdi-chevron-right-circle::before { + content: "\FB0F"; +} +.mdi-chevron-right-circle-outline::before { + content: "\FB10"; +} +.mdi-chevron-triple-down::before { + content: "\FD95"; +} +.mdi-chevron-triple-left::before { + content: "\FD96"; +} +.mdi-chevron-triple-right::before { + content: "\FD97"; +} +.mdi-chevron-triple-up::before { + content: "\FD98"; +} +.mdi-chevron-up::before { + content: "\F143"; +} +.mdi-chevron-up-box::before { + content: "\F9DB"; +} +.mdi-chevron-up-box-outline::before { + content: "\F9DC"; +} +.mdi-chevron-up-circle::before { + content: "\FB11"; +} +.mdi-chevron-up-circle-outline::before { + content: "\FB12"; +} +.mdi-chili-hot::before { + content: "\F7B1"; +} +.mdi-chili-medium::before { + content: "\F7B2"; +} +.mdi-chili-mild::before { + content: "\F7B3"; +} +.mdi-chip::before { + content: "\F61A"; +} +.mdi-christianity::before { + content: "\F952"; +} +.mdi-christianity-outline::before { + content: "\FCD2"; +} +.mdi-church::before { + content: "\F144"; +} +.mdi-circle::before { + content: "\F764"; +} +.mdi-circle-double::before { + content: "\FEB2"; +} +.mdi-circle-edit-outline::before { + content: "\F8D4"; +} +.mdi-circle-expand::before { + content: "\FEB3"; +} +.mdi-circle-medium::before { + content: "\F9DD"; +} +.mdi-circle-outline::before { + content: "\F765"; +} +.mdi-circle-slice-1::before { + content: "\FA9D"; +} +.mdi-circle-slice-2::before { + content: "\FA9E"; +} +.mdi-circle-slice-3::before { + content: "\FA9F"; +} +.mdi-circle-slice-4::before { + content: "\FAA0"; +} +.mdi-circle-slice-5::before { + content: "\FAA1"; +} +.mdi-circle-slice-6::before { + content: "\FAA2"; +} +.mdi-circle-slice-7::before { + content: "\FAA3"; +} +.mdi-circle-slice-8::before { + content: "\FAA4"; +} +.mdi-circle-small::before { + content: "\F9DE"; +} +.mdi-circular-saw::before { + content: "\FE73"; +} +.mdi-cisco-webex::before { + content: "\F145"; +} +.mdi-city::before { + content: "\F146"; +} +.mdi-city-variant::before { + content: "\FA35"; +} +.mdi-city-variant-outline::before { + content: "\FA36"; +} +.mdi-clipboard::before { + content: "\F147"; +} +.mdi-clipboard-account::before { + content: "\F148"; +} +.mdi-clipboard-account-outline::before { + content: "\FC31"; +} +.mdi-clipboard-alert::before { + content: "\F149"; +} +.mdi-clipboard-alert-outline::before { + content: "\FCD3"; +} +.mdi-clipboard-arrow-down::before { + content: "\F14A"; +} +.mdi-clipboard-arrow-down-outline::before { + content: "\FC32"; +} +.mdi-clipboard-arrow-left::before { + content: "\F14B"; +} +.mdi-clipboard-arrow-left-outline::before { + content: "\FCD4"; +} +.mdi-clipboard-arrow-right::before { + content: "\FCD5"; +} +.mdi-clipboard-arrow-right-outline::before { + content: "\FCD6"; +} +.mdi-clipboard-arrow-up::before { + content: "\FC33"; +} +.mdi-clipboard-arrow-up-outline::before { + content: "\FC34"; +} +.mdi-clipboard-check::before { + content: "\F14C"; +} +.mdi-clipboard-check-outline::before { + content: "\F8A7"; +} +.mdi-clipboard-flow::before { + content: "\F6C7"; +} +.mdi-clipboard-outline::before { + content: "\F14D"; +} +.mdi-clipboard-play::before { + content: "\FC35"; +} +.mdi-clipboard-play-outline::before { + content: "\FC36"; +} +.mdi-clipboard-plus::before { + content: "\F750"; +} +.mdi-clipboard-pulse::before { + content: "\F85C"; +} +.mdi-clipboard-pulse-outline::before { + content: "\F85D"; +} +.mdi-clipboard-text::before { + content: "\F14E"; +} +.mdi-clipboard-text-outline::before { + content: "\FA37"; +} +.mdi-clipboard-text-play::before { + content: "\FC37"; +} +.mdi-clipboard-text-play-outline::before { + content: "\FC38"; +} +.mdi-clippy::before { + content: "\F14F"; +} +.mdi-clock::before { + content: "\F953"; +} +.mdi-clock-alert::before { + content: "\F954"; +} +.mdi-clock-alert-outline::before { + content: "\F5CE"; +} +.mdi-clock-digital::before { + content: "\FEB4"; +} +.mdi-clock-end::before { + content: "\F151"; +} +.mdi-clock-fast::before { + content: "\F152"; +} +.mdi-clock-in::before { + content: "\F153"; +} +.mdi-clock-out::before { + content: "\F154"; +} +.mdi-clock-outline::before { + content: "\F150"; +} +.mdi-clock-start::before { + content: "\F155"; +} +.mdi-close::before { + content: "\F156"; +} +.mdi-close-box::before { + content: "\F157"; +} +.mdi-close-box-multiple::before { + content: "\FC39"; +} +.mdi-close-box-multiple-outline::before { + content: "\FC3A"; +} +.mdi-close-box-outline::before { + content: "\F158"; +} +.mdi-close-circle::before { + content: "\F159"; +} +.mdi-close-circle-outline::before { + content: "\F15A"; +} +.mdi-close-network::before { + content: "\F15B"; +} +.mdi-close-network-outline::before { + content: "\FC3B"; +} +.mdi-close-octagon::before { + content: "\F15C"; +} +.mdi-close-octagon-outline::before { + content: "\F15D"; +} +.mdi-close-outline::before { + content: "\F6C8"; +} +.mdi-closed-caption::before { + content: "\F15E"; +} +.mdi-closed-caption-outline::before { + content: "\FD99"; +} +.mdi-cloud::before { + content: "\F15F"; +} +.mdi-cloud-alert::before { + content: "\F9DF"; +} +.mdi-cloud-braces::before { + content: "\F7B4"; +} +.mdi-cloud-check::before { + content: "\F160"; +} +.mdi-cloud-circle::before { + content: "\F161"; +} +.mdi-cloud-download::before { + content: "\F162"; +} +.mdi-cloud-download-outline::before { + content: "\FB59"; +} +.mdi-cloud-off-outline::before { + content: "\F164"; +} +.mdi-cloud-outline::before { + content: "\F163"; +} +.mdi-cloud-print::before { + content: "\F165"; +} +.mdi-cloud-print-outline::before { + content: "\F166"; +} +.mdi-cloud-question::before { + content: "\FA38"; +} +.mdi-cloud-search::before { + content: "\F955"; +} +.mdi-cloud-search-outline::before { + content: "\F956"; +} +.mdi-cloud-sync::before { + content: "\F63F"; +} +.mdi-cloud-tags::before { + content: "\F7B5"; +} +.mdi-cloud-upload::before { + content: "\F167"; +} +.mdi-cloud-upload-outline::before { + content: "\FB5A"; +} +.mdi-clover::before { + content: "\F815"; +} +.mdi-code-array::before { + content: "\F168"; +} +.mdi-code-braces::before { + content: "\F169"; +} +.mdi-code-brackets::before { + content: "\F16A"; +} +.mdi-code-equal::before { + content: "\F16B"; +} +.mdi-code-greater-than::before { + content: "\F16C"; +} +.mdi-code-greater-than-or-equal::before { + content: "\F16D"; +} +.mdi-code-less-than::before { + content: "\F16E"; +} +.mdi-code-less-than-or-equal::before { + content: "\F16F"; +} +.mdi-code-not-equal::before { + content: "\F170"; +} +.mdi-code-not-equal-variant::before { + content: "\F171"; +} +.mdi-code-parentheses::before { + content: "\F172"; +} +.mdi-code-string::before { + content: "\F173"; +} +.mdi-code-tags::before { + content: "\F174"; +} +.mdi-code-tags-check::before { + content: "\F693"; +} +.mdi-codepen::before { + content: "\F175"; +} +.mdi-coffee::before { + content: "\F176"; +} +.mdi-coffee-off::before { + content: "\FFCA"; +} +.mdi-coffee-off-outline::before { + content: "\FFCB"; +} +.mdi-coffee-outline::before { + content: "\F6C9"; +} +.mdi-coffee-to-go::before { + content: "\F177"; +} +.mdi-coffin::before { + content: "\FB5B"; +} +.mdi-cogs::before { + content: "\F8D5"; +} +.mdi-coin::before { + content: "\F178"; +} +.mdi-coins::before { + content: "\F694"; +} +.mdi-collage::before { + content: "\F640"; +} +.mdi-collapse-all::before { + content: "\FAA5"; +} +.mdi-collapse-all-outline::before { + content: "\FAA6"; +} +.mdi-color-helper::before { + content: "\F179"; +} +.mdi-comma::before { + content: "\FE74"; +} +.mdi-comma-box::before { + content: "\FE75"; +} +.mdi-comma-box-outline::before { + content: "\FE76"; +} +.mdi-comma-circle::before { + content: "\FE77"; +} +.mdi-comma-circle-outline::before { + content: "\FE78"; +} +.mdi-comment::before { + content: "\F17A"; +} +.mdi-comment-account::before { + content: "\F17B"; +} +.mdi-comment-account-outline::before { + content: "\F17C"; +} +.mdi-comment-alert::before { + content: "\F17D"; +} +.mdi-comment-alert-outline::before { + content: "\F17E"; +} +.mdi-comment-arrow-left::before { + content: "\F9E0"; +} +.mdi-comment-arrow-left-outline::before { + content: "\F9E1"; +} +.mdi-comment-arrow-right::before { + content: "\F9E2"; +} +.mdi-comment-arrow-right-outline::before { + content: "\F9E3"; +} +.mdi-comment-check::before { + content: "\F17F"; +} +.mdi-comment-check-outline::before { + content: "\F180"; +} +.mdi-comment-eye::before { + content: "\FA39"; +} +.mdi-comment-eye-outline::before { + content: "\FA3A"; +} +.mdi-comment-multiple::before { + content: "\F85E"; +} +.mdi-comment-multiple-outline::before { + content: "\F181"; +} +.mdi-comment-outline::before { + content: "\F182"; +} +.mdi-comment-plus::before { + content: "\F9E4"; +} +.mdi-comment-plus-outline::before { + content: "\F183"; +} +.mdi-comment-processing::before { + content: "\F184"; +} +.mdi-comment-processing-outline::before { + content: "\F185"; +} +.mdi-comment-question::before { + content: "\F816"; +} +.mdi-comment-question-outline::before { + content: "\F186"; +} +.mdi-comment-remove::before { + content: "\F5DE"; +} +.mdi-comment-remove-outline::before { + content: "\F187"; +} +.mdi-comment-search::before { + content: "\FA3B"; +} +.mdi-comment-search-outline::before { + content: "\FA3C"; +} +.mdi-comment-text::before { + content: "\F188"; +} +.mdi-comment-text-multiple::before { + content: "\F85F"; +} +.mdi-comment-text-multiple-outline::before { + content: "\F860"; +} +.mdi-comment-text-outline::before { + content: "\F189"; +} +.mdi-compare::before { + content: "\F18A"; +} +.mdi-compass::before { + content: "\F18B"; +} +.mdi-compass-off::before { + content: "\FB5C"; +} +.mdi-compass-off-outline::before { + content: "\FB5D"; +} +.mdi-compass-outline::before { + content: "\F18C"; +} +.mdi-console::before { + content: "\F18D"; +} +.mdi-console-line::before { + content: "\F7B6"; +} +.mdi-console-network::before { + content: "\F8A8"; +} +.mdi-console-network-outline::before { + content: "\FC3C"; +} +.mdi-contact-mail::before { + content: "\F18E"; +} +.mdi-contact-mail-outline::before { + content: "\FEB5"; +} +.mdi-contact-phone::before { + content: "\FEB6"; +} +.mdi-contact-phone-outline::before { + content: "\FEB7"; +} +.mdi-contactless-payment::before { + content: "\FD46"; +} +.mdi-contacts::before { + content: "\F6CA"; +} +.mdi-contain::before { + content: "\FA3D"; +} +.mdi-contain-end::before { + content: "\FA3E"; +} +.mdi-contain-start::before { + content: "\FA3F"; +} +.mdi-content-copy::before { + content: "\F18F"; +} +.mdi-content-cut::before { + content: "\F190"; +} +.mdi-content-duplicate::before { + content: "\F191"; +} +.mdi-content-paste::before { + content: "\F192"; +} +.mdi-content-save::before { + content: "\F193"; +} +.mdi-content-save-alert::before { + content: "\FF5F"; +} +.mdi-content-save-alert-outline::before { + content: "\FF60"; +} +.mdi-content-save-all::before { + content: "\F194"; +} +.mdi-content-save-all-outline::before { + content: "\FF61"; +} +.mdi-content-save-edit::before { + content: "\FCD7"; +} +.mdi-content-save-edit-outline::before { + content: "\FCD8"; +} +.mdi-content-save-move::before { + content: "\FE79"; +} +.mdi-content-save-move-outline::before { + content: "\FE7A"; +} +.mdi-content-save-outline::before { + content: "\F817"; +} +.mdi-content-save-settings::before { + content: "\F61B"; +} +.mdi-content-save-settings-outline::before { + content: "\FB13"; +} +.mdi-contrast::before { + content: "\F195"; +} +.mdi-contrast-box::before { + content: "\F196"; +} +.mdi-contrast-circle::before { + content: "\F197"; +} +.mdi-controller-classic::before { + content: "\FB5E"; +} +.mdi-controller-classic-outline::before { + content: "\FB5F"; +} +.mdi-cookie::before { + content: "\F198"; +} +.mdi-copyright::before { + content: "\F5E6"; +} +.mdi-cordova::before { + content: "\F957"; +} +.mdi-corn::before { + content: "\F7B7"; +} +.mdi-counter::before { + content: "\F199"; +} +.mdi-cow::before { + content: "\F19A"; +} +.mdi-cowboy::before { + content: "\FEB8"; +} +.mdi-cpu-32-bit::before { + content: "\FEFC"; +} +.mdi-cpu-64-bit::before { + content: "\FEFD"; +} +.mdi-crane::before { + content: "\F861"; +} +.mdi-creation::before { + content: "\F1C9"; +} +.mdi-creative-commons::before { + content: "\FD47"; +} +.mdi-credit-card::before { + content: "\F19B"; +} +.mdi-credit-card-clock::before { + content: "\FEFE"; +} +.mdi-credit-card-clock-outline::before { + content: "\FFBC"; +} +.mdi-credit-card-marker::before { + content: "\FD9A"; +} +.mdi-credit-card-multiple::before { + content: "\F19C"; +} +.mdi-credit-card-off::before { + content: "\F5E4"; +} +.mdi-credit-card-plus::before { + content: "\F675"; +} +.mdi-credit-card-refund::before { + content: "\FAA7"; +} +.mdi-credit-card-scan::before { + content: "\F19D"; +} +.mdi-credit-card-settings::before { + content: "\F8D6"; +} +.mdi-credit-card-wireless::before { + content: "\FD48"; +} +.mdi-cricket::before { + content: "\FD49"; +} +.mdi-crop::before { + content: "\F19E"; +} +.mdi-crop-free::before { + content: "\F19F"; +} +.mdi-crop-landscape::before { + content: "\F1A0"; +} +.mdi-crop-portrait::before { + content: "\F1A1"; +} +.mdi-crop-rotate::before { + content: "\F695"; +} +.mdi-crop-square::before { + content: "\F1A2"; +} +.mdi-crosshairs::before { + content: "\F1A3"; +} +.mdi-crosshairs-gps::before { + content: "\F1A4"; +} +.mdi-crosshairs-off::before { + content: "\FF62"; +} +.mdi-crown::before { + content: "\F1A5"; +} +.mdi-cryengine::before { + content: "\F958"; +} +.mdi-crystal-ball::before { + content: "\FB14"; +} +.mdi-cube::before { + content: "\F1A6"; +} +.mdi-cube-outline::before { + content: "\F1A7"; +} +.mdi-cube-scan::before { + content: "\FB60"; +} +.mdi-cube-send::before { + content: "\F1A8"; +} +.mdi-cube-unfolded::before { + content: "\F1A9"; +} +.mdi-cup::before { + content: "\F1AA"; +} +.mdi-cup-off::before { + content: "\F5E5"; +} +.mdi-cup-water::before { + content: "\F1AB"; +} +.mdi-cupboard::before { + content: "\FF63"; +} +.mdi-cupboard-outline::before { + content: "\FF64"; +} +.mdi-cupcake::before { + content: "\F959"; +} +.mdi-curling::before { + content: "\F862"; +} +.mdi-currency-bdt::before { + content: "\F863"; +} +.mdi-currency-brl::before { + content: "\FB61"; +} +.mdi-currency-btc::before { + content: "\F1AC"; +} +.mdi-currency-chf::before { + content: "\F7B8"; +} +.mdi-currency-cny::before { + content: "\F7B9"; +} +.mdi-currency-eth::before { + content: "\F7BA"; +} +.mdi-currency-eur::before { + content: "\F1AD"; +} +.mdi-currency-gbp::before { + content: "\F1AE"; +} +.mdi-currency-ils::before { + content: "\FC3D"; +} +.mdi-currency-inr::before { + content: "\F1AF"; +} +.mdi-currency-jpy::before { + content: "\F7BB"; +} +.mdi-currency-krw::before { + content: "\F7BC"; +} +.mdi-currency-kzt::before { + content: "\F864"; +} +.mdi-currency-ngn::before { + content: "\F1B0"; +} +.mdi-currency-php::before { + content: "\F9E5"; +} +.mdi-currency-rial::before { + content: "\FEB9"; +} +.mdi-currency-rub::before { + content: "\F1B1"; +} +.mdi-currency-sign::before { + content: "\F7BD"; +} +.mdi-currency-try::before { + content: "\F1B2"; +} +.mdi-currency-twd::before { + content: "\F7BE"; +} +.mdi-currency-usd::before { + content: "\F1B3"; +} +.mdi-currency-usd-off::before { + content: "\F679"; +} +.mdi-current-ac::before { + content: "\F95A"; +} +.mdi-current-dc::before { + content: "\F95B"; +} +.mdi-cursor-default::before { + content: "\F1B4"; +} +.mdi-cursor-default-click::before { + content: "\FCD9"; +} +.mdi-cursor-default-click-outline::before { + content: "\FCDA"; +} +.mdi-cursor-default-outline::before { + content: "\F1B5"; +} +.mdi-cursor-move::before { + content: "\F1B6"; +} +.mdi-cursor-pointer::before { + content: "\F1B7"; +} +.mdi-cursor-text::before { + content: "\F5E7"; +} +.mdi-database::before { + content: "\F1B8"; +} +.mdi-database-check::before { + content: "\FAA8"; +} +.mdi-database-edit::before { + content: "\FB62"; +} +.mdi-database-export::before { + content: "\F95D"; +} +.mdi-database-import::before { + content: "\F95C"; +} +.mdi-database-lock::before { + content: "\FAA9"; +} +.mdi-database-minus::before { + content: "\F1B9"; +} +.mdi-database-plus::before { + content: "\F1BA"; +} +.mdi-database-refresh::before { + content: "\FCDB"; +} +.mdi-database-remove::before { + content: "\FCDC"; +} +.mdi-database-search::before { + content: "\F865"; +} +.mdi-database-settings::before { + content: "\FCDD"; +} +.mdi-death-star::before { + content: "\F8D7"; +} +.mdi-death-star-variant::before { + content: "\F8D8"; +} +.mdi-deathly-hallows::before { + content: "\FB63"; +} +.mdi-debian::before { + content: "\F8D9"; +} +.mdi-debug-step-into::before { + content: "\F1BB"; +} +.mdi-debug-step-out::before { + content: "\F1BC"; +} +.mdi-debug-step-over::before { + content: "\F1BD"; +} +.mdi-decagram::before { + content: "\F76B"; +} +.mdi-decagram-outline::before { + content: "\F76C"; +} +.mdi-decimal-decrease::before { + content: "\F1BE"; +} +.mdi-decimal-increase::before { + content: "\F1BF"; +} +.mdi-delete::before { + content: "\F1C0"; +} +.mdi-delete-circle::before { + content: "\F682"; +} +.mdi-delete-circle-outline::before { + content: "\FB64"; +} +.mdi-delete-empty::before { + content: "\F6CB"; +} +.mdi-delete-empty-outline::before { + content: "\FEBA"; +} +.mdi-delete-forever::before { + content: "\F5E8"; +} +.mdi-delete-forever-outline::before { + content: "\FB65"; +} +.mdi-delete-outline::before { + content: "\F9E6"; +} +.mdi-delete-restore::before { + content: "\F818"; +} +.mdi-delete-sweep::before { + content: "\F5E9"; +} +.mdi-delete-sweep-outline::before { + content: "\FC3E"; +} +.mdi-delete-variant::before { + content: "\F1C1"; +} +.mdi-delta::before { + content: "\F1C2"; +} +.mdi-desk-lamp::before { + content: "\F95E"; +} +.mdi-deskphone::before { + content: "\F1C3"; +} +.mdi-desktop-classic::before { + content: "\F7BF"; +} +.mdi-desktop-mac::before { + content: "\F1C4"; +} +.mdi-desktop-mac-dashboard::before { + content: "\F9E7"; +} +.mdi-desktop-tower::before { + content: "\F1C5"; +} +.mdi-desktop-tower-monitor::before { + content: "\FAAA"; +} +.mdi-details::before { + content: "\F1C6"; +} +.mdi-dev-to::before { + content: "\FD4A"; +} +.mdi-developer-board::before { + content: "\F696"; +} +.mdi-deviantart::before { + content: "\F1C7"; +} +.mdi-dialpad::before { + content: "\F61C"; +} +.mdi-diameter::before { + content: "\FC3F"; +} +.mdi-diameter-outline::before { + content: "\FC40"; +} +.mdi-diameter-variant::before { + content: "\FC41"; +} +.mdi-diamond::before { + content: "\FB66"; +} +.mdi-diamond-outline::before { + content: "\FB67"; +} +.mdi-diamond-stone::before { + content: "\F1C8"; +} +.mdi-dice-1::before { + content: "\F1CA"; +} +.mdi-dice-2::before { + content: "\F1CB"; +} +.mdi-dice-3::before { + content: "\F1CC"; +} +.mdi-dice-4::before { + content: "\F1CD"; +} +.mdi-dice-5::before { + content: "\F1CE"; +} +.mdi-dice-6::before { + content: "\F1CF"; +} +.mdi-dice-d10::before { + content: "\F76E"; +} +.mdi-dice-d12::before { + content: "\F866"; +} +.mdi-dice-d20::before { + content: "\F5EA"; +} +.mdi-dice-d4::before { + content: "\F5EB"; +} +.mdi-dice-d6::before { + content: "\F5EC"; +} +.mdi-dice-d8::before { + content: "\F5ED"; +} +.mdi-dice-multiple::before { + content: "\F76D"; +} +.mdi-dictionary::before { + content: "\F61D"; +} +.mdi-dip-switch::before { + content: "\F7C0"; +} +.mdi-directions::before { + content: "\F1D0"; +} +.mdi-directions-fork::before { + content: "\F641"; +} +.mdi-disc::before { + content: "\F5EE"; +} +.mdi-disc-alert::before { + content: "\F1D1"; +} +.mdi-disc-player::before { + content: "\F95F"; +} +.mdi-discord::before { + content: "\F66F"; +} +.mdi-dishwasher::before { + content: "\FAAB"; +} +.mdi-disqus::before { + content: "\F1D2"; +} +.mdi-disqus-outline::before { + content: "\F1D3"; +} +.mdi-diving-flippers::before { + content: "\FD9B"; +} +.mdi-diving-helmet::before { + content: "\FD9C"; +} +.mdi-diving-scuba::before { + content: "\FD9D"; +} +.mdi-diving-scuba-flag::before { + content: "\FD9E"; +} +.mdi-diving-scuba-tank::before { + content: "\FD9F"; +} +.mdi-diving-scuba-tank-multiple::before { + content: "\FDA0"; +} +.mdi-diving-snorkel::before { + content: "\FDA1"; +} +.mdi-division::before { + content: "\F1D4"; +} +.mdi-division-box::before { + content: "\F1D5"; +} +.mdi-dlna::before { + content: "\FA40"; +} +.mdi-dna::before { + content: "\F683"; +} +.mdi-dns::before { + content: "\F1D6"; +} +.mdi-dns-outline::before { + content: "\FB68"; +} +.mdi-do-not-disturb::before { + content: "\F697"; +} +.mdi-do-not-disturb-off::before { + content: "\F698"; +} +.mdi-docker::before { + content: "\F867"; +} +.mdi-doctor::before { + content: "\FA41"; +} +.mdi-dog::before { + content: "\FA42"; +} +.mdi-dog-service::before { + content: "\FAAC"; +} +.mdi-dog-side::before { + content: "\FA43"; +} +.mdi-dolby::before { + content: "\F6B2"; +} +.mdi-dolly::before { + content: "\FEBB"; +} +.mdi-domain::before { + content: "\F1D7"; +} +.mdi-domain-off::before { + content: "\FD4B"; +} +.mdi-donkey::before { + content: "\F7C1"; +} +.mdi-door::before { + content: "\F819"; +} +.mdi-door-closed::before { + content: "\F81A"; +} +.mdi-door-open::before { + content: "\F81B"; +} +.mdi-doorbell-video::before { + content: "\F868"; +} +.mdi-dot-net::before { + content: "\FAAD"; +} +.mdi-dots-horizontal::before { + content: "\F1D8"; +} +.mdi-dots-horizontal-circle::before { + content: "\F7C2"; +} +.mdi-dots-horizontal-circle-outline::before { + content: "\FB69"; +} +.mdi-dots-vertical::before { + content: "\F1D9"; +} +.mdi-dots-vertical-circle::before { + content: "\F7C3"; +} +.mdi-dots-vertical-circle-outline::before { + content: "\FB6A"; +} +.mdi-douban::before { + content: "\F699"; +} +.mdi-download::before { + content: "\F1DA"; +} +.mdi-download-multiple::before { + content: "\F9E8"; +} +.mdi-download-network::before { + content: "\F6F3"; +} +.mdi-download-network-outline::before { + content: "\FC42"; +} +.mdi-download-outline::before { + content: "\FB6B"; +} +.mdi-drag::before { + content: "\F1DB"; +} +.mdi-drag-horizontal::before { + content: "\F1DC"; +} +.mdi-drag-variant::before { + content: "\FB6C"; +} +.mdi-drag-vertical::before { + content: "\F1DD"; +} +.mdi-drama-masks::before { + content: "\FCDE"; +} +.mdi-draw::before { + content: "\FF66"; +} +.mdi-drawing::before { + content: "\F1DE"; +} +.mdi-drawing-box::before { + content: "\F1DF"; +} +.mdi-dresser::before { + content: "\FF67"; +} +.mdi-dresser-outline::before { + content: "\FF68"; +} +.mdi-dribbble::before { + content: "\F1E0"; +} +.mdi-dribbble-box::before { + content: "\F1E1"; +} +.mdi-drone::before { + content: "\F1E2"; +} +.mdi-dropbox::before { + content: "\F1E3"; +} +.mdi-drupal::before { + content: "\F1E4"; +} +.mdi-duck::before { + content: "\F1E5"; +} +.mdi-dumbbell::before { + content: "\F1E6"; +} +.mdi-dump-truck::before { + content: "\FC43"; +} +.mdi-ear-hearing::before { + content: "\F7C4"; +} +.mdi-ear-hearing-off::before { + content: "\FA44"; +} +.mdi-earth::before { + content: "\F1E7"; +} +.mdi-earth-box::before { + content: "\F6CC"; +} +.mdi-earth-box-off::before { + content: "\F6CD"; +} +.mdi-earth-off::before { + content: "\F1E8"; +} +.mdi-edge::before { + content: "\F1E9"; +} +.mdi-egg::before { + content: "\FAAE"; +} +.mdi-egg-easter::before { + content: "\FAAF"; +} +.mdi-eight-track::before { + content: "\F9E9"; +} +.mdi-eject::before { + content: "\F1EA"; +} +.mdi-eject-outline::before { + content: "\FB6D"; +} +.mdi-electric-switch::before { + content: "\FEBC"; +} +.mdi-elephant::before { + content: "\F7C5"; +} +.mdi-elevation-decline::before { + content: "\F1EB"; +} +.mdi-elevation-rise::before { + content: "\F1EC"; +} +.mdi-elevator::before { + content: "\F1ED"; +} +.mdi-ellipse::before { + content: "\FEBD"; +} +.mdi-ellipse-outline::before { + content: "\FEBE"; +} +.mdi-email::before { + content: "\F1EE"; +} +.mdi-email-alert::before { + content: "\F6CE"; +} +.mdi-email-box::before { + content: "\FCDF"; +} +.mdi-email-check::before { + content: "\FAB0"; +} +.mdi-email-check-outline::before { + content: "\FAB1"; +} +.mdi-email-edit::before { + content: "\FF00"; +} +.mdi-email-edit-outline::before { + content: "\FF01"; +} +.mdi-email-lock::before { + content: "\F1F1"; +} +.mdi-email-mark-as-unread::before { + content: "\FB6E"; +} +.mdi-email-minus::before { + content: "\FF02"; +} +.mdi-email-minus-outline::before { + content: "\FF03"; +} +.mdi-email-multiple::before { + content: "\FF04"; +} +.mdi-email-multiple-outline::before { + content: "\FF05"; +} +.mdi-email-open::before { + content: "\F1EF"; +} +.mdi-email-open-multiple::before { + content: "\FF06"; +} +.mdi-email-open-multiple-outline::before { + content: "\FF07"; +} +.mdi-email-open-outline::before { + content: "\F5EF"; +} +.mdi-email-outline::before { + content: "\F1F0"; +} +.mdi-email-plus::before { + content: "\F9EA"; +} +.mdi-email-plus-outline::before { + content: "\F9EB"; +} +.mdi-email-search::before { + content: "\F960"; +} +.mdi-email-search-outline::before { + content: "\F961"; +} +.mdi-email-variant::before { + content: "\F5F0"; +} +.mdi-ember::before { + content: "\FB15"; +} +.mdi-emby::before { + content: "\F6B3"; +} +.mdi-emoticon::before { + content: "\FC44"; +} +.mdi-emoticon-angry::before { + content: "\FC45"; +} +.mdi-emoticon-angry-outline::before { + content: "\FC46"; +} +.mdi-emoticon-cool::before { + content: "\FC47"; +} +.mdi-emoticon-cool-outline::before { + content: "\F1F3"; +} +.mdi-emoticon-cry::before { + content: "\FC48"; +} +.mdi-emoticon-cry-outline::before { + content: "\FC49"; +} +.mdi-emoticon-dead::before { + content: "\FC4A"; +} +.mdi-emoticon-dead-outline::before { + content: "\F69A"; +} +.mdi-emoticon-devil::before { + content: "\FC4B"; +} +.mdi-emoticon-devil-outline::before { + content: "\F1F4"; +} +.mdi-emoticon-excited::before { + content: "\FC4C"; +} +.mdi-emoticon-excited-outline::before { + content: "\F69B"; +} +.mdi-emoticon-frown::before { + content: "\FF69"; +} +.mdi-emoticon-frown-outline::before { + content: "\FF6A"; +} +.mdi-emoticon-happy::before { + content: "\FC4D"; +} +.mdi-emoticon-happy-outline::before { + content: "\F1F5"; +} +.mdi-emoticon-kiss::before { + content: "\FC4E"; +} +.mdi-emoticon-kiss-outline::before { + content: "\FC4F"; +} +.mdi-emoticon-neutral::before { + content: "\FC50"; +} +.mdi-emoticon-neutral-outline::before { + content: "\F1F6"; +} +.mdi-emoticon-outline::before { + content: "\F1F2"; +} +.mdi-emoticon-poop::before { + content: "\F1F7"; +} +.mdi-emoticon-poop-outline::before { + content: "\FC51"; +} +.mdi-emoticon-sad::before { + content: "\FC52"; +} +.mdi-emoticon-sad-outline::before { + content: "\F1F8"; +} +.mdi-emoticon-tongue::before { + content: "\F1F9"; +} +.mdi-emoticon-tongue-outline::before { + content: "\FC53"; +} +.mdi-emoticon-wink::before { + content: "\FC54"; +} +.mdi-emoticon-wink-outline::before { + content: "\FC55"; +} +.mdi-engine::before { + content: "\F1FA"; +} +.mdi-engine-off::before { + content: "\FA45"; +} +.mdi-engine-off-outline::before { + content: "\FA46"; +} +.mdi-engine-outline::before { + content: "\F1FB"; +} +.mdi-equal::before { + content: "\F1FC"; +} +.mdi-equal-box::before { + content: "\F1FD"; +} +.mdi-equalizer::before { + content: "\FEBF"; +} +.mdi-equalizer-outline::before { + content: "\FEC0"; +} +.mdi-eraser::before { + content: "\F1FE"; +} +.mdi-eraser-variant::before { + content: "\F642"; +} +.mdi-escalator::before { + content: "\F1FF"; +} +.mdi-eslint::before { + content: "\FC56"; +} +.mdi-et::before { + content: "\FAB2"; +} +.mdi-ethereum::before { + content: "\F869"; +} +.mdi-ethernet::before { + content: "\F200"; +} +.mdi-ethernet-cable::before { + content: "\F201"; +} +.mdi-ethernet-cable-off::before { + content: "\F202"; +} +.mdi-etsy::before { + content: "\F203"; +} +.mdi-ev-station::before { + content: "\F5F1"; +} +.mdi-eventbrite::before { + content: "\F7C6"; +} +.mdi-evernote::before { + content: "\F204"; +} +.mdi-exclamation::before { + content: "\F205"; +} +.mdi-exit-run::before { + content: "\FA47"; +} +.mdi-exit-to-app::before { + content: "\F206"; +} +.mdi-expand-all::before { + content: "\FAB3"; +} +.mdi-expand-all-outline::before { + content: "\FAB4"; +} +.mdi-exponent::before { + content: "\F962"; +} +.mdi-exponent-box::before { + content: "\F963"; +} +.mdi-export::before { + content: "\F207"; +} +.mdi-export-variant::before { + content: "\FB6F"; +} +.mdi-eye::before { + content: "\F208"; +} +.mdi-eye-check::before { + content: "\FCE0"; +} +.mdi-eye-check-outline::before { + content: "\FCE1"; +} +.mdi-eye-circle::before { + content: "\FB70"; +} +.mdi-eye-circle-outline::before { + content: "\FB71"; +} +.mdi-eye-off::before { + content: "\F209"; +} +.mdi-eye-off-outline::before { + content: "\F6D0"; +} +.mdi-eye-outline::before { + content: "\F6CF"; +} +.mdi-eye-plus::before { + content: "\F86A"; +} +.mdi-eye-plus-outline::before { + content: "\F86B"; +} +.mdi-eye-settings::before { + content: "\F86C"; +} +.mdi-eye-settings-outline::before { + content: "\F86D"; +} +.mdi-eyedropper::before { + content: "\F20A"; +} +.mdi-eyedropper-variant::before { + content: "\F20B"; +} +.mdi-face::before { + content: "\F643"; +} +.mdi-face-agent::before { + content: "\FD4C"; +} +.mdi-face-outline::before { + content: "\FB72"; +} +.mdi-face-profile::before { + content: "\F644"; +} +.mdi-face-recognition::before { + content: "\FC57"; +} +.mdi-facebook::before { + content: "\F20C"; +} +.mdi-facebook-box::before { + content: "\F20D"; +} +.mdi-facebook-messenger::before { + content: "\F20E"; +} +.mdi-facebook-workplace::before { + content: "\FB16"; +} +.mdi-factory::before { + content: "\F20F"; +} +.mdi-fan::before { + content: "\F210"; +} +.mdi-fan-off::before { + content: "\F81C"; +} +.mdi-fast-forward::before { + content: "\F211"; +} +.mdi-fast-forward-10::before { + content: "\FD4D"; +} +.mdi-fast-forward-30::before { + content: "\FCE2"; +} +.mdi-fast-forward-outline::before { + content: "\F6D1"; +} +.mdi-fax::before { + content: "\F212"; +} +.mdi-feather::before { + content: "\F6D2"; +} +.mdi-feature-search::before { + content: "\FA48"; +} +.mdi-feature-search-outline::before { + content: "\FA49"; +} +.mdi-fedora::before { + content: "\F8DA"; +} +.mdi-ferris-wheel::before { + content: "\FEC1"; +} +.mdi-ferry::before { + content: "\F213"; +} +.mdi-file::before { + content: "\F214"; +} +.mdi-file-account::before { + content: "\F73A"; +} +.mdi-file-alert::before { + content: "\FA4A"; +} +.mdi-file-alert-outline::before { + content: "\FA4B"; +} +.mdi-file-cabinet::before { + content: "\FAB5"; +} +.mdi-file-cad::before { + content: "\FF08"; +} +.mdi-file-cad-box::before { + content: "\FF09"; +} +.mdi-file-cancel::before { + content: "\FDA2"; +} +.mdi-file-cancel-outline::before { + content: "\FDA3"; +} +.mdi-file-chart::before { + content: "\F215"; +} +.mdi-file-check::before { + content: "\F216"; +} +.mdi-file-check-outline::before { + content: "\FE7B"; +} +.mdi-file-cloud::before { + content: "\F217"; +} +.mdi-file-compare::before { + content: "\F8A9"; +} +.mdi-file-delimited::before { + content: "\F218"; +} +.mdi-file-delimited-outline::before { + content: "\FEC2"; +} +.mdi-file-document::before { + content: "\F219"; +} +.mdi-file-document-box::before { + content: "\F21A"; +} +.mdi-file-document-box-check::before { + content: "\FEC3"; +} +.mdi-file-document-box-check-outline::before { + content: "\FEC4"; +} +.mdi-file-document-box-minus::before { + content: "\FEC5"; +} +.mdi-file-document-box-minus-outline::before { + content: "\FEC6"; +} +.mdi-file-document-box-multiple::before { + content: "\FAB6"; +} +.mdi-file-document-box-multiple-outline::before { + content: "\FAB7"; +} +.mdi-file-document-box-outline::before { + content: "\F9EC"; +} +.mdi-file-document-box-plus::before { + content: "\FEC7"; +} +.mdi-file-document-box-plus-outline::before { + content: "\FEC8"; +} +.mdi-file-document-box-remove::before { + content: "\FEC9"; +} +.mdi-file-document-box-remove-outline::before { + content: "\FECA"; +} +.mdi-file-document-box-search::before { + content: "\FECB"; +} +.mdi-file-document-box-search-outline::before { + content: "\FECC"; +} +.mdi-file-document-edit::before { + content: "\FDA4"; +} +.mdi-file-document-edit-outline::before { + content: "\FDA5"; +} +.mdi-file-document-outline::before { + content: "\F9ED"; +} +.mdi-file-download::before { + content: "\F964"; +} +.mdi-file-download-outline::before { + content: "\F965"; +} +.mdi-file-excel::before { + content: "\F21B"; +} +.mdi-file-excel-box::before { + content: "\F21C"; +} +.mdi-file-export::before { + content: "\F21D"; +} +.mdi-file-eye::before { + content: "\FDA6"; +} +.mdi-file-eye-outline::before { + content: "\FDA7"; +} +.mdi-file-find::before { + content: "\F21E"; +} +.mdi-file-find-outline::before { + content: "\FB73"; +} +.mdi-file-hidden::before { + content: "\F613"; +} +.mdi-file-image::before { + content: "\F21F"; +} +.mdi-file-image-outline::before { + content: "\FECD"; +} +.mdi-file-import::before { + content: "\F220"; +} +.mdi-file-lock::before { + content: "\F221"; +} +.mdi-file-move::before { + content: "\FAB8"; +} +.mdi-file-multiple::before { + content: "\F222"; +} +.mdi-file-music::before { + content: "\F223"; +} +.mdi-file-music-outline::before { + content: "\FE7C"; +} +.mdi-file-outline::before { + content: "\F224"; +} +.mdi-file-pdf::before { + content: "\F225"; +} +.mdi-file-pdf-box::before { + content: "\F226"; +} +.mdi-file-pdf-outline::before { + content: "\FE7D"; +} +.mdi-file-percent::before { + content: "\F81D"; +} +.mdi-file-plus::before { + content: "\F751"; +} +.mdi-file-plus-outline::before { + content: "\FF0A"; +} +.mdi-file-powerpoint::before { + content: "\F227"; +} +.mdi-file-powerpoint-box::before { + content: "\F228"; +} +.mdi-file-presentation-box::before { + content: "\F229"; +} +.mdi-file-question::before { + content: "\F86E"; +} +.mdi-file-remove::before { + content: "\FB74"; +} +.mdi-file-replace::before { + content: "\FB17"; +} +.mdi-file-replace-outline::before { + content: "\FB18"; +} +.mdi-file-restore::before { + content: "\F670"; +} +.mdi-file-search::before { + content: "\FC58"; +} +.mdi-file-search-outline::before { + content: "\FC59"; +} +.mdi-file-send::before { + content: "\F22A"; +} +.mdi-file-table::before { + content: "\FC5A"; +} +.mdi-file-table-outline::before { + content: "\FC5B"; +} +.mdi-file-tree::before { + content: "\F645"; +} +.mdi-file-undo::before { + content: "\F8DB"; +} +.mdi-file-upload::before { + content: "\FA4C"; +} +.mdi-file-upload-outline::before { + content: "\FA4D"; +} +.mdi-file-video::before { + content: "\F22B"; +} +.mdi-file-video-outline::before { + content: "\FE10"; +} +.mdi-file-word::before { + content: "\F22C"; +} +.mdi-file-word-box::before { + content: "\F22D"; +} +.mdi-file-xml::before { + content: "\F22E"; +} +.mdi-film::before { + content: "\F22F"; +} +.mdi-filmstrip::before { + content: "\F230"; +} +.mdi-filmstrip-off::before { + content: "\F231"; +} +.mdi-filter::before { + content: "\F232"; +} +.mdi-filter-minus::before { + content: "\FF0B"; +} +.mdi-filter-minus-outline::before { + content: "\FF0C"; +} +.mdi-filter-outline::before { + content: "\F233"; +} +.mdi-filter-plus::before { + content: "\FF0D"; +} +.mdi-filter-plus-outline::before { + content: "\FF0E"; +} +.mdi-filter-remove::before { + content: "\F234"; +} +.mdi-filter-remove-outline::before { + content: "\F235"; +} +.mdi-filter-variant::before { + content: "\F236"; +} +.mdi-finance::before { + content: "\F81E"; +} +.mdi-find-replace::before { + content: "\F6D3"; +} +.mdi-fingerprint::before { + content: "\F237"; +} +.mdi-fingerprint-off::before { + content: "\FECE"; +} +.mdi-fire::before { + content: "\F238"; +} +.mdi-fire-extinguisher::before { + content: "\FF0F"; +} +.mdi-fire-truck::before { + content: "\F8AA"; +} +.mdi-firebase::before { + content: "\F966"; +} +.mdi-firefox::before { + content: "\F239"; +} +.mdi-fireplace::before { + content: "\FE11"; +} +.mdi-fireplace-off::before { + content: "\FE12"; +} +.mdi-firework::before { + content: "\FE13"; +} +.mdi-fish::before { + content: "\F23A"; +} +.mdi-fishbowl::before { + content: "\FF10"; +} +.mdi-fishbowl-outline::before { + content: "\FF11"; +} +.mdi-fit-to-page::before { + content: "\FF12"; +} +.mdi-fit-to-page-outline::before { + content: "\FF13"; +} +.mdi-flag::before { + content: "\F23B"; +} +.mdi-flag-checkered::before { + content: "\F23C"; +} +.mdi-flag-minus::before { + content: "\FB75"; +} +.mdi-flag-outline::before { + content: "\F23D"; +} +.mdi-flag-plus::before { + content: "\FB76"; +} +.mdi-flag-remove::before { + content: "\FB77"; +} +.mdi-flag-triangle::before { + content: "\F23F"; +} +.mdi-flag-variant::before { + content: "\F240"; +} +.mdi-flag-variant-outline::before { + content: "\F23E"; +} +.mdi-flare::before { + content: "\FD4E"; +} +.mdi-flash::before { + content: "\F241"; +} +.mdi-flash-alert::before { + content: "\FF14"; +} +.mdi-flash-alert-outline::before { + content: "\FF15"; +} +.mdi-flash-auto::before { + content: "\F242"; +} +.mdi-flash-circle::before { + content: "\F81F"; +} +.mdi-flash-off::before { + content: "\F243"; +} +.mdi-flash-outline::before { + content: "\F6D4"; +} +.mdi-flash-red-eye::before { + content: "\F67A"; +} +.mdi-flashlight::before { + content: "\F244"; +} +.mdi-flashlight-off::before { + content: "\F245"; +} +.mdi-flask::before { + content: "\F093"; +} +.mdi-flask-empty::before { + content: "\F094"; +} +.mdi-flask-empty-outline::before { + content: "\F095"; +} +.mdi-flask-outline::before { + content: "\F096"; +} +.mdi-flattr::before { + content: "\F246"; +} +.mdi-flickr::before { + content: "\FCE3"; +} +.mdi-flip-to-back::before { + content: "\F247"; +} +.mdi-flip-to-front::before { + content: "\F248"; +} +.mdi-floor-lamp::before { + content: "\F8DC"; +} +.mdi-floor-plan::before { + content: "\F820"; +} +.mdi-floppy::before { + content: "\F249"; +} +.mdi-floppy-variant::before { + content: "\F9EE"; +} +.mdi-flower::before { + content: "\F24A"; +} +.mdi-flower-outline::before { + content: "\F9EF"; +} +.mdi-flower-poppy::before { + content: "\FCE4"; +} +.mdi-flower-tulip::before { + content: "\F9F0"; +} +.mdi-flower-tulip-outline::before { + content: "\F9F1"; +} +.mdi-focus-auto::before { + content: "\FF6B"; +} +.mdi-focus-field::before { + content: "\FF6C"; +} +.mdi-focus-field-horizontal::before { + content: "\FF6D"; +} +.mdi-focus-field-vertical::before { + content: "\FF6E"; +} +.mdi-folder::before { + content: "\F24B"; +} +.mdi-folder-account::before { + content: "\F24C"; +} +.mdi-folder-account-outline::before { + content: "\FB78"; +} +.mdi-folder-alert::before { + content: "\FDA8"; +} +.mdi-folder-alert-outline::before { + content: "\FDA9"; +} +.mdi-folder-clock::before { + content: "\FAB9"; +} +.mdi-folder-clock-outline::before { + content: "\FABA"; +} +.mdi-folder-download::before { + content: "\F24D"; +} +.mdi-folder-edit::before { + content: "\F8DD"; +} +.mdi-folder-edit-outline::before { + content: "\FDAA"; +} +.mdi-folder-google-drive::before { + content: "\F24E"; +} +.mdi-folder-image::before { + content: "\F24F"; +} +.mdi-folder-key::before { + content: "\F8AB"; +} +.mdi-folder-key-network::before { + content: "\F8AC"; +} +.mdi-folder-key-network-outline::before { + content: "\FC5C"; +} +.mdi-folder-lock::before { + content: "\F250"; +} +.mdi-folder-lock-open::before { + content: "\F251"; +} +.mdi-folder-move::before { + content: "\F252"; +} +.mdi-folder-multiple::before { + content: "\F253"; +} +.mdi-folder-multiple-image::before { + content: "\F254"; +} +.mdi-folder-multiple-outline::before { + content: "\F255"; +} +.mdi-folder-network::before { + content: "\F86F"; +} +.mdi-folder-network-outline::before { + content: "\FC5D"; +} +.mdi-folder-open::before { + content: "\F76F"; +} +.mdi-folder-open-outline::before { + content: "\FDAB"; +} +.mdi-folder-outline::before { + content: "\F256"; +} +.mdi-folder-plus::before { + content: "\F257"; +} +.mdi-folder-plus-outline::before { + content: "\FB79"; +} +.mdi-folder-pound::before { + content: "\FCE5"; +} +.mdi-folder-pound-outline::before { + content: "\FCE6"; +} +.mdi-folder-remove::before { + content: "\F258"; +} +.mdi-folder-remove-outline::before { + content: "\FB7A"; +} +.mdi-folder-search::before { + content: "\F967"; +} +.mdi-folder-search-outline::before { + content: "\F968"; +} +.mdi-folder-star::before { + content: "\F69C"; +} +.mdi-folder-star-outline::before { + content: "\FB7B"; +} +.mdi-folder-sync::before { + content: "\FCE7"; +} +.mdi-folder-sync-outline::before { + content: "\FCE8"; +} +.mdi-folder-text::before { + content: "\FC5E"; +} +.mdi-folder-text-outline::before { + content: "\FC5F"; +} +.mdi-folder-upload::before { + content: "\F259"; +} +.mdi-font-awesome::before { + content: "\F03A"; +} +.mdi-food::before { + content: "\F25A"; +} +.mdi-food-apple::before { + content: "\F25B"; +} +.mdi-food-apple-outline::before { + content: "\FC60"; +} +.mdi-food-croissant::before { + content: "\F7C7"; +} +.mdi-food-fork-drink::before { + content: "\F5F2"; +} +.mdi-food-off::before { + content: "\F5F3"; +} +.mdi-food-variant::before { + content: "\F25C"; +} +.mdi-foot-print::before { + content: "\FF6F"; +} +.mdi-football::before { + content: "\F25D"; +} +.mdi-football-australian::before { + content: "\F25E"; +} +.mdi-football-helmet::before { + content: "\F25F"; +} +.mdi-forklift::before { + content: "\F7C8"; +} +.mdi-format-align-bottom::before { + content: "\F752"; +} +.mdi-format-align-center::before { + content: "\F260"; +} +.mdi-format-align-justify::before { + content: "\F261"; +} +.mdi-format-align-left::before { + content: "\F262"; +} +.mdi-format-align-middle::before { + content: "\F753"; +} +.mdi-format-align-right::before { + content: "\F263"; +} +.mdi-format-align-top::before { + content: "\F754"; +} +.mdi-format-annotation-minus::before { + content: "\FABB"; +} +.mdi-format-annotation-plus::before { + content: "\F646"; +} +.mdi-format-bold::before { + content: "\F264"; +} +.mdi-format-clear::before { + content: "\F265"; +} +.mdi-format-color-fill::before { + content: "\F266"; +} +.mdi-format-color-highlight::before { + content: "\FE14"; +} +.mdi-format-color-text::before { + content: "\F69D"; +} +.mdi-format-columns::before { + content: "\F8DE"; +} +.mdi-format-float-center::before { + content: "\F267"; +} +.mdi-format-float-left::before { + content: "\F268"; +} +.mdi-format-float-none::before { + content: "\F269"; +} +.mdi-format-float-right::before { + content: "\F26A"; +} +.mdi-format-font::before { + content: "\F6D5"; +} +.mdi-format-font-size-decrease::before { + content: "\F9F2"; +} +.mdi-format-font-size-increase::before { + content: "\F9F3"; +} +.mdi-format-header-1::before { + content: "\F26B"; +} +.mdi-format-header-2::before { + content: "\F26C"; +} +.mdi-format-header-3::before { + content: "\F26D"; +} +.mdi-format-header-4::before { + content: "\F26E"; +} +.mdi-format-header-5::before { + content: "\F26F"; +} +.mdi-format-header-6::before { + content: "\F270"; +} +.mdi-format-header-decrease::before { + content: "\F271"; +} +.mdi-format-header-equal::before { + content: "\F272"; +} +.mdi-format-header-increase::before { + content: "\F273"; +} +.mdi-format-header-pound::before { + content: "\F274"; +} +.mdi-format-horizontal-align-center::before { + content: "\F61E"; +} +.mdi-format-horizontal-align-left::before { + content: "\F61F"; +} +.mdi-format-horizontal-align-right::before { + content: "\F620"; +} +.mdi-format-indent-decrease::before { + content: "\F275"; +} +.mdi-format-indent-increase::before { + content: "\F276"; +} +.mdi-format-italic::before { + content: "\F277"; +} +.mdi-format-letter-case::before { + content: "\FB19"; +} +.mdi-format-letter-case-lower::before { + content: "\FB1A"; +} +.mdi-format-letter-case-upper::before { + content: "\FB1B"; +} +.mdi-format-line-spacing::before { + content: "\F278"; +} +.mdi-format-line-style::before { + content: "\F5C8"; +} +.mdi-format-line-weight::before { + content: "\F5C9"; +} +.mdi-format-list-bulleted::before { + content: "\F279"; +} +.mdi-format-list-bulleted-square::before { + content: "\FDAC"; +} +.mdi-format-list-bulleted-type::before { + content: "\F27A"; +} +.mdi-format-list-checkbox::before { + content: "\F969"; +} +.mdi-format-list-checks::before { + content: "\F755"; +} +.mdi-format-list-numbered::before { + content: "\F27B"; +} +.mdi-format-list-numbered-rtl::before { + content: "\FCE9"; +} +.mdi-format-list-triangle::before { + content: "\FECF"; +} +.mdi-format-overline::before { + content: "\FED0"; +} +.mdi-format-page-break::before { + content: "\F6D6"; +} +.mdi-format-paint::before { + content: "\F27C"; +} +.mdi-format-paragraph::before { + content: "\F27D"; +} +.mdi-format-pilcrow::before { + content: "\F6D7"; +} +.mdi-format-quote-close::before { + content: "\F27E"; +} +.mdi-format-quote-open::before { + content: "\F756"; +} +.mdi-format-rotate-90::before { + content: "\F6A9"; +} +.mdi-format-section::before { + content: "\F69E"; +} +.mdi-format-size::before { + content: "\F27F"; +} +.mdi-format-strikethrough::before { + content: "\F280"; +} +.mdi-format-strikethrough-variant::before { + content: "\F281"; +} +.mdi-format-subscript::before { + content: "\F282"; +} +.mdi-format-superscript::before { + content: "\F283"; +} +.mdi-format-text::before { + content: "\F284"; +} +.mdi-format-text-rotation-down::before { + content: "\FD4F"; +} +.mdi-format-text-rotation-none::before { + content: "\FD50"; +} +.mdi-format-text-variant::before { + content: "\FE15"; +} +.mdi-format-text-wrapping-clip::before { + content: "\FCEA"; +} +.mdi-format-text-wrapping-overflow::before { + content: "\FCEB"; +} +.mdi-format-text-wrapping-wrap::before { + content: "\FCEC"; +} +.mdi-format-textbox::before { + content: "\FCED"; +} +.mdi-format-textdirection-l-to-r::before { + content: "\F285"; +} +.mdi-format-textdirection-r-to-l::before { + content: "\F286"; +} +.mdi-format-title::before { + content: "\F5F4"; +} +.mdi-format-underline::before { + content: "\F287"; +} +.mdi-format-vertical-align-bottom::before { + content: "\F621"; +} +.mdi-format-vertical-align-center::before { + content: "\F622"; +} +.mdi-format-vertical-align-top::before { + content: "\F623"; +} +.mdi-format-wrap-inline::before { + content: "\F288"; +} +.mdi-format-wrap-square::before { + content: "\F289"; +} +.mdi-format-wrap-tight::before { + content: "\F28A"; +} +.mdi-format-wrap-top-bottom::before { + content: "\F28B"; +} +.mdi-forum::before { + content: "\F28C"; +} +.mdi-forum-outline::before { + content: "\F821"; +} +.mdi-forward::before { + content: "\F28D"; +} +.mdi-forwardburger::before { + content: "\FD51"; +} +.mdi-fountain::before { + content: "\F96A"; +} +.mdi-fountain-pen::before { + content: "\FCEE"; +} +.mdi-fountain-pen-tip::before { + content: "\FCEF"; +} +.mdi-foursquare::before { + content: "\F28E"; +} +.mdi-freebsd::before { + content: "\F8DF"; +} +.mdi-frequently-asked-questions::before { + content: "\FED1"; +} +.mdi-fridge::before { + content: "\F290"; +} +.mdi-fridge-bottom::before { + content: "\F292"; +} +.mdi-fridge-outline::before { + content: "\F28F"; +} +.mdi-fridge-top::before { + content: "\F291"; +} +.mdi-fuel::before { + content: "\F7C9"; +} +.mdi-fullscreen::before { + content: "\F293"; +} +.mdi-fullscreen-exit::before { + content: "\F294"; +} +.mdi-function::before { + content: "\F295"; +} +.mdi-function-variant::before { + content: "\F870"; +} +.mdi-fuse::before { + content: "\FC61"; +} +.mdi-fuse-blade::before { + content: "\FC62"; +} +.mdi-gamepad::before { + content: "\F296"; +} +.mdi-gamepad-circle::before { + content: "\FE16"; +} +.mdi-gamepad-circle-down::before { + content: "\FE17"; +} +.mdi-gamepad-circle-left::before { + content: "\FE18"; +} +.mdi-gamepad-circle-outline::before { + content: "\FE19"; +} +.mdi-gamepad-circle-right::before { + content: "\FE1A"; +} +.mdi-gamepad-circle-up::before { + content: "\FE1B"; +} +.mdi-gamepad-down::before { + content: "\FE1C"; +} +.mdi-gamepad-left::before { + content: "\FE1D"; +} +.mdi-gamepad-right::before { + content: "\FE1E"; +} +.mdi-gamepad-round::before { + content: "\FE1F"; +} +.mdi-gamepad-round-down::before { + content: "\FE7E"; +} +.mdi-gamepad-round-left::before { + content: "\FE7F"; +} +.mdi-gamepad-round-outline::before { + content: "\FE80"; +} +.mdi-gamepad-round-right::before { + content: "\FE81"; +} +.mdi-gamepad-round-up::before { + content: "\FE82"; +} +.mdi-gamepad-square::before { + content: "\FED2"; +} +.mdi-gamepad-square-outline::before { + content: "\FED3"; +} +.mdi-gamepad-up::before { + content: "\FE83"; +} +.mdi-gamepad-variant::before { + content: "\F297"; +} +.mdi-gamepad-variant-outline::before { + content: "\FED4"; +} +.mdi-gantry-crane::before { + content: "\FDAD"; +} +.mdi-garage::before { + content: "\F6D8"; +} +.mdi-garage-alert::before { + content: "\F871"; +} +.mdi-garage-open::before { + content: "\F6D9"; +} +.mdi-gas-cylinder::before { + content: "\F647"; +} +.mdi-gas-station::before { + content: "\F298"; +} +.mdi-gas-station-outline::before { + content: "\FED5"; +} +.mdi-gate::before { + content: "\F299"; +} +.mdi-gate-and::before { + content: "\F8E0"; +} +.mdi-gate-nand::before { + content: "\F8E1"; +} +.mdi-gate-nor::before { + content: "\F8E2"; +} +.mdi-gate-not::before { + content: "\F8E3"; +} +.mdi-gate-or::before { + content: "\F8E4"; +} +.mdi-gate-xnor::before { + content: "\F8E5"; +} +.mdi-gate-xor::before { + content: "\F8E6"; +} +.mdi-gatsby::before { + content: "\FE84"; +} +.mdi-gauge::before { + content: "\F29A"; +} +.mdi-gauge-empty::before { + content: "\F872"; +} +.mdi-gauge-full::before { + content: "\F873"; +} +.mdi-gauge-low::before { + content: "\F874"; +} +.mdi-gavel::before { + content: "\F29B"; +} +.mdi-gender-female::before { + content: "\F29C"; +} +.mdi-gender-male::before { + content: "\F29D"; +} +.mdi-gender-male-female::before { + content: "\F29E"; +} +.mdi-gender-transgender::before { + content: "\F29F"; +} +.mdi-gentoo::before { + content: "\F8E7"; +} +.mdi-gesture::before { + content: "\F7CA"; +} +.mdi-gesture-double-tap::before { + content: "\F73B"; +} +.mdi-gesture-pinch::before { + content: "\FABC"; +} +.mdi-gesture-spread::before { + content: "\FABD"; +} +.mdi-gesture-swipe::before { + content: "\FD52"; +} +.mdi-gesture-swipe-down::before { + content: "\F73C"; +} +.mdi-gesture-swipe-horizontal::before { + content: "\FABE"; +} +.mdi-gesture-swipe-left::before { + content: "\F73D"; +} +.mdi-gesture-swipe-right::before { + content: "\F73E"; +} +.mdi-gesture-swipe-up::before { + content: "\F73F"; +} +.mdi-gesture-swipe-vertical::before { + content: "\FABF"; +} +.mdi-gesture-tap::before { + content: "\F740"; +} +.mdi-gesture-tap-hold::before { + content: "\FD53"; +} +.mdi-gesture-two-double-tap::before { + content: "\F741"; +} +.mdi-gesture-two-tap::before { + content: "\F742"; +} +.mdi-ghost::before { + content: "\F2A0"; +} +.mdi-ghost-off::before { + content: "\F9F4"; +} +.mdi-gif::before { + content: "\FD54"; +} +.mdi-gift::before { + content: "\FE85"; +} +.mdi-gift-outline::before { + content: "\F2A1"; +} +.mdi-git::before { + content: "\F2A2"; +} +.mdi-github-box::before { + content: "\F2A3"; +} +.mdi-github-circle::before { + content: "\F2A4"; +} +.mdi-github-face::before { + content: "\F6DA"; +} +.mdi-gitlab::before { + content: "\FB7C"; +} +.mdi-glass-cocktail::before { + content: "\F356"; +} +.mdi-glass-flute::before { + content: "\F2A5"; +} +.mdi-glass-mug::before { + content: "\F2A6"; +} +.mdi-glass-stange::before { + content: "\F2A7"; +} +.mdi-glass-tulip::before { + content: "\F2A8"; +} +.mdi-glass-wine::before { + content: "\F875"; +} +.mdi-glassdoor::before { + content: "\F2A9"; +} +.mdi-glasses::before { + content: "\F2AA"; +} +.mdi-globe-model::before { + content: "\F8E8"; +} +.mdi-gmail::before { + content: "\F2AB"; +} +.mdi-gnome::before { + content: "\F2AC"; +} +.mdi-go-kart::before { + content: "\FD55"; +} +.mdi-go-kart-track::before { + content: "\FD56"; +} +.mdi-gog::before { + content: "\FB7D"; +} +.mdi-golf::before { + content: "\F822"; +} +.mdi-gondola::before { + content: "\F685"; +} +.mdi-goodreads::before { + content: "\FD57"; +} +.mdi-google::before { + content: "\F2AD"; +} +.mdi-google-adwords::before { + content: "\FC63"; +} +.mdi-google-allo::before { + content: "\F801"; +} +.mdi-google-analytics::before { + content: "\F7CB"; +} +.mdi-google-assistant::before { + content: "\F7CC"; +} +.mdi-google-cardboard::before { + content: "\F2AE"; +} +.mdi-google-chrome::before { + content: "\F2AF"; +} +.mdi-google-circles::before { + content: "\F2B0"; +} +.mdi-google-circles-communities::before { + content: "\F2B1"; +} +.mdi-google-circles-extended::before { + content: "\F2B2"; +} +.mdi-google-circles-group::before { + content: "\F2B3"; +} +.mdi-google-classroom::before { + content: "\F2C0"; +} +.mdi-google-controller::before { + content: "\F2B4"; +} +.mdi-google-controller-off::before { + content: "\F2B5"; +} +.mdi-google-drive::before { + content: "\F2B6"; +} +.mdi-google-earth::before { + content: "\F2B7"; +} +.mdi-google-fit::before { + content: "\F96B"; +} +.mdi-google-glass::before { + content: "\F2B8"; +} +.mdi-google-hangouts::before { + content: "\F2C9"; +} +.mdi-google-home::before { + content: "\F823"; +} +.mdi-google-keep::before { + content: "\F6DB"; +} +.mdi-google-lens::before { + content: "\F9F5"; +} +.mdi-google-maps::before { + content: "\F5F5"; +} +.mdi-google-nearby::before { + content: "\F2B9"; +} +.mdi-google-pages::before { + content: "\F2BA"; +} +.mdi-google-photos::before { + content: "\F6DC"; +} +.mdi-google-physical-web::before { + content: "\F2BB"; +} +.mdi-google-play::before { + content: "\F2BC"; +} +.mdi-google-plus::before { + content: "\F2BD"; +} +.mdi-google-plus-box::before { + content: "\F2BE"; +} +.mdi-google-podcast::before { + content: "\FED6"; +} +.mdi-google-spreadsheet::before { + content: "\F9F6"; +} +.mdi-google-street-view::before { + content: "\FC64"; +} +.mdi-google-translate::before { + content: "\F2BF"; +} +.mdi-gpu::before { + content: "\F8AD"; +} +.mdi-gradient::before { + content: "\F69F"; +} +.mdi-grain::before { + content: "\FD58"; +} +.mdi-graphql::before { + content: "\F876"; +} +.mdi-grave-stone::before { + content: "\FB7E"; +} +.mdi-grease-pencil::before { + content: "\F648"; +} +.mdi-greater-than::before { + content: "\F96C"; +} +.mdi-greater-than-or-equal::before { + content: "\F96D"; +} +.mdi-grid::before { + content: "\F2C1"; +} +.mdi-grid-large::before { + content: "\F757"; +} +.mdi-grid-off::before { + content: "\F2C2"; +} +.mdi-grill::before { + content: "\FE86"; +} +.mdi-group::before { + content: "\F2C3"; +} +.mdi-guitar-acoustic::before { + content: "\F770"; +} +.mdi-guitar-electric::before { + content: "\F2C4"; +} +.mdi-guitar-pick::before { + content: "\F2C5"; +} +.mdi-guitar-pick-outline::before { + content: "\F2C6"; +} +.mdi-guy-fawkes-mask::before { + content: "\F824"; +} +.mdi-hackernews::before { + content: "\F624"; +} +.mdi-hail::before { + content: "\FAC0"; +} +.mdi-halloween::before { + content: "\FB7F"; +} +.mdi-hamburger::before { + content: "\F684"; +} +.mdi-hammer::before { + content: "\F8E9"; +} +.mdi-hand::before { + content: "\FA4E"; +} +.mdi-hand-left::before { + content: "\FE87"; +} +.mdi-hand-okay::before { + content: "\FA4F"; +} +.mdi-hand-peace::before { + content: "\FA50"; +} +.mdi-hand-peace-variant::before { + content: "\FA51"; +} +.mdi-hand-pointing-down::before { + content: "\FA52"; +} +.mdi-hand-pointing-left::before { + content: "\FA53"; +} +.mdi-hand-pointing-right::before { + content: "\F2C7"; +} +.mdi-hand-pointing-up::before { + content: "\FA54"; +} +.mdi-hand-right::before { + content: "\FE88"; +} +.mdi-hand-saw::before { + content: "\FE89"; +} +.mdi-handball::before { + content: "\FF70"; +} +.mdi-hanger::before { + content: "\F2C8"; +} +.mdi-hard-hat::before { + content: "\F96E"; +} +.mdi-harddisk::before { + content: "\F2CA"; +} +.mdi-hat-fedora::before { + content: "\FB80"; +} +.mdi-hazard-lights::before { + content: "\FC65"; +} +.mdi-hdr::before { + content: "\FD59"; +} +.mdi-hdr-off::before { + content: "\FD5A"; +} +.mdi-headphones::before { + content: "\F2CB"; +} +.mdi-headphones-bluetooth::before { + content: "\F96F"; +} +.mdi-headphones-box::before { + content: "\F2CC"; +} +.mdi-headphones-off::before { + content: "\F7CD"; +} +.mdi-headphones-settings::before { + content: "\F2CD"; +} +.mdi-headset::before { + content: "\F2CE"; +} +.mdi-headset-dock::before { + content: "\F2CF"; +} +.mdi-headset-off::before { + content: "\F2D0"; +} +.mdi-heart::before { + content: "\F2D1"; +} +.mdi-heart-box::before { + content: "\F2D2"; +} +.mdi-heart-box-outline::before { + content: "\F2D3"; +} +.mdi-heart-broken::before { + content: "\F2D4"; +} +.mdi-heart-broken-outline::before { + content: "\FCF0"; +} +.mdi-heart-circle::before { + content: "\F970"; +} +.mdi-heart-circle-outline::before { + content: "\F971"; +} +.mdi-heart-flash::before { + content: "\FF16"; +} +.mdi-heart-half::before { + content: "\F6DE"; +} +.mdi-heart-half-full::before { + content: "\F6DD"; +} +.mdi-heart-half-outline::before { + content: "\F6DF"; +} +.mdi-heart-multiple::before { + content: "\FA55"; +} +.mdi-heart-multiple-outline::before { + content: "\FA56"; +} +.mdi-heart-off::before { + content: "\F758"; +} +.mdi-heart-outline::before { + content: "\F2D5"; +} +.mdi-heart-pulse::before { + content: "\F5F6"; +} +.mdi-helicopter::before { + content: "\FAC1"; +} +.mdi-help::before { + content: "\F2D6"; +} +.mdi-help-box::before { + content: "\F78A"; +} +.mdi-help-circle::before { + content: "\F2D7"; +} +.mdi-help-circle-outline::before { + content: "\F625"; +} +.mdi-help-network::before { + content: "\F6F4"; +} +.mdi-help-network-outline::before { + content: "\FC66"; +} +.mdi-help-rhombus::before { + content: "\FB81"; +} +.mdi-help-rhombus-outline::before { + content: "\FB82"; +} +.mdi-hexagon::before { + content: "\F2D8"; +} +.mdi-hexagon-multiple::before { + content: "\F6E0"; +} +.mdi-hexagon-outline::before { + content: "\F2D9"; +} +.mdi-hexagon-slice-1::before { + content: "\FAC2"; +} +.mdi-hexagon-slice-2::before { + content: "\FAC3"; +} +.mdi-hexagon-slice-3::before { + content: "\FAC4"; +} +.mdi-hexagon-slice-4::before { + content: "\FAC5"; +} +.mdi-hexagon-slice-5::before { + content: "\FAC6"; +} +.mdi-hexagon-slice-6::before { + content: "\FAC7"; +} +.mdi-hexagram::before { + content: "\FAC8"; +} +.mdi-hexagram-outline::before { + content: "\FAC9"; +} +.mdi-high-definition::before { + content: "\F7CE"; +} +.mdi-high-definition-box::before { + content: "\F877"; +} +.mdi-highway::before { + content: "\F5F7"; +} +.mdi-hiking::before { + content: "\FD5B"; +} +.mdi-hinduism::before { + content: "\F972"; +} +.mdi-history::before { + content: "\F2DA"; +} +.mdi-hockey-puck::before { + content: "\F878"; +} +.mdi-hockey-sticks::before { + content: "\F879"; +} +.mdi-hololens::before { + content: "\F2DB"; +} +.mdi-home::before { + content: "\F2DC"; +} +.mdi-home-account::before { + content: "\F825"; +} +.mdi-home-alert::before { + content: "\F87A"; +} +.mdi-home-analytics::before { + content: "\FED7"; +} +.mdi-home-assistant::before { + content: "\F7CF"; +} +.mdi-home-automation::before { + content: "\F7D0"; +} +.mdi-home-circle::before { + content: "\F7D1"; +} +.mdi-home-city::before { + content: "\FCF1"; +} +.mdi-home-city-outline::before { + content: "\FCF2"; +} +.mdi-home-currency-usd::before { + content: "\F8AE"; +} +.mdi-home-export-outline::before { + content: "\FFB8"; +} +.mdi-home-flood::before { + content: "\FF17"; +} +.mdi-home-floor-0::before { + content: "\FDAE"; +} +.mdi-home-floor-1::before { + content: "\FD5C"; +} +.mdi-home-floor-2::before { + content: "\FD5D"; +} +.mdi-home-floor-3::before { + content: "\FD5E"; +} +.mdi-home-floor-a::before { + content: "\FD5F"; +} +.mdi-home-floor-b::before { + content: "\FD60"; +} +.mdi-home-floor-g::before { + content: "\FD61"; +} +.mdi-home-floor-l::before { + content: "\FD62"; +} +.mdi-home-floor-negative-1::before { + content: "\FDAF"; +} +.mdi-home-group::before { + content: "\FDB0"; +} +.mdi-home-heart::before { + content: "\F826"; +} +.mdi-home-import-outline::before { + content: "\FFB9"; +} +.mdi-home-lock::before { + content: "\F8EA"; +} +.mdi-home-lock-open::before { + content: "\F8EB"; +} +.mdi-home-map-marker::before { + content: "\F5F8"; +} +.mdi-home-minus::before { + content: "\F973"; +} +.mdi-home-modern::before { + content: "\F2DD"; +} +.mdi-home-outline::before { + content: "\F6A0"; +} +.mdi-home-plus::before { + content: "\F974"; +} +.mdi-home-thermometer::before { + content: "\FF71"; +} +.mdi-home-thermometer-outline::before { + content: "\FF72"; +} +.mdi-home-variant::before { + content: "\F2DE"; +} +.mdi-home-variant-outline::before { + content: "\FB83"; +} +.mdi-hook::before { + content: "\F6E1"; +} +.mdi-hook-off::before { + content: "\F6E2"; +} +.mdi-hops::before { + content: "\F2DF"; +} +.mdi-horseshoe::before { + content: "\FA57"; +} +.mdi-hospital::before { + content: "\F2E0"; +} +.mdi-hospital-building::before { + content: "\F2E1"; +} +.mdi-hospital-marker::before { + content: "\F2E2"; +} +.mdi-hot-tub::before { + content: "\F827"; +} +.mdi-hotel::before { + content: "\F2E3"; +} +.mdi-houzz::before { + content: "\F2E4"; +} +.mdi-houzz-box::before { + content: "\F2E5"; +} +.mdi-hubspot::before { + content: "\FCF3"; +} +.mdi-hulu::before { + content: "\F828"; +} +.mdi-human::before { + content: "\F2E6"; +} +.mdi-human-child::before { + content: "\F2E7"; +} +.mdi-human-female::before { + content: "\F649"; +} +.mdi-human-female-boy::before { + content: "\FA58"; +} +.mdi-human-female-female::before { + content: "\FA59"; +} +.mdi-human-female-girl::before { + content: "\FA5A"; +} +.mdi-human-greeting::before { + content: "\F64A"; +} +.mdi-human-handsdown::before { + content: "\F64B"; +} +.mdi-human-handsup::before { + content: "\F64C"; +} +.mdi-human-male::before { + content: "\F64D"; +} +.mdi-human-male-boy::before { + content: "\FA5B"; +} +.mdi-human-male-female::before { + content: "\F2E8"; +} +.mdi-human-male-girl::before { + content: "\FA5C"; +} +.mdi-human-male-height::before { + content: "\FF18"; +} +.mdi-human-male-height-variant::before { + content: "\FF19"; +} +.mdi-human-male-male::before { + content: "\FA5D"; +} +.mdi-human-pregnant::before { + content: "\F5CF"; +} +.mdi-humble-bundle::before { + content: "\F743"; +} +.mdi-ice-cream::before { + content: "\F829"; +} +.mdi-ice-pop::before { + content: "\FF1A"; +} +.mdi-identifier::before { + content: "\FF1B"; +} +.mdi-iframe::before { + content: "\FC67"; +} +.mdi-iframe-outline::before { + content: "\FC68"; +} +.mdi-image::before { + content: "\F2E9"; +} +.mdi-image-album::before { + content: "\F2EA"; +} +.mdi-image-area::before { + content: "\F2EB"; +} +.mdi-image-area-close::before { + content: "\F2EC"; +} +.mdi-image-broken::before { + content: "\F2ED"; +} +.mdi-image-broken-variant::before { + content: "\F2EE"; +} +.mdi-image-filter::before { + content: "\F2EF"; +} +.mdi-image-filter-black-white::before { + content: "\F2F0"; +} +.mdi-image-filter-center-focus::before { + content: "\F2F1"; +} +.mdi-image-filter-center-focus-strong::before { + content: "\FF1C"; +} +.mdi-image-filter-center-focus-strong-outline::before { + content: "\FF1D"; +} +.mdi-image-filter-center-focus-weak::before { + content: "\F2F2"; +} +.mdi-image-filter-drama::before { + content: "\F2F3"; +} +.mdi-image-filter-frames::before { + content: "\F2F4"; +} +.mdi-image-filter-hdr::before { + content: "\F2F5"; +} +.mdi-image-filter-none::before { + content: "\F2F6"; +} +.mdi-image-filter-tilt-shift::before { + content: "\F2F7"; +} +.mdi-image-filter-vintage::before { + content: "\F2F8"; +} +.mdi-image-frame::before { + content: "\FE8A"; +} +.mdi-image-move::before { + content: "\F9F7"; +} +.mdi-image-multiple::before { + content: "\F2F9"; +} +.mdi-image-off::before { + content: "\F82A"; +} +.mdi-image-outline::before { + content: "\F975"; +} +.mdi-image-plus::before { + content: "\F87B"; +} +.mdi-image-search::before { + content: "\F976"; +} +.mdi-image-search-outline::before { + content: "\F977"; +} +.mdi-image-size-select-actual::before { + content: "\FC69"; +} +.mdi-image-size-select-large::before { + content: "\FC6A"; +} +.mdi-image-size-select-small::before { + content: "\FC6B"; +} +.mdi-import::before { + content: "\F2FA"; +} +.mdi-inbox::before { + content: "\F686"; +} +.mdi-inbox-arrow-down::before { + content: "\F2FB"; +} +.mdi-inbox-arrow-up::before { + content: "\F3D1"; +} +.mdi-inbox-multiple::before { + content: "\F8AF"; +} +.mdi-inbox-multiple-outline::before { + content: "\FB84"; +} +.mdi-incognito::before { + content: "\F5F9"; +} +.mdi-infinity::before { + content: "\F6E3"; +} +.mdi-information::before { + content: "\F2FC"; +} +.mdi-information-outline::before { + content: "\F2FD"; +} +.mdi-information-variant::before { + content: "\F64E"; +} +.mdi-instagram::before { + content: "\F2FE"; +} +.mdi-instapaper::before { + content: "\F2FF"; +} +.mdi-internet-explorer::before { + content: "\F300"; +} +.mdi-invert-colors::before { + content: "\F301"; +} +.mdi-invert-colors-off::before { + content: "\FE8B"; +} +.mdi-ip::before { + content: "\FA5E"; +} +.mdi-ip-network::before { + content: "\FA5F"; +} +.mdi-ip-network-outline::before { + content: "\FC6C"; +} +.mdi-ipod::before { + content: "\FC6D"; +} +.mdi-islam::before { + content: "\F978"; +} +.mdi-itunes::before { + content: "\F676"; +} +.mdi-jabber::before { + content: "\FDB1"; +} +.mdi-jeepney::before { + content: "\F302"; +} +.mdi-jellyfish::before { + content: "\FF1E"; +} +.mdi-jellyfish-outline::before { + content: "\FF1F"; +} +.mdi-jira::before { + content: "\F303"; +} +.mdi-jquery::before { + content: "\F87C"; +} +.mdi-jsfiddle::before { + content: "\F304"; +} +.mdi-json::before { + content: "\F626"; +} +.mdi-judaism::before { + content: "\F979"; +} +.mdi-kabaddi::before { + content: "\FD63"; +} +.mdi-karate::before { + content: "\F82B"; +} +.mdi-keg::before { + content: "\F305"; +} +.mdi-kettle::before { + content: "\F5FA"; +} +.mdi-kettle-outline::before { + content: "\FF73"; +} +.mdi-key::before { + content: "\F306"; +} +.mdi-key-change::before { + content: "\F307"; +} +.mdi-key-minus::before { + content: "\F308"; +} +.mdi-key-outline::before { + content: "\FDB2"; +} +.mdi-key-plus::before { + content: "\F309"; +} +.mdi-key-remove::before { + content: "\F30A"; +} +.mdi-key-variant::before { + content: "\F30B"; +} +.mdi-keyboard::before { + content: "\F30C"; +} +.mdi-keyboard-backspace::before { + content: "\F30D"; +} +.mdi-keyboard-caps::before { + content: "\F30E"; +} +.mdi-keyboard-close::before { + content: "\F30F"; +} +.mdi-keyboard-off::before { + content: "\F310"; +} +.mdi-keyboard-off-outline::before { + content: "\FE8C"; +} +.mdi-keyboard-outline::before { + content: "\F97A"; +} +.mdi-keyboard-return::before { + content: "\F311"; +} +.mdi-keyboard-settings::before { + content: "\F9F8"; +} +.mdi-keyboard-settings-outline::before { + content: "\F9F9"; +} +.mdi-keyboard-tab::before { + content: "\F312"; +} +.mdi-keyboard-variant::before { + content: "\F313"; +} +.mdi-kickstarter::before { + content: "\F744"; +} +.mdi-knife::before { + content: "\F9FA"; +} +.mdi-knife-military::before { + content: "\F9FB"; +} +.mdi-kodi::before { + content: "\F314"; +} +.mdi-label::before { + content: "\F315"; +} +.mdi-label-off::before { + content: "\FACA"; +} +.mdi-label-off-outline::before { + content: "\FACB"; +} +.mdi-label-outline::before { + content: "\F316"; +} +.mdi-label-variant::before { + content: "\FACC"; +} +.mdi-label-variant-outline::before { + content: "\FACD"; +} +.mdi-ladybug::before { + content: "\F82C"; +} +.mdi-lambda::before { + content: "\F627"; +} +.mdi-lamp::before { + content: "\F6B4"; +} +.mdi-lan::before { + content: "\F317"; +} +.mdi-lan-connect::before { + content: "\F318"; +} +.mdi-lan-disconnect::before { + content: "\F319"; +} +.mdi-lan-pending::before { + content: "\F31A"; +} +.mdi-language-c::before { + content: "\F671"; +} +.mdi-language-cpp::before { + content: "\F672"; +} +.mdi-language-csharp::before { + content: "\F31B"; +} +.mdi-language-css3::before { + content: "\F31C"; +} +.mdi-language-go::before { + content: "\F7D2"; +} +.mdi-language-haskell::before { + content: "\FC6E"; +} +.mdi-language-html5::before { + content: "\F31D"; +} +.mdi-language-java::before { + content: "\FB1C"; +} +.mdi-language-javascript::before { + content: "\F31E"; +} +.mdi-language-lua::before { + content: "\F8B0"; +} +.mdi-language-php::before { + content: "\F31F"; +} +.mdi-language-python::before { + content: "\F320"; +} +.mdi-language-python-text::before { + content: "\F321"; +} +.mdi-language-r::before { + content: "\F7D3"; +} +.mdi-language-ruby-on-rails::before { + content: "\FACE"; +} +.mdi-language-swift::before { + content: "\F6E4"; +} +.mdi-language-typescript::before { + content: "\F6E5"; +} +.mdi-laptop::before { + content: "\F322"; +} +.mdi-laptop-chromebook::before { + content: "\F323"; +} +.mdi-laptop-mac::before { + content: "\F324"; +} +.mdi-laptop-off::before { + content: "\F6E6"; +} +.mdi-laptop-windows::before { + content: "\F325"; +} +.mdi-laravel::before { + content: "\FACF"; +} +.mdi-lasso::before { + content: "\FF20"; +} +.mdi-lastfm::before { + content: "\F326"; +} +.mdi-lastpass::before { + content: "\F446"; +} +.mdi-latitude::before { + content: "\FF74"; +} +.mdi-launch::before { + content: "\F327"; +} +.mdi-lava-lamp::before { + content: "\F7D4"; +} +.mdi-layers::before { + content: "\F328"; +} +.mdi-layers-minus::before { + content: "\FE8D"; +} +.mdi-layers-off::before { + content: "\F329"; +} +.mdi-layers-off-outline::before { + content: "\F9FC"; +} +.mdi-layers-outline::before { + content: "\F9FD"; +} +.mdi-layers-plus::before { + content: "\FE30"; +} +.mdi-layers-remove::before { + content: "\FE31"; +} +.mdi-layers-triple::before { + content: "\FF75"; +} +.mdi-layers-triple-outline::before { + content: "\FF76"; +} +.mdi-lead-pencil::before { + content: "\F64F"; +} +.mdi-leaf::before { + content: "\F32A"; +} +.mdi-leaf-maple::before { + content: "\FC6F"; +} +.mdi-leak::before { + content: "\FDB3"; +} +.mdi-leak-off::before { + content: "\FDB4"; +} +.mdi-led-off::before { + content: "\F32B"; +} +.mdi-led-on::before { + content: "\F32C"; +} +.mdi-led-outline::before { + content: "\F32D"; +} +.mdi-led-strip::before { + content: "\F7D5"; +} +.mdi-led-variant-off::before { + content: "\F32E"; +} +.mdi-led-variant-on::before { + content: "\F32F"; +} +.mdi-led-variant-outline::before { + content: "\F330"; +} +.mdi-less-than::before { + content: "\F97B"; +} +.mdi-less-than-or-equal::before { + content: "\F97C"; +} +.mdi-library::before { + content: "\F331"; +} +.mdi-library-books::before { + content: "\F332"; +} +.mdi-library-movie::before { + content: "\FCF4"; +} +.mdi-library-music::before { + content: "\F333"; +} +.mdi-library-music-outline::before { + content: "\FF21"; +} +.mdi-library-plus::before { + content: "\F334"; +} +.mdi-library-shelves::before { + content: "\FB85"; +} +.mdi-library-video::before { + content: "\FCF5"; +} +.mdi-lifebuoy::before { + content: "\F87D"; +} +.mdi-light-switch::before { + content: "\F97D"; +} +.mdi-lightbulb::before { + content: "\F335"; +} +.mdi-lightbulb-off::before { + content: "\FE32"; +} +.mdi-lightbulb-off-outline::before { + content: "\FE33"; +} +.mdi-lightbulb-on::before { + content: "\F6E7"; +} +.mdi-lightbulb-on-outline::before { + content: "\F6E8"; +} +.mdi-lightbulb-outline::before { + content: "\F336"; +} +.mdi-lighthouse::before { + content: "\F9FE"; +} +.mdi-lighthouse-on::before { + content: "\F9FF"; +} +.mdi-link::before { + content: "\F337"; +} +.mdi-link-box::before { + content: "\FCF6"; +} +.mdi-link-box-outline::before { + content: "\FCF7"; +} +.mdi-link-box-variant::before { + content: "\FCF8"; +} +.mdi-link-box-variant-outline::before { + content: "\FCF9"; +} +.mdi-link-off::before { + content: "\F338"; +} +.mdi-link-plus::before { + content: "\FC70"; +} +.mdi-link-variant::before { + content: "\F339"; +} +.mdi-link-variant-off::before { + content: "\F33A"; +} +.mdi-linkedin::before { + content: "\F33B"; +} +.mdi-linkedin-box::before { + content: "\F33C"; +} +.mdi-linux::before { + content: "\F33D"; +} +.mdi-linux-mint::before { + content: "\F8EC"; +} +.mdi-litecoin::before { + content: "\FA60"; +} +.mdi-loading::before { + content: "\F771"; +} +.mdi-lock::before { + content: "\F33E"; +} +.mdi-lock-alert::before { + content: "\F8ED"; +} +.mdi-lock-clock::before { + content: "\F97E"; +} +.mdi-lock-open::before { + content: "\F33F"; +} +.mdi-lock-open-outline::before { + content: "\F340"; +} +.mdi-lock-outline::before { + content: "\F341"; +} +.mdi-lock-pattern::before { + content: "\F6E9"; +} +.mdi-lock-plus::before { + content: "\F5FB"; +} +.mdi-lock-question::before { + content: "\F8EE"; +} +.mdi-lock-reset::before { + content: "\F772"; +} +.mdi-lock-smart::before { + content: "\F8B1"; +} +.mdi-locker::before { + content: "\F7D6"; +} +.mdi-locker-multiple::before { + content: "\F7D7"; +} +.mdi-login::before { + content: "\F342"; +} +.mdi-login-variant::before { + content: "\F5FC"; +} +.mdi-logout::before { + content: "\F343"; +} +.mdi-logout-variant::before { + content: "\F5FD"; +} +.mdi-longitude::before { + content: "\FF77"; +} +.mdi-looks::before { + content: "\F344"; +} +.mdi-loop::before { + content: "\F6EA"; +} +.mdi-loupe::before { + content: "\F345"; +} +.mdi-lumx::before { + content: "\F346"; +} +.mdi-lyft::before { + content: "\FB1D"; +} +.mdi-magnet::before { + content: "\F347"; +} +.mdi-magnet-on::before { + content: "\F348"; +} +.mdi-magnify::before { + content: "\F349"; +} +.mdi-magnify-close::before { + content: "\F97F"; +} +.mdi-magnify-minus::before { + content: "\F34A"; +} +.mdi-magnify-minus-cursor::before { + content: "\FA61"; +} +.mdi-magnify-minus-outline::before { + content: "\F6EB"; +} +.mdi-magnify-plus::before { + content: "\F34B"; +} +.mdi-magnify-plus-cursor::before { + content: "\FA62"; +} +.mdi-magnify-plus-outline::before { + content: "\F6EC"; +} +.mdi-mail::before { + content: "\FED8"; +} +.mdi-mail-ru::before { + content: "\F34C"; +} +.mdi-mailbox::before { + content: "\F6ED"; +} +.mdi-mailbox-open::before { + content: "\FD64"; +} +.mdi-mailbox-open-outline::before { + content: "\FD65"; +} +.mdi-mailbox-open-up::before { + content: "\FD66"; +} +.mdi-mailbox-open-up-outline::before { + content: "\FD67"; +} +.mdi-mailbox-outline::before { + content: "\FD68"; +} +.mdi-mailbox-up::before { + content: "\FD69"; +} +.mdi-mailbox-up-outline::before { + content: "\FD6A"; +} +.mdi-map::before { + content: "\F34D"; +} +.mdi-map-check::before { + content: "\FED9"; +} +.mdi-map-check-outline::before { + content: "\FEDA"; +} +.mdi-map-clock::before { + content: "\FCFA"; +} +.mdi-map-clock-outline::before { + content: "\FCFB"; +} +.mdi-map-legend::before { + content: "\FA00"; +} +.mdi-map-marker::before { + content: "\F34E"; +} +.mdi-map-marker-alert::before { + content: "\FF22"; +} +.mdi-map-marker-alert-outline::before { + content: "\FF23"; +} +.mdi-map-marker-check::before { + content: "\FC71"; +} +.mdi-map-marker-circle::before { + content: "\F34F"; +} +.mdi-map-marker-distance::before { + content: "\F8EF"; +} +.mdi-map-marker-minus::before { + content: "\F650"; +} +.mdi-map-marker-multiple::before { + content: "\F350"; +} +.mdi-map-marker-off::before { + content: "\F351"; +} +.mdi-map-marker-outline::before { + content: "\F7D8"; +} +.mdi-map-marker-path::before { + content: "\FCFC"; +} +.mdi-map-marker-plus::before { + content: "\F651"; +} +.mdi-map-marker-question::before { + content: "\FF24"; +} +.mdi-map-marker-question-outline::before { + content: "\FF25"; +} +.mdi-map-marker-radius::before { + content: "\F352"; +} +.mdi-map-marker-remove::before { + content: "\FF26"; +} +.mdi-map-marker-remove-variant::before { + content: "\FF27"; +} +.mdi-map-minus::before { + content: "\F980"; +} +.mdi-map-outline::before { + content: "\F981"; +} +.mdi-map-plus::before { + content: "\F982"; +} +.mdi-map-search::before { + content: "\F983"; +} +.mdi-map-search-outline::before { + content: "\F984"; +} +.mdi-mapbox::before { + content: "\FB86"; +} +.mdi-margin::before { + content: "\F353"; +} +.mdi-markdown::before { + content: "\F354"; +} +.mdi-markdown-outline::before { + content: "\FF78"; +} +.mdi-marker::before { + content: "\F652"; +} +.mdi-marker-cancel::before { + content: "\FDB5"; +} +.mdi-marker-check::before { + content: "\F355"; +} +.mdi-mastodon::before { + content: "\FAD0"; +} +.mdi-mastodon-variant::before { + content: "\FAD1"; +} +.mdi-material-design::before { + content: "\F985"; +} +.mdi-material-ui::before { + content: "\F357"; +} +.mdi-math-compass::before { + content: "\F358"; +} +.mdi-math-cos::before { + content: "\FC72"; +} +.mdi-math-sin::before { + content: "\FC73"; +} +.mdi-math-tan::before { + content: "\FC74"; +} +.mdi-matrix::before { + content: "\F628"; +} +.mdi-maxcdn::before { + content: "\F359"; +} +.mdi-medal::before { + content: "\F986"; +} +.mdi-medical-bag::before { + content: "\F6EE"; +} +.mdi-medium::before { + content: "\F35A"; +} +.mdi-meetup::before { + content: "\FAD2"; +} +.mdi-memory::before { + content: "\F35B"; +} +.mdi-menu::before { + content: "\F35C"; +} +.mdi-menu-down::before { + content: "\F35D"; +} +.mdi-menu-down-outline::before { + content: "\F6B5"; +} +.mdi-menu-left::before { + content: "\F35E"; +} +.mdi-menu-left-outline::before { + content: "\FA01"; +} +.mdi-menu-open::before { + content: "\FB87"; +} +.mdi-menu-right::before { + content: "\F35F"; +} +.mdi-menu-right-outline::before { + content: "\FA02"; +} +.mdi-menu-swap::before { + content: "\FA63"; +} +.mdi-menu-swap-outline::before { + content: "\FA64"; +} +.mdi-menu-up::before { + content: "\F360"; +} +.mdi-menu-up-outline::before { + content: "\F6B6"; +} +.mdi-merge::before { + content: "\FF79"; +} +.mdi-message::before { + content: "\F361"; +} +.mdi-message-alert::before { + content: "\F362"; +} +.mdi-message-alert-outline::before { + content: "\FA03"; +} +.mdi-message-bulleted::before { + content: "\F6A1"; +} +.mdi-message-bulleted-off::before { + content: "\F6A2"; +} +.mdi-message-draw::before { + content: "\F363"; +} +.mdi-message-image::before { + content: "\F364"; +} +.mdi-message-outline::before { + content: "\F365"; +} +.mdi-message-plus::before { + content: "\F653"; +} +.mdi-message-processing::before { + content: "\F366"; +} +.mdi-message-reply::before { + content: "\F367"; +} +.mdi-message-reply-text::before { + content: "\F368"; +} +.mdi-message-settings::before { + content: "\F6EF"; +} +.mdi-message-settings-variant::before { + content: "\F6F0"; +} +.mdi-message-text::before { + content: "\F369"; +} +.mdi-message-text-outline::before { + content: "\F36A"; +} +.mdi-message-video::before { + content: "\F36B"; +} +.mdi-meteor::before { + content: "\F629"; +} +.mdi-metronome::before { + content: "\F7D9"; +} +.mdi-metronome-tick::before { + content: "\F7DA"; +} +.mdi-micro-sd::before { + content: "\F7DB"; +} +.mdi-microphone::before { + content: "\F36C"; +} +.mdi-microphone-minus::before { + content: "\F8B2"; +} +.mdi-microphone-off::before { + content: "\F36D"; +} +.mdi-microphone-outline::before { + content: "\F36E"; +} +.mdi-microphone-plus::before { + content: "\F8B3"; +} +.mdi-microphone-settings::before { + content: "\F36F"; +} +.mdi-microphone-variant::before { + content: "\F370"; +} +.mdi-microphone-variant-off::before { + content: "\F371"; +} +.mdi-microscope::before { + content: "\F654"; +} +.mdi-microsoft::before { + content: "\F372"; +} +.mdi-microsoft-dynamics::before { + content: "\F987"; +} +.mdi-microwave::before { + content: "\FC75"; +} +.mdi-middleware::before { + content: "\FF7A"; +} +.mdi-middleware-outline::before { + content: "\FF7B"; +} +.mdi-midi::before { + content: "\F8F0"; +} +.mdi-midi-port::before { + content: "\F8F1"; +} +.mdi-mine::before { + content: "\FDB6"; +} +.mdi-minecraft::before { + content: "\F373"; +} +.mdi-mini-sd::before { + content: "\FA04"; +} +.mdi-minidisc::before { + content: "\FA05"; +} +.mdi-minus::before { + content: "\F374"; +} +.mdi-minus-box::before { + content: "\F375"; +} +.mdi-minus-box-outline::before { + content: "\F6F1"; +} +.mdi-minus-circle::before { + content: "\F376"; +} +.mdi-minus-circle-outline::before { + content: "\F377"; +} +.mdi-minus-network::before { + content: "\F378"; +} +.mdi-minus-network-outline::before { + content: "\FC76"; +} +.mdi-mixcloud::before { + content: "\F62A"; +} +.mdi-mixed-martial-arts::before { + content: "\FD6B"; +} +.mdi-mixed-reality::before { + content: "\F87E"; +} +.mdi-mixer::before { + content: "\F7DC"; +} +.mdi-molecule::before { + content: "\FB88"; +} +.mdi-monitor::before { + content: "\F379"; +} +.mdi-monitor-cellphone::before { + content: "\F988"; +} +.mdi-monitor-cellphone-star::before { + content: "\F989"; +} +.mdi-monitor-dashboard::before { + content: "\FA06"; +} +.mdi-monitor-lock::before { + content: "\FDB7"; +} +.mdi-monitor-multiple::before { + content: "\F37A"; +} +.mdi-monitor-off::before { + content: "\FD6C"; +} +.mdi-monitor-screenshot::before { + content: "\FE34"; +} +.mdi-monitor-speaker::before { + content: "\FF7C"; +} +.mdi-monitor-speaker-off::before { + content: "\FF7D"; +} +.mdi-monitor-star::before { + content: "\FDB8"; +} +.mdi-moon-first-quarter::before { + content: "\FF7E"; +} +.mdi-moon-full::before { + content: "\FF7F"; +} +.mdi-moon-last-quarter::before { + content: "\FF80"; +} +.mdi-moon-new::before { + content: "\FF81"; +} +.mdi-moon-waning-crescent::before { + content: "\FF82"; +} +.mdi-moon-waning-gibbous::before { + content: "\FF83"; +} +.mdi-moon-waxing-crescent::before { + content: "\FF84"; +} +.mdi-moon-waxing-gibbous::before { + content: "\FF85"; +} +.mdi-more::before { + content: "\F37B"; +} +.mdi-mother-nurse::before { + content: "\FCFD"; +} +.mdi-motion-sensor::before { + content: "\FD6D"; +} +.mdi-motorbike::before { + content: "\F37C"; +} +.mdi-mouse::before { + content: "\F37D"; +} +.mdi-mouse-bluetooth::before { + content: "\F98A"; +} +.mdi-mouse-off::before { + content: "\F37E"; +} +.mdi-mouse-variant::before { + content: "\F37F"; +} +.mdi-mouse-variant-off::before { + content: "\F380"; +} +.mdi-move-resize::before { + content: "\F655"; +} +.mdi-move-resize-variant::before { + content: "\F656"; +} +.mdi-movie::before { + content: "\F381"; +} +.mdi-movie-outline::before { + content: "\FDB9"; +} +.mdi-movie-roll::before { + content: "\F7DD"; +} +.mdi-muffin::before { + content: "\F98B"; +} +.mdi-multiplication::before { + content: "\F382"; +} +.mdi-multiplication-box::before { + content: "\F383"; +} +.mdi-mushroom::before { + content: "\F7DE"; +} +.mdi-mushroom-outline::before { + content: "\F7DF"; +} +.mdi-music::before { + content: "\F759"; +} +.mdi-music-accidental-double-flat::before { + content: "\FF86"; +} +.mdi-music-accidental-double-sharp::before { + content: "\FF87"; +} +.mdi-music-accidental-flat::before { + content: "\FF88"; +} +.mdi-music-accidental-natural::before { + content: "\FF89"; +} +.mdi-music-accidental-sharp::before { + content: "\FF8A"; +} +.mdi-music-box::before { + content: "\F384"; +} +.mdi-music-box-outline::before { + content: "\F385"; +} +.mdi-music-circle::before { + content: "\F386"; +} +.mdi-music-circle-outline::before { + content: "\FAD3"; +} +.mdi-music-clef-alto::before { + content: "\FF8B"; +} +.mdi-music-clef-bass::before { + content: "\FF8C"; +} +.mdi-music-clef-treble::before { + content: "\FF8D"; +} +.mdi-music-note::before { + content: "\F387"; +} +.mdi-music-note-bluetooth::before { + content: "\F5FE"; +} +.mdi-music-note-bluetooth-off::before { + content: "\F5FF"; +} +.mdi-music-note-eighth::before { + content: "\F388"; +} +.mdi-music-note-eighth-dotted::before { + content: "\FF8E"; +} +.mdi-music-note-half::before { + content: "\F389"; +} +.mdi-music-note-half-dotted::before { + content: "\FF8F"; +} +.mdi-music-note-off::before { + content: "\F38A"; +} +.mdi-music-note-off-outline::before { + content: "\FF90"; +} +.mdi-music-note-outline::before { + content: "\FF91"; +} +.mdi-music-note-plus::before { + content: "\FDBA"; +} +.mdi-music-note-quarter::before { + content: "\F38B"; +} +.mdi-music-note-quarter-dotted::before { + content: "\FF92"; +} +.mdi-music-note-sixteenth::before { + content: "\F38C"; +} +.mdi-music-note-sixteenth-dotted::before { + content: "\FF93"; +} +.mdi-music-note-whole::before { + content: "\F38D"; +} +.mdi-music-note-whole-dotted::before { + content: "\FF94"; +} +.mdi-music-off::before { + content: "\F75A"; +} +.mdi-music-rest-eighth::before { + content: "\FF95"; +} +.mdi-music-rest-half::before { + content: "\FF96"; +} +.mdi-music-rest-quarter::before { + content: "\FF97"; +} +.mdi-music-rest-sixteenth::before { + content: "\FF98"; +} +.mdi-music-rest-whole::before { + content: "\FF99"; +} +.mdi-nail::before { + content: "\FDBB"; +} +.mdi-nas::before { + content: "\F8F2"; +} +.mdi-nativescript::before { + content: "\F87F"; +} +.mdi-nature::before { + content: "\F38E"; +} +.mdi-nature-people::before { + content: "\F38F"; +} +.mdi-navigation::before { + content: "\F390"; +} +.mdi-near-me::before { + content: "\F5CD"; +} +.mdi-necklace::before { + content: "\FF28"; +} +.mdi-needle::before { + content: "\F391"; +} +.mdi-netflix::before { + content: "\F745"; +} +.mdi-network::before { + content: "\F6F2"; +} +.mdi-network-off::before { + content: "\FC77"; +} +.mdi-network-off-outline::before { + content: "\FC78"; +} +.mdi-network-outline::before { + content: "\FC79"; +} +.mdi-network-strength-1::before { + content: "\F8F3"; +} +.mdi-network-strength-1-alert::before { + content: "\F8F4"; +} +.mdi-network-strength-2::before { + content: "\F8F5"; +} +.mdi-network-strength-2-alert::before { + content: "\F8F6"; +} +.mdi-network-strength-3::before { + content: "\F8F7"; +} +.mdi-network-strength-3-alert::before { + content: "\F8F8"; +} +.mdi-network-strength-4::before { + content: "\F8F9"; +} +.mdi-network-strength-4-alert::before { + content: "\F8FA"; +} +.mdi-network-strength-off::before { + content: "\F8FB"; +} +.mdi-network-strength-off-outline::before { + content: "\F8FC"; +} +.mdi-network-strength-outline::before { + content: "\F8FD"; +} +.mdi-new-box::before { + content: "\F394"; +} +.mdi-newspaper::before { + content: "\F395"; +} +.mdi-newspaper-minus::before { + content: "\FF29"; +} +.mdi-newspaper-plus::before { + content: "\FF2A"; +} +.mdi-nfc::before { + content: "\F396"; +} +.mdi-nfc-off::before { + content: "\FE35"; +} +.mdi-nfc-search-variant::before { + content: "\FE36"; +} +.mdi-nfc-tap::before { + content: "\F397"; +} +.mdi-nfc-variant::before { + content: "\F398"; +} +.mdi-nfc-variant-off::before { + content: "\FE37"; +} +.mdi-ninja::before { + content: "\F773"; +} +.mdi-nintendo-switch::before { + content: "\F7E0"; +} +.mdi-nodejs::before { + content: "\F399"; +} +.mdi-not-equal::before { + content: "\F98C"; +} +.mdi-not-equal-variant::before { + content: "\F98D"; +} +.mdi-note::before { + content: "\F39A"; +} +.mdi-note-circle::before { + content: "\FEDB"; +} +.mdi-note-multiple::before { + content: "\F6B7"; +} +.mdi-note-multiple-outline::before { + content: "\F6B8"; +} +.mdi-note-outline::before { + content: "\F39B"; +} +.mdi-note-plus::before { + content: "\F39C"; +} +.mdi-note-plus-outline::before { + content: "\F39D"; +} +.mdi-note-text::before { + content: "\F39E"; +} +.mdi-notebook::before { + content: "\F82D"; +} +.mdi-notebook-multiple::before { + content: "\FE38"; +} +.mdi-notebook-outline::before { + content: "\FEDC"; +} +.mdi-notification-clear-all::before { + content: "\F39F"; +} +.mdi-npm::before { + content: "\F6F6"; +} +.mdi-npm-variant::before { + content: "\F98E"; +} +.mdi-npm-variant-outline::before { + content: "\F98F"; +} +.mdi-nuke::before { + content: "\F6A3"; +} +.mdi-null::before { + content: "\F7E1"; +} +.mdi-numeric::before { + content: "\F3A0"; +} +.mdi-numeric-0::before { + content: "\30"; +} +.mdi-numeric-0-box::before { + content: "\F3A1"; +} +.mdi-numeric-0-box-multiple::before { + content: "\FF2B"; +} +.mdi-numeric-0-box-multiple-outline::before { + content: "\F3A2"; +} +.mdi-numeric-0-box-outline::before { + content: "\F3A3"; +} +.mdi-numeric-0-circle::before { + content: "\FC7A"; +} +.mdi-numeric-0-circle-outline::before { + content: "\FC7B"; +} +.mdi-numeric-1::before { + content: "\31"; +} +.mdi-numeric-1-box::before { + content: "\F3A4"; +} +.mdi-numeric-1-box-multiple::before { + content: "\FF2C"; +} +.mdi-numeric-1-box-multiple-outline::before { + content: "\F3A5"; +} +.mdi-numeric-1-box-outline::before { + content: "\F3A6"; +} +.mdi-numeric-1-circle::before { + content: "\FC7C"; +} +.mdi-numeric-1-circle-outline::before { + content: "\FC7D"; +} +.mdi-numeric-10-box::before { + content: "\FF9A"; +} +.mdi-numeric-10-box-outline::before { + content: "\FF9B"; +} +.mdi-numeric-2::before { + content: "\32"; +} +.mdi-numeric-2-box::before { + content: "\F3A7"; +} +.mdi-numeric-2-box-multiple::before { + content: "\FF2D"; +} +.mdi-numeric-2-box-multiple-outline::before { + content: "\F3A8"; +} +.mdi-numeric-2-box-outline::before { + content: "\F3A9"; +} +.mdi-numeric-2-circle::before { + content: "\FC7E"; +} +.mdi-numeric-2-circle-outline::before { + content: "\FC7F"; +} +.mdi-numeric-3::before { + content: "\33"; +} +.mdi-numeric-3-box::before { + content: "\F3AA"; +} +.mdi-numeric-3-box-multiple::before { + content: "\FF2E"; +} +.mdi-numeric-3-box-multiple-outline::before { + content: "\F3AB"; +} +.mdi-numeric-3-box-outline::before { + content: "\F3AC"; +} +.mdi-numeric-3-circle::before { + content: "\FC80"; +} +.mdi-numeric-3-circle-outline::before { + content: "\FC81"; +} +.mdi-numeric-4::before { + content: "\34"; +} +.mdi-numeric-4-box::before { + content: "\F3AD"; +} +.mdi-numeric-4-box-multiple::before { + content: "\FF2F"; +} +.mdi-numeric-4-box-multiple-outline::before { + content: "\F3AE"; +} +.mdi-numeric-4-box-outline::before { + content: "\F3AF"; +} +.mdi-numeric-4-circle::before { + content: "\FC82"; +} +.mdi-numeric-4-circle-outline::before { + content: "\FC83"; +} +.mdi-numeric-5::before { + content: "\35"; +} +.mdi-numeric-5-box::before { + content: "\F3B0"; +} +.mdi-numeric-5-box-multiple::before { + content: "\FF30"; +} +.mdi-numeric-5-box-multiple-outline::before { + content: "\F3B1"; +} +.mdi-numeric-5-box-outline::before { + content: "\F3B2"; +} +.mdi-numeric-5-circle::before { + content: "\FC84"; +} +.mdi-numeric-5-circle-outline::before { + content: "\FC85"; +} +.mdi-numeric-6::before { + content: "\36"; +} +.mdi-numeric-6-box::before { + content: "\F3B3"; +} +.mdi-numeric-6-box-multiple::before { + content: "\FF31"; +} +.mdi-numeric-6-box-multiple-outline::before { + content: "\F3B4"; +} +.mdi-numeric-6-box-outline::before { + content: "\F3B5"; +} +.mdi-numeric-6-circle::before { + content: "\FC86"; +} +.mdi-numeric-6-circle-outline::before { + content: "\FC87"; +} +.mdi-numeric-7::before { + content: "\37"; +} +.mdi-numeric-7-box::before { + content: "\F3B6"; +} +.mdi-numeric-7-box-multiple::before { + content: "\FF32"; +} +.mdi-numeric-7-box-multiple-outline::before { + content: "\F3B7"; +} +.mdi-numeric-7-box-outline::before { + content: "\F3B8"; +} +.mdi-numeric-7-circle::before { + content: "\FC88"; +} +.mdi-numeric-7-circle-outline::before { + content: "\FC89"; +} +.mdi-numeric-8::before { + content: "\38"; +} +.mdi-numeric-8-box::before { + content: "\F3B9"; +} +.mdi-numeric-8-box-multiple::before { + content: "\FF33"; +} +.mdi-numeric-8-box-multiple-outline::before { + content: "\F3BA"; +} +.mdi-numeric-8-box-outline::before { + content: "\F3BB"; +} +.mdi-numeric-8-circle::before { + content: "\FC8A"; +} +.mdi-numeric-8-circle-outline::before { + content: "\FC8B"; +} +.mdi-numeric-9::before { + content: "\39"; +} +.mdi-numeric-9-box::before { + content: "\F3BC"; +} +.mdi-numeric-9-box-multiple::before { + content: "\FF34"; +} +.mdi-numeric-9-box-multiple-outline::before { + content: "\F3BD"; +} +.mdi-numeric-9-box-outline::before { + content: "\F3BE"; +} +.mdi-numeric-9-circle::before { + content: "\FC8C"; +} +.mdi-numeric-9-circle-outline::before { + content: "\FC8D"; +} +.mdi-numeric-9-plus-box::before { + content: "\F3BF"; +} +.mdi-numeric-9-plus-box-multiple::before { + content: "\FF35"; +} +.mdi-numeric-9-plus-box-multiple-outline::before { + content: "\F3C0"; +} +.mdi-numeric-9-plus-box-outline::before { + content: "\F3C1"; +} +.mdi-numeric-9-plus-circle::before { + content: "\FC8E"; +} +.mdi-numeric-9-plus-circle-outline::before { + content: "\FC8F"; +} +.mdi-nut::before { + content: "\F6F7"; +} +.mdi-nutrition::before { + content: "\F3C2"; +} +.mdi-oar::before { + content: "\F67B"; +} +.mdi-ocarina::before { + content: "\FDBC"; +} +.mdi-octagon::before { + content: "\F3C3"; +} +.mdi-octagon-outline::before { + content: "\F3C4"; +} +.mdi-octagram::before { + content: "\F6F8"; +} +.mdi-octagram-outline::before { + content: "\F774"; +} +.mdi-odnoklassniki::before { + content: "\F3C5"; +} +.mdi-office::before { + content: "\F3C6"; +} +.mdi-office-building::before { + content: "\F990"; +} +.mdi-oil::before { + content: "\F3C7"; +} +.mdi-oil-lamp::before { + content: "\FF36"; +} +.mdi-oil-temperature::before { + content: "\F3C8"; +} +.mdi-omega::before { + content: "\F3C9"; +} +.mdi-one-up::before { + content: "\FB89"; +} +.mdi-onedrive::before { + content: "\F3CA"; +} +.mdi-onenote::before { + content: "\F746"; +} +.mdi-onepassword::before { + content: "\F880"; +} +.mdi-opacity::before { + content: "\F5CC"; +} +.mdi-open-in-app::before { + content: "\F3CB"; +} +.mdi-open-in-new::before { + content: "\F3CC"; +} +.mdi-open-source-initiative::before { + content: "\FB8A"; +} +.mdi-openid::before { + content: "\F3CD"; +} +.mdi-opera::before { + content: "\F3CE"; +} +.mdi-orbit::before { + content: "\F018"; +} +.mdi-origin::before { + content: "\FB2B"; +} +.mdi-ornament::before { + content: "\F3CF"; +} +.mdi-ornament-variant::before { + content: "\F3D0"; +} +.mdi-outlook::before { + content: "\FCFE"; +} +.mdi-owl::before { + content: "\F3D2"; +} +.mdi-pac-man::before { + content: "\FB8B"; +} +.mdi-package::before { + content: "\F3D3"; +} +.mdi-package-down::before { + content: "\F3D4"; +} +.mdi-package-up::before { + content: "\F3D5"; +} +.mdi-package-variant::before { + content: "\F3D6"; +} +.mdi-package-variant-closed::before { + content: "\F3D7"; +} +.mdi-page-first::before { + content: "\F600"; +} +.mdi-page-last::before { + content: "\F601"; +} +.mdi-page-layout-body::before { + content: "\F6F9"; +} +.mdi-page-layout-footer::before { + content: "\F6FA"; +} +.mdi-page-layout-header::before { + content: "\F6FB"; +} +.mdi-page-layout-header-footer::before { + content: "\FF9C"; +} +.mdi-page-layout-sidebar-left::before { + content: "\F6FC"; +} +.mdi-page-layout-sidebar-right::before { + content: "\F6FD"; +} +.mdi-page-next::before { + content: "\FB8C"; +} +.mdi-page-next-outline::before { + content: "\FB8D"; +} +.mdi-page-previous::before { + content: "\FB8E"; +} +.mdi-page-previous-outline::before { + content: "\FB8F"; +} +.mdi-palette::before { + content: "\F3D8"; +} +.mdi-palette-advanced::before { + content: "\F3D9"; +} +.mdi-palette-outline::before { + content: "\FE6C"; +} +.mdi-palette-swatch::before { + content: "\F8B4"; +} +.mdi-pan::before { + content: "\FB90"; +} +.mdi-pan-bottom-left::before { + content: "\FB91"; +} +.mdi-pan-bottom-right::before { + content: "\FB92"; +} +.mdi-pan-down::before { + content: "\FB93"; +} +.mdi-pan-horizontal::before { + content: "\FB94"; +} +.mdi-pan-left::before { + content: "\FB95"; +} +.mdi-pan-right::before { + content: "\FB96"; +} +.mdi-pan-top-left::before { + content: "\FB97"; +} +.mdi-pan-top-right::before { + content: "\FB98"; +} +.mdi-pan-up::before { + content: "\FB99"; +} +.mdi-pan-vertical::before { + content: "\FB9A"; +} +.mdi-panda::before { + content: "\F3DA"; +} +.mdi-pandora::before { + content: "\F3DB"; +} +.mdi-panorama::before { + content: "\F3DC"; +} +.mdi-panorama-fisheye::before { + content: "\F3DD"; +} +.mdi-panorama-horizontal::before { + content: "\F3DE"; +} +.mdi-panorama-vertical::before { + content: "\F3DF"; +} +.mdi-panorama-wide-angle::before { + content: "\F3E0"; +} +.mdi-paper-cut-vertical::before { + content: "\F3E1"; +} +.mdi-paperclip::before { + content: "\F3E2"; +} +.mdi-parachute::before { + content: "\FC90"; +} +.mdi-parachute-outline::before { + content: "\FC91"; +} +.mdi-parking::before { + content: "\F3E3"; +} +.mdi-passport::before { + content: "\F7E2"; +} +.mdi-passport-biometric::before { + content: "\FDBD"; +} +.mdi-patio-heater::before { + content: "\FF9D"; +} +.mdi-patreon::before { + content: "\F881"; +} +.mdi-pause::before { + content: "\F3E4"; +} +.mdi-pause-circle::before { + content: "\F3E5"; +} +.mdi-pause-circle-outline::before { + content: "\F3E6"; +} +.mdi-pause-octagon::before { + content: "\F3E7"; +} +.mdi-pause-octagon-outline::before { + content: "\F3E8"; +} +.mdi-paw::before { + content: "\F3E9"; +} +.mdi-paw-off::before { + content: "\F657"; +} +.mdi-paypal::before { + content: "\F882"; +} +.mdi-pdf-box::before { + content: "\FE39"; +} +.mdi-peace::before { + content: "\F883"; +} +.mdi-pen::before { + content: "\F3EA"; +} +.mdi-pen-lock::before { + content: "\FDBE"; +} +.mdi-pen-minus::before { + content: "\FDBF"; +} +.mdi-pen-off::before { + content: "\FDC0"; +} +.mdi-pen-plus::before { + content: "\FDC1"; +} +.mdi-pen-remove::before { + content: "\FDC2"; +} +.mdi-pencil::before { + content: "\F3EB"; +} +.mdi-pencil-box::before { + content: "\F3EC"; +} +.mdi-pencil-box-outline::before { + content: "\F3ED"; +} +.mdi-pencil-circle::before { + content: "\F6FE"; +} +.mdi-pencil-circle-outline::before { + content: "\F775"; +} +.mdi-pencil-lock::before { + content: "\F3EE"; +} +.mdi-pencil-lock-outline::before { + content: "\FDC3"; +} +.mdi-pencil-minus::before { + content: "\FDC4"; +} +.mdi-pencil-minus-outline::before { + content: "\FDC5"; +} +.mdi-pencil-off::before { + content: "\F3EF"; +} +.mdi-pencil-off-outline::before { + content: "\FDC6"; +} +.mdi-pencil-outline::before { + content: "\FC92"; +} +.mdi-pencil-plus::before { + content: "\FDC7"; +} +.mdi-pencil-plus-outline::before { + content: "\FDC8"; +} +.mdi-pencil-remove::before { + content: "\FDC9"; +} +.mdi-pencil-remove-outline::before { + content: "\FDCA"; +} +.mdi-penguin::before { + content: "\FEDD"; +} +.mdi-pentagon::before { + content: "\F6FF"; +} +.mdi-pentagon-outline::before { + content: "\F700"; +} +.mdi-percent::before { + content: "\F3F0"; +} +.mdi-periodic-table::before { + content: "\F8B5"; +} +.mdi-periodic-table-co2::before { + content: "\F7E3"; +} +.mdi-periscope::before { + content: "\F747"; +} +.mdi-perspective-less::before { + content: "\FCFF"; +} +.mdi-perspective-more::before { + content: "\FD00"; +} +.mdi-pharmacy::before { + content: "\F3F1"; +} +.mdi-phone::before { + content: "\F3F2"; +} +.mdi-phone-alert::before { + content: "\FF37"; +} +.mdi-phone-bluetooth::before { + content: "\F3F3"; +} +.mdi-phone-classic::before { + content: "\F602"; +} +.mdi-phone-forward::before { + content: "\F3F4"; +} +.mdi-phone-hangup::before { + content: "\F3F5"; +} +.mdi-phone-in-talk::before { + content: "\F3F6"; +} +.mdi-phone-incoming::before { + content: "\F3F7"; +} +.mdi-phone-lock::before { + content: "\F3F8"; +} +.mdi-phone-log::before { + content: "\F3F9"; +} +.mdi-phone-minus::before { + content: "\F658"; +} +.mdi-phone-missed::before { + content: "\F3FA"; +} +.mdi-phone-off::before { + content: "\FDCB"; +} +.mdi-phone-outgoing::before { + content: "\F3FB"; +} +.mdi-phone-outline::before { + content: "\FDCC"; +} +.mdi-phone-paused::before { + content: "\F3FC"; +} +.mdi-phone-plus::before { + content: "\F659"; +} +.mdi-phone-return::before { + content: "\F82E"; +} +.mdi-phone-rotate-landscape::before { + content: "\F884"; +} +.mdi-phone-rotate-portrait::before { + content: "\F885"; +} +.mdi-phone-settings::before { + content: "\F3FD"; +} +.mdi-phone-voip::before { + content: "\F3FE"; +} +.mdi-pi::before { + content: "\F3FF"; +} +.mdi-pi-box::before { + content: "\F400"; +} +.mdi-pi-hole::before { + content: "\FDCD"; +} +.mdi-piano::before { + content: "\F67C"; +} +.mdi-pickaxe::before { + content: "\F8B6"; +} +.mdi-picture-in-picture-bottom-right::before { + content: "\FE3A"; +} +.mdi-picture-in-picture-bottom-right-outline::before { + content: "\FE3B"; +} +.mdi-picture-in-picture-top-right::before { + content: "\FE3C"; +} +.mdi-picture-in-picture-top-right-outline::before { + content: "\FE3D"; +} +.mdi-pier::before { + content: "\F886"; +} +.mdi-pier-crane::before { + content: "\F887"; +} +.mdi-pig::before { + content: "\F401"; +} +.mdi-pill::before { + content: "\F402"; +} +.mdi-pillar::before { + content: "\F701"; +} +.mdi-pin::before { + content: "\F403"; +} +.mdi-pin-off::before { + content: "\F404"; +} +.mdi-pin-off-outline::before { + content: "\F92F"; +} +.mdi-pin-outline::before { + content: "\F930"; +} +.mdi-pine-tree::before { + content: "\F405"; +} +.mdi-pine-tree-box::before { + content: "\F406"; +} +.mdi-pinterest::before { + content: "\F407"; +} +.mdi-pinterest-box::before { + content: "\F408"; +} +.mdi-pinwheel::before { + content: "\FAD4"; +} +.mdi-pinwheel-outline::before { + content: "\FAD5"; +} +.mdi-pipe::before { + content: "\F7E4"; +} +.mdi-pipe-disconnected::before { + content: "\F7E5"; +} +.mdi-pipe-leak::before { + content: "\F888"; +} +.mdi-pirate::before { + content: "\FA07"; +} +.mdi-pistol::before { + content: "\F702"; +} +.mdi-piston::before { + content: "\F889"; +} +.mdi-pizza::before { + content: "\F409"; +} +.mdi-play::before { + content: "\F40A"; +} +.mdi-play-box-outline::before { + content: "\F40B"; +} +.mdi-play-circle::before { + content: "\F40C"; +} +.mdi-play-circle-outline::before { + content: "\F40D"; +} +.mdi-play-network::before { + content: "\F88A"; +} +.mdi-play-network-outline::before { + content: "\FC93"; +} +.mdi-play-outline::before { + content: "\FF38"; +} +.mdi-play-pause::before { + content: "\F40E"; +} +.mdi-play-protected-content::before { + content: "\F40F"; +} +.mdi-play-speed::before { + content: "\F8FE"; +} +.mdi-playlist-check::before { + content: "\F5C7"; +} +.mdi-playlist-edit::before { + content: "\F8FF"; +} +.mdi-playlist-minus::before { + content: "\F410"; +} +.mdi-playlist-music::before { + content: "\FC94"; +} +.mdi-playlist-music-outline::before { + content: "\FC95"; +} +.mdi-playlist-play::before { + content: "\F411"; +} +.mdi-playlist-plus::before { + content: "\F412"; +} +.mdi-playlist-remove::before { + content: "\F413"; +} +.mdi-playlist-star::before { + content: "\FDCE"; +} +.mdi-playstation::before { + content: "\F414"; +} +.mdi-plex::before { + content: "\F6B9"; +} +.mdi-plus::before { + content: "\F415"; +} +.mdi-plus-box::before { + content: "\F416"; +} +.mdi-plus-box-outline::before { + content: "\F703"; +} +.mdi-plus-circle::before { + content: "\F417"; +} +.mdi-plus-circle-multiple-outline::before { + content: "\F418"; +} +.mdi-plus-circle-outline::before { + content: "\F419"; +} +.mdi-plus-minus::before { + content: "\F991"; +} +.mdi-plus-minus-box::before { + content: "\F992"; +} +.mdi-plus-network::before { + content: "\F41A"; +} +.mdi-plus-network-outline::before { + content: "\FC96"; +} +.mdi-plus-one::before { + content: "\F41B"; +} +.mdi-plus-outline::before { + content: "\F704"; +} +.mdi-pocket::before { + content: "\F41C"; +} +.mdi-podcast::before { + content: "\F993"; +} +.mdi-podium::before { + content: "\FD01"; +} +.mdi-podium-bronze::before { + content: "\FD02"; +} +.mdi-podium-gold::before { + content: "\FD03"; +} +.mdi-podium-silver::before { + content: "\FD04"; +} +.mdi-point-of-sale::before { + content: "\FD6E"; +} +.mdi-pokeball::before { + content: "\F41D"; +} +.mdi-pokemon-go::before { + content: "\FA08"; +} +.mdi-poker-chip::before { + content: "\F82F"; +} +.mdi-polaroid::before { + content: "\F41E"; +} +.mdi-poll::before { + content: "\F41F"; +} +.mdi-poll-box::before { + content: "\F420"; +} +.mdi-polymer::before { + content: "\F421"; +} +.mdi-pool::before { + content: "\F606"; +} +.mdi-popcorn::before { + content: "\F422"; +} +.mdi-postage-stamp::before { + content: "\FC97"; +} +.mdi-pot::before { + content: "\F65A"; +} +.mdi-pot-mix::before { + content: "\F65B"; +} +.mdi-pound::before { + content: "\F423"; +} +.mdi-pound-box::before { + content: "\F424"; +} +.mdi-power::before { + content: "\F425"; +} +.mdi-power-cycle::before { + content: "\F900"; +} +.mdi-power-off::before { + content: "\F901"; +} +.mdi-power-on::before { + content: "\F902"; +} +.mdi-power-plug::before { + content: "\F6A4"; +} +.mdi-power-plug-off::before { + content: "\F6A5"; +} +.mdi-power-settings::before { + content: "\F426"; +} +.mdi-power-sleep::before { + content: "\F903"; +} +.mdi-power-socket::before { + content: "\F427"; +} +.mdi-power-socket-au::before { + content: "\F904"; +} +.mdi-power-socket-eu::before { + content: "\F7E6"; +} +.mdi-power-socket-uk::before { + content: "\F7E7"; +} +.mdi-power-socket-us::before { + content: "\F7E8"; +} +.mdi-power-standby::before { + content: "\F905"; +} +.mdi-powershell::before { + content: "\FA09"; +} +.mdi-prescription::before { + content: "\F705"; +} +.mdi-presentation::before { + content: "\F428"; +} +.mdi-presentation-play::before { + content: "\F429"; +} +.mdi-printer::before { + content: "\F42A"; +} +.mdi-printer-3d::before { + content: "\F42B"; +} +.mdi-printer-3d-nozzle::before { + content: "\FE3E"; +} +.mdi-printer-3d-nozzle-outline::before { + content: "\FE3F"; +} +.mdi-printer-alert::before { + content: "\F42C"; +} +.mdi-printer-off::before { + content: "\FE40"; +} +.mdi-printer-settings::before { + content: "\F706"; +} +.mdi-printer-wireless::before { + content: "\FA0A"; +} +.mdi-priority-high::before { + content: "\F603"; +} +.mdi-priority-low::before { + content: "\F604"; +} +.mdi-professional-hexagon::before { + content: "\F42D"; +} +.mdi-progress-alert::before { + content: "\FC98"; +} +.mdi-progress-check::before { + content: "\F994"; +} +.mdi-progress-clock::before { + content: "\F995"; +} +.mdi-progress-download::before { + content: "\F996"; +} +.mdi-progress-upload::before { + content: "\F997"; +} +.mdi-progress-wrench::before { + content: "\FC99"; +} +.mdi-projector::before { + content: "\F42E"; +} +.mdi-projector-screen::before { + content: "\F42F"; +} +.mdi-publish::before { + content: "\F6A6"; +} +.mdi-pulse::before { + content: "\F430"; +} +.mdi-pumpkin::before { + content: "\FB9B"; +} +.mdi-purse::before { + content: "\FF39"; +} +.mdi-purse-outline::before { + content: "\FF3A"; +} +.mdi-puzzle::before { + content: "\F431"; +} +.mdi-puzzle-outline::before { + content: "\FA65"; +} +.mdi-qi::before { + content: "\F998"; +} +.mdi-qqchat::before { + content: "\F605"; +} +.mdi-qrcode::before { + content: "\F432"; +} +.mdi-qrcode-edit::before { + content: "\F8B7"; +} +.mdi-qrcode-scan::before { + content: "\F433"; +} +.mdi-quadcopter::before { + content: "\F434"; +} +.mdi-quality-high::before { + content: "\F435"; +} +.mdi-quality-low::before { + content: "\FA0B"; +} +.mdi-quality-medium::before { + content: "\FA0C"; +} +.mdi-quicktime::before { + content: "\F436"; +} +.mdi-quora::before { + content: "\FD05"; +} +.mdi-rabbit::before { + content: "\F906"; +} +.mdi-racing-helmet::before { + content: "\FD6F"; +} +.mdi-racquetball::before { + content: "\FD70"; +} +.mdi-radar::before { + content: "\F437"; +} +.mdi-radiator::before { + content: "\F438"; +} +.mdi-radiator-disabled::before { + content: "\FAD6"; +} +.mdi-radiator-off::before { + content: "\FAD7"; +} +.mdi-radio::before { + content: "\F439"; +} +.mdi-radio-am::before { + content: "\FC9A"; +} +.mdi-radio-fm::before { + content: "\FC9B"; +} +.mdi-radio-handheld::before { + content: "\F43A"; +} +.mdi-radio-tower::before { + content: "\F43B"; +} +.mdi-radioactive::before { + content: "\F43C"; +} +.mdi-radioactive-off::before { + content: "\FEDE"; +} +.mdi-radiobox-blank::before { + content: "\F43D"; +} +.mdi-radiobox-marked::before { + content: "\F43E"; +} +.mdi-radius::before { + content: "\FC9C"; +} +.mdi-radius-outline::before { + content: "\FC9D"; +} +.mdi-railroad-light::before { + content: "\FF3B"; +} +.mdi-raspberry-pi::before { + content: "\F43F"; +} +.mdi-ray-end::before { + content: "\F440"; +} +.mdi-ray-end-arrow::before { + content: "\F441"; +} +.mdi-ray-start::before { + content: "\F442"; +} +.mdi-ray-start-arrow::before { + content: "\F443"; +} +.mdi-ray-start-end::before { + content: "\F444"; +} +.mdi-ray-vertex::before { + content: "\F445"; +} +.mdi-react::before { + content: "\F707"; +} +.mdi-read::before { + content: "\F447"; +} +.mdi-receipt::before { + content: "\F449"; +} +.mdi-record::before { + content: "\F44A"; +} +.mdi-record-circle::before { + content: "\FEDF"; +} +.mdi-record-circle-outline::before { + content: "\FEE0"; +} +.mdi-record-player::before { + content: "\F999"; +} +.mdi-record-rec::before { + content: "\F44B"; +} +.mdi-rectangle::before { + content: "\FE41"; +} +.mdi-rectangle-outline::before { + content: "\FE42"; +} +.mdi-recycle::before { + content: "\F44C"; +} +.mdi-reddit::before { + content: "\F44D"; +} +.mdi-redo::before { + content: "\F44E"; +} +.mdi-redo-variant::before { + content: "\F44F"; +} +.mdi-reflect-horizontal::before { + content: "\FA0D"; +} +.mdi-reflect-vertical::before { + content: "\FA0E"; +} +.mdi-refresh::before { + content: "\F450"; +} +.mdi-regex::before { + content: "\F451"; +} +.mdi-registered-trademark::before { + content: "\FA66"; +} +.mdi-relative-scale::before { + content: "\F452"; +} +.mdi-reload::before { + content: "\F453"; +} +.mdi-reminder::before { + content: "\F88B"; +} +.mdi-remote::before { + content: "\F454"; +} +.mdi-remote-desktop::before { + content: "\F8B8"; +} +.mdi-remote-off::before { + content: "\FEE1"; +} +.mdi-remote-tv::before { + content: "\FEE2"; +} +.mdi-remote-tv-off::before { + content: "\FEE3"; +} +.mdi-rename-box::before { + content: "\F455"; +} +.mdi-reorder-horizontal::before { + content: "\F687"; +} +.mdi-reorder-vertical::before { + content: "\F688"; +} +.mdi-repeat::before { + content: "\F456"; +} +.mdi-repeat-off::before { + content: "\F457"; +} +.mdi-repeat-once::before { + content: "\F458"; +} +.mdi-replay::before { + content: "\F459"; +} +.mdi-reply::before { + content: "\F45A"; +} +.mdi-reply-all::before { + content: "\F45B"; +} +.mdi-reply-all-outline::before { + content: "\FF3C"; +} +.mdi-reply-outline::before { + content: "\FF3D"; +} +.mdi-reproduction::before { + content: "\F45C"; +} +.mdi-resistor::before { + content: "\FB1F"; +} +.mdi-resistor-nodes::before { + content: "\FB20"; +} +.mdi-resize::before { + content: "\FA67"; +} +.mdi-resize-bottom-right::before { + content: "\F45D"; +} +.mdi-responsive::before { + content: "\F45E"; +} +.mdi-restart::before { + content: "\F708"; +} +.mdi-restart-off::before { + content: "\FD71"; +} +.mdi-restore::before { + content: "\F99A"; +} +.mdi-restore-clock::before { + content: "\F6A7"; +} +.mdi-rewind::before { + content: "\F45F"; +} +.mdi-rewind-10::before { + content: "\FD06"; +} +.mdi-rewind-30::before { + content: "\FD72"; +} +.mdi-rewind-outline::before { + content: "\F709"; +} +.mdi-rhombus::before { + content: "\F70A"; +} +.mdi-rhombus-medium::before { + content: "\FA0F"; +} +.mdi-rhombus-outline::before { + content: "\F70B"; +} +.mdi-rhombus-split::before { + content: "\FA10"; +} +.mdi-ribbon::before { + content: "\F460"; +} +.mdi-rice::before { + content: "\F7E9"; +} +.mdi-ring::before { + content: "\F7EA"; +} +.mdi-rivet::before { + content: "\FE43"; +} +.mdi-road::before { + content: "\F461"; +} +.mdi-road-variant::before { + content: "\F462"; +} +.mdi-robot::before { + content: "\F6A8"; +} +.mdi-robot-industrial::before { + content: "\FB21"; +} +.mdi-robot-vacuum::before { + content: "\F70C"; +} +.mdi-robot-vacuum-variant::before { + content: "\F907"; +} +.mdi-rocket::before { + content: "\F463"; +} +.mdi-roller-skate::before { + content: "\FD07"; +} +.mdi-rollerblade::before { + content: "\FD08"; +} +.mdi-rollupjs::before { + content: "\FB9C"; +} +.mdi-room-service::before { + content: "\F88C"; +} +.mdi-room-service-outline::before { + content: "\FD73"; +} +.mdi-rotate-3d::before { + content: "\FEE4"; +} +.mdi-rotate-3d-variant::before { + content: "\F464"; +} +.mdi-rotate-left::before { + content: "\F465"; +} +.mdi-rotate-left-variant::before { + content: "\F466"; +} +.mdi-rotate-orbit::before { + content: "\FD74"; +} +.mdi-rotate-right::before { + content: "\F467"; +} +.mdi-rotate-right-variant::before { + content: "\F468"; +} +.mdi-rounded-corner::before { + content: "\F607"; +} +.mdi-router-wireless::before { + content: "\F469"; +} +.mdi-router-wireless-settings::before { + content: "\FA68"; +} +.mdi-routes::before { + content: "\F46A"; +} +.mdi-rowing::before { + content: "\F608"; +} +.mdi-rss::before { + content: "\F46B"; +} +.mdi-rss-box::before { + content: "\F46C"; +} +.mdi-rss-off::before { + content: "\FF3E"; +} +.mdi-ruby::before { + content: "\FD09"; +} +.mdi-rugby::before { + content: "\FD75"; +} +.mdi-ruler::before { + content: "\F46D"; +} +.mdi-ruler-square::before { + content: "\FC9E"; +} +.mdi-run::before { + content: "\F70D"; +} +.mdi-run-fast::before { + content: "\F46E"; +} +.mdi-sack::before { + content: "\FD0A"; +} +.mdi-sack-percent::before { + content: "\FD0B"; +} +.mdi-safe::before { + content: "\FA69"; +} +.mdi-safety-goggles::before { + content: "\FD0C"; +} +.mdi-sailing::before { + content: "\FEE5"; +} +.mdi-sale::before { + content: "\F46F"; +} +.mdi-salesforce::before { + content: "\F88D"; +} +.mdi-sass::before { + content: "\F7EB"; +} +.mdi-satellite::before { + content: "\F470"; +} +.mdi-satellite-uplink::before { + content: "\F908"; +} +.mdi-satellite-variant::before { + content: "\F471"; +} +.mdi-sausage::before { + content: "\F8B9"; +} +.mdi-saw-blade::before { + content: "\FE44"; +} +.mdi-saxophone::before { + content: "\F609"; +} +.mdi-scale::before { + content: "\F472"; +} +.mdi-scale-balance::before { + content: "\F5D1"; +} +.mdi-scale-bathroom::before { + content: "\F473"; +} +.mdi-scanner::before { + content: "\F6AA"; +} +.mdi-scanner-off::before { + content: "\F909"; +} +.mdi-scatter-plot::before { + content: "\FEE6"; +} +.mdi-scatter-plot-outline::before { + content: "\FEE7"; +} +.mdi-school::before { + content: "\F474"; +} +.mdi-scissors-cutting::before { + content: "\FA6A"; +} +.mdi-screen-rotation::before { + content: "\F475"; +} +.mdi-screen-rotation-lock::before { + content: "\F476"; +} +.mdi-screw-flat-top::before { + content: "\FDCF"; +} +.mdi-screw-lag::before { + content: "\FE54"; +} +.mdi-screw-machine-flat-top::before { + content: "\FE55"; +} +.mdi-screw-machine-round-top::before { + content: "\FE56"; +} +.mdi-screw-round-top::before { + content: "\FE57"; +} +.mdi-screwdriver::before { + content: "\F477"; +} +.mdi-script::before { + content: "\FB9D"; +} +.mdi-script-outline::before { + content: "\F478"; +} +.mdi-script-text::before { + content: "\FB9E"; +} +.mdi-script-text-outline::before { + content: "\FB9F"; +} +.mdi-sd::before { + content: "\F479"; +} +.mdi-seal::before { + content: "\F47A"; +} +.mdi-search-web::before { + content: "\F70E"; +} +.mdi-seat::before { + content: "\FC9F"; +} +.mdi-seat-flat::before { + content: "\F47B"; +} +.mdi-seat-flat-angled::before { + content: "\F47C"; +} +.mdi-seat-individual-suite::before { + content: "\F47D"; +} +.mdi-seat-legroom-extra::before { + content: "\F47E"; +} +.mdi-seat-legroom-normal::before { + content: "\F47F"; +} +.mdi-seat-legroom-reduced::before { + content: "\F480"; +} +.mdi-seat-outline::before { + content: "\FCA0"; +} +.mdi-seat-recline-extra::before { + content: "\F481"; +} +.mdi-seat-recline-normal::before { + content: "\F482"; +} +.mdi-seatbelt::before { + content: "\FCA1"; +} +.mdi-security::before { + content: "\F483"; +} +.mdi-security-network::before { + content: "\F484"; +} +.mdi-seed::before { + content: "\FE45"; +} +.mdi-seed-outline::before { + content: "\FE46"; +} +.mdi-segment::before { + content: "\FEE8"; +} +.mdi-select::before { + content: "\F485"; +} +.mdi-select-all::before { + content: "\F486"; +} +.mdi-select-color::before { + content: "\FD0D"; +} +.mdi-select-compare::before { + content: "\FAD8"; +} +.mdi-select-drag::before { + content: "\FA6B"; +} +.mdi-select-group::before { + content: "\FF9F"; +} +.mdi-select-inverse::before { + content: "\F487"; +} +.mdi-select-off::before { + content: "\F488"; +} +.mdi-selection::before { + content: "\F489"; +} +.mdi-selection-drag::before { + content: "\FA6C"; +} +.mdi-selection-ellipse::before { + content: "\FD0E"; +} +.mdi-selection-ellipse-arrow-inside::before { + content: "\FF3F"; +} +.mdi-selection-off::before { + content: "\F776"; +} +.mdi-send::before { + content: "\F48A"; +} +.mdi-send-circle::before { + content: "\FE58"; +} +.mdi-send-circle-outline::before { + content: "\FE59"; +} +.mdi-send-lock::before { + content: "\F7EC"; +} +.mdi-serial-port::before { + content: "\F65C"; +} +.mdi-server::before { + content: "\F48B"; +} +.mdi-server-minus::before { + content: "\F48C"; +} +.mdi-server-network::before { + content: "\F48D"; +} +.mdi-server-network-off::before { + content: "\F48E"; +} +.mdi-server-off::before { + content: "\F48F"; +} +.mdi-server-plus::before { + content: "\F490"; +} +.mdi-server-remove::before { + content: "\F491"; +} +.mdi-server-security::before { + content: "\F492"; +} +.mdi-set-all::before { + content: "\F777"; +} +.mdi-set-center::before { + content: "\F778"; +} +.mdi-set-center-right::before { + content: "\F779"; +} +.mdi-set-left::before { + content: "\F77A"; +} +.mdi-set-left-center::before { + content: "\F77B"; +} +.mdi-set-left-right::before { + content: "\F77C"; +} +.mdi-set-none::before { + content: "\F77D"; +} +.mdi-set-right::before { + content: "\F77E"; +} +.mdi-set-top-box::before { + content: "\F99E"; +} +.mdi-settings::before { + content: "\F493"; +} +.mdi-settings-box::before { + content: "\F494"; +} +.mdi-settings-helper::before { + content: "\FA6D"; +} +.mdi-settings-outline::before { + content: "\F8BA"; +} +.mdi-shape::before { + content: "\F830"; +} +.mdi-shape-circle-plus::before { + content: "\F65D"; +} +.mdi-shape-outline::before { + content: "\F831"; +} +.mdi-shape-plus::before { + content: "\F495"; +} +.mdi-shape-polygon-plus::before { + content: "\F65E"; +} +.mdi-shape-rectangle-plus::before { + content: "\F65F"; +} +.mdi-shape-square-plus::before { + content: "\F660"; +} +.mdi-share::before { + content: "\F496"; +} +.mdi-share-off::before { + content: "\FF40"; +} +.mdi-share-off-outline::before { + content: "\FF41"; +} +.mdi-share-outline::before { + content: "\F931"; +} +.mdi-share-variant::before { + content: "\F497"; +} +.mdi-sheep::before { + content: "\FCA2"; +} +.mdi-shield::before { + content: "\F498"; +} +.mdi-shield-account::before { + content: "\F88E"; +} +.mdi-shield-account-outline::before { + content: "\FA11"; +} +.mdi-shield-airplane::before { + content: "\F6BA"; +} +.mdi-shield-airplane-outline::before { + content: "\FCA3"; +} +.mdi-shield-alert::before { + content: "\FEE9"; +} +.mdi-shield-alert-outline::before { + content: "\FEEA"; +} +.mdi-shield-car::before { + content: "\FFA0"; +} +.mdi-shield-check::before { + content: "\F565"; +} +.mdi-shield-check-outline::before { + content: "\FCA4"; +} +.mdi-shield-cross::before { + content: "\FCA5"; +} +.mdi-shield-cross-outline::before { + content: "\FCA6"; +} +.mdi-shield-half-full::before { + content: "\F77F"; +} +.mdi-shield-home::before { + content: "\F689"; +} +.mdi-shield-home-outline::before { + content: "\FCA7"; +} +.mdi-shield-key::before { + content: "\FBA0"; +} +.mdi-shield-key-outline::before { + content: "\FBA1"; +} +.mdi-shield-link-variant::before { + content: "\FD0F"; +} +.mdi-shield-link-variant-outline::before { + content: "\FD10"; +} +.mdi-shield-lock::before { + content: "\F99C"; +} +.mdi-shield-lock-outline::before { + content: "\FCA8"; +} +.mdi-shield-off::before { + content: "\F99D"; +} +.mdi-shield-off-outline::before { + content: "\F99B"; +} +.mdi-shield-outline::before { + content: "\F499"; +} +.mdi-shield-plus::before { + content: "\FAD9"; +} +.mdi-shield-plus-outline::before { + content: "\FADA"; +} +.mdi-shield-remove::before { + content: "\FADB"; +} +.mdi-shield-remove-outline::before { + content: "\FADC"; +} +.mdi-shield-search::before { + content: "\FD76"; +} +.mdi-ship-wheel::before { + content: "\F832"; +} +.mdi-shoe-formal::before { + content: "\FB22"; +} +.mdi-shoe-heel::before { + content: "\FB23"; +} +.mdi-shoe-print::before { + content: "\FE5A"; +} +.mdi-shopify::before { + content: "\FADD"; +} +.mdi-shopping::before { + content: "\F49A"; +} +.mdi-shopping-music::before { + content: "\F49B"; +} +.mdi-shopping-search::before { + content: "\FFA1"; +} +.mdi-shovel::before { + content: "\F70F"; +} +.mdi-shovel-off::before { + content: "\F710"; +} +.mdi-shower::before { + content: "\F99F"; +} +.mdi-shower-head::before { + content: "\F9A0"; +} +.mdi-shredder::before { + content: "\F49C"; +} +.mdi-shuffle::before { + content: "\F49D"; +} +.mdi-shuffle-disabled::before { + content: "\F49E"; +} +.mdi-shuffle-variant::before { + content: "\F49F"; +} +.mdi-sigma::before { + content: "\F4A0"; +} +.mdi-sigma-lower::before { + content: "\F62B"; +} +.mdi-sign-caution::before { + content: "\F4A1"; +} +.mdi-sign-direction::before { + content: "\F780"; +} +.mdi-sign-text::before { + content: "\F781"; +} +.mdi-signal::before { + content: "\F4A2"; +} +.mdi-signal-2g::before { + content: "\F711"; +} +.mdi-signal-3g::before { + content: "\F712"; +} +.mdi-signal-4g::before { + content: "\F713"; +} +.mdi-signal-5g::before { + content: "\FA6E"; +} +.mdi-signal-cellular-1::before { + content: "\F8BB"; +} +.mdi-signal-cellular-2::before { + content: "\F8BC"; +} +.mdi-signal-cellular-3::before { + content: "\F8BD"; +} +.mdi-signal-cellular-outline::before { + content: "\F8BE"; +} +.mdi-signal-distance-variant::before { + content: "\FE47"; +} +.mdi-signal-hspa::before { + content: "\F714"; +} +.mdi-signal-hspa-plus::before { + content: "\F715"; +} +.mdi-signal-off::before { + content: "\F782"; +} +.mdi-signal-variant::before { + content: "\F60A"; +} +.mdi-signature::before { + content: "\FE5B"; +} +.mdi-signature-freehand::before { + content: "\FE5C"; +} +.mdi-signature-image::before { + content: "\FE5D"; +} +.mdi-signature-text::before { + content: "\FE5E"; +} +.mdi-silo::before { + content: "\FB24"; +} +.mdi-silverware::before { + content: "\F4A3"; +} +.mdi-silverware-fork::before { + content: "\F4A4"; +} +.mdi-silverware-fork-knife::before { + content: "\FA6F"; +} +.mdi-silverware-spoon::before { + content: "\F4A5"; +} +.mdi-silverware-variant::before { + content: "\F4A6"; +} +.mdi-sim::before { + content: "\F4A7"; +} +.mdi-sim-alert::before { + content: "\F4A8"; +} +.mdi-sim-off::before { + content: "\F4A9"; +} +.mdi-sina-weibo::before { + content: "\FADE"; +} +.mdi-sitemap::before { + content: "\F4AA"; +} +.mdi-skate::before { + content: "\FD11"; +} +.mdi-skew-less::before { + content: "\FD12"; +} +.mdi-skew-more::before { + content: "\FD13"; +} +.mdi-skip-backward::before { + content: "\F4AB"; +} +.mdi-skip-backward-outline::before { + content: "\FF42"; +} +.mdi-skip-forward::before { + content: "\F4AC"; +} +.mdi-skip-forward-outline::before { + content: "\FF43"; +} +.mdi-skip-next::before { + content: "\F4AD"; +} +.mdi-skip-next-circle::before { + content: "\F661"; +} +.mdi-skip-next-circle-outline::before { + content: "\F662"; +} +.mdi-skip-next-outline::before { + content: "\FF44"; +} +.mdi-skip-previous::before { + content: "\F4AE"; +} +.mdi-skip-previous-circle::before { + content: "\F663"; +} +.mdi-skip-previous-circle-outline::before { + content: "\F664"; +} +.mdi-skip-previous-outline::before { + content: "\FF45"; +} +.mdi-skull::before { + content: "\F68B"; +} +.mdi-skull-crossbones::before { + content: "\FBA2"; +} +.mdi-skull-crossbones-outline::before { + content: "\FBA3"; +} +.mdi-skull-outline::before { + content: "\FBA4"; +} +.mdi-skype::before { + content: "\F4AF"; +} +.mdi-skype-business::before { + content: "\F4B0"; +} +.mdi-slack::before { + content: "\F4B1"; +} +.mdi-slackware::before { + content: "\F90A"; +} +.mdi-sleep::before { + content: "\F4B2"; +} +.mdi-sleep-off::before { + content: "\F4B3"; +} +.mdi-slope-downhill::before { + content: "\FE5F"; +} +.mdi-slope-uphill::before { + content: "\FE60"; +} +.mdi-smog::before { + content: "\FA70"; +} +.mdi-smoke-detector::before { + content: "\F392"; +} +.mdi-smoking::before { + content: "\F4B4"; +} +.mdi-smoking-off::before { + content: "\F4B5"; +} +.mdi-snapchat::before { + content: "\F4B6"; +} +.mdi-snowflake::before { + content: "\F716"; +} +.mdi-snowflake-alert::before { + content: "\FF46"; +} +.mdi-snowflake-variant::before { + content: "\FF47"; +} +.mdi-snowman::before { + content: "\F4B7"; +} +.mdi-soccer::before { + content: "\F4B8"; +} +.mdi-soccer-field::before { + content: "\F833"; +} +.mdi-sofa::before { + content: "\F4B9"; +} +.mdi-solar-panel::before { + content: "\FD77"; +} +.mdi-solar-panel-large::before { + content: "\FD78"; +} +.mdi-solar-power::before { + content: "\FA71"; +} +.mdi-solid::before { + content: "\F68C"; +} +.mdi-sort::before { + content: "\F4BA"; +} +.mdi-sort-alphabetical::before { + content: "\F4BB"; +} +.mdi-sort-ascending::before { + content: "\F4BC"; +} +.mdi-sort-descending::before { + content: "\F4BD"; +} +.mdi-sort-numeric::before { + content: "\F4BE"; +} +.mdi-sort-variant::before { + content: "\F4BF"; +} +.mdi-sort-variant-lock::before { + content: "\FCA9"; +} +.mdi-sort-variant-lock-open::before { + content: "\FCAA"; +} +.mdi-soundcloud::before { + content: "\F4C0"; +} +.mdi-source-branch::before { + content: "\F62C"; +} +.mdi-source-commit::before { + content: "\F717"; +} +.mdi-source-commit-end::before { + content: "\F718"; +} +.mdi-source-commit-end-local::before { + content: "\F719"; +} +.mdi-source-commit-local::before { + content: "\F71A"; +} +.mdi-source-commit-next-local::before { + content: "\F71B"; +} +.mdi-source-commit-start::before { + content: "\F71C"; +} +.mdi-source-commit-start-next-local::before { + content: "\F71D"; +} +.mdi-source-fork::before { + content: "\F4C1"; +} +.mdi-source-merge::before { + content: "\F62D"; +} +.mdi-source-pull::before { + content: "\F4C2"; +} +.mdi-source-repository::before { + content: "\FCAB"; +} +.mdi-source-repository-multiple::before { + content: "\FCAC"; +} +.mdi-soy-sauce::before { + content: "\F7ED"; +} +.mdi-spa::before { + content: "\FCAD"; +} +.mdi-spa-outline::before { + content: "\FCAE"; +} +.mdi-space-invaders::before { + content: "\FBA5"; +} +.mdi-spade::before { + content: "\FE48"; +} +.mdi-speaker::before { + content: "\F4C3"; +} +.mdi-speaker-bluetooth::before { + content: "\F9A1"; +} +.mdi-speaker-multiple::before { + content: "\FD14"; +} +.mdi-speaker-off::before { + content: "\F4C4"; +} +.mdi-speaker-wireless::before { + content: "\F71E"; +} +.mdi-speedometer::before { + content: "\F4C5"; +} +.mdi-speedometer-medium::before { + content: "\FFA2"; +} +.mdi-speedometer-slow::before { + content: "\FFA3"; +} +.mdi-spellcheck::before { + content: "\F4C6"; +} +.mdi-spider-web::before { + content: "\FBA6"; +} +.mdi-spotify::before { + content: "\F4C7"; +} +.mdi-spotlight::before { + content: "\F4C8"; +} +.mdi-spotlight-beam::before { + content: "\F4C9"; +} +.mdi-spray::before { + content: "\F665"; +} +.mdi-spray-bottle::before { + content: "\FADF"; +} +.mdi-sprout::before { + content: "\FE49"; +} +.mdi-sprout-outline::before { + content: "\FE4A"; +} +.mdi-square::before { + content: "\F763"; +} +.mdi-square-edit-outline::before { + content: "\F90B"; +} +.mdi-square-inc::before { + content: "\F4CA"; +} +.mdi-square-inc-cash::before { + content: "\F4CB"; +} +.mdi-square-medium::before { + content: "\FA12"; +} +.mdi-square-medium-outline::before { + content: "\FA13"; +} +.mdi-square-outline::before { + content: "\F762"; +} +.mdi-square-root::before { + content: "\F783"; +} +.mdi-square-root-box::before { + content: "\F9A2"; +} +.mdi-square-small::before { + content: "\FA14"; +} +.mdi-squeegee::before { + content: "\FAE0"; +} +.mdi-ssh::before { + content: "\F8BF"; +} +.mdi-stack-exchange::before { + content: "\F60B"; +} +.mdi-stack-overflow::before { + content: "\F4CC"; +} +.mdi-stadium::before { + content: "\F71F"; +} +.mdi-stairs::before { + content: "\F4CD"; +} +.mdi-stamper::before { + content: "\FD15"; +} +.mdi-standard-definition::before { + content: "\F7EE"; +} +.mdi-star::before { + content: "\F4CE"; +} +.mdi-star-box::before { + content: "\FA72"; +} +.mdi-star-box-outline::before { + content: "\FA73"; +} +.mdi-star-circle::before { + content: "\F4CF"; +} +.mdi-star-circle-outline::before { + content: "\F9A3"; +} +.mdi-star-face::before { + content: "\F9A4"; +} +.mdi-star-four-points::before { + content: "\FAE1"; +} +.mdi-star-four-points-outline::before { + content: "\FAE2"; +} +.mdi-star-half::before { + content: "\F4D0"; +} +.mdi-star-off::before { + content: "\F4D1"; +} +.mdi-star-outline::before { + content: "\F4D2"; +} +.mdi-star-three-points::before { + content: "\FAE3"; +} +.mdi-star-three-points-outline::before { + content: "\FAE4"; +} +.mdi-steam::before { + content: "\F4D3"; +} +.mdi-steam-box::before { + content: "\F90C"; +} +.mdi-steering::before { + content: "\F4D4"; +} +.mdi-steering-off::before { + content: "\F90D"; +} +.mdi-step-backward::before { + content: "\F4D5"; +} +.mdi-step-backward-2::before { + content: "\F4D6"; +} +.mdi-step-forward::before { + content: "\F4D7"; +} +.mdi-step-forward-2::before { + content: "\F4D8"; +} +.mdi-stethoscope::before { + content: "\F4D9"; +} +.mdi-sticker::before { + content: "\F5D0"; +} +.mdi-sticker-emoji::before { + content: "\F784"; +} +.mdi-stocking::before { + content: "\F4DA"; +} +.mdi-stop::before { + content: "\F4DB"; +} +.mdi-stop-circle::before { + content: "\F666"; +} +.mdi-stop-circle-outline::before { + content: "\F667"; +} +.mdi-store::before { + content: "\F4DC"; +} +.mdi-store-24-hour::before { + content: "\F4DD"; +} +.mdi-stove::before { + content: "\F4DE"; +} +.mdi-strava::before { + content: "\FB25"; +} +.mdi-stretch-to-page::before { + content: "\FF48"; +} +.mdi-stretch-to-page-outline::before { + content: "\FF49"; +} +.mdi-subdirectory-arrow-left::before { + content: "\F60C"; +} +.mdi-subdirectory-arrow-right::before { + content: "\F60D"; +} +.mdi-subtitles::before { + content: "\FA15"; +} +.mdi-subtitles-outline::before { + content: "\FA16"; +} +.mdi-subway::before { + content: "\F6AB"; +} +.mdi-subway-alert-variant::before { + content: "\FD79"; +} +.mdi-subway-variant::before { + content: "\F4DF"; +} +.mdi-summit::before { + content: "\F785"; +} +.mdi-sunglasses::before { + content: "\F4E0"; +} +.mdi-surround-sound::before { + content: "\F5C5"; +} +.mdi-surround-sound-2-0::before { + content: "\F7EF"; +} +.mdi-surround-sound-3-1::before { + content: "\F7F0"; +} +.mdi-surround-sound-5-1::before { + content: "\F7F1"; +} +.mdi-surround-sound-7-1::before { + content: "\F7F2"; +} +.mdi-svg::before { + content: "\F720"; +} +.mdi-swap-horizontal::before { + content: "\F4E1"; +} +.mdi-swap-horizontal-bold::before { + content: "\FBA9"; +} +.mdi-swap-horizontal-variant::before { + content: "\F8C0"; +} +.mdi-swap-vertical::before { + content: "\F4E2"; +} +.mdi-swap-vertical-bold::before { + content: "\FBAA"; +} +.mdi-swap-vertical-variant::before { + content: "\F8C1"; +} +.mdi-swim::before { + content: "\F4E3"; +} +.mdi-switch::before { + content: "\F4E4"; +} +.mdi-sword::before { + content: "\F4E5"; +} +.mdi-sword-cross::before { + content: "\F786"; +} +.mdi-symfony::before { + content: "\FAE5"; +} +.mdi-sync::before { + content: "\F4E6"; +} +.mdi-sync-alert::before { + content: "\F4E7"; +} +.mdi-sync-off::before { + content: "\F4E8"; +} +.mdi-tab::before { + content: "\F4E9"; +} +.mdi-tab-minus::before { + content: "\FB26"; +} +.mdi-tab-plus::before { + content: "\F75B"; +} +.mdi-tab-remove::before { + content: "\FB27"; +} +.mdi-tab-unselected::before { + content: "\F4EA"; +} +.mdi-table::before { + content: "\F4EB"; +} +.mdi-table-border::before { + content: "\FA17"; +} +.mdi-table-column::before { + content: "\F834"; +} +.mdi-table-column-plus-after::before { + content: "\F4EC"; +} +.mdi-table-column-plus-before::before { + content: "\F4ED"; +} +.mdi-table-column-remove::before { + content: "\F4EE"; +} +.mdi-table-column-width::before { + content: "\F4EF"; +} +.mdi-table-edit::before { + content: "\F4F0"; +} +.mdi-table-large::before { + content: "\F4F1"; +} +.mdi-table-large-plus::before { + content: "\FFA4"; +} +.mdi-table-large-remove::before { + content: "\FFA5"; +} +.mdi-table-merge-cells::before { + content: "\F9A5"; +} +.mdi-table-of-contents::before { + content: "\F835"; +} +.mdi-table-plus::before { + content: "\FA74"; +} +.mdi-table-remove::before { + content: "\FA75"; +} +.mdi-table-row::before { + content: "\F836"; +} +.mdi-table-row-height::before { + content: "\F4F2"; +} +.mdi-table-row-plus-after::before { + content: "\F4F3"; +} +.mdi-table-row-plus-before::before { + content: "\F4F4"; +} +.mdi-table-row-remove::before { + content: "\F4F5"; +} +.mdi-table-search::before { + content: "\F90E"; +} +.mdi-table-settings::before { + content: "\F837"; +} +.mdi-table-tennis::before { + content: "\FE4B"; +} +.mdi-tablet::before { + content: "\F4F6"; +} +.mdi-tablet-android::before { + content: "\F4F7"; +} +.mdi-tablet-cellphone::before { + content: "\F9A6"; +} +.mdi-tablet-dashboard::before { + content: "\FEEB"; +} +.mdi-tablet-ipad::before { + content: "\F4F8"; +} +.mdi-taco::before { + content: "\F761"; +} +.mdi-tag::before { + content: "\F4F9"; +} +.mdi-tag-faces::before { + content: "\F4FA"; +} +.mdi-tag-heart::before { + content: "\F68A"; +} +.mdi-tag-heart-outline::before { + content: "\FBAB"; +} +.mdi-tag-minus::before { + content: "\F90F"; +} +.mdi-tag-multiple::before { + content: "\F4FB"; +} +.mdi-tag-outline::before { + content: "\F4FC"; +} +.mdi-tag-plus::before { + content: "\F721"; +} +.mdi-tag-remove::before { + content: "\F722"; +} +.mdi-tag-text-outline::before { + content: "\F4FD"; +} +.mdi-tank::before { + content: "\FD16"; +} +.mdi-tape-measure::before { + content: "\FB28"; +} +.mdi-target::before { + content: "\F4FE"; +} +.mdi-target-account::before { + content: "\FBAC"; +} +.mdi-target-variant::before { + content: "\FA76"; +} +.mdi-taxi::before { + content: "\F4FF"; +} +.mdi-tea::before { + content: "\FD7A"; +} +.mdi-tea-outline::before { + content: "\FD7B"; +} +.mdi-teach::before { + content: "\F88F"; +} +.mdi-teamviewer::before { + content: "\F500"; +} +.mdi-telegram::before { + content: "\F501"; +} +.mdi-telescope::before { + content: "\FB29"; +} +.mdi-television::before { + content: "\F502"; +} +.mdi-television-box::before { + content: "\F838"; +} +.mdi-television-classic::before { + content: "\F7F3"; +} +.mdi-television-classic-off::before { + content: "\F839"; +} +.mdi-television-guide::before { + content: "\F503"; +} +.mdi-television-off::before { + content: "\F83A"; +} +.mdi-television-pause::before { + content: "\FFA6"; +} +.mdi-television-play::before { + content: "\FEEC"; +} +.mdi-television-stop::before { + content: "\FFA7"; +} +.mdi-temperature-celsius::before { + content: "\F504"; +} +.mdi-temperature-fahrenheit::before { + content: "\F505"; +} +.mdi-temperature-kelvin::before { + content: "\F506"; +} +.mdi-tennis::before { + content: "\FD7C"; +} +.mdi-tennis-ball::before { + content: "\F507"; +} +.mdi-tent::before { + content: "\F508"; +} +.mdi-terrain::before { + content: "\F509"; +} +.mdi-test-tube::before { + content: "\F668"; +} +.mdi-test-tube-empty::before { + content: "\F910"; +} +.mdi-test-tube-off::before { + content: "\F911"; +} +.mdi-text::before { + content: "\F9A7"; +} +.mdi-text-shadow::before { + content: "\F669"; +} +.mdi-text-short::before { + content: "\F9A8"; +} +.mdi-text-subject::before { + content: "\F9A9"; +} +.mdi-text-to-speech::before { + content: "\F50A"; +} +.mdi-text-to-speech-off::before { + content: "\F50B"; +} +.mdi-textbox::before { + content: "\F60E"; +} +.mdi-textbox-password::before { + content: "\F7F4"; +} +.mdi-texture::before { + content: "\F50C"; +} +.mdi-theater::before { + content: "\F50D"; +} +.mdi-theme-light-dark::before { + content: "\F50E"; +} +.mdi-thermometer::before { + content: "\F50F"; +} +.mdi-thermometer-alert::before { + content: "\FE61"; +} +.mdi-thermometer-chevron-down::before { + content: "\FE62"; +} +.mdi-thermometer-chevron-up::before { + content: "\FE63"; +} +.mdi-thermometer-lines::before { + content: "\F510"; +} +.mdi-thermometer-minus::before { + content: "\FE64"; +} +.mdi-thermometer-plus::before { + content: "\FE65"; +} +.mdi-thermostat::before { + content: "\F393"; +} +.mdi-thermostat-box::before { + content: "\F890"; +} +.mdi-thought-bubble::before { + content: "\F7F5"; +} +.mdi-thought-bubble-outline::before { + content: "\F7F6"; +} +.mdi-thumb-down::before { + content: "\F511"; +} +.mdi-thumb-down-outline::before { + content: "\F512"; +} +.mdi-thumb-up::before { + content: "\F513"; +} +.mdi-thumb-up-outline::before { + content: "\F514"; +} +.mdi-thumbs-up-down::before { + content: "\F515"; +} +.mdi-ticket::before { + content: "\F516"; +} +.mdi-ticket-account::before { + content: "\F517"; +} +.mdi-ticket-confirmation::before { + content: "\F518"; +} +.mdi-ticket-outline::before { + content: "\F912"; +} +.mdi-ticket-percent::before { + content: "\F723"; +} +.mdi-tie::before { + content: "\F519"; +} +.mdi-tilde::before { + content: "\F724"; +} +.mdi-timelapse::before { + content: "\F51A"; +} +.mdi-timeline::before { + content: "\FBAD"; +} +.mdi-timeline-alert::before { + content: "\FFB2"; +} +.mdi-timeline-alert-outline::before { + content: "\FFB5"; +} +.mdi-timeline-help::before { + content: "\FFB6"; +} +.mdi-timeline-help-outline::before { + content: "\FFB7"; +} +.mdi-timeline-outline::before { + content: "\FBAE"; +} +.mdi-timeline-plus::before { + content: "\FFB3"; +} +.mdi-timeline-plus-outline::before { + content: "\FFB4"; +} +.mdi-timeline-text::before { + content: "\FBAF"; +} +.mdi-timeline-text-outline::before { + content: "\FBB0"; +} +.mdi-timer::before { + content: "\F51B"; +} +.mdi-timer-10::before { + content: "\F51C"; +} +.mdi-timer-3::before { + content: "\F51D"; +} +.mdi-timer-off::before { + content: "\F51E"; +} +.mdi-timer-sand::before { + content: "\F51F"; +} +.mdi-timer-sand-empty::before { + content: "\F6AC"; +} +.mdi-timer-sand-full::before { + content: "\F78B"; +} +.mdi-timetable::before { + content: "\F520"; +} +.mdi-toaster-oven::before { + content: "\FCAF"; +} +.mdi-toggle-switch::before { + content: "\F521"; +} +.mdi-toggle-switch-off::before { + content: "\F522"; +} +.mdi-toggle-switch-off-outline::before { + content: "\FA18"; +} +.mdi-toggle-switch-outline::before { + content: "\FA19"; +} +.mdi-toilet::before { + content: "\F9AA"; +} +.mdi-toolbox::before { + content: "\F9AB"; +} +.mdi-toolbox-outline::before { + content: "\F9AC"; +} +.mdi-tooltip::before { + content: "\F523"; +} +.mdi-tooltip-account::before { + content: "\F00C"; +} +.mdi-tooltip-edit::before { + content: "\F524"; +} +.mdi-tooltip-image::before { + content: "\F525"; +} +.mdi-tooltip-image-outline::before { + content: "\FBB1"; +} +.mdi-tooltip-outline::before { + content: "\F526"; +} +.mdi-tooltip-plus::before { + content: "\FBB2"; +} +.mdi-tooltip-plus-outline::before { + content: "\F527"; +} +.mdi-tooltip-text::before { + content: "\F528"; +} +.mdi-tooltip-text-outline::before { + content: "\FBB3"; +} +.mdi-tooth::before { + content: "\F8C2"; +} +.mdi-tooth-outline::before { + content: "\F529"; +} +.mdi-tor::before { + content: "\F52A"; +} +.mdi-tortoise::before { + content: "\FD17"; +} +.mdi-tournament::before { + content: "\F9AD"; +} +.mdi-tower-beach::before { + content: "\F680"; +} +.mdi-tower-fire::before { + content: "\F681"; +} +.mdi-towing::before { + content: "\F83B"; +} +.mdi-track-light::before { + content: "\F913"; +} +.mdi-trackpad::before { + content: "\F7F7"; +} +.mdi-trackpad-lock::before { + content: "\F932"; +} +.mdi-tractor::before { + content: "\F891"; +} +.mdi-trademark::before { + content: "\FA77"; +} +.mdi-traffic-light::before { + content: "\F52B"; +} +.mdi-train::before { + content: "\F52C"; +} +.mdi-train-car::before { + content: "\FBB4"; +} +.mdi-train-variant::before { + content: "\F8C3"; +} +.mdi-tram::before { + content: "\F52D"; +} +.mdi-transcribe::before { + content: "\F52E"; +} +.mdi-transcribe-close::before { + content: "\F52F"; +} +.mdi-transfer-down::before { + content: "\FD7D"; +} +.mdi-transfer-left::before { + content: "\FD7E"; +} +.mdi-transfer-right::before { + content: "\F530"; +} +.mdi-transfer-up::before { + content: "\FD7F"; +} +.mdi-transit-connection::before { + content: "\FD18"; +} +.mdi-transit-connection-variant::before { + content: "\FD19"; +} +.mdi-transit-detour::before { + content: "\FFA8"; +} +.mdi-transit-transfer::before { + content: "\F6AD"; +} +.mdi-transition::before { + content: "\F914"; +} +.mdi-transition-masked::before { + content: "\F915"; +} +.mdi-translate::before { + content: "\F5CA"; +} +.mdi-translate-off::before { + content: "\FE66"; +} +.mdi-transmission-tower::before { + content: "\FD1A"; +} +.mdi-trash-can::before { + content: "\FA78"; +} +.mdi-trash-can-outline::before { + content: "\FA79"; +} +.mdi-treasure-chest::before { + content: "\F725"; +} +.mdi-tree::before { + content: "\F531"; +} +.mdi-tree-outline::before { + content: "\FE4C"; +} +.mdi-trello::before { + content: "\F532"; +} +.mdi-trending-down::before { + content: "\F533"; +} +.mdi-trending-neutral::before { + content: "\F534"; +} +.mdi-trending-up::before { + content: "\F535"; +} +.mdi-triangle::before { + content: "\F536"; +} +.mdi-triangle-outline::before { + content: "\F537"; +} +.mdi-triforce::before { + content: "\FBB5"; +} +.mdi-trophy::before { + content: "\F538"; +} +.mdi-trophy-award::before { + content: "\F539"; +} +.mdi-trophy-broken::before { + content: "\FD80"; +} +.mdi-trophy-outline::before { + content: "\F53A"; +} +.mdi-trophy-variant::before { + content: "\F53B"; +} +.mdi-trophy-variant-outline::before { + content: "\F53C"; +} +.mdi-truck::before { + content: "\F53D"; +} +.mdi-truck-check::before { + content: "\FCB0"; +} +.mdi-truck-delivery::before { + content: "\F53E"; +} +.mdi-truck-fast::before { + content: "\F787"; +} +.mdi-truck-trailer::before { + content: "\F726"; +} +.mdi-tshirt-crew::before { + content: "\FA7A"; +} +.mdi-tshirt-crew-outline::before { + content: "\F53F"; +} +.mdi-tshirt-v::before { + content: "\FA7B"; +} +.mdi-tshirt-v-outline::before { + content: "\F540"; +} +.mdi-tumble-dryer::before { + content: "\F916"; +} +.mdi-tumblr::before { + content: "\F541"; +} +.mdi-tumblr-box::before { + content: "\F917"; +} +.mdi-tumblr-reblog::before { + content: "\F542"; +} +.mdi-tune::before { + content: "\F62E"; +} +.mdi-tune-vertical::before { + content: "\F66A"; +} +.mdi-turnstile::before { + content: "\FCB1"; +} +.mdi-turnstile-outline::before { + content: "\FCB2"; +} +.mdi-turtle::before { + content: "\FCB3"; +} +.mdi-twitch::before { + content: "\F543"; +} +.mdi-twitter::before { + content: "\F544"; +} +.mdi-twitter-box::before { + content: "\F545"; +} +.mdi-twitter-circle::before { + content: "\F546"; +} +.mdi-twitter-retweet::before { + content: "\F547"; +} +.mdi-two-factor-authentication::before { + content: "\F9AE"; +} +.mdi-typewriter::before { + content: "\FF4A"; +} +.mdi-uber::before { + content: "\F748"; +} +.mdi-ubisoft::before { + content: "\FBB6"; +} +.mdi-ubuntu::before { + content: "\F548"; +} +.mdi-ultra-high-definition::before { + content: "\F7F8"; +} +.mdi-umbraco::before { + content: "\F549"; +} +.mdi-umbrella::before { + content: "\F54A"; +} +.mdi-umbrella-closed::before { + content: "\F9AF"; +} +.mdi-umbrella-outline::before { + content: "\F54B"; +} +.mdi-undo::before { + content: "\F54C"; +} +.mdi-undo-variant::before { + content: "\F54D"; +} +.mdi-unfold-less-horizontal::before { + content: "\F54E"; +} +.mdi-unfold-less-vertical::before { + content: "\F75F"; +} +.mdi-unfold-more-horizontal::before { + content: "\F54F"; +} +.mdi-unfold-more-vertical::before { + content: "\F760"; +} +.mdi-ungroup::before { + content: "\F550"; +} +.mdi-unicode::before { + content: "\FEED"; +} +.mdi-unity::before { + content: "\F6AE"; +} +.mdi-unreal::before { + content: "\F9B0"; +} +.mdi-untappd::before { + content: "\F551"; +} +.mdi-update::before { + content: "\F6AF"; +} +.mdi-upload::before { + content: "\F552"; +} +.mdi-upload-multiple::before { + content: "\F83C"; +} +.mdi-upload-network::before { + content: "\F6F5"; +} +.mdi-upload-network-outline::before { + content: "\FCB4"; +} +.mdi-upload-outline::before { + content: "\FE67"; +} +.mdi-usb::before { + content: "\F553"; +} +.mdi-van-passenger::before { + content: "\F7F9"; +} +.mdi-van-utility::before { + content: "\F7FA"; +} +.mdi-vanish::before { + content: "\F7FB"; +} +.mdi-variable::before { + content: "\FAE6"; +} +.mdi-vector-arrange-above::before { + content: "\F554"; +} +.mdi-vector-arrange-below::before { + content: "\F555"; +} +.mdi-vector-bezier::before { + content: "\FAE7"; +} +.mdi-vector-circle::before { + content: "\F556"; +} +.mdi-vector-circle-variant::before { + content: "\F557"; +} +.mdi-vector-combine::before { + content: "\F558"; +} +.mdi-vector-curve::before { + content: "\F559"; +} +.mdi-vector-difference::before { + content: "\F55A"; +} +.mdi-vector-difference-ab::before { + content: "\F55B"; +} +.mdi-vector-difference-ba::before { + content: "\F55C"; +} +.mdi-vector-ellipse::before { + content: "\F892"; +} +.mdi-vector-intersection::before { + content: "\F55D"; +} +.mdi-vector-line::before { + content: "\F55E"; +} +.mdi-vector-point::before { + content: "\F55F"; +} +.mdi-vector-polygon::before { + content: "\F560"; +} +.mdi-vector-polyline::before { + content: "\F561"; +} +.mdi-vector-radius::before { + content: "\F749"; +} +.mdi-vector-rectangle::before { + content: "\F5C6"; +} +.mdi-vector-selection::before { + content: "\F562"; +} +.mdi-vector-square::before { + content: "\F001"; +} +.mdi-vector-triangle::before { + content: "\F563"; +} +.mdi-vector-union::before { + content: "\F564"; +} +.mdi-venmo::before { + content: "\F578"; +} +.mdi-vhs::before { + content: "\FA1A"; +} +.mdi-vibrate::before { + content: "\F566"; +} +.mdi-vibrate-off::before { + content: "\FCB5"; +} +.mdi-video::before { + content: "\F567"; +} +.mdi-video-3d::before { + content: "\F7FC"; +} +.mdi-video-3d-variant::before { + content: "\FEEE"; +} +.mdi-video-4k-box::before { + content: "\F83D"; +} +.mdi-video-account::before { + content: "\F918"; +} +.mdi-video-image::before { + content: "\F919"; +} +.mdi-video-input-antenna::before { + content: "\F83E"; +} +.mdi-video-input-component::before { + content: "\F83F"; +} +.mdi-video-input-hdmi::before { + content: "\F840"; +} +.mdi-video-input-scart::before { + content: "\FFA9"; +} +.mdi-video-input-svideo::before { + content: "\F841"; +} +.mdi-video-minus::before { + content: "\F9B1"; +} +.mdi-video-off::before { + content: "\F568"; +} +.mdi-video-off-outline::before { + content: "\FBB7"; +} +.mdi-video-outline::before { + content: "\FBB8"; +} +.mdi-video-plus::before { + content: "\F9B2"; +} +.mdi-video-stabilization::before { + content: "\F91A"; +} +.mdi-video-switch::before { + content: "\F569"; +} +.mdi-video-vintage::before { + content: "\FA1B"; +} +.mdi-video-wireless::before { + content: "\FEEF"; +} +.mdi-video-wireless-outline::before { + content: "\FEF0"; +} +.mdi-view-agenda::before { + content: "\F56A"; +} +.mdi-view-array::before { + content: "\F56B"; +} +.mdi-view-carousel::before { + content: "\F56C"; +} +.mdi-view-column::before { + content: "\F56D"; +} +.mdi-view-comfy::before { + content: "\FE4D"; +} +.mdi-view-compact::before { + content: "\FE4E"; +} +.mdi-view-compact-outline::before { + content: "\FE4F"; +} +.mdi-view-dashboard::before { + content: "\F56E"; +} +.mdi-view-dashboard-outline::before { + content: "\FA1C"; +} +.mdi-view-dashboard-variant::before { + content: "\F842"; +} +.mdi-view-day::before { + content: "\F56F"; +} +.mdi-view-grid::before { + content: "\F570"; +} +.mdi-view-grid-plus::before { + content: "\FFAA"; +} +.mdi-view-headline::before { + content: "\F571"; +} +.mdi-view-list::before { + content: "\F572"; +} +.mdi-view-module::before { + content: "\F573"; +} +.mdi-view-parallel::before { + content: "\F727"; +} +.mdi-view-quilt::before { + content: "\F574"; +} +.mdi-view-sequential::before { + content: "\F728"; +} +.mdi-view-split-horizontal::before { + content: "\FBA7"; +} +.mdi-view-split-vertical::before { + content: "\FBA8"; +} +.mdi-view-stream::before { + content: "\F575"; +} +.mdi-view-week::before { + content: "\F576"; +} +.mdi-vimeo::before { + content: "\F577"; +} +.mdi-violin::before { + content: "\F60F"; +} +.mdi-virtual-reality::before { + content: "\F893"; +} +.mdi-visual-studio::before { + content: "\F610"; +} +.mdi-visual-studio-code::before { + content: "\FA1D"; +} +.mdi-vk::before { + content: "\F579"; +} +.mdi-vk-box::before { + content: "\F57A"; +} +.mdi-vk-circle::before { + content: "\F57B"; +} +.mdi-vlc::before { + content: "\F57C"; +} +.mdi-voice::before { + content: "\F5CB"; +} +.mdi-voice-off::before { + content: "\FEF1"; +} +.mdi-voicemail::before { + content: "\F57D"; +} +.mdi-volleyball::before { + content: "\F9B3"; +} +.mdi-volume-high::before { + content: "\F57E"; +} +.mdi-volume-low::before { + content: "\F57F"; +} +.mdi-volume-medium::before { + content: "\F580"; +} +.mdi-volume-minus::before { + content: "\F75D"; +} +.mdi-volume-mute::before { + content: "\F75E"; +} +.mdi-volume-off::before { + content: "\F581"; +} +.mdi-volume-plus::before { + content: "\F75C"; +} +.mdi-volume-variant-off::before { + content: "\FE68"; +} +.mdi-vote::before { + content: "\FA1E"; +} +.mdi-vote-outline::before { + content: "\FA1F"; +} +.mdi-vpn::before { + content: "\F582"; +} +.mdi-vuejs::before { + content: "\F843"; +} +.mdi-vuetify::before { + content: "\FE50"; +} +.mdi-walk::before { + content: "\F583"; +} +.mdi-wall::before { + content: "\F7FD"; +} +.mdi-wall-sconce::before { + content: "\F91B"; +} +.mdi-wall-sconce-flat::before { + content: "\F91C"; +} +.mdi-wall-sconce-variant::before { + content: "\F91D"; +} +.mdi-wallet::before { + content: "\F584"; +} +.mdi-wallet-giftcard::before { + content: "\F585"; +} +.mdi-wallet-membership::before { + content: "\F586"; +} +.mdi-wallet-outline::before { + content: "\FBB9"; +} +.mdi-wallet-plus::before { + content: "\FFAB"; +} +.mdi-wallet-plus-outline::before { + content: "\FFAC"; +} +.mdi-wallet-travel::before { + content: "\F587"; +} +.mdi-wallpaper::before { + content: "\FE69"; +} +.mdi-wan::before { + content: "\F588"; +} +.mdi-wardrobe::before { + content: "\FFAD"; +} +.mdi-wardrobe-outline::before { + content: "\FFAE"; +} +.mdi-warehouse::before { + content: "\FFBB"; +} +.mdi-washing-machine::before { + content: "\F729"; +} +.mdi-watch::before { + content: "\F589"; +} +.mdi-watch-export::before { + content: "\F58A"; +} +.mdi-watch-export-variant::before { + content: "\F894"; +} +.mdi-watch-import::before { + content: "\F58B"; +} +.mdi-watch-import-variant::before { + content: "\F895"; +} +.mdi-watch-variant::before { + content: "\F896"; +} +.mdi-watch-vibrate::before { + content: "\F6B0"; +} +.mdi-watch-vibrate-off::before { + content: "\FCB6"; +} +.mdi-water::before { + content: "\F58C"; +} +.mdi-water-boiler::before { + content: "\FFAF"; +} +.mdi-water-off::before { + content: "\F58D"; +} +.mdi-water-outline::before { + content: "\FE6A"; +} +.mdi-water-percent::before { + content: "\F58E"; +} +.mdi-water-pump::before { + content: "\F58F"; +} +.mdi-water-pump-off::before { + content: "\FFB0"; +} +.mdi-watermark::before { + content: "\F612"; +} +.mdi-wave::before { + content: "\FF4B"; +} +.mdi-waves::before { + content: "\F78C"; +} +.mdi-waze::before { + content: "\FBBA"; +} +.mdi-weather-cloudy::before { + content: "\F590"; +} +.mdi-weather-cloudy-alert::before { + content: "\FF4C"; +} +.mdi-weather-cloudy-arrow-right::before { + content: "\FE51"; +} +.mdi-weather-fog::before { + content: "\F591"; +} +.mdi-weather-hail::before { + content: "\F592"; +} +.mdi-weather-hazy::before { + content: "\FF4D"; +} +.mdi-weather-hurricane::before { + content: "\F897"; +} +.mdi-weather-lightning::before { + content: "\F593"; +} +.mdi-weather-lightning-rainy::before { + content: "\F67D"; +} +.mdi-weather-night::before { + content: "\F594"; +} +.mdi-weather-night-partly-cloudy::before { + content: "\FF4E"; +} +.mdi-weather-partly-cloudy::before { + content: "\F595"; +} +.mdi-weather-partly-lightning::before { + content: "\FF4F"; +} +.mdi-weather-partly-rainy::before { + content: "\FF50"; +} +.mdi-weather-partly-snowy::before { + content: "\FF51"; +} +.mdi-weather-partly-snowy-rainy::before { + content: "\FF52"; +} +.mdi-weather-pouring::before { + content: "\F596"; +} +.mdi-weather-rainy::before { + content: "\F597"; +} +.mdi-weather-snowy::before { + content: "\F598"; +} +.mdi-weather-snowy-heavy::before { + content: "\FF53"; +} +.mdi-weather-snowy-rainy::before { + content: "\F67E"; +} +.mdi-weather-sunny::before { + content: "\F599"; +} +.mdi-weather-sunny-alert::before { + content: "\FF54"; +} +.mdi-weather-sunset::before { + content: "\F59A"; +} +.mdi-weather-sunset-down::before { + content: "\F59B"; +} +.mdi-weather-sunset-up::before { + content: "\F59C"; +} +.mdi-weather-tornado::before { + content: "\FF55"; +} +.mdi-weather-windy::before { + content: "\F59D"; +} +.mdi-weather-windy-variant::before { + content: "\F59E"; +} +.mdi-web::before { + content: "\F59F"; +} +.mdi-web-box::before { + content: "\FFB1"; +} +.mdi-webcam::before { + content: "\F5A0"; +} +.mdi-webhook::before { + content: "\F62F"; +} +.mdi-webpack::before { + content: "\F72A"; +} +.mdi-wechat::before { + content: "\F611"; +} +.mdi-weight::before { + content: "\F5A1"; +} +.mdi-weight-gram::before { + content: "\FD1B"; +} +.mdi-weight-kilogram::before { + content: "\F5A2"; +} +.mdi-weight-pound::before { + content: "\F9B4"; +} +.mdi-whatsapp::before { + content: "\F5A3"; +} +.mdi-wheelchair-accessibility::before { + content: "\F5A4"; +} +.mdi-whistle::before { + content: "\F9B5"; +} +.mdi-white-balance-auto::before { + content: "\F5A5"; +} +.mdi-white-balance-incandescent::before { + content: "\F5A6"; +} +.mdi-white-balance-iridescent::before { + content: "\F5A7"; +} +.mdi-white-balance-sunny::before { + content: "\F5A8"; +} +.mdi-widgets::before { + content: "\F72B"; +} +.mdi-wifi::before { + content: "\F5A9"; +} +.mdi-wifi-off::before { + content: "\F5AA"; +} +.mdi-wifi-star::before { + content: "\FE6B"; +} +.mdi-wifi-strength-1::before { + content: "\F91E"; +} +.mdi-wifi-strength-1-alert::before { + content: "\F91F"; +} +.mdi-wifi-strength-1-lock::before { + content: "\F920"; +} +.mdi-wifi-strength-2::before { + content: "\F921"; +} +.mdi-wifi-strength-2-alert::before { + content: "\F922"; +} +.mdi-wifi-strength-2-lock::before { + content: "\F923"; +} +.mdi-wifi-strength-3::before { + content: "\F924"; +} +.mdi-wifi-strength-3-alert::before { + content: "\F925"; +} +.mdi-wifi-strength-3-lock::before { + content: "\F926"; +} +.mdi-wifi-strength-4::before { + content: "\F927"; +} +.mdi-wifi-strength-4-alert::before { + content: "\F928"; +} +.mdi-wifi-strength-4-lock::before { + content: "\F929"; +} +.mdi-wifi-strength-alert-outline::before { + content: "\F92A"; +} +.mdi-wifi-strength-lock-outline::before { + content: "\F92B"; +} +.mdi-wifi-strength-off::before { + content: "\F92C"; +} +.mdi-wifi-strength-off-outline::before { + content: "\F92D"; +} +.mdi-wifi-strength-outline::before { + content: "\F92E"; +} +.mdi-wii::before { + content: "\F5AB"; +} +.mdi-wiiu::before { + content: "\F72C"; +} +.mdi-wikipedia::before { + content: "\F5AC"; +} +.mdi-wind-turbine::before { + content: "\FD81"; +} +.mdi-window-close::before { + content: "\F5AD"; +} +.mdi-window-closed::before { + content: "\F5AE"; +} +.mdi-window-maximize::before { + content: "\F5AF"; +} +.mdi-window-minimize::before { + content: "\F5B0"; +} +.mdi-window-open::before { + content: "\F5B1"; +} +.mdi-window-restore::before { + content: "\F5B2"; +} +.mdi-windows::before { + content: "\F5B3"; +} +.mdi-windows-classic::before { + content: "\FA20"; +} +.mdi-wiper::before { + content: "\FAE8"; +} +.mdi-wiper-wash::before { + content: "\FD82"; +} +.mdi-wordpress::before { + content: "\F5B4"; +} +.mdi-worker::before { + content: "\F5B5"; +} +.mdi-wrap::before { + content: "\F5B6"; +} +.mdi-wrap-disabled::before { + content: "\FBBB"; +} +.mdi-wrench::before { + content: "\F5B7"; +} +.mdi-wrench-outline::before { + content: "\FBBC"; +} +.mdi-wunderlist::before { + content: "\F5B8"; +} +.mdi-xamarin::before { + content: "\F844"; +} +.mdi-xamarin-outline::before { + content: "\F845"; +} +.mdi-xaml::before { + content: "\F673"; +} +.mdi-xbox::before { + content: "\F5B9"; +} +.mdi-xbox-controller::before { + content: "\F5BA"; +} +.mdi-xbox-controller-battery-alert::before { + content: "\F74A"; +} +.mdi-xbox-controller-battery-charging::before { + content: "\FA21"; +} +.mdi-xbox-controller-battery-empty::before { + content: "\F74B"; +} +.mdi-xbox-controller-battery-full::before { + content: "\F74C"; +} +.mdi-xbox-controller-battery-low::before { + content: "\F74D"; +} +.mdi-xbox-controller-battery-medium::before { + content: "\F74E"; +} +.mdi-xbox-controller-battery-unknown::before { + content: "\F74F"; +} +.mdi-xbox-controller-menu::before { + content: "\FE52"; +} +.mdi-xbox-controller-off::before { + content: "\F5BB"; +} +.mdi-xbox-controller-view::before { + content: "\FE53"; +} +.mdi-xda::before { + content: "\F5BC"; +} +.mdi-xing::before { + content: "\F5BD"; +} +.mdi-xing-box::before { + content: "\F5BE"; +} +.mdi-xing-circle::before { + content: "\F5BF"; +} +.mdi-xml::before { + content: "\F5C0"; +} +.mdi-xmpp::before { + content: "\F7FE"; +} +.mdi-yahoo::before { + content: "\FB2A"; +} +.mdi-yammer::before { + content: "\F788"; +} +.mdi-yeast::before { + content: "\F5C1"; +} +.mdi-yelp::before { + content: "\F5C2"; +} +.mdi-yin-yang::before { + content: "\F67F"; +} +.mdi-youtube::before { + content: "\F5C3"; +} +.mdi-youtube-creator-studio::before { + content: "\F846"; +} +.mdi-youtube-gaming::before { + content: "\F847"; +} +.mdi-youtube-subscription::before { + content: "\FD1C"; +} +.mdi-youtube-tv::before { + content: "\F448"; +} +.mdi-z-wave::before { + content: "\FAE9"; +} +.mdi-zend::before { + content: "\FAEA"; +} +.mdi-zigbee::before { + content: "\FD1D"; +} +.mdi-zip-box::before { + content: "\F5C4"; +} +.mdi-zip-disk::before { + content: "\FA22"; +} +.mdi-zodiac-aquarius::before { + content: "\FA7C"; +} +.mdi-zodiac-aries::before { + content: "\FA7D"; +} +.mdi-zodiac-cancer::before { + content: "\FA7E"; +} +.mdi-zodiac-capricorn::before { + content: "\FA7F"; +} +.mdi-zodiac-gemini::before { + content: "\FA80"; +} +.mdi-zodiac-leo::before { + content: "\FA81"; +} +.mdi-zodiac-libra::before { + content: "\FA82"; +} +.mdi-zodiac-pisces::before { + content: "\FA83"; +} +.mdi-zodiac-sagittarius::before { + content: "\FA84"; +} +.mdi-zodiac-scorpio::before { + content: "\FA85"; +} +.mdi-zodiac-taurus::before { + content: "\FA86"; +} +.mdi-zodiac-virgo::before { + content: "\FA87"; +} +.mdi-blank::before { + content: "\F68C"; + visibility: hidden; +} +.mdi-18px.mdi-set, +.mdi-18px.mdi:before { + font-size: 18px; +} +.mdi-24px.mdi-set, +.mdi-24px.mdi:before { + font-size: 24px; +} +.mdi-36px.mdi-set, +.mdi-36px.mdi:before { + font-size: 36px; +} +.mdi-48px.mdi-set, +.mdi-48px.mdi:before { + font-size: 48px; +} +.mdi-dark:before { + color: rgba(0, 0, 0, 0.54); +} +.mdi-dark.mdi-inactive:before { + color: rgba(0, 0, 0, 0.26); +} +.mdi-light:before { + color: #fff; +} +.mdi-light.mdi-inactive:before { + color: rgba(255, 255, 255, 0.3); +} +.mdi-rotate-45:before { + -webkit-transform: rotate(45deg); + -ms-transform: rotate(45deg); + transform: rotate(45deg); +} +.mdi-rotate-90:before { + -webkit-transform: rotate(90deg); + -ms-transform: rotate(90deg); + transform: rotate(90deg); +} +.mdi-rotate-135:before { + -webkit-transform: rotate(135deg); + -ms-transform: rotate(135deg); + transform: rotate(135deg); +} +.mdi-rotate-180:before { + -webkit-transform: rotate(180deg); + -ms-transform: rotate(180deg); + transform: rotate(180deg); +} +.mdi-rotate-225:before { + -webkit-transform: rotate(225deg); + -ms-transform: rotate(225deg); + transform: rotate(225deg); +} +.mdi-rotate-270:before { + -webkit-transform: rotate(270deg); + -ms-transform: rotate(270deg); + transform: rotate(270deg); +} +.mdi-rotate-315:before { + -webkit-transform: rotate(315deg); + -ms-transform: rotate(315deg); + transform: rotate(315deg); +} +.mdi-flip-h:before { + -webkit-transform: scaleX(-1); + transform: scaleX(-1); + filter: FlipH; + -ms-filter: "FlipH"; +} +.mdi-flip-v:before { + -webkit-transform: scaleY(-1); + transform: scaleY(-1); + filter: FlipV; + -ms-filter: "FlipV"; +} +.mdi-spin:before { + -webkit-animation: mdi-spin 2s infinite linear; + animation: mdi-spin 2s infinite linear; +} +@-webkit-keyframes mdi-spin { + 0% { + -webkit-transform: rotate(0deg); + transform: rotate(0deg); + } + 100% { + -webkit-transform: rotate(359deg); + transform: rotate(359deg); + } +} +@keyframes mdi-spin { + 0% { + -webkit-transform: rotate(0deg); + transform: rotate(0deg); + } + 100% { + -webkit-transform: rotate(359deg); + transform: rotate(359deg); + } +} +>>>>>>> 42271d072b5508617432803ceb2659d2d3067682 -/*# sourceMappingURL=materialdesignicons.css.map */ \ No newline at end of file +/*# sourceMappingURL=materialdesignicons.css.map */ diff --git a/notemyprogress/db/access.php b/notemyprogress/db/access.php index f3fdcaec36b9c5d8d00a77364b919efdc8d84434..8b11e6e5e62a389c199e19a3d2d5a29dbadbc720 100644 --- a/notemyprogress/db/access.php +++ b/notemyprogress/db/access.php @@ -157,12 +157,35 @@ $capabilities = array( 'student' => CAP_ALLOW, ) ), +<<<<<<< HEAD 'local/notemyprogress:student_planning' => array( +======= + 'local/notemyprogress:teacher_gamification' => array( + 'captype' => 'read', + 'contextlevel' => CONTEXT_COURSE, + 'archetypes' => array( + 'teacher' => CAP_ALLOW, + 'editingteacher' => CAP_ALLOW, + 'manager' => CAP_ALLOW + ) + ), + 'local/notemyprogress:student_gamification' => array( +>>>>>>> 42271d072b5508617432803ceb2659d2d3067682 'captype' => 'read', 'contextlevel' => CONTEXT_COURSE, 'archetypes' => array( 'student' => CAP_ALLOW, ) ), +<<<<<<< HEAD +======= + 'local/notemyprogress:earnxp' => array( + 'captype' => 'read', + 'contextlevel' => CONTEXT_MODULE, + 'archetypes' => array( + 'student' => CAP_ALLOW + ), + ), +>>>>>>> 42271d072b5508617432803ceb2659d2d3067682 ); diff --git a/notemyprogress/db/events.php b/notemyprogress/db/events.php new file mode 100644 index 0000000000000000000000000000000000000000..7a10a57177ecef0ccf703d1627f16cecf33da2d9 --- /dev/null +++ b/notemyprogress/db/events.php @@ -0,0 +1,38 @@ +<?php +// This file is part of Moodle - http://moodle.org/ +// +// Moodle is free software: you can redistribute it and/or modify +// it under the terms of the GNU General Public License as published by +// the Free Software Foundation, either version 3 of the License, or +// (at your option) any later version. +// +// Moodle is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +// GNU General Public License for more details. +// +// You should have received a copy of the GNU General Public License +// along with Moodle. If not, see <http://www.gnu.org/licenses/>. + +/** + * Observers + * + * @package local_notemyprogress + * @autor Edisson Sigua, Bryan Aguilar + * @copyright 2020 Edisson Sigua <edissonf.sigua@gmail.com>, Bryan Aguilar <bryan.aguilar6174@gmail.com> + * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later + */ + +defined('MOODLE_INTERNAL') || die(); + +$observers = [ + [ + 'eventname' => '*', + 'callback' => 'local_notemyprogress\\observer\\observer::catch_all', + 'internal' => false + ], + [ + 'eventname' => '\\core\\event\\course_deleted', + 'callback' => 'local_notemyprogress\\observer\\observer::course_deleted' + ] +]; \ No newline at end of file diff --git a/notemyprogress/db/install.php b/notemyprogress/db/install.php index 8637b100e653bf6c1f68b91f7f65621298e8087f..06c46a760f6ef6b24ef590a5489ee55417102063 100644 --- a/notemyprogress/db/install.php +++ b/notemyprogress/db/install.php @@ -28,6 +28,7 @@ defined('MOODLE_INTERNAL') || die(); /** * Custom code to be run on installing the plugin. */ +<<<<<<< HEAD function xmldb_local_notemyprogress_install() { global $DB; @@ -155,4 +156,8 @@ function xmldb_local_notemyprogress_install() $answer->questionid = $questionid; $answer->enunciated = 'answers_number_four_option_four'; $DB->insert_record("st_rpt_answers", $answer, true); +======= +function xmldb_local_notemyprogress_install() { + return true; +>>>>>>> 42271d072b5508617432803ceb2659d2d3067682 } diff --git a/notemyprogress/db/install.xml b/notemyprogress/db/install.xml index c1225693c1d0358a0b3c84b706bd8b76be010d0a..fda68475ab3794e4b100139a0236af5475adc5b7 100644 --- a/notemyprogress/db/install.xml +++ b/notemyprogress/db/install.xml @@ -1,5 +1,6 @@ <?xml version="1.0" encoding="UTF-8" ?> <XMLDB PATH="local/notemyprogress/db" VERSION="2020111000" COMMENT="XMLDB file for Moodle local/notemyprogress" +<<<<<<< HEAD xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="../../../lib/xmldb/xmldb.xsd"> <TABLES> <TABLE NAME="notemyprogress_instances" COMMENT="table notemyprogress_instances"> @@ -199,5 +200,162 @@ <INDEX NAME="userid" UNIQUE="false" FIELDS="userid" HINTS="userid" COMMENT="userid index"/> </INDEXES> </TABLE> +======= + xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" + xsi:noNamespaceSchemaLocation="../../../lib/xmldb/xmldb.xsd" +> + <TABLES> + <TABLE NAME="notemyprogress_instances" COMMENT="table notemyprogress_instances"> + <FIELDS> + <FIELD NAME="id" TYPE="int" LENGTH="10" NOTNULL="true" SEQUENCE="true"/> + <FIELD NAME="courseid" TYPE="int" LENGTH="20" NOTNULL="true" DEFAULT="0" SEQUENCE="false"/> + <FIELD NAME="year" TYPE="int" LENGTH="20" NOTNULL="true" DEFAULT="0" SEQUENCE="false"/> + </FIELDS> + <KEYS> + <KEY NAME="primary" TYPE="primary" FIELDS="id"/> + </KEYS> + </TABLE> + <TABLE NAME="notemyprogress_weeks" COMMENT="table notemyprogress_weeks"> + <FIELDS> + <FIELD NAME="id" TYPE="int" LENGTH="10" NOTNULL="true" SEQUENCE="true"/> + <FIELD NAME="instanceid" TYPE="int" LENGTH="20" NOTNULL="true" SEQUENCE="false"/> + <FIELD NAME="courseid" TYPE="int" LENGTH="10" NOTNULL="true" SEQUENCE="false"/> + <FIELD NAME="weekstart" TYPE="int" LENGTH="10" NOTNULL="true" SEQUENCE="false"/> + <FIELD NAME="weekend" TYPE="int" LENGTH="10" NOTNULL="true" SEQUENCE="false"/> + <FIELD NAME="position" TYPE="int" LENGTH="10" NOTNULL="true" SEQUENCE="false"/> + <FIELD NAME="modified_by" TYPE="int" LENGTH="10" NOTNULL="true" SEQUENCE="false"/> + <FIELD NAME="created_by" TYPE="int" LENGTH="10" NOTNULL="true" SEQUENCE="false"/> + <FIELD NAME="timedeleted" TYPE="int" LENGTH="10" NOTNULL="false" SEQUENCE="false"/> + <FIELD NAME="timecreated" TYPE="int" LENGTH="10" NOTNULL="true" SEQUENCE="false"/> + <FIELD NAME="timemodified" TYPE="int" LENGTH="10" NOTNULL="false" SEQUENCE="false"/> + <FIELD NAME="weekcode" TYPE="int" LENGTH="20" NOTNULL="true" SEQUENCE="false"/> + <FIELD NAME="hours_dedications" TYPE="int" LENGTH="5" NOTNULL="true" DEFAULT="0" SEQUENCE="false" COMMENT="hours_dedications"/> + </FIELDS> + <KEYS> + <KEY NAME="primary" TYPE="primary" FIELDS="id"/> + </KEYS> + <INDEXES> + <INDEX NAME="weekcode" UNIQUE="false" FIELDS="weekcode" HINTS="weekcode" COMMENT="weekcode index"/> + <INDEX NAME="instanceid" UNIQUE="false" FIELDS="instanceid" HINTS="instanceid" COMMENT="instanceid index"/> + </INDEXES> + </TABLE> + <TABLE NAME="notemyprogress_sections" COMMENT="table notemyprogress_sections"> + <FIELDS> + <FIELD NAME="id" TYPE="int" LENGTH="10" NOTNULL="true" SEQUENCE="true"/> + <FIELD NAME="weekcode" TYPE="int" LENGTH="10" NOTNULL="true" SEQUENCE="false"/> + <FIELD NAME="sectionid" TYPE="int" LENGTH="10" NOTNULL="true" SEQUENCE="false"/> + <FIELD NAME="section_name" TYPE="char" LENGTH="1333" NOTNULL="true" SEQUENCE="false"/> + <FIELD NAME="position" TYPE="int" LENGTH="10" NOTNULL="true" SEQUENCE="false"/> + <FIELD NAME="timedeleted" TYPE="int" LENGTH="10" NOTNULL="false" SEQUENCE="false"/> + <FIELD NAME="timecreated" TYPE="int" LENGTH="10" NOTNULL="true" SEQUENCE="false"/> + <FIELD NAME="timemodified" TYPE="int" LENGTH="10" NOTNULL="false" SEQUENCE="false"/> + </FIELDS> + <KEYS> + <KEY NAME="primary" TYPE="primary" FIELDS="id"/> + </KEYS> + </TABLE> + <TABLE NAME="notemyprogress_logs" COMMENT="table notemyprogress_logs"> + <FIELDS> + <FIELD NAME="id" TYPE="int" LENGTH="10" NOTNULL="true" SEQUENCE="true"/> + <FIELD NAME="userid" TYPE="int" LENGTH="10" NOTNULL="true" SEQUENCE="false"/> + <FIELD NAME="username" TYPE="text" NOTNULL="false" SEQUENCE="false"/> + <FIELD NAME="name" TYPE="char" LENGTH="1333" NOTNULL="false" SEQUENCE="false"/> + <FIELD NAME="lastname" TYPE="char" LENGTH="1333" NOTNULL="false" SEQUENCE="false"/> + <FIELD NAME="email" TYPE="char" LENGTH="1333" NOTNULL="false" SEQUENCE="false"/> + <FIELD NAME="current_roles" TYPE="char" LENGTH="1333" NOTNULL="true" SEQUENCE="false"/> + <FIELD NAME="courseid" TYPE="int" LENGTH="10" NOTNULL="true" SEQUENCE="false"/> + <FIELD NAME="component" TYPE="char" LENGTH="1333" NOTNULL="true" SEQUENCE="false"/> + <FIELD NAME="action" TYPE="char" LENGTH="1333" NOTNULL="true" SEQUENCE="false"/> + <FIELD NAME="timecreated" TYPE="int" LENGTH="10" NOTNULL="true" SEQUENCE="false"/> + </FIELDS> + <KEYS> + <KEY NAME="primary" TYPE="primary" FIELDS="id"/> + </KEYS> + </TABLE> + <TABLE NAME="notemyprogress_clustering" COMMENT="table notemyprogress_clustering"> + <FIELDS> + <FIELD NAME="id" TYPE="int" LENGTH="10" NOTNULL="true" SEQUENCE="true"/> + <FIELD NAME="courseid" TYPE="int" LENGTH="10" NOTNULL="true" SEQUENCE="false"/> + <FIELD NAME="userid" TYPE="int" LENGTH="10" NOTNULL="true" SEQUENCE="false"/> + <FIELD NAME="cluster" TYPE="int" LENGTH="2" NOTNULL="true" SEQUENCE="false"/> + <FIELD NAME="active" TYPE="int" LENGTH="2" NOTNULL="true" SEQUENCE="false"/> + <FIELD NAME="timecreated" TYPE="int" LENGTH="10" NOTNULL="true" SEQUENCE="false"/> + </FIELDS> + <KEYS> + <KEY NAME="primary" TYPE="primary" FIELDS="id"/> + </KEYS> + <INDEXES> + <INDEX NAME="courseid" UNIQUE="false" FIELDS="courseid" HINTS="courseid" COMMENT="courseid index"/> + <INDEX NAME="userid" UNIQUE="false" FIELDS="userid" HINTS="userid" COMMENT="userid index"/> + </INDEXES> + </TABLE> + <TABLE NAME="notemyprogress_levels_data" COMMENT="Default comment for the table, please edit me"> + <FIELDS> + <FIELD NAME="id" TYPE="int" LENGTH="10" NOTNULL="true" SEQUENCE="true"/> + <FIELD NAME="courseid" TYPE="int" LENGTH="10" NOTNULL="false" SEQUENCE="false"/> + <FIELD NAME="levelsdata" TYPE="text" NOTNULL="false" SEQUENCE="false"/> + <FIELD NAME="settings" TYPE="text" NOTNULL="false" SEQUENCE="false"/> + <FIELD NAME="rules" TYPE="text" NOTNULL="false" SEQUENCE="false"/> + <FIELD NAME="created_by" TYPE="int" LENGTH="10" NOTNULL="true" SEQUENCE="false"/> + <FIELD NAME="modified_by" TYPE="int" LENGTH="10" NOTNULL="true" SEQUENCE="false"/> + <FIELD NAME="timecreated" TYPE="int" LENGTH="10" NOTNULL="true" SEQUENCE="false"/> + <FIELD NAME="timemodified" TYPE="int" LENGTH="10" NOTNULL="true" SEQUENCE="false"/> + <FIELD NAME ="timedeleted" TYPE="int" LENGTH="10" NOTNULL="false" SEQUENCE="false"/> + </FIELDS> + <KEYS> + <KEY NAME="primary" TYPE="primary" FIELDS="id"/> + </KEYS> + </TABLE> + <TABLE NAME="notemyprogress_xp" COMMENT="Esta tabla contiene el nivel y los puntos de experiencia de los usuarios"> + <FIELDS> + <FIELD NAME="id" TYPE="int" LENGTH="10" NOTNULL="true" SEQUENCE="true"/> + <FIELD NAME="courseid" TYPE="int" LENGTH="10" NOTNULL="true" SEQUENCE="false"/> + <FIELD NAME="userid" TYPE="int" LENGTH="10" NOTNULL="true" SEQUENCE="false"/> + <FIELD NAME="points" TYPE="int" LENGTH="10" NOTNULL="false" SEQUENCE="false"/> + <FIELD NAME="level" TYPE="int" LENGTH="5" NOTNULL="false" SEQUENCE="false"/> + <FIELD NAME="rankable" TYPE="int" LENGTH="5" NOTNULL="false" SEQUENCE="false"/> + </FIELDS> + <KEYS> + <KEY NAME="primary" TYPE="primary" FIELDS="id"/> + </KEYS> + </TABLE> + <TABLE NAME="notemyprogress_xp_log" COMMENT="Esta tabla almacena los eventos por los cuales los estudiantes reciben puntos de experiencia"> + <FIELDS> + <FIELD NAME="id" TYPE="int" LENGTH="10" NOTNULL="true" SEQUENCE="true"/> + <FIELD NAME="courseid" TYPE="int" LENGTH="10" NOTNULL="false" SEQUENCE="false"/> + <FIELD NAME="userid" TYPE="int" LENGTH="10" NOTNULL="true" SEQUENCE="false"/> + <FIELD NAME="event" TYPE="text" NOTNULL="false" SEQUENCE="false"/> + <FIELD NAME="points" TYPE="int" LENGTH="10" NOTNULL="false" SEQUENCE="false"/> + <FIELD NAME="timecreated" TYPE="int" LENGTH="10" NOTNULL="true" SEQUENCE="false"/> + </FIELDS> + <KEYS> + <KEY NAME="primary" TYPE="primary" FIELDS="id"/> + </KEYS> + </TABLE> + <TABLE NAME="notemyprogress_times" COMMENT="notemyprogress students times"> + <FIELDS> + <FIELD NAME="id" TYPE="int" LENGTH="10" NOTNULL="true" SEQUENCE="true"/> + <FIELD NAME="courseid" TYPE="int" LENGTH="10" NOTNULL="true" SEQUENCE="false"/> + <FIELD NAME="userid" TYPE="int" LENGTH="10" NOTNULL="true" SEQUENCE="false"/> + <FIELD NAME="weeks" TYPE="text" NOTNULL="false" SEQUENCE="false"/> + <FIELD NAME="timecreated" TYPE="int" LENGTH="10" NOTNULL="true" SEQUENCE="false"/> + </FIELDS> + <KEYS> + <KEY NAME="primary" TYPE="primary" FIELDS="id"/> + </KEYS> + </TABLE> + <TABLE NAME="notemyprogress_gamification" COMMENT="gamification parameters"> + <FIELDS> + <FIELD NAME="id" TYPE="int" LENGTH="10" NOTNULL="true" SEQUENCE="true"/> + <FIELD NAME="courseid" TYPE="int" LENGTH="10" NOTNULL="true" SEQUENCE="false"/> + <FIELD NAME="userid" TYPE="int" LENGTH="10" NOTNULL="true" SEQUENCE="false"/> + <FIELD NAME="enablegamification" TYPE="int" LENGTH="1" NOTNULL="true" SEQUENCE="false" /> + <FIELD NAME="timecreated" TYPE="int" LENGTH="10" NOTNULL="true" SEQUENCE="false"/> + </FIELDS> + <KEYS> + <KEY NAME="primary" TYPE="primary" FIELDS="id"/> + </KEYS> + </TABLE> +>>>>>>> 42271d072b5508617432803ceb2659d2d3067682 </TABLES> </XMLDB> \ No newline at end of file diff --git a/notemyprogress/db/services.php b/notemyprogress/db/services.php new file mode 100644 index 0000000000000000000000000000000000000000..9784a00f6fd570a83711313ac91fc3bebc5d00a3 --- /dev/null +++ b/notemyprogress/db/services.php @@ -0,0 +1,33 @@ +<?php +// This file is part of Moodle - http://moodle.org/ +// +// Moodle is free software: you can redistribute it and/or modify +// it under the terms of the GNU General Public License as published by +// the Free Software Foundation, either version 3 of the License, or +// (at your option) any later version. +// +// Moodle is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +// GNU General Public License for more details. +// +// You should have received a copy of the GNU General Public License +// along with Moodle. If not, see <http://www.gnu.org/licenses/>. + +/** + * This file defines available ajax calls for mod_millionaire. + * + * @package mod_millionaire + * @copyright 2019 Benedikt Kulmann <b@kulmann.biz> + * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later + */ + +$functions = [ + 'local_notemyprogress_get_levels' => [ + 'classname' => 'local_notemyprogress\external\external', + 'methodname' => 'get_levels', + 'description' => 'Get levels for the game overview.', + 'type' => 'read', + 'ajax' => true, + ], +]; \ No newline at end of file diff --git a/notemyprogress/gamification.php b/notemyprogress/gamification.php new file mode 100644 index 0000000000000000000000000000000000000000..392dac98236677db5eaaea684b5bde729fa11283 --- /dev/null +++ b/notemyprogress/gamification.php @@ -0,0 +1,132 @@ +<?php + +// This file is part of Moodle - http://moodle.org/ +// +// Moodle is free software: you can redistribute it and/or modify +// it under the terms of the GNU General Public License as published by +// the Free Software Foundation, either version 3 of the License, or +// (at your option) any later version. +// +// Moodle is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +// GNU General Public License for more details. +// +// You should have received a copy of the GNU General Public License +// along with Moodle. If not, see <http://www.gnu.org/licenses/>. + +/** + * local notemyprogress + * + * @package local_notemyprogress + * @copyright 2020 Edisson Sigua <edissonf.sigua@gmail.com>, Bryan Aguilar <bryan.aguilar6174@gmail.com> + * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later + */ +require_once('locallib.php'); +global $COURSE, $USER , $DB; + +$courseid = required_param('courseid', PARAM_INT); +$course = $DB->get_record('course', array('id' => $courseid), '*', MUST_EXIST); +$context = context_course::instance($course->id); + +$url = '/local/notemyprogress/gamification.php'; +local_notemyprogress_set_page($course, $url); + +require_capability('local/notemyprogress:usepluggin', $context); +require_capability('local/notemyprogress:teacher_gamification', $context); +require_capability('local/notemyprogress:setweeks', $context); + +$maxTimeSql = "SELECT MAX(timecreated) as maximum from {notemyprogress_gamification} where courseid=? "; +$timecrated = $DB->get_record_sql($maxTimeSql, array("courseid="=>($courseid))); + +$sql = "SELECT enablegamification from {notemyprogress_gamification} where courseid=? AND timecreated=? "; +$value = $DB->get_record_sql($sql, array("courseid="=>($courseid),"timecreated="=>$timecrated->maximum)); +if($value->enablegamification==1){ + $swValue = true; +}else{ + $swValue = false; +} + +$actualLink = (isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] === 'on' ? "https" : "http") . "://$_SERVER[HTTP_HOST]$_SERVER[REQUEST_URI]"; + +$logs = new \local_notemyprogress\logs($COURSE->id, $USER->id); +$logs->addLogsNMP("viewed", "section", "CONFIGURATION_GAMIFICATION", "configuration_gamification", $actualLink, "Section where teacher can configure gamification"); + +$configgamification = new \local_notemyprogress\configgamification($COURSE->id, $USER->id); +$es = new \local_notemyprogress\event_strategy($COURSE, $USER); +$reports = new \local_notemyprogress\teacher($COURSE->id, $USER->id); + + + +$content = [ + 'strings' =>[ + 'title' => get_string('tg_section_title', 'local_notemyprogress'), + 'help_title' => get_string('tg_section_help_title', 'local_notemyprogress'), + 'help_description' => get_string('tg_section_help_description', 'local_notemyprogress'), + 'helplabel' => get_string("helplabel","local_notemyprogress"), + 'error_network' => get_string('fml_api_error_network', 'local_notemyprogress'), + 'save_successful' => get_string('fml_api_save_successful', 'local_notemyprogress'), + 'cancel_action' => get_string('fml_api_cancel_action', 'local_notemyprogress'), + 'save_warning_title' => get_string('tg_save_warning_title', 'local_notemyprogress'), + 'save_warning_content' => get_string('tg_save_warning_content', 'local_notemyprogress'), + 'confirm_ok' => get_string('tg_confirm_ok', 'local_notemyprogress'), + 'confirm_cancel' => get_string('tg_confirm_cancel', 'local_notemyprogress'), + 'exitbutton' => get_string("exitbutton","local_notemyprogress"), + 'save' => get_string("tg_save","local_notemyprogress"), + 'preview' => get_string("tg_section_preview","local_notemyprogress"), + 'information' => get_string("tg_section_information","local_notemyprogress"), + 'ranking' => get_string("tg_section_ranking","local_notemyprogress"), + 'settings' => get_string("tg_section_settings","local_notemyprogress"), + 'points' => get_string("tg_section_points","local_notemyprogress"), + 'no_description' => get_string("tg_section_no_description","local_notemyprogress"), + 'no_name' => get_string("tg_section_no_name","local_notemyprogress"), + 'description' => get_string("tg_section_description","local_notemyprogress"), + 'to_next_level' => get_string("tg_section_preview_next_level","local_notemyprogress"), + 'ranking_text' => get_string("tg_section_ranking_ranking_text","local_notemyprogress"), + 'level' => get_string("tg_section_ranking_level","local_notemyprogress"), + 'student' => get_string("tg_section_ranking_student","local_notemyprogress"), + 'total' => get_string("tg_section_ranking_total","local_notemyprogress"), + 'progress' => get_string("tg_section_ranking_progress","local_notemyprogress"), + 'appearance' => get_string("tg_section_settings_appearance","local_notemyprogress"), + 'appearance_title' => get_string("tg_section_settings_appearance_title","local_notemyprogress"), + 'settings_level' => get_string("tg_section_settings_levels","local_notemyprogress"), + 'quantity' => get_string("tg_section_settings_levels_quantity","local_notemyprogress"), + 'base_points' => get_string("tg_section_settings_levels_base_points","local_notemyprogress"), + 'calculated' => get_string("tg_section_settings_levels_calculated","local_notemyprogress"), + 'manually' => get_string("tg_section_settings_levels_manually","local_notemyprogress"), + 'name' => get_string("tg_section_settings_levels_name","local_notemyprogress"), + 'levels_required' => get_string("tg_section_settings_levels_required","local_notemyprogress"), + 'rules' => get_string("tg_section_settings_rules","local_notemyprogress"), + 'add_rule' => get_string("tg_section_settings_add_rule","local_notemyprogress"), + 'earn' => get_string("tg_section_settings_earn","local_notemyprogress"), + 'select_event' => get_string("tg_section_settings_select_event","local_notemyprogress"), + 'enable'=>get_string("EnableGame","local_notemyprogress"), + 'swValue'=>$swValue, + 'chart' => $reports->get_chart_langs(), + 'pointError'=>get_string("game_point_error","local_notemyprogress"), + 'eventError'=>get_string("game_event_error","local_notemyprogress"), + 'nameError'=>get_string("game_name_error","local_notemyprogress"), + 'chartTitle'=>get_string("gm_Chart_Title","local_notemyprogress"), + 'chartYaxis'=>get_string("gm_Chart_Y","local_notemyprogress"), + ], + 'token' => local_notemyprogress_generate_token($COURSE->id, $USER->id, "teacher"), + 'userid' => $USER->id, + 'courseid' => $courseid, + 'levels_data' => $configgamification->get_levels_data(), + 'ranking' => $es->get_ranking(0), + 'events' => $configgamification->events_list(), + 'image' => $OUTPUT->image_url('badge', 'local_notemyprogress'), + 'indicators' => $reports->get_general_indicators(), + 'profile_render' => $reports->render_has(), + 'timezone' => $reports->timezone, + 'chart_data' => $configgamification->get_spread_chart($COURSE->id), +]; + +$templatecontext = [ + 'image' => $OUTPUT->image_url('badge', 'local_notemyprogress') +]; + +$PAGE->requires->js_call_amd('local_notemyprogress/gamification','init', ['content' => $content]); +echo $OUTPUT->header(); +echo $OUTPUT->render_from_template('local_notemyprogress/gamification', $templatecontext); +echo $OUTPUT->footer(); \ No newline at end of file diff --git a/notemyprogress/js/alertify.js b/notemyprogress/js/alertify.js index 745a8a92965c172f231b528782f35106efec7de0..33a34522a46302071f7a3ef8f509c40a93b2749a 100644 --- a/notemyprogress/js/alertify.js +++ b/notemyprogress/js/alertify.js @@ -1,3609 +1,3831 @@ /** * alertifyjs 1.11.4 http://alertifyjs.com * AlertifyJS is a javascript framework for developing pretty browser dialogs and notifications. - * Copyright 2019 Mohammad Younes <Mohammad@alertifyjs.com> (http://alertifyjs.com) + * Copyright 2019 Mohammad Younes <Mohammad@alertifyjs.com> (http://alertifyjs.com) * Licensed under GPL 3 <https://opensource.org/licenses/gpl-3.0>*/ -( function ( window ) { - 'use strict'; - +(function (window) { + "use strict"; + + /** + * Keys enum + * @type {Object} + */ + var keys = { + ENTER: 13, + ESC: 27, + F1: 112, + F12: 123, + LEFT: 37, + RIGHT: 39, + }; + /** + * Default options + * @type {Object} + */ + var defaults = { + autoReset: true, + basic: false, + closable: true, + closableByDimmer: true, + frameless: false, + maintainFocus: true, //global default not per instance, applies to all dialogs + maximizable: true, + modal: true, + movable: true, + moveBounded: false, + overflow: true, + padding: true, + pinnable: true, + pinned: true, + preventBodyShift: false, //global default not per instance, applies to all dialogs + resizable: true, + startMaximized: false, + transition: "pulse", + notifier: { + delay: 5, + position: "bottom-right", + closeButton: false, + }, + glossary: { + title: "AlertifyJS", + ok: "OK", + cancel: "Cancel", + acccpt: "Accept", + deny: "Deny", + confirm: "Confirm", + decline: "Decline", + close: "Close", + maximize: "Maximize", + restore: "Restore", + }, + theme: { + input: "ajs-input", + ok: "ajs-ok", + cancel: "ajs-cancel", + }, + }; + + //holds open dialogs instances + var openDialogs = []; + + /** + * [Helper] Adds the specified class(es) to the element. + * + * @element {node} The element + * @className {string} One or more space-separated classes to be added to the class attribute of the element. + * + * @return {undefined} + */ + function addClass(element, classNames) { + element.className += " " + classNames; + } + + /** + * [Helper] Removes the specified class(es) from the element. + * + * @element {node} The element + * @className {string} One or more space-separated classes to be removed from the class attribute of the element. + * + * @return {undefined} + */ + function removeClass(element, classNames) { + var original = element.className.split(" "); + var toBeRemoved = classNames.split(" "); + for (var x = 0; x < toBeRemoved.length; x += 1) { + var index = original.indexOf(toBeRemoved[x]); + if (index > -1) { + original.splice(index, 1); + } + } + element.className = original.join(" "); + } + + /** + * [Helper] Checks if the document is RTL + * + * @return {Boolean} True if the document is RTL, false otherwise. + */ + function isRightToLeft() { + return window.getComputedStyle(document.body).direction === "rtl"; + } + /** + * [Helper] Get the document current scrollTop + * + * @return {Number} current document scrollTop value + */ + function getScrollTop() { + return ( + (document.documentElement && document.documentElement.scrollTop) || + document.body.scrollTop + ); + } + + /** + * [Helper] Get the document current scrollLeft + * + * @return {Number} current document scrollLeft value + */ + function getScrollLeft() { + return ( + (document.documentElement && document.documentElement.scrollLeft) || + document.body.scrollLeft + ); + } + + /** + * Helper: clear contents + * + */ + function clearContents(element) { + while (element.lastChild) { + element.removeChild(element.lastChild); + } + } + /** + * Extends a given prototype by merging properties from base into sub. + * + * @sub {Object} sub The prototype being overwritten. + * @base {Object} base The prototype being written. + * + * @return {Object} The extended prototype. + */ + function copy(src) { + if (null === src) { + return src; + } + var cpy; + if (Array.isArray(src)) { + cpy = []; + for (var x = 0; x < src.length; x += 1) { + cpy.push(copy(src[x])); + } + return cpy; + } + + if (src instanceof Date) { + return new Date(src.getTime()); + } + + if (src instanceof RegExp) { + cpy = new RegExp(src.source); + cpy.global = src.global; + cpy.ignoreCase = src.ignoreCase; + cpy.multiline = src.multiline; + cpy.lastIndex = src.lastIndex; + return cpy; + } + + if (typeof src === "object") { + cpy = {}; + // copy dialog pototype over definition. + for (var prop in src) { + if (src.hasOwnProperty(prop)) { + cpy[prop] = copy(src[prop]); + } + } + return cpy; + } + return src; + } + /** + * Helper: destruct the dialog + * + */ + function destruct(instance, initialize) { + if (instance.elements) { + //delete the dom and it's references. + var root = instance.elements.root; + root.parentNode.removeChild(root); + delete instance.elements; + //copy back initial settings. + instance.settings = copy(instance.__settings); + //re-reference init function. + instance.__init = initialize; + //delete __internal variable to allow re-initialization. + delete instance.__internal; + } + } + + /** + * Use a closure to return proper event listener method. Try to use + * `addEventListener` by default but fallback to `attachEvent` for + * unsupported browser. The closure simply ensures that the test doesn't + * happen every time the method is called. + * + * @param {Node} el Node element + * @param {String} event Event type + * @param {Function} fn Callback of event + * @return {Function} + */ + var on = (function () { + if (document.addEventListener) { + return function (el, event, fn, useCapture) { + el.addEventListener(event, fn, useCapture === true); + }; + } else if (document.attachEvent) { + return function (el, event, fn) { + el.attachEvent("on" + event, fn); + }; + } + })(); + + /** + * Use a closure to return proper event listener method. Try to use + * `removeEventListener` by default but fallback to `detachEvent` for + * unsupported browser. The closure simply ensures that the test doesn't + * happen every time the method is called. + * + * @param {Node} el Node element + * @param {String} event Event type + * @param {Function} fn Callback of event + * @return {Function} + */ + var off = (function () { + if (document.removeEventListener) { + return function (el, event, fn, useCapture) { + el.removeEventListener(event, fn, useCapture === true); + }; + } else if (document.detachEvent) { + return function (el, event, fn) { + el.detachEvent("on" + event, fn); + }; + } + })(); + + /** + * Prevent default event from firing + * + * @param {Event} event Event object + * @return {undefined} + + function prevent ( event ) { + if ( event ) { + if ( event.preventDefault ) { + event.preventDefault(); + } else { + event.returnValue = false; + } + } + } + */ + var transition = (function () { + var t, type; + var supported = false; + var transitions = { + animation: "animationend", + OAnimation: "oAnimationEnd oanimationend", + msAnimation: "MSAnimationEnd", + MozAnimation: "animationend", + WebkitAnimation: "webkitAnimationEnd", + }; + + for (t in transitions) { + if (document.documentElement.style[t] !== undefined) { + type = transitions[t]; + supported = true; + break; + } + } + + return { + type: type, + supported: supported, + }; + })(); + + /** + * Creates event handler delegate that sends the instance as last argument. + * + * @return {Function} a function wrapper which sends the instance as last argument. + */ + function delegate(context, method) { + return function () { + if (arguments.length > 0) { + var args = []; + for (var x = 0; x < arguments.length; x += 1) { + args.push(arguments[x]); + } + args.push(context); + return method.apply(context, args); + } + return method.apply(context, [null, context]); + }; + } + /** + * Helper for creating a dialog close event. + * + * @return {object} + */ + function createCloseEvent(index, button) { + return { + index: index, + button: button, + cancel: false, + }; + } + /** + * Helper for dispatching events. + * + * @param {string} evenType The type of the event to disptach. + * @param {object} instance The dialog instance disptaching the event. + * + * @return {any} The result of the invoked function. + */ + function dispatchEvent(eventType, instance) { + if (typeof instance.get(eventType) === "function") { + return instance.get(eventType).call(instance); + } + } + + /** + * Super class for all dialogs + * + * @return {Object} base dialog prototype + */ + var dialog = (function () { + var //holds the list of used keys. + usedKeys = [], + //dummy variable, used to trigger dom reflow. + reflow = null, + //holds body tab index in case it has any. + tabindex = false, + //condition for detecting safari + isSafari = + window.navigator.userAgent.indexOf("Safari") > -1 && + window.navigator.userAgent.indexOf("Chrome") < 0, + //dialog building blocks + templates = { + dimmer: '<div class="ajs-dimmer"></div>', + /*tab index required to fire click event before body focus*/ + modal: '<div class="ajs-modal" tabindex="0"></div>', + dialog: '<div class="ajs-dialog" tabindex="0"></div>', + reset: '<button class="ajs-reset"></button>', + commands: + '<div class="ajs-commands"><button class="ajs-pin"></button><button class="ajs-maximize"></button><button class="ajs-close"></button></div>', + header: '<div class="ajs-header"></div>', + body: '<div class="ajs-body"></div>', + content: '<div class="ajs-content"></div>', + footer: '<div class="ajs-footer"></div>', + buttons: { + primary: '<div class="ajs-primary ajs-buttons"></div>', + auxiliary: '<div class="ajs-auxiliary ajs-buttons"></div>', + }, + button: '<button class="ajs-button"></button>', + resizeHandle: '<div class="ajs-handle"></div>', + }, + //common class names + classes = { + animationIn: "ajs-in", + animationOut: "ajs-out", + base: "alertify", + basic: "ajs-basic", + capture: "ajs-capture", + closable: "ajs-closable", + fixed: "ajs-fixed", + frameless: "ajs-frameless", + hidden: "ajs-hidden", + maximize: "ajs-maximize", + maximized: "ajs-maximized", + maximizable: "ajs-maximizable", + modeless: "ajs-modeless", + movable: "ajs-movable", + noSelection: "ajs-no-selection", + noOverflow: "ajs-no-overflow", + noPadding: "ajs-no-padding", + pin: "ajs-pin", + pinnable: "ajs-pinnable", + prefix: "ajs-", + resizable: "ajs-resizable", + restore: "ajs-restore", + shake: "ajs-shake", + unpinned: "ajs-unpinned", + }; + /** - * Keys enum - * @type {Object} + * Helper: initializes the dialog instance + * + * @return {Number} The total count of currently open modals. */ - var keys = { - ENTER: 13, - ESC: 27, - F1: 112, - F12: 123, - LEFT: 37, - RIGHT: 39 - }; + function initialize(instance) { + if (!instance.__internal) { + //no need to expose init after this. + delete instance.__init; + + //keep a copy of initial dialog settings + if (!instance.__settings) { + instance.__settings = copy(instance.settings); + } + + //get dialog buttons/focus setup + var setup; + if (typeof instance.setup === "function") { + setup = instance.setup(); + setup.options = setup.options || {}; + setup.focus = setup.focus || {}; + } else { + setup = { + buttons: [], + focus: { + element: null, + select: false, + }, + options: {}, + }; + } + + //initialize hooks object. + if (typeof instance.hooks !== "object") { + instance.hooks = {}; + } + + //copy buttons defintion + var buttonsDefinition = []; + if (Array.isArray(setup.buttons)) { + for (var b = 0; b < setup.buttons.length; b += 1) { + var ref = setup.buttons[b], + cpy = {}; + for (var i in ref) { + if (ref.hasOwnProperty(i)) { + cpy[i] = ref[i]; + } + } + buttonsDefinition.push(cpy); + } + } + + var internal = (instance.__internal = { + /** + * Flag holding the open state of the dialog + * + * @type {Boolean} + */ + isOpen: false, + /** + * Active element is the element that will receive focus after + * closing the dialog. It defaults as the body tag, but gets updated + * to the last focused element before the dialog was opened. + * + * @type {Node} + */ + activeElement: document.body, + timerIn: undefined, + timerOut: undefined, + buttons: buttonsDefinition, + focus: setup.focus, + options: { + title: undefined, + modal: undefined, + basic: undefined, + frameless: undefined, + pinned: undefined, + movable: undefined, + moveBounded: undefined, + resizable: undefined, + autoReset: undefined, + closable: undefined, + closableByDimmer: undefined, + maximizable: undefined, + startMaximized: undefined, + pinnable: undefined, + transition: undefined, + padding: undefined, + overflow: undefined, + onshow: undefined, + onclosing: undefined, + onclose: undefined, + onfocus: undefined, + onmove: undefined, + onmoved: undefined, + onresize: undefined, + onresized: undefined, + onmaximize: undefined, + onmaximized: undefined, + onrestore: undefined, + onrestored: undefined, + }, + resetHandler: undefined, + beginMoveHandler: undefined, + beginResizeHandler: undefined, + bringToFrontHandler: undefined, + modalClickHandler: undefined, + buttonsClickHandler: undefined, + commandsClickHandler: undefined, + transitionInHandler: undefined, + transitionOutHandler: undefined, + destroy: undefined, + }); + + var elements = {}; + //root node + elements.root = document.createElement("div"); + //prevent FOUC in case of async styles loading. + elements.root.style.display = "none"; + elements.root.className = classes.base + " " + classes.hidden + " "; + + elements.root.innerHTML = templates.dimmer + templates.modal; + + //dimmer + elements.dimmer = elements.root.firstChild; + + //dialog + elements.modal = elements.root.lastChild; + elements.modal.innerHTML = templates.dialog; + elements.dialog = elements.modal.firstChild; + elements.dialog.innerHTML = + templates.reset + + templates.commands + + templates.header + + templates.body + + templates.footer + + templates.resizeHandle + + templates.reset; + + //reset links + elements.reset = []; + elements.reset.push(elements.dialog.firstChild); + elements.reset.push(elements.dialog.lastChild); + + //commands + elements.commands = {}; + elements.commands.container = elements.reset[0].nextSibling; + elements.commands.pin = elements.commands.container.firstChild; + elements.commands.maximize = elements.commands.pin.nextSibling; + elements.commands.close = elements.commands.maximize.nextSibling; + + //header + elements.header = elements.commands.container.nextSibling; + + //body + elements.body = elements.header.nextSibling; + elements.body.innerHTML = templates.content; + elements.content = elements.body.firstChild; + + //footer + elements.footer = elements.body.nextSibling; + elements.footer.innerHTML = + templates.buttons.auxiliary + templates.buttons.primary; + + //resize handle + elements.resizeHandle = elements.footer.nextSibling; + + //buttons + elements.buttons = {}; + elements.buttons.auxiliary = elements.footer.firstChild; + elements.buttons.primary = elements.buttons.auxiliary.nextSibling; + elements.buttons.primary.innerHTML = templates.button; + elements.buttonTemplate = elements.buttons.primary.firstChild; + //remove button template + elements.buttons.primary.removeChild(elements.buttonTemplate); + + for (var x = 0; x < instance.__internal.buttons.length; x += 1) { + var button = instance.__internal.buttons[x]; + + // add to the list of used keys. + if (usedKeys.indexOf(button.key) < 0) { + usedKeys.push(button.key); + } + + button.element = elements.buttonTemplate.cloneNode(); + button.element.innerHTML = button.text; + if (typeof button.className === "string" && button.className !== "") { + addClass(button.element, button.className); + } + for (var key in button.attrs) { + if (key !== "className" && button.attrs.hasOwnProperty(key)) { + button.element.setAttribute(key, button.attrs[key]); + } + } + if (button.scope === "auxiliary") { + elements.buttons.auxiliary.appendChild(button.element); + } else { + elements.buttons.primary.appendChild(button.element); + } + } + //make elements pubic + instance.elements = elements; + + //save event handlers delegates + internal.resetHandler = delegate(instance, onReset); + internal.beginMoveHandler = delegate(instance, beginMove); + internal.beginResizeHandler = delegate(instance, beginResize); + internal.bringToFrontHandler = delegate(instance, bringToFront); + internal.modalClickHandler = delegate(instance, modalClickHandler); + internal.buttonsClickHandler = delegate(instance, buttonsClickHandler); + internal.commandsClickHandler = delegate( + instance, + commandsClickHandler + ); + internal.transitionInHandler = delegate( + instance, + handleTransitionInEvent + ); + internal.transitionOutHandler = delegate( + instance, + handleTransitionOutEvent + ); + + //settings + for (var opKey in internal.options) { + if (setup.options[opKey] !== undefined) { + // if found in user options + instance.set(opKey, setup.options[opKey]); + } else if (alertify.defaults.hasOwnProperty(opKey)) { + // else if found in defaults options + instance.set(opKey, alertify.defaults[opKey]); + } else if (opKey === "title") { + // else if title key, use alertify.defaults.glossary + instance.set(opKey, alertify.defaults.glossary[opKey]); + } + } + + // allow dom customization + if (typeof instance.build === "function") { + instance.build(); + } + } + + //add to the end of the DOM tree. + document.body.appendChild(instance.elements.root); + } + /** - * Default options - * @type {Object} + * Helper: maintains scroll position + * */ - var defaults = { - autoReset:true, - basic:false, - closable:true, - closableByDimmer:true, - frameless:false, - maintainFocus:true, //global default not per instance, applies to all dialogs - maximizable:true, - modal:true, - movable:true, - moveBounded:false, - overflow:true, - padding: true, - pinnable:true, - pinned:true, - preventBodyShift:false, //global default not per instance, applies to all dialogs - resizable:true, - startMaximized:false, - transition:'pulse', - notifier:{ - delay:5, - position:'bottom-right', - closeButton:false - }, - glossary:{ - title:'AlertifyJS', - ok: 'OK', - cancel: 'Cancel', - acccpt: 'Accept', - deny: 'Deny', - confirm: 'Confirm', - decline: 'Decline', - close: 'Close', - maximize: 'Maximize', - restore: 'Restore', - }, - theme:{ - input:'ajs-input', - ok:'ajs-ok', - cancel:'ajs-cancel', - } - }; - - //holds open dialogs instances - var openDialogs = []; + var scrollX, scrollY; + function saveScrollPosition() { + scrollX = getScrollLeft(); + scrollY = getScrollTop(); + } + function restoreScrollPosition() { + window.scrollTo(scrollX, scrollY); + } /** - * [Helper] Adds the specified class(es) to the element. + * Helper: adds/removes no-overflow class from body + * + */ + function ensureNoOverflow() { + var requiresNoOverflow = 0; + for (var x = 0; x < openDialogs.length; x += 1) { + var instance = openDialogs[x]; + if (instance.isModal() || instance.isMaximized()) { + requiresNoOverflow += 1; + } + } + if ( + requiresNoOverflow === 0 && + document.body.className.indexOf(classes.noOverflow) >= 0 + ) { + //last open modal or last maximized one + removeClass(document.body, classes.noOverflow); + preventBodyShift(false); + } else if ( + requiresNoOverflow > 0 && + document.body.className.indexOf(classes.noOverflow) < 0 + ) { + //first open modal or first maximized one + preventBodyShift(true); + addClass(document.body, classes.noOverflow); + } + } + var top = "", + topScroll = 0; + /** + * Helper: prevents body shift. + * + */ + function preventBodyShift(add) { + if (alertify.defaults.preventBodyShift) { + if ( + add && + document.documentElement.scrollHeight > + document.documentElement.clientHeight + ) { + //&& openDialogs[openDialogs.length-1].elements.dialog.clientHeight <= document.documentElement.clientHeight){ + topScroll = scrollY; + top = window.getComputedStyle(document.body).top; + addClass(document.body, classes.fixed); + document.body.style.top = -scrollY + "px"; + } else if (!add) { + scrollY = topScroll; + document.body.style.top = top; + removeClass(document.body, classes.fixed); + restoreScrollPosition(); + } + } + } + + /** + * Sets the name of the transition used to show/hide the dialog + * + * @param {Object} instance The dilog instance. * - * @element {node} The element - * @className {string} One or more space-separated classes to be added to the class attribute of the element. - * - * @return {undefined} */ - function addClass(element,classNames){ - element.className += ' ' + classNames; + function updateTransition(instance, value, oldValue) { + if (typeof oldValue === "string") { + removeClass(instance.elements.root, classes.prefix + oldValue); + } + addClass(instance.elements.root, classes.prefix + value); + reflow = instance.elements.root.offsetWidth; } - + /** - * [Helper] Removes the specified class(es) from the element. + * Toggles the dialog display mode + * + * @param {Object} instance The dilog instance. * - * @element {node} The element - * @className {string} One or more space-separated classes to be removed from the class attribute of the element. - * * @return {undefined} */ - function removeClass(element, classNames) { - var original = element.className.split(' '); - var toBeRemoved = classNames.split(' '); - for (var x = 0; x < toBeRemoved.length; x += 1) { - var index = original.indexOf(toBeRemoved[x]); - if (index > -1){ - original.splice(index,1); - } + function updateDisplayMode(instance) { + if (instance.get("modal")) { + //make modal + removeClass(instance.elements.root, classes.modeless); + + //only if open + if (instance.isOpen()) { + unbindModelessEvents(instance); + + //in case a pinned modless dialog was made modal while open. + updateAbsPositionFix(instance); + + ensureNoOverflow(); + } + } else { + //make modelss + addClass(instance.elements.root, classes.modeless); + + //only if open + if (instance.isOpen()) { + bindModelessEvents(instance); + + //in case pin/unpin was called while a modal is open + updateAbsPositionFix(instance); + + ensureNoOverflow(); } - element.className = original.join(' '); + } } /** - * [Helper] Checks if the document is RTL + * Toggles the dialog basic view mode + * + * @param {Object} instance The dilog instance. * - * @return {Boolean} True if the document is RTL, false otherwise. + * @return {undefined} */ - function isRightToLeft(){ - return window.getComputedStyle(document.body).direction === 'rtl'; + function updateBasicMode(instance) { + if (instance.get("basic")) { + // add class + addClass(instance.elements.root, classes.basic); + } else { + // remove class + removeClass(instance.elements.root, classes.basic); + } } + /** - * [Helper] Get the document current scrollTop + * Toggles the dialog frameless view mode * - * @return {Number} current document scrollTop value + * @param {Object} instance The dilog instance. + * + * @return {undefined} */ - function getScrollTop(){ - return ((document.documentElement && document.documentElement.scrollTop) || document.body.scrollTop); + function updateFramelessMode(instance) { + if (instance.get("frameless")) { + // add class + addClass(instance.elements.root, classes.frameless); + } else { + // remove class + removeClass(instance.elements.root, classes.frameless); + } } /** - * [Helper] Get the document current scrollLeft + * Helper: Brings the modeless dialog to front, attached to modeless dialogs. * - * @return {Number} current document scrollLeft value + * @param {Event} event Focus event + * @param {Object} instance The dilog instance. + * + * @return {undefined} */ - function getScrollLeft(){ - return ((document.documentElement && document.documentElement.scrollLeft) || document.body.scrollLeft); + function bringToFront(event, instance) { + // Do not bring to front if preceeded by an open modal + var index = openDialogs.indexOf(instance); + for (var x = index + 1; x < openDialogs.length; x += 1) { + if (openDialogs[x].isModal()) { + return; + } + } + + // Bring to front by making it the last child. + if (document.body.lastChild !== instance.elements.root) { + document.body.appendChild(instance.elements.root); + //also make sure its at the end of the list + openDialogs.splice(openDialogs.indexOf(instance), 1); + openDialogs.push(instance); + setFocus(instance); + } + + return false; } /** - * Helper: clear contents - * - */ - function clearContents(element){ - while (element.lastChild) { - element.removeChild(element.lastChild); - } + * Helper: reflects dialogs options updates + * + * @param {Object} instance The dilog instance. + * @param {String} option The updated option name. + * + * @return {undefined} + */ + function optionUpdated(instance, option, oldValue, newValue) { + switch (option) { + case "title": + instance.setHeader(newValue); + break; + case "modal": + updateDisplayMode(instance); + break; + case "basic": + updateBasicMode(instance); + break; + case "frameless": + updateFramelessMode(instance); + break; + case "pinned": + updatePinned(instance); + break; + case "closable": + updateClosable(instance); + break; + case "maximizable": + updateMaximizable(instance); + break; + case "pinnable": + updatePinnable(instance); + break; + case "movable": + updateMovable(instance); + break; + case "resizable": + updateResizable(instance); + break; + case "padding": + if (newValue) { + removeClass(instance.elements.root, classes.noPadding); + } else if ( + instance.elements.root.className.indexOf(classes.noPadding) < 0 + ) { + addClass(instance.elements.root, classes.noPadding); + } + break; + case "overflow": + if (newValue) { + removeClass(instance.elements.root, classes.noOverflow); + } else if ( + instance.elements.root.className.indexOf(classes.noOverflow) < 0 + ) { + addClass(instance.elements.root, classes.noOverflow); + } + break; + case "transition": + updateTransition(instance, newValue, oldValue); + break; + } + + // internal on option updated event + if (typeof instance.hooks.onupdate === "function") { + instance.hooks.onupdate.call(instance, option, oldValue, newValue); + } } + /** - * Extends a given prototype by merging properties from base into sub. + * Helper: reflects dialogs options updates * - * @sub {Object} sub The prototype being overwritten. - * @base {Object} base The prototype being written. + * @param {Object} instance The dilog instance. + * @param {Object} obj The object to set/get a value on/from. + * @param {Function} callback The callback function to call if the key was found. + * @param {String|Object} key A string specifying a propery name or a collection of key value pairs. + * @param {Object} value Optional, the value associated with the key (in case it was a string). + * @param {String} option The updated option name. * - * @return {Object} The extended prototype. + * @return {Object} result object + * The result objects has an 'op' property, indicating of this is a SET or GET operation. + * GET: + * - found: a flag indicating if the key was found or not. + * - value: the property value. + * SET: + * - items: a list of key value pairs of the properties being set. + * each contains: + * - found: a flag indicating if the key was found or not. + * - key: the property key. + * - value: the property value. */ - function copy(src) { - if(null === src){ - return src; - } - var cpy; - if(Array.isArray(src)){ - cpy = []; - for(var x=0;x<src.length;x+=1){ - cpy.push(copy(src[x])); - } - return cpy; - } - - if(src instanceof Date){ - return new Date(src.getTime()); - } - - if(src instanceof RegExp){ - cpy = new RegExp(src.source); - cpy.global = src.global; - cpy.ignoreCase = src.ignoreCase; - cpy.multiline = src.multiline; - cpy.lastIndex = src.lastIndex; - return cpy; - } - - if(typeof src === 'object'){ - cpy = {}; - // copy dialog pototype over definition. - for (var prop in src) { - if (src.hasOwnProperty(prop)) { - cpy[prop] = copy(src[prop]); - } - } - return cpy; - } - return src; + function update(instance, obj, callback, key, value) { + var result = { op: undefined, items: [] }; + if (typeof value === "undefined" && typeof key === "string") { + //get + result.op = "get"; + if (obj.hasOwnProperty(key)) { + result.found = true; + result.value = obj[key]; + } else { + result.found = false; + result.value = undefined; + } + } else { + var old; + //set + result.op = "set"; + if (typeof key === "object") { + //set multiple + var args = key; + for (var prop in args) { + if (obj.hasOwnProperty(prop)) { + if (obj[prop] !== args[prop]) { + old = obj[prop]; + obj[prop] = args[prop]; + callback.call(instance, prop, old, args[prop]); + } + result.items.push({ key: prop, value: args[prop], found: true }); + } else { + result.items.push({ key: prop, value: args[prop], found: false }); + } + } + } else if (typeof key === "string") { + //set single + if (obj.hasOwnProperty(key)) { + if (obj[key] !== value) { + old = obj[key]; + obj[key] = value; + callback.call(instance, key, old, value); + } + result.items.push({ key: key, value: value, found: true }); + } else { + result.items.push({ key: key, value: value, found: false }); + } + } else { + //invalid params + throw new Error("args must be a string or object"); + } + } + return result; } + /** - * Helper: destruct the dialog - * - */ - function destruct(instance, initialize){ - if(instance.elements){ - //delete the dom and it's references. - var root = instance.elements.root; - root.parentNode.removeChild(root); - delete instance.elements; - //copy back initial settings. - instance.settings = copy(instance.__settings); - //re-reference init function. - instance.__init = initialize; - //delete __internal variable to allow re-initialization. - delete instance.__internal; - } + * Triggers a close event. + * + * @param {Object} instance The dilog instance. + * + * @return {undefined} + */ + function triggerClose(instance) { + var found; + triggerCallback(instance, function (button) { + return (found = button.invokeOnClose === true); + }); + //none of the buttons registered as onclose callback + //close the dialog + if (!found && instance.isOpen()) { + instance.close(); + } } /** - * Use a closure to return proper event listener method. Try to use - * `addEventListener` by default but fallback to `attachEvent` for - * unsupported browser. The closure simply ensures that the test doesn't - * happen every time the method is called. - * - * @param {Node} el Node element - * @param {String} event Event type - * @param {Function} fn Callback of event - * @return {Function} + * Dialogs commands event handler, attached to the dialog commands element. + * + * @param {Event} event DOM event object. + * @param {Object} instance The dilog instance. + * + * @return {undefined} */ - var on = (function () { - if (document.addEventListener) { - return function (el, event, fn, useCapture) { - el.addEventListener(event, fn, useCapture === true); - }; - } else if (document.attachEvent) { - return function (el, event, fn) { - el.attachEvent('on' + event, fn); - }; - } - }()); + function commandsClickHandler(event, instance) { + var target = event.srcElement || event.target; + switch (target) { + case instance.elements.commands.pin: + if (!instance.isPinned()) { + pin(instance); + } else { + unpin(instance); + } + break; + case instance.elements.commands.maximize: + if (!instance.isMaximized()) { + maximize(instance); + } else { + restore(instance); + } + break; + case instance.elements.commands.close: + triggerClose(instance); + break; + } + return false; + } /** - * Use a closure to return proper event listener method. Try to use - * `removeEventListener` by default but fallback to `detachEvent` for - * unsupported browser. The closure simply ensures that the test doesn't - * happen every time the method is called. - * - * @param {Node} el Node element - * @param {String} event Event type - * @param {Function} fn Callback of event - * @return {Function} + * Helper: pins the modeless dialog. + * + * @param {Object} instance The dialog instance. + * + * @return {undefined} */ - var off = (function () { - if (document.removeEventListener) { - return function (el, event, fn, useCapture) { - el.removeEventListener(event, fn, useCapture === true); - }; - } else if (document.detachEvent) { - return function (el, event, fn) { - el.detachEvent('on' + event, fn); - }; - } - }()); + function pin(instance) { + //pin the dialog + instance.set("pinned", true); + } /** - * Prevent default event from firing + * Helper: unpins the modeless dialog. + * + * @param {Object} instance The dilog instance. * - * @param {Event} event Event object * @return {undefined} + */ + function unpin(instance) { + //unpin the dialog + instance.set("pinned", false); + } - function prevent ( event ) { - if ( event ) { - if ( event.preventDefault ) { - event.preventDefault(); - } else { - event.returnValue = false; - } - } + /** + * Helper: enlarges the dialog to fill the entire screen. + * + * @param {Object} instance The dilog instance. + * + * @return {undefined} + */ + function maximize(instance) { + // allow custom `onmaximize` method + dispatchEvent("onmaximize", instance); + //maximize the dialog + addClass(instance.elements.root, classes.maximized); + if (instance.isOpen()) { + ensureNoOverflow(); + } + // allow custom `onmaximized` method + dispatchEvent("onmaximized", instance); } - */ - var transition = (function () { - var t, type; - var supported = false; - var transitions = { - 'animation' : 'animationend', - 'OAnimation' : 'oAnimationEnd oanimationend', - 'msAnimation' : 'MSAnimationEnd', - 'MozAnimation' : 'animationend', - 'WebkitAnimation' : 'webkitAnimationEnd' - }; - for (t in transitions) { - if (document.documentElement.style[t] !== undefined) { - type = transitions[t]; - supported = true; - break; - } - } + /** + * Helper: returns the dialog to its former size. + * + * @param {Object} instance The dilog instance. + * + * @return {undefined} + */ + function restore(instance) { + // allow custom `onrestore` method + dispatchEvent("onrestore", instance); + //maximize the dialog + removeClass(instance.elements.root, classes.maximized); + if (instance.isOpen()) { + ensureNoOverflow(); + } + // allow custom `onrestored` method + dispatchEvent("onrestored", instance); + } - return { - type: type, - supported: supported - }; - }()); + /** + * Show or hide the maximize box. + * + * @param {Object} instance The dilog instance. + * @param {Boolean} on True to add the behavior, removes it otherwise. + * + * @return {undefined} + */ + function updatePinnable(instance) { + if (instance.get("pinnable")) { + // add class + addClass(instance.elements.root, classes.pinnable); + } else { + // remove class + removeClass(instance.elements.root, classes.pinnable); + } + } /** - * Creates event handler delegate that sends the instance as last argument. - * - * @return {Function} a function wrapper which sends the instance as last argument. - */ - function delegate(context, method) { - return function () { - if (arguments.length > 0) { - var args = []; - for (var x = 0; x < arguments.length; x += 1) { - args.push(arguments[x]); - } - args.push(context); - return method.apply(context, args); - } - return method.apply(context, [null, context]); - }; + * Helper: Fixes the absolutly positioned modal div position. + * + * @param {Object} instance The dialog instance. + * + * @return {undefined} + */ + function addAbsPositionFix(instance) { + var scrollLeft = getScrollLeft(); + instance.elements.modal.style.marginTop = getScrollTop() + "px"; + instance.elements.modal.style.marginLeft = scrollLeft + "px"; + instance.elements.modal.style.marginRight = -scrollLeft + "px"; } + /** - * Helper for creating a dialog close event. - * - * @return {object} - */ - function createCloseEvent(index, button) { - return { - index: index, - button: button, - cancel: false - }; + * Helper: Removes the absolutly positioned modal div position fix. + * + * @param {Object} instance The dialog instance. + * + * @return {undefined} + */ + function removeAbsPositionFix(instance) { + var marginTop = parseInt(instance.elements.modal.style.marginTop, 10); + var marginLeft = parseInt(instance.elements.modal.style.marginLeft, 10); + instance.elements.modal.style.marginTop = ""; + instance.elements.modal.style.marginLeft = ""; + instance.elements.modal.style.marginRight = ""; + + if (instance.isOpen()) { + var top = 0, + left = 0; + if (instance.elements.dialog.style.top !== "") { + top = parseInt(instance.elements.dialog.style.top, 10); + } + instance.elements.dialog.style.top = + top + (marginTop - getScrollTop()) + "px"; + + if (instance.elements.dialog.style.left !== "") { + left = parseInt(instance.elements.dialog.style.left, 10); + } + instance.elements.dialog.style.left = + left + (marginLeft - getScrollLeft()) + "px"; + } } /** - * Helper for dispatching events. - * - * @param {string} evenType The type of the event to disptach. - * @param {object} instance The dialog instance disptaching the event. - * - * @return {any} The result of the invoked function. - */ - function dispatchEvent(eventType, instance) { - if ( typeof instance.get(eventType) === 'function' ) { - return instance.get(eventType).call(instance); - } + * Helper: Adds/Removes the absolutly positioned modal div position fix based on its pinned setting. + * + * @param {Object} instance The dialog instance. + * + * @return {undefined} + */ + function updateAbsPositionFix(instance) { + // if modeless and unpinned add fix + if (!instance.get("modal") && !instance.get("pinned")) { + addAbsPositionFix(instance); + } else { + removeAbsPositionFix(instance); + } + } + /** + * Toggles the dialog position lock | modeless only. + * + * @param {Object} instance The dilog instance. + * @param {Boolean} on True to make it modal, false otherwise. + * + * @return {undefined} + */ + function updatePinned(instance) { + if (instance.get("pinned")) { + removeClass(instance.elements.root, classes.unpinned); + if (instance.isOpen()) { + removeAbsPositionFix(instance); + } + } else { + addClass(instance.elements.root, classes.unpinned); + if (instance.isOpen() && !instance.isModal()) { + addAbsPositionFix(instance); + } + } } + /** + * Show or hide the maximize box. + * + * @param {Object} instance The dilog instance. + * @param {Boolean} on True to add the behavior, removes it otherwise. + * + * @return {undefined} + */ + function updateMaximizable(instance) { + if (instance.get("maximizable")) { + // add class + addClass(instance.elements.root, classes.maximizable); + } else { + // remove class + removeClass(instance.elements.root, classes.maximizable); + } + } /** - * Super class for all dialogs + * Show or hide the close box. * - * @return {Object} base dialog prototype + * @param {Object} instance The dilog instance. + * @param {Boolean} on True to add the behavior, removes it otherwise. + * + * @return {undefined} */ - var dialog = (function () { - var //holds the list of used keys. - usedKeys = [], - //dummy variable, used to trigger dom reflow. - reflow = null, - //holds body tab index in case it has any. - tabindex = false, - //condition for detecting safari - isSafari = window.navigator.userAgent.indexOf('Safari') > -1 && window.navigator.userAgent.indexOf('Chrome') < 0, - //dialog building blocks - templates = { - dimmer:'<div class="ajs-dimmer"></div>', - /*tab index required to fire click event before body focus*/ - modal: '<div class="ajs-modal" tabindex="0"></div>', - dialog: '<div class="ajs-dialog" tabindex="0"></div>', - reset: '<button class="ajs-reset"></button>', - commands: '<div class="ajs-commands"><button class="ajs-pin"></button><button class="ajs-maximize"></button><button class="ajs-close"></button></div>', - header: '<div class="ajs-header"></div>', - body: '<div class="ajs-body"></div>', - content: '<div class="ajs-content"></div>', - footer: '<div class="ajs-footer"></div>', - buttons: { primary: '<div class="ajs-primary ajs-buttons"></div>', auxiliary: '<div class="ajs-auxiliary ajs-buttons"></div>' }, - button: '<button class="ajs-button"></button>', - resizeHandle: '<div class="ajs-handle"></div>', - }, - //common class names - classes = { - animationIn: 'ajs-in', - animationOut: 'ajs-out', - base: 'alertify', - basic:'ajs-basic', - capture: 'ajs-capture', - closable:'ajs-closable', - fixed: 'ajs-fixed', - frameless:'ajs-frameless', - hidden: 'ajs-hidden', - maximize: 'ajs-maximize', - maximized: 'ajs-maximized', - maximizable:'ajs-maximizable', - modeless: 'ajs-modeless', - movable: 'ajs-movable', - noSelection: 'ajs-no-selection', - noOverflow: 'ajs-no-overflow', - noPadding:'ajs-no-padding', - pin:'ajs-pin', - pinnable:'ajs-pinnable', - prefix: 'ajs-', - resizable: 'ajs-resizable', - restore: 'ajs-restore', - shake:'ajs-shake', - unpinned:'ajs-unpinned', - }; + function updateClosable(instance) { + if (instance.get("closable")) { + // add class + addClass(instance.elements.root, classes.closable); + bindClosableEvents(instance); + } else { + // remove class + removeClass(instance.elements.root, classes.closable); + unbindClosableEvents(instance); + } + } - /** - * Helper: initializes the dialog instance - * - * @return {Number} The total count of currently open modals. - */ - function initialize(instance){ - - if(!instance.__internal){ - - //no need to expose init after this. - delete instance.__init; - - //keep a copy of initial dialog settings - if(!instance.__settings){ - instance.__settings = copy(instance.settings); - } - - //get dialog buttons/focus setup - var setup; - if(typeof instance.setup === 'function'){ - setup = instance.setup(); - setup.options = setup.options || {}; - setup.focus = setup.focus || {}; - }else{ - setup = { - buttons:[], - focus:{ - element:null, - select:false - }, - options:{ - } - }; - } - - //initialize hooks object. - if(typeof instance.hooks !== 'object'){ - instance.hooks = {}; - } + var cancelClick = false, // flag to cancel click event if already handled by end resize event (the mousedown, mousemove, mouseup sequence fires a click event.). + modalClickHandlerTS = 0; // stores last click timestamp to prevent executing the handler twice on double click. + /** + * Helper: closes the modal dialog when clicking the modal + * + * @param {Event} event DOM event object. + * @param {Object} instance The dilog instance. + * + * @return {undefined} + */ + function modalClickHandler(event, instance) { + if ( + event.timeStamp - modalClickHandlerTS > 200 && + (modalClickHandlerTS = event.timeStamp) && + !cancelClick + ) { + var target = event.srcElement || event.target; + if ( + instance.get("closableByDimmer") === true && + target === instance.elements.modal + ) { + triggerClose(instance); + } + cancelClick = false; + return false; + } + } - //copy buttons defintion - var buttonsDefinition = []; - if(Array.isArray(setup.buttons)){ - for(var b=0;b<setup.buttons.length;b+=1){ - var ref = setup.buttons[b], - cpy = {}; - for (var i in ref) { - if (ref.hasOwnProperty(i)) { - cpy[i] = ref[i]; - } - } - buttonsDefinition.push(cpy); - } - } + // stores last call timestamp to prevent triggering the callback twice. + var callbackTS = 0; + // flag to cancel keyup event if already handled by click event (pressing Enter on a focusted button). + var cancelKeyup = false; + /** + * Helper: triggers a button callback + * + * @param {Object} The dilog instance. + * @param {Function} Callback to check which button triggered the event. + * + * @return {undefined} + */ + function triggerCallback(instance, check) { + if (Date.now() - callbackTS > 200 && (callbackTS = Date.now())) { + for (var idx = 0; idx < instance.__internal.buttons.length; idx += 1) { + var button = instance.__internal.buttons[idx]; + if (!button.element.disabled && check(button)) { + var closeEvent = createCloseEvent(idx, button); + if (typeof instance.callback === "function") { + instance.callback.apply(instance, [closeEvent]); + } + //close the dialog only if not canceled. + if (closeEvent.cancel === false) { + instance.close(); + } + break; + } + } + } + } - var internal = instance.__internal = { - /** - * Flag holding the open state of the dialog - * - * @type {Boolean} - */ - isOpen:false, - /** - * Active element is the element that will receive focus after - * closing the dialog. It defaults as the body tag, but gets updated - * to the last focused element before the dialog was opened. - * - * @type {Node} - */ - activeElement:document.body, - timerIn:undefined, - timerOut:undefined, - buttons: buttonsDefinition, - focus: setup.focus, - options: { - title: undefined, - modal: undefined, - basic:undefined, - frameless:undefined, - pinned: undefined, - movable: undefined, - moveBounded:undefined, - resizable: undefined, - autoReset: undefined, - closable: undefined, - closableByDimmer: undefined, - maximizable: undefined, - startMaximized: undefined, - pinnable: undefined, - transition: undefined, - padding:undefined, - overflow:undefined, - onshow:undefined, - onclosing:undefined, - onclose:undefined, - onfocus:undefined, - onmove:undefined, - onmoved:undefined, - onresize:undefined, - onresized:undefined, - onmaximize:undefined, - onmaximized:undefined, - onrestore:undefined, - onrestored:undefined - }, - resetHandler:undefined, - beginMoveHandler:undefined, - beginResizeHandler:undefined, - bringToFrontHandler:undefined, - modalClickHandler:undefined, - buttonsClickHandler:undefined, - commandsClickHandler:undefined, - transitionInHandler:undefined, - transitionOutHandler:undefined, - destroy:undefined - }; - - var elements = {}; - //root node - elements.root = document.createElement('div'); - //prevent FOUC in case of async styles loading. - elements.root.style.display = 'none'; - elements.root.className = classes.base + ' ' + classes.hidden + ' '; - - elements.root.innerHTML = templates.dimmer + templates.modal; - - //dimmer - elements.dimmer = elements.root.firstChild; - - //dialog - elements.modal = elements.root.lastChild; - elements.modal.innerHTML = templates.dialog; - elements.dialog = elements.modal.firstChild; - elements.dialog.innerHTML = templates.reset + templates.commands + templates.header + templates.body + templates.footer + templates.resizeHandle + templates.reset; - - //reset links - elements.reset = []; - elements.reset.push(elements.dialog.firstChild); - elements.reset.push(elements.dialog.lastChild); - - //commands - elements.commands = {}; - elements.commands.container = elements.reset[0].nextSibling; - elements.commands.pin = elements.commands.container.firstChild; - elements.commands.maximize = elements.commands.pin.nextSibling; - elements.commands.close = elements.commands.maximize.nextSibling; - - //header - elements.header = elements.commands.container.nextSibling; - - //body - elements.body = elements.header.nextSibling; - elements.body.innerHTML = templates.content; - elements.content = elements.body.firstChild; - - //footer - elements.footer = elements.body.nextSibling; - elements.footer.innerHTML = templates.buttons.auxiliary + templates.buttons.primary; - - //resize handle - elements.resizeHandle = elements.footer.nextSibling; - - //buttons - elements.buttons = {}; - elements.buttons.auxiliary = elements.footer.firstChild; - elements.buttons.primary = elements.buttons.auxiliary.nextSibling; - elements.buttons.primary.innerHTML = templates.button; - elements.buttonTemplate = elements.buttons.primary.firstChild; - //remove button template - elements.buttons.primary.removeChild(elements.buttonTemplate); - - for(var x=0; x < instance.__internal.buttons.length; x+=1) { - var button = instance.__internal.buttons[x]; - - // add to the list of used keys. - if(usedKeys.indexOf(button.key) < 0){ - usedKeys.push(button.key); - } - - button.element = elements.buttonTemplate.cloneNode(); - button.element.innerHTML = button.text; - if(typeof button.className === 'string' && button.className !== ''){ - addClass(button.element, button.className); - } - for(var key in button.attrs){ - if(key !== 'className' && button.attrs.hasOwnProperty(key)){ - button.element.setAttribute(key, button.attrs[key]); - } - } - if(button.scope === 'auxiliary'){ - elements.buttons.auxiliary.appendChild(button.element); - }else{ - elements.buttons.primary.appendChild(button.element); - } - } - //make elements pubic - instance.elements = elements; - - //save event handlers delegates - internal.resetHandler = delegate(instance, onReset); - internal.beginMoveHandler = delegate(instance, beginMove); - internal.beginResizeHandler = delegate(instance, beginResize); - internal.bringToFrontHandler = delegate(instance, bringToFront); - internal.modalClickHandler = delegate(instance, modalClickHandler); - internal.buttonsClickHandler = delegate(instance, buttonsClickHandler); - internal.commandsClickHandler = delegate(instance, commandsClickHandler); - internal.transitionInHandler = delegate(instance, handleTransitionInEvent); - internal.transitionOutHandler = delegate(instance, handleTransitionOutEvent); - - //settings - for(var opKey in internal.options){ - if(setup.options[opKey] !== undefined){ - // if found in user options - instance.set(opKey, setup.options[opKey]); - }else if(alertify.defaults.hasOwnProperty(opKey)) { - // else if found in defaults options - instance.set(opKey, alertify.defaults[opKey]); - }else if(opKey === 'title' ) { - // else if title key, use alertify.defaults.glossary - instance.set(opKey, alertify.defaults.glossary[opKey]); - } - } + /** + * Clicks event handler, attached to the dialog footer. + * + * @param {Event} DOM event object. + * @param {Object} The dilog instance. + * + * @return {undefined} + */ + function buttonsClickHandler(event, instance) { + var target = event.srcElement || event.target; + triggerCallback(instance, function (button) { + // if this button caused the click, cancel keyup event + return button.element === target && (cancelKeyup = true); + }); + } - // allow dom customization - if(typeof instance.build === 'function'){ - instance.build(); - } + /** + * Keyup event handler, attached to the document.body + * + * @param {Event} DOM event object. + * @param {Object} The dilog instance. + * + * @return {undefined} + */ + function keyupHandler(event) { + //hitting enter while button has focus will trigger keyup too. + //ignore if handled by clickHandler + if (cancelKeyup) { + cancelKeyup = false; + return; + } + var instance = openDialogs[openDialogs.length - 1]; + var keyCode = event.keyCode; + if ( + instance.__internal.buttons.length === 0 && + keyCode === keys.ESC && + instance.get("closable") === true + ) { + triggerClose(instance); + return false; + } else if (usedKeys.indexOf(keyCode) > -1) { + triggerCallback(instance, function (button) { + return button.key === keyCode; + }); + return false; + } + } + /** + * Keydown event handler, attached to the document.body + * + * @param {Event} DOM event object. + * @param {Object} The dilog instance. + * + * @return {undefined} + */ + function keydownHandler(event) { + var instance = openDialogs[openDialogs.length - 1]; + var keyCode = event.keyCode; + if (keyCode === keys.LEFT || keyCode === keys.RIGHT) { + var buttons = instance.__internal.buttons; + for (var x = 0; x < buttons.length; x += 1) { + if (document.activeElement === buttons[x].element) { + switch (keyCode) { + case keys.LEFT: + buttons[(x || buttons.length) - 1].element.focus(); + return; + case keys.RIGHT: + buttons[(x + 1) % buttons.length].element.focus(); + return; } - - //add to the end of the DOM tree. - document.body.appendChild(instance.elements.root); - } + } + } + } else if ( + keyCode < keys.F12 + 1 && + keyCode > keys.F1 - 1 && + usedKeys.indexOf(keyCode) > -1 + ) { + event.preventDefault(); + event.stopPropagation(); + triggerCallback(instance, function (button) { + return button.key === keyCode; + }); + return false; + } + } - /** - * Helper: maintains scroll position - * - */ - var scrollX, scrollY; - function saveScrollPosition(){ - scrollX = getScrollLeft(); - scrollY = getScrollTop(); - } - function restoreScrollPosition(){ - window.scrollTo(scrollX, scrollY); - } + /** + * Sets focus to proper dialog element + * + * @param {Object} instance The dilog instance. + * @param {Node} [resetTarget=undefined] DOM element to reset focus to. + * + * @return {undefined} + */ + function setFocus(instance, resetTarget) { + // reset target has already been determined. + if (resetTarget) { + resetTarget.focus(); + } else { + // current instance focus settings + var focus = instance.__internal.focus; + // the focus element. + var element = focus.element; + + switch (typeof focus.element) { + // a number means a button index + case "number": + if (instance.__internal.buttons.length > focus.element) { + //in basic view, skip focusing the buttons. + if (instance.get("basic") === true) { + element = instance.elements.reset[0]; + } else { + element = instance.__internal.buttons[focus.element].element; + } + } + break; + // a string means querySelector to select from dialog body contents. + case "string": + element = instance.elements.body.querySelector(focus.element); + break; + // a function should return the focus element. + case "function": + element = focus.element.call(instance); + break; + } + + // if no focus element, default to first reset element. + if ( + (typeof element === "undefined" || element === null) && + instance.__internal.buttons.length === 0 + ) { + element = instance.elements.reset[0]; + } + // focus + if (element && element.focus) { + element.focus(); + // if selectable + if (focus.select && element.select) { + element.select(); + } + } + } + } - /** - * Helper: adds/removes no-overflow class from body - * - */ - function ensureNoOverflow(){ - var requiresNoOverflow = 0; - for(var x=0;x<openDialogs.length;x+=1){ - var instance = openDialogs[x]; - if(instance.isModal() || instance.isMaximized()){ - requiresNoOverflow+=1; - } - } - if(requiresNoOverflow === 0 && document.body.className.indexOf(classes.noOverflow) >= 0){ - //last open modal or last maximized one - removeClass(document.body, classes.noOverflow); - preventBodyShift(false); - }else if(requiresNoOverflow > 0 && document.body.className.indexOf(classes.noOverflow) < 0){ - //first open modal or first maximized one - preventBodyShift(true); - addClass(document.body, classes.noOverflow); - } - } - var top = '', topScroll = 0; - /** - * Helper: prevents body shift. - * - */ - function preventBodyShift(add){ - if(alertify.defaults.preventBodyShift){ - if(add && document.documentElement.scrollHeight > document.documentElement.clientHeight ){//&& openDialogs[openDialogs.length-1].elements.dialog.clientHeight <= document.documentElement.clientHeight){ - topScroll = scrollY; - top = window.getComputedStyle(document.body).top; - addClass(document.body, classes.fixed); - document.body.style.top = -scrollY + 'px'; - } else if(!add) { - scrollY = topScroll; - document.body.style.top = top; - removeClass(document.body, classes.fixed); - restoreScrollPosition(); - } - } - } - - /** - * Sets the name of the transition used to show/hide the dialog - * - * @param {Object} instance The dilog instance. - * - */ - function updateTransition(instance, value, oldValue){ - if(typeof oldValue === 'string'){ - removeClass(instance.elements.root,classes.prefix + oldValue); - } - addClass(instance.elements.root, classes.prefix + value); - reflow = instance.elements.root.offsetWidth; - } - - /** - * Toggles the dialog display mode - * - * @param {Object} instance The dilog instance. - * - * @return {undefined} - */ - function updateDisplayMode(instance){ - if(instance.get('modal')){ - - //make modal - removeClass(instance.elements.root, classes.modeless); - - //only if open - if(instance.isOpen()){ - unbindModelessEvents(instance); - - //in case a pinned modless dialog was made modal while open. - updateAbsPositionFix(instance); - - ensureNoOverflow(); - } - }else{ - //make modelss - addClass(instance.elements.root, classes.modeless); - - //only if open - if(instance.isOpen()){ - bindModelessEvents(instance); - - //in case pin/unpin was called while a modal is open - updateAbsPositionFix(instance); - - ensureNoOverflow(); - } - } - } - - /** - * Toggles the dialog basic view mode - * - * @param {Object} instance The dilog instance. - * - * @return {undefined} - */ - function updateBasicMode(instance){ - if (instance.get('basic')) { - // add class - addClass(instance.elements.root, classes.basic); - } else { - // remove class - removeClass(instance.elements.root, classes.basic); - } - } - - /** - * Toggles the dialog frameless view mode - * - * @param {Object} instance The dilog instance. - * - * @return {undefined} - */ - function updateFramelessMode(instance){ - if (instance.get('frameless')) { - // add class - addClass(instance.elements.root, classes.frameless); - } else { - // remove class - removeClass(instance.elements.root, classes.frameless); - } - } - - /** - * Helper: Brings the modeless dialog to front, attached to modeless dialogs. - * - * @param {Event} event Focus event - * @param {Object} instance The dilog instance. - * - * @return {undefined} - */ - function bringToFront(event, instance){ - - // Do not bring to front if preceeded by an open modal - var index = openDialogs.indexOf(instance); - for(var x=index+1;x<openDialogs.length;x+=1){ - if(openDialogs[x].isModal()){ - return; - } - } - - // Bring to front by making it the last child. - if(document.body.lastChild !== instance.elements.root){ - document.body.appendChild(instance.elements.root); - //also make sure its at the end of the list - openDialogs.splice(openDialogs.indexOf(instance),1); - openDialogs.push(instance); - setFocus(instance); - } - - return false; - } - - /** - * Helper: reflects dialogs options updates - * - * @param {Object} instance The dilog instance. - * @param {String} option The updated option name. - * - * @return {undefined} - */ - function optionUpdated(instance, option, oldValue, newValue){ - switch(option){ - case 'title': - instance.setHeader(newValue); - break; - case 'modal': - updateDisplayMode(instance); - break; - case 'basic': - updateBasicMode(instance); - break; - case 'frameless': - updateFramelessMode(instance); - break; - case 'pinned': - updatePinned(instance); - break; - case 'closable': - updateClosable(instance); - break; - case 'maximizable': - updateMaximizable(instance); - break; - case 'pinnable': - updatePinnable(instance); - break; - case 'movable': - updateMovable(instance); - break; - case 'resizable': - updateResizable(instance); - break; - case 'padding': - if(newValue){ - removeClass(instance.elements.root, classes.noPadding); - }else if(instance.elements.root.className.indexOf(classes.noPadding) < 0){ - addClass(instance.elements.root, classes.noPadding); - } - break; - case 'overflow': - if(newValue){ - removeClass(instance.elements.root, classes.noOverflow); - }else if(instance.elements.root.className.indexOf(classes.noOverflow) < 0){ - addClass(instance.elements.root, classes.noOverflow); - } - break; - case 'transition': - updateTransition(instance,newValue, oldValue); - break; - } - - // internal on option updated event - if(typeof instance.hooks.onupdate === 'function'){ - instance.hooks.onupdate.call(instance, option, oldValue, newValue); - } - } - - /** - * Helper: reflects dialogs options updates - * - * @param {Object} instance The dilog instance. - * @param {Object} obj The object to set/get a value on/from. - * @param {Function} callback The callback function to call if the key was found. - * @param {String|Object} key A string specifying a propery name or a collection of key value pairs. - * @param {Object} value Optional, the value associated with the key (in case it was a string). - * @param {String} option The updated option name. - * - * @return {Object} result object - * The result objects has an 'op' property, indicating of this is a SET or GET operation. - * GET: - * - found: a flag indicating if the key was found or not. - * - value: the property value. - * SET: - * - items: a list of key value pairs of the properties being set. - * each contains: - * - found: a flag indicating if the key was found or not. - * - key: the property key. - * - value: the property value. - */ - function update(instance, obj, callback, key, value){ - var result = {op:undefined, items: [] }; - if(typeof value === 'undefined' && typeof key === 'string') { - //get - result.op = 'get'; - if(obj.hasOwnProperty(key)){ - result.found = true; - result.value = obj[key]; - }else{ - result.found = false; - result.value = undefined; - } - } - else - { - var old; - //set - result.op = 'set'; - if(typeof key === 'object'){ - //set multiple - var args = key; - for (var prop in args) { - if (obj.hasOwnProperty(prop)) { - if(obj[prop] !== args[prop]){ - old = obj[prop]; - obj[prop] = args[prop]; - callback.call(instance,prop, old, args[prop]); - } - result.items.push({ 'key': prop, 'value': args[prop], 'found':true}); - }else{ - result.items.push({ 'key': prop, 'value': args[prop], 'found':false}); - } - } - } else if (typeof key === 'string'){ - //set single - if (obj.hasOwnProperty(key)) { - if(obj[key] !== value){ - old = obj[key]; - obj[key] = value; - callback.call(instance,key, old, value); - } - result.items.push({'key': key, 'value': value , 'found':true}); - - }else{ - result.items.push({'key': key, 'value': value , 'found':false}); - } - } else { - //invalid params - throw new Error('args must be a string or object'); - } - } - return result; - } - - - /** - * Triggers a close event. - * - * @param {Object} instance The dilog instance. - * - * @return {undefined} - */ - function triggerClose(instance) { - var found; - triggerCallback(instance, function (button) { - return found = (button.invokeOnClose === true); - }); - //none of the buttons registered as onclose callback - //close the dialog - if (!found && instance.isOpen()) { - instance.close(); - } - } - - /** - * Dialogs commands event handler, attached to the dialog commands element. - * - * @param {Event} event DOM event object. - * @param {Object} instance The dilog instance. - * - * @return {undefined} - */ - function commandsClickHandler(event, instance) { - var target = event.srcElement || event.target; - switch (target) { - case instance.elements.commands.pin: - if (!instance.isPinned()) { - pin(instance); - } else { - unpin(instance); - } - break; - case instance.elements.commands.maximize: - if (!instance.isMaximized()) { - maximize(instance); - } else { - restore(instance); - } - break; - case instance.elements.commands.close: - triggerClose(instance); - break; - } - return false; - } - - /** - * Helper: pins the modeless dialog. - * - * @param {Object} instance The dialog instance. - * - * @return {undefined} - */ - function pin(instance) { - //pin the dialog - instance.set('pinned', true); - } - - /** - * Helper: unpins the modeless dialog. - * - * @param {Object} instance The dilog instance. - * - * @return {undefined} - */ - function unpin(instance) { - //unpin the dialog - instance.set('pinned', false); - } - - - /** - * Helper: enlarges the dialog to fill the entire screen. - * - * @param {Object} instance The dilog instance. - * - * @return {undefined} - */ - function maximize(instance) { - // allow custom `onmaximize` method - dispatchEvent('onmaximize', instance); - //maximize the dialog - addClass(instance.elements.root, classes.maximized); - if (instance.isOpen()) { - ensureNoOverflow(); - } - // allow custom `onmaximized` method - dispatchEvent('onmaximized', instance); - } - - /** - * Helper: returns the dialog to its former size. - * - * @param {Object} instance The dilog instance. - * - * @return {undefined} - */ - function restore(instance) { - // allow custom `onrestore` method - dispatchEvent('onrestore', instance); - //maximize the dialog - removeClass(instance.elements.root, classes.maximized); - if (instance.isOpen()) { - ensureNoOverflow(); - } - // allow custom `onrestored` method - dispatchEvent('onrestored', instance); - } - - /** - * Show or hide the maximize box. - * - * @param {Object} instance The dilog instance. - * @param {Boolean} on True to add the behavior, removes it otherwise. - * - * @return {undefined} - */ - function updatePinnable(instance) { - if (instance.get('pinnable')) { - // add class - addClass(instance.elements.root, classes.pinnable); - } else { - // remove class - removeClass(instance.elements.root, classes.pinnable); - } - } - - /** - * Helper: Fixes the absolutly positioned modal div position. - * - * @param {Object} instance The dialog instance. - * - * @return {undefined} - */ - function addAbsPositionFix(instance) { - var scrollLeft = getScrollLeft(); - instance.elements.modal.style.marginTop = getScrollTop() + 'px'; - instance.elements.modal.style.marginLeft = scrollLeft + 'px'; - instance.elements.modal.style.marginRight = (-scrollLeft) + 'px'; - } - - /** - * Helper: Removes the absolutly positioned modal div position fix. - * - * @param {Object} instance The dialog instance. - * - * @return {undefined} - */ - function removeAbsPositionFix(instance) { - var marginTop = parseInt(instance.elements.modal.style.marginTop, 10); - var marginLeft = parseInt(instance.elements.modal.style.marginLeft, 10); - instance.elements.modal.style.marginTop = ''; - instance.elements.modal.style.marginLeft = ''; - instance.elements.modal.style.marginRight = ''; - - if (instance.isOpen()) { - var top = 0, - left = 0 - ; - if (instance.elements.dialog.style.top !== '') { - top = parseInt(instance.elements.dialog.style.top, 10); - } - instance.elements.dialog.style.top = (top + (marginTop - getScrollTop())) + 'px'; - - if (instance.elements.dialog.style.left !== '') { - left = parseInt(instance.elements.dialog.style.left, 10); - } - instance.elements.dialog.style.left = (left + (marginLeft - getScrollLeft())) + 'px'; - } - } - /** - * Helper: Adds/Removes the absolutly positioned modal div position fix based on its pinned setting. - * - * @param {Object} instance The dialog instance. - * - * @return {undefined} - */ - function updateAbsPositionFix(instance) { - // if modeless and unpinned add fix - if (!instance.get('modal') && !instance.get('pinned')) { - addAbsPositionFix(instance); - } else { - removeAbsPositionFix(instance); - } - } - /** - * Toggles the dialog position lock | modeless only. - * - * @param {Object} instance The dilog instance. - * @param {Boolean} on True to make it modal, false otherwise. - * - * @return {undefined} - */ - function updatePinned(instance) { - if (instance.get('pinned')) { - removeClass(instance.elements.root, classes.unpinned); - if (instance.isOpen()) { - removeAbsPositionFix(instance); - } - } else { - addClass(instance.elements.root, classes.unpinned); - if (instance.isOpen() && !instance.isModal()) { - addAbsPositionFix(instance); - } - } - } - - /** - * Show or hide the maximize box. - * - * @param {Object} instance The dilog instance. - * @param {Boolean} on True to add the behavior, removes it otherwise. - * - * @return {undefined} - */ - function updateMaximizable(instance) { - if (instance.get('maximizable')) { - // add class - addClass(instance.elements.root, classes.maximizable); - } else { - // remove class - removeClass(instance.elements.root, classes.maximizable); - } - } - - /** - * Show or hide the close box. - * - * @param {Object} instance The dilog instance. - * @param {Boolean} on True to add the behavior, removes it otherwise. - * - * @return {undefined} - */ - function updateClosable(instance) { - if (instance.get('closable')) { - // add class - addClass(instance.elements.root, classes.closable); - bindClosableEvents(instance); - } else { - // remove class - removeClass(instance.elements.root, classes.closable); - unbindClosableEvents(instance); - } - } - - - var cancelClick = false,// flag to cancel click event if already handled by end resize event (the mousedown, mousemove, mouseup sequence fires a click event.). - modalClickHandlerTS=0 // stores last click timestamp to prevent executing the handler twice on double click. - ; - - /** - * Helper: closes the modal dialog when clicking the modal - * - * @param {Event} event DOM event object. - * @param {Object} instance The dilog instance. - * - * @return {undefined} - */ - function modalClickHandler(event, instance) { - if(event.timeStamp - modalClickHandlerTS > 200 && (modalClickHandlerTS = event.timeStamp) && !cancelClick){ - var target = event.srcElement || event.target; - if (instance.get('closableByDimmer') === true && target === instance.elements.modal) { - triggerClose(instance); - } - cancelClick = false; - return false; - } - } - - // stores last call timestamp to prevent triggering the callback twice. - var callbackTS = 0; - // flag to cancel keyup event if already handled by click event (pressing Enter on a focusted button). - var cancelKeyup = false; - /** - * Helper: triggers a button callback - * - * @param {Object} The dilog instance. - * @param {Function} Callback to check which button triggered the event. - * - * @return {undefined} - */ - function triggerCallback(instance, check) { - if(Date.now() - callbackTS > 200 && (callbackTS = Date.now())){ - for (var idx = 0; idx < instance.__internal.buttons.length; idx += 1) { - var button = instance.__internal.buttons[idx]; - if (!button.element.disabled && check(button)) { - var closeEvent = createCloseEvent(idx, button); - if (typeof instance.callback === 'function') { - instance.callback.apply(instance, [closeEvent]); - } - //close the dialog only if not canceled. - if (closeEvent.cancel === false) { - instance.close(); - } - break; - } - } - } - } - - /** - * Clicks event handler, attached to the dialog footer. - * - * @param {Event} DOM event object. - * @param {Object} The dilog instance. - * - * @return {undefined} - */ - function buttonsClickHandler(event, instance) { - var target = event.srcElement || event.target; - triggerCallback(instance, function (button) { - // if this button caused the click, cancel keyup event - return button.element === target && (cancelKeyup = true); - }); - } - - /** - * Keyup event handler, attached to the document.body - * - * @param {Event} DOM event object. - * @param {Object} The dilog instance. - * - * @return {undefined} - */ - function keyupHandler(event) { - //hitting enter while button has focus will trigger keyup too. - //ignore if handled by clickHandler - if (cancelKeyup) { - cancelKeyup = false; - return; - } - var instance = openDialogs[openDialogs.length - 1]; - var keyCode = event.keyCode; - if (instance.__internal.buttons.length === 0 && keyCode === keys.ESC && instance.get('closable') === true) { - triggerClose(instance); - return false; - }else if (usedKeys.indexOf(keyCode) > -1) { - triggerCallback(instance, function (button) { - return button.key === keyCode; - }); - return false; - } - } - /** - * Keydown event handler, attached to the document.body - * - * @param {Event} DOM event object. - * @param {Object} The dilog instance. - * - * @return {undefined} - */ - function keydownHandler(event) { - var instance = openDialogs[openDialogs.length - 1]; - var keyCode = event.keyCode; - if (keyCode === keys.LEFT || keyCode === keys.RIGHT) { - var buttons = instance.__internal.buttons; - for (var x = 0; x < buttons.length; x += 1) { - if (document.activeElement === buttons[x].element) { - switch (keyCode) { - case keys.LEFT: - buttons[(x || buttons.length) - 1].element.focus(); - return; - case keys.RIGHT: - buttons[(x + 1) % buttons.length].element.focus(); - return; - } - } - } - }else if (keyCode < keys.F12 + 1 && keyCode > keys.F1 - 1 && usedKeys.indexOf(keyCode) > -1) { - event.preventDefault(); - event.stopPropagation(); - triggerCallback(instance, function (button) { - return button.key === keyCode; - }); - return false; - } - } - - - /** - * Sets focus to proper dialog element - * - * @param {Object} instance The dilog instance. - * @param {Node} [resetTarget=undefined] DOM element to reset focus to. - * - * @return {undefined} - */ - function setFocus(instance, resetTarget) { - // reset target has already been determined. - if (resetTarget) { - resetTarget.focus(); - } else { - // current instance focus settings - var focus = instance.__internal.focus; - // the focus element. - var element = focus.element; - - switch (typeof focus.element) { - // a number means a button index - case 'number': - if (instance.__internal.buttons.length > focus.element) { - //in basic view, skip focusing the buttons. - if (instance.get('basic') === true) { - element = instance.elements.reset[0]; - } else { - element = instance.__internal.buttons[focus.element].element; - } - } - break; - // a string means querySelector to select from dialog body contents. - case 'string': - element = instance.elements.body.querySelector(focus.element); - break; - // a function should return the focus element. - case 'function': - element = focus.element.call(instance); - break; - } - - // if no focus element, default to first reset element. - if ((typeof element === 'undefined' || element === null) && instance.__internal.buttons.length === 0) { - element = instance.elements.reset[0]; - } - // focus - if (element && element.focus) { - element.focus(); - // if selectable - if (focus.select && element.select) { - element.select(); - } - } - } - } - - /** - * Focus event handler, attached to document.body and dialogs own reset links. - * handles the focus for modal dialogs only. - * - * @param {Event} event DOM focus event object. - * @param {Object} instance The dilog instance. - * - * @return {undefined} - */ - function onReset(event, instance) { - - // should work on last modal if triggered from document.body - if (!instance) { - for (var x = openDialogs.length - 1; x > -1; x -= 1) { - if (openDialogs[x].isModal()) { - instance = openDialogs[x]; - break; - } - } - } - // if modal - if (instance && instance.isModal()) { - // determine reset target to enable forward/backward tab cycle. - var resetTarget, target = event.srcElement || event.target; - var lastResetElement = target === instance.elements.reset[1] || (instance.__internal.buttons.length === 0 && target === document.body); - - // if last reset link, then go to maximize or close - if (lastResetElement) { - if (instance.get('maximizable')) { - resetTarget = instance.elements.commands.maximize; - } else if (instance.get('closable')) { - resetTarget = instance.elements.commands.close; - } - } - // if no reset target found, try finding the best button - if (resetTarget === undefined) { - if (typeof instance.__internal.focus.element === 'number') { - // button focus element, go to first available button - if (target === instance.elements.reset[0]) { - resetTarget = instance.elements.buttons.auxiliary.firstChild || instance.elements.buttons.primary.firstChild; - } else if (lastResetElement) { - //restart the cycle by going to first reset link - resetTarget = instance.elements.reset[0]; - } - } else { - // will reach here when tapping backwards, so go to last child - // The focus element SHOULD NOT be a button (logically!). - if (target === instance.elements.reset[0]) { - resetTarget = instance.elements.buttons.primary.lastChild || instance.elements.buttons.auxiliary.lastChild; - } - } - } - // focus - setFocus(instance, resetTarget); - } - } - /** - * Transition in transitionend event handler. - * - * @param {Event} TransitionEnd event object. - * @param {Object} The dilog instance. - * - * @return {undefined} - */ - function handleTransitionInEvent(event, instance) { - // clear the timer - clearTimeout(instance.__internal.timerIn); - - // once transition is complete, set focus - setFocus(instance); - - //restore scroll to prevent document jump - restoreScrollPosition(); - - // allow handling key up after transition ended. - cancelKeyup = false; - - // allow custom `onfocus` method - dispatchEvent('onfocus', instance); - - // unbind the event - off(instance.elements.dialog, transition.type, instance.__internal.transitionInHandler); - - removeClass(instance.elements.root, classes.animationIn); - } - - /** - * Transition out transitionend event handler. - * - * @param {Event} TransitionEnd event object. - * @param {Object} The dilog instance. - * - * @return {undefined} - */ - function handleTransitionOutEvent(event, instance) { - // clear the timer - clearTimeout(instance.__internal.timerOut); - // unbind the event - off(instance.elements.dialog, transition.type, instance.__internal.transitionOutHandler); - - // reset move updates - resetMove(instance); - // reset resize updates - resetResize(instance); - - // restore if maximized - if (instance.isMaximized() && !instance.get('startMaximized')) { - restore(instance); - } - - // return focus to the last active element - if (alertify.defaults.maintainFocus && instance.__internal.activeElement) { - instance.__internal.activeElement.focus(); - instance.__internal.activeElement = null; - } - - //destory the instance - if (typeof instance.__internal.destroy === 'function') { - instance.__internal.destroy.apply(instance); - } - } - /* Controls moving a dialog around */ - //holde the current moving instance - var movable = null, - //holds the current X offset when move starts - offsetX = 0, - //holds the current Y offset when move starts - offsetY = 0, - xProp = 'pageX', - yProp = 'pageY', - bounds = null, - refreshTop = false, - moveDelegate = null - ; - - /** - * Helper: sets the element top/left coordinates - * - * @param {Event} event DOM event object. - * @param {Node} element The element being moved. - * - * @return {undefined} - */ - function moveElement(event, element) { - var left = (event[xProp] - offsetX), - top = (event[yProp] - offsetY); - - if(refreshTop){ - top -= document.body.scrollTop; - } - - element.style.left = left + 'px'; - element.style.top = top + 'px'; - - } - /** - * Helper: sets the element top/left coordinates within screen bounds - * - * @param {Event} event DOM event object. - * @param {Node} element The element being moved. - * - * @return {undefined} - */ - function moveElementBounded(event, element) { - var left = (event[xProp] - offsetX), - top = (event[yProp] - offsetY); + /** + * Focus event handler, attached to document.body and dialogs own reset links. + * handles the focus for modal dialogs only. + * + * @param {Event} event DOM focus event object. + * @param {Object} instance The dilog instance. + * + * @return {undefined} + */ + function onReset(event, instance) { + // should work on last modal if triggered from document.body + if (!instance) { + for (var x = openDialogs.length - 1; x > -1; x -= 1) { + if (openDialogs[x].isModal()) { + instance = openDialogs[x]; + break; + } + } + } + // if modal + if (instance && instance.isModal()) { + // determine reset target to enable forward/backward tab cycle. + var resetTarget, + target = event.srcElement || event.target; + var lastResetElement = + target === instance.elements.reset[1] || + (instance.__internal.buttons.length === 0 && + target === document.body); + + // if last reset link, then go to maximize or close + if (lastResetElement) { + if (instance.get("maximizable")) { + resetTarget = instance.elements.commands.maximize; + } else if (instance.get("closable")) { + resetTarget = instance.elements.commands.close; + } + } + // if no reset target found, try finding the best button + if (resetTarget === undefined) { + if (typeof instance.__internal.focus.element === "number") { + // button focus element, go to first available button + if (target === instance.elements.reset[0]) { + resetTarget = + instance.elements.buttons.auxiliary.firstChild || + instance.elements.buttons.primary.firstChild; + } else if (lastResetElement) { + //restart the cycle by going to first reset link + resetTarget = instance.elements.reset[0]; + } + } else { + // will reach here when tapping backwards, so go to last child + // The focus element SHOULD NOT be a button (logically!). + if (target === instance.elements.reset[0]) { + resetTarget = + instance.elements.buttons.primary.lastChild || + instance.elements.buttons.auxiliary.lastChild; + } + } + } + // focus + setFocus(instance, resetTarget); + } + } + /** + * Transition in transitionend event handler. + * + * @param {Event} TransitionEnd event object. + * @param {Object} The dilog instance. + * + * @return {undefined} + */ + function handleTransitionInEvent(event, instance) { + // clear the timer + clearTimeout(instance.__internal.timerIn); - if(refreshTop){ - top -= document.body.scrollTop; - } - - element.style.left = Math.min(bounds.maxLeft, Math.max(bounds.minLeft, left)) + 'px'; - if(refreshTop){ - element.style.top = Math.min(bounds.maxTop, Math.max(bounds.minTop, top)) + 'px'; - }else{ - element.style.top = Math.max(bounds.minTop, top) + 'px'; - } - } - + // once transition is complete, set focus + setFocus(instance); - /** - * Triggers the start of a move event, attached to the header element mouse down event. - * Adds no-selection class to the body, disabling selection while moving. - * - * @param {Event} event DOM event object. - * @param {Object} instance The dilog instance. - * - * @return {Boolean} false - */ - function beginMove(event, instance) { - if (resizable === null && !instance.isMaximized() && instance.get('movable')) { - var eventSrc, left=0, top=0; - if (event.type === 'touchstart') { - event.preventDefault(); - eventSrc = event.targetTouches[0]; - xProp = 'clientX'; - yProp = 'clientY'; - } else if (event.button === 0) { - eventSrc = event; - } + //restore scroll to prevent document jump + restoreScrollPosition(); - if (eventSrc) { - - var element = instance.elements.dialog; - addClass(element, classes.capture); - - if (element.style.left) { - left = parseInt(element.style.left, 10); - } - - if (element.style.top) { - top = parseInt(element.style.top, 10); - } - - offsetX = eventSrc[xProp] - left; - offsetY = eventSrc[yProp] - top; - - if(instance.isModal()){ - offsetY += instance.elements.modal.scrollTop; - }else if(instance.isPinned()){ - offsetY -= document.body.scrollTop; - } - - if(instance.get('moveBounded')){ - var current = element, - offsetLeft = -left, - offsetTop = -top; - - //calc offset - do { - offsetLeft += current.offsetLeft; - offsetTop += current.offsetTop; - } while (current = current.offsetParent); - - bounds = { - maxLeft : offsetLeft, - minLeft : -offsetLeft, - maxTop : document.documentElement.clientHeight - element.clientHeight - offsetTop, - minTop : -offsetTop - }; - moveDelegate = moveElementBounded; - }else{ - bounds = null; - moveDelegate = moveElement; - } - - // allow custom `onmove` method - dispatchEvent('onmove', instance); - - refreshTop = !instance.isModal() && instance.isPinned(); - movable = instance; - moveDelegate(eventSrc, element); - addClass(document.body, classes.noSelection); - return false; - } - } - } + // allow handling key up after transition ended. + cancelKeyup = false; - /** - * The actual move handler, attached to document.body mousemove event. - * - * @param {Event} event DOM event object. - * - * @return {undefined} - */ - function move(event) { - if (movable) { - var eventSrc; - if (event.type === 'touchmove') { - event.preventDefault(); - eventSrc = event.targetTouches[0]; - } else if (event.button === 0) { - eventSrc = event; - } - if (eventSrc) { - moveDelegate(eventSrc, movable.elements.dialog); - } - } - } + // allow custom `onfocus` method + dispatchEvent("onfocus", instance); - /** - * Triggers the end of a move event, attached to document.body mouseup event. - * Removes no-selection class from document.body, allowing selection. - * - * @return {undefined} - */ - function endMove() { - if (movable) { - var instance = movable; - movable = bounds = null; - removeClass(document.body, classes.noSelection); - removeClass(instance.elements.dialog, classes.capture); - // allow custom `onmoved` method - dispatchEvent('onmoved', instance); - } - } + // unbind the event + off( + instance.elements.dialog, + transition.type, + instance.__internal.transitionInHandler + ); - /** - * Resets any changes made by moving the element to its original state, - * - * @param {Object} instance The dilog instance. - * - * @return {undefined} - */ - function resetMove(instance) { - movable = null; - var element = instance.elements.dialog; - element.style.left = element.style.top = ''; - } + removeClass(instance.elements.root, classes.animationIn); + } - /** - * Updates the dialog move behavior. - * - * @param {Object} instance The dilog instance. - * @param {Boolean} on True to add the behavior, removes it otherwise. - * - * @return {undefined} - */ - function updateMovable(instance) { - if (instance.get('movable')) { - // add class - addClass(instance.elements.root, classes.movable); - if (instance.isOpen()) { - bindMovableEvents(instance); - } - } else { + /** + * Transition out transitionend event handler. + * + * @param {Event} TransitionEnd event object. + * @param {Object} The dilog instance. + * + * @return {undefined} + */ + function handleTransitionOutEvent(event, instance) { + // clear the timer + clearTimeout(instance.__internal.timerOut); + // unbind the event + off( + instance.elements.dialog, + transition.type, + instance.__internal.transitionOutHandler + ); + + // reset move updates + resetMove(instance); + // reset resize updates + resetResize(instance); + + // restore if maximized + if (instance.isMaximized() && !instance.get("startMaximized")) { + restore(instance); + } + + // return focus to the last active element + if ( + alertify.defaults.maintainFocus && + instance.__internal.activeElement + ) { + instance.__internal.activeElement.focus(); + instance.__internal.activeElement = null; + } + + //destory the instance + if (typeof instance.__internal.destroy === "function") { + instance.__internal.destroy.apply(instance); + } + } + /* Controls moving a dialog around */ + //holde the current moving instance + var movable = null, + //holds the current X offset when move starts + offsetX = 0, + //holds the current Y offset when move starts + offsetY = 0, + xProp = "pageX", + yProp = "pageY", + bounds = null, + refreshTop = false, + moveDelegate = null; + /** + * Helper: sets the element top/left coordinates + * + * @param {Event} event DOM event object. + * @param {Node} element The element being moved. + * + * @return {undefined} + */ + function moveElement(event, element) { + var left = event[xProp] - offsetX, + top = event[yProp] - offsetY; - //reset - resetMove(instance); - // remove class - removeClass(instance.elements.root, classes.movable); - if (instance.isOpen()) { - unbindMovableEvents(instance); - } - } - } + if (refreshTop) { + top -= document.body.scrollTop; + } - /* Controls moving a dialog around */ - //holde the current instance being resized - var resizable = null, - //holds the staring left offset when resize starts. - startingLeft = Number.Nan, - //holds the staring width when resize starts. - startingWidth = 0, - //holds the initial width when resized for the first time. - minWidth = 0, - //holds the offset of the resize handle. - handleOffset = 0 - ; - - /** - * Helper: sets the element width/height and updates left coordinate if neccessary. - * - * @param {Event} event DOM mousemove event object. - * @param {Node} element The element being moved. - * @param {Boolean} pinned A flag indicating if the element being resized is pinned to the screen. - * - * @return {undefined} - */ - function resizeElement(event, element, pageRelative) { + element.style.left = left + "px"; + element.style.top = top + "px"; + } + /** + * Helper: sets the element top/left coordinates within screen bounds + * + * @param {Event} event DOM event object. + * @param {Node} element The element being moved. + * + * @return {undefined} + */ + function moveElementBounded(event, element) { + var left = event[xProp] - offsetX, + top = event[yProp] - offsetY; + + if (refreshTop) { + top -= document.body.scrollTop; + } + + element.style.left = + Math.min(bounds.maxLeft, Math.max(bounds.minLeft, left)) + "px"; + if (refreshTop) { + element.style.top = + Math.min(bounds.maxTop, Math.max(bounds.minTop, top)) + "px"; + } else { + element.style.top = Math.max(bounds.minTop, top) + "px"; + } + } - //calculate offsets from 0,0 - var current = element; - var offsetLeft = 0; - var offsetTop = 0; + /** + * Triggers the start of a move event, attached to the header element mouse down event. + * Adds no-selection class to the body, disabling selection while moving. + * + * @param {Event} event DOM event object. + * @param {Object} instance The dilog instance. + * + * @return {Boolean} false + */ + function beginMove(event, instance) { + if ( + resizable === null && + !instance.isMaximized() && + instance.get("movable") + ) { + var eventSrc, + left = 0, + top = 0; + if (event.type === "touchstart") { + event.preventDefault(); + eventSrc = event.targetTouches[0]; + xProp = "clientX"; + yProp = "clientY"; + } else if (event.button === 0) { + eventSrc = event; + } + + if (eventSrc) { + var element = instance.elements.dialog; + addClass(element, classes.capture); + + if (element.style.left) { + left = parseInt(element.style.left, 10); + } + + if (element.style.top) { + top = parseInt(element.style.top, 10); + } + + offsetX = eventSrc[xProp] - left; + offsetY = eventSrc[yProp] - top; + + if (instance.isModal()) { + offsetY += instance.elements.modal.scrollTop; + } else if (instance.isPinned()) { + offsetY -= document.body.scrollTop; + } + + if (instance.get("moveBounded")) { + var current = element, + offsetLeft = -left, + offsetTop = -top; + + //calc offset do { - offsetLeft += current.offsetLeft; - offsetTop += current.offsetTop; - } while (current = current.offsetParent); - - // determine X,Y coordinates. - var X, Y; - if (pageRelative === true) { - X = event.pageX; - Y = event.pageY; - } else { - X = event.clientX; - Y = event.clientY; - } - // rtl handling - var isRTL = isRightToLeft(); - if (isRTL) { - // reverse X - X = document.body.offsetWidth - X; - // if has a starting left, calculate offsetRight - if (!isNaN(startingLeft)) { - offsetLeft = document.body.offsetWidth - offsetLeft - element.offsetWidth; - } - } - - // set width/height - element.style.height = (Y - offsetTop + handleOffset) + 'px'; - element.style.width = (X - offsetLeft + handleOffset) + 'px'; - - // if the element being resized has a starting left, maintain it. - // the dialog is centered, divide by half the offset to maintain the margins. - if (!isNaN(startingLeft)) { - var diff = Math.abs(element.offsetWidth - startingWidth) * 0.5; - if (isRTL) { - //negate the diff, why? - //when growing it should decrease left - //when shrinking it should increase left - diff *= -1; - } - if (element.offsetWidth > startingWidth) { - //growing - element.style.left = (startingLeft + diff) + 'px'; - } else if (element.offsetWidth >= minWidth) { - //shrinking - element.style.left = (startingLeft - diff) + 'px'; - } - } - } - - /** - * Triggers the start of a resize event, attached to the resize handle element mouse down event. - * Adds no-selection class to the body, disabling selection while moving. - * - * @param {Event} event DOM event object. - * @param {Object} instance The dilog instance. - * - * @return {Boolean} false - */ - function beginResize(event, instance) { - if (!instance.isMaximized()) { - var eventSrc; - if (event.type === 'touchstart') { - event.preventDefault(); - eventSrc = event.targetTouches[0]; - } else if (event.button === 0) { - eventSrc = event; - } - if (eventSrc) { - // allow custom `onresize` method - dispatchEvent('onresize', instance); - - resizable = instance; - handleOffset = instance.elements.resizeHandle.offsetHeight / 2; - var element = instance.elements.dialog; - addClass(element, classes.capture); - startingLeft = parseInt(element.style.left, 10); - element.style.height = element.offsetHeight + 'px'; - element.style.minHeight = instance.elements.header.offsetHeight + instance.elements.footer.offsetHeight + 'px'; - element.style.width = (startingWidth = element.offsetWidth) + 'px'; - - if (element.style.maxWidth !== 'none') { - element.style.minWidth = (minWidth = element.offsetWidth) + 'px'; - } - element.style.maxWidth = 'none'; - addClass(document.body, classes.noSelection); - return false; - } - } - } - - /** - * The actual resize handler, attached to document.body mousemove event. - * - * @param {Event} event DOM event object. - * - * @return {undefined} - */ - function resize(event) { - if (resizable) { - var eventSrc; - if (event.type === 'touchmove') { - event.preventDefault(); - eventSrc = event.targetTouches[0]; - } else if (event.button === 0) { - eventSrc = event; - } - if (eventSrc) { - resizeElement(eventSrc, resizable.elements.dialog, !resizable.get('modal') && !resizable.get('pinned')); - } - } - } - - /** - * Triggers the end of a resize event, attached to document.body mouseup event. - * Removes no-selection class from document.body, allowing selection. - * - * @return {undefined} - */ - function endResize() { - if (resizable) { - var instance = resizable; - resizable = null; - removeClass(document.body, classes.noSelection); - removeClass(instance.elements.dialog, classes.capture); - cancelClick = true; - // allow custom `onresized` method - dispatchEvent('onresized', instance); - } - } - - /** - * Resets any changes made by resizing the element to its original state. - * - * @param {Object} instance The dilog instance. - * - * @return {undefined} - */ - function resetResize(instance) { - resizable = null; - var element = instance.elements.dialog; - if (element.style.maxWidth === 'none') { - //clear inline styles. - element.style.maxWidth = element.style.minWidth = element.style.width = element.style.height = element.style.minHeight = element.style.left = ''; - //reset variables. - startingLeft = Number.Nan; - startingWidth = minWidth = handleOffset = 0; - } - } - - - /** - * Updates the dialog move behavior. - * - * @param {Object} instance The dilog instance. - * @param {Boolean} on True to add the behavior, removes it otherwise. - * - * @return {undefined} - */ - function updateResizable(instance) { - if (instance.get('resizable')) { - // add class - addClass(instance.elements.root, classes.resizable); - if (instance.isOpen()) { - bindResizableEvents(instance); - } - } else { - //reset - resetResize(instance); - // remove class - removeClass(instance.elements.root, classes.resizable); - if (instance.isOpen()) { - unbindResizableEvents(instance); - } - } - } - - /** - * Reset move/resize on window resize. - * - * @param {Event} event window resize event object. - * - * @return {undefined} - */ - function windowResize(/*event*/) { - for (var x = 0; x < openDialogs.length; x += 1) { - var instance = openDialogs[x]; - if (instance.get('autoReset')) { - resetMove(instance); - resetResize(instance); - } - } - } - /** - * Bind dialogs events - * - * @param {Object} instance The dilog instance. - * - * @return {undefined} - */ - function bindEvents(instance) { - // if first dialog, hook global handlers - if (openDialogs.length === 1) { - //global - on(window, 'resize', windowResize); - on(document.body, 'keyup', keyupHandler); - on(document.body, 'keydown', keydownHandler); - on(document.body, 'focus', onReset); - - //move - on(document.documentElement, 'mousemove', move); - on(document.documentElement, 'touchmove', move); - on(document.documentElement, 'mouseup', endMove); - on(document.documentElement, 'touchend', endMove); - //resize - on(document.documentElement, 'mousemove', resize); - on(document.documentElement, 'touchmove', resize); - on(document.documentElement, 'mouseup', endResize); - on(document.documentElement, 'touchend', endResize); - } - - // common events - on(instance.elements.commands.container, 'click', instance.__internal.commandsClickHandler); - on(instance.elements.footer, 'click', instance.__internal.buttonsClickHandler); - on(instance.elements.reset[0], 'focus', instance.__internal.resetHandler); - on(instance.elements.reset[1], 'focus', instance.__internal.resetHandler); - - //prevent handling key up when dialog is being opened by a key stroke. - cancelKeyup = true; - // hook in transition handler - on(instance.elements.dialog, transition.type, instance.__internal.transitionInHandler); - - // modelss only events - if (!instance.get('modal')) { - bindModelessEvents(instance); - } - - // resizable - if (instance.get('resizable')) { - bindResizableEvents(instance); - } - - // movable - if (instance.get('movable')) { - bindMovableEvents(instance); - } - } - - /** - * Unbind dialogs events - * - * @param {Object} instance The dilog instance. - * - * @return {undefined} - */ - function unbindEvents(instance) { - // if last dialog, remove global handlers - if (openDialogs.length === 1) { - //global - off(window, 'resize', windowResize); - off(document.body, 'keyup', keyupHandler); - off(document.body, 'keydown', keydownHandler); - off(document.body, 'focus', onReset); - //move - off(document.documentElement, 'mousemove', move); - off(document.documentElement, 'mouseup', endMove); - //resize - off(document.documentElement, 'mousemove', resize); - off(document.documentElement, 'mouseup', endResize); - } - - // common events - off(instance.elements.commands.container, 'click', instance.__internal.commandsClickHandler); - off(instance.elements.footer, 'click', instance.__internal.buttonsClickHandler); - off(instance.elements.reset[0], 'focus', instance.__internal.resetHandler); - off(instance.elements.reset[1], 'focus', instance.__internal.resetHandler); - - // hook out transition handler - on(instance.elements.dialog, transition.type, instance.__internal.transitionOutHandler); - - // modelss only events - if (!instance.get('modal')) { - unbindModelessEvents(instance); - } - - // movable - if (instance.get('movable')) { - unbindMovableEvents(instance); - } - - // resizable - if (instance.get('resizable')) { - unbindResizableEvents(instance); - } - - } - - /** - * Bind modeless specific events - * - * @param {Object} instance The dilog instance. - * - * @return {undefined} - */ - function bindModelessEvents(instance) { - on(instance.elements.dialog, 'focus', instance.__internal.bringToFrontHandler, true); - } + offsetLeft += current.offsetLeft; + offsetTop += current.offsetTop; + } while ((current = current.offsetParent)); + + bounds = { + maxLeft: offsetLeft, + minLeft: -offsetLeft, + maxTop: + document.documentElement.clientHeight - + element.clientHeight - + offsetTop, + minTop: -offsetTop, + }; + moveDelegate = moveElementBounded; + } else { + bounds = null; + moveDelegate = moveElement; + } + + // allow custom `onmove` method + dispatchEvent("onmove", instance); + + refreshTop = !instance.isModal() && instance.isPinned(); + movable = instance; + moveDelegate(eventSrc, element); + addClass(document.body, classes.noSelection); + return false; + } + } + } - /** - * Unbind modeless specific events - * - * @param {Object} instance The dilog instance. - * - * @return {undefined} - */ - function unbindModelessEvents(instance) { - off(instance.elements.dialog, 'focus', instance.__internal.bringToFrontHandler, true); - } + /** + * The actual move handler, attached to document.body mousemove event. + * + * @param {Event} event DOM event object. + * + * @return {undefined} + */ + function move(event) { + if (movable) { + var eventSrc; + if (event.type === "touchmove") { + event.preventDefault(); + eventSrc = event.targetTouches[0]; + } else if (event.button === 0) { + eventSrc = event; + } + if (eventSrc) { + moveDelegate(eventSrc, movable.elements.dialog); + } + } + } + /** + * Triggers the end of a move event, attached to document.body mouseup event. + * Removes no-selection class from document.body, allowing selection. + * + * @return {undefined} + */ + function endMove() { + if (movable) { + var instance = movable; + movable = bounds = null; + removeClass(document.body, classes.noSelection); + removeClass(instance.elements.dialog, classes.capture); + // allow custom `onmoved` method + dispatchEvent("onmoved", instance); + } + } + /** + * Resets any changes made by moving the element to its original state, + * + * @param {Object} instance The dilog instance. + * + * @return {undefined} + */ + function resetMove(instance) { + movable = null; + var element = instance.elements.dialog; + element.style.left = element.style.top = ""; + } - /** - * Bind movable specific events - * - * @param {Object} instance The dilog instance. - * - * @return {undefined} - */ - function bindMovableEvents(instance) { - on(instance.elements.header, 'mousedown', instance.__internal.beginMoveHandler); - on(instance.elements.header, 'touchstart', instance.__internal.beginMoveHandler); - } + /** + * Updates the dialog move behavior. + * + * @param {Object} instance The dilog instance. + * @param {Boolean} on True to add the behavior, removes it otherwise. + * + * @return {undefined} + */ + function updateMovable(instance) { + if (instance.get("movable")) { + // add class + addClass(instance.elements.root, classes.movable); + if (instance.isOpen()) { + bindMovableEvents(instance); + } + } else { + //reset + resetMove(instance); + // remove class + removeClass(instance.elements.root, classes.movable); + if (instance.isOpen()) { + unbindMovableEvents(instance); + } + } + } - /** - * Unbind movable specific events - * - * @param {Object} instance The dilog instance. - * - * @return {undefined} - */ - function unbindMovableEvents(instance) { - off(instance.elements.header, 'mousedown', instance.__internal.beginMoveHandler); - off(instance.elements.header, 'touchstart', instance.__internal.beginMoveHandler); - } + /* Controls moving a dialog around */ + //holde the current instance being resized + var resizable = null, + //holds the staring left offset when resize starts. + startingLeft = Number.Nan, + //holds the staring width when resize starts. + startingWidth = 0, + //holds the initial width when resized for the first time. + minWidth = 0, + //holds the offset of the resize handle. + handleOffset = 0; + /** + * Helper: sets the element width/height and updates left coordinate if neccessary. + * + * @param {Event} event DOM mousemove event object. + * @param {Node} element The element being moved. + * @param {Boolean} pinned A flag indicating if the element being resized is pinned to the screen. + * + * @return {undefined} + */ + function resizeElement(event, element, pageRelative) { + //calculate offsets from 0,0 + var current = element; + var offsetLeft = 0; + var offsetTop = 0; + do { + offsetLeft += current.offsetLeft; + offsetTop += current.offsetTop; + } while ((current = current.offsetParent)); + + // determine X,Y coordinates. + var X, Y; + if (pageRelative === true) { + X = event.pageX; + Y = event.pageY; + } else { + X = event.clientX; + Y = event.clientY; + } + // rtl handling + var isRTL = isRightToLeft(); + if (isRTL) { + // reverse X + X = document.body.offsetWidth - X; + // if has a starting left, calculate offsetRight + if (!isNaN(startingLeft)) { + offsetLeft = + document.body.offsetWidth - offsetLeft - element.offsetWidth; + } + } + + // set width/height + element.style.height = Y - offsetTop + handleOffset + "px"; + element.style.width = X - offsetLeft + handleOffset + "px"; + + // if the element being resized has a starting left, maintain it. + // the dialog is centered, divide by half the offset to maintain the margins. + if (!isNaN(startingLeft)) { + var diff = Math.abs(element.offsetWidth - startingWidth) * 0.5; + if (isRTL) { + //negate the diff, why? + //when growing it should decrease left + //when shrinking it should increase left + diff *= -1; + } + if (element.offsetWidth > startingWidth) { + //growing + element.style.left = startingLeft + diff + "px"; + } else if (element.offsetWidth >= minWidth) { + //shrinking + element.style.left = startingLeft - diff + "px"; + } + } + } + /** + * Triggers the start of a resize event, attached to the resize handle element mouse down event. + * Adds no-selection class to the body, disabling selection while moving. + * + * @param {Event} event DOM event object. + * @param {Object} instance The dilog instance. + * + * @return {Boolean} false + */ + function beginResize(event, instance) { + if (!instance.isMaximized()) { + var eventSrc; + if (event.type === "touchstart") { + event.preventDefault(); + eventSrc = event.targetTouches[0]; + } else if (event.button === 0) { + eventSrc = event; + } + if (eventSrc) { + // allow custom `onresize` method + dispatchEvent("onresize", instance); + + resizable = instance; + handleOffset = instance.elements.resizeHandle.offsetHeight / 2; + var element = instance.elements.dialog; + addClass(element, classes.capture); + startingLeft = parseInt(element.style.left, 10); + element.style.height = element.offsetHeight + "px"; + element.style.minHeight = + instance.elements.header.offsetHeight + + instance.elements.footer.offsetHeight + + "px"; + element.style.width = (startingWidth = element.offsetWidth) + "px"; + + if (element.style.maxWidth !== "none") { + element.style.minWidth = (minWidth = element.offsetWidth) + "px"; + } + element.style.maxWidth = "none"; + addClass(document.body, classes.noSelection); + return false; + } + } + } + /** + * The actual resize handler, attached to document.body mousemove event. + * + * @param {Event} event DOM event object. + * + * @return {undefined} + */ + function resize(event) { + if (resizable) { + var eventSrc; + if (event.type === "touchmove") { + event.preventDefault(); + eventSrc = event.targetTouches[0]; + } else if (event.button === 0) { + eventSrc = event; + } + if (eventSrc) { + resizeElement( + eventSrc, + resizable.elements.dialog, + !resizable.get("modal") && !resizable.get("pinned") + ); + } + } + } - /** - * Bind resizable specific events - * - * @param {Object} instance The dilog instance. - * - * @return {undefined} - */ - function bindResizableEvents(instance) { - on(instance.elements.resizeHandle, 'mousedown', instance.__internal.beginResizeHandler); - on(instance.elements.resizeHandle, 'touchstart', instance.__internal.beginResizeHandler); - } + /** + * Triggers the end of a resize event, attached to document.body mouseup event. + * Removes no-selection class from document.body, allowing selection. + * + * @return {undefined} + */ + function endResize() { + if (resizable) { + var instance = resizable; + resizable = null; + removeClass(document.body, classes.noSelection); + removeClass(instance.elements.dialog, classes.capture); + cancelClick = true; + // allow custom `onresized` method + dispatchEvent("onresized", instance); + } + } - /** - * Unbind resizable specific events - * - * @param {Object} instance The dilog instance. - * - * @return {undefined} - */ - function unbindResizableEvents(instance) { - off(instance.elements.resizeHandle, 'mousedown', instance.__internal.beginResizeHandler); - off(instance.elements.resizeHandle, 'touchstart', instance.__internal.beginResizeHandler); - } + /** + * Resets any changes made by resizing the element to its original state. + * + * @param {Object} instance The dilog instance. + * + * @return {undefined} + */ + function resetResize(instance) { + resizable = null; + var element = instance.elements.dialog; + if (element.style.maxWidth === "none") { + //clear inline styles. + element.style.maxWidth = + element.style.minWidth = + element.style.width = + element.style.height = + element.style.minHeight = + element.style.left = + ""; + //reset variables. + startingLeft = Number.Nan; + startingWidth = minWidth = handleOffset = 0; + } + } - /** - * Bind closable events - * - * @param {Object} instance The dilog instance. - * - * @return {undefined} - */ - function bindClosableEvents(instance) { - on(instance.elements.modal, 'click', instance.__internal.modalClickHandler); - } + /** + * Updates the dialog move behavior. + * + * @param {Object} instance The dilog instance. + * @param {Boolean} on True to add the behavior, removes it otherwise. + * + * @return {undefined} + */ + function updateResizable(instance) { + if (instance.get("resizable")) { + // add class + addClass(instance.elements.root, classes.resizable); + if (instance.isOpen()) { + bindResizableEvents(instance); + } + } else { + //reset + resetResize(instance); + // remove class + removeClass(instance.elements.root, classes.resizable); + if (instance.isOpen()) { + unbindResizableEvents(instance); + } + } + } - /** - * Unbind closable specific events - * - * @param {Object} instance The dilog instance. - * - * @return {undefined} - */ - function unbindClosableEvents(instance) { - off(instance.elements.modal, 'click', instance.__internal.modalClickHandler); - } - // dialog API - return { - __init:initialize, - /** - * Check if dialog is currently open - * - * @return {Boolean} - */ - isOpen: function () { - return this.__internal.isOpen; - }, - isModal: function (){ - return this.elements.root.className.indexOf(classes.modeless) < 0; - }, - isMaximized:function(){ - return this.elements.root.className.indexOf(classes.maximized) > -1; - }, - isPinned:function(){ - return this.elements.root.className.indexOf(classes.unpinned) < 0; - }, - maximize:function(){ - if(!this.isMaximized()){ - maximize(this); - } - return this; - }, - restore:function(){ - if(this.isMaximized()){ - restore(this); - } - return this; - }, - pin:function(){ - if(!this.isPinned()){ - pin(this); - } - return this; - }, - unpin:function(){ - if(this.isPinned()){ - unpin(this); - } - return this; - }, - bringToFront:function(){ - bringToFront(null, this); - return this; - }, - /** - * Move the dialog to a specific x/y coordinates - * - * @param {Number} x The new dialog x coordinate in pixels. - * @param {Number} y The new dialog y coordinate in pixels. - * - * @return {Object} The dialog instance. - */ - moveTo:function(x,y){ - if(!isNaN(x) && !isNaN(y)){ - // allow custom `onmove` method - dispatchEvent('onmove', this); - - var element = this.elements.dialog, - current = element, - offsetLeft = 0, - offsetTop = 0; - - //subtract existing left,top - if (element.style.left) { - offsetLeft -= parseInt(element.style.left, 10); - } - if (element.style.top) { - offsetTop -= parseInt(element.style.top, 10); - } - //calc offset - do { - offsetLeft += current.offsetLeft; - offsetTop += current.offsetTop; - } while (current = current.offsetParent); - - //calc left, top - var left = (x - offsetLeft); - var top = (y - offsetTop); - - //// rtl handling - if (isRightToLeft()) { - left *= -1; - } - - element.style.left = left + 'px'; - element.style.top = top + 'px'; - - // allow custom `onmoved` method - dispatchEvent('onmoved', this); - } - return this; - }, - /** - * Resize the dialog to a specific width/height (the dialog must be 'resizable'). - * The dialog can be resized to: - * A minimum width equal to the initial display width - * A minimum height equal to the sum of header/footer heights. - * - * - * @param {Number or String} width The new dialog width in pixels or in percent. - * @param {Number or String} height The new dialog height in pixels or in percent. - * - * @return {Object} The dialog instance. - */ - resizeTo:function(width,height){ - var w = parseFloat(width), - h = parseFloat(height), - regex = /(\d*\.\d+|\d+)%/ - ; - - if(!isNaN(w) && !isNaN(h) && this.get('resizable') === true){ - - // allow custom `onresize` method - dispatchEvent('onresize', this); - - if(('' + width).match(regex)){ - w = w / 100 * document.documentElement.clientWidth ; - } - - if(('' + height).match(regex)){ - h = h / 100 * document.documentElement.clientHeight; - } - - var element = this.elements.dialog; - if (element.style.maxWidth !== 'none') { - element.style.minWidth = (minWidth = element.offsetWidth) + 'px'; - } - element.style.maxWidth = 'none'; - element.style.minHeight = this.elements.header.offsetHeight + this.elements.footer.offsetHeight + 'px'; - element.style.width = w + 'px'; - element.style.height = h + 'px'; - - // allow custom `onresized` method - dispatchEvent('onresized', this); - } - return this; - }, - /** - * Gets or Sets dialog settings/options - * - * @param {String|Object} key A string specifying a propery name or a collection of key/value pairs. - * @param {Object} value Optional, the value associated with the key (in case it was a string). - * - * @return {undefined} - */ - setting : function (key, value) { - var self = this; - var result = update(this, this.__internal.options, function(k,o,n){ optionUpdated(self,k,o,n); }, key, value); - if(result.op === 'get'){ - if(result.found){ - return result.value; - }else if(typeof this.settings !== 'undefined'){ - return update(this, this.settings, this.settingUpdated || function(){}, key, value).value; - }else{ - return undefined; - } - }else if(result.op === 'set'){ - if(result.items.length > 0){ - var callback = this.settingUpdated || function(){}; - for(var x=0;x<result.items.length;x+=1){ - var item = result.items[x]; - if(!item.found && typeof this.settings !== 'undefined'){ - update(this, this.settings, callback, item.key, item.value); - } - } - } - return this; - } - }, - /** - * [Alias] Sets dialog settings/options - */ - set:function(key, value){ - this.setting(key,value); - return this; - }, - /** - * [Alias] Gets dialog settings/options - */ - get:function(key){ - return this.setting(key); - }, - /** - * Sets dialog header - * @content {string or element} - * - * @return {undefined} - */ - setHeader:function(content){ - if(typeof content === 'string'){ - clearContents(this.elements.header); - this.elements.header.innerHTML = content; - }else if (content instanceof window.HTMLElement && this.elements.header.firstChild !== content){ - clearContents(this.elements.header); - this.elements.header.appendChild(content); - } - return this; - }, - /** - * Sets dialog contents - * @content {string or element} - * - * @return {undefined} - */ - setContent:function(content){ - if(typeof content === 'string'){ - clearContents(this.elements.content); - this.elements.content.innerHTML = content; - }else if (content instanceof window.HTMLElement && this.elements.content.firstChild !== content){ - clearContents(this.elements.content); - this.elements.content.appendChild(content); - } - return this; - }, - /** - * Show the dialog as modal - * - * @return {Object} the dialog instance. - */ - showModal: function(className){ - return this.show(true, className); - }, - /** - * Show the dialog - * - * @return {Object} the dialog instance. - */ - show: function (modal, className) { - - // ensure initialization - initialize(this); - - if ( !this.__internal.isOpen ) { - - // add to open dialogs - this.__internal.isOpen = true; - openDialogs.push(this); - - // save last focused element - if(alertify.defaults.maintainFocus){ - this.__internal.activeElement = document.activeElement; - } - - // set tabindex attribute on body element this allows script to give it focusable - if(!document.body.hasAttribute('tabindex')) { - document.body.setAttribute( 'tabindex', tabindex = '0'); - } - - //allow custom dom manipulation updates before showing the dialog. - if(typeof this.prepare === 'function'){ - this.prepare(); - } - - bindEvents(this); - - if(modal !== undefined){ - this.set('modal', modal); - } - - //save scroll to prevent document jump - saveScrollPosition(); - - ensureNoOverflow(); - - // allow custom dialog class on show - if(typeof className === 'string' && className !== ''){ - this.__internal.className = className; - addClass(this.elements.root, className); - } - - // maximize if start maximized - if ( this.get('startMaximized')) { - this.maximize(); - }else if(this.isMaximized()){ - restore(this); - } - - updateAbsPositionFix(this); - this.elements.root.removeAttribute('style'); - removeClass(this.elements.root, classes.animationOut); - addClass(this.elements.root, classes.animationIn); - - // set 1s fallback in case transition event doesn't fire - clearTimeout( this.__internal.timerIn); - this.__internal.timerIn = setTimeout( this.__internal.transitionInHandler, transition.supported ? 1000 : 100 ); - - if(isSafari){ - // force desktop safari reflow - var root = this.elements.root; - root.style.display = 'none'; - setTimeout(function(){root.style.display = 'block';}, 0); - } - - //reflow - reflow = this.elements.root.offsetWidth; - - // show dialog - removeClass(this.elements.root, classes.hidden); - - // internal on show event - if(typeof this.hooks.onshow === 'function'){ - this.hooks.onshow.call(this); - } - - // allow custom `onshow` method - dispatchEvent('onshow', this); - - }else{ - // reset move updates - resetMove(this); - // reset resize updates - resetResize(this); - // shake the dialog to indicate its already open - addClass(this.elements.dialog, classes.shake); - var self = this; - setTimeout(function(){ - removeClass(self.elements.dialog, classes.shake); - },200); - } - return this; - }, - /** - * Close the dialog - * - * @return {Object} The dialog instance - */ - close: function () { - if (this.__internal.isOpen ) { - // custom `onclosing` event - if(dispatchEvent('onclosing', this) !== false){ - - unbindEvents(this); - - removeClass(this.elements.root, classes.animationIn); - addClass(this.elements.root, classes.animationOut); - - // set 1s fallback in case transition event doesn't fire - clearTimeout( this.__internal.timerOut ); - this.__internal.timerOut = setTimeout( this.__internal.transitionOutHandler, transition.supported ? 1000 : 100 ); - // hide dialog - addClass(this.elements.root, classes.hidden); - //reflow - reflow = this.elements.modal.offsetWidth; - - // remove custom dialog class on hide - if (typeof this.__internal.className !== 'undefined' && this.__internal.className !== '') { - removeClass(this.elements.root, this.__internal.className); - } - - // internal on close event - if(typeof this.hooks.onclose === 'function'){ - this.hooks.onclose.call(this); - } - - // allow custom `onclose` method - dispatchEvent('onclose', this); - - //remove from open dialogs - openDialogs.splice(openDialogs.indexOf(this),1); - this.__internal.isOpen = false; - - ensureNoOverflow(); - } + /** + * Reset move/resize on window resize. + * + * @param {Event} event window resize event object. + * + * @return {undefined} + */ + function windowResize(/*event*/) { + for (var x = 0; x < openDialogs.length; x += 1) { + var instance = openDialogs[x]; + if (instance.get("autoReset")) { + resetMove(instance); + resetResize(instance); + } + } + } + /** + * Bind dialogs events + * + * @param {Object} instance The dilog instance. + * + * @return {undefined} + */ + function bindEvents(instance) { + // if first dialog, hook global handlers + if (openDialogs.length === 1) { + //global + on(window, "resize", windowResize); + on(document.body, "keyup", keyupHandler); + on(document.body, "keydown", keydownHandler); + on(document.body, "focus", onReset); + + //move + on(document.documentElement, "mousemove", move); + on(document.documentElement, "touchmove", move); + on(document.documentElement, "mouseup", endMove); + on(document.documentElement, "touchend", endMove); + //resize + on(document.documentElement, "mousemove", resize); + on(document.documentElement, "touchmove", resize); + on(document.documentElement, "mouseup", endResize); + on(document.documentElement, "touchend", endResize); + } + + // common events + on( + instance.elements.commands.container, + "click", + instance.__internal.commandsClickHandler + ); + on( + instance.elements.footer, + "click", + instance.__internal.buttonsClickHandler + ); + on(instance.elements.reset[0], "focus", instance.__internal.resetHandler); + on(instance.elements.reset[1], "focus", instance.__internal.resetHandler); + + //prevent handling key up when dialog is being opened by a key stroke. + cancelKeyup = true; + // hook in transition handler + on( + instance.elements.dialog, + transition.type, + instance.__internal.transitionInHandler + ); + + // modelss only events + if (!instance.get("modal")) { + bindModelessEvents(instance); + } + + // resizable + if (instance.get("resizable")) { + bindResizableEvents(instance); + } + + // movable + if (instance.get("movable")) { + bindMovableEvents(instance); + } + } - } - // last dialog and tab index was set by us, remove it. - if(!openDialogs.length && tabindex === '0'){ - document.body.removeAttribute('tabindex'); - } - return this; - }, - /** - * Close all open dialogs except this. - * - * @return {undefined} - */ - closeOthers:function(){ - alertify.closeAll(this); - return this; - }, - /** - * Destroys this dialog instance - * - * @return {undefined} - */ - destroy:function(){ - if(this.__internal) { - if (this.__internal.isOpen ) { - //mark dialog for destruction, this will be called on tranistionOut event. - this.__internal.destroy = function(){ - destruct(this, initialize); - }; - //close the dialog to unbind all events. - this.close(); - }else if(!this.__internal.destroy){ - destruct(this, initialize); - } - } - return this; - }, - }; - } () ); - var notifier = (function () { - var reflow, - element, - openInstances = [], - classes = { - base: 'alertify-notifier', - message: 'ajs-message', - top: 'ajs-top', - right: 'ajs-right', - bottom: 'ajs-bottom', - left: 'ajs-left', - center: 'ajs-center', - visible: 'ajs-visible', - hidden: 'ajs-hidden', - close: 'ajs-close' - }; - /** - * Helper: initializes the notifier instance - * - */ - function initialize(instance) { + /** + * Unbind dialogs events + * + * @param {Object} instance The dilog instance. + * + * @return {undefined} + */ + function unbindEvents(instance) { + // if last dialog, remove global handlers + if (openDialogs.length === 1) { + //global + off(window, "resize", windowResize); + off(document.body, "keyup", keyupHandler); + off(document.body, "keydown", keydownHandler); + off(document.body, "focus", onReset); + //move + off(document.documentElement, "mousemove", move); + off(document.documentElement, "mouseup", endMove); + //resize + off(document.documentElement, "mousemove", resize); + off(document.documentElement, "mouseup", endResize); + } + + // common events + off( + instance.elements.commands.container, + "click", + instance.__internal.commandsClickHandler + ); + off( + instance.elements.footer, + "click", + instance.__internal.buttonsClickHandler + ); + off( + instance.elements.reset[0], + "focus", + instance.__internal.resetHandler + ); + off( + instance.elements.reset[1], + "focus", + instance.__internal.resetHandler + ); + + // hook out transition handler + on( + instance.elements.dialog, + transition.type, + instance.__internal.transitionOutHandler + ); + + // modelss only events + if (!instance.get("modal")) { + unbindModelessEvents(instance); + } + + // movable + if (instance.get("movable")) { + unbindMovableEvents(instance); + } + + // resizable + if (instance.get("resizable")) { + unbindResizableEvents(instance); + } + } - if (!instance.__internal) { - instance.__internal = { - position: alertify.defaults.notifier.position, - delay: alertify.defaults.notifier.delay, - }; + /** + * Bind modeless specific events + * + * @param {Object} instance The dilog instance. + * + * @return {undefined} + */ + function bindModelessEvents(instance) { + on( + instance.elements.dialog, + "focus", + instance.__internal.bringToFrontHandler, + true + ); + } - element = document.createElement('DIV'); + /** + * Unbind modeless specific events + * + * @param {Object} instance The dilog instance. + * + * @return {undefined} + */ + function unbindModelessEvents(instance) { + off( + instance.elements.dialog, + "focus", + instance.__internal.bringToFrontHandler, + true + ); + } - updatePosition(instance); - } + /** + * Bind movable specific events + * + * @param {Object} instance The dilog instance. + * + * @return {undefined} + */ + function bindMovableEvents(instance) { + on( + instance.elements.header, + "mousedown", + instance.__internal.beginMoveHandler + ); + on( + instance.elements.header, + "touchstart", + instance.__internal.beginMoveHandler + ); + } - //add to DOM tree. - if (element.parentNode !== document.body) { - document.body.appendChild(element); - } - } + /** + * Unbind movable specific events + * + * @param {Object} instance The dilog instance. + * + * @return {undefined} + */ + function unbindMovableEvents(instance) { + off( + instance.elements.header, + "mousedown", + instance.__internal.beginMoveHandler + ); + off( + instance.elements.header, + "touchstart", + instance.__internal.beginMoveHandler + ); + } - function pushInstance(instance) { - instance.__internal.pushed = true; - openInstances.push(instance); - } - function popInstance(instance) { - openInstances.splice(openInstances.indexOf(instance), 1); - instance.__internal.pushed = false; - } - /** - * Helper: update the notifier instance position - * - */ - function updatePosition(instance) { - element.className = classes.base; - switch (instance.__internal.position) { - case 'top-right': - addClass(element, classes.top + ' ' + classes.right); - break; - case 'top-left': - addClass(element, classes.top + ' ' + classes.left); - break; - case 'top-center': - addClass(element, classes.top + ' ' + classes.center); - break; - case 'bottom-left': - addClass(element, classes.bottom + ' ' + classes.left); - break; - case 'bottom-center': - addClass(element, classes.bottom + ' ' + classes.center); - break; + /** + * Bind resizable specific events + * + * @param {Object} instance The dilog instance. + * + * @return {undefined} + */ + function bindResizableEvents(instance) { + on( + instance.elements.resizeHandle, + "mousedown", + instance.__internal.beginResizeHandler + ); + on( + instance.elements.resizeHandle, + "touchstart", + instance.__internal.beginResizeHandler + ); + } - default: - case 'bottom-right': - addClass(element, classes.bottom + ' ' + classes.right); - break; - } - } + /** + * Unbind resizable specific events + * + * @param {Object} instance The dilog instance. + * + * @return {undefined} + */ + function unbindResizableEvents(instance) { + off( + instance.elements.resizeHandle, + "mousedown", + instance.__internal.beginResizeHandler + ); + off( + instance.elements.resizeHandle, + "touchstart", + instance.__internal.beginResizeHandler + ); + } - /** - * creates a new notification message - * - * @param {DOMElement} message The notifier message element - * @param {Number} wait Time (in ms) to wait before the message is dismissed, a value of 0 means keep open till clicked. - * @param {Function} callback A callback function to be invoked when the message is dismissed. - * - * @return {undefined} - */ - function create(div, callback) { - - function clickDelegate(event, instance) { - if(!instance.__internal.closeButton || event.target.getAttribute('data-close') === 'true'){ - instance.dismiss(true); - } - } + /** + * Bind closable events + * + * @param {Object} instance The dilog instance. + * + * @return {undefined} + */ + function bindClosableEvents(instance) { + on( + instance.elements.modal, + "click", + instance.__internal.modalClickHandler + ); + } - function transitionDone(event, instance) { - // unbind event - off(instance.element, transition.type, transitionDone); - // remove the message - element.removeChild(instance.element); - } + /** + * Unbind closable specific events + * + * @param {Object} instance The dilog instance. + * + * @return {undefined} + */ + function unbindClosableEvents(instance) { + off( + instance.elements.modal, + "click", + instance.__internal.modalClickHandler + ); + } + // dialog API + return { + __init: initialize, + /** + * Check if dialog is currently open + * + * @return {Boolean} + */ + isOpen: function () { + return this.__internal.isOpen; + }, + isModal: function () { + return this.elements.root.className.indexOf(classes.modeless) < 0; + }, + isMaximized: function () { + return this.elements.root.className.indexOf(classes.maximized) > -1; + }, + isPinned: function () { + return this.elements.root.className.indexOf(classes.unpinned) < 0; + }, + maximize: function () { + if (!this.isMaximized()) { + maximize(this); + } + return this; + }, + restore: function () { + if (this.isMaximized()) { + restore(this); + } + return this; + }, + pin: function () { + if (!this.isPinned()) { + pin(this); + } + return this; + }, + unpin: function () { + if (this.isPinned()) { + unpin(this); + } + return this; + }, + bringToFront: function () { + bringToFront(null, this); + return this; + }, + /** + * Move the dialog to a specific x/y coordinates + * + * @param {Number} x The new dialog x coordinate in pixels. + * @param {Number} y The new dialog y coordinate in pixels. + * + * @return {Object} The dialog instance. + */ + moveTo: function (x, y) { + if (!isNaN(x) && !isNaN(y)) { + // allow custom `onmove` method + dispatchEvent("onmove", this); + + var element = this.elements.dialog, + current = element, + offsetLeft = 0, + offsetTop = 0; + + //subtract existing left,top + if (element.style.left) { + offsetLeft -= parseInt(element.style.left, 10); + } + if (element.style.top) { + offsetTop -= parseInt(element.style.top, 10); + } + //calc offset + do { + offsetLeft += current.offsetLeft; + offsetTop += current.offsetTop; + } while ((current = current.offsetParent)); + + //calc left, top + var left = x - offsetLeft; + var top = y - offsetTop; + + //// rtl handling + if (isRightToLeft()) { + left *= -1; + } + + element.style.left = left + "px"; + element.style.top = top + "px"; + + // allow custom `onmoved` method + dispatchEvent("onmoved", this); + } + return this; + }, + /** + * Resize the dialog to a specific width/height (the dialog must be 'resizable'). + * The dialog can be resized to: + * A minimum width equal to the initial display width + * A minimum height equal to the sum of header/footer heights. + * + * + * @param {Number or String} width The new dialog width in pixels or in percent. + * @param {Number or String} height The new dialog height in pixels or in percent. + * + * @return {Object} The dialog instance. + */ + resizeTo: function (width, height) { + var w = parseFloat(width), + h = parseFloat(height), + regex = /(\d*\.\d+|\d+)%/; + if (!isNaN(w) && !isNaN(h) && this.get("resizable") === true) { + // allow custom `onresize` method + dispatchEvent("onresize", this); + + if (("" + width).match(regex)) { + w = (w / 100) * document.documentElement.clientWidth; + } + + if (("" + height).match(regex)) { + h = (h / 100) * document.documentElement.clientHeight; + } + + var element = this.elements.dialog; + if (element.style.maxWidth !== "none") { + element.style.minWidth = (minWidth = element.offsetWidth) + "px"; + } + element.style.maxWidth = "none"; + element.style.minHeight = + this.elements.header.offsetHeight + + this.elements.footer.offsetHeight + + "px"; + element.style.width = w + "px"; + element.style.height = h + "px"; + + // allow custom `onresized` method + dispatchEvent("onresized", this); + } + return this; + }, + /** + * Gets or Sets dialog settings/options + * + * @param {String|Object} key A string specifying a propery name or a collection of key/value pairs. + * @param {Object} value Optional, the value associated with the key (in case it was a string). + * + * @return {undefined} + */ + setting: function (key, value) { + var self = this; + var result = update( + this, + this.__internal.options, + function (k, o, n) { + optionUpdated(self, k, o, n); + }, + key, + value + ); + if (result.op === "get") { + if (result.found) { + return result.value; + } else if (typeof this.settings !== "undefined") { + return update( + this, + this.settings, + this.settingUpdated || function () {}, + key, + value + ).value; + } else { + return undefined; + } + } else if (result.op === "set") { + if (result.items.length > 0) { + var callback = this.settingUpdated || function () {}; + for (var x = 0; x < result.items.length; x += 1) { + var item = result.items[x]; + if (!item.found && typeof this.settings !== "undefined") { + update(this, this.settings, callback, item.key, item.value); + } + } + } + return this; + } + }, + /** + * [Alias] Sets dialog settings/options + */ + set: function (key, value) { + this.setting(key, value); + return this; + }, + /** + * [Alias] Gets dialog settings/options + */ + get: function (key) { + return this.setting(key); + }, + /** + * Sets dialog header + * @content {string or element} + * + * @return {undefined} + */ + setHeader: function (content) { + if (typeof content === "string") { + clearContents(this.elements.header); + this.elements.header.innerHTML = content; + } else if ( + content instanceof window.HTMLElement && + this.elements.header.firstChild !== content + ) { + clearContents(this.elements.header); + this.elements.header.appendChild(content); + } + return this; + }, + /** + * Sets dialog contents + * @content {string or element} + * + * @return {undefined} + */ + setContent: function (content) { + if (typeof content === "string") { + clearContents(this.elements.content); + this.elements.content.innerHTML = content; + } else if ( + content instanceof window.HTMLElement && + this.elements.content.firstChild !== content + ) { + clearContents(this.elements.content); + this.elements.content.appendChild(content); + } + return this; + }, + /** + * Show the dialog as modal + * + * @return {Object} the dialog instance. + */ + showModal: function (className) { + return this.show(true, className); + }, + /** + * Show the dialog + * + * @return {Object} the dialog instance. + */ + show: function (modal, className) { + // ensure initialization + initialize(this); + + if (!this.__internal.isOpen) { + // add to open dialogs + this.__internal.isOpen = true; + openDialogs.push(this); + + // save last focused element + if (alertify.defaults.maintainFocus) { + this.__internal.activeElement = document.activeElement; + } + + // set tabindex attribute on body element this allows script to give it focusable + if (!document.body.hasAttribute("tabindex")) { + document.body.setAttribute("tabindex", (tabindex = "0")); + } + + //allow custom dom manipulation updates before showing the dialog. + if (typeof this.prepare === "function") { + this.prepare(); + } + + bindEvents(this); + + if (modal !== undefined) { + this.set("modal", modal); + } + + //save scroll to prevent document jump + saveScrollPosition(); + + ensureNoOverflow(); + + // allow custom dialog class on show + if (typeof className === "string" && className !== "") { + this.__internal.className = className; + addClass(this.elements.root, className); + } + + // maximize if start maximized + if (this.get("startMaximized")) { + this.maximize(); + } else if (this.isMaximized()) { + restore(this); + } + + updateAbsPositionFix(this); + this.elements.root.removeAttribute("style"); + removeClass(this.elements.root, classes.animationOut); + addClass(this.elements.root, classes.animationIn); + + // set 1s fallback in case transition event doesn't fire + clearTimeout(this.__internal.timerIn); + this.__internal.timerIn = setTimeout( + this.__internal.transitionInHandler, + transition.supported ? 1000 : 100 + ); + + if (isSafari) { + // force desktop safari reflow + var root = this.elements.root; + root.style.display = "none"; + setTimeout(function () { + root.style.display = "block"; + }, 0); + } + + //reflow + reflow = this.elements.root.offsetWidth; + + // show dialog + removeClass(this.elements.root, classes.hidden); + + // internal on show event + if (typeof this.hooks.onshow === "function") { + this.hooks.onshow.call(this); + } + + // allow custom `onshow` method + dispatchEvent("onshow", this); + } else { + // reset move updates + resetMove(this); + // reset resize updates + resetResize(this); + // shake the dialog to indicate its already open + addClass(this.elements.dialog, classes.shake); + var self = this; + setTimeout(function () { + removeClass(self.elements.dialog, classes.shake); + }, 200); + } + return this; + }, + /** + * Close the dialog + * + * @return {Object} The dialog instance + */ + close: function () { + if (this.__internal.isOpen) { + // custom `onclosing` event + if (dispatchEvent("onclosing", this) !== false) { + unbindEvents(this); + + removeClass(this.elements.root, classes.animationIn); + addClass(this.elements.root, classes.animationOut); + + // set 1s fallback in case transition event doesn't fire + clearTimeout(this.__internal.timerOut); + this.__internal.timerOut = setTimeout( + this.__internal.transitionOutHandler, + transition.supported ? 1000 : 100 + ); + // hide dialog + addClass(this.elements.root, classes.hidden); + //reflow + reflow = this.elements.modal.offsetWidth; + + // remove custom dialog class on hide + if ( + typeof this.__internal.className !== "undefined" && + this.__internal.className !== "" + ) { + removeClass(this.elements.root, this.__internal.className); + } + + // internal on close event + if (typeof this.hooks.onclose === "function") { + this.hooks.onclose.call(this); + } + + // allow custom `onclose` method + dispatchEvent("onclose", this); + + //remove from open dialogs + openDialogs.splice(openDialogs.indexOf(this), 1); + this.__internal.isOpen = false; + + ensureNoOverflow(); + } + } + // last dialog and tab index was set by us, remove it. + if (!openDialogs.length && tabindex === "0") { + document.body.removeAttribute("tabindex"); + } + return this; + }, + /** + * Close all open dialogs except this. + * + * @return {undefined} + */ + closeOthers: function () { + alertify.closeAll(this); + return this; + }, + /** + * Destroys this dialog instance + * + * @return {undefined} + */ + destroy: function () { + if (this.__internal) { + if (this.__internal.isOpen) { + //mark dialog for destruction, this will be called on tranistionOut event. + this.__internal.destroy = function () { + destruct(this, initialize); + }; + //close the dialog to unbind all events. + this.close(); + } else if (!this.__internal.destroy) { + destruct(this, initialize); + } + } + return this; + }, + }; + })(); + var notifier = (function () { + var reflow, + element, + openInstances = [], + classes = { + base: "alertify-notifier", + message: "ajs-message", + top: "ajs-top", + right: "ajs-right", + bottom: "ajs-bottom", + left: "ajs-left", + center: "ajs-center", + visible: "ajs-visible", + hidden: "ajs-hidden", + close: "ajs-close", + }; + /** + * Helper: initializes the notifier instance + * + */ + function initialize(instance) { + if (!instance.__internal) { + instance.__internal = { + position: alertify.defaults.notifier.position, + delay: alertify.defaults.notifier.delay, + }; - function initialize(instance) { - if (!instance.__internal) { - instance.__internal = { - pushed: false, - delay : undefined, - timer: undefined, - clickHandler: undefined, - transitionEndHandler: undefined, - transitionTimeout: undefined - }; - instance.__internal.clickHandler = delegate(instance, clickDelegate); - instance.__internal.transitionEndHandler = delegate(instance, transitionDone); - } - return instance; - } - function clearTimers(instance) { - clearTimeout(instance.__internal.timer); - clearTimeout(instance.__internal.transitionTimeout); - } - return initialize({ - /* notification DOM element*/ - element: div, - /* - * Pushes a notification message - * @param {string or DOMElement} content The notification message content - * @param {Number} wait The time (in seconds) to wait before the message is dismissed, a value of 0 means keep open till clicked. - * - */ - push: function (_content, _wait) { - if (!this.__internal.pushed) { - - pushInstance(this); - clearTimers(this); - - var content, wait; - switch (arguments.length) { - case 0: - wait = this.__internal.delay; - break; - case 1: - if (typeof (_content) === 'number') { - wait = _content; - } else { - content = _content; - wait = this.__internal.delay; - } - break; - case 2: - content = _content; - wait = _wait; - break; - } - this.__internal.closeButton = alertify.defaults.notifier.closeButton; - // set contents - if (typeof content !== 'undefined') { - this.setContent(content); - } - // append or insert - if (notifier.__internal.position.indexOf('top') < 0) { - element.appendChild(this.element); - } else { - element.insertBefore(this.element, element.firstChild); - } - reflow = this.element.offsetWidth; - addClass(this.element, classes.visible); - // attach click event - on(this.element, 'click', this.__internal.clickHandler); - return this.delay(wait); - } - return this; - }, - /* - * {Function} callback function to be invoked before dismissing the notification message. - * Remarks: A return value === 'false' will cancel the dismissal - * - */ - ondismiss: function () { }, - /* - * {Function} callback function to be invoked when the message is dismissed. - * - */ - callback: callback, - /* - * Dismisses the notification message - * @param {Boolean} clicked A flag indicating if the dismissal was caused by a click. - * - */ - dismiss: function (clicked) { - if (this.__internal.pushed) { - clearTimers(this); - if (!(typeof this.ondismiss === 'function' && this.ondismiss.call(this) === false)) { - //detach click event - off(this.element, 'click', this.__internal.clickHandler); - // ensure element exists - if (typeof this.element !== 'undefined' && this.element.parentNode === element) { - //transition end or fallback - this.__internal.transitionTimeout = setTimeout(this.__internal.transitionEndHandler, transition.supported ? 1000 : 100); - removeClass(this.element, classes.visible); - - // custom callback on dismiss - if (typeof this.callback === 'function') { - this.callback.call(this, clicked); - } - } - popInstance(this); - } - } - return this; - }, - /* - * Delays the notification message dismissal - * @param {Number} wait The time (in seconds) to wait before the message is dismissed, a value of 0 means keep open till clicked. - * - */ - delay: function (wait) { - clearTimers(this); - this.__internal.delay = typeof wait !== 'undefined' && !isNaN(+wait) ? +wait : notifier.__internal.delay; - if (this.__internal.delay > 0) { - var self = this; - this.__internal.timer = setTimeout(function () { self.dismiss(); }, this.__internal.delay * 1000); - } - return this; - }, - /* - * Sets the notification message contents - * @param {string or DOMElement} content The notification message content - * - */ - setContent: function (content) { - if (typeof content === 'string') { - clearContents(this.element); - this.element.innerHTML = content; - } else if (content instanceof window.HTMLElement && this.element.firstChild !== content) { - clearContents(this.element); - this.element.appendChild(content); - } - if(this.__internal.closeButton){ - var close = document.createElement('span'); - addClass(close, classes.close); - close.setAttribute('data-close', true); - this.element.appendChild(close); - } - return this; - }, - /* - * Dismisses all open notifications except this. - * - */ - dismissOthers: function () { - notifier.dismissAll(this); - return this; - } - }); - } + element = document.createElement("DIV"); - //notifier api - return { - /** - * Gets or Sets notifier settings. - * - * @param {string} key The setting name - * @param {Variant} value The setting value. - * - * @return {Object} if the called as a setter, return the notifier instance. - */ - setting: function (key, value) { - //ensure init - initialize(this); - - if (typeof value === 'undefined') { - //get - return this.__internal[key]; - } else { - //set - switch (key) { - case 'position': - this.__internal.position = value; - updatePosition(this); - break; - case 'delay': - this.__internal.delay = value; - break; - } - } - return this; - }, - /** - * [Alias] Sets dialog settings/options - */ - set:function(key,value){ - this.setting(key,value); - return this; - }, - /** - * [Alias] Gets dialog settings/options - */ - get:function(key){ - return this.setting(key); - }, - /** - * Creates a new notification message - * - * @param {string} type The type of notification message (simply a CSS class name 'ajs-{type}' to be added). - * @param {Function} callback A callback function to be invoked when the message is dismissed. - * - * @return {undefined} - */ - create: function (type, callback) { - //ensure notifier init - initialize(this); - //create new notification message - var div = document.createElement('div'); - div.className = classes.message + ((typeof type === 'string' && type !== '') ? ' ajs-' + type : ''); - return create(div, callback); - }, - /** - * Dismisses all open notifications. - * - * @param {Object} excpet [optional] The notification object to exclude from dismissal. - * - */ - dismissAll: function (except) { - var clone = openInstances.slice(0); - for (var x = 0; x < clone.length; x += 1) { - var instance = clone[x]; - if (except === undefined || except !== instance) { - instance.dismiss(); - } - } - } - }; - })(); + updatePosition(instance); + } + + //add to DOM tree. + if (element.parentNode !== document.body) { + document.body.appendChild(element); + } + } + function pushInstance(instance) { + instance.__internal.pushed = true; + openInstances.push(instance); + } + function popInstance(instance) { + openInstances.splice(openInstances.indexOf(instance), 1); + instance.__internal.pushed = false; + } /** - * Alertify public API - * This contains everything that is exposed through the alertify object. + * Helper: update the notifier instance position * - * @return {Object} */ - function Alertify() { - - // holds a references of created dialogs - var dialogs = {}; + function updatePosition(instance) { + element.className = classes.base; + switch (instance.__internal.position) { + case "top-right": + addClass(element, classes.top + " " + classes.right); + break; + case "top-left": + addClass(element, classes.top + " " + classes.left); + break; + case "top-center": + addClass(element, classes.top + " " + classes.center); + break; + case "bottom-left": + addClass(element, classes.bottom + " " + classes.left); + break; + case "bottom-center": + addClass(element, classes.bottom + " " + classes.center); + break; + + default: + case "bottom-right": + addClass(element, classes.bottom + " " + classes.right); + break; + } + } - /** - * Extends a given prototype by merging properties from base into sub. - * - * @sub {Object} sub The prototype being overwritten. - * @base {Object} base The prototype being written. + /** + * creates a new notification message + * + * @param {DOMElement} message The notifier message element + * @param {Number} wait Time (in ms) to wait before the message is dismissed, a value of 0 means keep open till clicked. + * @param {Function} callback A callback function to be invoked when the message is dismissed. + * + * @return {undefined} + */ + function create(div, callback) { + function clickDelegate(event, instance) { + if ( + !instance.__internal.closeButton || + event.target.getAttribute("data-close") === "true" + ) { + instance.dismiss(true); + } + } + + function transitionDone(event, instance) { + // unbind event + off(instance.element, transition.type, transitionDone); + // remove the message + element.removeChild(instance.element); + } + + function initialize(instance) { + if (!instance.__internal) { + instance.__internal = { + pushed: false, + delay: undefined, + timer: undefined, + clickHandler: undefined, + transitionEndHandler: undefined, + transitionTimeout: undefined, + }; + instance.__internal.clickHandler = delegate(instance, clickDelegate); + instance.__internal.transitionEndHandler = delegate( + instance, + transitionDone + ); + } + return instance; + } + function clearTimers(instance) { + clearTimeout(instance.__internal.timer); + clearTimeout(instance.__internal.transitionTimeout); + } + return initialize({ + /* notification DOM element*/ + element: div, + /* + * Pushes a notification message + * @param {string or DOMElement} content The notification message content + * @param {Number} wait The time (in seconds) to wait before the message is dismissed, a value of 0 means keep open till clicked. * - * @return {Object} The extended prototype. */ - function extend(sub, base) { - // copy dialog pototype over definition. - for (var prop in base) { - if (base.hasOwnProperty(prop)) { - sub[prop] = base[prop]; + push: function (_content, _wait) { + if (!this.__internal.pushed) { + pushInstance(this); + clearTimers(this); + + var content, wait; + switch (arguments.length) { + case 0: + wait = this.__internal.delay; + break; + case 1: + if (typeof _content === "number") { + wait = _content; + } else { + content = _content; + wait = this.__internal.delay; } + break; + case 2: + content = _content; + wait = _wait; + break; } - return sub; - } - - - /** - * Helper: returns a dialog instance from saved dialogs. - * and initializes the dialog if its not already initialized. - * - * @name {String} name The dialog name. - * - * @return {Object} The dialog instance. - */ - function get_dialog(name) { - var dialog = dialogs[name].dialog; - //initialize the dialog if its not already initialized. - if (dialog && typeof dialog.__init === 'function') { - dialog.__init(dialog); + this.__internal.closeButton = + alertify.defaults.notifier.closeButton; + // set contents + if (typeof content !== "undefined") { + this.setContent(content); } - return dialog; - } - - /** - * Helper: registers a new dialog definition. + // append or insert + if (notifier.__internal.position.indexOf("top") < 0) { + element.appendChild(this.element); + } else { + element.insertBefore(this.element, element.firstChild); + } + reflow = this.element.offsetWidth; + addClass(this.element, classes.visible); + // attach click event + on(this.element, "click", this.__internal.clickHandler); + return this.delay(wait); + } + return this; + }, + /* + * {Function} callback function to be invoked before dismissing the notification message. + * Remarks: A return value === 'false' will cancel the dismissal * - * @name {String} name The dialog name. - * @Factory {Function} Factory a function resposible for creating dialog prototype. - * @transient {Boolean} transient True to create a new dialog instance each time the dialog is invoked, false otherwise. - * @base {String} base the name of another dialog to inherit from. + */ + ondismiss: function () {}, + /* + * {Function} callback function to be invoked when the message is dismissed. * - * @return {Object} The dialog definition. */ - function register(name, Factory, transient, base) { - var definition = { - dialog: null, - factory: Factory - }; - - //if this is based on an existing dialog, create a new definition - //by applying the new protoype over the existing one. - if (base !== undefined) { - definition.factory = function () { - return extend(new dialogs[base].factory(), new Factory()); - }; - } - - if (!transient) { - //create a new definition based on dialog - definition.dialog = extend(new definition.factory(), dialog); - } - return dialogs[name] = definition; - } - - return { - /** - * Alertify defaults - * - * @type {Object} - */ - defaults: defaults, - /** - * Dialogs factory - * - * @param {string} Dialog name. - * @param {Function} A Dialog factory function. - * @param {Boolean} Indicates whether to create a singleton or transient dialog. - * @param {String} The name of the base type to inherit from. - */ - dialog: function (name, Factory, transient, base) { - - // get request, create a new instance and return it. - if (typeof Factory !== 'function') { - return get_dialog(name); - } - - if (this.hasOwnProperty(name)) { - throw new Error('alertify.dialog: name already exists'); - } + callback: callback, + /* + * Dismisses the notification message + * @param {Boolean} clicked A flag indicating if the dismissal was caused by a click. + * + */ + dismiss: function (clicked) { + if (this.__internal.pushed) { + clearTimers(this); + if ( + !( + typeof this.ondismiss === "function" && + this.ondismiss.call(this) === false + ) + ) { + //detach click event + off(this.element, "click", this.__internal.clickHandler); + // ensure element exists + if ( + typeof this.element !== "undefined" && + this.element.parentNode === element + ) { + //transition end or fallback + this.__internal.transitionTimeout = setTimeout( + this.__internal.transitionEndHandler, + transition.supported ? 1000 : 100 + ); + removeClass(this.element, classes.visible); + + // custom callback on dismiss + if (typeof this.callback === "function") { + this.callback.call(this, clicked); + } + } + popInstance(this); + } + } + return this; + }, + /* + * Delays the notification message dismissal + * @param {Number} wait The time (in seconds) to wait before the message is dismissed, a value of 0 means keep open till clicked. + * + */ + delay: function (wait) { + clearTimers(this); + this.__internal.delay = + typeof wait !== "undefined" && !isNaN(+wait) + ? +wait + : notifier.__internal.delay; + if (this.__internal.delay > 0) { + var self = this; + this.__internal.timer = setTimeout(function () { + self.dismiss(); + }, this.__internal.delay * 1000); + } + return this; + }, + /* + * Sets the notification message contents + * @param {string or DOMElement} content The notification message content + * + */ + setContent: function (content) { + if (typeof content === "string") { + clearContents(this.element); + this.element.innerHTML = content; + } else if ( + content instanceof window.HTMLElement && + this.element.firstChild !== content + ) { + clearContents(this.element); + this.element.appendChild(content); + } + if (this.__internal.closeButton) { + var close = document.createElement("span"); + addClass(close, classes.close); + close.setAttribute("data-close", true); + this.element.appendChild(close); + } + return this; + }, + /* + * Dismisses all open notifications except this. + * + */ + dismissOthers: function () { + notifier.dismissAll(this); + return this; + }, + }); + } - // register the dialog - var definition = register(name, Factory, transient, base); - - if (transient) { - - // make it public - this[name] = function () { - //if passed with no params, consider it a get request - if (arguments.length === 0) { - return definition.dialog; - } else { - var instance = extend(new definition.factory(), dialog); - //ensure init - if (instance && typeof instance.__init === 'function') { - instance.__init(instance); - } - instance['main'].apply(instance, arguments); - return instance['show'].apply(instance); - } - }; - } else { - // make it public - this[name] = function () { - //ensure init - if (definition.dialog && typeof definition.dialog.__init === 'function') { - definition.dialog.__init(definition.dialog); - } - //if passed with no params, consider it a get request - if (arguments.length === 0) { - return definition.dialog; - } else { - var dialog = definition.dialog; - dialog['main'].apply(definition.dialog, arguments); - return dialog['show'].apply(definition.dialog); - } - }; - } - }, - /** - * Close all open dialogs. - * - * @param {Object} excpet [optional] The dialog object to exclude from closing. - * - * @return {undefined} - */ - closeAll: function (except) { - var clone = openDialogs.slice(0); - for (var x = 0; x < clone.length; x += 1) { - var instance = clone[x]; - if (except === undefined || except !== instance) { - instance.close(); - } - } - }, - /** - * Gets or Sets dialog settings/options. if the dialog is transient, this call does nothing. - * - * @param {string} name The dialog name. - * @param {String|Object} key A string specifying a propery name or a collection of key/value pairs. - * @param {Variant} value Optional, the value associated with the key (in case it was a string). - * - * @return {undefined} - */ - setting: function (name, key, value) { - - if (name === 'notifier') { - return notifier.setting(key, value); - } + //notifier api + return { + /** + * Gets or Sets notifier settings. + * + * @param {string} key The setting name + * @param {Variant} value The setting value. + * + * @return {Object} if the called as a setter, return the notifier instance. + */ + setting: function (key, value) { + //ensure init + initialize(this); + + if (typeof value === "undefined") { + //get + return this.__internal[key]; + } else { + //set + switch (key) { + case "position": + this.__internal.position = value; + updatePosition(this); + break; + case "delay": + this.__internal.delay = value; + break; + } + } + return this; + }, + /** + * [Alias] Sets dialog settings/options + */ + set: function (key, value) { + this.setting(key, value); + return this; + }, + /** + * [Alias] Gets dialog settings/options + */ + get: function (key) { + return this.setting(key); + }, + /** + * Creates a new notification message + * + * @param {string} type The type of notification message (simply a CSS class name 'ajs-{type}' to be added). + * @param {Function} callback A callback function to be invoked when the message is dismissed. + * + * @return {undefined} + */ + create: function (type, callback) { + //ensure notifier init + initialize(this); + //create new notification message + var div = document.createElement("div"); + div.className = + classes.message + + (typeof type === "string" && type !== "" ? " ajs-" + type : ""); + return create(div, callback); + }, + /** + * Dismisses all open notifications. + * + * @param {Object} excpet [optional] The notification object to exclude from dismissal. + * + */ + dismissAll: function (except) { + var clone = openInstances.slice(0); + for (var x = 0; x < clone.length; x += 1) { + var instance = clone[x]; + if (except === undefined || except !== instance) { + instance.dismiss(); + } + } + }, + }; + })(); + + /** + * Alertify public API + * This contains everything that is exposed through the alertify object. + * + * @return {Object} + */ + function Alertify() { + // holds a references of created dialogs + var dialogs = {}; - var dialog = get_dialog(name); - if (dialog) { - return dialog.setting(key, value); - } - }, - /** - * [Alias] Sets dialog settings/options - */ - set: function(name,key,value){ - return this.setting(name, key,value); - }, - /** - * [Alias] Gets dialog settings/options - */ - get: function(name, key){ - return this.setting(name, key); - }, - /** - * Creates a new notification message. - * If a type is passed, a class name "ajs-{type}" will be added. - * This allows for custom look and feel for various types of notifications. - * - * @param {String | DOMElement} [message=undefined] Message text - * @param {String} [type=''] Type of log message - * @param {String} [wait=''] Time (in seconds) to wait before auto-close - * @param {Function} [callback=undefined] A callback function to be invoked when the log is closed. - * - * @return {Object} Notification object. - */ - notify: function (message, type, wait, callback) { - return notifier.create(type, callback).push(message, wait); - }, - /** - * Creates a new notification message. - * - * @param {String} [message=undefined] Message text - * @param {String} [wait=''] Time (in seconds) to wait before auto-close - * @param {Function} [callback=undefined] A callback function to be invoked when the log is closed. - * - * @return {Object} Notification object. - */ - message: function (message, wait, callback) { - return notifier.create(null, callback).push(message, wait); - }, - /** - * Creates a new notification message of type 'success'. - * - * @param {String} [message=undefined] Message text - * @param {String} [wait=''] Time (in seconds) to wait before auto-close - * @param {Function} [callback=undefined] A callback function to be invoked when the log is closed. - * - * @return {Object} Notification object. - */ - success: function (message, wait, callback) { - return notifier.create('success', callback).push(message, wait); - }, - /** - * Creates a new notification message of type 'error'. - * - * @param {String} [message=undefined] Message text - * @param {String} [wait=''] Time (in seconds) to wait before auto-close - * @param {Function} [callback=undefined] A callback function to be invoked when the log is closed. - * - * @return {Object} Notification object. - */ - error: function (message, wait, callback) { - return notifier.create('error', callback).push(message, wait); - }, - /** - * Creates a new notification message of type 'warning'. - * - * @param {String} [message=undefined] Message text - * @param {String} [wait=''] Time (in seconds) to wait before auto-close - * @param {Function} [callback=undefined] A callback function to be invoked when the log is closed. - * - * @return {Object} Notification object. - */ - warning: function (message, wait, callback) { - return notifier.create('warning', callback).push(message, wait); - }, - /** - * Dismisses all open notifications - * - * @return {undefined} - */ - dismissAll: function () { - notifier.dismissAll(); - } - }; + /** + * Extends a given prototype by merging properties from base into sub. + * + * @sub {Object} sub The prototype being overwritten. + * @base {Object} base The prototype being written. + * + * @return {Object} The extended prototype. + */ + function extend(sub, base) { + // copy dialog pototype over definition. + for (var prop in base) { + if (base.hasOwnProperty(prop)) { + sub[prop] = base[prop]; + } + } + return sub; } - var alertify = new Alertify(); /** - * Alert dialog definition - * - * invoked by: - * alertify.alert(message); - * alertify.alert(title, message); - * alertify.alert(message, onok); - * alertify.alert(title, message, onok); + * Helper: returns a dialog instance from saved dialogs. + * and initializes the dialog if its not already initialized. + * + * @name {String} name The dialog name. + * + * @return {Object} The dialog instance. */ - alertify.dialog('alert', function () { - return { - main: function (_title, _message, _onok) { - var title, message, onok; - switch (arguments.length) { - case 1: - message = _title; - break; - case 2: - if (typeof _message === 'function') { - message = _title; - onok = _message; - } else { - title = _title; - message = _message; - } - break; - case 3: - title = _title; - message = _message; - onok = _onok; - break; - } - this.set('title', title); - this.set('message', message); - this.set('onok', onok); - return this; - }, - setup: function () { - return { - buttons: [ - { - text: alertify.defaults.glossary.ok, - key: keys.ESC, - invokeOnClose: true, - className: alertify.defaults.theme.ok, - } - ], - focus: { - element: 0, - select: false - }, - options: { - maximizable: false, - resizable: false - } - }; - }, - build: function () { - // nothing - }, - prepare: function () { - //nothing - }, - setMessage: function (message) { - this.setContent(message); - }, - settings: { - message: undefined, - onok: undefined, - label: undefined, - }, - settingUpdated: function (key, oldValue, newValue) { - switch (key) { - case 'message': - this.setMessage(newValue); - break; - case 'label': - if (this.__internal.buttons[0].element) { - this.__internal.buttons[0].element.innerHTML = newValue; - } - break; - } - }, - callback: function (closeEvent) { - if (typeof this.get('onok') === 'function') { - var returnValue = this.get('onok').call(this, closeEvent); - if (typeof returnValue !== 'undefined') { - closeEvent.cancel = !returnValue; - } - } - } - }; - }); + function get_dialog(name) { + var dialog = dialogs[name].dialog; + //initialize the dialog if its not already initialized. + if (dialog && typeof dialog.__init === "function") { + dialog.__init(dialog); + } + return dialog; + } + /** - * Confirm dialog object + * Helper: registers a new dialog definition. * - * alertify.confirm(message); - * alertify.confirm(message, onok); - * alertify.confirm(message, onok, oncancel); - * alertify.confirm(title, message, onok, oncancel); + * @name {String} name The dialog name. + * @Factory {Function} Factory a function resposible for creating dialog prototype. + * @transient {Boolean} transient True to create a new dialog instance each time the dialog is invoked, false otherwise. + * @base {String} base the name of another dialog to inherit from. + * + * @return {Object} The dialog definition. */ - alertify.dialog('confirm', function () { - - var autoConfirm = { - timer: null, - index: null, - text: null, - duration: null, - task: function (event, self) { - if (self.isOpen()) { - self.__internal.buttons[autoConfirm.index].element.innerHTML = autoConfirm.text + ' (‏' + autoConfirm.duration + '‏) '; - autoConfirm.duration -= 1; - if (autoConfirm.duration === -1) { - clearAutoConfirm(self); - var button = self.__internal.buttons[autoConfirm.index]; - var closeEvent = createCloseEvent(autoConfirm.index, button); - - if (typeof self.callback === 'function') { - self.callback.apply(self, [closeEvent]); - } - //close the dialog. - if (closeEvent.close !== false) { - self.close(); - } - } - } else { - clearAutoConfirm(self); - } - } + function register(name, Factory, transient, base) { + var definition = { + dialog: null, + factory: Factory, + }; + + //if this is based on an existing dialog, create a new definition + //by applying the new protoype over the existing one. + if (base !== undefined) { + definition.factory = function () { + return extend(new dialogs[base].factory(), new Factory()); }; + } - function clearAutoConfirm(self) { - if (autoConfirm.timer !== null) { - clearInterval(autoConfirm.timer); - autoConfirm.timer = null; - self.__internal.buttons[autoConfirm.index].element.innerHTML = autoConfirm.text; - } - } + if (!transient) { + //create a new definition based on dialog + definition.dialog = extend(new definition.factory(), dialog); + } + return (dialogs[name] = definition); + } - function startAutoConfirm(self, index, duration) { + return { + /** + * Alertify defaults + * + * @type {Object} + */ + defaults: defaults, + /** + * Dialogs factory + * + * @param {string} Dialog name. + * @param {Function} A Dialog factory function. + * @param {Boolean} Indicates whether to create a singleton or transient dialog. + * @param {String} The name of the base type to inherit from. + */ + dialog: function (name, Factory, transient, base) { + // get request, create a new instance and return it. + if (typeof Factory !== "function") { + return get_dialog(name); + } + + if (this.hasOwnProperty(name)) { + throw new Error("alertify.dialog: name already exists"); + } + + // register the dialog + var definition = register(name, Factory, transient, base); + + if (transient) { + // make it public + this[name] = function () { + //if passed with no params, consider it a get request + if (arguments.length === 0) { + return definition.dialog; + } else { + var instance = extend(new definition.factory(), dialog); + //ensure init + if (instance && typeof instance.__init === "function") { + instance.__init(instance); + } + instance["main"].apply(instance, arguments); + return instance["show"].apply(instance); + } + }; + } else { + // make it public + this[name] = function () { + //ensure init + if ( + definition.dialog && + typeof definition.dialog.__init === "function" + ) { + definition.dialog.__init(definition.dialog); + } + //if passed with no params, consider it a get request + if (arguments.length === 0) { + return definition.dialog; + } else { + var dialog = definition.dialog; + dialog["main"].apply(definition.dialog, arguments); + return dialog["show"].apply(definition.dialog); + } + }; + } + }, + /** + * Close all open dialogs. + * + * @param {Object} excpet [optional] The dialog object to exclude from closing. + * + * @return {undefined} + */ + closeAll: function (except) { + var clone = openDialogs.slice(0); + for (var x = 0; x < clone.length; x += 1) { + var instance = clone[x]; + if (except === undefined || except !== instance) { + instance.close(); + } + } + }, + /** + * Gets or Sets dialog settings/options. if the dialog is transient, this call does nothing. + * + * @param {string} name The dialog name. + * @param {String|Object} key A string specifying a propery name or a collection of key/value pairs. + * @param {Variant} value Optional, the value associated with the key (in case it was a string). + * + * @return {undefined} + */ + setting: function (name, key, value) { + if (name === "notifier") { + return notifier.setting(key, value); + } + + var dialog = get_dialog(name); + if (dialog) { + return dialog.setting(key, value); + } + }, + /** + * [Alias] Sets dialog settings/options + */ + set: function (name, key, value) { + return this.setting(name, key, value); + }, + /** + * [Alias] Gets dialog settings/options + */ + get: function (name, key) { + return this.setting(name, key); + }, + /** + * Creates a new notification message. + * If a type is passed, a class name "ajs-{type}" will be added. + * This allows for custom look and feel for various types of notifications. + * + * @param {String | DOMElement} [message=undefined] Message text + * @param {String} [type=''] Type of log message + * @param {String} [wait=''] Time (in seconds) to wait before auto-close + * @param {Function} [callback=undefined] A callback function to be invoked when the log is closed. + * + * @return {Object} Notification object. + */ + notify: function (message, type, wait, callback) { + return notifier.create(type, callback).push(message, wait); + }, + /** + * Creates a new notification message. + * + * @param {String} [message=undefined] Message text + * @param {String} [wait=''] Time (in seconds) to wait before auto-close + * @param {Function} [callback=undefined] A callback function to be invoked when the log is closed. + * + * @return {Object} Notification object. + */ + message: function (message, wait, callback) { + return notifier.create(null, callback).push(message, wait); + }, + /** + * Creates a new notification message of type 'success'. + * + * @param {String} [message=undefined] Message text + * @param {String} [wait=''] Time (in seconds) to wait before auto-close + * @param {Function} [callback=undefined] A callback function to be invoked when the log is closed. + * + * @return {Object} Notification object. + */ + success: function (message, wait, callback) { + return notifier.create("success", callback).push(message, wait); + }, + /** + * Creates a new notification message of type 'error'. + * + * @param {String} [message=undefined] Message text + * @param {String} [wait=''] Time (in seconds) to wait before auto-close + * @param {Function} [callback=undefined] A callback function to be invoked when the log is closed. + * + * @return {Object} Notification object. + */ + error: function (message, wait, callback) { + return notifier.create("error", callback).push(message, wait); + }, + /** + * Creates a new notification message of type 'warning'. + * + * @param {String} [message=undefined] Message text + * @param {String} [wait=''] Time (in seconds) to wait before auto-close + * @param {Function} [callback=undefined] A callback function to be invoked when the log is closed. + * + * @return {Object} Notification object. + */ + warning: function (message, wait, callback) { + return notifier.create("warning", callback).push(message, wait); + }, + /** + * Dismisses all open notifications + * + * @return {undefined} + */ + dismissAll: function () { + notifier.dismissAll(); + }, + }; + } + var alertify = new Alertify(); + + /** + * Alert dialog definition + * + * invoked by: + * alertify.alert(message); + * alertify.alert(title, message); + * alertify.alert(message, onok); + * alertify.alert(title, message, onok); + */ + alertify.dialog("alert", function () { + return { + main: function (_title, _message, _onok) { + var title, message, onok; + switch (arguments.length) { + case 1: + message = _title; + break; + case 2: + if (typeof _message === "function") { + message = _title; + onok = _message; + } else { + title = _title; + message = _message; + } + break; + case 3: + title = _title; + message = _message; + onok = _onok; + break; + } + this.set("title", title); + this.set("message", message); + this.set("onok", onok); + return this; + }, + setup: function () { + return { + buttons: [ + { + text: alertify.defaults.glossary.ok, + key: keys.ESC, + invokeOnClose: true, + className: alertify.defaults.theme.ok, + }, + ], + focus: { + element: 0, + select: false, + }, + options: { + maximizable: false, + resizable: false, + }, + }; + }, + build: function () { + // nothing + }, + prepare: function () { + //nothing + }, + setMessage: function (message) { + this.setContent(message); + }, + settings: { + message: undefined, + onok: undefined, + label: undefined, + }, + settingUpdated: function (key, oldValue, newValue) { + switch (key) { + case "message": + this.setMessage(newValue); + break; + case "label": + if (this.__internal.buttons[0].element) { + this.__internal.buttons[0].element.innerHTML = newValue; + } + break; + } + }, + callback: function (closeEvent) { + if (typeof this.get("onok") === "function") { + var returnValue = this.get("onok").call(this, closeEvent); + if (typeof returnValue !== "undefined") { + closeEvent.cancel = !returnValue; + } + } + }, + }; + }); + /** + * Confirm dialog object + * + * alertify.confirm(message); + * alertify.confirm(message, onok); + * alertify.confirm(message, onok, oncancel); + * alertify.confirm(title, message, onok, oncancel); + */ + alertify.dialog("confirm", function () { + var autoConfirm = { + timer: null, + index: null, + text: null, + duration: null, + task: function (event, self) { + if (self.isOpen()) { + self.__internal.buttons[autoConfirm.index].element.innerHTML = + autoConfirm.text + " (‏" + autoConfirm.duration + "‏) "; + autoConfirm.duration -= 1; + if (autoConfirm.duration === -1) { clearAutoConfirm(self); - autoConfirm.duration = duration; - autoConfirm.index = index; - autoConfirm.text = self.__internal.buttons[index].element.innerHTML; - autoConfirm.timer = setInterval(delegate(self, autoConfirm.task), 1000); - autoConfirm.task(null, self); + var button = self.__internal.buttons[autoConfirm.index]; + var closeEvent = createCloseEvent(autoConfirm.index, button); + + if (typeof self.callback === "function") { + self.callback.apply(self, [closeEvent]); + } + //close the dialog. + if (closeEvent.close !== false) { + self.close(); + } + } + } else { + clearAutoConfirm(self); } + }, + }; + function clearAutoConfirm(self) { + if (autoConfirm.timer !== null) { + clearInterval(autoConfirm.timer); + autoConfirm.timer = null; + self.__internal.buttons[autoConfirm.index].element.innerHTML = + autoConfirm.text; + } + } + + function startAutoConfirm(self, index, duration) { + clearAutoConfirm(self); + autoConfirm.duration = duration; + autoConfirm.index = index; + autoConfirm.text = self.__internal.buttons[index].element.innerHTML; + autoConfirm.timer = setInterval(delegate(self, autoConfirm.task), 1000); + autoConfirm.task(null, self); + } + return { + main: function (_title, _message, _onok, _oncancel) { + var title, message, onok, oncancel; + switch (arguments.length) { + case 1: + message = _title; + break; + case 2: + message = _title; + onok = _message; + break; + case 3: + message = _title; + onok = _message; + oncancel = _onok; + break; + case 4: + title = _title; + message = _message; + onok = _onok; + oncancel = _oncancel; + break; + } + this.set("title", title); + this.set("message", message); + this.set("onok", onok); + this.set("oncancel", oncancel); + return this; + }, + setup: function () { return { - main: function (_title, _message, _onok, _oncancel) { - var title, message, onok, oncancel; - switch (arguments.length) { - case 1: - message = _title; - break; - case 2: - message = _title; - onok = _message; - break; - case 3: - message = _title; - onok = _message; - oncancel = _onok; - break; - case 4: - title = _title; - message = _message; - onok = _onok; - oncancel = _oncancel; - break; - } - this.set('title', title); - this.set('message', message); - this.set('onok', onok); - this.set('oncancel', oncancel); - return this; - }, - setup: function () { - return { - buttons: [ - { - text: alertify.defaults.glossary.ok, - key: keys.ENTER, - className: alertify.defaults.theme.ok, - }, - { - text: alertify.defaults.glossary.cancel, - key: keys.ESC, - invokeOnClose: true, - className: alertify.defaults.theme.cancel, - } - ], - focus: { - element: 0, - select: false - }, - options: { - maximizable: false, - resizable: false - } - }; - }, - build: function () { - //nothing - }, - prepare: function () { - //nothing - }, - setMessage: function (message) { - this.setContent(message); - }, - settings: { - message: null, - labels: null, - onok: null, - oncancel: null, - defaultFocus: null, - reverseButtons: null, - }, - settingUpdated: function (key, oldValue, newValue) { - switch (key) { - case 'message': - this.setMessage(newValue); - break; - case 'labels': - if ('ok' in newValue && this.__internal.buttons[0].element) { - this.__internal.buttons[0].text = newValue.ok; - this.__internal.buttons[0].element.innerHTML = newValue.ok; - } - if ('cancel' in newValue && this.__internal.buttons[1].element) { - this.__internal.buttons[1].text = newValue.cancel; - this.__internal.buttons[1].element.innerHTML = newValue.cancel; - } - break; - case 'reverseButtons': - if (newValue === true) { - this.elements.buttons.primary.appendChild(this.__internal.buttons[0].element); - } else { - this.elements.buttons.primary.appendChild(this.__internal.buttons[1].element); - } - break; - case 'defaultFocus': - this.__internal.focus.element = newValue === 'ok' ? 0 : 1; - break; - } - }, - callback: function (closeEvent) { - clearAutoConfirm(this); - var returnValue; - switch (closeEvent.index) { - case 0: - if (typeof this.get('onok') === 'function') { - returnValue = this.get('onok').call(this, closeEvent); - if (typeof returnValue !== 'undefined') { - closeEvent.cancel = !returnValue; - } - } - break; - case 1: - if (typeof this.get('oncancel') === 'function') { - returnValue = this.get('oncancel').call(this, closeEvent); - if (typeof returnValue !== 'undefined') { - closeEvent.cancel = !returnValue; - } - } - break; - } + buttons: [ + { + text: alertify.defaults.glossary.ok, + key: keys.ENTER, + className: alertify.defaults.theme.ok, }, - autoOk: function (duration) { - startAutoConfirm(this, 0, duration); - return this; + { + text: alertify.defaults.glossary.cancel, + key: keys.ESC, + invokeOnClose: true, + className: alertify.defaults.theme.cancel, }, - autoCancel: function (duration) { - startAutoConfirm(this, 1, duration); - return this; - } + ], + focus: { + element: 0, + select: false, + }, + options: { + maximizable: false, + resizable: false, + }, }; - }); - /** - * Prompt dialog object - * - * invoked by: - * alertify.prompt(message); - * alertify.prompt(message, value); - * alertify.prompt(message, value, onok); - * alertify.prompt(message, value, onok, oncancel); - * alertify.prompt(title, message, value, onok, oncancel); - */ - alertify.dialog('prompt', function () { - var input = document.createElement('INPUT'); - var p = document.createElement('P'); + }, + build: function () { + //nothing + }, + prepare: function () { + //nothing + }, + setMessage: function (message) { + this.setContent(message); + }, + settings: { + message: null, + labels: null, + onok: null, + oncancel: null, + defaultFocus: null, + reverseButtons: null, + }, + settingUpdated: function (key, oldValue, newValue) { + switch (key) { + case "message": + this.setMessage(newValue); + break; + case "labels": + if ("ok" in newValue && this.__internal.buttons[0].element) { + this.__internal.buttons[0].text = newValue.ok; + this.__internal.buttons[0].element.innerHTML = newValue.ok; + } + if ("cancel" in newValue && this.__internal.buttons[1].element) { + this.__internal.buttons[1].text = newValue.cancel; + this.__internal.buttons[1].element.innerHTML = newValue.cancel; + } + break; + case "reverseButtons": + if (newValue === true) { + this.elements.buttons.primary.appendChild( + this.__internal.buttons[0].element + ); + } else { + this.elements.buttons.primary.appendChild( + this.__internal.buttons[1].element + ); + } + break; + case "defaultFocus": + this.__internal.focus.element = newValue === "ok" ? 0 : 1; + break; + } + }, + callback: function (closeEvent) { + clearAutoConfirm(this); + var returnValue; + switch (closeEvent.index) { + case 0: + if (typeof this.get("onok") === "function") { + returnValue = this.get("onok").call(this, closeEvent); + if (typeof returnValue !== "undefined") { + closeEvent.cancel = !returnValue; + } + } + break; + case 1: + if (typeof this.get("oncancel") === "function") { + returnValue = this.get("oncancel").call(this, closeEvent); + if (typeof returnValue !== "undefined") { + closeEvent.cancel = !returnValue; + } + } + break; + } + }, + autoOk: function (duration) { + startAutoConfirm(this, 0, duration); + return this; + }, + autoCancel: function (duration) { + startAutoConfirm(this, 1, duration); + return this; + }, + }; + }); + /** + * Prompt dialog object + * + * invoked by: + * alertify.prompt(message); + * alertify.prompt(message, value); + * alertify.prompt(message, value, onok); + * alertify.prompt(message, value, onok, oncancel); + * alertify.prompt(title, message, value, onok, oncancel); + */ + alertify.dialog("prompt", function () { + var input = document.createElement("INPUT"); + var p = document.createElement("P"); + return { + main: function (_title, _message, _value, _onok, _oncancel) { + var title, message, value, onok, oncancel; + switch (arguments.length) { + case 1: + message = _title; + break; + case 2: + message = _title; + value = _message; + break; + case 3: + message = _title; + value = _message; + onok = _value; + break; + case 4: + message = _title; + value = _message; + onok = _value; + oncancel = _onok; + break; + case 5: + title = _title; + message = _message; + value = _value; + onok = _onok; + oncancel = _oncancel; + break; + } + this.set("title", title); + this.set("message", message); + this.set("value", value); + this.set("onok", onok); + this.set("oncancel", oncancel); + return this; + }, + setup: function () { return { - main: function (_title, _message, _value, _onok, _oncancel) { - var title, message, value, onok, oncancel; - switch (arguments.length) { - case 1: - message = _title; - break; - case 2: - message = _title; - value = _message; - break; - case 3: - message = _title; - value = _message; - onok = _value; - break; - case 4: - message = _title; - value = _message; - onok = _value; - oncancel = _onok; - break; - case 5: - title = _title; - message = _message; - value = _value; - onok = _onok; - oncancel = _oncancel; - break; - } - this.set('title', title); - this.set('message', message); - this.set('value', value); - this.set('onok', onok); - this.set('oncancel', oncancel); - return this; - }, - setup: function () { - return { - buttons: [ - { - text: alertify.defaults.glossary.ok, - key: keys.ENTER, - className: alertify.defaults.theme.ok, - }, - { - text: alertify.defaults.glossary.cancel, - key: keys.ESC, - invokeOnClose: true, - className: alertify.defaults.theme.cancel, - } - ], - focus: { - element: input, - select: true - }, - options: { - maximizable: false, - resizable: false - } - }; - }, - build: function () { - input.className = alertify.defaults.theme.input; - input.setAttribute('type', 'text'); - input.value = this.get('value'); - this.elements.content.appendChild(p); - this.elements.content.appendChild(input); - }, - prepare: function () { - //nothing - }, - setMessage: function (message) { - if (typeof message === 'string') { - clearContents(p); - p.innerHTML = message; - } else if (message instanceof window.HTMLElement && p.firstChild !== message) { - clearContents(p); - p.appendChild(message); - } - }, - settings: { - message: undefined, - labels: undefined, - onok: undefined, - oncancel: undefined, - value: '', - type:'text', - reverseButtons: undefined, + buttons: [ + { + text: alertify.defaults.glossary.ok, + key: keys.ENTER, + className: alertify.defaults.theme.ok, }, - settingUpdated: function (key, oldValue, newValue) { - switch (key) { - case 'message': - this.setMessage(newValue); - break; - case 'value': - input.value = newValue; - break; - case 'type': - switch (newValue) { - case 'text': - case 'color': - case 'date': - case 'datetime-local': - case 'email': - case 'month': - case 'number': - case 'password': - case 'search': - case 'tel': - case 'time': - case 'week': - input.type = newValue; - break; - default: - input.type = 'text'; - break; - } - break; - case 'labels': - if (newValue.ok && this.__internal.buttons[0].element) { - this.__internal.buttons[0].element.innerHTML = newValue.ok; - } - if (newValue.cancel && this.__internal.buttons[1].element) { - this.__internal.buttons[1].element.innerHTML = newValue.cancel; - } - break; - case 'reverseButtons': - if (newValue === true) { - this.elements.buttons.primary.appendChild(this.__internal.buttons[0].element); - } else { - this.elements.buttons.primary.appendChild(this.__internal.buttons[1].element); - } - break; - } + { + text: alertify.defaults.glossary.cancel, + key: keys.ESC, + invokeOnClose: true, + className: alertify.defaults.theme.cancel, }, - callback: function (closeEvent) { - var returnValue; - switch (closeEvent.index) { - case 0: - this.settings.value = input.value; - if (typeof this.get('onok') === 'function') { - returnValue = this.get('onok').call(this, closeEvent, this.settings.value); - if (typeof returnValue !== 'undefined') { - closeEvent.cancel = !returnValue; - } - } - break; - case 1: - if (typeof this.get('oncancel') === 'function') { - returnValue = this.get('oncancel').call(this, closeEvent); - if (typeof returnValue !== 'undefined') { - closeEvent.cancel = !returnValue; - } - } - if(!closeEvent.cancel){ - input.value = this.settings.value; - } - break; - } - } + ], + focus: { + element: input, + select: true, + }, + options: { + maximizable: false, + resizable: false, + }, }; - }); + }, + build: function () { + input.className = alertify.defaults.theme.input; + input.setAttribute("type", "text"); + input.value = this.get("value"); + this.elements.content.appendChild(p); + this.elements.content.appendChild(input); + }, + prepare: function () { + //nothing + }, + setMessage: function (message) { + if (typeof message === "string") { + clearContents(p); + p.innerHTML = message; + } else if ( + message instanceof window.HTMLElement && + p.firstChild !== message + ) { + clearContents(p); + p.appendChild(message); + } + }, + settings: { + message: undefined, + labels: undefined, + onok: undefined, + oncancel: undefined, + value: "", + type: "text", + reverseButtons: undefined, + }, + settingUpdated: function (key, oldValue, newValue) { + switch (key) { + case "message": + this.setMessage(newValue); + break; + case "value": + input.value = newValue; + break; + case "type": + switch (newValue) { + case "text": + case "color": + case "date": + case "datetime-local": + case "email": + case "month": + case "number": + case "password": + case "search": + case "tel": + case "time": + case "week": + input.type = newValue; + break; + default: + input.type = "text"; + break; + } + break; + case "labels": + if (newValue.ok && this.__internal.buttons[0].element) { + this.__internal.buttons[0].element.innerHTML = newValue.ok; + } + if (newValue.cancel && this.__internal.buttons[1].element) { + this.__internal.buttons[1].element.innerHTML = newValue.cancel; + } + break; + case "reverseButtons": + if (newValue === true) { + this.elements.buttons.primary.appendChild( + this.__internal.buttons[0].element + ); + } else { + this.elements.buttons.primary.appendChild( + this.__internal.buttons[1].element + ); + } + break; + } + }, + callback: function (closeEvent) { + var returnValue; + switch (closeEvent.index) { + case 0: + this.settings.value = input.value; + if (typeof this.get("onok") === "function") { + returnValue = this.get("onok").call( + this, + closeEvent, + this.settings.value + ); + if (typeof returnValue !== "undefined") { + closeEvent.cancel = !returnValue; + } + } + break; + case 1: + if (typeof this.get("oncancel") === "function") { + returnValue = this.get("oncancel").call(this, closeEvent); + if (typeof returnValue !== "undefined") { + closeEvent.cancel = !returnValue; + } + } + if (!closeEvent.cancel) { + input.value = this.settings.value; + } + break; + } + }, + }; + }); - // CommonJS - if ( typeof module === 'object' && typeof module.exports === 'object' ) { - module.exports = alertify; + // CommonJS + if (typeof module === "object" && typeof module.exports === "object") { + module.exports = alertify; // AMD - } else if ( typeof define === 'function' && define.amd) { - define( [], function () { - return alertify; - } ); + } else if (typeof define === "function" && define.amd) { + define([], function () { + return alertify; + }); // window - } else if ( !window.alertify ) { - window.alertify = alertify; - } - -} ( typeof window !== 'undefined' ? window : this ) ); + } else if (!window.alertify) { + window.alertify = alertify; + } +})(typeof window !== "undefined" ? window : this); diff --git a/notemyprogress/js/axios.js b/notemyprogress/js/axios.js index 6ace1061432fa40193fcd995d6d15674276a5675..ce4a02a42a0f56513712253ad71967a3920ab63f 100644 --- a/notemyprogress/js/axios.js +++ b/notemyprogress/js/axios.js @@ -373,7 +373,11 @@ * * ```js * var result = merge({foo: 123}, {foo: 456}); +<<<<<<< HEAD * //console.log(result.foo); // outputs 456 +======= + * console.log(result.foo); // outputs 456 +>>>>>>> 42271d072b5508617432803ceb2659d2d3067682 * ``` * * @param {Object} obj1 Object to merge diff --git a/notemyprogress/js/highcharts/highcharts.src.js b/notemyprogress/js/highcharts/highcharts.src.js index 27bc6118483898f892d9945fccb679437b3cf465..104c0c148e6fa8bbd0da40942f68765acee8e1dc 100644 --- a/notemyprogress/js/highcharts/highcharts.src.js +++ b/notemyprogress/js/highcharts/highcharts.src.js @@ -506,7 +506,11 @@ win.console && error.messages.indexOf(message) === -1 // prevent console flooting ) { +<<<<<<< HEAD //console.log(message); // eslint-disable-line no-console +======= + console.log(message); // eslint-disable-line no-console +>>>>>>> 42271d072b5508617432803ceb2659d2d3067682 } }; if (typeof params !== "undefined") { @@ -10608,7 +10612,11 @@ * }); * * // Use the Time object +<<<<<<< HEAD * //console.log( +======= + * console.log( +>>>>>>> 42271d072b5508617432803ceb2659d2d3067682 * 'Current time in New York', * chart.time.dateFormat('%Y-%m-%d %H:%M:%S', Date.now()) * ); @@ -10912,7 +10920,11 @@ * @example * const time = new Highcharts.Time(); * const s = time.dateFormat('%Y-%m-%d %H:%M:%S', Date.UTC(2020, 0, 1)); +<<<<<<< HEAD * //console.log(s); // => 2020-01-01 00:00:00 +======= + * console.log(s); // => 2020-01-01 00:00:00 +>>>>>>> 42271d072b5508617432803ceb2659d2d3067682 * * @function Highcharts.Time#dateFormat * @@ -11813,7 +11825,11 @@ * }); * * // Use the Time object +<<<<<<< HEAD * //console.log( +======= + * console.log( +>>>>>>> 42271d072b5508617432803ceb2659d2d3067682 * 'Current time in New York', * chart.time.dateFormat('%Y-%m-%d %H:%M:%S', Date.now()) * ); @@ -12051,7 +12067,11 @@ * * ```js * click: function(e) { +<<<<<<< HEAD * //console.log( +======= + * console.log( +>>>>>>> 42271d072b5508617432803ceb2659d2d3067682 * Highcharts.dateFormat('%Y-%m-%d %H:%M:%S', e.xAxis[0].value), * e.yAxis[0].value * ) @@ -12141,7 +12161,11 @@ * ```js * selection: function(event) { * // log the min and max of the primary, datetime x-axis +<<<<<<< HEAD * //console.log( +======= + * console.log( +>>>>>>> 42271d072b5508617432803ceb2659d2d3067682 * Highcharts.dateFormat( * '%Y-%m-%d %H:%M:%S', * event.xAxis[0].min @@ -12152,7 +12176,11 @@ * ) * ); * // log the min and max of the y axis +<<<<<<< HEAD * //console.log(event.yAxis[0].min, event.yAxis[0].max); +======= + * console.log(event.yAxis[0].min, event.yAxis[0].max); +>>>>>>> 42271d072b5508617432803ceb2659d2d3067682 * } * ``` * @@ -13674,12 +13702,21 @@ /** * The pixel size of the up and down arrows in the legend paging * navigation. +<<<<<<< HEAD * * @sample {highcharts} highcharts/legend/navigation/ * Legend page navigation demonstrated * @sample {highstock} highcharts/legend/navigation/ * Legend page navigation demonstrated * +======= + * + * @sample {highcharts} highcharts/legend/navigation/ + * Legend page navigation demonstrated + * @sample {highstock} highcharts/legend/navigation/ + * Legend page navigation demonstrated + * +>>>>>>> 42271d072b5508617432803ceb2659d2d3067682 * @type {number} * @default 12 * @since 2.2.4 @@ -15898,6 +15935,16 @@ * Translate a value in terms of axis units into pixels within the chart. * * @function Highcharts.Axis#toPixels +<<<<<<< HEAD + * + * @param {number} value + * A value in terms of axis units. + * + * @param {boolean} paneCoordinates + * Whether to return the pixel coordinate relative to the chart or just the + * axis/pane itself. + * +======= * * @param {number} value * A value in terms of axis units. @@ -15906,6 +15953,7 @@ * Whether to return the pixel coordinate relative to the chart or just the * axis/pane itself. * +>>>>>>> 42271d072b5508617432803ceb2659d2d3067682 * @return {number} * Pixel position of the value on the chart or axis. */ @@ -18495,6 +18543,22 @@ ].forEach(function (prop) { if (axis[prop]) { axis[prop] = axis[prop].destroy(); +<<<<<<< HEAD + } + }); + // Destroy each generated group for plotlines and plotbands + for (plotGroup in axis.plotLinesAndBandsGroups) { + // eslint-disable-line guard-for-in + axis.plotLinesAndBandsGroups[plotGroup] = + axis.plotLinesAndBandsGroups[plotGroup].destroy(); + } + // Delete all properties and fall back to the prototype. + objectEach(axis, function (val, key) { + if (axis.getKeepProps().indexOf(key) === -1) { + delete axis[key]; + } + }); +======= } }); // Destroy each generated group for plotlines and plotbands @@ -18509,6 +18573,7 @@ delete axis[key]; } }); +>>>>>>> 42271d072b5508617432803ceb2659d2d3067682 }; /** * Internal function to draw a crosshair. diff --git a/notemyprogress/js/highcharts/modules/accessibility.js b/notemyprogress/js/highcharts/modules/accessibility.js index 05cad981ff09c89e33328b9d9eadcfd771a831e7..7df713986a0e8ebfe31ba0cbe87a584d7124e553 100644 --- a/notemyprogress/js/highcharts/modules/accessibility.js +++ b/notemyprogress/js/highcharts/modules/accessibility.js @@ -8,174 +8,4199 @@ License: www.highcharts.com/license */ -(function(a){"object"===typeof module&&module.exports?(a["default"]=a,module.exports=a):"function"===typeof define&&define.amd?define("highcharts/modules/accessibility",["highcharts"],function(p){a(p);a.Highcharts=p;return a}):a("undefined"!==typeof Highcharts?Highcharts:void 0)})(function(a){function p(a,f,l,m){a.hasOwnProperty(f)||(a[f]=m.apply(null,l))}a=a?a._modules:{};p(a,"Accessibility/Utils/HTMLUtilities.js",[a["Core/Globals.js"],a["Core/Utilities.js"]],function(a,f){function u(a){return a.replace(/&/g, -"&").replace(/</g,"<").replace(/>/g,">").replace(/"/g,""").replace(/'/g,"'").replace(/\//g,"/")}var m=a.doc,n=a.win,g=f.merge;return{addClass:function(a,g){a.classList?a.classList.add(g):0>a.className.indexOf(g)&&(a.className+=g)},escapeStringForHTML:u,getElement:function(a){return m.getElementById(a)},getFakeMouseEvent:function(a){if("function"===typeof n.MouseEvent)return new n.MouseEvent(a);if(m.createEvent){var g=m.createEvent("MouseEvent");if(g.initMouseEvent)return g.initMouseEvent(a, -!0,!0,n,"click"===a?1:0,0,0,0,0,!1,!1,!1,!1,0,null),g}return{type:a}},removeElement:function(a){a&&a.parentNode&&a.parentNode.removeChild(a)},reverseChildNodes:function(a){for(var g=a.childNodes.length;g--;)a.appendChild(a.childNodes[g])},setElAttrs:function(a,g){Object.keys(g).forEach(function(e){var d=g[e];null===d?a.removeAttribute(e):(d=u(""+d),a.setAttribute(e,d))})},stripHTMLTagsFromString:function(a){return"string"===typeof a?a.replace(/<\/?[^>]+(>|$)/g,""):a},visuallyHideElement:function(a){g(!0, -a.style,{position:"absolute",width:"1px",height:"1px",overflow:"hidden",whiteSpace:"nowrap",clip:"rect(1px, 1px, 1px, 1px)",marginTop:"-3px","-ms-filter":"progid:DXImageTransform.Microsoft.Alpha(Opacity=1)",filter:"alpha(opacity=1)",opacity:"0.01"})}}});p(a,"Accessibility/Utils/ChartUtilities.js",[a["Accessibility/Utils/HTMLUtilities.js"],a["Core/Utilities.js"]],function(a,f){function u(d){var b,c;if(null===(b=d.points)||void 0===b?0:b.length)return d=q(d.points,function(c){return!!c.graphic}),null=== -(c=null===d||void 0===d?void 0:d.graphic)||void 0===c?void 0:c.element}function m(d){var b=u(d);return b&&b.parentNode||d.graph&&d.graph.element||d.group&&d.group.element}function n(d,b){b.setAttribute("aria-hidden",!1);b!==d.renderTo&&b.parentNode&&(Array.prototype.forEach.call(b.parentNode.childNodes,function(c){c.hasAttribute("aria-hidden")||c.setAttribute("aria-hidden",!0)}),n(d,b.parentNode))}var g=a.stripHTMLTagsFromString,h=f.defined,q=f.find,e=f.fireEvent;return{getChartTitle:function(d){return g(d.options.title.text|| -d.langFormat("accessibility.defaultChartTitle",{chart:d}))},getAxisDescription:function(d){return g(d&&(d.userOptions&&d.userOptions.accessibility&&d.userOptions.accessibility.description||d.axisTitle&&d.axisTitle.textStr||d.options.id||d.categories&&"categories"||d.dateTime&&"Time"||"values"))},getPointFromXY:function(d,b,c){for(var k=d.length,t;k--;)if(t=q(d[k].points||[],function(v){return v.x===b&&v.y===c}))return t},getSeriesFirstPointElement:u,getSeriesFromName:function(d,b){return b?(d.series|| -[]).filter(function(c){return c.name===b}):d.series},getSeriesA11yElement:m,unhideChartElementFromAT:n,hideSeriesFromAT:function(d){(d=m(d))&&d.setAttribute("aria-hidden",!0)},scrollToPoint:function(d){var b=d.series.xAxis,c=d.series.yAxis,k=(null===b||void 0===b?0:b.scrollbar)?b:c;if((b=null===k||void 0===k?void 0:k.scrollbar)&&h(b.to)&&h(b.from)){c=b.to-b.from;if(h(k.dataMin)&&h(k.dataMax)){var t=k.toPixels(k.dataMin),v=k.toPixels(k.dataMax);d=(k.toPixels(d["xAxis"===k.coll?"x":"y"]||0)-t)/(v-t)}else d= -0;b.updatePosition(d-c/2,d+c/2);e(b,"changed",{from:b.from,to:b.to,trigger:"scrollbar",DOMEvent:null})}}}});p(a,"Accessibility/KeyboardNavigationHandler.js",[a["Core/Utilities.js"]],function(a){function f(a,f){this.chart=a;this.keyCodeMap=f.keyCodeMap||[];this.validate=f.validate;this.init=f.init;this.terminate=f.terminate;this.response={success:1,prev:2,next:3,noHandler:4,fail:5}}var u=a.find;f.prototype={run:function(a){var f=a.which||a.keyCode,g=this.response.noHandler,h=u(this.keyCodeMap,function(a){return-1< -a[0].indexOf(f)});h?g=h[1].call(this,f,a):9===f&&(g=this.response[a.shiftKey?"prev":"next"]);return g}};return f});p(a,"Accessibility/Utils/DOMElementProvider.js",[a["Core/Globals.js"],a["Accessibility/Utils/HTMLUtilities.js"],a["Core/Utilities.js"]],function(a,f,l){var u=a.doc,n=f.removeElement;a=l.extend;f=function(){this.elements=[]};a(f.prototype,{createElement:function(){var a=u.createElement.apply(u,arguments);this.elements.push(a);return a},destroyCreatedElements:function(){this.elements.forEach(function(a){n(a)}); -this.elements=[]}});return f});p(a,"Accessibility/Utils/EventProvider.js",[a["Core/Globals.js"],a["Core/Utilities.js"]],function(a,f){var u=f.addEvent;f=f.extend;var m=function(){this.eventRemovers=[]};f(m.prototype,{addEvent:function(){var f=u.apply(a,arguments);this.eventRemovers.push(f);return f},removeAddedEvents:function(){this.eventRemovers.forEach(function(a){a()});this.eventRemovers=[]}});return m});p(a,"Accessibility/AccessibilityComponent.js",[a["Accessibility/Utils/ChartUtilities.js"], -a["Accessibility/Utils/DOMElementProvider.js"],a["Accessibility/Utils/EventProvider.js"],a["Core/Globals.js"],a["Accessibility/Utils/HTMLUtilities.js"],a["Core/Utilities.js"]],function(a,f,l,m,n,g){function h(){}var q=a.unhideChartElementFromAT,e=m.doc,d=m.win,b=n.removeElement,c=n.getFakeMouseEvent;a=g.extend;var k=g.fireEvent,t=g.merge;h.prototype={initBase:function(c){this.chart=c;this.eventProvider=new l;this.domElementProvider=new f;this.keyCodes={left:37,right:39,up:38,down:40,enter:13,space:32, -esc:27,tab:9}},addEvent:function(){return this.eventProvider.addEvent.apply(this.eventProvider,arguments)},createElement:function(){return this.domElementProvider.createElement.apply(this.domElementProvider,arguments)},fireEventOnWrappedOrUnwrappedElement:function(c,b){var v=b.type;e.createEvent&&(c.dispatchEvent||c.fireEvent)?c.dispatchEvent?c.dispatchEvent(b):c.fireEvent(v,b):k(c,v,b)},fakeClickEvent:function(b){if(b){var v=c("click");this.fireEventOnWrappedOrUnwrappedElement(b,v)}},addProxyGroup:function(c){this.createOrUpdateProxyContainer(); -var b=this.createElement("div");Object.keys(c||{}).forEach(function(v){null!==c[v]&&b.setAttribute(v,c[v])});this.chart.a11yProxyContainer.appendChild(b);return b},createOrUpdateProxyContainer:function(){var c=this.chart,b=c.renderer.box;c.a11yProxyContainer=c.a11yProxyContainer||this.createProxyContainerElement();b.nextSibling!==c.a11yProxyContainer&&c.container.insertBefore(c.a11yProxyContainer,b.nextSibling)},createProxyContainerElement:function(){var c=e.createElement("div");c.className="highcharts-a11y-proxy-container"; -return c},createProxyButton:function(c,b,a,d,k){var v=c.element,e=this.createElement("button"),w=t({"aria-label":v.getAttribute("aria-label")},a);Object.keys(w).forEach(function(c){null!==w[c]&&e.setAttribute(c,w[c])});e.className="highcharts-a11y-proxy-button";k&&this.addEvent(e,"click",k);this.setProxyButtonStyle(e);this.updateProxyButtonPosition(e,d||c);this.proxyMouseEventsForButton(v,e);b.appendChild(e);w["aria-hidden"]||q(this.chart,e);return e},getElementPosition:function(c){var b=c.element; -return(c=this.chart.renderTo)&&b&&b.getBoundingClientRect?(b=b.getBoundingClientRect(),c=c.getBoundingClientRect(),{x:b.left-c.left,y:b.top-c.top,width:b.right-b.left,height:b.bottom-b.top}):{x:0,y:0,width:1,height:1}},setProxyButtonStyle:function(c){t(!0,c.style,{"border-width":0,"background-color":"transparent",cursor:"pointer",outline:"none",opacity:.001,filter:"alpha(opacity=1)","-ms-filter":"progid:DXImageTransform.Microsoft.Alpha(Opacity=1)",zIndex:999,overflow:"hidden",padding:0,margin:0,display:"block", -position:"absolute"})},updateProxyButtonPosition:function(c,b){b=this.getElementPosition(b);t(!0,c.style,{width:(b.width||1)+"px",height:(b.height||1)+"px",left:(b.x||0)+"px",top:(b.y||0)+"px"})},proxyMouseEventsForButton:function(c,b){var a=this;"click touchstart touchend touchcancel touchmove mouseover mouseenter mouseleave mouseout".split(" ").forEach(function(d){var t=0===d.indexOf("touch");a.addEvent(b,d,function(b){var d=t?a.cloneTouchEvent(b):a.cloneMouseEvent(b);c&&a.fireEventOnWrappedOrUnwrappedElement(c, -d);b.stopPropagation();b.preventDefault()})})},cloneMouseEvent:function(b){if("function"===typeof d.MouseEvent)return new d.MouseEvent(b.type,b);if(e.createEvent){var a=e.createEvent("MouseEvent");if(a.initMouseEvent)return a.initMouseEvent(b.type,b.bubbles,b.cancelable,b.view||d,b.detail,b.screenX,b.screenY,b.clientX,b.clientY,b.ctrlKey,b.altKey,b.shiftKey,b.metaKey,b.button,b.relatedTarget),a}return c(b.type)},cloneTouchEvent:function(b){var c=function(b){for(var c=[],a=0;a<b.length;++a){var d= -b.item(a);d&&c.push(d)}return c};if("function"===typeof d.TouchEvent)return c=new d.TouchEvent(b.type,{touches:c(b.touches),targetTouches:c(b.targetTouches),changedTouches:c(b.changedTouches),ctrlKey:b.ctrlKey,shiftKey:b.shiftKey,altKey:b.altKey,metaKey:b.metaKey,bubbles:b.bubbles,cancelable:b.cancelable,composed:b.composed,detail:b.detail,view:b.view}),b.defaultPrevented&&c.preventDefault(),c;c=this.cloneMouseEvent(b);c.touches=b.touches;c.changedTouches=b.changedTouches;c.targetTouches=b.targetTouches; -return c},destroyBase:function(){b(this.chart.a11yProxyContainer);this.domElementProvider.destroyCreatedElements();this.eventProvider.removeAddedEvents()}};a(h.prototype,{init:function(){},getKeyboardNavigation:function(){},onChartUpdate:function(){},onChartRender:function(){},destroy:function(){}});return h});p(a,"Accessibility/KeyboardNavigation.js",[a["Core/Globals.js"],a["Core/Utilities.js"],a["Accessibility/Utils/HTMLUtilities.js"],a["Accessibility/Utils/EventProvider.js"]],function(a,f,l,m){function n(b, -c){this.init(b,c)}var g=a.doc,h=a.win,q=f.addEvent,e=f.fireEvent,d=l.getElement;q(g,"keydown",function(b){27===(b.which||b.keyCode)&&a.charts&&a.charts.forEach(function(b){b&&b.dismissPopupContent&&b.dismissPopupContent()})});a.Chart.prototype.dismissPopupContent=function(){var b=this;e(this,"dismissPopupContent",{},function(){b.tooltip&&b.tooltip.hide(0);b.hideExportMenu()})};n.prototype={init:function(b,c){var a=this,d=this.eventProvider=new m;this.chart=b;this.components=c;this.modules=[];this.currentModuleIx= -0;this.update();d.addEvent(this.tabindexContainer,"keydown",function(b){return a.onKeydown(b)});d.addEvent(this.tabindexContainer,"focus",function(b){return a.onFocus(b)});["mouseup","touchend"].forEach(function(b){return d.addEvent(g,b,function(){return a.onMouseUp()})});["mousedown","touchstart"].forEach(function(c){return d.addEvent(b.renderTo,c,function(){a.isClickingChart=!0})});d.addEvent(b.renderTo,"mouseover",function(){a.pointerIsOverChart=!0});d.addEvent(b.renderTo,"mouseout",function(){a.pointerIsOverChart= -!1});this.modules.length&&this.modules[0].init(1)},update:function(b){var c=this.chart.options.accessibility;c=c&&c.keyboardNavigation;var a=this.components;this.updateContainerTabindex();c&&c.enabled&&b&&b.length?(this.modules=b.reduce(function(b,c){c=a[c].getKeyboardNavigation();return b.concat(c)},[]),this.updateExitAnchor()):(this.modules=[],this.currentModuleIx=0,this.removeExitAnchor())},onFocus:function(b){var c,a=this.chart;b=b.relatedTarget&&a.container.contains(b.relatedTarget);this.isClickingChart|| -b||(null===(c=this.modules[0])||void 0===c?void 0:c.init(1))},onMouseUp:function(){delete this.isClickingChart;if(!this.keyboardReset&&!this.pointerIsOverChart){var b=this.chart,c=this.modules&&this.modules[this.currentModuleIx||0];c&&c.terminate&&c.terminate();b.focusElement&&b.focusElement.removeFocusBorder();this.currentModuleIx=0;this.keyboardReset=!0}},onKeydown:function(b){b=b||h.event;var c,a=this.modules&&this.modules.length&&this.modules[this.currentModuleIx];this.keyboardReset=!1;if(a){var d= -a.run(b);d===a.response.success?c=!0:d===a.response.prev?c=this.prev():d===a.response.next&&(c=this.next());c&&(b.preventDefault(),b.stopPropagation())}},prev:function(){return this.move(-1)},next:function(){return this.move(1)},move:function(b){var c=this.modules&&this.modules[this.currentModuleIx];c&&c.terminate&&c.terminate(b);this.chart.focusElement&&this.chart.focusElement.removeFocusBorder();this.currentModuleIx+=b;if(c=this.modules&&this.modules[this.currentModuleIx]){if(c.validate&&!c.validate())return this.move(b); -if(c.init)return c.init(b),!0}this.currentModuleIx=0;0<b?(this.exiting=!0,this.exitAnchor.focus()):this.tabindexContainer.focus();return!1},updateExitAnchor:function(){var b=d("highcharts-end-of-chart-marker-"+this.chart.index);this.removeExitAnchor();b?(this.makeElementAnExitAnchor(b),this.exitAnchor=b):this.createExitAnchor()},updateContainerTabindex:function(){var b=this.chart.options.accessibility;b=b&&b.keyboardNavigation;b=!(b&&!1===b.enabled);var c=this.chart,a=c.container;c.renderTo.hasAttribute("tabindex")&& -(a.removeAttribute("tabindex"),a=c.renderTo);this.tabindexContainer=a;var d=a.getAttribute("tabindex");b&&!d?a.setAttribute("tabindex","0"):b||c.container.removeAttribute("tabindex")},makeElementAnExitAnchor:function(b){var c=this.tabindexContainer.getAttribute("tabindex")||0;b.setAttribute("class","highcharts-exit-anchor");b.setAttribute("tabindex",c);b.setAttribute("aria-hidden",!1);this.addExitAnchorEventsToEl(b)},createExitAnchor:function(){var b=this.chart,c=this.exitAnchor=g.createElement("div"); -b.renderTo.appendChild(c);this.makeElementAnExitAnchor(c)},removeExitAnchor:function(){this.exitAnchor&&this.exitAnchor.parentNode&&(this.exitAnchor.parentNode.removeChild(this.exitAnchor),delete this.exitAnchor)},addExitAnchorEventsToEl:function(b){var c=this.chart,a=this;this.eventProvider.addEvent(b,"focus",function(b){b=b||h.event;b.relatedTarget&&c.container.contains(b.relatedTarget)||a.exiting?a.exiting=!1:(a.tabindexContainer.focus(),b.preventDefault(),a.modules&&a.modules.length&&(a.currentModuleIx= -a.modules.length-1,(b=a.modules[a.currentModuleIx])&&b.validate&&!b.validate()?a.prev():b&&b.init(-1)))})},destroy:function(){this.removeExitAnchor();this.eventProvider.removeAddedEvents();this.chart.container.removeAttribute("tabindex")}};return n});p(a,"Accessibility/Components/LegendComponent.js",[a["Core/Globals.js"],a["Core/Legend.js"],a["Core/Utilities.js"],a["Accessibility/AccessibilityComponent.js"],a["Accessibility/KeyboardNavigationHandler.js"],a["Accessibility/Utils/HTMLUtilities.js"]], -function(a,f,l,m,n,g){function h(b){var c=b.legend&&b.legend.allItems,a=b.options.legend.accessibility||{};return!(!c||!c.length||b.colorAxis&&b.colorAxis.length||!1===a.enabled)}var q=l.addEvent,e=l.extend,d=l.find,b=l.fireEvent,c=g.stripHTMLTagsFromString,k=g.removeElement;a.Chart.prototype.highlightLegendItem=function(c){var a=this.legend.allItems,d=this.highlightedLegendItemIx;if(a[c]){a[d]&&b(a[d].legendGroup.element,"mouseout");d=this.legend;var k=d.allItems[c].pageIx,t=d.currentPage;"undefined"!== -typeof k&&k+1!==t&&d.scroll(1+k-t);this.setFocusToElement(a[c].legendItem,a[c].a11yProxyElement);b(a[c].legendGroup.element,"mouseover");return!0}return!1};q(f,"afterColorizeItem",function(b){var c=b.item;this.chart.options.accessibility.enabled&&c&&c.a11yProxyElement&&c.a11yProxyElement.setAttribute("aria-pressed",b.visible?"false":"true")});a=function(){};a.prototype=new m;e(a.prototype,{init:function(){var b=this;this.proxyElementsList=[];this.recreateProxies();this.addEvent(f,"afterScroll",function(){this.chart=== -b.chart&&(b.updateProxiesPositions(),b.updateLegendItemProxyVisibility(),this.chart.highlightLegendItem(b.highlightedLegendItemIx))});this.addEvent(f,"afterPositionItem",function(c){this.chart===b.chart&&this.chart.renderer&&b.updateProxyPositionForItem(c.item)})},updateLegendItemProxyVisibility:function(){var b=this.chart.legend,c=b.currentPage||1,a=b.clipHeight||0;(b.allItems||[]).forEach(function(d){var k=d.pageIx||0,t=d._legendItemPos?d._legendItemPos[1]:0,e=d.legendItem?Math.round(d.legendItem.getBBox().height): -0;k=t+e-b.pages[k]>a||k!==c-1;d.a11yProxyElement&&(d.a11yProxyElement.style.visibility=k?"hidden":"visible")})},onChartRender:function(){h(this.chart)?this.updateProxiesPositions():this.removeProxies()},updateProxiesPositions:function(){for(var b=0,c=this.proxyElementsList;b<c.length;b++){var a=c[b];this.updateProxyButtonPosition(a.element,a.posElement)}},updateProxyPositionForItem:function(b){var c=d(this.proxyElementsList,function(c){return c.item===b});c&&this.updateProxyButtonPosition(c.element, -c.posElement)},recreateProxies:function(){this.removeProxies();h(this.chart)&&(this.addLegendProxyGroup(),this.proxyLegendItems(),this.updateLegendItemProxyVisibility())},removeProxies:function(){k(this.legendProxyGroup);this.proxyElementsList=[]},addLegendProxyGroup:function(){var b=this.chart.options.accessibility,c=this.chart.langFormat("accessibility.legend.legendLabel",{});this.legendProxyGroup=this.addProxyGroup({"aria-label":c,role:"all"===b.landmarkVerbosity?"region":null})},proxyLegendItems:function(){var b= -this;(this.chart.legend&&this.chart.legend.allItems||[]).forEach(function(c){c.legendItem&&c.legendItem.element&&b.proxyLegendItem(c)})},proxyLegendItem:function(b){if(b.legendItem&&b.legendGroup){var a=this.chart.langFormat("accessibility.legend.legendItem",{chart:this.chart,itemName:c(b.name)}),d=b.legendGroup.div?b.legendItem:b.legendGroup;b.a11yProxyElement=this.createProxyButton(b.legendItem,this.legendProxyGroup,{tabindex:-1,"aria-pressed":!b.visible,"aria-label":a},d);this.proxyElementsList.push({item:b, -element:b.a11yProxyElement,posElement:d})}},getKeyboardNavigation:function(){var b=this.keyCodes,c=this;return new n(this.chart,{keyCodeMap:[[[b.left,b.right,b.up,b.down],function(b){return c.onKbdArrowKey(this,b)}],[[b.enter,b.space],function(){return c.onKbdClick(this)}]],validate:function(){return c.shouldHaveLegendNavigation()},init:function(b){return c.onKbdNavigationInit(b)}})},onKbdArrowKey:function(b,c){var a=this.keyCodes,d=b.response,k=this.chart,e=k.options.accessibility,t=k.legend.allItems.length; -c=c===a.left||c===a.up?-1:1;return k.highlightLegendItem(this.highlightedLegendItemIx+c)?(this.highlightedLegendItemIx+=c,d.success):1<t&&e.keyboardNavigation.wrapAround?(b.init(c),d.success):d[0<c?"next":"prev"]},onKbdClick:function(c){var a=this.chart.legend.allItems[this.highlightedLegendItemIx];a&&a.a11yProxyElement&&b(a.a11yProxyElement,"click");return c.response.success},shouldHaveLegendNavigation:function(){var b=this.chart,c=b.colorAxis&&b.colorAxis.length,a=(b.options.legend||{}).accessibility|| -{};return!!(b.legend&&b.legend.allItems&&b.legend.display&&!c&&a.enabled&&a.keyboardNavigation&&a.keyboardNavigation.enabled)},onKbdNavigationInit:function(b){var c=this.chart,a=c.legend.allItems.length-1;b=0<b?0:a;c.highlightLegendItem(b);this.highlightedLegendItemIx=b}});return a});p(a,"Accessibility/Components/MenuComponent.js",[a["Core/Globals.js"],a["Core/Utilities.js"],a["Accessibility/AccessibilityComponent.js"],a["Accessibility/KeyboardNavigationHandler.js"],a["Accessibility/Utils/ChartUtilities.js"], -a["Accessibility/Utils/HTMLUtilities.js"]],function(a,f,l,m,n,g){function h(b){return b.exportSVGElements&&b.exportSVGElements[0]}f=f.extend;var q=n.unhideChartElementFromAT,e=g.removeElement,d=g.getFakeMouseEvent;a.Chart.prototype.showExportMenu=function(){var b=h(this);if(b&&(b=b.element,b.onclick))b.onclick(d("click"))};a.Chart.prototype.hideExportMenu=function(){var b=this.exportDivElements;b&&this.exportContextMenu&&(b.forEach(function(b){if("highcharts-menu-item"===b.className&&b.onmouseout)b.onmouseout(d("mouseout"))}), -this.highlightedExportItemIx=0,this.exportContextMenu.hideMenu(),this.container.focus())};a.Chart.prototype.highlightExportItem=function(b){var c=this.exportDivElements&&this.exportDivElements[b],a=this.exportDivElements&&this.exportDivElements[this.highlightedExportItemIx];if(c&&"LI"===c.tagName&&(!c.children||!c.children.length)){var e=!!(this.renderTo.getElementsByTagName("g")[0]||{}).focus;c.focus&&e&&c.focus();if(a&&a.onmouseout)a.onmouseout(d("mouseout"));if(c.onmouseover)c.onmouseover(d("mouseover")); -this.highlightedExportItemIx=b;return!0}return!1};a.Chart.prototype.highlightLastExportItem=function(){var b;if(this.exportDivElements)for(b=this.exportDivElements.length;b--;)if(this.highlightExportItem(b))return!0;return!1};a=function(){};a.prototype=new l;f(a.prototype,{init:function(){var b=this.chart,c=this;this.addEvent(b,"exportMenuShown",function(){c.onMenuShown()});this.addEvent(b,"exportMenuHidden",function(){c.onMenuHidden()})},onMenuHidden:function(){var b=this.chart.exportContextMenu; -b&&b.setAttribute("aria-hidden","true");this.isExportMenuShown=!1;this.setExportButtonExpandedState("false")},onMenuShown:function(){var b=this.chart,c=b.exportContextMenu;c&&(this.addAccessibleContextMenuAttribs(),q(b,c));this.isExportMenuShown=!0;this.setExportButtonExpandedState("true")},setExportButtonExpandedState:function(b){var c=this.exportButtonProxy;c&&c.setAttribute("aria-expanded",b)},onChartRender:function(){var b=this.chart,c=b.options.accessibility;e(this.exportProxyGroup);var a=b.options.exporting, -d=h(b);a&&!1!==a.enabled&&a.accessibility&&a.accessibility.enabled&&d&&d.element&&(this.exportProxyGroup=this.addProxyGroup("all"===c.landmarkVerbosity?{"aria-label":b.langFormat("accessibility.exporting.exportRegionLabel",{chart:b}),role:"region"}:{}),c=h(this.chart),this.exportButtonProxy=this.createProxyButton(c,this.exportProxyGroup,{"aria-label":b.langFormat("accessibility.exporting.menuButtonLabel",{chart:b}),"aria-expanded":"false"}))},addAccessibleContextMenuAttribs:function(){var b=this.chart, -c=b.exportDivElements;c&&c.length&&(c.forEach(function(b){"LI"!==b.tagName||b.children&&b.children.length?b.setAttribute("aria-hidden","true"):b.setAttribute("tabindex",-1)}),c=c[0].parentNode,c.removeAttribute("aria-hidden"),c.setAttribute("aria-label",b.langFormat("accessibility.exporting.chartMenuLabel",{chart:b})))},getKeyboardNavigation:function(){var b=this.keyCodes,c=this.chart,a=this;return new m(c,{keyCodeMap:[[[b.left,b.up],function(){return a.onKbdPrevious(this)}],[[b.right,b.down],function(){return a.onKbdNext(this)}], -[[b.enter,b.space],function(){return a.onKbdClick(this)}]],validate:function(){return c.exportChart&&!1!==c.options.exporting.enabled&&!1!==c.options.exporting.accessibility.enabled},init:function(){var b=a.exportButtonProxy,d=c.exportingGroup;d&&b&&c.setFocusToElement(d,b)},terminate:function(){c.hideExportMenu()}})},onKbdPrevious:function(b){var c=this.chart,a=c.options.accessibility;b=b.response;for(var d=c.highlightedExportItemIx||0;d--;)if(c.highlightExportItem(d))return b.success;return a.keyboardNavigation.wrapAround? -(c.highlightLastExportItem(),b.success):b.prev},onKbdNext:function(b){var c=this.chart,a=c.options.accessibility;b=b.response;for(var d=(c.highlightedExportItemIx||0)+1;d<c.exportDivElements.length;++d)if(c.highlightExportItem(d))return b.success;return a.keyboardNavigation.wrapAround?(c.highlightExportItem(0),b.success):b.next},onKbdClick:function(b){var c=this.chart,a=c.exportDivElements[c.highlightedExportItemIx],d=h(c).element;this.isExportMenuShown?this.fakeClickEvent(a):(this.fakeClickEvent(d), -c.highlightExportItem(0));return b.response.success}});return a});p(a,"Accessibility/Components/SeriesComponent/SeriesKeyboardNavigation.js",[a["Core/Series/Series.js"],a["Core/Series/CartesianSeries.js"],a["Core/Chart/Chart.js"],a["Core/Series/Point.js"],a["Core/Utilities.js"],a["Accessibility/KeyboardNavigationHandler.js"],a["Accessibility/Utils/EventProvider.js"],a["Accessibility/Utils/ChartUtilities.js"]],function(a,f,l,m,n,g,h,q){function e(b){var c=b.index,a=b.series.points,d=a.length;if(a[c]!== -b)for(;d--;){if(a[d]===b)return d}else return c}function d(b){var c=b.chart.options.accessibility.keyboardNavigation.seriesNavigation,a=b.options.accessibility||{},d=a.keyboardNavigation;return d&&!1===d.enabled||!1===a.enabled||!1===b.options.enableMouseTracking||!b.visible||c.pointNavigationEnabledThreshold&&c.pointNavigationEnabledThreshold<=b.points.length}function b(b){var c=b.series.chart.options.accessibility;return b.isNull&&c.keyboardNavigation.seriesNavigation.skipNullPoints||!1===b.visible|| -d(b.series)}function c(b,c,a,d){var r=Infinity,e=c.points.length,k=function(b){return!(w(b.plotX)&&w(b.plotY))};if(!k(b)){for(;e--;){var g=c.points[e];if(!k(g)&&(g=(b.plotX-g.plotX)*(b.plotX-g.plotX)*(a||1)+(b.plotY-g.plotY)*(b.plotY-g.plotY)*(d||1),g<r)){r=g;var h=e}}return w(h)?c.points[h]:void 0}}function k(b){var c=!1;delete b.highlightedPoint;return c=b.series.reduce(function(b,c){return b||c.highlightFirstValidPoint()},!1)}function t(b,c){this.keyCodes=c;this.chart=b}var v=a.seriesTypes,w=n.defined; -a=n.extend;var u=q.getPointFromXY,A=q.getSeriesFromName,p=q.scrollToPoint;f.prototype.keyboardMoveVertical=!0;["column","pie"].forEach(function(b){v[b]&&(v[b].prototype.keyboardMoveVertical=!1)});m.prototype.highlight=function(){var b=this.series.chart;if(this.isNull)b.tooltip&&b.tooltip.hide(0);else this.onMouseOver();p(this);this.graphic&&b.setFocusToElement(this.graphic);b.highlightedPoint=this;return this};l.prototype.highlightAdjacentPoint=function(c){var a=this.series,k=this.highlightedPoint, -r=k&&e(k)||0,g=k&&k.series.points,h=this.series&&this.series[this.series.length-1];h=h&&h.points&&h.points[h.points.length-1];if(!a[0]||!a[0].points)return!1;if(k){if(a=a[k.series.index+(c?1:-1)],r=g[r+(c?1:-1)],!r&&a&&(r=a.points[c?0:a.points.length-1]),!r)return!1}else r=c?a[0].points[0]:h;return b(r)?(a=r.series,d(a)?this.highlightedPoint=c?a.points[a.points.length-1]:a.points[0]:this.highlightedPoint=r,this.highlightAdjacentPoint(c)):r.highlight()};f.prototype.highlightFirstValidPoint=function(){var c= -this.chart.highlightedPoint,a=(c&&c.series)===this?e(c):0;c=this.points;var d=c.length;if(c&&d){for(var r=a;r<d;++r)if(!b(c[r]))return c[r].highlight();for(;0<=a;--a)if(!b(c[a]))return c[a].highlight()}return!1};l.prototype.highlightAdjacentSeries=function(b){var a,k=this.highlightedPoint;var r=(a=this.series&&this.series[this.series.length-1])&&a.points&&a.points[a.points.length-1];if(!this.highlightedPoint)return a=b?this.series&&this.series[0]:a,(r=b?a&&a.points&&a.points[0]:r)?r.highlight():!1; -a=this.series[k.series.index+(b?-1:1)];if(!a)return!1;r=c(k,a,4);if(!r)return!1;if(d(a))return r.highlight(),b=this.highlightAdjacentSeries(b),b?b:(k.highlight(),!1);r.highlight();return r.series.highlightFirstValidPoint()};l.prototype.highlightAdjacentPointVertical=function(c){var a=this.highlightedPoint,k=Infinity,r;if(!w(a.plotX)||!w(a.plotY))return!1;this.series.forEach(function(e){d(e)||e.points.forEach(function(d){if(w(d.plotY)&&w(d.plotX)&&d!==a){var g=d.plotY-a.plotY,h=Math.abs(d.plotX-a.plotX); -h=Math.abs(g)*Math.abs(g)+h*h*4;e.yAxis&&e.yAxis.reversed&&(g*=-1);!(0>=g&&c||0<=g&&!c||5>h||b(d))&&h<k&&(k=h,r=d)}})});return r?r.highlight():!1};a(t.prototype,{init:function(){var b=this,c=this.chart,a=this.eventProvider=new h;a.addEvent(f,"destroy",function(){return b.onSeriesDestroy(this)});a.addEvent(c,"afterDrilldown",function(){k(this);this.focusElement&&this.focusElement.removeFocusBorder()});a.addEvent(c,"drilldown",function(c){c=c.point;var a=c.series;b.lastDrilledDownPoint={x:c.x,y:c.y, -seriesName:a?a.name:""}});a.addEvent(c,"drillupall",function(){setTimeout(function(){b.onDrillupAll()},10)})},onDrillupAll:function(){var b=this.lastDrilledDownPoint,c=this.chart,a=b&&A(c,b.seriesName),d;b&&a&&w(b.x)&&w(b.y)&&(d=u(a,b.x,b.y));c.container&&c.container.focus();d&&d.highlight&&d.highlight();c.focusElement&&c.focusElement.removeFocusBorder()},getKeyboardNavigationHandler:function(){var b=this,c=this.keyCodes,a=this.chart,d=a.inverted;return new g(a,{keyCodeMap:[[d?[c.up,c.down]:[c.left, -c.right],function(c){return b.onKbdSideways(this,c)}],[d?[c.left,c.right]:[c.up,c.down],function(c){return b.onKbdVertical(this,c)}],[[c.enter,c.space],function(){a.highlightedPoint&&a.highlightedPoint.firePointEvent("click");return this.response.success}]],init:function(c){return b.onHandlerInit(this,c)},terminate:function(){return b.onHandlerTerminate()}})},onKbdSideways:function(b,c){var a=this.keyCodes;return this.attemptHighlightAdjacentPoint(b,c===a.right||c===a.down)},onKbdVertical:function(b, -c){var a=this.chart,d=this.keyCodes;c=c===d.down||c===d.right;d=a.options.accessibility.keyboardNavigation.seriesNavigation;if(d.mode&&"serialize"===d.mode)return this.attemptHighlightAdjacentPoint(b,c);a[a.highlightedPoint&&a.highlightedPoint.series.keyboardMoveVertical?"highlightAdjacentPointVertical":"highlightAdjacentSeries"](c);return b.response.success},onHandlerInit:function(b,c){var a=this.chart;if(0<c)k(a);else{c=a.series.length;for(var d;c--&&!(a.highlightedPoint=a.series[c].points[a.series[c].points.length- -1],d=a.series[c].highlightFirstValidPoint()););}return b.response.success},onHandlerTerminate:function(){var b,c,a=this.chart,d=a.highlightedPoint;null===(b=a.tooltip)||void 0===b?void 0:b.hide(0);null===(c=null===d||void 0===d?void 0:d.onMouseOut)||void 0===c?void 0:c.call(d);delete a.highlightedPoint},attemptHighlightAdjacentPoint:function(b,c){var a=this.chart,d=a.options.accessibility.keyboardNavigation.wrapAround;return a.highlightAdjacentPoint(c)?b.response.success:d?b.init(c?1:-1):b.response[c? -"next":"prev"]},onSeriesDestroy:function(b){var c=this.chart;c.highlightedPoint&&c.highlightedPoint.series===b&&(delete c.highlightedPoint,c.focusElement&&c.focusElement.removeFocusBorder())},destroy:function(){this.eventProvider.removeAddedEvents()}});return t});p(a,"Accessibility/Components/AnnotationsA11y.js",[a["Accessibility/Utils/HTMLUtilities.js"]],function(a){function f(a){return(a.annotations||[]).reduce(function(a,d){var b;!1!==(null===(b=d.options)||void 0===b?void 0:b.visible)&&(a=a.concat(d.labels)); -return a},[])}function l(a){var e,d,b,c,k=null===(d=null===(e=a.options)||void 0===e?void 0:e.accessibility)||void 0===d?void 0:d.description;return k?k:(null===(c=null===(b=a.graphic)||void 0===b?void 0:b.text)||void 0===c?void 0:c.textStr)||""}function m(a){var e,d,b=null===(d=null===(e=a.options)||void 0===e?void 0:e.accessibility)||void 0===d?void 0:d.description;if(b)return b;e=a.chart;d=l(a);b=a.points.filter(function(b){return!!b.graphic}).map(function(b){var c,a;if(!(a=null===(c=null===b|| -void 0===b?void 0:b.accessibility)||void 0===c?void 0:c.valueDescription)){var d,e;a=(null===(e=null===(d=null===b||void 0===b?void 0:b.graphic)||void 0===d?void 0:d.element)||void 0===e?void 0:e.getAttribute("aria-label"))||""}b=(null===b||void 0===b?void 0:b.series.name)||"";return(b?b+", ":"")+"data point "+a}).filter(function(b){return!!b});var c=b.length;a="accessibility.screenReaderSection.annotations.description"+(1<c?"MultiplePoints":c?"SinglePoint":"NoPoints");d={annotationText:d,numPoints:c, -annotationPoint:b[0],additionalAnnotationPoints:b.slice(1)};return e.langFormat(a,d)}function n(a){return f(a).map(function(a){return(a=g(h(m(a))))?"<li>"+a+"</li>":""})}var g=a.escapeStringForHTML,h=a.stripHTMLTagsFromString;return{getAnnotationsInfoHTML:function(a){var e=a.annotations;return e&&e.length?"<ul>"+n(a).join(" ")+"</ul>":""},getAnnotationLabelDescription:m,getAnnotationListItems:n,getPointAnnotationTexts:function(a){var e=f(a.series.chart).filter(function(d){return-1<d.points.indexOf(a)}); -return e.length?e.map(function(a){return""+l(a)}):[]}}});p(a,"Accessibility/Components/SeriesComponent/SeriesDescriber.js",[a["Accessibility/Components/AnnotationsA11y.js"],a["Accessibility/Utils/ChartUtilities.js"],a["Accessibility/Utils/HTMLUtilities.js"],a["Core/Tooltip.js"],a["Core/Utilities.js"]],function(a,f,l,m,n){function g(b){var c=b.index;return b.series&&b.series.data&&G(c)?K(b.series.data,function(b){return!!(b&&"undefined"!==typeof b.index&&b.index>c&&b.graphic&&b.graphic.element)})|| -null:null}function h(b){var c=b.chart.options.accessibility.series.pointDescriptionEnabledThreshold;return!!(!1!==c&&b.points&&b.points.length>=c)}function q(b){var c=b.options.accessibility||{};return!h(b)&&!c.exposeAsGroupOnly}function e(b){var c=b.chart.options.accessibility.keyboardNavigation.seriesNavigation;return!(!b.points||!(b.points.length<c.pointNavigationEnabledThreshold||!1===c.pointNavigationEnabledThreshold))}function d(b,c){var a=b.series.chart,d=a.options.accessibility.point||{}; -b=b.series.tooltipOptions||{};a=a.options.lang;return L(c)?M(c,d.valueDecimals||b.valueDecimals||-1,a.decimalPoint,a.accessibility.thousandsSep||a.thousandsSep):c}function b(b){var c=(b.options.accessibility||{}).description;return c&&b.chart.langFormat("accessibility.series.description",{description:c,series:b})||""}function c(b,c){return b.chart.langFormat("accessibility.series."+c+"Description",{name:x(b[c]),series:b})}function k(b){var c=b.series,a=c.chart,d=a.options.accessibility.point||{}; -if(c.xAxis&&c.xAxis.dateTime)return c=m.prototype.getXDateFormat.call({getDateFormat:m.prototype.getDateFormat,chart:a},b,a.options.tooltip,c.xAxis),d=d.dateFormatter&&d.dateFormatter(b)||d.dateFormat||c,a.time.dateFormat(d,b.x,void 0)}function t(b){var c=k(b),a=(b.series.xAxis||{}).categories&&G(b.category)&&(""+b.category).replace("<br/>"," "),d=b.id&&0>b.id.indexOf("highcharts-"),e="x, "+b.x;return b.name||c||a||(d?b.id:e)}function v(b,c,a){var e=c||"",k=a||"";return b.series.pointArrayMap.reduce(function(c, -a){c+=c.length?", ":"";var r=d(b,C(b[a],b.options[a]));return c+(a+": "+e+r+k)},"")}function w(b){var c=b.series,a=c.chart.options.accessibility.point||{},e=c.tooltipOptions||{},k=a.valuePrefix||e.valuePrefix||"";a=a.valueSuffix||e.valueSuffix||"";e=d(b,b["undefined"!==typeof b.value?"value":"y"]);return b.isNull?c.chart.langFormat("accessibility.series.nullPointValue",{point:b}):c.pointArrayMap?v(b,k,a):k+e+a}function u(b){var c=b.series,a=c.chart,d=a.options.accessibility.point.valueDescriptionFormat, -e=(c=C(c.xAxis&&c.xAxis.options.accessibility&&c.xAxis.options.accessibility.enabled,!a.angular))?t(b):"";b={point:b,index:G(b.index)?b.index+1:"",xDescription:e,value:w(b),separator:c?", ":""};return N(d,b,a)}function A(b){var c=b.series,a=c.chart,d=u(b),e=b.options&&b.options.accessibility&&b.options.accessibility.description;e=e?" "+e:"";c=1<a.series.length&&c.name?" "+c.name+".":"";a=b.series.chart;var k=z(b),r={point:b,annotations:k};a=k.length?a.langFormat("accessibility.series.pointAnnotationsDescription", -r):"";b.accessibility=b.accessibility||{};b.accessibility.valueDescription=d;return d+e+c+(a?" "+a:"")}function p(b){var c=q(b),a=e(b);(c||a)&&b.points.forEach(function(b){var a;if(!(a=b.graphic&&b.graphic.element)&&(a=b.series&&b.series.is("sunburst"),a=b.isNull&&!a)){var d=b.series,e=g(b);d=(a=e&&e.graphic)?a.parentGroup:d.graph||d.group;e=e?{x:C(b.plotX,e.plotX,0),y:C(b.plotY,e.plotY,0)}:{x:C(b.plotX,0),y:C(b.plotY,0)};e=b.series.chart.renderer.rect(e.x,e.y,1,1);e.attr({"class":"highcharts-a11y-dummy-point", -fill:"none",opacity:0,"fill-opacity":0,"stroke-opacity":0});d&&d.element?(b.graphic=e,b.hasDummyGraphic=!0,e.add(d),d.element.insertBefore(e.element,a?a.element:null),a=e.element):a=void 0}a&&(a.setAttribute("tabindex","-1"),a.style.outline="0",c?(e=b.series,d=e.chart.options.accessibility.point||{},e=e.options.accessibility||{},b=B(I(e.pointDescriptionFormatter&&e.pointDescriptionFormatter(b)||d.descriptionFormatter&&d.descriptionFormatter(b)||A(b))),a.setAttribute("role","img"),a.setAttribute("aria-label", -b)):a.setAttribute("aria-hidden",!0))})}function y(a){var d=a.chart,e=d.types||[],k=b(a),r=function(b){return d[b]&&1<d[b].length&&a[b]},g=c(a,"xAxis"),h=c(a,"yAxis"),f={name:a.name||"",ix:a.index+1,numSeries:d.series&&d.series.length,numPoints:a.points&&a.points.length,series:a};e=1<e.length?"Combination":"";return(d.langFormat("accessibility.series.summary."+a.type+e,f)||d.langFormat("accessibility.series.summary.default"+e,f))+(k?" "+k:"")+(r("yAxis")?" "+h:"")+(r("xAxis")?" "+g:"")}var z=a.getPointAnnotationTexts, -x=f.getAxisDescription,r=f.getSeriesFirstPointElement,J=f.getSeriesA11yElement,F=f.unhideChartElementFromAT,B=l.escapeStringForHTML,E=l.reverseChildNodes,I=l.stripHTMLTagsFromString,K=n.find,N=n.format,L=n.isNumber,M=n.numberFormat,C=n.pick,G=n.defined;return{describeSeries:function(b){var c=b.chart,a=r(b),d=J(b),e=c.is3d&&c.is3d();if(d){d.lastChild!==a||e||E(d);p(b);F(c,d);e=b.chart;c=e.options.chart||{};a=1<e.series.length;e=e.options.accessibility.series.describeSingleSeries;var k=(b.options.accessibility|| -{}).exposeAsGroupOnly;c.options3d&&c.options3d.enabled&&a||!(a||e||k||h(b))?d.setAttribute("aria-label",""):(c=b.chart.options.accessibility,a=c.landmarkVerbosity,(b.options.accessibility||{}).exposeAsGroupOnly?d.setAttribute("role","img"):"all"===a&&d.setAttribute("role","region"),d.setAttribute("tabindex","-1"),d.style.outline="0",d.setAttribute("aria-label",B(I(c.series.descriptionFormatter&&c.series.descriptionFormatter(b)||y(b)))))}},defaultPointDescriptionFormatter:A,defaultSeriesDescriptionFormatter:y, -getPointA11yTimeDescription:k,getPointXDescription:t,getPointValue:w,getPointValueDescription:u}});p(a,"Accessibility/Utils/Announcer.js",[a["Core/Globals.js"],a["Accessibility/Utils/DOMElementProvider.js"],a["Accessibility/Utils/HTMLUtilities.js"]],function(a,f,l){var m=l.visuallyHideElement;l=function(){function a(a,h){this.chart=a;this.domElementProvider=new f;this.announceRegion=this.addAnnounceRegion(h)}a.prototype.destroy=function(){this.domElementProvider.destroyCreatedElements()};a.prototype.announce= -function(a){var g=this;this.announceRegion.innerHTML=a;this.clearAnnouncementRegionTimer&&clearTimeout(this.clearAnnouncementRegionTimer);this.clearAnnouncementRegionTimer=setTimeout(function(){g.announceRegion.innerHTML="";delete g.clearAnnouncementRegionTimer},1E3)};a.prototype.addAnnounceRegion=function(a){var g=this.chart.renderTo,f=this.domElementProvider.createElement("div");f.setAttribute("aria-hidden",!1);f.setAttribute("aria-live",a);m(f);g.insertBefore(f,g.firstChild);return f};return a}(); -return a.Announcer=l});p(a,"Accessibility/Components/SeriesComponent/NewDataAnnouncer.js",[a["Core/Globals.js"],a["Core/Series/CartesianSeries.js"],a["Core/Utilities.js"],a["Accessibility/Utils/ChartUtilities.js"],a["Accessibility/Components/SeriesComponent/SeriesDescriber.js"],a["Accessibility/Utils/Announcer.js"],a["Accessibility/Utils/EventProvider.js"]],function(a,f,l,m,n,g,h){function q(b){var c=b.series.data.filter(function(c){return b.x===c.x&&b.y===c.y});return 1===c.length?c[0]:b}function e(b, -c){var a=(b||[]).concat(c||[]).reduce(function(b,c){b[c.name+c.index]=c;return b},{});return Object.keys(a).map(function(b){return a[b]})}var d=l.extend,b=l.defined,c=m.getChartTitle,k=n.defaultPointDescriptionFormatter,t=n.defaultSeriesDescriptionFormatter;l=function(b){this.chart=b};d(l.prototype,{init:function(){var b=this.chart,c=b.options.accessibility.announceNewData.interruptUser?"assertive":"polite";this.lastAnnouncementTime=0;this.dirty={allSeries:{}};this.eventProvider=new h;this.announcer= -new g(b,c);this.addEventListeners()},destroy:function(){this.eventProvider.removeAddedEvents();this.announcer.destroy()},addEventListeners:function(){var b=this,c=this.chart,a=this.eventProvider;a.addEvent(c,"afterDrilldown",function(){b.lastAnnouncementTime=0});a.addEvent(f,"updatedData",function(){b.onSeriesUpdatedData(this)});a.addEvent(c,"afterAddSeries",function(c){b.onSeriesAdded(c.series)});a.addEvent(f,"addPoint",function(c){b.onPointAdded(c.point)});a.addEvent(c,"redraw",function(){b.announceDirtyData()})}, -onSeriesUpdatedData:function(b){var c=this.chart;b.chart===c&&c.options.accessibility.announceNewData.enabled&&(this.dirty.hasDirty=!0,this.dirty.allSeries[b.name+b.index]=b)},onSeriesAdded:function(c){this.chart.options.accessibility.announceNewData.enabled&&(this.dirty.hasDirty=!0,this.dirty.allSeries[c.name+c.index]=c,this.dirty.newSeries=b(this.dirty.newSeries)?void 0:c)},onPointAdded:function(c){var a=c.series.chart;this.chart===a&&a.options.accessibility.announceNewData.enabled&&(this.dirty.newPoint= -b(this.dirty.newPoint)?void 0:c)},announceDirtyData:function(){var b=this;if(this.chart.options.accessibility.announceNewData&&this.dirty.hasDirty){var c=this.dirty.newPoint;c&&(c=q(c));this.queueAnnouncement(Object.keys(this.dirty.allSeries).map(function(c){return b.dirty.allSeries[c]}),this.dirty.newSeries,c);this.dirty={allSeries:{}}}},queueAnnouncement:function(b,c,a){var d=this,k=this.chart.options.accessibility.announceNewData;if(k.enabled){var g=+new Date;k=Math.max(0,k.minAnnounceInterval- -(g-this.lastAnnouncementTime));b=e(this.queuedAnnouncement&&this.queuedAnnouncement.series,b);if(c=this.buildAnnouncementMessage(b,c,a))this.queuedAnnouncement&&clearTimeout(this.queuedAnnouncementTimer),this.queuedAnnouncement={time:g,message:c,series:b},this.queuedAnnouncementTimer=setTimeout(function(){d&&d.announcer&&(d.lastAnnouncementTime=+new Date,d.announcer.announce(d.queuedAnnouncement.message),delete d.queuedAnnouncement,delete d.queuedAnnouncementTimer)},k)}},buildAnnouncementMessage:function(b, -d,e){var g=this.chart,h=g.options.accessibility.announceNewData;if(h.announcementFormatter&&(b=h.announcementFormatter(b,d,e),!1!==b))return b.length?b:null;b=a.charts&&1<a.charts.length?"Multiple":"Single";b=d?"newSeriesAnnounce"+b:e?"newPointAnnounce"+b:"newDataAnnounce";h=c(g);return g.langFormat("accessibility.announceNewData."+b,{chartTitle:h,seriesDesc:d?t(d):null,pointDesc:e?k(e):null,point:e,series:d})}});return l});p(a,"Accessibility/Components/SeriesComponent/ForcedMarkers.js",[a["Core/Series/CartesianSeries.js"], -a["Core/Utilities.js"]],function(a,f){function l(a){n(!0,a,{marker:{enabled:!0,states:{normal:{opacity:0}}}})}var m=f.addEvent,n=f.merge;return function(){m(a,"render",function(){var a=this.options,h=!1!==(this.options.accessibility&&this.options.accessibility.enabled);if(h=this.chart.options.accessibility.enabled&&h)h=this.chart.options.accessibility,h=this.points.length<h.series.pointDescriptionEnabledThreshold||!1===h.series.pointDescriptionEnabledThreshold;if(h){if(a.marker&&!1===a.marker.enabled&& -(this.a11yMarkersForced=!0,l(this.options)),this._hasPointMarkers&&this.points&&this.points.length)for(a=this.points.length;a--;){h=this.points[a];var f=h.options;delete h.hasForcedA11yMarker;f.marker&&(f.marker.enabled?(n(!0,f.marker,{states:{normal:{opacity:f.marker.states&&f.marker.states.normal&&f.marker.states.normal.opacity||1}}}),h.hasForcedA11yMarker=!1):(l(f),h.hasForcedA11yMarker=!0))}}else this.a11yMarkersForced&&(delete this.a11yMarkersForced,(a=this.resetA11yMarkerOptions)&&n(!0,this.options, -{marker:{enabled:a.enabled,states:{normal:{opacity:a.states&&a.states.normal&&a.states.normal.opacity}}}}))});m(a,"afterSetOptions",function(a){this.resetA11yMarkerOptions=n(a.options.marker||{},this.userOptions.marker||{})});m(a,"afterRender",function(){if(this.chart.styledMode){if(this.markerGroup)this.markerGroup[this.a11yMarkersForced?"addClass":"removeClass"]("highcharts-a11y-markers-hidden");this._hasPointMarkers&&this.points&&this.points.length&&this.points.forEach(function(a){a.graphic&&(a.graphic[a.hasForcedA11yMarker? -"addClass":"removeClass"]("highcharts-a11y-marker-hidden"),a.graphic[!1===a.hasForcedA11yMarker?"addClass":"removeClass"]("highcharts-a11y-marker-visible"))})}})}});p(a,"Accessibility/Components/SeriesComponent/SeriesComponent.js",[a["Core/Globals.js"],a["Core/Utilities.js"],a["Accessibility/AccessibilityComponent.js"],a["Accessibility/Components/SeriesComponent/SeriesKeyboardNavigation.js"],a["Accessibility/Components/SeriesComponent/NewDataAnnouncer.js"],a["Accessibility/Components/SeriesComponent/ForcedMarkers.js"], -a["Accessibility/Utils/ChartUtilities.js"],a["Accessibility/Components/SeriesComponent/SeriesDescriber.js"],a["Core/Tooltip.js"]],function(a,f,l,m,n,g,h,q,e){f=f.extend;var d=h.hideSeriesFromAT,b=q.describeSeries;a.SeriesAccessibilityDescriber=q;g();a=function(){};a.prototype=new l;f(a.prototype,{init:function(){this.newDataAnnouncer=new n(this.chart);this.newDataAnnouncer.init();this.keyboardNavigation=new m(this.chart,this.keyCodes);this.keyboardNavigation.init();this.hideTooltipFromATWhenShown(); -this.hideSeriesLabelsFromATWhenShown()},hideTooltipFromATWhenShown:function(){var b=this;this.addEvent(e,"refresh",function(){this.chart===b.chart&&this.label&&this.label.element&&this.label.element.setAttribute("aria-hidden",!0)})},hideSeriesLabelsFromATWhenShown:function(){this.addEvent(this.chart,"afterDrawSeriesLabels",function(){this.series.forEach(function(b){b.labelBySeries&&b.labelBySeries.attr("aria-hidden",!0)})})},onChartRender:function(){this.chart.series.forEach(function(c){!1!==(c.options.accessibility&& -c.options.accessibility.enabled)&&c.visible?b(c):d(c)})},getKeyboardNavigation:function(){return this.keyboardNavigation.getKeyboardNavigationHandler()},destroy:function(){this.newDataAnnouncer.destroy();this.keyboardNavigation.destroy()}});return a});p(a,"Accessibility/Components/ZoomComponent.js",[a["Accessibility/AccessibilityComponent.js"],a["Accessibility/Utils/ChartUtilities.js"],a["Core/Globals.js"],a["Accessibility/Utils/HTMLUtilities.js"],a["Accessibility/KeyboardNavigationHandler.js"],a["Core/Utilities.js"]], -function(a,f,l,m,n,g){var h=f.unhideChartElementFromAT;f=l.noop;var q=m.removeElement,e=m.setElAttrs;m=g.extend;var d=g.pick;l.Axis.prototype.panStep=function(b,c){var a=c||3;c=this.getExtremes();var d=(c.max-c.min)/a*b;a=c.max+d;d=c.min+d;var e=a-d;0>b&&d<c.dataMin?(d=c.dataMin,a=d+e):0<b&&a>c.dataMax&&(a=c.dataMax,d=a-e);this.setExtremes(d,a)};f.prototype=new a;m(f.prototype,{init:function(){var b=this,c=this.chart;["afterShowResetZoom","afterDrilldown","drillupall"].forEach(function(a){b.addEvent(c, -a,function(){b.updateProxyOverlays()})})},onChartUpdate:function(){var b=this.chart,c=this;b.mapNavButtons&&b.mapNavButtons.forEach(function(a,d){h(b,a.element);c.setMapNavButtonAttrs(a.element,"accessibility.zoom.mapZoom"+(d?"Out":"In"))})},setMapNavButtonAttrs:function(b,c){var a=this.chart;c=a.langFormat(c,{chart:a});e(b,{tabindex:-1,role:"button","aria-label":c})},onChartRender:function(){this.updateProxyOverlays()},updateProxyOverlays:function(){var b=this.chart;q(this.drillUpProxyGroup);q(this.resetZoomProxyGroup); -b.resetZoomButton&&this.recreateProxyButtonAndGroup(b.resetZoomButton,"resetZoomProxyButton","resetZoomProxyGroup",b.langFormat("accessibility.zoom.resetZoomButton",{chart:b}));b.drillUpButton&&this.recreateProxyButtonAndGroup(b.drillUpButton,"drillUpProxyButton","drillUpProxyGroup",b.langFormat("accessibility.drillUpButton",{chart:b,buttonText:b.getDrilldownBackText()}))},recreateProxyButtonAndGroup:function(b,c,a,d){q(this[a]);this[a]=this.addProxyGroup();this[c]=this.createProxyButton(b,this[a], -{"aria-label":d,tabindex:-1})},getMapZoomNavigation:function(){var b=this.keyCodes,a=this.chart,d=this;return new n(a,{keyCodeMap:[[[b.up,b.down,b.left,b.right],function(b){return d.onMapKbdArrow(this,b)}],[[b.tab],function(b,a){return d.onMapKbdTab(this,a)}],[[b.space,b.enter],function(){return d.onMapKbdClick(this)}]],validate:function(){return!!(a.mapZoom&&a.mapNavButtons&&a.mapNavButtons.length)},init:function(b){return d.onMapNavInit(b)}})},onMapKbdArrow:function(b,a){var c=this.keyCodes;this.chart[a=== -c.up||a===c.down?"yAxis":"xAxis"][0].panStep(a===c.left||a===c.up?-1:1);return b.response.success},onMapKbdTab:function(b,a){var c=this.chart;b=b.response;var d=(a=a.shiftKey)&&!this.focusedMapNavButtonIx||!a&&this.focusedMapNavButtonIx;c.mapNavButtons[this.focusedMapNavButtonIx].setState(0);if(d)return c.mapZoom(),b[a?"prev":"next"];this.focusedMapNavButtonIx+=a?-1:1;a=c.mapNavButtons[this.focusedMapNavButtonIx];c.setFocusToElement(a.box,a.element);a.setState(2);return b.success},onMapKbdClick:function(b){this.fakeClickEvent(this.chart.mapNavButtons[this.focusedMapNavButtonIx].element); -return b.response.success},onMapNavInit:function(b){var a=this.chart,d=a.mapNavButtons[0],e=a.mapNavButtons[1];d=0<b?d:e;a.setFocusToElement(d.box,d.element);d.setState(2);this.focusedMapNavButtonIx=0<b?0:1},simpleButtonNavigation:function(b,a,e){var c=this.keyCodes,k=this,g=this.chart;return new n(g,{keyCodeMap:[[[c.tab,c.up,c.down,c.left,c.right],function(b,a){return this.response[b===c.tab&&a.shiftKey||b===c.left||b===c.up?"prev":"next"]}],[[c.space,c.enter],function(){var b=e(this,g);return d(b, -this.response.success)}]],validate:function(){return g[b]&&g[b].box&&k[a]},init:function(){g.setFocusToElement(g[b].box,k[a])}})},getKeyboardNavigation:function(){return[this.simpleButtonNavigation("resetZoomButton","resetZoomProxyButton",function(b,a){a.zoomOut()}),this.simpleButtonNavigation("drillUpButton","drillUpProxyButton",function(b,a){a.drillUp();return b.response.prev}),this.getMapZoomNavigation()]}});return f});p(a,"Accessibility/Components/RangeSelectorComponent.js",[a["Accessibility/AccessibilityComponent.js"], -a["Accessibility/Utils/ChartUtilities.js"],a["Core/Globals.js"],a["Accessibility/Utils/HTMLUtilities.js"],a["Accessibility/KeyboardNavigationHandler.js"],a["Core/Utilities.js"]],function(a,f,l,m,n,g){var h=f.unhideChartElementFromAT,q=m.setElAttrs;f=g.extend;l.Chart.prototype.highlightRangeSelectorButton=function(a){var d=this.rangeSelector.buttons,b=this.highlightedRangeSelectorItemIx;"undefined"!==typeof b&&d[b]&&d[b].setState(this.oldRangeSelectorItemState||0);this.highlightedRangeSelectorItemIx= -a;return d[a]?(this.setFocusToElement(d[a].box,d[a].element),this.oldRangeSelectorItemState=d[a].state,d[a].setState(2),!0):!1};l=function(){};l.prototype=new a;f(l.prototype,{onChartUpdate:function(){var a=this.chart,d=this,b=a.rangeSelector;b&&(b.buttons&&b.buttons.length&&b.buttons.forEach(function(b){h(a,b.element);d.setRangeButtonAttrs(b)}),b.maxInput&&b.minInput&&["minInput","maxInput"].forEach(function(c,e){if(c=b[c])h(a,c),d.setRangeInputAttrs(c,"accessibility.rangeSelector."+(e?"max":"min")+ -"InputLabel")}))},setRangeButtonAttrs:function(a){var d=this.chart;d=d.langFormat("accessibility.rangeSelector.buttonText",{chart:d,buttonText:a.text&&a.text.textStr});q(a.element,{tabindex:-1,role:"button","aria-label":d})},setRangeInputAttrs:function(a,d){var b=this.chart;q(a,{tabindex:-1,role:"textbox","aria-label":b.langFormat(d,{chart:b})})},getRangeSelectorButtonNavigation:function(){var a=this.chart,d=this.keyCodes,b=this;return new n(a,{keyCodeMap:[[[d.left,d.right,d.up,d.down],function(a){return b.onButtonNavKbdArrowKey(this, -a)}],[[d.enter,d.space],function(){return b.onButtonNavKbdClick(this)}]],validate:function(){return a.rangeSelector&&a.rangeSelector.buttons&&a.rangeSelector.buttons.length},init:function(b){var c=a.rangeSelector.buttons.length-1;a.highlightRangeSelectorButton(0<b?0:c)}})},onButtonNavKbdArrowKey:function(a,d){var b=a.response,c=this.keyCodes,e=this.chart,g=e.options.accessibility.keyboardNavigation.wrapAround;d=d===c.left||d===c.up?-1:1;return e.highlightRangeSelectorButton(e.highlightedRangeSelectorItemIx+ -d)?b.success:g?(a.init(d),b.success):b[0<d?"next":"prev"]},onButtonNavKbdClick:function(a){a=a.response;var d=this.chart;3!==d.oldRangeSelectorItemState&&this.fakeClickEvent(d.rangeSelector.buttons[d.highlightedRangeSelectorItemIx].element);return a.success},getRangeSelectorInputNavigation:function(){var a=this.chart,d=this.keyCodes,b=this;return new n(a,{keyCodeMap:[[[d.tab,d.up,d.down],function(a,e){return b.onInputKbdMove(this,a===d.tab&&e.shiftKey||a===d.up?-1:1)}]],validate:function(){return a.rangeSelector&& -a.rangeSelector.inputGroup&&"hidden"!==a.rangeSelector.inputGroup.element.getAttribute("visibility")&&!1!==a.options.rangeSelector.inputEnabled&&a.rangeSelector.minInput&&a.rangeSelector.maxInput},init:function(a){b.onInputNavInit(a)},terminate:function(){b.onInputNavTerminate()}})},onInputKbdMove:function(a,d){var b=this.chart;a=a.response;var c=b.highlightedInputRangeIx+=d;if(1<c||0>c)return a[0<d?"next":"prev"];b.rangeSelector[c?"maxInput":"minInput"].focus();return a.success},onInputNavInit:function(a){var d= -this.chart;a=0<a?0:1;d.highlightedInputRangeIx=a;d.rangeSelector[a?"maxInput":"minInput"].focus()},onInputNavTerminate:function(){var a=this.chart.rangeSelector||{};a.maxInput&&a.hideInput("max");a.minInput&&a.hideInput("min")},getKeyboardNavigation:function(){return[this.getRangeSelectorButtonNavigation(),this.getRangeSelectorInputNavigation()]}});return l});p(a,"Accessibility/Components/InfoRegionsComponent.js",[a["Core/Globals.js"],a["Core/Utilities.js"],a["Accessibility/AccessibilityComponent.js"], -a["Accessibility/Utils/Announcer.js"],a["Accessibility/Components/AnnotationsA11y.js"],a["Accessibility/Utils/ChartUtilities.js"],a["Accessibility/Utils/HTMLUtilities.js"]],function(a,f,l,m,n,g,h){function q(b){return b.replace(/<(h[1-7]|p|div|ul|ol|li)>/g,"<$1>").replace(/</(h[1-7]|p|div|ul|ol|li|a|button)>/g,"</$1>").replace(/<(div|a|button) id="([a-zA-Z\-0-9#]*?)">/g,'<$1 id="$2">')}var e=a.doc,d=f.extend,b=f.format,c=f.pick,k=n.getAnnotationsInfoHTML,t=g.unhideChartElementFromAT, -v=g.getChartTitle,w=g.getAxisDescription,p=h.addClass,u=h.setElAttrs,D=h.escapeStringForHTML,y=h.stripHTMLTagsFromString,z=h.getElement,x=h.visuallyHideElement;a.Chart.prototype.getTypeDescription=function(b){var a=b[0],c=this.series&&this.series[0]||{};c={numSeries:this.series.length,numPoints:c.points&&c.points.length,chart:this,mapTitle:c.mapTitle};if(!a)return this.langFormat("accessibility.chartTypes.emptyChart",c);if("map"===a)return c.mapTitle?this.langFormat("accessibility.chartTypes.mapTypeDescription", -c):this.langFormat("accessibility.chartTypes.unknownMap",c);if(1<this.types.length)return this.langFormat("accessibility.chartTypes.combinationChart",c);b=b[0];a=this.langFormat("accessibility.seriesTypeDescriptions."+b,c);var d=this.series&&2>this.series.length?"Single":"Multiple";return(this.langFormat("accessibility.chartTypes."+b+d,c)||this.langFormat("accessibility.chartTypes.default"+d,c))+(a?" "+a:"")};f=function(){};f.prototype=new l;d(f.prototype,{init:function(){var b=this.chart,a=this; -this.initRegionsDefinitions();this.addEvent(b,"afterGetTable",function(b){a.onDataTableCreated(b)});this.addEvent(b,"afterViewData",function(b){a.dataTableDiv=b;setTimeout(function(){a.focusDataTable()},300)});this.announcer=new m(b,"assertive")},initRegionsDefinitions:function(){var b=this;this.screenReaderSections={before:{element:null,buildContent:function(a){var c=a.options.accessibility.screenReaderSection.beforeChartFormatter;return c?c(a):b.defaultBeforeChartFormatter(a)},insertIntoDOM:function(b, -a){a.renderTo.insertBefore(b,a.renderTo.firstChild)},afterInserted:function(){"undefined"!==typeof b.sonifyButtonId&&b.initSonifyButton(b.sonifyButtonId);"undefined"!==typeof b.dataTableButtonId&&b.initDataTableButton(b.dataTableButtonId)}},after:{element:null,buildContent:function(a){var c=a.options.accessibility.screenReaderSection.afterChartFormatter;return c?c(a):b.defaultAfterChartFormatter()},insertIntoDOM:function(b,a){a.renderTo.insertBefore(b,a.container.nextSibling)}}}},onChartRender:function(){var b= -this;this.linkedDescriptionElement=this.getLinkedDescriptionElement();this.setLinkedDescriptionAttrs();Object.keys(this.screenReaderSections).forEach(function(a){b.updateScreenReaderSection(a)})},getLinkedDescriptionElement:function(){var a=this.chart.options.accessibility.linkedDescription;if(a){if("string"!==typeof a)return a;a=b(a,this.chart);a=e.querySelectorAll(a);if(1===a.length)return a[0]}},setLinkedDescriptionAttrs:function(){var b=this.linkedDescriptionElement;b&&(b.setAttribute("aria-hidden", -"true"),p(b,"highcharts-linked-description"))},updateScreenReaderSection:function(b){var a=this.chart,c=this.screenReaderSections[b],d=c.buildContent(a),e=c.element=c.element||this.createElement("div"),g=e.firstChild||this.createElement("div");this.setScreenReaderSectionAttribs(e,b);g.innerHTML=d;e.appendChild(g);c.insertIntoDOM(e,a);x(g);t(a,g);c.afterInserted&&c.afterInserted()},setScreenReaderSectionAttribs:function(b,a){var c=this.chart,d=c.langFormat("accessibility.screenReaderSection."+a+"RegionLabel", -{chart:c});u(b,{id:"highcharts-screen-reader-region-"+a+"-"+c.index,"aria-label":d});b.style.position="relative";"all"===c.options.accessibility.landmarkVerbosity&&d&&b.setAttribute("role","region")},defaultBeforeChartFormatter:function(){var b,c=this.chart,d=c.options.accessibility.screenReaderSection.beforeChartFormat,e=this.getAxesDescription(),g=c.sonify&&(null===(b=c.options.sonification)||void 0===b?void 0:b.enabled);b="highcharts-a11y-sonify-data-btn-"+c.index;var h="hc-linkto-highcharts-data-table-"+ -c.index,f=k(c),t=c.langFormat("accessibility.screenReaderSection.annotations.heading",{chart:c});e={chartTitle:v(c),typeDescription:this.getTypeDescriptionText(),chartSubtitle:this.getSubtitleText(),chartLongdesc:this.getLongdescText(),xAxisDescription:e.xAxis,yAxisDescription:e.yAxis,playAsSoundButton:g?this.getSonifyButtonText(b):"",viewTableButton:c.getCSV?this.getDataTableButtonText(h):"",annotationsTitle:f?t:"",annotationsList:f};c=a.i18nFormat(d,e,c);this.dataTableButtonId=h;this.sonifyButtonId= -b;return q(D(c)).replace(/<(\w+)[^>]*?>\s*<\/\1>/g,"")},defaultAfterChartFormatter:function(){var b=this.chart,c=b.options.accessibility.screenReaderSection.afterChartFormat,d={endOfChartMarker:this.getEndOfChartMarkerText()};b=a.i18nFormat(c,d,b);return q(D(b)).replace(/<(\w+)[^>]*?>\s*<\/\1>/g,"")},getLinkedDescription:function(){var b=this.linkedDescriptionElement;return y(b&&b.innerHTML||"")},getLongdescText:function(){var b=this.chart.options,a=b.caption;a=a&&a.text;var c=this.getLinkedDescription(); -return b.accessibility.description||c||a||""},getTypeDescriptionText:function(){var b=this.chart;return b.types?b.options.accessibility.typeDescription||b.getTypeDescription(b.types):""},getDataTableButtonText:function(b){var a=this.chart;a=a.langFormat("accessibility.table.viewAsDataTableButtonText",{chart:a,chartTitle:v(a)});return'<button id="'+b+'">'+a+"</button>"},getSonifyButtonText:function(b){var a,c=this.chart;if(!1===(null===(a=c.options.sonification)||void 0===a?void 0:a.enabled))return""; -a=c.langFormat("accessibility.sonification.playAsSoundButtonText",{chart:c,chartTitle:v(c)});return'<button id="'+b+'">'+a+"</button>"},getSubtitleText:function(){var b=this.chart.options.subtitle;return y(b&&b.text||"")},getEndOfChartMarkerText:function(){var b=this.chart,a=b.langFormat("accessibility.screenReaderSection.endOfChartMarker",{chart:b});return'<div id="highcharts-end-of-chart-marker-'+b.index+'">'+a+"</div>"},onDataTableCreated:function(b){var a=this.chart;a.options.accessibility.enabled&& -(this.viewDataTableButton&&this.viewDataTableButton.setAttribute("aria-expanded","true"),b.html=b.html.replace("<table ",'<table tabindex="-1" summary="'+a.langFormat("accessibility.table.tableSummary",{chart:a})+'"'))},focusDataTable:function(){var b=this.dataTableDiv;(b=b&&b.getElementsByTagName("table")[0])&&b.focus&&b.focus()},initSonifyButton:function(b){var a=this,c=this.sonifyButton=z(b),d=this.chart,e=function(b){null===c||void 0===c?void 0:c.setAttribute("aria-hidden","true");null===c||void 0=== -c?void 0:c.setAttribute("aria-label","");b.preventDefault();b.stopPropagation();b=d.langFormat("accessibility.sonification.playAsSoundClickAnnouncement",{chart:d});a.announcer.announce(b);setTimeout(function(){null===c||void 0===c?void 0:c.removeAttribute("aria-hidden");null===c||void 0===c?void 0:c.removeAttribute("aria-label");d.sonify&&d.sonify()},1E3)};c&&d&&(u(c,{tabindex:"-1"}),c.onclick=function(b){var a;((null===(a=d.options.accessibility)||void 0===a?void 0:a.screenReaderSection.onPlayAsSoundClick)|| -e).call(this,b,d)})},initDataTableButton:function(b){var a=this.viewDataTableButton=z(b),c=this.chart;b=b.replace("hc-linkto-","");a&&(u(a,{tabindex:"-1","aria-expanded":!!z(b)}),a.onclick=c.options.accessibility.screenReaderSection.onViewDataTableClick||function(){c.viewData()})},getAxesDescription:function(){var b=this.chart,a=function(a,d){a=b[a];return 1<a.length||a[0]&&c(a[0].options.accessibility&&a[0].options.accessibility.enabled,d)},d=!!b.types&&0>b.types.indexOf("map"),e=!!b.hasCartesianSeries, -g=a("xAxis",!b.angular&&e&&d);a=a("yAxis",e&&d);d={};g&&(d.xAxis=this.getAxisDescriptionText("xAxis"));a&&(d.yAxis=this.getAxisDescriptionText("yAxis"));return d},getAxisDescriptionText:function(b){var a=this,c=this.chart,d=c[b];return c.langFormat("accessibility.axis."+b+"Description"+(1<d.length?"Plural":"Singular"),{chart:c,names:d.map(function(b){return w(b)}),ranges:d.map(function(b){return a.getAxisRangeDescription(b)}),numAxes:d.length})},getAxisRangeDescription:function(b){var a=b.options|| -{};return a.accessibility&&"undefined"!==typeof a.accessibility.rangeDescription?a.accessibility.rangeDescription:b.categories?this.getCategoryAxisRangeDesc(b):!b.dateTime||0!==b.min&&0!==b.dataMin?this.getAxisFromToDescription(b):this.getAxisTimeLengthDesc(b)},getCategoryAxisRangeDesc:function(b){var a=this.chart;return b.dataMax&&b.dataMin?a.langFormat("accessibility.axis.rangeCategories",{chart:a,axis:b,numCategories:b.dataMax-b.dataMin+1}):""},getAxisTimeLengthDesc:function(b){var a=this.chart, -c={},d="Seconds";c.Seconds=((b.max||0)-(b.min||0))/1E3;c.Minutes=c.Seconds/60;c.Hours=c.Minutes/60;c.Days=c.Hours/24;["Minutes","Hours","Days"].forEach(function(b){2<c[b]&&(d=b)});var e=c[d].toFixed("Seconds"!==d&&"Minutes"!==d?1:0);return a.langFormat("accessibility.axis.timeRange"+d,{chart:a,axis:b,range:e.replace(".0","")})},getAxisFromToDescription:function(b){var a=this.chart,c=a.options.accessibility.screenReaderSection.axisRangeDateFormat,d=function(d){return b.dateTime?a.time.dateFormat(c, -b[d]):b[d]};return a.langFormat("accessibility.axis.rangeFromTo",{chart:a,axis:b,rangeFrom:d("min"),rangeTo:d("max")})},destroy:function(){var b;null===(b=this.announcer)||void 0===b?void 0:b.destroy()}});return f});p(a,"Accessibility/Components/ContainerComponent.js",[a["Accessibility/AccessibilityComponent.js"],a["Accessibility/Utils/ChartUtilities.js"],a["Core/Globals.js"],a["Accessibility/Utils/HTMLUtilities.js"],a["Core/Utilities.js"]],function(a,f,l,m,n){var g=f.unhideChartElementFromAT,h=f.getChartTitle, -q=l.doc,e=m.stripHTMLTagsFromString;f=n.extend;l=function(){};l.prototype=new a;f(l.prototype,{onChartUpdate:function(){this.handleSVGTitleElement();this.setSVGContainerLabel();this.setGraphicContainerAttrs();this.setRenderToAttrs();this.makeCreditsAccessible()},handleSVGTitleElement:function(){var a=this.chart,b="highcharts-title-"+a.index,c=e(a.langFormat("accessibility.svgContainerTitle",{chartTitle:h(a)}));if(c.length){var g=this.svgTitleElement=this.svgTitleElement||q.createElementNS("http://www.w3.org/2000/svg", -"title");g.textContent=c;g.id=b;a.renderTo.insertBefore(g,a.renderTo.firstChild)}},setSVGContainerLabel:function(){var a=this.chart,b=e(a.langFormat("accessibility.svgContainerLabel",{chartTitle:h(a)}));a.renderer.box&&b.length&&a.renderer.box.setAttribute("aria-label",b)},setGraphicContainerAttrs:function(){var a=this.chart,b=a.langFormat("accessibility.graphicContainerLabel",{chartTitle:h(a)});b.length&&a.container.setAttribute("aria-label",b)},setRenderToAttrs:function(){var a=this.chart;"disabled"!== -a.options.accessibility.landmarkVerbosity?a.renderTo.setAttribute("role","region"):a.renderTo.removeAttribute("role");a.renderTo.setAttribute("aria-label",a.langFormat("accessibility.chartContainerLabel",{title:h(a),chart:a}))},makeCreditsAccessible:function(){var a=this.chart,b=a.credits;b&&(b.textStr&&b.element.setAttribute("aria-label",e(a.langFormat("accessibility.credits",{creditsStr:b.textStr}))),g(a,b.element))},destroy:function(){this.chart.renderTo.setAttribute("aria-hidden",!0)}});return l}); -p(a,"Accessibility/HighContrastMode.js",[a["Core/Globals.js"]],function(a){var f=a.isMS,l=a.win,m=l.document;return{isHighContrastModeActive:function(){var a=/(Edg)/.test(l.navigator.userAgent);if(l.matchMedia&&a)return l.matchMedia("(-ms-high-contrast: active)").matches;if(f&&l.getComputedStyle){a=m.createElement("div");a.style.backgroundImage="url()";m.body.appendChild(a);var g=(a.currentStyle||l.getComputedStyle(a)).backgroundImage; -m.body.removeChild(a);return"none"===g}return!1},setHighContrastTheme:function(a){a.highContrastModeActive=!0;var g=a.options.accessibility.highContrastTheme;a.update(g,!1);a.series.forEach(function(a){var f=g.plotOptions[a.type]||{};a.update({color:f.color||"windowText",colors:[f.color||"windowText"],borderColor:f.borderColor||"window"});a.points.forEach(function(a){a.options&&a.options.color&&a.update({color:f.color||"windowText",borderColor:f.borderColor||"window"},!1)})});a.redraw()}}});p(a,"Accessibility/HighContrastTheme.js", -[],function(){return{chart:{backgroundColor:"window"},title:{style:{color:"windowText"}},subtitle:{style:{color:"windowText"}},colorAxis:{minColor:"windowText",maxColor:"windowText",stops:[]},colors:["windowText"],xAxis:{gridLineColor:"windowText",labels:{style:{color:"windowText"}},lineColor:"windowText",minorGridLineColor:"windowText",tickColor:"windowText",title:{style:{color:"windowText"}}},yAxis:{gridLineColor:"windowText",labels:{style:{color:"windowText"}},lineColor:"windowText",minorGridLineColor:"windowText", -tickColor:"windowText",title:{style:{color:"windowText"}}},tooltip:{backgroundColor:"window",borderColor:"windowText",style:{color:"windowText"}},plotOptions:{series:{lineColor:"windowText",fillColor:"window",borderColor:"windowText",edgeColor:"windowText",borderWidth:1,dataLabels:{connectorColor:"windowText",color:"windowText",style:{color:"windowText",textOutline:"none"}},marker:{lineColor:"windowText",fillColor:"windowText"}},pie:{color:"window",colors:["window"],borderColor:"windowText",borderWidth:1}, -boxplot:{fillColor:"window"},candlestick:{lineColor:"windowText",fillColor:"window"},errorbar:{fillColor:"window"}},legend:{backgroundColor:"window",itemStyle:{color:"windowText"},itemHoverStyle:{color:"windowText"},itemHiddenStyle:{color:"#555"},title:{style:{color:"windowText"}}},credits:{style:{color:"windowText"}},labels:{style:{color:"windowText"}},drilldown:{activeAxisLabelStyle:{color:"windowText"},activeDataLabelStyle:{color:"windowText"}},navigation:{buttonOptions:{symbolStroke:"windowText", -theme:{fill:"window"}}},rangeSelector:{buttonTheme:{fill:"window",stroke:"windowText",style:{color:"windowText"},states:{hover:{fill:"window",stroke:"windowText",style:{color:"windowText"}},select:{fill:"#444",stroke:"windowText",style:{color:"windowText"}}}},inputBoxBorderColor:"windowText",inputStyle:{backgroundColor:"window",color:"windowText"},labelStyle:{color:"windowText"}},navigator:{handles:{backgroundColor:"window",borderColor:"windowText"},outlineColor:"windowText",maskFill:"transparent", -series:{color:"windowText",lineColor:"windowText"},xAxis:{gridLineColor:"windowText"}},scrollbar:{barBackgroundColor:"#444",barBorderColor:"windowText",buttonArrowColor:"windowText",buttonBackgroundColor:"window",buttonBorderColor:"windowText",rifleColor:"windowText",trackBackgroundColor:"window",trackBorderColor:"windowText"}}});p(a,"Accessibility/Options/Options.js",[],function(){return{accessibility:{enabled:!0,screenReaderSection:{beforeChartFormat:"<h5>{chartTitle}</h5><div>{typeDescription}</div><div>{chartSubtitle}</div><div>{chartLongdesc}</div><div>{playAsSoundButton}</div><div>{viewTableButton}</div><div>{xAxisDescription}</div><div>{yAxisDescription}</div><div>{annotationsTitle}{annotationsList}</div>", -afterChartFormat:"{endOfChartMarker}",axisRangeDateFormat:"%Y-%m-%d %H:%M:%S"},series:{describeSingleSeries:!1,pointDescriptionEnabledThreshold:200},point:{valueDescriptionFormat:"{index}. {xDescription}{separator}{value}."},landmarkVerbosity:"all",linkedDescription:'*[data-highcharts-chart="{index}"] + .highcharts-description',keyboardNavigation:{enabled:!0,focusBorder:{enabled:!0,hideBrowserFocusOutline:!0,style:{color:"#335cad",lineWidth:2,borderRadius:3},margin:2},order:["series","zoom","rangeSelector", -"legend","chartMenu"],wrapAround:!0,seriesNavigation:{skipNullPoints:!0,pointNavigationEnabledThreshold:!1}},announceNewData:{enabled:!1,minAnnounceInterval:5E3,interruptUser:!1}},legend:{accessibility:{enabled:!0,keyboardNavigation:{enabled:!0}}},exporting:{accessibility:{enabled:!0}}}});p(a,"Accessibility/Options/LangOptions.js",[],function(){return{accessibility:{defaultChartTitle:"Chart",chartContainerLabel:"{title}. Highcharts interactive chart.",svgContainerLabel:"Interactive chart",drillUpButton:"{buttonText}", -credits:"Chart credits: {creditsStr}",thousandsSep:",",svgContainerTitle:"",graphicContainerLabel:"",screenReaderSection:{beforeRegionLabel:"Chart screen reader information.",afterRegionLabel:"",annotations:{heading:"Chart annotations summary",descriptionSinglePoint:"{annotationText}. Related to {annotationPoint}",descriptionMultiplePoints:"{annotationText}. Related to {annotationPoint}{ Also related to, #each(additionalAnnotationPoints)}",descriptionNoPoints:"{annotationText}"},endOfChartMarker:"End of interactive chart."}, -sonification:{playAsSoundButtonText:"Play as sound, {chartTitle}",playAsSoundClickAnnouncement:"Play"},legend:{legendLabel:"Toggle series visibility",legendItem:"Hide {itemName}"},zoom:{mapZoomIn:"Zoom chart",mapZoomOut:"Zoom out chart",resetZoomButton:"Reset zoom"},rangeSelector:{minInputLabel:"Select start date.",maxInputLabel:"Select end date.",buttonText:"Select range {buttonText}"},table:{viewAsDataTableButtonText:"View as data table, {chartTitle}",tableSummary:"Table representation of chart."}, -announceNewData:{newDataAnnounce:"Updated data for chart {chartTitle}",newSeriesAnnounceSingle:"New data series: {seriesDesc}",newPointAnnounceSingle:"New data point: {pointDesc}",newSeriesAnnounceMultiple:"New data series in chart {chartTitle}: {seriesDesc}",newPointAnnounceMultiple:"New data point in chart {chartTitle}: {pointDesc}"},seriesTypeDescriptions:{boxplot:"Box plot charts are typically used to display groups of statistical data. Each data point in the chart can have up to 5 values: minimum, lower quartile, median, upper quartile, and maximum.", -arearange:"Arearange charts are line charts displaying a range between a lower and higher value for each point.",areasplinerange:"These charts are line charts displaying a range between a lower and higher value for each point.",bubble:"Bubble charts are scatter charts where each data point also has a size value.",columnrange:"Columnrange charts are column charts displaying a range between a lower and higher value for each point.",errorbar:"Errorbar series are used to display the variability of the data.", -funnel:"Funnel charts are used to display reduction of data in stages.",pyramid:"Pyramid charts consist of a single pyramid with item heights corresponding to each point value.",waterfall:"A waterfall chart is a column chart where each column contributes towards a total end value."},chartTypes:{emptyChart:"Empty chart",mapTypeDescription:"Map of {mapTitle} with {numSeries} data series.",unknownMap:"Map of unspecified region with {numSeries} data series.",combinationChart:"Combination chart with {numSeries} data series.", -defaultSingle:"Chart with {numPoints} data {#plural(numPoints, points, point)}.",defaultMultiple:"Chart with {numSeries} data series.",splineSingle:"Line chart with {numPoints} data {#plural(numPoints, points, point)}.",splineMultiple:"Line chart with {numSeries} lines.",lineSingle:"Line chart with {numPoints} data {#plural(numPoints, points, point)}.",lineMultiple:"Line chart with {numSeries} lines.",columnSingle:"Bar chart with {numPoints} {#plural(numPoints, bars, bar)}.",columnMultiple:"Bar chart with {numSeries} data series.", -barSingle:"Bar chart with {numPoints} {#plural(numPoints, bars, bar)}.",barMultiple:"Bar chart with {numSeries} data series.",pieSingle:"Pie chart with {numPoints} {#plural(numPoints, slices, slice)}.",pieMultiple:"Pie chart with {numSeries} pies.",scatterSingle:"Scatter chart with {numPoints} {#plural(numPoints, points, point)}.",scatterMultiple:"Scatter chart with {numSeries} data series.",boxplotSingle:"Boxplot with {numPoints} {#plural(numPoints, boxes, box)}.",boxplotMultiple:"Boxplot with {numSeries} data series.", -bubbleSingle:"Bubble chart with {numPoints} {#plural(numPoints, bubbles, bubble)}.",bubbleMultiple:"Bubble chart with {numSeries} data series."},axis:{xAxisDescriptionSingular:"The chart has 1 X axis displaying {names[0]}. {ranges[0]}",xAxisDescriptionPlural:"The chart has {numAxes} X axes displaying {#each(names, -1) }and {names[-1]}.",yAxisDescriptionSingular:"The chart has 1 Y axis displaying {names[0]}. {ranges[0]}",yAxisDescriptionPlural:"The chart has {numAxes} Y axes displaying {#each(names, -1) }and {names[-1]}.", -timeRangeDays:"Range: {range} days.",timeRangeHours:"Range: {range} hours.",timeRangeMinutes:"Range: {range} minutes.",timeRangeSeconds:"Range: {range} seconds.",rangeFromTo:"Range: {rangeFrom} to {rangeTo}.",rangeCategories:"Range: {numCategories} categories."},exporting:{chartMenuLabel:"Chart menu",menuButtonLabel:"View chart menu",exportRegionLabel:"Chart menu"},series:{summary:{"default":"{name}, series {ix} of {numSeries} with {numPoints} data {#plural(numPoints, points, point)}.",defaultCombination:"{name}, series {ix} of {numSeries} with {numPoints} data {#plural(numPoints, points, point)}.", -line:"{name}, line {ix} of {numSeries} with {numPoints} data {#plural(numPoints, points, point)}.",lineCombination:"{name}, series {ix} of {numSeries}. Line with {numPoints} data {#plural(numPoints, points, point)}.",spline:"{name}, line {ix} of {numSeries} with {numPoints} data {#plural(numPoints, points, point)}.",splineCombination:"{name}, series {ix} of {numSeries}. Line with {numPoints} data {#plural(numPoints, points, point)}.",column:"{name}, bar series {ix} of {numSeries} with {numPoints} {#plural(numPoints, bars, bar)}.", -columnCombination:"{name}, series {ix} of {numSeries}. Bar series with {numPoints} {#plural(numPoints, bars, bar)}.",bar:"{name}, bar series {ix} of {numSeries} with {numPoints} {#plural(numPoints, bars, bar)}.",barCombination:"{name}, series {ix} of {numSeries}. Bar series with {numPoints} {#plural(numPoints, bars, bar)}.",pie:"{name}, pie {ix} of {numSeries} with {numPoints} {#plural(numPoints, slices, slice)}.",pieCombination:"{name}, series {ix} of {numSeries}. Pie with {numPoints} {#plural(numPoints, slices, slice)}.", -scatter:"{name}, scatter plot {ix} of {numSeries} with {numPoints} {#plural(numPoints, points, point)}.",scatterCombination:"{name}, series {ix} of {numSeries}, scatter plot with {numPoints} {#plural(numPoints, points, point)}.",boxplot:"{name}, boxplot {ix} of {numSeries} with {numPoints} {#plural(numPoints, boxes, box)}.",boxplotCombination:"{name}, series {ix} of {numSeries}. Boxplot with {numPoints} {#plural(numPoints, boxes, box)}.",bubble:"{name}, bubble series {ix} of {numSeries} with {numPoints} {#plural(numPoints, bubbles, bubble)}.", -bubbleCombination:"{name}, series {ix} of {numSeries}. Bubble series with {numPoints} {#plural(numPoints, bubbles, bubble)}.",map:"{name}, map {ix} of {numSeries} with {numPoints} {#plural(numPoints, areas, area)}.",mapCombination:"{name}, series {ix} of {numSeries}. Map with {numPoints} {#plural(numPoints, areas, area)}.",mapline:"{name}, line {ix} of {numSeries} with {numPoints} data {#plural(numPoints, points, point)}.",maplineCombination:"{name}, series {ix} of {numSeries}. Line with {numPoints} data {#plural(numPoints, points, point)}.", -mapbubble:"{name}, bubble series {ix} of {numSeries} with {numPoints} {#plural(numPoints, bubbles, bubble)}.",mapbubbleCombination:"{name}, series {ix} of {numSeries}. Bubble series with {numPoints} {#plural(numPoints, bubbles, bubble)}."},description:"{description}",xAxisDescription:"X axis, {name}",yAxisDescription:"Y axis, {name}",nullPointValue:"No value",pointAnnotationsDescription:"{Annotation: #each(annotations). }"}}}});p(a,"Accessibility/Options/DeprecatedOptions.js",[a["Core/Utilities.js"]], -function(a){function f(a,d,b){for(var c,e=0;e<d.length-1;++e)c=d[e],a=a[c]=q(a[c],{});a[d[d.length-1]]=b}function l(a,d,b,c){function e(b,a){return a.reduce(function(b,a){return b[a]},b)}var g=e(a.options,d),l=e(a.options,b);Object.keys(c).forEach(function(e){var k,t=g[e];"undefined"!==typeof t&&(f(l,c[e],t),h(32,!1,a,(k={},k[d.join(".")+"."+e]=b.join(".")+"."+c[e].join("."),k)))})}function m(a){var d=a.options.chart||{},b=a.options.accessibility||{};["description","typeDescription"].forEach(function(c){var e; -d[c]&&(b[c]=d[c],h(32,!1,a,(e={},e["chart."+c]="use accessibility."+c,e)))})}function n(a){a.axes.forEach(function(d){(d=d.options)&&d.description&&(d.accessibility=d.accessibility||{},d.accessibility.description=d.description,h(32,!1,a,{"axis.description":"use axis.accessibility.description"}))})}function g(a){var d={description:["accessibility","description"],exposeElementToA11y:["accessibility","exposeAsGroupOnly"],pointDescriptionFormatter:["accessibility","pointDescriptionFormatter"],skipKeyboardNavigation:["accessibility", -"keyboardNavigation","enabled"]};a.series.forEach(function(b){Object.keys(d).forEach(function(c){var e,g=b.options[c];"undefined"!==typeof g&&(f(b.options,d[c],"skipKeyboardNavigation"===c?!g:g),h(32,!1,a,(e={},e["series."+c]="series."+d[c].join("."),e)))})})}var h=a.error,q=a.pick;return function(a){m(a);n(a);a.series&&g(a);l(a,["accessibility"],["accessibility"],{pointDateFormat:["point","dateFormat"],pointDateFormatter:["point","dateFormatter"],pointDescriptionFormatter:["point","descriptionFormatter"], -pointDescriptionThreshold:["series","pointDescriptionEnabledThreshold"],pointNavigationThreshold:["keyboardNavigation","seriesNavigation","pointNavigationEnabledThreshold"],pointValueDecimals:["point","valueDecimals"],pointValuePrefix:["point","valuePrefix"],pointValueSuffix:["point","valueSuffix"],screenReaderSectionFormatter:["screenReaderSection","beforeChartFormatter"],describeSingleSeries:["series","describeSingleSeries"],seriesDescriptionFormatter:["series","descriptionFormatter"],onTableAnchorClick:["screenReaderSection", -"onViewDataTableClick"],axisRangeDateFormat:["screenReaderSection","axisRangeDateFormat"]});l(a,["accessibility","keyboardNavigation"],["accessibility","keyboardNavigation","seriesNavigation"],{skipNullPoints:["skipNullPoints"],mode:["mode"]});l(a,["lang","accessibility"],["lang","accessibility"],{legendItem:["legend","legendItem"],legendLabel:["legend","legendLabel"],mapZoomIn:["zoom","mapZoomIn"],mapZoomOut:["zoom","mapZoomOut"],resetZoomButton:["zoom","resetZoomButton"],screenReaderRegionLabel:["screenReaderSection", -"beforeRegionLabel"],rangeSelectorButton:["rangeSelector","buttonText"],rangeSelectorMaxInput:["rangeSelector","maxInputLabel"],rangeSelectorMinInput:["rangeSelector","minInputLabel"],svgContainerEnd:["screenReaderSection","endOfChartMarker"],viewAsDataTable:["table","viewAsDataTableButtonText"],tableSummary:["table","tableSummary"]})}});p(a,"Accessibility/A11yI18n.js",[a["Core/Globals.js"],a["Core/Utilities.js"]],function(a,f){function l(a,f){var g=a.indexOf("#each("),e=a.indexOf("#plural("),d=a.indexOf("["), -b=a.indexOf("]");if(-1<g){d=a.slice(g).indexOf(")")+g;var c=a.substring(0,g);e=a.substring(d+1);d=a.substring(g+6,d).split(",");g=Number(d[1]);a="";if(f=f[d[0]])for(g=isNaN(g)?f.length:g,g=0>g?f.length+g:Math.min(g,f.length),d=0;d<g;++d)a+=c+f[d]+e;return a.length?a:""}if(-1<e){c=a.slice(e).indexOf(")")+e;a=a.substring(e+8,c).split(",");switch(Number(f[a[0]])){case 0:a=n(a[4],a[1]);break;case 1:a=n(a[2],a[1]);break;case 2:a=n(a[3],a[1]);break;default:a=a[1]}a?(f=a,f=f.trim&&f.trim()||f.replace(/^\s+|\s+$/g, -"")):f="";return f}return-1<d?(e=a.substring(0,d),a=Number(a.substring(d+1,b)),f=f[e],!isNaN(a)&&f&&(0>a?(c=f[f.length+a],"undefined"===typeof c&&(c=f[0])):(c=f[a],"undefined"===typeof c&&(c=f[f.length-1]))),"undefined"!==typeof c?c:""):"{"+a+"}"}var m=f.format,n=f.pick;a.i18nFormat=function(a,f,n){var e=function(a,b){a=a.slice(b||0);var c=a.indexOf("{"),d=a.indexOf("}");if(-1<c&&d>c)return{statement:a.substring(c+1,d),begin:b+c+1,end:b+d}},d=[],b=0;do{var c=e(a,b);var g=a.substring(b,c&&c.begin- -1);g.length&&d.push({value:g,type:"constant"});c&&d.push({value:c.statement,type:"statement"});b=c?c.end+1:b+1}while(c);d.forEach(function(a){"statement"===a.type&&(a.value=l(a.value,f))});return m(d.reduce(function(a,b){return a+b.value},""),f,n)};a.Chart.prototype.langFormat=function(f,h){f=f.split(".");for(var g=this.options.lang,e=0;e<f.length;++e)g=g&&g[f[e]];return"string"===typeof g?a.i18nFormat(g,h,this):""}});p(a,"Accessibility/FocusBorder.js",[a["Core/Globals.js"],a["Core/Renderer/SVG/SVGElement.js"], -a["Core/Renderer/SVG/SVGLabel.js"],a["Core/Utilities.js"]],function(a,f,l,m){function n(a){if(!a.focusBorderDestroyHook){var b=a.destroy;a.destroy=function(){var c,d;null===(d=null===(c=a.focusBorder)||void 0===c?void 0:c.destroy)||void 0===d?void 0:d.call(c);return b.apply(a,arguments)};a.focusBorderDestroyHook=b}}function g(a){for(var c=[],d=1;d<arguments.length;d++)c[d-1]=arguments[d];a.focusBorderUpdateHooks||(a.focusBorderUpdateHooks={},b.forEach(function(b){b+="Setter";var d=a[b]||a._defaultSetter; -a.focusBorderUpdateHooks[b]=d;a[b]=function(){var b=d.apply(a,arguments);a.addFocusBorder.apply(a,c);return b}}))}function h(a){a.focusBorderUpdateHooks&&(Object.keys(a.focusBorderUpdateHooks).forEach(function(b){var c=a.focusBorderUpdateHooks[b];c===a._defaultSetter?delete a[b]:a[b]=c}),delete a.focusBorderUpdateHooks)}var q=m.addEvent,e=m.extend,d=m.pick,b="x y transform width height r d stroke-width".split(" ");e(f.prototype,{addFocusBorder:function(b,e){this.focusBorder&&this.removeFocusBorder(); -var c=this.getBBox(),f=d(b,3);c.x+=this.translateX?this.translateX:0;c.y+=this.translateY?this.translateY:0;var h=c.x-f,k=c.y-f,m=c.width+2*f,q=c.height+2*f,p=this instanceof l;if("text"===this.element.nodeName||p){var u=!!this.rotation;if(p)var x={x:u?1:0,y:0};else h=x=0,"middle"===this.attr("text-anchor")?(x=a.isFirefox&&this.rotation?.25:.5,h=a.isFirefox&&!this.rotation?.75:.5):this.rotation?x=.25:h=.75,x={x:x,y:h};h=+this.attr("x")-c.width*x.x-f;k=+this.attr("y")-c.height*x.y-f;p&&u&&(p=m,m=q, -q=p,h=+this.attr("x")-c.height*x.x-f,k=+this.attr("y")-c.width*x.y-f)}this.focusBorder=this.renderer.rect(h,k,m,q,parseInt((e&&e.borderRadius||0).toString(),10)).addClass("highcharts-focus-border").attr({zIndex:99}).add(this.parentGroup);this.renderer.styledMode||this.focusBorder.attr({stroke:e&&e.stroke,"stroke-width":e&&e.strokeWidth});g(this,b,e);n(this)},removeFocusBorder:function(){h(this);this.focusBorderDestroyHook&&(this.destroy=this.focusBorderDestroyHook,delete this.focusBorderDestroyHook); -this.focusBorder&&(this.focusBorder.destroy(),delete this.focusBorder)}});a.Chart.prototype.renderFocusBorder=function(){var a=this.focusElement,b=this.options.accessibility.keyboardNavigation.focusBorder;a&&(a.removeFocusBorder(),b.enabled&&a.addFocusBorder(b.margin,{stroke:b.style.color,strokeWidth:b.style.lineWidth,borderRadius:b.style.borderRadius}))};a.Chart.prototype.setFocusToElement=function(a,b){var c=this.options.accessibility.keyboardNavigation.focusBorder;(b=b||a.element)&&b.focus&&(b.hcEvents&& -b.hcEvents.focusin||q(b,"focusin",function(){}),b.focus(),c.hideBrowserFocusOutline&&(b.style.outline="none"));this.focusElement&&this.focusElement.removeFocusBorder();this.focusElement=a;this.renderFocusBorder()}});p(a,"Accessibility/Accessibility.js",[a["Accessibility/Utils/ChartUtilities.js"],a["Core/Globals.js"],a["Accessibility/KeyboardNavigationHandler.js"],a["Core/Series/CartesianSeries.js"],a["Core/Options.js"],a["Core/Series/Point.js"],a["Core/Utilities.js"],a["Accessibility/AccessibilityComponent.js"], -a["Accessibility/KeyboardNavigation.js"],a["Accessibility/Components/LegendComponent.js"],a["Accessibility/Components/MenuComponent.js"],a["Accessibility/Components/SeriesComponent/SeriesComponent.js"],a["Accessibility/Components/ZoomComponent.js"],a["Accessibility/Components/RangeSelectorComponent.js"],a["Accessibility/Components/InfoRegionsComponent.js"],a["Accessibility/Components/ContainerComponent.js"],a["Accessibility/HighContrastMode.js"],a["Accessibility/HighContrastTheme.js"],a["Accessibility/Options/Options.js"], -a["Accessibility/Options/LangOptions.js"],a["Accessibility/Options/DeprecatedOptions.js"]],function(a,f,l,m,n,g,h,p,e,d,b,c,k,t,v,w,H,A,D,y,z){function q(a){this.init(a)}var r=f.doc,u=h.addEvent,F=h.extend,B=h.fireEvent,E=h.merge;E(!0,n.defaultOptions,D,{accessibility:{highContrastTheme:A},lang:y});f.A11yChartUtilities=a;f.KeyboardNavigationHandler=l;f.AccessibilityComponent=p;q.prototype={init:function(a){this.chart=a;r.addEventListener&&a.renderer.isSVG?(z(a),this.initComponents(),this.keyboardNavigation= -new e(a,this.components),this.update()):a.renderTo.setAttribute("aria-hidden",!0)},initComponents:function(){var a=this.chart,e=a.options.accessibility;this.components={container:new w,infoRegions:new v,legend:new d,chartMenu:new b,rangeSelector:new t,series:new c,zoom:new k};e.customComponents&&F(this.components,e.customComponents);var f=this.components;this.getComponentOrder().forEach(function(b){f[b].initBase(a);f[b].init()})},getComponentOrder:function(){if(!this.components)return[];if(!this.components.series)return Object.keys(this.components); -var a=Object.keys(this.components).filter(function(a){return"series"!==a});return["series"].concat(a)},update:function(){var a=this.components,b=this.chart,c=b.options.accessibility;B(b,"beforeA11yUpdate");b.types=this.getChartTypes();this.getComponentOrder().forEach(function(c){a[c].onChartUpdate();B(b,"afterA11yComponentUpdate",{name:c,component:a[c]})});this.keyboardNavigation.update(c.keyboardNavigation.order);!b.highContrastModeActive&&H.isHighContrastModeActive()&&H.setHighContrastTheme(b); -B(b,"afterA11yUpdate",{accessibility:this})},destroy:function(){var a=this.chart||{},b=this.components;Object.keys(b).forEach(function(a){b[a].destroy();b[a].destroyBase()});this.keyboardNavigation&&this.keyboardNavigation.destroy();a.renderTo&&a.renderTo.setAttribute("aria-hidden",!0);a.focusElement&&a.focusElement.removeFocusBorder()},getChartTypes:function(){var a={};this.chart.series.forEach(function(b){a[b.type]=1});return Object.keys(a)}};f.Chart.prototype.updateA11yEnabled=function(){var a= -this.accessibility,b=this.options.accessibility;b&&b.enabled?a?a.update():this.accessibility=new q(this):a?(a.destroy&&a.destroy(),delete this.accessibility):this.renderTo.setAttribute("aria-hidden",!0)};u(f.Chart,"render",function(a){this.a11yDirty&&this.renderTo&&(delete this.a11yDirty,this.updateA11yEnabled());var b=this.accessibility;b&&b.getComponentOrder().forEach(function(a){b.components[a].onChartRender()})});u(f.Chart,"update",function(a){if(a=a.options.accessibility)a.customComponents&& -(this.options.accessibility.customComponents=a.customComponents,delete a.customComponents),E(!0,this.options.accessibility,a),this.accessibility&&this.accessibility.destroy&&(this.accessibility.destroy(),delete this.accessibility);this.a11yDirty=!0});u(g,"update",function(){this.series.chart.accessibility&&(this.series.chart.a11yDirty=!0)});["addSeries","init"].forEach(function(a){u(f.Chart,a,function(){this.a11yDirty=!0})});["update","updatedData","remove"].forEach(function(a){u(m,a,function(){this.chart.accessibility&& -(this.chart.a11yDirty=!0)})});["afterDrilldown","drillupall"].forEach(function(a){u(f.Chart,a,function(){this.accessibility&&this.accessibility.update()})});u(f.Chart,"destroy",function(){this.accessibility&&this.accessibility.destroy()})});p(a,"masters/modules/accessibility.src.js",[],function(){})}); -//# sourceMappingURL=accessibility.js.map \ No newline at end of file +(function (a) { + "object" === typeof module && module.exports + ? ((a["default"] = a), (module.exports = a)) + : "function" === typeof define && define.amd + ? define("highcharts/modules/accessibility", ["highcharts"], function (p) { + a(p); + a.Highcharts = p; + return a; + }) + : a("undefined" !== typeof Highcharts ? Highcharts : void 0); +})(function (a) { + function p(a, f, l, m) { + a.hasOwnProperty(f) || (a[f] = m.apply(null, l)); + } + a = a ? a._modules : {}; + p( + a, + "Accessibility/Utils/HTMLUtilities.js", + [a["Core/Globals.js"], a["Core/Utilities.js"]], + function (a, f) { + function u(a) { + return a + .replace(/&/g, "&") + .replace(/</g, "<") + .replace(/>/g, ">") + .replace(/"/g, """) + .replace(/'/g, "'") + .replace(/\//g, "/"); + } + var m = a.doc, + n = a.win, + g = f.merge; + return { + addClass: function (a, g) { + a.classList + ? a.classList.add(g) + : 0 > a.className.indexOf(g) && (a.className += g); + }, + escapeStringForHTML: u, + getElement: function (a) { + return m.getElementById(a); + }, + getFakeMouseEvent: function (a) { + if ("function" === typeof n.MouseEvent) return new n.MouseEvent(a); + if (m.createEvent) { + var g = m.createEvent("MouseEvent"); + if (g.initMouseEvent) + return ( + g.initMouseEvent( + a, + !0, + !0, + n, + "click" === a ? 1 : 0, + 0, + 0, + 0, + 0, + !1, + !1, + !1, + !1, + 0, + null + ), + g + ); + } + return { type: a }; + }, + removeElement: function (a) { + a && a.parentNode && a.parentNode.removeChild(a); + }, + reverseChildNodes: function (a) { + for (var g = a.childNodes.length; g--; ) + a.appendChild(a.childNodes[g]); + }, + setElAttrs: function (a, g) { + Object.keys(g).forEach(function (e) { + var d = g[e]; + null === d + ? a.removeAttribute(e) + : ((d = u("" + d)), a.setAttribute(e, d)); + }); + }, + stripHTMLTagsFromString: function (a) { + return "string" === typeof a ? a.replace(/<\/?[^>]+(>|$)/g, "") : a; + }, + visuallyHideElement: function (a) { + g(!0, a.style, { + position: "absolute", + width: "1px", + height: "1px", + overflow: "hidden", + whiteSpace: "nowrap", + clip: "rect(1px, 1px, 1px, 1px)", + marginTop: "-3px", + "-ms-filter": "progid:DXImageTransform.Microsoft.Alpha(Opacity=1)", + filter: "alpha(opacity=1)", + opacity: "0.01", + }); + }, + }; + } + ); + p( + a, + "Accessibility/Utils/ChartUtilities.js", + [a["Accessibility/Utils/HTMLUtilities.js"], a["Core/Utilities.js"]], + function (a, f) { + function u(d) { + var b, c; + if (null === (b = d.points) || void 0 === b ? 0 : b.length) + return ( + (d = q(d.points, function (c) { + return !!c.graphic; + })), + null === (c = null === d || void 0 === d ? void 0 : d.graphic) || + void 0 === c + ? void 0 + : c.element + ); + } + function m(d) { + var b = u(d); + return ( + (b && b.parentNode) || + (d.graph && d.graph.element) || + (d.group && d.group.element) + ); + } + function n(d, b) { + b.setAttribute("aria-hidden", !1); + b !== d.renderTo && + b.parentNode && + (Array.prototype.forEach.call(b.parentNode.childNodes, function (c) { + c.hasAttribute("aria-hidden") || c.setAttribute("aria-hidden", !0); + }), + n(d, b.parentNode)); + } + var g = a.stripHTMLTagsFromString, + h = f.defined, + q = f.find, + e = f.fireEvent; + return { + getChartTitle: function (d) { + return g( + d.options.title.text || + d.langFormat("accessibility.defaultChartTitle", { chart: d }) + ); + }, + getAxisDescription: function (d) { + return g( + d && + ((d.userOptions && + d.userOptions.accessibility && + d.userOptions.accessibility.description) || + (d.axisTitle && d.axisTitle.textStr) || + d.options.id || + (d.categories && "categories") || + (d.dateTime && "Time") || + "values") + ); + }, + getPointFromXY: function (d, b, c) { + for (var k = d.length, t; k--; ) + if ( + (t = q(d[k].points || [], function (v) { + return v.x === b && v.y === c; + })) + ) + return t; + }, + getSeriesFirstPointElement: u, + getSeriesFromName: function (d, b) { + return b + ? (d.series || []).filter(function (c) { + return c.name === b; + }) + : d.series; + }, + getSeriesA11yElement: m, + unhideChartElementFromAT: n, + hideSeriesFromAT: function (d) { + (d = m(d)) && d.setAttribute("aria-hidden", !0); + }, + scrollToPoint: function (d) { + var b = d.series.xAxis, + c = d.series.yAxis, + k = (null === b || void 0 === b ? 0 : b.scrollbar) ? b : c; + if ( + (b = null === k || void 0 === k ? void 0 : k.scrollbar) && + h(b.to) && + h(b.from) + ) { + c = b.to - b.from; + if (h(k.dataMin) && h(k.dataMax)) { + var t = k.toPixels(k.dataMin), + v = k.toPixels(k.dataMax); + d = + (k.toPixels(d["xAxis" === k.coll ? "x" : "y"] || 0) - t) / + (v - t); + } else d = 0; + b.updatePosition(d - c / 2, d + c / 2); + e(b, "changed", { + from: b.from, + to: b.to, + trigger: "scrollbar", + DOMEvent: null, + }); + } + }, + }; + } + ); + p( + a, + "Accessibility/KeyboardNavigationHandler.js", + [a["Core/Utilities.js"]], + function (a) { + function f(a, f) { + this.chart = a; + this.keyCodeMap = f.keyCodeMap || []; + this.validate = f.validate; + this.init = f.init; + this.terminate = f.terminate; + this.response = { success: 1, prev: 2, next: 3, noHandler: 4, fail: 5 }; + } + var u = a.find; + f.prototype = { + run: function (a) { + var f = a.which || a.keyCode, + g = this.response.noHandler, + h = u(this.keyCodeMap, function (a) { + return -1 < a[0].indexOf(f); + }); + h + ? (g = h[1].call(this, f, a)) + : 9 === f && (g = this.response[a.shiftKey ? "prev" : "next"]); + return g; + }, + }; + return f; + } + ); + p( + a, + "Accessibility/Utils/DOMElementProvider.js", + [ + a["Core/Globals.js"], + a["Accessibility/Utils/HTMLUtilities.js"], + a["Core/Utilities.js"], + ], + function (a, f, l) { + var u = a.doc, + n = f.removeElement; + a = l.extend; + f = function () { + this.elements = []; + }; + a(f.prototype, { + createElement: function () { + var a = u.createElement.apply(u, arguments); + this.elements.push(a); + return a; + }, + destroyCreatedElements: function () { + this.elements.forEach(function (a) { + n(a); + }); + this.elements = []; + }, + }); + return f; + } + ); + p( + a, + "Accessibility/Utils/EventProvider.js", + [a["Core/Globals.js"], a["Core/Utilities.js"]], + function (a, f) { + var u = f.addEvent; + f = f.extend; + var m = function () { + this.eventRemovers = []; + }; + f(m.prototype, { + addEvent: function () { + var f = u.apply(a, arguments); + this.eventRemovers.push(f); + return f; + }, + removeAddedEvents: function () { + this.eventRemovers.forEach(function (a) { + a(); + }); + this.eventRemovers = []; + }, + }); + return m; + } + ); + p( + a, + "Accessibility/AccessibilityComponent.js", + [ + a["Accessibility/Utils/ChartUtilities.js"], + a["Accessibility/Utils/DOMElementProvider.js"], + a["Accessibility/Utils/EventProvider.js"], + a["Core/Globals.js"], + a["Accessibility/Utils/HTMLUtilities.js"], + a["Core/Utilities.js"], + ], + function (a, f, l, m, n, g) { + function h() {} + var q = a.unhideChartElementFromAT, + e = m.doc, + d = m.win, + b = n.removeElement, + c = n.getFakeMouseEvent; + a = g.extend; + var k = g.fireEvent, + t = g.merge; + h.prototype = { + initBase: function (c) { + this.chart = c; + this.eventProvider = new l(); + this.domElementProvider = new f(); + this.keyCodes = { + left: 37, + right: 39, + up: 38, + down: 40, + enter: 13, + space: 32, + esc: 27, + tab: 9, + }; + }, + addEvent: function () { + return this.eventProvider.addEvent.apply( + this.eventProvider, + arguments + ); + }, + createElement: function () { + return this.domElementProvider.createElement.apply( + this.domElementProvider, + arguments + ); + }, + fireEventOnWrappedOrUnwrappedElement: function (c, b) { + var v = b.type; + e.createEvent && (c.dispatchEvent || c.fireEvent) + ? c.dispatchEvent + ? c.dispatchEvent(b) + : c.fireEvent(v, b) + : k(c, v, b); + }, + fakeClickEvent: function (b) { + if (b) { + var v = c("click"); + this.fireEventOnWrappedOrUnwrappedElement(b, v); + } + }, + addProxyGroup: function (c) { + this.createOrUpdateProxyContainer(); + var b = this.createElement("div"); + Object.keys(c || {}).forEach(function (v) { + null !== c[v] && b.setAttribute(v, c[v]); + }); + this.chart.a11yProxyContainer.appendChild(b); + return b; + }, + createOrUpdateProxyContainer: function () { + var c = this.chart, + b = c.renderer.box; + c.a11yProxyContainer = + c.a11yProxyContainer || this.createProxyContainerElement(); + b.nextSibling !== c.a11yProxyContainer && + c.container.insertBefore(c.a11yProxyContainer, b.nextSibling); + }, + createProxyContainerElement: function () { + var c = e.createElement("div"); + c.className = "highcharts-a11y-proxy-container"; + return c; + }, + createProxyButton: function (c, b, a, d, k) { + var v = c.element, + e = this.createElement("button"), + w = t({ "aria-label": v.getAttribute("aria-label") }, a); + Object.keys(w).forEach(function (c) { + null !== w[c] && e.setAttribute(c, w[c]); + }); + e.className = "highcharts-a11y-proxy-button"; + k && this.addEvent(e, "click", k); + this.setProxyButtonStyle(e); + this.updateProxyButtonPosition(e, d || c); + this.proxyMouseEventsForButton(v, e); + b.appendChild(e); + w["aria-hidden"] || q(this.chart, e); + return e; + }, + getElementPosition: function (c) { + var b = c.element; + return (c = this.chart.renderTo) && b && b.getBoundingClientRect + ? ((b = b.getBoundingClientRect()), + (c = c.getBoundingClientRect()), + { + x: b.left - c.left, + y: b.top - c.top, + width: b.right - b.left, + height: b.bottom - b.top, + }) + : { x: 0, y: 0, width: 1, height: 1 }; + }, + setProxyButtonStyle: function (c) { + t(!0, c.style, { + "border-width": 0, + "background-color": "transparent", + cursor: "pointer", + outline: "none", + opacity: 0.001, + filter: "alpha(opacity=1)", + "-ms-filter": "progid:DXImageTransform.Microsoft.Alpha(Opacity=1)", + zIndex: 999, + overflow: "hidden", + padding: 0, + margin: 0, + display: "block", + position: "absolute", + }); + }, + updateProxyButtonPosition: function (c, b) { + b = this.getElementPosition(b); + t(!0, c.style, { + width: (b.width || 1) + "px", + height: (b.height || 1) + "px", + left: (b.x || 0) + "px", + top: (b.y || 0) + "px", + }); + }, + proxyMouseEventsForButton: function (c, b) { + var a = this; + "click touchstart touchend touchcancel touchmove mouseover mouseenter mouseleave mouseout" + .split(" ") + .forEach(function (d) { + var t = 0 === d.indexOf("touch"); + a.addEvent(b, d, function (b) { + var d = t ? a.cloneTouchEvent(b) : a.cloneMouseEvent(b); + c && a.fireEventOnWrappedOrUnwrappedElement(c, d); + b.stopPropagation(); + b.preventDefault(); + }); + }); + }, + cloneMouseEvent: function (b) { + if ("function" === typeof d.MouseEvent) + return new d.MouseEvent(b.type, b); + if (e.createEvent) { + var a = e.createEvent("MouseEvent"); + if (a.initMouseEvent) + return ( + a.initMouseEvent( + b.type, + b.bubbles, + b.cancelable, + b.view || d, + b.detail, + b.screenX, + b.screenY, + b.clientX, + b.clientY, + b.ctrlKey, + b.altKey, + b.shiftKey, + b.metaKey, + b.button, + b.relatedTarget + ), + a + ); + } + return c(b.type); + }, + cloneTouchEvent: function (b) { + var c = function (b) { + for (var c = [], a = 0; a < b.length; ++a) { + var d = b.item(a); + d && c.push(d); + } + return c; + }; + if ("function" === typeof d.TouchEvent) + return ( + (c = new d.TouchEvent(b.type, { + touches: c(b.touches), + targetTouches: c(b.targetTouches), + changedTouches: c(b.changedTouches), + ctrlKey: b.ctrlKey, + shiftKey: b.shiftKey, + altKey: b.altKey, + metaKey: b.metaKey, + bubbles: b.bubbles, + cancelable: b.cancelable, + composed: b.composed, + detail: b.detail, + view: b.view, + })), + b.defaultPrevented && c.preventDefault(), + c + ); + c = this.cloneMouseEvent(b); + c.touches = b.touches; + c.changedTouches = b.changedTouches; + c.targetTouches = b.targetTouches; + return c; + }, + destroyBase: function () { + b(this.chart.a11yProxyContainer); + this.domElementProvider.destroyCreatedElements(); + this.eventProvider.removeAddedEvents(); + }, + }; + a(h.prototype, { + init: function () {}, + getKeyboardNavigation: function () {}, + onChartUpdate: function () {}, + onChartRender: function () {}, + destroy: function () {}, + }); + return h; + } + ); + p( + a, + "Accessibility/KeyboardNavigation.js", + [ + a["Core/Globals.js"], + a["Core/Utilities.js"], + a["Accessibility/Utils/HTMLUtilities.js"], + a["Accessibility/Utils/EventProvider.js"], + ], + function (a, f, l, m) { + function n(b, c) { + this.init(b, c); + } + var g = a.doc, + h = a.win, + q = f.addEvent, + e = f.fireEvent, + d = l.getElement; + q(g, "keydown", function (b) { + 27 === (b.which || b.keyCode) && + a.charts && + a.charts.forEach(function (b) { + b && b.dismissPopupContent && b.dismissPopupContent(); + }); + }); + a.Chart.prototype.dismissPopupContent = function () { + var b = this; + e(this, "dismissPopupContent", {}, function () { + b.tooltip && b.tooltip.hide(0); + b.hideExportMenu(); + }); + }; + n.prototype = { + init: function (b, c) { + var a = this, + d = (this.eventProvider = new m()); + this.chart = b; + this.components = c; + this.modules = []; + this.currentModuleIx = 0; + this.update(); + d.addEvent(this.tabindexContainer, "keydown", function (b) { + return a.onKeydown(b); + }); + d.addEvent(this.tabindexContainer, "focus", function (b) { + return a.onFocus(b); + }); + ["mouseup", "touchend"].forEach(function (b) { + return d.addEvent(g, b, function () { + return a.onMouseUp(); + }); + }); + ["mousedown", "touchstart"].forEach(function (c) { + return d.addEvent(b.renderTo, c, function () { + a.isClickingChart = !0; + }); + }); + d.addEvent(b.renderTo, "mouseover", function () { + a.pointerIsOverChart = !0; + }); + d.addEvent(b.renderTo, "mouseout", function () { + a.pointerIsOverChart = !1; + }); + this.modules.length && this.modules[0].init(1); + }, + update: function (b) { + var c = this.chart.options.accessibility; + c = c && c.keyboardNavigation; + var a = this.components; + this.updateContainerTabindex(); + c && c.enabled && b && b.length + ? ((this.modules = b.reduce(function (b, c) { + c = a[c].getKeyboardNavigation(); + return b.concat(c); + }, [])), + this.updateExitAnchor()) + : ((this.modules = []), + (this.currentModuleIx = 0), + this.removeExitAnchor()); + }, + onFocus: function (b) { + var c, + a = this.chart; + b = b.relatedTarget && a.container.contains(b.relatedTarget); + this.isClickingChart || + b || + (null === (c = this.modules[0]) || void 0 === c + ? void 0 + : c.init(1)); + }, + onMouseUp: function () { + delete this.isClickingChart; + if (!this.keyboardReset && !this.pointerIsOverChart) { + var b = this.chart, + c = this.modules && this.modules[this.currentModuleIx || 0]; + c && c.terminate && c.terminate(); + b.focusElement && b.focusElement.removeFocusBorder(); + this.currentModuleIx = 0; + this.keyboardReset = !0; + } + }, + onKeydown: function (b) { + b = b || h.event; + var c, + a = + this.modules && + this.modules.length && + this.modules[this.currentModuleIx]; + this.keyboardReset = !1; + if (a) { + var d = a.run(b); + d === a.response.success + ? (c = !0) + : d === a.response.prev + ? (c = this.prev()) + : d === a.response.next && (c = this.next()); + c && (b.preventDefault(), b.stopPropagation()); + } + }, + prev: function () { + return this.move(-1); + }, + next: function () { + return this.move(1); + }, + move: function (b) { + var c = this.modules && this.modules[this.currentModuleIx]; + c && c.terminate && c.terminate(b); + this.chart.focusElement && + this.chart.focusElement.removeFocusBorder(); + this.currentModuleIx += b; + if ((c = this.modules && this.modules[this.currentModuleIx])) { + if (c.validate && !c.validate()) return this.move(b); + if (c.init) return c.init(b), !0; + } + this.currentModuleIx = 0; + 0 < b + ? ((this.exiting = !0), this.exitAnchor.focus()) + : this.tabindexContainer.focus(); + return !1; + }, + updateExitAnchor: function () { + var b = d("highcharts-end-of-chart-marker-" + this.chart.index); + this.removeExitAnchor(); + b + ? (this.makeElementAnExitAnchor(b), (this.exitAnchor = b)) + : this.createExitAnchor(); + }, + updateContainerTabindex: function () { + var b = this.chart.options.accessibility; + b = b && b.keyboardNavigation; + b = !(b && !1 === b.enabled); + var c = this.chart, + a = c.container; + c.renderTo.hasAttribute("tabindex") && + (a.removeAttribute("tabindex"), (a = c.renderTo)); + this.tabindexContainer = a; + var d = a.getAttribute("tabindex"); + b && !d + ? a.setAttribute("tabindex", "0") + : b || c.container.removeAttribute("tabindex"); + }, + makeElementAnExitAnchor: function (b) { + var c = this.tabindexContainer.getAttribute("tabindex") || 0; + b.setAttribute("class", "highcharts-exit-anchor"); + b.setAttribute("tabindex", c); + b.setAttribute("aria-hidden", !1); + this.addExitAnchorEventsToEl(b); + }, + createExitAnchor: function () { + var b = this.chart, + c = (this.exitAnchor = g.createElement("div")); + b.renderTo.appendChild(c); + this.makeElementAnExitAnchor(c); + }, + removeExitAnchor: function () { + this.exitAnchor && + this.exitAnchor.parentNode && + (this.exitAnchor.parentNode.removeChild(this.exitAnchor), + delete this.exitAnchor); + }, + addExitAnchorEventsToEl: function (b) { + var c = this.chart, + a = this; + this.eventProvider.addEvent(b, "focus", function (b) { + b = b || h.event; + (b.relatedTarget && c.container.contains(b.relatedTarget)) || + a.exiting + ? (a.exiting = !1) + : (a.tabindexContainer.focus(), + b.preventDefault(), + a.modules && + a.modules.length && + ((a.currentModuleIx = a.modules.length - 1), + (b = a.modules[a.currentModuleIx]) && + b.validate && + !b.validate() + ? a.prev() + : b && b.init(-1))); + }); + }, + destroy: function () { + this.removeExitAnchor(); + this.eventProvider.removeAddedEvents(); + this.chart.container.removeAttribute("tabindex"); + }, + }; + return n; + } + ); + p( + a, + "Accessibility/Components/LegendComponent.js", + [ + a["Core/Globals.js"], + a["Core/Legend.js"], + a["Core/Utilities.js"], + a["Accessibility/AccessibilityComponent.js"], + a["Accessibility/KeyboardNavigationHandler.js"], + a["Accessibility/Utils/HTMLUtilities.js"], + ], + function (a, f, l, m, n, g) { + function h(b) { + var c = b.legend && b.legend.allItems, + a = b.options.legend.accessibility || {}; + return !( + !c || + !c.length || + (b.colorAxis && b.colorAxis.length) || + !1 === a.enabled + ); + } + var q = l.addEvent, + e = l.extend, + d = l.find, + b = l.fireEvent, + c = g.stripHTMLTagsFromString, + k = g.removeElement; + a.Chart.prototype.highlightLegendItem = function (c) { + var a = this.legend.allItems, + d = this.highlightedLegendItemIx; + if (a[c]) { + a[d] && b(a[d].legendGroup.element, "mouseout"); + d = this.legend; + var k = d.allItems[c].pageIx, + t = d.currentPage; + "undefined" !== typeof k && k + 1 !== t && d.scroll(1 + k - t); + this.setFocusToElement(a[c].legendItem, a[c].a11yProxyElement); + b(a[c].legendGroup.element, "mouseover"); + return !0; + } + return !1; + }; + q(f, "afterColorizeItem", function (b) { + var c = b.item; + this.chart.options.accessibility.enabled && + c && + c.a11yProxyElement && + c.a11yProxyElement.setAttribute( + "aria-pressed", + b.visible ? "false" : "true" + ); + }); + a = function () {}; + a.prototype = new m(); + e(a.prototype, { + init: function () { + var b = this; + this.proxyElementsList = []; + this.recreateProxies(); + this.addEvent(f, "afterScroll", function () { + this.chart === b.chart && + (b.updateProxiesPositions(), + b.updateLegendItemProxyVisibility(), + this.chart.highlightLegendItem(b.highlightedLegendItemIx)); + }); + this.addEvent(f, "afterPositionItem", function (c) { + this.chart === b.chart && + this.chart.renderer && + b.updateProxyPositionForItem(c.item); + }); + }, + updateLegendItemProxyVisibility: function () { + var b = this.chart.legend, + c = b.currentPage || 1, + a = b.clipHeight || 0; + (b.allItems || []).forEach(function (d) { + var k = d.pageIx || 0, + t = d._legendItemPos ? d._legendItemPos[1] : 0, + e = d.legendItem ? Math.round(d.legendItem.getBBox().height) : 0; + k = t + e - b.pages[k] > a || k !== c - 1; + d.a11yProxyElement && + (d.a11yProxyElement.style.visibility = k ? "hidden" : "visible"); + }); + }, + onChartRender: function () { + h(this.chart) ? this.updateProxiesPositions() : this.removeProxies(); + }, + updateProxiesPositions: function () { + for (var b = 0, c = this.proxyElementsList; b < c.length; b++) { + var a = c[b]; + this.updateProxyButtonPosition(a.element, a.posElement); + } + }, + updateProxyPositionForItem: function (b) { + var c = d(this.proxyElementsList, function (c) { + return c.item === b; + }); + c && this.updateProxyButtonPosition(c.element, c.posElement); + }, + recreateProxies: function () { + this.removeProxies(); + h(this.chart) && + (this.addLegendProxyGroup(), + this.proxyLegendItems(), + this.updateLegendItemProxyVisibility()); + }, + removeProxies: function () { + k(this.legendProxyGroup); + this.proxyElementsList = []; + }, + addLegendProxyGroup: function () { + var b = this.chart.options.accessibility, + c = this.chart.langFormat("accessibility.legend.legendLabel", {}); + this.legendProxyGroup = this.addProxyGroup({ + "aria-label": c, + role: "all" === b.landmarkVerbosity ? "region" : null, + }); + }, + proxyLegendItems: function () { + var b = this; + ((this.chart.legend && this.chart.legend.allItems) || []).forEach( + function (c) { + c.legendItem && c.legendItem.element && b.proxyLegendItem(c); + } + ); + }, + proxyLegendItem: function (b) { + if (b.legendItem && b.legendGroup) { + var a = this.chart.langFormat("accessibility.legend.legendItem", { + chart: this.chart, + itemName: c(b.name), + }), + d = b.legendGroup.div ? b.legendItem : b.legendGroup; + b.a11yProxyElement = this.createProxyButton( + b.legendItem, + this.legendProxyGroup, + { tabindex: -1, "aria-pressed": !b.visible, "aria-label": a }, + d + ); + this.proxyElementsList.push({ + item: b, + element: b.a11yProxyElement, + posElement: d, + }); + } + }, + getKeyboardNavigation: function () { + var b = this.keyCodes, + c = this; + return new n(this.chart, { + keyCodeMap: [ + [ + [b.left, b.right, b.up, b.down], + function (b) { + return c.onKbdArrowKey(this, b); + }, + ], + [ + [b.enter, b.space], + function () { + return c.onKbdClick(this); + }, + ], + ], + validate: function () { + return c.shouldHaveLegendNavigation(); + }, + init: function (b) { + return c.onKbdNavigationInit(b); + }, + }); + }, + onKbdArrowKey: function (b, c) { + var a = this.keyCodes, + d = b.response, + k = this.chart, + e = k.options.accessibility, + t = k.legend.allItems.length; + c = c === a.left || c === a.up ? -1 : 1; + return k.highlightLegendItem(this.highlightedLegendItemIx + c) + ? ((this.highlightedLegendItemIx += c), d.success) + : 1 < t && e.keyboardNavigation.wrapAround + ? (b.init(c), d.success) + : d[0 < c ? "next" : "prev"]; + }, + onKbdClick: function (c) { + var a = this.chart.legend.allItems[this.highlightedLegendItemIx]; + a && a.a11yProxyElement && b(a.a11yProxyElement, "click"); + return c.response.success; + }, + shouldHaveLegendNavigation: function () { + var b = this.chart, + c = b.colorAxis && b.colorAxis.length, + a = (b.options.legend || {}).accessibility || {}; + return !!( + b.legend && + b.legend.allItems && + b.legend.display && + !c && + a.enabled && + a.keyboardNavigation && + a.keyboardNavigation.enabled + ); + }, + onKbdNavigationInit: function (b) { + var c = this.chart, + a = c.legend.allItems.length - 1; + b = 0 < b ? 0 : a; + c.highlightLegendItem(b); + this.highlightedLegendItemIx = b; + }, + }); + return a; + } + ); + p( + a, + "Accessibility/Components/MenuComponent.js", + [ + a["Core/Globals.js"], + a["Core/Utilities.js"], + a["Accessibility/AccessibilityComponent.js"], + a["Accessibility/KeyboardNavigationHandler.js"], + a["Accessibility/Utils/ChartUtilities.js"], + a["Accessibility/Utils/HTMLUtilities.js"], + ], + function (a, f, l, m, n, g) { + function h(b) { + return b.exportSVGElements && b.exportSVGElements[0]; + } + f = f.extend; + var q = n.unhideChartElementFromAT, + e = g.removeElement, + d = g.getFakeMouseEvent; + a.Chart.prototype.showExportMenu = function () { + var b = h(this); + if (b && ((b = b.element), b.onclick)) b.onclick(d("click")); + }; + a.Chart.prototype.hideExportMenu = function () { + var b = this.exportDivElements; + b && + this.exportContextMenu && + (b.forEach(function (b) { + if ("highcharts-menu-item" === b.className && b.onmouseout) + b.onmouseout(d("mouseout")); + }), + (this.highlightedExportItemIx = 0), + this.exportContextMenu.hideMenu(), + this.container.focus()); + }; + a.Chart.prototype.highlightExportItem = function (b) { + var c = this.exportDivElements && this.exportDivElements[b], + a = + this.exportDivElements && + this.exportDivElements[this.highlightedExportItemIx]; + if (c && "LI" === c.tagName && (!c.children || !c.children.length)) { + var e = !!(this.renderTo.getElementsByTagName("g")[0] || {}).focus; + c.focus && e && c.focus(); + if (a && a.onmouseout) a.onmouseout(d("mouseout")); + if (c.onmouseover) c.onmouseover(d("mouseover")); + this.highlightedExportItemIx = b; + return !0; + } + return !1; + }; + a.Chart.prototype.highlightLastExportItem = function () { + var b; + if (this.exportDivElements) + for (b = this.exportDivElements.length; b--; ) + if (this.highlightExportItem(b)) return !0; + return !1; + }; + a = function () {}; + a.prototype = new l(); + f(a.prototype, { + init: function () { + var b = this.chart, + c = this; + this.addEvent(b, "exportMenuShown", function () { + c.onMenuShown(); + }); + this.addEvent(b, "exportMenuHidden", function () { + c.onMenuHidden(); + }); + }, + onMenuHidden: function () { + var b = this.chart.exportContextMenu; + b && b.setAttribute("aria-hidden", "true"); + this.isExportMenuShown = !1; + this.setExportButtonExpandedState("false"); + }, + onMenuShown: function () { + var b = this.chart, + c = b.exportContextMenu; + c && (this.addAccessibleContextMenuAttribs(), q(b, c)); + this.isExportMenuShown = !0; + this.setExportButtonExpandedState("true"); + }, + setExportButtonExpandedState: function (b) { + var c = this.exportButtonProxy; + c && c.setAttribute("aria-expanded", b); + }, + onChartRender: function () { + var b = this.chart, + c = b.options.accessibility; + e(this.exportProxyGroup); + var a = b.options.exporting, + d = h(b); + a && + !1 !== a.enabled && + a.accessibility && + a.accessibility.enabled && + d && + d.element && + ((this.exportProxyGroup = this.addProxyGroup( + "all" === c.landmarkVerbosity + ? { + "aria-label": b.langFormat( + "accessibility.exporting.exportRegionLabel", + { chart: b } + ), + role: "region", + } + : {} + )), + (c = h(this.chart)), + (this.exportButtonProxy = this.createProxyButton( + c, + this.exportProxyGroup, + { + "aria-label": b.langFormat( + "accessibility.exporting.menuButtonLabel", + { chart: b } + ), + "aria-expanded": "false", + } + ))); + }, + addAccessibleContextMenuAttribs: function () { + var b = this.chart, + c = b.exportDivElements; + c && + c.length && + (c.forEach(function (b) { + "LI" !== b.tagName || (b.children && b.children.length) + ? b.setAttribute("aria-hidden", "true") + : b.setAttribute("tabindex", -1); + }), + (c = c[0].parentNode), + c.removeAttribute("aria-hidden"), + c.setAttribute( + "aria-label", + b.langFormat("accessibility.exporting.chartMenuLabel", { + chart: b, + }) + )); + }, + getKeyboardNavigation: function () { + var b = this.keyCodes, + c = this.chart, + a = this; + return new m(c, { + keyCodeMap: [ + [ + [b.left, b.up], + function () { + return a.onKbdPrevious(this); + }, + ], + [ + [b.right, b.down], + function () { + return a.onKbdNext(this); + }, + ], + [ + [b.enter, b.space], + function () { + return a.onKbdClick(this); + }, + ], + ], + validate: function () { + return ( + c.exportChart && + !1 !== c.options.exporting.enabled && + !1 !== c.options.exporting.accessibility.enabled + ); + }, + init: function () { + var b = a.exportButtonProxy, + d = c.exportingGroup; + d && b && c.setFocusToElement(d, b); + }, + terminate: function () { + c.hideExportMenu(); + }, + }); + }, + onKbdPrevious: function (b) { + var c = this.chart, + a = c.options.accessibility; + b = b.response; + for (var d = c.highlightedExportItemIx || 0; d--; ) + if (c.highlightExportItem(d)) return b.success; + return a.keyboardNavigation.wrapAround + ? (c.highlightLastExportItem(), b.success) + : b.prev; + }, + onKbdNext: function (b) { + var c = this.chart, + a = c.options.accessibility; + b = b.response; + for ( + var d = (c.highlightedExportItemIx || 0) + 1; + d < c.exportDivElements.length; + ++d + ) + if (c.highlightExportItem(d)) return b.success; + return a.keyboardNavigation.wrapAround + ? (c.highlightExportItem(0), b.success) + : b.next; + }, + onKbdClick: function (b) { + var c = this.chart, + a = c.exportDivElements[c.highlightedExportItemIx], + d = h(c).element; + this.isExportMenuShown + ? this.fakeClickEvent(a) + : (this.fakeClickEvent(d), c.highlightExportItem(0)); + return b.response.success; + }, + }); + return a; + } + ); + p( + a, + "Accessibility/Components/SeriesComponent/SeriesKeyboardNavigation.js", + [ + a["Core/Series/Series.js"], + a["Core/Series/CartesianSeries.js"], + a["Core/Chart/Chart.js"], + a["Core/Series/Point.js"], + a["Core/Utilities.js"], + a["Accessibility/KeyboardNavigationHandler.js"], + a["Accessibility/Utils/EventProvider.js"], + a["Accessibility/Utils/ChartUtilities.js"], + ], + function (a, f, l, m, n, g, h, q) { + function e(b) { + var c = b.index, + a = b.series.points, + d = a.length; + if (a[c] !== b) + for (; d--; ) { + if (a[d] === b) return d; + } + else return c; + } + function d(b) { + var c = + b.chart.options.accessibility.keyboardNavigation.seriesNavigation, + a = b.options.accessibility || {}, + d = a.keyboardNavigation; + return ( + (d && !1 === d.enabled) || + !1 === a.enabled || + !1 === b.options.enableMouseTracking || + !b.visible || + (c.pointNavigationEnabledThreshold && + c.pointNavigationEnabledThreshold <= b.points.length) + ); + } + function b(b) { + var c = b.series.chart.options.accessibility; + return ( + (b.isNull && c.keyboardNavigation.seriesNavigation.skipNullPoints) || + !1 === b.visible || + d(b.series) + ); + } + function c(b, c, a, d) { + var r = Infinity, + e = c.points.length, + k = function (b) { + return !(w(b.plotX) && w(b.plotY)); + }; + if (!k(b)) { + for (; e--; ) { + var g = c.points[e]; + if ( + !k(g) && + ((g = + (b.plotX - g.plotX) * (b.plotX - g.plotX) * (a || 1) + + (b.plotY - g.plotY) * (b.plotY - g.plotY) * (d || 1)), + g < r) + ) { + r = g; + var h = e; + } + } + return w(h) ? c.points[h] : void 0; + } + } + function k(b) { + var c = !1; + delete b.highlightedPoint; + return (c = b.series.reduce(function (b, c) { + return b || c.highlightFirstValidPoint(); + }, !1)); + } + function t(b, c) { + this.keyCodes = c; + this.chart = b; + } + var v = a.seriesTypes, + w = n.defined; + a = n.extend; + var u = q.getPointFromXY, + A = q.getSeriesFromName, + p = q.scrollToPoint; + f.prototype.keyboardMoveVertical = !0; + ["column", "pie"].forEach(function (b) { + v[b] && (v[b].prototype.keyboardMoveVertical = !1); + }); + m.prototype.highlight = function () { + var b = this.series.chart; + if (this.isNull) b.tooltip && b.tooltip.hide(0); + else this.onMouseOver(); + p(this); + this.graphic && b.setFocusToElement(this.graphic); + b.highlightedPoint = this; + return this; + }; + l.prototype.highlightAdjacentPoint = function (c) { + var a = this.series, + k = this.highlightedPoint, + r = (k && e(k)) || 0, + g = k && k.series.points, + h = this.series && this.series[this.series.length - 1]; + h = h && h.points && h.points[h.points.length - 1]; + if (!a[0] || !a[0].points) return !1; + if (k) { + if ( + ((a = a[k.series.index + (c ? 1 : -1)]), + (r = g[r + (c ? 1 : -1)]), + !r && a && (r = a.points[c ? 0 : a.points.length - 1]), + !r) + ) + return !1; + } else r = c ? a[0].points[0] : h; + return b(r) + ? ((a = r.series), + d(a) + ? (this.highlightedPoint = c + ? a.points[a.points.length - 1] + : a.points[0]) + : (this.highlightedPoint = r), + this.highlightAdjacentPoint(c)) + : r.highlight(); + }; + f.prototype.highlightFirstValidPoint = function () { + var c = this.chart.highlightedPoint, + a = (c && c.series) === this ? e(c) : 0; + c = this.points; + var d = c.length; + if (c && d) { + for (var r = a; r < d; ++r) if (!b(c[r])) return c[r].highlight(); + for (; 0 <= a; --a) if (!b(c[a])) return c[a].highlight(); + } + return !1; + }; + l.prototype.highlightAdjacentSeries = function (b) { + var a, + k = this.highlightedPoint; + var r = + (a = this.series && this.series[this.series.length - 1]) && + a.points && + a.points[a.points.length - 1]; + if (!this.highlightedPoint) + return ( + (a = b ? this.series && this.series[0] : a), + (r = b ? a && a.points && a.points[0] : r) ? r.highlight() : !1 + ); + a = this.series[k.series.index + (b ? -1 : 1)]; + if (!a) return !1; + r = c(k, a, 4); + if (!r) return !1; + if (d(a)) + return ( + r.highlight(), + (b = this.highlightAdjacentSeries(b)), + b ? b : (k.highlight(), !1) + ); + r.highlight(); + return r.series.highlightFirstValidPoint(); + }; + l.prototype.highlightAdjacentPointVertical = function (c) { + var a = this.highlightedPoint, + k = Infinity, + r; + if (!w(a.plotX) || !w(a.plotY)) return !1; + this.series.forEach(function (e) { + d(e) || + e.points.forEach(function (d) { + if (w(d.plotY) && w(d.plotX) && d !== a) { + var g = d.plotY - a.plotY, + h = Math.abs(d.plotX - a.plotX); + h = Math.abs(g) * Math.abs(g) + h * h * 4; + e.yAxis && e.yAxis.reversed && (g *= -1); + !((0 >= g && c) || (0 <= g && !c) || 5 > h || b(d)) && + h < k && + ((k = h), (r = d)); + } + }); + }); + return r ? r.highlight() : !1; + }; + a(t.prototype, { + init: function () { + var b = this, + c = this.chart, + a = (this.eventProvider = new h()); + a.addEvent(f, "destroy", function () { + return b.onSeriesDestroy(this); + }); + a.addEvent(c, "afterDrilldown", function () { + k(this); + this.focusElement && this.focusElement.removeFocusBorder(); + }); + a.addEvent(c, "drilldown", function (c) { + c = c.point; + var a = c.series; + b.lastDrilledDownPoint = { + x: c.x, + y: c.y, + seriesName: a ? a.name : "", + }; + }); + a.addEvent(c, "drillupall", function () { + setTimeout(function () { + b.onDrillupAll(); + }, 10); + }); + }, + onDrillupAll: function () { + var b = this.lastDrilledDownPoint, + c = this.chart, + a = b && A(c, b.seriesName), + d; + b && a && w(b.x) && w(b.y) && (d = u(a, b.x, b.y)); + c.container && c.container.focus(); + d && d.highlight && d.highlight(); + c.focusElement && c.focusElement.removeFocusBorder(); + }, + getKeyboardNavigationHandler: function () { + var b = this, + c = this.keyCodes, + a = this.chart, + d = a.inverted; + return new g(a, { + keyCodeMap: [ + [ + d ? [c.up, c.down] : [c.left, c.right], + function (c) { + return b.onKbdSideways(this, c); + }, + ], + [ + d ? [c.left, c.right] : [c.up, c.down], + function (c) { + return b.onKbdVertical(this, c); + }, + ], + [ + [c.enter, c.space], + function () { + a.highlightedPoint && + a.highlightedPoint.firePointEvent("click"); + return this.response.success; + }, + ], + ], + init: function (c) { + return b.onHandlerInit(this, c); + }, + terminate: function () { + return b.onHandlerTerminate(); + }, + }); + }, + onKbdSideways: function (b, c) { + var a = this.keyCodes; + return this.attemptHighlightAdjacentPoint( + b, + c === a.right || c === a.down + ); + }, + onKbdVertical: function (b, c) { + var a = this.chart, + d = this.keyCodes; + c = c === d.down || c === d.right; + d = a.options.accessibility.keyboardNavigation.seriesNavigation; + if (d.mode && "serialize" === d.mode) + return this.attemptHighlightAdjacentPoint(b, c); + a[ + a.highlightedPoint && a.highlightedPoint.series.keyboardMoveVertical + ? "highlightAdjacentPointVertical" + : "highlightAdjacentSeries" + ](c); + return b.response.success; + }, + onHandlerInit: function (b, c) { + var a = this.chart; + if (0 < c) k(a); + else { + c = a.series.length; + for ( + var d; + c-- && + !((a.highlightedPoint = + a.series[c].points[a.series[c].points.length - 1]), + (d = a.series[c].highlightFirstValidPoint())); + + ); + } + return b.response.success; + }, + onHandlerTerminate: function () { + var b, + c, + a = this.chart, + d = a.highlightedPoint; + null === (b = a.tooltip) || void 0 === b ? void 0 : b.hide(0); + null === (c = null === d || void 0 === d ? void 0 : d.onMouseOut) || + void 0 === c + ? void 0 + : c.call(d); + delete a.highlightedPoint; + }, + attemptHighlightAdjacentPoint: function (b, c) { + var a = this.chart, + d = a.options.accessibility.keyboardNavigation.wrapAround; + return a.highlightAdjacentPoint(c) + ? b.response.success + : d + ? b.init(c ? 1 : -1) + : b.response[c ? "next" : "prev"]; + }, + onSeriesDestroy: function (b) { + var c = this.chart; + c.highlightedPoint && + c.highlightedPoint.series === b && + (delete c.highlightedPoint, + c.focusElement && c.focusElement.removeFocusBorder()); + }, + destroy: function () { + this.eventProvider.removeAddedEvents(); + }, + }); + return t; + } + ); + p( + a, + "Accessibility/Components/AnnotationsA11y.js", + [a["Accessibility/Utils/HTMLUtilities.js"]], + function (a) { + function f(a) { + return (a.annotations || []).reduce(function (a, d) { + var b; + !1 !== + (null === (b = d.options) || void 0 === b ? void 0 : b.visible) && + (a = a.concat(d.labels)); + return a; + }, []); + } + function l(a) { + var e, + d, + b, + c, + k = + null === + (d = + null === (e = a.options) || void 0 === e + ? void 0 + : e.accessibility) || void 0 === d + ? void 0 + : d.description; + return k + ? k + : (null === + (c = + null === (b = a.graphic) || void 0 === b ? void 0 : b.text) || + void 0 === c + ? void 0 + : c.textStr) || ""; + } + function m(a) { + var e, + d, + b = + null === + (d = + null === (e = a.options) || void 0 === e + ? void 0 + : e.accessibility) || void 0 === d + ? void 0 + : d.description; + if (b) return b; + e = a.chart; + d = l(a); + b = a.points + .filter(function (b) { + return !!b.graphic; + }) + .map(function (b) { + var c, a; + if ( + !(a = + null === + (c = null === b || void 0 === b ? void 0 : b.accessibility) || + void 0 === c + ? void 0 + : c.valueDescription) + ) { + var d, e; + a = + (null === + (e = + null === + (d = null === b || void 0 === b ? void 0 : b.graphic) || + void 0 === d + ? void 0 + : d.element) || void 0 === e + ? void 0 + : e.getAttribute("aria-label")) || ""; + } + b = (null === b || void 0 === b ? void 0 : b.series.name) || ""; + return (b ? b + ", " : "") + "data point " + a; + }) + .filter(function (b) { + return !!b; + }); + var c = b.length; + a = + "accessibility.screenReaderSection.annotations.description" + + (1 < c ? "MultiplePoints" : c ? "SinglePoint" : "NoPoints"); + d = { + annotationText: d, + numPoints: c, + annotationPoint: b[0], + additionalAnnotationPoints: b.slice(1), + }; + return e.langFormat(a, d); + } + function n(a) { + return f(a).map(function (a) { + return (a = g(h(m(a)))) ? "<li>" + a + "</li>" : ""; + }); + } + var g = a.escapeStringForHTML, + h = a.stripHTMLTagsFromString; + return { + getAnnotationsInfoHTML: function (a) { + var e = a.annotations; + return e && e.length ? "<ul>" + n(a).join(" ") + "</ul>" : ""; + }, + getAnnotationLabelDescription: m, + getAnnotationListItems: n, + getPointAnnotationTexts: function (a) { + var e = f(a.series.chart).filter(function (d) { + return -1 < d.points.indexOf(a); + }); + return e.length + ? e.map(function (a) { + return "" + l(a); + }) + : []; + }, + }; + } + ); + p( + a, + "Accessibility/Components/SeriesComponent/SeriesDescriber.js", + [ + a["Accessibility/Components/AnnotationsA11y.js"], + a["Accessibility/Utils/ChartUtilities.js"], + a["Accessibility/Utils/HTMLUtilities.js"], + a["Core/Tooltip.js"], + a["Core/Utilities.js"], + ], + function (a, f, l, m, n) { + function g(b) { + var c = b.index; + return b.series && b.series.data && G(c) + ? K(b.series.data, function (b) { + return !!( + b && + "undefined" !== typeof b.index && + b.index > c && + b.graphic && + b.graphic.element + ); + }) || null + : null; + } + function h(b) { + var c = + b.chart.options.accessibility.series.pointDescriptionEnabledThreshold; + return !!(!1 !== c && b.points && b.points.length >= c); + } + function q(b) { + var c = b.options.accessibility || {}; + return !h(b) && !c.exposeAsGroupOnly; + } + function e(b) { + var c = + b.chart.options.accessibility.keyboardNavigation.seriesNavigation; + return !( + !b.points || + !( + b.points.length < c.pointNavigationEnabledThreshold || + !1 === c.pointNavigationEnabledThreshold + ) + ); + } + function d(b, c) { + var a = b.series.chart, + d = a.options.accessibility.point || {}; + b = b.series.tooltipOptions || {}; + a = a.options.lang; + return L(c) + ? M( + c, + d.valueDecimals || b.valueDecimals || -1, + a.decimalPoint, + a.accessibility.thousandsSep || a.thousandsSep + ) + : c; + } + function b(b) { + var c = (b.options.accessibility || {}).description; + return ( + (c && + b.chart.langFormat("accessibility.series.description", { + description: c, + series: b, + })) || + "" + ); + } + function c(b, c) { + return b.chart.langFormat("accessibility.series." + c + "Description", { + name: x(b[c]), + series: b, + }); + } + function k(b) { + var c = b.series, + a = c.chart, + d = a.options.accessibility.point || {}; + if (c.xAxis && c.xAxis.dateTime) + return ( + (c = m.prototype.getXDateFormat.call( + { getDateFormat: m.prototype.getDateFormat, chart: a }, + b, + a.options.tooltip, + c.xAxis + )), + (d = (d.dateFormatter && d.dateFormatter(b)) || d.dateFormat || c), + a.time.dateFormat(d, b.x, void 0) + ); + } + function t(b) { + var c = k(b), + a = + (b.series.xAxis || {}).categories && + G(b.category) && + ("" + b.category).replace("<br/>", " "), + d = b.id && 0 > b.id.indexOf("highcharts-"), + e = "x, " + b.x; + return b.name || c || a || (d ? b.id : e); + } + function v(b, c, a) { + var e = c || "", + k = a || ""; + return b.series.pointArrayMap.reduce(function (c, a) { + c += c.length ? ", " : ""; + var r = d(b, C(b[a], b.options[a])); + return c + (a + ": " + e + r + k); + }, ""); + } + function w(b) { + var c = b.series, + a = c.chart.options.accessibility.point || {}, + e = c.tooltipOptions || {}, + k = a.valuePrefix || e.valuePrefix || ""; + a = a.valueSuffix || e.valueSuffix || ""; + e = d(b, b["undefined" !== typeof b.value ? "value" : "y"]); + return b.isNull + ? c.chart.langFormat("accessibility.series.nullPointValue", { + point: b, + }) + : c.pointArrayMap + ? v(b, k, a) + : k + e + a; + } + function u(b) { + var c = b.series, + a = c.chart, + d = a.options.accessibility.point.valueDescriptionFormat, + e = (c = C( + c.xAxis && + c.xAxis.options.accessibility && + c.xAxis.options.accessibility.enabled, + !a.angular + )) + ? t(b) + : ""; + b = { + point: b, + index: G(b.index) ? b.index + 1 : "", + xDescription: e, + value: w(b), + separator: c ? ", " : "", + }; + return N(d, b, a); + } + function A(b) { + var c = b.series, + a = c.chart, + d = u(b), + e = + b.options && + b.options.accessibility && + b.options.accessibility.description; + e = e ? " " + e : ""; + c = 1 < a.series.length && c.name ? " " + c.name + "." : ""; + a = b.series.chart; + var k = z(b), + r = { point: b, annotations: k }; + a = k.length + ? a.langFormat("accessibility.series.pointAnnotationsDescription", r) + : ""; + b.accessibility = b.accessibility || {}; + b.accessibility.valueDescription = d; + return d + e + c + (a ? " " + a : ""); + } + function p(b) { + var c = q(b), + a = e(b); + (c || a) && + b.points.forEach(function (b) { + var a; + if ( + !(a = b.graphic && b.graphic.element) && + ((a = b.series && b.series.is("sunburst")), (a = b.isNull && !a)) + ) { + var d = b.series, + e = g(b); + d = (a = e && e.graphic) ? a.parentGroup : d.graph || d.group; + e = e + ? { x: C(b.plotX, e.plotX, 0), y: C(b.plotY, e.plotY, 0) } + : { x: C(b.plotX, 0), y: C(b.plotY, 0) }; + e = b.series.chart.renderer.rect(e.x, e.y, 1, 1); + e.attr({ + class: "highcharts-a11y-dummy-point", + fill: "none", + opacity: 0, + "fill-opacity": 0, + "stroke-opacity": 0, + }); + d && d.element + ? ((b.graphic = e), + (b.hasDummyGraphic = !0), + e.add(d), + d.element.insertBefore(e.element, a ? a.element : null), + (a = e.element)) + : (a = void 0); + } + a && + (a.setAttribute("tabindex", "-1"), + (a.style.outline = "0"), + c + ? ((e = b.series), + (d = e.chart.options.accessibility.point || {}), + (e = e.options.accessibility || {}), + (b = B( + I( + (e.pointDescriptionFormatter && + e.pointDescriptionFormatter(b)) || + (d.descriptionFormatter && d.descriptionFormatter(b)) || + A(b) + ) + )), + a.setAttribute("role", "img"), + a.setAttribute("aria-label", b)) + : a.setAttribute("aria-hidden", !0)); + }); + } + function y(a) { + var d = a.chart, + e = d.types || [], + k = b(a), + r = function (b) { + return d[b] && 1 < d[b].length && a[b]; + }, + g = c(a, "xAxis"), + h = c(a, "yAxis"), + f = { + name: a.name || "", + ix: a.index + 1, + numSeries: d.series && d.series.length, + numPoints: a.points && a.points.length, + series: a, + }; + e = 1 < e.length ? "Combination" : ""; + return ( + (d.langFormat("accessibility.series.summary." + a.type + e, f) || + d.langFormat("accessibility.series.summary.default" + e, f)) + + (k ? " " + k : "") + + (r("yAxis") ? " " + h : "") + + (r("xAxis") ? " " + g : "") + ); + } + var z = a.getPointAnnotationTexts, + x = f.getAxisDescription, + r = f.getSeriesFirstPointElement, + J = f.getSeriesA11yElement, + F = f.unhideChartElementFromAT, + B = l.escapeStringForHTML, + E = l.reverseChildNodes, + I = l.stripHTMLTagsFromString, + K = n.find, + N = n.format, + L = n.isNumber, + M = n.numberFormat, + C = n.pick, + G = n.defined; + return { + describeSeries: function (b) { + var c = b.chart, + a = r(b), + d = J(b), + e = c.is3d && c.is3d(); + if (d) { + d.lastChild !== a || e || E(d); + p(b); + F(c, d); + e = b.chart; + c = e.options.chart || {}; + a = 1 < e.series.length; + e = e.options.accessibility.series.describeSingleSeries; + var k = (b.options.accessibility || {}).exposeAsGroupOnly; + (c.options3d && c.options3d.enabled && a) || !(a || e || k || h(b)) + ? d.setAttribute("aria-label", "") + : ((c = b.chart.options.accessibility), + (a = c.landmarkVerbosity), + (b.options.accessibility || {}).exposeAsGroupOnly + ? d.setAttribute("role", "img") + : "all" === a && d.setAttribute("role", "region"), + d.setAttribute("tabindex", "-1"), + (d.style.outline = "0"), + d.setAttribute( + "aria-label", + B( + I( + (c.series.descriptionFormatter && + c.series.descriptionFormatter(b)) || + y(b) + ) + ) + )); + } + }, + defaultPointDescriptionFormatter: A, + defaultSeriesDescriptionFormatter: y, + getPointA11yTimeDescription: k, + getPointXDescription: t, + getPointValue: w, + getPointValueDescription: u, + }; + } + ); + p( + a, + "Accessibility/Utils/Announcer.js", + [ + a["Core/Globals.js"], + a["Accessibility/Utils/DOMElementProvider.js"], + a["Accessibility/Utils/HTMLUtilities.js"], + ], + function (a, f, l) { + var m = l.visuallyHideElement; + l = (function () { + function a(a, h) { + this.chart = a; + this.domElementProvider = new f(); + this.announceRegion = this.addAnnounceRegion(h); + } + a.prototype.destroy = function () { + this.domElementProvider.destroyCreatedElements(); + }; + a.prototype.announce = function (a) { + var g = this; + this.announceRegion.innerHTML = a; + this.clearAnnouncementRegionTimer && + clearTimeout(this.clearAnnouncementRegionTimer); + this.clearAnnouncementRegionTimer = setTimeout(function () { + g.announceRegion.innerHTML = ""; + delete g.clearAnnouncementRegionTimer; + }, 1e3); + }; + a.prototype.addAnnounceRegion = function (a) { + var g = this.chart.renderTo, + f = this.domElementProvider.createElement("div"); + f.setAttribute("aria-hidden", !1); + f.setAttribute("aria-live", a); + m(f); + g.insertBefore(f, g.firstChild); + return f; + }; + return a; + })(); + return (a.Announcer = l); + } + ); + p( + a, + "Accessibility/Components/SeriesComponent/NewDataAnnouncer.js", + [ + a["Core/Globals.js"], + a["Core/Series/CartesianSeries.js"], + a["Core/Utilities.js"], + a["Accessibility/Utils/ChartUtilities.js"], + a["Accessibility/Components/SeriesComponent/SeriesDescriber.js"], + a["Accessibility/Utils/Announcer.js"], + a["Accessibility/Utils/EventProvider.js"], + ], + function (a, f, l, m, n, g, h) { + function q(b) { + var c = b.series.data.filter(function (c) { + return b.x === c.x && b.y === c.y; + }); + return 1 === c.length ? c[0] : b; + } + function e(b, c) { + var a = (b || []).concat(c || []).reduce(function (b, c) { + b[c.name + c.index] = c; + return b; + }, {}); + return Object.keys(a).map(function (b) { + return a[b]; + }); + } + var d = l.extend, + b = l.defined, + c = m.getChartTitle, + k = n.defaultPointDescriptionFormatter, + t = n.defaultSeriesDescriptionFormatter; + l = function (b) { + this.chart = b; + }; + d(l.prototype, { + init: function () { + var b = this.chart, + c = b.options.accessibility.announceNewData.interruptUser + ? "assertive" + : "polite"; + this.lastAnnouncementTime = 0; + this.dirty = { allSeries: {} }; + this.eventProvider = new h(); + this.announcer = new g(b, c); + this.addEventListeners(); + }, + destroy: function () { + this.eventProvider.removeAddedEvents(); + this.announcer.destroy(); + }, + addEventListeners: function () { + var b = this, + c = this.chart, + a = this.eventProvider; + a.addEvent(c, "afterDrilldown", function () { + b.lastAnnouncementTime = 0; + }); + a.addEvent(f, "updatedData", function () { + b.onSeriesUpdatedData(this); + }); + a.addEvent(c, "afterAddSeries", function (c) { + b.onSeriesAdded(c.series); + }); + a.addEvent(f, "addPoint", function (c) { + b.onPointAdded(c.point); + }); + a.addEvent(c, "redraw", function () { + b.announceDirtyData(); + }); + }, + onSeriesUpdatedData: function (b) { + var c = this.chart; + b.chart === c && + c.options.accessibility.announceNewData.enabled && + ((this.dirty.hasDirty = !0), + (this.dirty.allSeries[b.name + b.index] = b)); + }, + onSeriesAdded: function (c) { + this.chart.options.accessibility.announceNewData.enabled && + ((this.dirty.hasDirty = !0), + (this.dirty.allSeries[c.name + c.index] = c), + (this.dirty.newSeries = b(this.dirty.newSeries) ? void 0 : c)); + }, + onPointAdded: function (c) { + var a = c.series.chart; + this.chart === a && + a.options.accessibility.announceNewData.enabled && + (this.dirty.newPoint = b(this.dirty.newPoint) ? void 0 : c); + }, + announceDirtyData: function () { + var b = this; + if ( + this.chart.options.accessibility.announceNewData && + this.dirty.hasDirty + ) { + var c = this.dirty.newPoint; + c && (c = q(c)); + this.queueAnnouncement( + Object.keys(this.dirty.allSeries).map(function (c) { + return b.dirty.allSeries[c]; + }), + this.dirty.newSeries, + c + ); + this.dirty = { allSeries: {} }; + } + }, + queueAnnouncement: function (b, c, a) { + var d = this, + k = this.chart.options.accessibility.announceNewData; + if (k.enabled) { + var g = +new Date(); + k = Math.max( + 0, + k.minAnnounceInterval - (g - this.lastAnnouncementTime) + ); + b = e(this.queuedAnnouncement && this.queuedAnnouncement.series, b); + if ((c = this.buildAnnouncementMessage(b, c, a))) + this.queuedAnnouncement && + clearTimeout(this.queuedAnnouncementTimer), + (this.queuedAnnouncement = { time: g, message: c, series: b }), + (this.queuedAnnouncementTimer = setTimeout(function () { + d && + d.announcer && + ((d.lastAnnouncementTime = +new Date()), + d.announcer.announce(d.queuedAnnouncement.message), + delete d.queuedAnnouncement, + delete d.queuedAnnouncementTimer); + }, k)); + } + }, + buildAnnouncementMessage: function (b, d, e) { + var g = this.chart, + h = g.options.accessibility.announceNewData; + if ( + h.announcementFormatter && + ((b = h.announcementFormatter(b, d, e)), !1 !== b) + ) + return b.length ? b : null; + b = a.charts && 1 < a.charts.length ? "Multiple" : "Single"; + b = d + ? "newSeriesAnnounce" + b + : e + ? "newPointAnnounce" + b + : "newDataAnnounce"; + h = c(g); + return g.langFormat("accessibility.announceNewData." + b, { + chartTitle: h, + seriesDesc: d ? t(d) : null, + pointDesc: e ? k(e) : null, + point: e, + series: d, + }); + }, + }); + return l; + } + ); + p( + a, + "Accessibility/Components/SeriesComponent/ForcedMarkers.js", + [a["Core/Series/CartesianSeries.js"], a["Core/Utilities.js"]], + function (a, f) { + function l(a) { + n(!0, a, { + marker: { enabled: !0, states: { normal: { opacity: 0 } } }, + }); + } + var m = f.addEvent, + n = f.merge; + return function () { + m(a, "render", function () { + var a = this.options, + h = + !1 !== + (this.options.accessibility && + this.options.accessibility.enabled); + if ((h = this.chart.options.accessibility.enabled && h)) + (h = this.chart.options.accessibility), + (h = + this.points.length < + h.series.pointDescriptionEnabledThreshold || + !1 === h.series.pointDescriptionEnabledThreshold); + if (h) { + if ( + (a.marker && + !1 === a.marker.enabled && + ((this.a11yMarkersForced = !0), l(this.options)), + this._hasPointMarkers && this.points && this.points.length) + ) + for (a = this.points.length; a--; ) { + h = this.points[a]; + var f = h.options; + delete h.hasForcedA11yMarker; + f.marker && + (f.marker.enabled + ? (n(!0, f.marker, { + states: { + normal: { + opacity: + (f.marker.states && + f.marker.states.normal && + f.marker.states.normal.opacity) || + 1, + }, + }, + }), + (h.hasForcedA11yMarker = !1)) + : (l(f), (h.hasForcedA11yMarker = !0))); + } + } else this.a11yMarkersForced && (delete this.a11yMarkersForced, (a = this.resetA11yMarkerOptions) && n(!0, this.options, { marker: { enabled: a.enabled, states: { normal: { opacity: a.states && a.states.normal && a.states.normal.opacity } } } })); + }); + m(a, "afterSetOptions", function (a) { + this.resetA11yMarkerOptions = n( + a.options.marker || {}, + this.userOptions.marker || {} + ); + }); + m(a, "afterRender", function () { + if (this.chart.styledMode) { + if (this.markerGroup) + this.markerGroup[ + this.a11yMarkersForced ? "addClass" : "removeClass" + ]("highcharts-a11y-markers-hidden"); + this._hasPointMarkers && + this.points && + this.points.length && + this.points.forEach(function (a) { + a.graphic && + (a.graphic[ + a.hasForcedA11yMarker ? "addClass" : "removeClass" + ]("highcharts-a11y-marker-hidden"), + a.graphic[ + !1 === a.hasForcedA11yMarker ? "addClass" : "removeClass" + ]("highcharts-a11y-marker-visible")); + }); + } + }); + }; + } + ); + p( + a, + "Accessibility/Components/SeriesComponent/SeriesComponent.js", + [ + a["Core/Globals.js"], + a["Core/Utilities.js"], + a["Accessibility/AccessibilityComponent.js"], + a["Accessibility/Components/SeriesComponent/SeriesKeyboardNavigation.js"], + a["Accessibility/Components/SeriesComponent/NewDataAnnouncer.js"], + a["Accessibility/Components/SeriesComponent/ForcedMarkers.js"], + a["Accessibility/Utils/ChartUtilities.js"], + a["Accessibility/Components/SeriesComponent/SeriesDescriber.js"], + a["Core/Tooltip.js"], + ], + function (a, f, l, m, n, g, h, q, e) { + f = f.extend; + var d = h.hideSeriesFromAT, + b = q.describeSeries; + a.SeriesAccessibilityDescriber = q; + g(); + a = function () {}; + a.prototype = new l(); + f(a.prototype, { + init: function () { + this.newDataAnnouncer = new n(this.chart); + this.newDataAnnouncer.init(); + this.keyboardNavigation = new m(this.chart, this.keyCodes); + this.keyboardNavigation.init(); + this.hideTooltipFromATWhenShown(); + this.hideSeriesLabelsFromATWhenShown(); + }, + hideTooltipFromATWhenShown: function () { + var b = this; + this.addEvent(e, "refresh", function () { + this.chart === b.chart && + this.label && + this.label.element && + this.label.element.setAttribute("aria-hidden", !0); + }); + }, + hideSeriesLabelsFromATWhenShown: function () { + this.addEvent(this.chart, "afterDrawSeriesLabels", function () { + this.series.forEach(function (b) { + b.labelBySeries && b.labelBySeries.attr("aria-hidden", !0); + }); + }); + }, + onChartRender: function () { + this.chart.series.forEach(function (c) { + !1 !== + (c.options.accessibility && c.options.accessibility.enabled) && + c.visible + ? b(c) + : d(c); + }); + }, + getKeyboardNavigation: function () { + return this.keyboardNavigation.getKeyboardNavigationHandler(); + }, + destroy: function () { + this.newDataAnnouncer.destroy(); + this.keyboardNavigation.destroy(); + }, + }); + return a; + } + ); + p( + a, + "Accessibility/Components/ZoomComponent.js", + [ + a["Accessibility/AccessibilityComponent.js"], + a["Accessibility/Utils/ChartUtilities.js"], + a["Core/Globals.js"], + a["Accessibility/Utils/HTMLUtilities.js"], + a["Accessibility/KeyboardNavigationHandler.js"], + a["Core/Utilities.js"], + ], + function (a, f, l, m, n, g) { + var h = f.unhideChartElementFromAT; + f = l.noop; + var q = m.removeElement, + e = m.setElAttrs; + m = g.extend; + var d = g.pick; + l.Axis.prototype.panStep = function (b, c) { + var a = c || 3; + c = this.getExtremes(); + var d = ((c.max - c.min) / a) * b; + a = c.max + d; + d = c.min + d; + var e = a - d; + 0 > b && d < c.dataMin + ? ((d = c.dataMin), (a = d + e)) + : 0 < b && a > c.dataMax && ((a = c.dataMax), (d = a - e)); + this.setExtremes(d, a); + }; + f.prototype = new a(); + m(f.prototype, { + init: function () { + var b = this, + c = this.chart; + ["afterShowResetZoom", "afterDrilldown", "drillupall"].forEach( + function (a) { + b.addEvent(c, a, function () { + b.updateProxyOverlays(); + }); + } + ); + }, + onChartUpdate: function () { + var b = this.chart, + c = this; + b.mapNavButtons && + b.mapNavButtons.forEach(function (a, d) { + h(b, a.element); + c.setMapNavButtonAttrs( + a.element, + "accessibility.zoom.mapZoom" + (d ? "Out" : "In") + ); + }); + }, + setMapNavButtonAttrs: function (b, c) { + var a = this.chart; + c = a.langFormat(c, { chart: a }); + e(b, { tabindex: -1, role: "button", "aria-label": c }); + }, + onChartRender: function () { + this.updateProxyOverlays(); + }, + updateProxyOverlays: function () { + var b = this.chart; + q(this.drillUpProxyGroup); + q(this.resetZoomProxyGroup); + b.resetZoomButton && + this.recreateProxyButtonAndGroup( + b.resetZoomButton, + "resetZoomProxyButton", + "resetZoomProxyGroup", + b.langFormat("accessibility.zoom.resetZoomButton", { chart: b }) + ); + b.drillUpButton && + this.recreateProxyButtonAndGroup( + b.drillUpButton, + "drillUpProxyButton", + "drillUpProxyGroup", + b.langFormat("accessibility.drillUpButton", { + chart: b, + buttonText: b.getDrilldownBackText(), + }) + ); + }, + recreateProxyButtonAndGroup: function (b, c, a, d) { + q(this[a]); + this[a] = this.addProxyGroup(); + this[c] = this.createProxyButton(b, this[a], { + "aria-label": d, + tabindex: -1, + }); + }, + getMapZoomNavigation: function () { + var b = this.keyCodes, + a = this.chart, + d = this; + return new n(a, { + keyCodeMap: [ + [ + [b.up, b.down, b.left, b.right], + function (b) { + return d.onMapKbdArrow(this, b); + }, + ], + [ + [b.tab], + function (b, a) { + return d.onMapKbdTab(this, a); + }, + ], + [ + [b.space, b.enter], + function () { + return d.onMapKbdClick(this); + }, + ], + ], + validate: function () { + return !!(a.mapZoom && a.mapNavButtons && a.mapNavButtons.length); + }, + init: function (b) { + return d.onMapNavInit(b); + }, + }); + }, + onMapKbdArrow: function (b, a) { + var c = this.keyCodes; + this.chart[a === c.up || a === c.down ? "yAxis" : "xAxis"][0].panStep( + a === c.left || a === c.up ? -1 : 1 + ); + return b.response.success; + }, + onMapKbdTab: function (b, a) { + var c = this.chart; + b = b.response; + var d = + ((a = a.shiftKey) && !this.focusedMapNavButtonIx) || + (!a && this.focusedMapNavButtonIx); + c.mapNavButtons[this.focusedMapNavButtonIx].setState(0); + if (d) return c.mapZoom(), b[a ? "prev" : "next"]; + this.focusedMapNavButtonIx += a ? -1 : 1; + a = c.mapNavButtons[this.focusedMapNavButtonIx]; + c.setFocusToElement(a.box, a.element); + a.setState(2); + return b.success; + }, + onMapKbdClick: function (b) { + this.fakeClickEvent( + this.chart.mapNavButtons[this.focusedMapNavButtonIx].element + ); + return b.response.success; + }, + onMapNavInit: function (b) { + var a = this.chart, + d = a.mapNavButtons[0], + e = a.mapNavButtons[1]; + d = 0 < b ? d : e; + a.setFocusToElement(d.box, d.element); + d.setState(2); + this.focusedMapNavButtonIx = 0 < b ? 0 : 1; + }, + simpleButtonNavigation: function (b, a, e) { + var c = this.keyCodes, + k = this, + g = this.chart; + return new n(g, { + keyCodeMap: [ + [ + [c.tab, c.up, c.down, c.left, c.right], + function (b, a) { + return this.response[ + (b === c.tab && a.shiftKey) || b === c.left || b === c.up + ? "prev" + : "next" + ]; + }, + ], + [ + [c.space, c.enter], + function () { + var b = e(this, g); + return d(b, this.response.success); + }, + ], + ], + validate: function () { + return g[b] && g[b].box && k[a]; + }, + init: function () { + g.setFocusToElement(g[b].box, k[a]); + }, + }); + }, + getKeyboardNavigation: function () { + return [ + this.simpleButtonNavigation( + "resetZoomButton", + "resetZoomProxyButton", + function (b, a) { + a.zoomOut(); + } + ), + this.simpleButtonNavigation( + "drillUpButton", + "drillUpProxyButton", + function (b, a) { + a.drillUp(); + return b.response.prev; + } + ), + this.getMapZoomNavigation(), + ]; + }, + }); + return f; + } + ); + p( + a, + "Accessibility/Components/RangeSelectorComponent.js", + [ + a["Accessibility/AccessibilityComponent.js"], + a["Accessibility/Utils/ChartUtilities.js"], + a["Core/Globals.js"], + a["Accessibility/Utils/HTMLUtilities.js"], + a["Accessibility/KeyboardNavigationHandler.js"], + a["Core/Utilities.js"], + ], + function (a, f, l, m, n, g) { + var h = f.unhideChartElementFromAT, + q = m.setElAttrs; + f = g.extend; + l.Chart.prototype.highlightRangeSelectorButton = function (a) { + var d = this.rangeSelector.buttons, + b = this.highlightedRangeSelectorItemIx; + "undefined" !== typeof b && + d[b] && + d[b].setState(this.oldRangeSelectorItemState || 0); + this.highlightedRangeSelectorItemIx = a; + return d[a] + ? (this.setFocusToElement(d[a].box, d[a].element), + (this.oldRangeSelectorItemState = d[a].state), + d[a].setState(2), + !0) + : !1; + }; + l = function () {}; + l.prototype = new a(); + f(l.prototype, { + onChartUpdate: function () { + var a = this.chart, + d = this, + b = a.rangeSelector; + b && + (b.buttons && + b.buttons.length && + b.buttons.forEach(function (b) { + h(a, b.element); + d.setRangeButtonAttrs(b); + }), + b.maxInput && + b.minInput && + ["minInput", "maxInput"].forEach(function (c, e) { + if ((c = b[c])) + h(a, c), + d.setRangeInputAttrs( + c, + "accessibility.rangeSelector." + + (e ? "max" : "min") + + "InputLabel" + ); + })); + }, + setRangeButtonAttrs: function (a) { + var d = this.chart; + d = d.langFormat("accessibility.rangeSelector.buttonText", { + chart: d, + buttonText: a.text && a.text.textStr, + }); + q(a.element, { tabindex: -1, role: "button", "aria-label": d }); + }, + setRangeInputAttrs: function (a, d) { + var b = this.chart; + q(a, { + tabindex: -1, + role: "textbox", + "aria-label": b.langFormat(d, { chart: b }), + }); + }, + getRangeSelectorButtonNavigation: function () { + var a = this.chart, + d = this.keyCodes, + b = this; + return new n(a, { + keyCodeMap: [ + [ + [d.left, d.right, d.up, d.down], + function (a) { + return b.onButtonNavKbdArrowKey(this, a); + }, + ], + [ + [d.enter, d.space], + function () { + return b.onButtonNavKbdClick(this); + }, + ], + ], + validate: function () { + return ( + a.rangeSelector && + a.rangeSelector.buttons && + a.rangeSelector.buttons.length + ); + }, + init: function (b) { + var c = a.rangeSelector.buttons.length - 1; + a.highlightRangeSelectorButton(0 < b ? 0 : c); + }, + }); + }, + onButtonNavKbdArrowKey: function (a, d) { + var b = a.response, + c = this.keyCodes, + e = this.chart, + g = e.options.accessibility.keyboardNavigation.wrapAround; + d = d === c.left || d === c.up ? -1 : 1; + return e.highlightRangeSelectorButton( + e.highlightedRangeSelectorItemIx + d + ) + ? b.success + : g + ? (a.init(d), b.success) + : b[0 < d ? "next" : "prev"]; + }, + onButtonNavKbdClick: function (a) { + a = a.response; + var d = this.chart; + 3 !== d.oldRangeSelectorItemState && + this.fakeClickEvent( + d.rangeSelector.buttons[d.highlightedRangeSelectorItemIx].element + ); + return a.success; + }, + getRangeSelectorInputNavigation: function () { + var a = this.chart, + d = this.keyCodes, + b = this; + return new n(a, { + keyCodeMap: [ + [ + [d.tab, d.up, d.down], + function (a, e) { + return b.onInputKbdMove( + this, + (a === d.tab && e.shiftKey) || a === d.up ? -1 : 1 + ); + }, + ], + ], + validate: function () { + return ( + a.rangeSelector && + a.rangeSelector.inputGroup && + "hidden" !== + a.rangeSelector.inputGroup.element.getAttribute( + "visibility" + ) && + !1 !== a.options.rangeSelector.inputEnabled && + a.rangeSelector.minInput && + a.rangeSelector.maxInput + ); + }, + init: function (a) { + b.onInputNavInit(a); + }, + terminate: function () { + b.onInputNavTerminate(); + }, + }); + }, + onInputKbdMove: function (a, d) { + var b = this.chart; + a = a.response; + var c = (b.highlightedInputRangeIx += d); + if (1 < c || 0 > c) return a[0 < d ? "next" : "prev"]; + b.rangeSelector[c ? "maxInput" : "minInput"].focus(); + return a.success; + }, + onInputNavInit: function (a) { + var d = this.chart; + a = 0 < a ? 0 : 1; + d.highlightedInputRangeIx = a; + d.rangeSelector[a ? "maxInput" : "minInput"].focus(); + }, + onInputNavTerminate: function () { + var a = this.chart.rangeSelector || {}; + a.maxInput && a.hideInput("max"); + a.minInput && a.hideInput("min"); + }, + getKeyboardNavigation: function () { + return [ + this.getRangeSelectorButtonNavigation(), + this.getRangeSelectorInputNavigation(), + ]; + }, + }); + return l; + } + ); + p( + a, + "Accessibility/Components/InfoRegionsComponent.js", + [ + a["Core/Globals.js"], + a["Core/Utilities.js"], + a["Accessibility/AccessibilityComponent.js"], + a["Accessibility/Utils/Announcer.js"], + a["Accessibility/Components/AnnotationsA11y.js"], + a["Accessibility/Utils/ChartUtilities.js"], + a["Accessibility/Utils/HTMLUtilities.js"], + ], + function (a, f, l, m, n, g, h) { + function q(b) { + return b + .replace(/<(h[1-7]|p|div|ul|ol|li)>/g, "<$1>") + .replace(/</(h[1-7]|p|div|ul|ol|li|a|button)>/g, "</$1>") + .replace( + /<(div|a|button) id="([a-zA-Z\-0-9#]*?)">/g, + '<$1 id="$2">' + ); + } + var e = a.doc, + d = f.extend, + b = f.format, + c = f.pick, + k = n.getAnnotationsInfoHTML, + t = g.unhideChartElementFromAT, + v = g.getChartTitle, + w = g.getAxisDescription, + p = h.addClass, + u = h.setElAttrs, + D = h.escapeStringForHTML, + y = h.stripHTMLTagsFromString, + z = h.getElement, + x = h.visuallyHideElement; + a.Chart.prototype.getTypeDescription = function (b) { + var a = b[0], + c = (this.series && this.series[0]) || {}; + c = { + numSeries: this.series.length, + numPoints: c.points && c.points.length, + chart: this, + mapTitle: c.mapTitle, + }; + if (!a) + return this.langFormat("accessibility.chartTypes.emptyChart", c); + if ("map" === a) + return c.mapTitle + ? this.langFormat("accessibility.chartTypes.mapTypeDescription", c) + : this.langFormat("accessibility.chartTypes.unknownMap", c); + if (1 < this.types.length) + return this.langFormat( + "accessibility.chartTypes.combinationChart", + c + ); + b = b[0]; + a = this.langFormat("accessibility.seriesTypeDescriptions." + b, c); + var d = this.series && 2 > this.series.length ? "Single" : "Multiple"; + return ( + (this.langFormat("accessibility.chartTypes." + b + d, c) || + this.langFormat("accessibility.chartTypes.default" + d, c)) + + (a ? " " + a : "") + ); + }; + f = function () {}; + f.prototype = new l(); + d(f.prototype, { + init: function () { + var b = this.chart, + a = this; + this.initRegionsDefinitions(); + this.addEvent(b, "afterGetTable", function (b) { + a.onDataTableCreated(b); + }); + this.addEvent(b, "afterViewData", function (b) { + a.dataTableDiv = b; + setTimeout(function () { + a.focusDataTable(); + }, 300); + }); + this.announcer = new m(b, "assertive"); + }, + initRegionsDefinitions: function () { + var b = this; + this.screenReaderSections = { + before: { + element: null, + buildContent: function (a) { + var c = + a.options.accessibility.screenReaderSection + .beforeChartFormatter; + return c ? c(a) : b.defaultBeforeChartFormatter(a); + }, + insertIntoDOM: function (b, a) { + a.renderTo.insertBefore(b, a.renderTo.firstChild); + }, + afterInserted: function () { + "undefined" !== typeof b.sonifyButtonId && + b.initSonifyButton(b.sonifyButtonId); + "undefined" !== typeof b.dataTableButtonId && + b.initDataTableButton(b.dataTableButtonId); + }, + }, + after: { + element: null, + buildContent: function (a) { + var c = + a.options.accessibility.screenReaderSection + .afterChartFormatter; + return c ? c(a) : b.defaultAfterChartFormatter(); + }, + insertIntoDOM: function (b, a) { + a.renderTo.insertBefore(b, a.container.nextSibling); + }, + }, + }; + }, + onChartRender: function () { + var b = this; + this.linkedDescriptionElement = this.getLinkedDescriptionElement(); + this.setLinkedDescriptionAttrs(); + Object.keys(this.screenReaderSections).forEach(function (a) { + b.updateScreenReaderSection(a); + }); + }, + getLinkedDescriptionElement: function () { + var a = this.chart.options.accessibility.linkedDescription; + if (a) { + if ("string" !== typeof a) return a; + a = b(a, this.chart); + a = e.querySelectorAll(a); + if (1 === a.length) return a[0]; + } + }, + setLinkedDescriptionAttrs: function () { + var b = this.linkedDescriptionElement; + b && + (b.setAttribute("aria-hidden", "true"), + p(b, "highcharts-linked-description")); + }, + updateScreenReaderSection: function (b) { + var a = this.chart, + c = this.screenReaderSections[b], + d = c.buildContent(a), + e = (c.element = c.element || this.createElement("div")), + g = e.firstChild || this.createElement("div"); + this.setScreenReaderSectionAttribs(e, b); + g.innerHTML = d; + e.appendChild(g); + c.insertIntoDOM(e, a); + x(g); + t(a, g); + c.afterInserted && c.afterInserted(); + }, + setScreenReaderSectionAttribs: function (b, a) { + var c = this.chart, + d = c.langFormat( + "accessibility.screenReaderSection." + a + "RegionLabel", + { chart: c } + ); + u(b, { + id: "highcharts-screen-reader-region-" + a + "-" + c.index, + "aria-label": d, + }); + b.style.position = "relative"; + "all" === c.options.accessibility.landmarkVerbosity && + d && + b.setAttribute("role", "region"); + }, + defaultBeforeChartFormatter: function () { + var b, + c = this.chart, + d = c.options.accessibility.screenReaderSection.beforeChartFormat, + e = this.getAxesDescription(), + g = + c.sonify && + (null === (b = c.options.sonification) || void 0 === b + ? void 0 + : b.enabled); + b = "highcharts-a11y-sonify-data-btn-" + c.index; + var h = "hc-linkto-highcharts-data-table-" + c.index, + f = k(c), + t = c.langFormat( + "accessibility.screenReaderSection.annotations.heading", + { chart: c } + ); + e = { + chartTitle: v(c), + typeDescription: this.getTypeDescriptionText(), + chartSubtitle: this.getSubtitleText(), + chartLongdesc: this.getLongdescText(), + xAxisDescription: e.xAxis, + yAxisDescription: e.yAxis, + playAsSoundButton: g ? this.getSonifyButtonText(b) : "", + viewTableButton: c.getCSV ? this.getDataTableButtonText(h) : "", + annotationsTitle: f ? t : "", + annotationsList: f, + }; + c = a.i18nFormat(d, e, c); + this.dataTableButtonId = h; + this.sonifyButtonId = b; + return q(D(c)).replace(/<(\w+)[^>]*?>\s*<\/\1>/g, ""); + }, + defaultAfterChartFormatter: function () { + var b = this.chart, + c = b.options.accessibility.screenReaderSection.afterChartFormat, + d = { endOfChartMarker: this.getEndOfChartMarkerText() }; + b = a.i18nFormat(c, d, b); + return q(D(b)).replace(/<(\w+)[^>]*?>\s*<\/\1>/g, ""); + }, + getLinkedDescription: function () { + var b = this.linkedDescriptionElement; + return y((b && b.innerHTML) || ""); + }, + getLongdescText: function () { + var b = this.chart.options, + a = b.caption; + a = a && a.text; + var c = this.getLinkedDescription(); + return b.accessibility.description || c || a || ""; + }, + getTypeDescriptionText: function () { + var b = this.chart; + return b.types + ? b.options.accessibility.typeDescription || + b.getTypeDescription(b.types) + : ""; + }, + getDataTableButtonText: function (b) { + var a = this.chart; + a = a.langFormat("accessibility.table.viewAsDataTableButtonText", { + chart: a, + chartTitle: v(a), + }); + return '<button id="' + b + '">' + a + "</button>"; + }, + getSonifyButtonText: function (b) { + var a, + c = this.chart; + if ( + !1 === + (null === (a = c.options.sonification) || void 0 === a + ? void 0 + : a.enabled) + ) + return ""; + a = c.langFormat("accessibility.sonification.playAsSoundButtonText", { + chart: c, + chartTitle: v(c), + }); + return '<button id="' + b + '">' + a + "</button>"; + }, + getSubtitleText: function () { + var b = this.chart.options.subtitle; + return y((b && b.text) || ""); + }, + getEndOfChartMarkerText: function () { + var b = this.chart, + a = b.langFormat( + "accessibility.screenReaderSection.endOfChartMarker", + { chart: b } + ); + return ( + '<div id="highcharts-end-of-chart-marker-' + + b.index + + '">' + + a + + "</div>" + ); + }, + onDataTableCreated: function (b) { + var a = this.chart; + a.options.accessibility.enabled && + (this.viewDataTableButton && + this.viewDataTableButton.setAttribute("aria-expanded", "true"), + (b.html = b.html.replace( + "<table ", + '<table tabindex="-1" summary="' + + a.langFormat("accessibility.table.tableSummary", { chart: a }) + + '"' + ))); + }, + focusDataTable: function () { + var b = this.dataTableDiv; + (b = b && b.getElementsByTagName("table")[0]) && b.focus && b.focus(); + }, + initSonifyButton: function (b) { + var a = this, + c = (this.sonifyButton = z(b)), + d = this.chart, + e = function (b) { + null === c || void 0 === c + ? void 0 + : c.setAttribute("aria-hidden", "true"); + null === c || void 0 === c + ? void 0 + : c.setAttribute("aria-label", ""); + b.preventDefault(); + b.stopPropagation(); + b = d.langFormat( + "accessibility.sonification.playAsSoundClickAnnouncement", + { chart: d } + ); + a.announcer.announce(b); + setTimeout(function () { + null === c || void 0 === c + ? void 0 + : c.removeAttribute("aria-hidden"); + null === c || void 0 === c + ? void 0 + : c.removeAttribute("aria-label"); + d.sonify && d.sonify(); + }, 1e3); + }; + c && + d && + (u(c, { tabindex: "-1" }), + (c.onclick = function (b) { + var a; + ( + (null === (a = d.options.accessibility) || void 0 === a + ? void 0 + : a.screenReaderSection.onPlayAsSoundClick) || e + ).call(this, b, d); + })); + }, + initDataTableButton: function (b) { + var a = (this.viewDataTableButton = z(b)), + c = this.chart; + b = b.replace("hc-linkto-", ""); + a && + (u(a, { tabindex: "-1", "aria-expanded": !!z(b) }), + (a.onclick = + c.options.accessibility.screenReaderSection + .onViewDataTableClick || + function () { + c.viewData(); + })); + }, + getAxesDescription: function () { + var b = this.chart, + a = function (a, d) { + a = b[a]; + return ( + 1 < a.length || + (a[0] && + c( + a[0].options.accessibility && + a[0].options.accessibility.enabled, + d + )) + ); + }, + d = !!b.types && 0 > b.types.indexOf("map"), + e = !!b.hasCartesianSeries, + g = a("xAxis", !b.angular && e && d); + a = a("yAxis", e && d); + d = {}; + g && (d.xAxis = this.getAxisDescriptionText("xAxis")); + a && (d.yAxis = this.getAxisDescriptionText("yAxis")); + return d; + }, + getAxisDescriptionText: function (b) { + var a = this, + c = this.chart, + d = c[b]; + return c.langFormat( + "accessibility.axis." + + b + + "Description" + + (1 < d.length ? "Plural" : "Singular"), + { + chart: c, + names: d.map(function (b) { + return w(b); + }), + ranges: d.map(function (b) { + return a.getAxisRangeDescription(b); + }), + numAxes: d.length, + } + ); + }, + getAxisRangeDescription: function (b) { + var a = b.options || {}; + return a.accessibility && + "undefined" !== typeof a.accessibility.rangeDescription + ? a.accessibility.rangeDescription + : b.categories + ? this.getCategoryAxisRangeDesc(b) + : !b.dateTime || (0 !== b.min && 0 !== b.dataMin) + ? this.getAxisFromToDescription(b) + : this.getAxisTimeLengthDesc(b); + }, + getCategoryAxisRangeDesc: function (b) { + var a = this.chart; + return b.dataMax && b.dataMin + ? a.langFormat("accessibility.axis.rangeCategories", { + chart: a, + axis: b, + numCategories: b.dataMax - b.dataMin + 1, + }) + : ""; + }, + getAxisTimeLengthDesc: function (b) { + var a = this.chart, + c = {}, + d = "Seconds"; + c.Seconds = ((b.max || 0) - (b.min || 0)) / 1e3; + c.Minutes = c.Seconds / 60; + c.Hours = c.Minutes / 60; + c.Days = c.Hours / 24; + ["Minutes", "Hours", "Days"].forEach(function (b) { + 2 < c[b] && (d = b); + }); + var e = c[d].toFixed("Seconds" !== d && "Minutes" !== d ? 1 : 0); + return a.langFormat("accessibility.axis.timeRange" + d, { + chart: a, + axis: b, + range: e.replace(".0", ""), + }); + }, + getAxisFromToDescription: function (b) { + var a = this.chart, + c = a.options.accessibility.screenReaderSection.axisRangeDateFormat, + d = function (d) { + return b.dateTime ? a.time.dateFormat(c, b[d]) : b[d]; + }; + return a.langFormat("accessibility.axis.rangeFromTo", { + chart: a, + axis: b, + rangeFrom: d("min"), + rangeTo: d("max"), + }); + }, + destroy: function () { + var b; + null === (b = this.announcer) || void 0 === b ? void 0 : b.destroy(); + }, + }); + return f; + } + ); + p( + a, + "Accessibility/Components/ContainerComponent.js", + [ + a["Accessibility/AccessibilityComponent.js"], + a["Accessibility/Utils/ChartUtilities.js"], + a["Core/Globals.js"], + a["Accessibility/Utils/HTMLUtilities.js"], + a["Core/Utilities.js"], + ], + function (a, f, l, m, n) { + var g = f.unhideChartElementFromAT, + h = f.getChartTitle, + q = l.doc, + e = m.stripHTMLTagsFromString; + f = n.extend; + l = function () {}; + l.prototype = new a(); + f(l.prototype, { + onChartUpdate: function () { + this.handleSVGTitleElement(); + this.setSVGContainerLabel(); + this.setGraphicContainerAttrs(); + this.setRenderToAttrs(); + this.makeCreditsAccessible(); + }, + handleSVGTitleElement: function () { + var a = this.chart, + b = "highcharts-title-" + a.index, + c = e( + a.langFormat("accessibility.svgContainerTitle", { + chartTitle: h(a), + }) + ); + if (c.length) { + var g = (this.svgTitleElement = + this.svgTitleElement || + q.createElementNS("http://www.w3.org/2000/svg", "title")); + g.textContent = c; + g.id = b; + a.renderTo.insertBefore(g, a.renderTo.firstChild); + } + }, + setSVGContainerLabel: function () { + var a = this.chart, + b = e( + a.langFormat("accessibility.svgContainerLabel", { + chartTitle: h(a), + }) + ); + a.renderer.box && + b.length && + a.renderer.box.setAttribute("aria-label", b); + }, + setGraphicContainerAttrs: function () { + var a = this.chart, + b = a.langFormat("accessibility.graphicContainerLabel", { + chartTitle: h(a), + }); + b.length && a.container.setAttribute("aria-label", b); + }, + setRenderToAttrs: function () { + var a = this.chart; + "disabled" !== a.options.accessibility.landmarkVerbosity + ? a.renderTo.setAttribute("role", "region") + : a.renderTo.removeAttribute("role"); + a.renderTo.setAttribute( + "aria-label", + a.langFormat("accessibility.chartContainerLabel", { + title: h(a), + chart: a, + }) + ); + }, + makeCreditsAccessible: function () { + var a = this.chart, + b = a.credits; + b && + (b.textStr && + b.element.setAttribute( + "aria-label", + e( + a.langFormat("accessibility.credits", { + creditsStr: b.textStr, + }) + ) + ), + g(a, b.element)); + }, + destroy: function () { + this.chart.renderTo.setAttribute("aria-hidden", !0); + }, + }); + return l; + } + ); + p( + a, + "Accessibility/HighContrastMode.js", + [a["Core/Globals.js"]], + function (a) { + var f = a.isMS, + l = a.win, + m = l.document; + return { + isHighContrastModeActive: function () { + var a = /(Edg)/.test(l.navigator.userAgent); + if (l.matchMedia && a) + return l.matchMedia("(-ms-high-contrast: active)").matches; + if (f && l.getComputedStyle) { + a = m.createElement("div"); + a.style.backgroundImage = + "url()"; + m.body.appendChild(a); + var g = (a.currentStyle || l.getComputedStyle(a)).backgroundImage; + m.body.removeChild(a); + return "none" === g; + } + return !1; + }, + setHighContrastTheme: function (a) { + a.highContrastModeActive = !0; + var g = a.options.accessibility.highContrastTheme; + a.update(g, !1); + a.series.forEach(function (a) { + var f = g.plotOptions[a.type] || {}; + a.update({ + color: f.color || "windowText", + colors: [f.color || "windowText"], + borderColor: f.borderColor || "window", + }); + a.points.forEach(function (a) { + a.options && + a.options.color && + a.update( + { + color: f.color || "windowText", + borderColor: f.borderColor || "window", + }, + !1 + ); + }); + }); + a.redraw(); + }, + }; + } + ); + p(a, "Accessibility/HighContrastTheme.js", [], function () { + return { + chart: { backgroundColor: "window" }, + title: { style: { color: "windowText" } }, + subtitle: { style: { color: "windowText" } }, + colorAxis: { minColor: "windowText", maxColor: "windowText", stops: [] }, + colors: ["windowText"], + xAxis: { + gridLineColor: "windowText", + labels: { style: { color: "windowText" } }, + lineColor: "windowText", + minorGridLineColor: "windowText", + tickColor: "windowText", + title: { style: { color: "windowText" } }, + }, + yAxis: { + gridLineColor: "windowText", + labels: { style: { color: "windowText" } }, + lineColor: "windowText", + minorGridLineColor: "windowText", + tickColor: "windowText", + title: { style: { color: "windowText" } }, + }, + tooltip: { + backgroundColor: "window", + borderColor: "windowText", + style: { color: "windowText" }, + }, + plotOptions: { + series: { + lineColor: "windowText", + fillColor: "window", + borderColor: "windowText", + edgeColor: "windowText", + borderWidth: 1, + dataLabels: { + connectorColor: "windowText", + color: "windowText", + style: { color: "windowText", textOutline: "none" }, + }, + marker: { lineColor: "windowText", fillColor: "windowText" }, + }, + pie: { + color: "window", + colors: ["window"], + borderColor: "windowText", + borderWidth: 1, + }, + boxplot: { fillColor: "window" }, + candlestick: { lineColor: "windowText", fillColor: "window" }, + errorbar: { fillColor: "window" }, + }, + legend: { + backgroundColor: "window", + itemStyle: { color: "windowText" }, + itemHoverStyle: { color: "windowText" }, + itemHiddenStyle: { color: "#555" }, + title: { style: { color: "windowText" } }, + }, + credits: { style: { color: "windowText" } }, + labels: { style: { color: "windowText" } }, + drilldown: { + activeAxisLabelStyle: { color: "windowText" }, + activeDataLabelStyle: { color: "windowText" }, + }, + navigation: { + buttonOptions: { + symbolStroke: "windowText", + theme: { fill: "window" }, + }, + }, + rangeSelector: { + buttonTheme: { + fill: "window", + stroke: "windowText", + style: { color: "windowText" }, + states: { + hover: { + fill: "window", + stroke: "windowText", + style: { color: "windowText" }, + }, + select: { + fill: "#444", + stroke: "windowText", + style: { color: "windowText" }, + }, + }, + }, + inputBoxBorderColor: "windowText", + inputStyle: { backgroundColor: "window", color: "windowText" }, + labelStyle: { color: "windowText" }, + }, + navigator: { + handles: { backgroundColor: "window", borderColor: "windowText" }, + outlineColor: "windowText", + maskFill: "transparent", + series: { color: "windowText", lineColor: "windowText" }, + xAxis: { gridLineColor: "windowText" }, + }, + scrollbar: { + barBackgroundColor: "#444", + barBorderColor: "windowText", + buttonArrowColor: "windowText", + buttonBackgroundColor: "window", + buttonBorderColor: "windowText", + rifleColor: "windowText", + trackBackgroundColor: "window", + trackBorderColor: "windowText", + }, + }; + }); + p(a, "Accessibility/Options/Options.js", [], function () { + return { + accessibility: { + enabled: !0, + screenReaderSection: { + beforeChartFormat: + "<h5>{chartTitle}</h5><div>{typeDescription}</div><div>{chartSubtitle}</div><div>{chartLongdesc}</div><div>{playAsSoundButton}</div><div>{viewTableButton}</div><div>{xAxisDescription}</div><div>{yAxisDescription}</div><div>{annotationsTitle}{annotationsList}</div>", + afterChartFormat: "{endOfChartMarker}", + axisRangeDateFormat: "%Y-%m-%d %H:%M:%S", + }, + series: { + describeSingleSeries: !1, + pointDescriptionEnabledThreshold: 200, + }, + point: { + valueDescriptionFormat: "{index}. {xDescription}{separator}{value}.", + }, + landmarkVerbosity: "all", + linkedDescription: + '*[data-highcharts-chart="{index}"] + .highcharts-description', + keyboardNavigation: { + enabled: !0, + focusBorder: { + enabled: !0, + hideBrowserFocusOutline: !0, + style: { color: "#335cad", lineWidth: 2, borderRadius: 3 }, + margin: 2, + }, + order: ["series", "zoom", "rangeSelector", "legend", "chartMenu"], + wrapAround: !0, + seriesNavigation: { + skipNullPoints: !0, + pointNavigationEnabledThreshold: !1, + }, + }, + announceNewData: { + enabled: !1, + minAnnounceInterval: 5e3, + interruptUser: !1, + }, + }, + legend: { + accessibility: { enabled: !0, keyboardNavigation: { enabled: !0 } }, + }, + exporting: { accessibility: { enabled: !0 } }, + }; + }); + p(a, "Accessibility/Options/LangOptions.js", [], function () { + return { + accessibility: { + defaultChartTitle: "Chart", + chartContainerLabel: "{title}. Highcharts interactive chart.", + svgContainerLabel: "Interactive chart", + drillUpButton: "{buttonText}", + credits: "Chart credits: {creditsStr}", + thousandsSep: ",", + svgContainerTitle: "", + graphicContainerLabel: "", + screenReaderSection: { + beforeRegionLabel: "Chart screen reader information.", + afterRegionLabel: "", + annotations: { + heading: "Chart annotations summary", + descriptionSinglePoint: + "{annotationText}. Related to {annotationPoint}", + descriptionMultiplePoints: + "{annotationText}. Related to {annotationPoint}{ Also related to, #each(additionalAnnotationPoints)}", + descriptionNoPoints: "{annotationText}", + }, + endOfChartMarker: "End of interactive chart.", + }, + sonification: { + playAsSoundButtonText: "Play as sound, {chartTitle}", + playAsSoundClickAnnouncement: "Play", + }, + legend: { + legendLabel: "Toggle series visibility", + legendItem: "Hide {itemName}", + }, + zoom: { + mapZoomIn: "Zoom chart", + mapZoomOut: "Zoom out chart", + resetZoomButton: "Reset zoom", + }, + rangeSelector: { + minInputLabel: "Select start date.", + maxInputLabel: "Select end date.", + buttonText: "Select range {buttonText}", + }, + table: { + viewAsDataTableButtonText: "View as data table, {chartTitle}", + tableSummary: "Table representation of chart.", + }, + announceNewData: { + newDataAnnounce: "Updated data for chart {chartTitle}", + newSeriesAnnounceSingle: "New data series: {seriesDesc}", + newPointAnnounceSingle: "New data point: {pointDesc}", + newSeriesAnnounceMultiple: + "New data series in chart {chartTitle}: {seriesDesc}", + newPointAnnounceMultiple: + "New data point in chart {chartTitle}: {pointDesc}", + }, + seriesTypeDescriptions: { + boxplot: + "Box plot charts are typically used to display groups of statistical data. Each data point in the chart can have up to 5 values: minimum, lower quartile, median, upper quartile, and maximum.", + arearange: + "Arearange charts are line charts displaying a range between a lower and higher value for each point.", + areasplinerange: + "These charts are line charts displaying a range between a lower and higher value for each point.", + bubble: + "Bubble charts are scatter charts where each data point also has a size value.", + columnrange: + "Columnrange charts are column charts displaying a range between a lower and higher value for each point.", + errorbar: + "Errorbar series are used to display the variability of the data.", + funnel: + "Funnel charts are used to display reduction of data in stages.", + pyramid: + "Pyramid charts consist of a single pyramid with item heights corresponding to each point value.", + waterfall: + "A waterfall chart is a column chart where each column contributes towards a total end value.", + }, + chartTypes: { + emptyChart: "Empty chart", + mapTypeDescription: "Map of {mapTitle} with {numSeries} data series.", + unknownMap: "Map of unspecified region with {numSeries} data series.", + combinationChart: "Combination chart with {numSeries} data series.", + defaultSingle: + "Chart with {numPoints} data {#plural(numPoints, points, point)}.", + defaultMultiple: "Chart with {numSeries} data series.", + splineSingle: + "Line chart with {numPoints} data {#plural(numPoints, points, point)}.", + splineMultiple: "Line chart with {numSeries} lines.", + lineSingle: + "Line chart with {numPoints} data {#plural(numPoints, points, point)}.", + lineMultiple: "Line chart with {numSeries} lines.", + columnSingle: + "Bar chart with {numPoints} {#plural(numPoints, bars, bar)}.", + columnMultiple: "Bar chart with {numSeries} data series.", + barSingle: + "Bar chart with {numPoints} {#plural(numPoints, bars, bar)}.", + barMultiple: "Bar chart with {numSeries} data series.", + pieSingle: + "Pie chart with {numPoints} {#plural(numPoints, slices, slice)}.", + pieMultiple: "Pie chart with {numSeries} pies.", + scatterSingle: + "Scatter chart with {numPoints} {#plural(numPoints, points, point)}.", + scatterMultiple: "Scatter chart with {numSeries} data series.", + boxplotSingle: + "Boxplot with {numPoints} {#plural(numPoints, boxes, box)}.", + boxplotMultiple: "Boxplot with {numSeries} data series.", + bubbleSingle: + "Bubble chart with {numPoints} {#plural(numPoints, bubbles, bubble)}.", + bubbleMultiple: "Bubble chart with {numSeries} data series.", + }, + axis: { + xAxisDescriptionSingular: + "The chart has 1 X axis displaying {names[0]}. {ranges[0]}", + xAxisDescriptionPlural: + "The chart has {numAxes} X axes displaying {#each(names, -1) }and {names[-1]}.", + yAxisDescriptionSingular: + "The chart has 1 Y axis displaying {names[0]}. {ranges[0]}", + yAxisDescriptionPlural: + "The chart has {numAxes} Y axes displaying {#each(names, -1) }and {names[-1]}.", + timeRangeDays: "Range: {range} days.", + timeRangeHours: "Range: {range} hours.", + timeRangeMinutes: "Range: {range} minutes.", + timeRangeSeconds: "Range: {range} seconds.", + rangeFromTo: "Range: {rangeFrom} to {rangeTo}.", + rangeCategories: "Range: {numCategories} categories.", + }, + exporting: { + chartMenuLabel: "Chart menu", + menuButtonLabel: "View chart menu", + exportRegionLabel: "Chart menu", + }, + series: { + summary: { + default: + "{name}, series {ix} of {numSeries} with {numPoints} data {#plural(numPoints, points, point)}.", + defaultCombination: + "{name}, series {ix} of {numSeries} with {numPoints} data {#plural(numPoints, points, point)}.", + line: "{name}, line {ix} of {numSeries} with {numPoints} data {#plural(numPoints, points, point)}.", + lineCombination: + "{name}, series {ix} of {numSeries}. Line with {numPoints} data {#plural(numPoints, points, point)}.", + spline: + "{name}, line {ix} of {numSeries} with {numPoints} data {#plural(numPoints, points, point)}.", + splineCombination: + "{name}, series {ix} of {numSeries}. Line with {numPoints} data {#plural(numPoints, points, point)}.", + column: + "{name}, bar series {ix} of {numSeries} with {numPoints} {#plural(numPoints, bars, bar)}.", + columnCombination: + "{name}, series {ix} of {numSeries}. Bar series with {numPoints} {#plural(numPoints, bars, bar)}.", + bar: "{name}, bar series {ix} of {numSeries} with {numPoints} {#plural(numPoints, bars, bar)}.", + barCombination: + "{name}, series {ix} of {numSeries}. Bar series with {numPoints} {#plural(numPoints, bars, bar)}.", + pie: "{name}, pie {ix} of {numSeries} with {numPoints} {#plural(numPoints, slices, slice)}.", + pieCombination: + "{name}, series {ix} of {numSeries}. Pie with {numPoints} {#plural(numPoints, slices, slice)}.", + scatter: + "{name}, scatter plot {ix} of {numSeries} with {numPoints} {#plural(numPoints, points, point)}.", + scatterCombination: + "{name}, series {ix} of {numSeries}, scatter plot with {numPoints} {#plural(numPoints, points, point)}.", + boxplot: + "{name}, boxplot {ix} of {numSeries} with {numPoints} {#plural(numPoints, boxes, box)}.", + boxplotCombination: + "{name}, series {ix} of {numSeries}. Boxplot with {numPoints} {#plural(numPoints, boxes, box)}.", + bubble: + "{name}, bubble series {ix} of {numSeries} with {numPoints} {#plural(numPoints, bubbles, bubble)}.", + bubbleCombination: + "{name}, series {ix} of {numSeries}. Bubble series with {numPoints} {#plural(numPoints, bubbles, bubble)}.", + map: "{name}, map {ix} of {numSeries} with {numPoints} {#plural(numPoints, areas, area)}.", + mapCombination: + "{name}, series {ix} of {numSeries}. Map with {numPoints} {#plural(numPoints, areas, area)}.", + mapline: + "{name}, line {ix} of {numSeries} with {numPoints} data {#plural(numPoints, points, point)}.", + maplineCombination: + "{name}, series {ix} of {numSeries}. Line with {numPoints} data {#plural(numPoints, points, point)}.", + mapbubble: + "{name}, bubble series {ix} of {numSeries} with {numPoints} {#plural(numPoints, bubbles, bubble)}.", + mapbubbleCombination: + "{name}, series {ix} of {numSeries}. Bubble series with {numPoints} {#plural(numPoints, bubbles, bubble)}.", + }, + description: "{description}", + xAxisDescription: "X axis, {name}", + yAxisDescription: "Y axis, {name}", + nullPointValue: "No value", + pointAnnotationsDescription: "{Annotation: #each(annotations). }", + }, + }, + }; + }); + p( + a, + "Accessibility/Options/DeprecatedOptions.js", + [a["Core/Utilities.js"]], + function (a) { + function f(a, d, b) { + for (var c, e = 0; e < d.length - 1; ++e) + (c = d[e]), (a = a[c] = q(a[c], {})); + a[d[d.length - 1]] = b; + } + function l(a, d, b, c) { + function e(b, a) { + return a.reduce(function (b, a) { + return b[a]; + }, b); + } + var g = e(a.options, d), + l = e(a.options, b); + Object.keys(c).forEach(function (e) { + var k, + t = g[e]; + "undefined" !== typeof t && + (f(l, c[e], t), + h( + 32, + !1, + a, + ((k = {}), + (k[d.join(".") + "." + e] = b.join(".") + "." + c[e].join(".")), + k) + )); + }); + } + function m(a) { + var d = a.options.chart || {}, + b = a.options.accessibility || {}; + ["description", "typeDescription"].forEach(function (c) { + var e; + d[c] && + ((b[c] = d[c]), + h( + 32, + !1, + a, + ((e = {}), (e["chart." + c] = "use accessibility." + c), e) + )); + }); + } + function n(a) { + a.axes.forEach(function (d) { + (d = d.options) && + d.description && + ((d.accessibility = d.accessibility || {}), + (d.accessibility.description = d.description), + h(32, !1, a, { + "axis.description": "use axis.accessibility.description", + })); + }); + } + function g(a) { + var d = { + description: ["accessibility", "description"], + exposeElementToA11y: ["accessibility", "exposeAsGroupOnly"], + pointDescriptionFormatter: [ + "accessibility", + "pointDescriptionFormatter", + ], + skipKeyboardNavigation: [ + "accessibility", + "keyboardNavigation", + "enabled", + ], + }; + a.series.forEach(function (b) { + Object.keys(d).forEach(function (c) { + var e, + g = b.options[c]; + "undefined" !== typeof g && + (f(b.options, d[c], "skipKeyboardNavigation" === c ? !g : g), + h( + 32, + !1, + a, + ((e = {}), (e["series." + c] = "series." + d[c].join(".")), e) + )); + }); + }); + } + var h = a.error, + q = a.pick; + return function (a) { + m(a); + n(a); + a.series && g(a); + l(a, ["accessibility"], ["accessibility"], { + pointDateFormat: ["point", "dateFormat"], + pointDateFormatter: ["point", "dateFormatter"], + pointDescriptionFormatter: ["point", "descriptionFormatter"], + pointDescriptionThreshold: [ + "series", + "pointDescriptionEnabledThreshold", + ], + pointNavigationThreshold: [ + "keyboardNavigation", + "seriesNavigation", + "pointNavigationEnabledThreshold", + ], + pointValueDecimals: ["point", "valueDecimals"], + pointValuePrefix: ["point", "valuePrefix"], + pointValueSuffix: ["point", "valueSuffix"], + screenReaderSectionFormatter: [ + "screenReaderSection", + "beforeChartFormatter", + ], + describeSingleSeries: ["series", "describeSingleSeries"], + seriesDescriptionFormatter: ["series", "descriptionFormatter"], + onTableAnchorClick: ["screenReaderSection", "onViewDataTableClick"], + axisRangeDateFormat: ["screenReaderSection", "axisRangeDateFormat"], + }); + l( + a, + ["accessibility", "keyboardNavigation"], + ["accessibility", "keyboardNavigation", "seriesNavigation"], + { skipNullPoints: ["skipNullPoints"], mode: ["mode"] } + ); + l(a, ["lang", "accessibility"], ["lang", "accessibility"], { + legendItem: ["legend", "legendItem"], + legendLabel: ["legend", "legendLabel"], + mapZoomIn: ["zoom", "mapZoomIn"], + mapZoomOut: ["zoom", "mapZoomOut"], + resetZoomButton: ["zoom", "resetZoomButton"], + screenReaderRegionLabel: ["screenReaderSection", "beforeRegionLabel"], + rangeSelectorButton: ["rangeSelector", "buttonText"], + rangeSelectorMaxInput: ["rangeSelector", "maxInputLabel"], + rangeSelectorMinInput: ["rangeSelector", "minInputLabel"], + svgContainerEnd: ["screenReaderSection", "endOfChartMarker"], + viewAsDataTable: ["table", "viewAsDataTableButtonText"], + tableSummary: ["table", "tableSummary"], + }); + }; + } + ); + p( + a, + "Accessibility/A11yI18n.js", + [a["Core/Globals.js"], a["Core/Utilities.js"]], + function (a, f) { + function l(a, f) { + var g = a.indexOf("#each("), + e = a.indexOf("#plural("), + d = a.indexOf("["), + b = a.indexOf("]"); + if (-1 < g) { + d = a.slice(g).indexOf(")") + g; + var c = a.substring(0, g); + e = a.substring(d + 1); + d = a.substring(g + 6, d).split(","); + g = Number(d[1]); + a = ""; + if ((f = f[d[0]])) + for ( + g = isNaN(g) ? f.length : g, + g = 0 > g ? f.length + g : Math.min(g, f.length), + d = 0; + d < g; + ++d + ) + a += c + f[d] + e; + return a.length ? a : ""; + } + if (-1 < e) { + c = a.slice(e).indexOf(")") + e; + a = a.substring(e + 8, c).split(","); + switch (Number(f[a[0]])) { + case 0: + a = n(a[4], a[1]); + break; + case 1: + a = n(a[2], a[1]); + break; + case 2: + a = n(a[3], a[1]); + break; + default: + a = a[1]; + } + a + ? ((f = a), + (f = (f.trim && f.trim()) || f.replace(/^\s+|\s+$/g, ""))) + : (f = ""); + return f; + } + return -1 < d + ? ((e = a.substring(0, d)), + (a = Number(a.substring(d + 1, b))), + (f = f[e]), + !isNaN(a) && + f && + (0 > a + ? ((c = f[f.length + a]), + "undefined" === typeof c && (c = f[0])) + : ((c = f[a]), + "undefined" === typeof c && (c = f[f.length - 1]))), + "undefined" !== typeof c ? c : "") + : "{" + a + "}"; + } + var m = f.format, + n = f.pick; + a.i18nFormat = function (a, f, n) { + var e = function (a, b) { + a = a.slice(b || 0); + var c = a.indexOf("{"), + d = a.indexOf("}"); + if (-1 < c && d > c) + return { + statement: a.substring(c + 1, d), + begin: b + c + 1, + end: b + d, + }; + }, + d = [], + b = 0; + do { + var c = e(a, b); + var g = a.substring(b, c && c.begin - 1); + g.length && d.push({ value: g, type: "constant" }); + c && d.push({ value: c.statement, type: "statement" }); + b = c ? c.end + 1 : b + 1; + } while (c); + d.forEach(function (a) { + "statement" === a.type && (a.value = l(a.value, f)); + }); + return m( + d.reduce(function (a, b) { + return a + b.value; + }, ""), + f, + n + ); + }; + a.Chart.prototype.langFormat = function (f, h) { + f = f.split("."); + for (var g = this.options.lang, e = 0; e < f.length; ++e) + g = g && g[f[e]]; + return "string" === typeof g ? a.i18nFormat(g, h, this) : ""; + }; + } + ); + p( + a, + "Accessibility/FocusBorder.js", + [ + a["Core/Globals.js"], + a["Core/Renderer/SVG/SVGElement.js"], + a["Core/Renderer/SVG/SVGLabel.js"], + a["Core/Utilities.js"], + ], + function (a, f, l, m) { + function n(a) { + if (!a.focusBorderDestroyHook) { + var b = a.destroy; + a.destroy = function () { + var c, d; + null === + (d = + null === (c = a.focusBorder) || void 0 === c + ? void 0 + : c.destroy) || void 0 === d + ? void 0 + : d.call(c); + return b.apply(a, arguments); + }; + a.focusBorderDestroyHook = b; + } + } + function g(a) { + for (var c = [], d = 1; d < arguments.length; d++) + c[d - 1] = arguments[d]; + a.focusBorderUpdateHooks || + ((a.focusBorderUpdateHooks = {}), + b.forEach(function (b) { + b += "Setter"; + var d = a[b] || a._defaultSetter; + a.focusBorderUpdateHooks[b] = d; + a[b] = function () { + var b = d.apply(a, arguments); + a.addFocusBorder.apply(a, c); + return b; + }; + })); + } + function h(a) { + a.focusBorderUpdateHooks && + (Object.keys(a.focusBorderUpdateHooks).forEach(function (b) { + var c = a.focusBorderUpdateHooks[b]; + c === a._defaultSetter ? delete a[b] : (a[b] = c); + }), + delete a.focusBorderUpdateHooks); + } + var q = m.addEvent, + e = m.extend, + d = m.pick, + b = "x y transform width height r d stroke-width".split(" "); + e(f.prototype, { + addFocusBorder: function (b, e) { + this.focusBorder && this.removeFocusBorder(); + var c = this.getBBox(), + f = d(b, 3); + c.x += this.translateX ? this.translateX : 0; + c.y += this.translateY ? this.translateY : 0; + var h = c.x - f, + k = c.y - f, + m = c.width + 2 * f, + q = c.height + 2 * f, + p = this instanceof l; + if ("text" === this.element.nodeName || p) { + var u = !!this.rotation; + if (p) var x = { x: u ? 1 : 0, y: 0 }; + else + (h = x = 0), + "middle" === this.attr("text-anchor") + ? ((x = a.isFirefox && this.rotation ? 0.25 : 0.5), + (h = a.isFirefox && !this.rotation ? 0.75 : 0.5)) + : this.rotation + ? (x = 0.25) + : (h = 0.75), + (x = { x: x, y: h }); + h = +this.attr("x") - c.width * x.x - f; + k = +this.attr("y") - c.height * x.y - f; + p && + u && + ((p = m), + (m = q), + (q = p), + (h = +this.attr("x") - c.height * x.x - f), + (k = +this.attr("y") - c.width * x.y - f)); + } + this.focusBorder = this.renderer + .rect( + h, + k, + m, + q, + parseInt(((e && e.borderRadius) || 0).toString(), 10) + ) + .addClass("highcharts-focus-border") + .attr({ zIndex: 99 }) + .add(this.parentGroup); + this.renderer.styledMode || + this.focusBorder.attr({ + stroke: e && e.stroke, + "stroke-width": e && e.strokeWidth, + }); + g(this, b, e); + n(this); + }, + removeFocusBorder: function () { + h(this); + this.focusBorderDestroyHook && + ((this.destroy = this.focusBorderDestroyHook), + delete this.focusBorderDestroyHook); + this.focusBorder && + (this.focusBorder.destroy(), delete this.focusBorder); + }, + }); + a.Chart.prototype.renderFocusBorder = function () { + var a = this.focusElement, + b = this.options.accessibility.keyboardNavigation.focusBorder; + a && + (a.removeFocusBorder(), + b.enabled && + a.addFocusBorder(b.margin, { + stroke: b.style.color, + strokeWidth: b.style.lineWidth, + borderRadius: b.style.borderRadius, + })); + }; + a.Chart.prototype.setFocusToElement = function (a, b) { + var c = this.options.accessibility.keyboardNavigation.focusBorder; + (b = b || a.element) && + b.focus && + ((b.hcEvents && b.hcEvents.focusin) || + q(b, "focusin", function () {}), + b.focus(), + c.hideBrowserFocusOutline && (b.style.outline = "none")); + this.focusElement && this.focusElement.removeFocusBorder(); + this.focusElement = a; + this.renderFocusBorder(); + }; + } + ); + p( + a, + "Accessibility/Accessibility.js", + [ + a["Accessibility/Utils/ChartUtilities.js"], + a["Core/Globals.js"], + a["Accessibility/KeyboardNavigationHandler.js"], + a["Core/Series/CartesianSeries.js"], + a["Core/Options.js"], + a["Core/Series/Point.js"], + a["Core/Utilities.js"], + a["Accessibility/AccessibilityComponent.js"], + a["Accessibility/KeyboardNavigation.js"], + a["Accessibility/Components/LegendComponent.js"], + a["Accessibility/Components/MenuComponent.js"], + a["Accessibility/Components/SeriesComponent/SeriesComponent.js"], + a["Accessibility/Components/ZoomComponent.js"], + a["Accessibility/Components/RangeSelectorComponent.js"], + a["Accessibility/Components/InfoRegionsComponent.js"], + a["Accessibility/Components/ContainerComponent.js"], + a["Accessibility/HighContrastMode.js"], + a["Accessibility/HighContrastTheme.js"], + a["Accessibility/Options/Options.js"], + a["Accessibility/Options/LangOptions.js"], + a["Accessibility/Options/DeprecatedOptions.js"], + ], + function (a, f, l, m, n, g, h, p, e, d, b, c, k, t, v, w, H, A, D, y, z) { + function q(a) { + this.init(a); + } + var r = f.doc, + u = h.addEvent, + F = h.extend, + B = h.fireEvent, + E = h.merge; + E(!0, n.defaultOptions, D, { + accessibility: { highContrastTheme: A }, + lang: y, + }); + f.A11yChartUtilities = a; + f.KeyboardNavigationHandler = l; + f.AccessibilityComponent = p; + q.prototype = { + init: function (a) { + this.chart = a; + r.addEventListener && a.renderer.isSVG + ? (z(a), + this.initComponents(), + (this.keyboardNavigation = new e(a, this.components)), + this.update()) + : a.renderTo.setAttribute("aria-hidden", !0); + }, + initComponents: function () { + var a = this.chart, + e = a.options.accessibility; + this.components = { + container: new w(), + infoRegions: new v(), + legend: new d(), + chartMenu: new b(), + rangeSelector: new t(), + series: new c(), + zoom: new k(), + }; + e.customComponents && F(this.components, e.customComponents); + var f = this.components; + this.getComponentOrder().forEach(function (b) { + f[b].initBase(a); + f[b].init(); + }); + }, + getComponentOrder: function () { + if (!this.components) return []; + if (!this.components.series) return Object.keys(this.components); + var a = Object.keys(this.components).filter(function (a) { + return "series" !== a; + }); + return ["series"].concat(a); + }, + update: function () { + var a = this.components, + b = this.chart, + c = b.options.accessibility; + B(b, "beforeA11yUpdate"); + b.types = this.getChartTypes(); + this.getComponentOrder().forEach(function (c) { + a[c].onChartUpdate(); + B(b, "afterA11yComponentUpdate", { name: c, component: a[c] }); + }); + this.keyboardNavigation.update(c.keyboardNavigation.order); + !b.highContrastModeActive && + H.isHighContrastModeActive() && + H.setHighContrastTheme(b); + B(b, "afterA11yUpdate", { accessibility: this }); + }, + destroy: function () { + var a = this.chart || {}, + b = this.components; + Object.keys(b).forEach(function (a) { + b[a].destroy(); + b[a].destroyBase(); + }); + this.keyboardNavigation && this.keyboardNavigation.destroy(); + a.renderTo && a.renderTo.setAttribute("aria-hidden", !0); + a.focusElement && a.focusElement.removeFocusBorder(); + }, + getChartTypes: function () { + var a = {}; + this.chart.series.forEach(function (b) { + a[b.type] = 1; + }); + return Object.keys(a); + }, + }; + f.Chart.prototype.updateA11yEnabled = function () { + var a = this.accessibility, + b = this.options.accessibility; + b && b.enabled + ? a + ? a.update() + : (this.accessibility = new q(this)) + : a + ? (a.destroy && a.destroy(), delete this.accessibility) + : this.renderTo.setAttribute("aria-hidden", !0); + }; + u(f.Chart, "render", function (a) { + this.a11yDirty && + this.renderTo && + (delete this.a11yDirty, this.updateA11yEnabled()); + var b = this.accessibility; + b && + b.getComponentOrder().forEach(function (a) { + b.components[a].onChartRender(); + }); + }); + u(f.Chart, "update", function (a) { + if ((a = a.options.accessibility)) + a.customComponents && + ((this.options.accessibility.customComponents = a.customComponents), + delete a.customComponents), + E(!0, this.options.accessibility, a), + this.accessibility && + this.accessibility.destroy && + (this.accessibility.destroy(), delete this.accessibility); + this.a11yDirty = !0; + }); + u(g, "update", function () { + this.series.chart.accessibility && (this.series.chart.a11yDirty = !0); + }); + ["addSeries", "init"].forEach(function (a) { + u(f.Chart, a, function () { + this.a11yDirty = !0; + }); + }); + ["update", "updatedData", "remove"].forEach(function (a) { + u(m, a, function () { + this.chart.accessibility && (this.chart.a11yDirty = !0); + }); + }); + ["afterDrilldown", "drillupall"].forEach(function (a) { + u(f.Chart, a, function () { + this.accessibility && this.accessibility.update(); + }); + }); + u(f.Chart, "destroy", function () { + this.accessibility && this.accessibility.destroy(); + }); + } + ); + p(a, "masters/modules/accessibility.src.js", [], function () {}); +}); +//# sourceMappingURL=accessibility.js.map diff --git a/notemyprogress/js/vue.js b/notemyprogress/js/vue.js index 919aa1251299c4970b9860571d26c1852141e4ad..5632204c8494f4ae8ceada93ee28f233ee07433b 100644 --- a/notemyprogress/js/vue.js +++ b/notemyprogress/js/vue.js @@ -4,10 +4,13 @@ * Released under the MIT License. */ (function (global, factory) { - typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() : - typeof define === 'function' && define.amd ? define(factory) : - (global = global || self, global.Vue = factory()); -}(this, function () { 'use strict'; + typeof exports === "object" && typeof module !== "undefined" + ? (module.exports = factory()) + : typeof define === "function" && define.amd + ? define(factory) + : ((global = global || self), (global.Vue = factory())); +})(this, function () { + "use strict"; /* */ @@ -15,33 +18,33 @@ // These helpers produce better VM code in JS engines due to their // explicitness and function inlining. - function isUndef (v) { - return v === undefined || v === null + function isUndef(v) { + return v === undefined || v === null; } - function isDef (v) { - return v !== undefined && v !== null + function isDef(v) { + return v !== undefined && v !== null; } - function isTrue (v) { - return v === true + function isTrue(v) { + return v === true; } - function isFalse (v) { - return v === false + function isFalse(v) { + return v === false; } /** * Check if value is primitive. */ - function isPrimitive (value) { + function isPrimitive(value) { return ( - typeof value === 'string' || - typeof value === 'number' || + typeof value === "string" || + typeof value === "number" || // $flow-disable-line - typeof value === 'symbol' || - typeof value === 'boolean' - ) + typeof value === "symbol" || + typeof value === "boolean" + ); } /** @@ -49,8 +52,8 @@ * Objects from primitive values when we know the value * is a JSON-compliant type. */ - function isObject (obj) { - return obj !== null && typeof obj === 'object' + function isObject(obj) { + return obj !== null && typeof obj === "object"; } /** @@ -58,94 +61,95 @@ */ var _toString = Object.prototype.toString; - function toRawType (value) { - return _toString.call(value).slice(8, -1) + function toRawType(value) { + return _toString.call(value).slice(8, -1); } /** * Strict object type check. Only returns true * for plain JavaScript objects. */ - function isPlainObject (obj) { - return _toString.call(obj) === '[object Object]' + function isPlainObject(obj) { + return _toString.call(obj) === "[object Object]"; } - function isRegExp (v) { - return _toString.call(v) === '[object RegExp]' + function isRegExp(v) { + return _toString.call(v) === "[object RegExp]"; } /** * Check if val is a valid array index. */ - function isValidArrayIndex (val) { + function isValidArrayIndex(val) { var n = parseFloat(String(val)); - return n >= 0 && Math.floor(n) === n && isFinite(val) + return n >= 0 && Math.floor(n) === n && isFinite(val); } - function isPromise (val) { + function isPromise(val) { return ( isDef(val) && - typeof val.then === 'function' && - typeof val.catch === 'function' - ) + typeof val.then === "function" && + typeof val.catch === "function" + ); } /** * Convert a value to a string that is actually rendered. */ - function toString (val) { + function toString(val) { return val == null - ? '' + ? "" : Array.isArray(val) || (isPlainObject(val) && val.toString === _toString) - ? JSON.stringify(val, null, 2) - : String(val) + ? JSON.stringify(val, null, 2) + : String(val); } /** * Convert an input value to a number for persistence. * If the conversion fails, return original string. */ - function toNumber (val) { + function toNumber(val) { var n = parseFloat(val); - return isNaN(n) ? val : n + return isNaN(n) ? val : n; } /** * Make a map and return a function for checking if a key * is in that map. */ - function makeMap ( - str, - expectsLowerCase - ) { + function makeMap(str, expectsLowerCase) { var map = Object.create(null); - var list = str.split(','); + var list = str.split(","); for (var i = 0; i < list.length; i++) { map[list[i]] = true; } return expectsLowerCase - ? function (val) { return map[val.toLowerCase()]; } - : function (val) { return map[val]; } + ? function (val) { + return map[val.toLowerCase()]; + } + : function (val) { + return map[val]; + }; } /** * Check if a tag is a built-in tag. */ - var isBuiltInTag = makeMap('slot,component', true); + var isBuiltInTag = makeMap("slot,component", true); /** * Check if an attribute is a reserved attribute. */ - var isReservedAttribute = makeMap('key,ref,slot,slot-scope,is'); + var isReservedAttribute = makeMap("key,ref,slot,slot-scope,is"); /** * Remove an item from an array. */ - function remove (arr, item) { + function remove(arr, item) { if (arr.length) { var index = arr.indexOf(item); if (index > -1) { - return arr.splice(index, 1) + return arr.splice(index, 1); } } } @@ -154,19 +158,19 @@ * Check whether an object has the property. */ var hasOwnProperty = Object.prototype.hasOwnProperty; - function hasOwn (obj, key) { - return hasOwnProperty.call(obj, key) + function hasOwn(obj, key) { + return hasOwnProperty.call(obj, key); } /** * Create a cached version of a pure function. */ - function cached (fn) { + function cached(fn) { var cache = Object.create(null); - return (function cachedFn (str) { + return function cachedFn(str) { var hit = cache[str]; - return hit || (cache[str] = fn(str)) - }) + return hit || (cache[str] = fn(str)); + }; } /** @@ -174,14 +178,16 @@ */ var camelizeRE = /-(\w)/g; var camelize = cached(function (str) { - return str.replace(camelizeRE, function (_, c) { return c ? c.toUpperCase() : ''; }) + return str.replace(camelizeRE, function (_, c) { + return c ? c.toUpperCase() : ""; + }); }); /** * Capitalize a string. */ var capitalize = cached(function (str) { - return str.charAt(0).toUpperCase() + str.slice(1) + return str.charAt(0).toUpperCase() + str.slice(1); }); /** @@ -189,7 +195,7 @@ */ var hyphenateRE = /\B([A-Z])/g; var hyphenate = cached(function (str) { - return str.replace(hyphenateRE, '-$1').toLowerCase() + return str.replace(hyphenateRE, "-$1").toLowerCase(); }); /** @@ -201,62 +207,60 @@ */ /* istanbul ignore next */ - function polyfillBind (fn, ctx) { - function boundFn (a) { + function polyfillBind(fn, ctx) { + function boundFn(a) { var l = arguments.length; return l ? l > 1 ? fn.apply(ctx, arguments) : fn.call(ctx, a) - : fn.call(ctx) + : fn.call(ctx); } boundFn._length = fn.length; - return boundFn + return boundFn; } - function nativeBind (fn, ctx) { - return fn.bind(ctx) + function nativeBind(fn, ctx) { + return fn.bind(ctx); } - var bind = Function.prototype.bind - ? nativeBind - : polyfillBind; + var bind = Function.prototype.bind ? nativeBind : polyfillBind; /** * Convert an Array-like object to a real Array. */ - function toArray (list, start) { + function toArray(list, start) { start = start || 0; var i = list.length - start; var ret = new Array(i); while (i--) { ret[i] = list[i + start]; } - return ret + return ret; } /** * Mix properties into target object. */ - function extend (to, _from) { + function extend(to, _from) { for (var key in _from) { to[key] = _from[key]; } - return to + return to; } /** * Merge an Array of Objects into a single Object. */ - function toObject (arr) { + function toObject(arr) { var res = {}; for (var i = 0; i < arr.length; i++) { if (arr[i]) { extend(res, arr[i]); } } - return res + return res; } /* eslint-disable no-unused-vars */ @@ -266,35 +270,43 @@ * Stubbing args to make Flow happy without leaving useless transpiled code * with ...rest (https://flow.org/blog/2017/05/07/Strict-Function-Call-Arity/). */ - function noop (a, b, c) {} + function noop(a, b, c) {} /** * Always return false. */ - var no = function (a, b, c) { return false; }; + var no = function (a, b, c) { + return false; + }; /* eslint-enable no-unused-vars */ /** * Return the same value. */ - var identity = function (_) { return _; }; + var identity = function (_) { + return _; + }; /** * Generate a string containing static keys from compiler modules. */ - function genStaticKeys (modules) { - return modules.reduce(function (keys, m) { - return keys.concat(m.staticKeys || []) - }, []).join(',') + function genStaticKeys(modules) { + return modules + .reduce(function (keys, m) { + return keys.concat(m.staticKeys || []); + }, []) + .join(","); } /** * Check if two values are loosely equal - that is, * if they are plain objects, do they have the same shape? */ - function looseEqual (a, b) { - if (a === b) { return true } + function looseEqual(a, b) { + if (a === b) { + return true; + } var isObjectA = isObject(a); var isObjectB = isObject(b); if (isObjectA && isObjectB) { @@ -302,29 +314,35 @@ var isArrayA = Array.isArray(a); var isArrayB = Array.isArray(b); if (isArrayA && isArrayB) { - return a.length === b.length && a.every(function (e, i) { - return looseEqual(e, b[i]) - }) + return ( + a.length === b.length && + a.every(function (e, i) { + return looseEqual(e, b[i]); + }) + ); } else if (a instanceof Date && b instanceof Date) { - return a.getTime() === b.getTime() + return a.getTime() === b.getTime(); } else if (!isArrayA && !isArrayB) { var keysA = Object.keys(a); var keysB = Object.keys(b); - return keysA.length === keysB.length && keysA.every(function (key) { - return looseEqual(a[key], b[key]) - }) + return ( + keysA.length === keysB.length && + keysA.every(function (key) { + return looseEqual(a[key], b[key]); + }) + ); } else { /* istanbul ignore next */ - return false + return false; } } catch (e) { /* istanbul ignore next */ - return false + return false; } } else if (!isObjectA && !isObjectB) { - return String(a) === String(b) + return String(a) === String(b); } else { - return false + return false; } } @@ -333,54 +351,50 @@ * found in the array (if value is a plain object, the array must * contain an object of the same shape), or -1 if it is not present. */ - function looseIndexOf (arr, val) { + function looseIndexOf(arr, val) { for (var i = 0; i < arr.length; i++) { - if (looseEqual(arr[i], val)) { return i } + if (looseEqual(arr[i], val)) { + return i; + } } - return -1 + return -1; } /** * Ensure a function is called only once. */ - function once (fn) { + function once(fn) { var called = false; return function () { if (!called) { called = true; fn.apply(this, arguments); } - } + }; } - var SSR_ATTR = 'data-server-rendered'; + var SSR_ATTR = "data-server-rendered"; - var ASSET_TYPES = [ - 'component', - 'directive', - 'filter' - ]; + var ASSET_TYPES = ["component", "directive", "filter"]; var LIFECYCLE_HOOKS = [ - 'beforeCreate', - 'created', - 'beforeMount', - 'mounted', - 'beforeUpdate', - 'updated', - 'beforeDestroy', - 'destroyed', - 'activated', - 'deactivated', - 'errorCaptured', - 'serverPrefetch' + "beforeCreate", + "created", + "beforeMount", + "mounted", + "beforeUpdate", + "updated", + "beforeDestroy", + "destroyed", + "activated", + "deactivated", + "errorCaptured", + "serverPrefetch", ]; /* */ - - - var config = ({ + var config = { /** * Option merge strategies (used in core/util/options) */ @@ -395,12 +409,12 @@ /** * Show production mode tip message on boot? */ - productionTip: "development" !== 'production', + productionTip: "development" !== "production", /** * Whether to enable devtools */ - devtools: "development" !== 'production', + devtools: "development" !== "production", /** * Whether to record perf @@ -471,8 +485,8 @@ /** * Exposed for legacy reasons */ - _lifecycleHooks: LIFECYCLE_HOOKS - }); + _lifecycleHooks: LIFECYCLE_HOOKS, + }; /* */ @@ -481,79 +495,83 @@ * using https://www.w3.org/TR/html53/semantics-scripting.html#potentialcustomelementname * skipping \u10000-\uEFFFF due to it freezing up PhantomJS */ - var unicodeRegExp = /a-zA-Z\u00B7\u00C0-\u00D6\u00D8-\u00F6\u00F8-\u037D\u037F-\u1FFF\u200C-\u200D\u203F-\u2040\u2070-\u218F\u2C00-\u2FEF\u3001-\uD7FF\uF900-\uFDCF\uFDF0-\uFFFD/; + var unicodeRegExp = + /a-zA-Z\u00B7\u00C0-\u00D6\u00D8-\u00F6\u00F8-\u037D\u037F-\u1FFF\u200C-\u200D\u203F-\u2040\u2070-\u218F\u2C00-\u2FEF\u3001-\uD7FF\uF900-\uFDCF\uFDF0-\uFFFD/; /** * Check if a string starts with $ or _ */ - function isReserved (str) { - var c = (str + '').charCodeAt(0); - return c === 0x24 || c === 0x5F + function isReserved(str) { + var c = (str + "").charCodeAt(0); + return c === 0x24 || c === 0x5f; } /** * Define a property. */ - function def (obj, key, val, enumerable) { + function def(obj, key, val, enumerable) { Object.defineProperty(obj, key, { value: val, enumerable: !!enumerable, writable: true, - configurable: true + configurable: true, }); } /** * Parse simple path. */ - var bailRE = new RegExp(("[^" + (unicodeRegExp.source) + ".$_\\d]")); - function parsePath (path) { + var bailRE = new RegExp("[^" + unicodeRegExp.source + ".$_\\d]"); + function parsePath(path) { if (bailRE.test(path)) { - return + return; } - var segments = path.split('.'); + var segments = path.split("."); return function (obj) { for (var i = 0; i < segments.length; i++) { - if (!obj) { return } + if (!obj) { + return; + } obj = obj[segments[i]]; } - return obj - } + return obj; + }; } /* */ // can we use __proto__? - var hasProto = '__proto__' in {}; + var hasProto = "__proto__" in {}; // Browser environment sniffing - var inBrowser = typeof window !== 'undefined'; - var inWeex = typeof WXEnvironment !== 'undefined' && !!WXEnvironment.platform; + var inBrowser = typeof window !== "undefined"; + var inWeex = typeof WXEnvironment !== "undefined" && !!WXEnvironment.platform; var weexPlatform = inWeex && WXEnvironment.platform.toLowerCase(); var UA = inBrowser && window.navigator.userAgent.toLowerCase(); var isIE = UA && /msie|trident/.test(UA); - var isIE9 = UA && UA.indexOf('msie 9.0') > 0; - var isEdge = UA && UA.indexOf('edge/') > 0; - var isAndroid = (UA && UA.indexOf('android') > 0) || (weexPlatform === 'android'); - var isIOS = (UA && /iphone|ipad|ipod|ios/.test(UA)) || (weexPlatform === 'ios'); + var isIE9 = UA && UA.indexOf("msie 9.0") > 0; + var isEdge = UA && UA.indexOf("edge/") > 0; + var isAndroid = + (UA && UA.indexOf("android") > 0) || weexPlatform === "android"; + var isIOS = (UA && /iphone|ipad|ipod|ios/.test(UA)) || weexPlatform === "ios"; var isChrome = UA && /chrome\/\d+/.test(UA) && !isEdge; var isPhantomJS = UA && /phantomjs/.test(UA); var isFF = UA && UA.match(/firefox\/(\d+)/); // Firefox has a "watch" function on Object.prototype... - var nativeWatch = ({}).watch; + var nativeWatch = {}.watch; var supportsPassive = false; if (inBrowser) { try { var opts = {}; - Object.defineProperty(opts, 'passive', ({ - get: function get () { + Object.defineProperty(opts, "passive", { + get: function get() { /* istanbul ignore next */ supportsPassive = true; - } - })); // https://github.com/facebook/flow/issues/285 - window.addEventListener('test-passive', null, opts); + }, + }); // https://github.com/facebook/flow/issues/285 + window.addEventListener("test-passive", null, opts); } catch (e) {} } @@ -563,93 +581,101 @@ var isServerRendering = function () { if (_isServer === undefined) { /* istanbul ignore if */ - if (!inBrowser && !inWeex && typeof global !== 'undefined') { + if (!inBrowser && !inWeex && typeof global !== "undefined") { // detect presence of vue-server-renderer and avoid // Webpack shimming the process - _isServer = global['process'] && global['process'].env.VUE_ENV === 'server'; + _isServer = + global["process"] && global["process"].env.VUE_ENV === "server"; } else { _isServer = false; } } - return _isServer + return _isServer; }; // detect devtools var devtools = inBrowser && window.__VUE_DEVTOOLS_GLOBAL_HOOK__; /* istanbul ignore next */ - function isNative (Ctor) { - return typeof Ctor === 'function' && /native code/.test(Ctor.toString()) + function isNative(Ctor) { + return typeof Ctor === "function" && /native code/.test(Ctor.toString()); } var hasSymbol = - typeof Symbol !== 'undefined' && isNative(Symbol) && - typeof Reflect !== 'undefined' && isNative(Reflect.ownKeys); + typeof Symbol !== "undefined" && + isNative(Symbol) && + typeof Reflect !== "undefined" && + isNative(Reflect.ownKeys); var _Set; /* istanbul ignore if */ // $flow-disable-line - if (typeof Set !== 'undefined' && isNative(Set)) { + if (typeof Set !== "undefined" && isNative(Set)) { // use native Set when available. _Set = Set; } else { // a non-standard Set polyfill that only works with primitive keys. - _Set = /*@__PURE__*/(function () { - function Set () { + _Set = /*@__PURE__*/ (function () { + function Set() { this.set = Object.create(null); } - Set.prototype.has = function has (key) { - return this.set[key] === true + Set.prototype.has = function has(key) { + return this.set[key] === true; }; - Set.prototype.add = function add (key) { + Set.prototype.add = function add(key) { this.set[key] = true; }; - Set.prototype.clear = function clear () { + Set.prototype.clear = function clear() { this.set = Object.create(null); }; return Set; - }()); + })(); } /* */ var warn = noop; var tip = noop; - var generateComponentTrace = (noop); // work around flow check - var formatComponentName = (noop); + var generateComponentTrace = noop; // work around flow check + var formatComponentName = noop; { - var hasConsole = typeof console !== 'undefined'; + var hasConsole = typeof console !== "undefined"; var classifyRE = /(?:^|[-_])(\w)/g; - var classify = function (str) { return str - .replace(classifyRE, function (c) { return c.toUpperCase(); }) - .replace(/[-_]/g, ''); }; + var classify = function (str) { + return str + .replace(classifyRE, function (c) { + return c.toUpperCase(); + }) + .replace(/[-_]/g, ""); + }; warn = function (msg, vm) { - var trace = vm ? generateComponentTrace(vm) : ''; + var trace = vm ? generateComponentTrace(vm) : ""; if (config.warnHandler) { config.warnHandler.call(null, msg, vm, trace); - } else if (hasConsole && (!config.silent)) { - console.error(("[Vue warn]: " + msg + trace)); + } else if (hasConsole && !config.silent) { + console.error("[Vue warn]: " + msg + trace); } }; tip = function (msg, vm) { - if (hasConsole && (!config.silent)) { - console.warn("[Vue tip]: " + msg + ( - vm ? generateComponentTrace(vm) : '' - )); + if (hasConsole && !config.silent) { + console.warn( + "[Vue tip]: " + msg + (vm ? generateComponentTrace(vm) : "") + ); } }; formatComponentName = function (vm, includeFile) { if (vm.$root === vm) { - return '<Root>' + return "<Root>"; } - var options = typeof vm === 'function' && vm.cid != null - ? vm.options - : vm._isVue + var options = + typeof vm === "function" && vm.cid != null + ? vm.options + : vm._isVue ? vm.$options || vm.constructor.options : vm; var name = options.name || options._componentTag; @@ -660,19 +686,23 @@ } return ( - (name ? ("<" + (classify(name)) + ">") : "<Anonymous>") + - (file && includeFile !== false ? (" at " + file) : '') - ) + (name ? "<" + classify(name) + ">" : "<Anonymous>") + + (file && includeFile !== false ? " at " + file : "") + ); }; var repeat = function (str, n) { - var res = ''; + var res = ""; while (n) { - if (n % 2 === 1) { res += str; } - if (n > 1) { str += str; } + if (n % 2 === 1) { + res += str; + } + if (n > 1) { + str += str; + } n >>= 1; } - return res + return res; }; generateComponentTrace = function (vm) { @@ -685,7 +715,7 @@ if (last.constructor === vm.constructor) { currentRecursiveSequence++; vm = vm.$parent; - continue + continue; } else if (currentRecursiveSequence > 0) { tree[tree.length - 1] = [last, currentRecursiveSequence]; currentRecursiveSequence = 0; @@ -694,13 +724,25 @@ tree.push(vm); vm = vm.$parent; } - return '\n\nfound in\n\n' + tree - .map(function (vm, i) { return ("" + (i === 0 ? '---> ' : repeat(' ', 5 + i * 2)) + (Array.isArray(vm) - ? ((formatComponentName(vm[0])) + "... (" + (vm[1]) + " recursive calls)") - : formatComponentName(vm))); }) - .join('\n') + return ( + "\n\nfound in\n\n" + + tree + .map(function (vm, i) { + return ( + "" + + (i === 0 ? "---> " : repeat(" ", 5 + i * 2)) + + (Array.isArray(vm) + ? formatComponentName(vm[0]) + + "... (" + + vm[1] + + " recursive calls)" + : formatComponentName(vm)) + ); + }) + .join("\n") + ); } else { - return ("\n\n(found in " + (formatComponentName(vm)) + ")") + return "\n\n(found in " + formatComponentName(vm) + ")"; } }; } @@ -713,33 +755,35 @@ * A dep is an observable that can have multiple * directives subscribing to it. */ - var Dep = function Dep () { + var Dep = function Dep() { this.id = uid++; this.subs = []; }; - Dep.prototype.addSub = function addSub (sub) { + Dep.prototype.addSub = function addSub(sub) { this.subs.push(sub); }; - Dep.prototype.removeSub = function removeSub (sub) { + Dep.prototype.removeSub = function removeSub(sub) { remove(this.subs, sub); }; - Dep.prototype.depend = function depend () { + Dep.prototype.depend = function depend() { if (Dep.target) { Dep.target.addDep(this); } }; - Dep.prototype.notify = function notify () { + Dep.prototype.notify = function notify() { // stabilize the subscriber list first var subs = this.subs.slice(); if (!config.async) { // subs aren't sorted in scheduler if not running async // we need to sort them now to make sure they fire in correct // order - subs.sort(function (a, b) { return a.id - b.id; }); + subs.sort(function (a, b) { + return a.id - b.id; + }); } for (var i = 0, l = subs.length; i < l; i++) { subs[i].update(); @@ -752,19 +796,19 @@ Dep.target = null; var targetStack = []; - function pushTarget (target) { + function pushTarget(target) { targetStack.push(target); Dep.target = target; } - function popTarget () { + function popTarget() { targetStack.pop(); Dep.target = targetStack[targetStack.length - 1]; } /* */ - var VNode = function VNode ( + var VNode = function VNode( tag, data, children, @@ -804,29 +848,29 @@ // DEPRECATED: alias for componentInstance for backwards compat. /* istanbul ignore next */ prototypeAccessors.child.get = function () { - return this.componentInstance + return this.componentInstance; }; - Object.defineProperties( VNode.prototype, prototypeAccessors ); + Object.defineProperties(VNode.prototype, prototypeAccessors); var createEmptyVNode = function (text) { - if ( text === void 0 ) text = ''; + if (text === void 0) text = ""; var node = new VNode(); node.text = text; node.isComment = true; - return node + return node; }; - function createTextVNode (val) { - return new VNode(undefined, undefined, undefined, String(val)) + function createTextVNode(val) { + return new VNode(undefined, undefined, undefined, String(val)); } // optimized shallow clone // used for static nodes and slot nodes because they may be reused across // multiple renders, cloning them avoids errors when DOM manipulations rely // on their elm reference. - function cloneVNode (vnode) { + function cloneVNode(vnode) { var cloned = new VNode( vnode.tag, vnode.data, @@ -849,7 +893,7 @@ cloned.fnScopeId = vnode.fnScopeId; cloned.asyncMeta = vnode.asyncMeta; cloned.isCloned = true; - return cloned + return cloned; } /* @@ -861,13 +905,13 @@ var arrayMethods = Object.create(arrayProto); var methodsToPatch = [ - 'push', - 'pop', - 'shift', - 'unshift', - 'splice', - 'sort', - 'reverse' + "push", + "pop", + "shift", + "unshift", + "splice", + "sort", + "reverse", ]; /** @@ -876,26 +920,29 @@ methodsToPatch.forEach(function (method) { // cache original method var original = arrayProto[method]; - def(arrayMethods, method, function mutator () { - var args = [], len = arguments.length; - while ( len-- ) args[ len ] = arguments[ len ]; + def(arrayMethods, method, function mutator() { + var args = [], + len = arguments.length; + while (len--) args[len] = arguments[len]; var result = original.apply(this, args); var ob = this.__ob__; var inserted; switch (method) { - case 'push': - case 'unshift': + case "push": + case "unshift": inserted = args; - break - case 'splice': + break; + case "splice": inserted = args.slice(2); - break + break; + } + if (inserted) { + ob.observeArray(inserted); } - if (inserted) { ob.observeArray(inserted); } // notify change ob.dep.notify(); - return result + return result; }); }); @@ -909,7 +956,7 @@ */ var shouldObserve = true; - function toggleObserving (value) { + function toggleObserving(value) { shouldObserve = value; } @@ -919,11 +966,11 @@ * object's property keys into getter/setters that * collect dependencies and dispatch updates. */ - var Observer = function Observer (value) { + var Observer = function Observer(value) { this.value = value; this.dep = new Dep(); this.vmCount = 0; - def(value, '__ob__', this); + def(value, "__ob__", this); if (Array.isArray(value)) { if (hasProto) { protoAugment(value, arrayMethods); @@ -941,7 +988,7 @@ * getter/setters. This method should only be called when * value type is Object. */ - Observer.prototype.walk = function walk (obj) { + Observer.prototype.walk = function walk(obj) { var keys = Object.keys(obj); for (var i = 0; i < keys.length; i++) { defineReactive$$1(obj, keys[i]); @@ -951,7 +998,7 @@ /** * Observe a list of Array items. */ - Observer.prototype.observeArray = function observeArray (items) { + Observer.prototype.observeArray = function observeArray(items) { for (var i = 0, l = items.length; i < l; i++) { observe(items[i]); } @@ -963,7 +1010,7 @@ * Augment a target Object or Array by intercepting * the prototype chain using __proto__ */ - function protoAugment (target, src) { + function protoAugment(target, src) { /* eslint-disable no-proto */ target.__proto__ = src; /* eslint-enable no-proto */ @@ -974,7 +1021,7 @@ * hidden properties. */ /* istanbul ignore next */ - function copyAugment (target, src, keys) { + function copyAugment(target, src, keys) { for (var i = 0, l = keys.length; i < l; i++) { var key = keys[i]; def(target, key, src[key]); @@ -986,12 +1033,12 @@ * returns the new observer if successfully observed, * or the existing observer if the value already has one. */ - function observe (value, asRootData) { + function observe(value, asRootData) { if (!isObject(value) || value instanceof VNode) { - return + return; } var ob; - if (hasOwn(value, '__ob__') && value.__ob__ instanceof Observer) { + if (hasOwn(value, "__ob__") && value.__ob__ instanceof Observer) { ob = value.__ob__; } else if ( shouldObserve && @@ -1005,24 +1052,18 @@ if (asRootData && ob) { ob.vmCount++; } - return ob + return ob; } /** * Define a reactive property on an Object. */ - function defineReactive$$1 ( - obj, - key, - val, - customSetter, - shallow - ) { + function defineReactive$$1(obj, key, val, customSetter, shallow) { var dep = new Dep(); var property = Object.getOwnPropertyDescriptor(obj, key); if (property && property.configurable === false) { - return + return; } // cater for pre-defined getter/setters @@ -1036,7 +1077,7 @@ Object.defineProperty(obj, key, { enumerable: true, configurable: true, - get: function reactiveGetter () { + get: function reactiveGetter() { var value = getter ? getter.call(obj) : val; if (Dep.target) { dep.depend(); @@ -1047,20 +1088,22 @@ } } } - return value + return value; }, - set: function reactiveSetter (newVal) { + set: function reactiveSetter(newVal) { var value = getter ? getter.call(obj) : val; /* eslint-disable no-self-compare */ if (newVal === value || (newVal !== newVal && value !== value)) { - return + return; } /* eslint-enable no-self-compare */ if (customSetter) { customSetter(); } // #7981: for accessor properties without setter - if (getter && !setter) { return } + if (getter && !setter) { + return; + } if (setter) { setter.call(obj, newVal); } else { @@ -1068,7 +1111,7 @@ } childOb = !shallow && observe(newVal); dep.notify(); - } + }, }); } @@ -1077,63 +1120,67 @@ * triggers change notification if the property doesn't * already exist. */ - function set (target, key, val) { - if (isUndef(target) || isPrimitive(target) - ) { - warn(("Cannot set reactive property on undefined, null, or primitive value: " + ((target)))); + function set(target, key, val) { + if (isUndef(target) || isPrimitive(target)) { + warn( + "Cannot set reactive property on undefined, null, or primitive value: " + + target + ); } if (Array.isArray(target) && isValidArrayIndex(key)) { target.length = Math.max(target.length, key); target.splice(key, 1, val); - return val + return val; } if (key in target && !(key in Object.prototype)) { target[key] = val; - return val + return val; } - var ob = (target).__ob__; + var ob = target.__ob__; if (target._isVue || (ob && ob.vmCount)) { warn( - 'Avoid adding reactive properties to a Vue instance or its root $data ' + - 'at runtime - declare it upfront in the data option.' + "Avoid adding reactive properties to a Vue instance or its root $data " + + "at runtime - declare it upfront in the data option." ); - return val + return val; } if (!ob) { target[key] = val; - return val + return val; } defineReactive$$1(ob.value, key, val); ob.dep.notify(); - return val + return val; } /** * Delete a property and trigger change if necessary. */ - function del (target, key) { - if (isUndef(target) || isPrimitive(target) - ) { - warn(("Cannot delete reactive property on undefined, null, or primitive value: " + ((target)))); + function del(target, key) { + if (isUndef(target) || isPrimitive(target)) { + warn( + "Cannot delete reactive property on undefined, null, or primitive value: " + + target + ); } if (Array.isArray(target) && isValidArrayIndex(key)) { target.splice(key, 1); - return + return; } - var ob = (target).__ob__; + var ob = target.__ob__; if (target._isVue || (ob && ob.vmCount)) { warn( - 'Avoid deleting properties on a Vue instance or its root $data ' + - '- just set it to null.' + "Avoid deleting properties on a Vue instance or its root $data " + + "- just set it to null." ); - return + return; } if (!hasOwn(target, key)) { - return + return; } delete target[key]; if (!ob) { - return + return; } ob.dep.notify(); } @@ -1142,8 +1189,8 @@ * Collect dependencies on array elements when the array is touched, since * we cannot intercept array element access like property getters. */ - function dependArray (value) { - for (var e = (void 0), i = 0, l = value.length; i < l; i++) { + function dependArray(value) { + for (var e = void 0, i = 0, l = value.length; i < l; i++) { e = value[i]; e && e.__ob__ && e.__ob__.dep.depend(); if (Array.isArray(e)) { @@ -1168,29 +1215,33 @@ strats.el = strats.propsData = function (parent, child, vm, key) { if (!vm) { warn( - "option \"" + key + "\" can only be used during instance " + - 'creation with the `new` keyword.' + 'option "' + + key + + '" can only be used during instance ' + + "creation with the `new` keyword." ); } - return defaultStrat(parent, child) + return defaultStrat(parent, child); }; } /** * Helper that recursively merges two data objects together. */ - function mergeData (to, from) { - if (!from) { return to } + function mergeData(to, from) { + if (!from) { + return to; + } var key, toVal, fromVal; - var keys = hasSymbol - ? Reflect.ownKeys(from) - : Object.keys(from); + var keys = hasSymbol ? Reflect.ownKeys(from) : Object.keys(from); for (var i = 0; i < keys.length; i++) { key = keys[i]; // in case the object is already observed... - if (key === '__ob__') { continue } + if (key === "__ob__") { + continue; + } toVal = to[key]; fromVal = from[key]; if (!hasOwn(to, key)) { @@ -1203,103 +1254,90 @@ mergeData(toVal, fromVal); } } - return to + return to; } /** * Data */ - function mergeDataOrFn ( - parentVal, - childVal, - vm - ) { + function mergeDataOrFn(parentVal, childVal, vm) { if (!vm) { // in a Vue.extend merge, both should be functions if (!childVal) { - return parentVal + return parentVal; } if (!parentVal) { - return childVal + return childVal; } // when parentVal & childVal are both present, // we need to return a function that returns the // merged result of both functions... no need to // check if parentVal is a function here because // it has to be a function to pass previous merges. - return function mergedDataFn () { + return function mergedDataFn() { return mergeData( - typeof childVal === 'function' ? childVal.call(this, this) : childVal, - typeof parentVal === 'function' ? parentVal.call(this, this) : parentVal - ) - } + typeof childVal === "function" ? childVal.call(this, this) : childVal, + typeof parentVal === "function" + ? parentVal.call(this, this) + : parentVal + ); + }; } else { - return function mergedInstanceDataFn () { + return function mergedInstanceDataFn() { // instance merge - var instanceData = typeof childVal === 'function' - ? childVal.call(vm, vm) - : childVal; - var defaultData = typeof parentVal === 'function' - ? parentVal.call(vm, vm) - : parentVal; + var instanceData = + typeof childVal === "function" ? childVal.call(vm, vm) : childVal; + var defaultData = + typeof parentVal === "function" ? parentVal.call(vm, vm) : parentVal; if (instanceData) { - return mergeData(instanceData, defaultData) + return mergeData(instanceData, defaultData); } else { - return defaultData + return defaultData; } - } + }; } } - strats.data = function ( - parentVal, - childVal, - vm - ) { + strats.data = function (parentVal, childVal, vm) { if (!vm) { - if (childVal && typeof childVal !== 'function') { + if (childVal && typeof childVal !== "function") { warn( 'The "data" option should be a function ' + - 'that returns a per-instance value in component ' + - 'definitions.', + "that returns a per-instance value in component " + + "definitions.", vm ); - return parentVal + return parentVal; } - return mergeDataOrFn(parentVal, childVal) + return mergeDataOrFn(parentVal, childVal); } - return mergeDataOrFn(parentVal, childVal, vm) + return mergeDataOrFn(parentVal, childVal, vm); }; /** * Hooks and props are merged as arrays. */ - function mergeHook ( - parentVal, - childVal - ) { + function mergeHook(parentVal, childVal) { var res = childVal ? parentVal ? parentVal.concat(childVal) : Array.isArray(childVal) - ? childVal - : [childVal] + ? childVal + : [childVal] : parentVal; - return res - ? dedupeHooks(res) - : res + return res ? dedupeHooks(res) : res; } - function dedupeHooks (hooks) { + function dedupeHooks(hooks) { var res = []; for (var i = 0; i < hooks.length; i++) { if (res.indexOf(hooks[i]) === -1) { res.push(hooks[i]); } } - return res + return res; } LIFECYCLE_HOOKS.forEach(function (hook) { @@ -1313,23 +1351,18 @@ * a three-way merge between constructor options, instance * options and parent options. */ - function mergeAssets ( - parentVal, - childVal, - vm, - key - ) { + function mergeAssets(parentVal, childVal, vm, key) { var res = Object.create(parentVal || null); if (childVal) { assertObjectType(key, childVal, vm); - return extend(res, childVal) + return extend(res, childVal); } else { - return res + return res; } } ASSET_TYPES.forEach(function (type) { - strats[type + 's'] = mergeAssets; + strats[type + "s"] = mergeAssets; }); /** @@ -1338,21 +1371,24 @@ * Watchers hashes should not overwrite one * another, so we merge them as arrays. */ - strats.watch = function ( - parentVal, - childVal, - vm, - key - ) { + strats.watch = function (parentVal, childVal, vm, key) { // work around Firefox's Object.prototype.watch... - if (parentVal === nativeWatch) { parentVal = undefined; } - if (childVal === nativeWatch) { childVal = undefined; } + if (parentVal === nativeWatch) { + parentVal = undefined; + } + if (childVal === nativeWatch) { + childVal = undefined; + } /* istanbul ignore if */ - if (!childVal) { return Object.create(parentVal || null) } + if (!childVal) { + return Object.create(parentVal || null); + } { assertObjectType(key, childVal, vm); } - if (!parentVal) { return childVal } + if (!parentVal) { + return childVal; + } var ret = {}; extend(ret, parentVal); for (var key$1 in childVal) { @@ -1363,63 +1399,70 @@ } ret[key$1] = parent ? parent.concat(child) - : Array.isArray(child) ? child : [child]; + : Array.isArray(child) + ? child + : [child]; } - return ret + return ret; }; /** * Other object hashes. */ strats.props = - strats.methods = - strats.inject = - strats.computed = function ( - parentVal, - childVal, - vm, - key - ) { - if (childVal && "development" !== 'production') { - assertObjectType(key, childVal, vm); - } - if (!parentVal) { return childVal } - var ret = Object.create(null); - extend(ret, parentVal); - if (childVal) { extend(ret, childVal); } - return ret - }; + strats.methods = + strats.inject = + strats.computed = + function (parentVal, childVal, vm, key) { + if (childVal && "development" !== "production") { + assertObjectType(key, childVal, vm); + } + if (!parentVal) { + return childVal; + } + var ret = Object.create(null); + extend(ret, parentVal); + if (childVal) { + extend(ret, childVal); + } + return ret; + }; strats.provide = mergeDataOrFn; /** * Default strategy. */ var defaultStrat = function (parentVal, childVal) { - return childVal === undefined - ? parentVal - : childVal + return childVal === undefined ? parentVal : childVal; }; /** * Validate component names */ - function checkComponents (options) { + function checkComponents(options) { for (var key in options.components) { validateComponentName(key); } } - function validateComponentName (name) { - if (!new RegExp(("^[a-zA-Z][\\-\\.0-9_" + (unicodeRegExp.source) + "]*$")).test(name)) { + function validateComponentName(name) { + if ( + !new RegExp("^[a-zA-Z][\\-\\.0-9_" + unicodeRegExp.source + "]*$").test( + name + ) + ) { warn( - 'Invalid component name: "' + name + '". Component names ' + - 'should conform to valid custom element name in html5 specification.' + 'Invalid component name: "' + + name + + '". Component names ' + + "should conform to valid custom element name in html5 specification." ); } if (isBuiltInTag(name) || config.isReservedTag(name)) { warn( - 'Do not use built-in or reserved HTML elements as component ' + - 'id: ' + name + "Do not use built-in or reserved HTML elements as component " + + "id: " + + name ); } } @@ -1428,34 +1471,36 @@ * Ensure all props option syntax are normalized into the * Object-based format. */ - function normalizeProps (options, vm) { + function normalizeProps(options, vm) { var props = options.props; - if (!props) { return } + if (!props) { + return; + } var res = {}; var i, val, name; if (Array.isArray(props)) { i = props.length; while (i--) { val = props[i]; - if (typeof val === 'string') { + if (typeof val === "string") { name = camelize(val); res[name] = { type: null }; } else { - warn('props must be strings when using array syntax.'); + warn("props must be strings when using array syntax."); } } } else if (isPlainObject(props)) { for (var key in props) { val = props[key]; name = camelize(key); - res[name] = isPlainObject(val) - ? val - : { type: val }; + res[name] = isPlainObject(val) ? val : { type: val }; } } else { warn( - "Invalid value for option \"props\": expected an Array or an Object, " + - "but got " + (toRawType(props)) + ".", + 'Invalid value for option "props": expected an Array or an Object, ' + + "but got " + + toRawType(props) + + ".", vm ); } @@ -1465,10 +1510,12 @@ /** * Normalize all injections into Object-based format */ - function normalizeInject (options, vm) { + function normalizeInject(options, vm) { var inject = options.inject; - if (!inject) { return } - var normalized = options.inject = {}; + if (!inject) { + return; + } + var normalized = (options.inject = {}); if (Array.isArray(inject)) { for (var i = 0; i < inject.length; i++) { normalized[inject[i]] = { from: inject[i] }; @@ -1482,8 +1529,10 @@ } } else { warn( - "Invalid value for option \"inject\": expected an Array or an Object, " + - "but got " + (toRawType(inject)) + ".", + 'Invalid value for option "inject": expected an Array or an Object, ' + + "but got " + + toRawType(inject) + + ".", vm ); } @@ -1492,23 +1541,27 @@ /** * Normalize raw function directives into object format. */ - function normalizeDirectives (options) { + function normalizeDirectives(options) { var dirs = options.directives; if (dirs) { for (var key in dirs) { var def$$1 = dirs[key]; - if (typeof def$$1 === 'function') { + if (typeof def$$1 === "function") { dirs[key] = { bind: def$$1, update: def$$1 }; } } } } - function assertObjectType (name, value, vm) { + function assertObjectType(name, value, vm) { if (!isPlainObject(value)) { warn( - "Invalid value for option \"" + name + "\": expected an Object, " + - "but got " + (toRawType(value)) + ".", + 'Invalid value for option "' + + name + + '": expected an Object, ' + + "but got " + + toRawType(value) + + ".", vm ); } @@ -1518,16 +1571,12 @@ * Merge two option objects into a new one. * Core utility used in both instantiation and inheritance. */ - function mergeOptions ( - parent, - child, - vm - ) { + function mergeOptions(parent, child, vm) { { checkComponents(child); } - if (typeof child === 'function') { + if (typeof child === "function") { child = child.options; } @@ -1560,11 +1609,11 @@ mergeField(key); } } - function mergeField (key) { + function mergeField(key) { var strat = strats[key] || defaultStrat; options[key] = strat(parent[key], child[key], vm, key); } - return options + return options; } /** @@ -1572,53 +1621,44 @@ * This function is used because child instances need access * to assets defined in its ancestor chain. */ - function resolveAsset ( - options, - type, - id, - warnMissing - ) { + function resolveAsset(options, type, id, warnMissing) { /* istanbul ignore if */ - if (typeof id !== 'string') { - return + if (typeof id !== "string") { + return; } var assets = options[type]; // check local registration variations first - if (hasOwn(assets, id)) { return assets[id] } + if (hasOwn(assets, id)) { + return assets[id]; + } var camelizedId = camelize(id); - if (hasOwn(assets, camelizedId)) { return assets[camelizedId] } + if (hasOwn(assets, camelizedId)) { + return assets[camelizedId]; + } var PascalCaseId = capitalize(camelizedId); - if (hasOwn(assets, PascalCaseId)) { return assets[PascalCaseId] } + if (hasOwn(assets, PascalCaseId)) { + return assets[PascalCaseId]; + } // fallback to prototype chain var res = assets[id] || assets[camelizedId] || assets[PascalCaseId]; if (warnMissing && !res) { - warn( - 'Failed to resolve ' + type.slice(0, -1) + ': ' + id, - options - ); + warn("Failed to resolve " + type.slice(0, -1) + ": " + id, options); } - return res + return res; } /* */ - - - function validateProp ( - key, - propOptions, - propsData, - vm - ) { + function validateProp(key, propOptions, propsData, vm) { var prop = propOptions[key]; var absent = !hasOwn(propsData, key); var value = propsData[key]; // boolean casting var booleanIndex = getTypeIndex(Boolean, prop.type); if (booleanIndex > -1) { - if (absent && !hasOwn(prop, 'default')) { + if (absent && !hasOwn(prop, "default")) { value = false; - } else if (value === '' || value === hyphenate(key)) { + } else if (value === "" || value === hyphenate(key)) { // only cast empty string / same name to boolean if // boolean has higher priority var stringIndex = getTypeIndex(String, prop.type); @@ -1640,61 +1680,56 @@ { assertProp(prop, key, value, vm, absent); } - return value + return value; } /** * Get the default value of a prop. */ - function getPropDefaultValue (vm, prop, key) { + function getPropDefaultValue(vm, prop, key) { // no default, return undefined - if (!hasOwn(prop, 'default')) { - return undefined + if (!hasOwn(prop, "default")) { + return undefined; } var def = prop.default; // warn against non-factory defaults for Object & Array if (isObject(def)) { warn( - 'Invalid default value for prop "' + key + '": ' + - 'Props with type Object/Array must use a factory function ' + - 'to return the default value.', + 'Invalid default value for prop "' + + key + + '": ' + + "Props with type Object/Array must use a factory function " + + "to return the default value.", vm ); } // the raw prop value was also undefined from previous render, // return previous default value to avoid unnecessary watcher trigger - if (vm && vm.$options.propsData && + if ( + vm && + vm.$options.propsData && vm.$options.propsData[key] === undefined && vm._props[key] !== undefined ) { - return vm._props[key] + return vm._props[key]; } // call factory function for non-Function types // a value is Function if its prototype is function even across different execution context - return typeof def === 'function' && getType(prop.type) !== 'Function' + return typeof def === "function" && getType(prop.type) !== "Function" ? def.call(vm) - : def + : def; } /** * Assert whether a prop is valid. */ - function assertProp ( - prop, - name, - value, - vm, - absent - ) { + function assertProp(prop, name, value, vm, absent) { if (prop.required && absent) { - warn( - 'Missing required prop: "' + name + '"', - vm - ); - return + warn('Missing required prop: "' + name + '"', vm); + return; } if (value == null && !prop.required) { - return + return; } var type = prop.type; var valid = !type || type === true; @@ -1705,23 +1740,22 @@ } for (var i = 0; i < type.length && !valid; i++) { var assertedType = assertType(value, type[i]); - expectedTypes.push(assertedType.expectedType || ''); + expectedTypes.push(assertedType.expectedType || ""); valid = assertedType.valid; } } if (!valid) { - warn( - getInvalidTypeMessage(name, value, expectedTypes), - vm - ); - return + warn(getInvalidTypeMessage(name, value, expectedTypes), vm); + return; } var validator = prop.validator; if (validator) { if (!validator(value)) { warn( - 'Invalid prop: custom validator check failed for prop "' + name + '".', + 'Invalid prop: custom validator check failed for prop "' + + name + + '".', vm ); } @@ -1730,27 +1764,27 @@ var simpleCheckRE = /^(String|Number|Boolean|Function|Symbol)$/; - function assertType (value, type) { + function assertType(value, type) { var valid; var expectedType = getType(type); if (simpleCheckRE.test(expectedType)) { var t = typeof value; valid = t === expectedType.toLowerCase(); // for primitive wrapper objects - if (!valid && t === 'object') { + if (!valid && t === "object") { valid = value instanceof type; } - } else if (expectedType === 'Object') { + } else if (expectedType === "Object") { valid = isPlainObject(value); - } else if (expectedType === 'Array') { + } else if (expectedType === "Array") { valid = Array.isArray(value); } else { valid = value instanceof type; } return { valid: valid, - expectedType: expectedType - } + expectedType: expectedType, + }; } /** @@ -1758,38 +1792,44 @@ * because a simple equality check will fail when running * across different vms / iframes. */ - function getType (fn) { + function getType(fn) { var match = fn && fn.toString().match(/^\s*function (\w+)/); - return match ? match[1] : '' + return match ? match[1] : ""; } - function isSameType (a, b) { - return getType(a) === getType(b) + function isSameType(a, b) { + return getType(a) === getType(b); } - function getTypeIndex (type, expectedTypes) { + function getTypeIndex(type, expectedTypes) { if (!Array.isArray(expectedTypes)) { - return isSameType(expectedTypes, type) ? 0 : -1 + return isSameType(expectedTypes, type) ? 0 : -1; } for (var i = 0, len = expectedTypes.length; i < len; i++) { if (isSameType(expectedTypes[i], type)) { - return i + return i; } } - return -1 + return -1; } - function getInvalidTypeMessage (name, value, expectedTypes) { - var message = "Invalid prop: type check failed for prop \"" + name + "\"." + - " Expected " + (expectedTypes.map(capitalize).join(', ')); + function getInvalidTypeMessage(name, value, expectedTypes) { + var message = + 'Invalid prop: type check failed for prop "' + + name + + '".' + + " Expected " + + expectedTypes.map(capitalize).join(", "); var expectedType = expectedTypes[0]; var receivedType = toRawType(value); var expectedValue = styleValue(value, expectedType); var receivedValue = styleValue(value, receivedType); // check if we need to specify expected value - if (expectedTypes.length === 1 && - isExplicable(expectedType) && - !isBoolean(expectedType, receivedType)) { + if ( + expectedTypes.length === 1 && + isExplicable(expectedType) && + !isBoolean(expectedType, receivedType) + ) { message += " with value " + expectedValue; } message += ", got " + receivedType + " "; @@ -1797,34 +1837,39 @@ if (isExplicable(receivedType)) { message += "with value " + receivedValue + "."; } - return message + return message; } - function styleValue (value, type) { - if (type === 'String') { - return ("\"" + value + "\"") - } else if (type === 'Number') { - return ("" + (Number(value))) + function styleValue(value, type) { + if (type === "String") { + return '"' + value + '"'; + } else if (type === "Number") { + return "" + Number(value); } else { - return ("" + value) + return "" + value; } } - function isExplicable (value) { - var explicitTypes = ['string', 'number', 'boolean']; - return explicitTypes.some(function (elem) { return value.toLowerCase() === elem; }) + function isExplicable(value) { + var explicitTypes = ["string", "number", "boolean"]; + return explicitTypes.some(function (elem) { + return value.toLowerCase() === elem; + }); } - function isBoolean () { - var args = [], len = arguments.length; - while ( len-- ) args[ len ] = arguments[ len ]; + function isBoolean() { + var args = [], + len = arguments.length; + while (len--) args[len] = arguments[len]; - return args.some(function (elem) { return elem.toLowerCase() === 'boolean'; }) + return args.some(function (elem) { + return elem.toLowerCase() === "boolean"; + }); } /* */ - function handleError (err, vm, info) { + function handleError(err, vm, info) { // Deactivate deps tracking while processing error handler to avoid possible infinite rendering. // See: https://github.com/vuejs/vuex/issues/1505 pushTarget(); @@ -1837,9 +1882,11 @@ for (var i = 0; i < hooks.length; i++) { try { var capture = hooks[i].call(cur, err, vm, info) === false; - if (capture) { return } + if (capture) { + return; + } } catch (e) { - globalHandleError(e, cur, 'errorCaptured hook'); + globalHandleError(e, cur, "errorCaptured hook"); } } } @@ -1851,18 +1898,14 @@ } } - function invokeWithErrorHandling ( - handler, - context, - args, - vm, - info - ) { + function invokeWithErrorHandling(handler, context, args, vm, info) { var res; try { res = args ? handler.apply(context, args) : handler.call(context); if (res && !res._isVue && isPromise(res) && !res._handled) { - res.catch(function (e) { return handleError(e, vm, info + " (Promise/async)"); }); + res.catch(function (e) { + return handleError(e, vm, info + " (Promise/async)"); + }); // issue #9511 // avoid catch triggering multiple times when nested calls res._handled = true; @@ -1870,33 +1913,33 @@ } catch (e) { handleError(e, vm, info); } - return res + return res; } - function globalHandleError (err, vm, info) { + function globalHandleError(err, vm, info) { if (config.errorHandler) { try { - return config.errorHandler.call(null, err, vm, info) + return config.errorHandler.call(null, err, vm, info); } catch (e) { // if the user intentionally throws the original error in the handler, // do not log it twice if (e !== err) { - logError(e, null, 'config.errorHandler'); + logError(e, null, "config.errorHandler"); } } } logError(err, vm, info); } - function logError (err, vm, info) { + function logError(err, vm, info) { { - warn(("Error in " + info + ": \"" + (err.toString()) + "\""), vm); + warn("Error in " + info + ': "' + err.toString() + '"', vm); } /* istanbul ignore else */ - if ((inBrowser || inWeex) && typeof console !== 'undefined') { + if ((inBrowser || inWeex) && typeof console !== "undefined") { console.error(err); } else { - throw err + throw err; } } @@ -1907,7 +1950,7 @@ var callbacks = []; var pending = false; - function flushCallbacks () { + function flushCallbacks() { pending = false; var copies = callbacks.slice(0); callbacks.length = 0; @@ -1936,7 +1979,7 @@ // completely stops working after triggering a few times... so, if native // Promise is available, we will use it: /* istanbul ignore next, $flow-disable-line */ - if (typeof Promise !== 'undefined' && isNative(Promise)) { + if (typeof Promise !== "undefined" && isNative(Promise)) { var p = Promise.resolve(); timerFunc = function () { p.then(flushCallbacks); @@ -1945,14 +1988,18 @@ // microtask queue but the queue isn't being flushed, until the browser // needs to do some other work, e.g. handle a timer. Therefore we can // "force" the microtask queue to be flushed by adding an empty timer. - if (isIOS) { setTimeout(noop); } + if (isIOS) { + setTimeout(noop); + } }; isUsingMicroTask = true; - } else if (!isIE && typeof MutationObserver !== 'undefined' && ( - isNative(MutationObserver) || - // PhantomJS and iOS 7.x - MutationObserver.toString() === '[object MutationObserverConstructor]' - )) { + } else if ( + !isIE && + typeof MutationObserver !== "undefined" && + (isNative(MutationObserver) || + // PhantomJS and iOS 7.x + MutationObserver.toString() === "[object MutationObserverConstructor]") + ) { // Use MutationObserver where native Promise is not available, // e.g. PhantomJS, iOS7, Android 4.4 // (#6466 MutationObserver is unreliable in IE11) @@ -1960,14 +2007,14 @@ var observer = new MutationObserver(flushCallbacks); var textNode = document.createTextNode(String(counter)); observer.observe(textNode, { - characterData: true + characterData: true, }); timerFunc = function () { counter = (counter + 1) % 2; textNode.data = String(counter); }; isUsingMicroTask = true; - } else if (typeof setImmediate !== 'undefined' && isNative(setImmediate)) { + } else if (typeof setImmediate !== "undefined" && isNative(setImmediate)) { // Fallback to setImmediate. // Technically it leverages the (macro) task queue, // but it is still a better choice than setTimeout. @@ -1981,14 +2028,14 @@ }; } - function nextTick (cb, ctx) { + function nextTick(cb, ctx) { var _resolve; callbacks.push(function () { if (cb) { try { cb.call(ctx); } catch (e) { - handleError(e, ctx, 'nextTick'); + handleError(e, ctx, "nextTick"); } } else if (_resolve) { _resolve(ctx); @@ -1999,10 +2046,10 @@ timerFunc(); } // $flow-disable-line - if (!cb && typeof Promise !== 'undefined') { + if (!cb && typeof Promise !== "undefined") { return new Promise(function (resolve) { _resolve = resolve; - }) + }); } } @@ -2021,7 +2068,9 @@ perf.clearMarks && perf.clearMeasures ) { - mark = function (tag) { return perf.mark(tag); }; + mark = function (tag) { + return perf.mark(tag); + }; measure = function (name, startTag, endTag) { perf.measure(name, startTag, endTag); perf.clearMarks(startTag); @@ -2037,81 +2086,100 @@ { var allowedGlobals = makeMap( - 'Infinity,undefined,NaN,isFinite,isNaN,' + - 'parseFloat,parseInt,decodeURI,decodeURIComponent,encodeURI,encodeURIComponent,' + - 'Math,Number,Date,Array,Object,Boolean,String,RegExp,Map,Set,JSON,Intl,' + - 'require' // for Webpack/Browserify + "Infinity,undefined,NaN,isFinite,isNaN," + + "parseFloat,parseInt,decodeURI,decodeURIComponent,encodeURI,encodeURIComponent," + + "Math,Number,Date,Array,Object,Boolean,String,RegExp,Map,Set,JSON,Intl," + + "require" // for Webpack/Browserify ); var warnNonPresent = function (target, key) { warn( - "Property or method \"" + key + "\" is not defined on the instance but " + - 'referenced during render. Make sure that this property is reactive, ' + - 'either in the data option, or for class-based components, by ' + - 'initializing the property. ' + - 'See: https://vuejs.org/v2/guide/reactivity.html#Declaring-Reactive-Properties.', + 'Property or method "' + + key + + '" is not defined on the instance but ' + + "referenced during render. Make sure that this property is reactive, " + + "either in the data option, or for class-based components, by " + + "initializing the property. " + + "See: https://vuejs.org/v2/guide/reactivity.html#Declaring-Reactive-Properties.", target ); }; var warnReservedPrefix = function (target, key) { warn( - "Property \"" + key + "\" must be accessed with \"$data." + key + "\" because " + - 'properties starting with "$" or "_" are not proxied in the Vue instance to ' + - 'prevent conflicts with Vue internals. ' + - 'See: https://vuejs.org/v2/api/#data', + 'Property "' + + key + + '" must be accessed with "$data.' + + key + + '" because ' + + 'properties starting with "$" or "_" are not proxied in the Vue instance to ' + + "prevent conflicts with Vue internals. " + + "See: https://vuejs.org/v2/api/#data", target ); }; - var hasProxy = - typeof Proxy !== 'undefined' && isNative(Proxy); + var hasProxy = typeof Proxy !== "undefined" && isNative(Proxy); if (hasProxy) { - var isBuiltInModifier = makeMap('stop,prevent,self,ctrl,shift,alt,meta,exact'); + var isBuiltInModifier = makeMap( + "stop,prevent,self,ctrl,shift,alt,meta,exact" + ); config.keyCodes = new Proxy(config.keyCodes, { - set: function set (target, key, value) { + set: function set(target, key, value) { if (isBuiltInModifier(key)) { - warn(("Avoid overwriting built-in modifier in config.keyCodes: ." + key)); - return false + warn( + "Avoid overwriting built-in modifier in config.keyCodes: ." + key + ); + return false; } else { target[key] = value; - return true + return true; } - } + }, }); } var hasHandler = { - has: function has (target, key) { + has: function has(target, key) { var has = key in target; - var isAllowed = allowedGlobals(key) || - (typeof key === 'string' && key.charAt(0) === '_' && !(key in target.$data)); + var isAllowed = + allowedGlobals(key) || + (typeof key === "string" && + key.charAt(0) === "_" && + !(key in target.$data)); if (!has && !isAllowed) { - if (key in target.$data) { warnReservedPrefix(target, key); } - else { warnNonPresent(target, key); } + if (key in target.$data) { + warnReservedPrefix(target, key); + } else { + warnNonPresent(target, key); + } } - return has || !isAllowed - } + return has || !isAllowed; + }, }; var getHandler = { - get: function get (target, key) { - if (typeof key === 'string' && !(key in target)) { - if (key in target.$data) { warnReservedPrefix(target, key); } - else { warnNonPresent(target, key); } + get: function get(target, key) { + if (typeof key === "string" && !(key in target)) { + if (key in target.$data) { + warnReservedPrefix(target, key); + } else { + warnNonPresent(target, key); + } } - return target[key] - } + return target[key]; + }, }; - initProxy = function initProxy (vm) { + initProxy = function initProxy(vm) { if (hasProxy) { // determine which proxy handler to use var options = vm.$options; - var handlers = options.render && options.render._withStripped - ? getHandler - : hasHandler; + var handlers = + options.render && options.render._withStripped + ? getHandler + : hasHandler; vm._renderProxy = new Proxy(vm, handlers); } else { vm._renderProxy = vm; @@ -2128,78 +2196,91 @@ * getters, so that every nested property inside the object * is collected as a "deep" dependency. */ - function traverse (val) { + function traverse(val) { _traverse(val, seenObjects); seenObjects.clear(); } - function _traverse (val, seen) { + function _traverse(val, seen) { var i, keys; var isA = Array.isArray(val); - if ((!isA && !isObject(val)) || Object.isFrozen(val) || val instanceof VNode) { - return + if ( + (!isA && !isObject(val)) || + Object.isFrozen(val) || + val instanceof VNode + ) { + return; } if (val.__ob__) { var depId = val.__ob__.dep.id; if (seen.has(depId)) { - return + return; } seen.add(depId); } if (isA) { i = val.length; - while (i--) { _traverse(val[i], seen); } + while (i--) { + _traverse(val[i], seen); + } } else { keys = Object.keys(val); i = keys.length; - while (i--) { _traverse(val[keys[i]], seen); } + while (i--) { + _traverse(val[keys[i]], seen); + } } } /* */ var normalizeEvent = cached(function (name) { - var passive = name.charAt(0) === '&'; + var passive = name.charAt(0) === "&"; name = passive ? name.slice(1) : name; - var once$$1 = name.charAt(0) === '~'; // Prefixed last, checked first + var once$$1 = name.charAt(0) === "~"; // Prefixed last, checked first name = once$$1 ? name.slice(1) : name; - var capture = name.charAt(0) === '!'; + var capture = name.charAt(0) === "!"; name = capture ? name.slice(1) : name; return { name: name, once: once$$1, capture: capture, - passive: passive - } + passive: passive, + }; }); - function createFnInvoker (fns, vm) { - function invoker () { + function createFnInvoker(fns, vm) { + function invoker() { var arguments$1 = arguments; var fns = invoker.fns; if (Array.isArray(fns)) { var cloned = fns.slice(); for (var i = 0; i < cloned.length; i++) { - invokeWithErrorHandling(cloned[i], null, arguments$1, vm, "v-on handler"); + invokeWithErrorHandling( + cloned[i], + null, + arguments$1, + vm, + "v-on handler" + ); } } else { // return handler return value for single handlers - return invokeWithErrorHandling(fns, null, arguments, vm, "v-on handler") + return invokeWithErrorHandling( + fns, + null, + arguments, + vm, + "v-on handler" + ); } } invoker.fns = fns; - return invoker + return invoker; } - function updateListeners ( - on, - oldOn, - add, - remove$$1, - createOnceHandler, - vm - ) { + function updateListeners(on, oldOn, add, remove$$1, createOnceHandler, vm) { var name, def$$1, cur, old, event; for (name in on) { def$$1 = cur = on[name]; @@ -2207,7 +2288,7 @@ event = normalizeEvent(name); if (isUndef(cur)) { warn( - "Invalid handler for event \"" + (event.name) + "\": got " + String(cur), + 'Invalid handler for event "' + event.name + '": got ' + String(cur), vm ); } else if (isUndef(old)) { @@ -2233,14 +2314,14 @@ /* */ - function mergeVNodeHook (def, hookKey, hook) { + function mergeVNodeHook(def, hookKey, hook) { if (def instanceof VNode) { def = def.data.hook || (def.data.hook = {}); } var invoker; var oldHook = def[hookKey]; - function wrappedHook () { + function wrappedHook() { hook.apply(this, arguments); // important: remove merged hook to ensure it's called only once // and prevent memory leak @@ -2268,17 +2349,13 @@ /* */ - function extractPropsFromVNodeData ( - data, - Ctor, - tag - ) { + function extractPropsFromVNodeData(data, Ctor, tag) { // we are only extracting raw values here. // validation and default values are handled in the child // component itself. var propOptions = Ctor.options.props; if (isUndef(propOptions)) { - return + return; } var res = {}; var attrs = data.attrs; @@ -2290,48 +2367,52 @@ var keyInLowerCase = key.toLowerCase(); if ( key !== keyInLowerCase && - attrs && hasOwn(attrs, keyInLowerCase) + attrs && + hasOwn(attrs, keyInLowerCase) ) { tip( - "Prop \"" + keyInLowerCase + "\" is passed to component " + - (formatComponentName(tag || Ctor)) + ", but the declared prop name is" + - " \"" + key + "\". " + - "Note that HTML attributes are case-insensitive and camelCased " + - "props need to use their kebab-case equivalents when using in-DOM " + - "templates. You should probably use \"" + altKey + "\" instead of \"" + key + "\"." + 'Prop "' + + keyInLowerCase + + '" is passed to component ' + + formatComponentName(tag || Ctor) + + ", but the declared prop name is" + + ' "' + + key + + '". ' + + "Note that HTML attributes are case-insensitive and camelCased " + + "props need to use their kebab-case equivalents when using in-DOM " + + 'templates. You should probably use "' + + altKey + + '" instead of "' + + key + + '".' ); } } checkProp(res, props, key, altKey, true) || - checkProp(res, attrs, key, altKey, false); + checkProp(res, attrs, key, altKey, false); } } - return res + return res; } - function checkProp ( - res, - hash, - key, - altKey, - preserve - ) { + function checkProp(res, hash, key, altKey, preserve) { if (isDef(hash)) { if (hasOwn(hash, key)) { res[key] = hash[key]; if (!preserve) { delete hash[key]; } - return true + return true; } else if (hasOwn(hash, altKey)) { res[key] = hash[altKey]; if (!preserve) { delete hash[altKey]; } - return true + return true; } } - return false + return false; } /* */ @@ -2348,46 +2429,48 @@ // normalization is needed - if any child is an Array, we flatten the whole // thing with Array.prototype.concat. It is guaranteed to be only 1-level deep // because functional components already normalize their own children. - function simpleNormalizeChildren (children) { + function simpleNormalizeChildren(children) { for (var i = 0; i < children.length; i++) { if (Array.isArray(children[i])) { - return Array.prototype.concat.apply([], children) + return Array.prototype.concat.apply([], children); } } - return children + return children; } // 2. When the children contains constructs that always generated nested Arrays, // e.g. <template>, <slot>, v-for, or when the children is provided by user // with hand-written render functions / JSX. In such cases a full normalization // is needed to cater to all possible types of children values. - function normalizeChildren (children) { + function normalizeChildren(children) { return isPrimitive(children) ? [createTextVNode(children)] : Array.isArray(children) - ? normalizeArrayChildren(children) - : undefined + ? normalizeArrayChildren(children) + : undefined; } - function isTextNode (node) { - return isDef(node) && isDef(node.text) && isFalse(node.isComment) + function isTextNode(node) { + return isDef(node) && isDef(node.text) && isFalse(node.isComment); } - function normalizeArrayChildren (children, nestedIndex) { + function normalizeArrayChildren(children, nestedIndex) { var res = []; var i, c, lastIndex, last; for (i = 0; i < children.length; i++) { c = children[i]; - if (isUndef(c) || typeof c === 'boolean') { continue } + if (isUndef(c) || typeof c === "boolean") { + continue; + } lastIndex = res.length - 1; last = res[lastIndex]; // nested if (Array.isArray(c)) { if (c.length > 0) { - c = normalizeArrayChildren(c, ((nestedIndex || '') + "_" + i)); + c = normalizeArrayChildren(c, (nestedIndex || "") + "_" + i); // merge adjacent text nodes if (isTextNode(c[0]) && isTextNode(last)) { - res[lastIndex] = createTextVNode(last.text + (c[0]).text); + res[lastIndex] = createTextVNode(last.text + c[0].text); c.shift(); } res.push.apply(res, c); @@ -2398,7 +2481,7 @@ // this is necessary for SSR hydration because text nodes are // essentially merged when rendered to HTML strings res[lastIndex] = createTextVNode(last.text + c); - } else if (c !== '') { + } else if (c !== "") { // convert primitive to vnode res.push(createTextVNode(c)); } @@ -2408,31 +2491,31 @@ res[lastIndex] = createTextVNode(last.text + c.text); } else { // default key for nested array children (likely generated by v-for) - if (isTrue(children._isVList) && + if ( + isTrue(children._isVList) && isDef(c.tag) && isUndef(c.key) && - isDef(nestedIndex)) { + isDef(nestedIndex) + ) { c.key = "__vlist" + nestedIndex + "_" + i + "__"; } res.push(c); } } } - return res + return res; } /* */ - function initProvide (vm) { + function initProvide(vm) { var provide = vm.$options.provide; if (provide) { - vm._provided = typeof provide === 'function' - ? provide.call(vm) - : provide; + vm._provided = typeof provide === "function" ? provide.call(vm) : provide; } } - function initInjections (vm) { + function initInjections(vm) { var result = resolveInject(vm.$options.inject, vm); if (result) { toggleObserving(false); @@ -2442,8 +2525,10 @@ defineReactive$$1(vm, key, result[key], function () { warn( "Avoid mutating an injected value directly since the changes will be " + - "overwritten whenever the provided component re-renders. " + - "injection being mutated: \"" + key + "\"", + "overwritten whenever the provided component re-renders. " + + 'injection being mutated: "' + + key + + '"', vm ); }); @@ -2453,55 +2538,51 @@ } } - function resolveInject (inject, vm) { + function resolveInject(inject, vm) { if (inject) { // inject is :any because flow is not smart enough to figure out cached var result = Object.create(null); - var keys = hasSymbol - ? Reflect.ownKeys(inject) - : Object.keys(inject); + var keys = hasSymbol ? Reflect.ownKeys(inject) : Object.keys(inject); for (var i = 0; i < keys.length; i++) { var key = keys[i]; // #6574 in case the inject object is observed... - if (key === '__ob__') { continue } + if (key === "__ob__") { + continue; + } var provideKey = inject[key].from; var source = vm; while (source) { if (source._provided && hasOwn(source._provided, provideKey)) { result[key] = source._provided[provideKey]; - break + break; } source = source.$parent; } if (!source) { - if ('default' in inject[key]) { + if ("default" in inject[key]) { var provideDefault = inject[key].default; - result[key] = typeof provideDefault === 'function' - ? provideDefault.call(vm) - : provideDefault; + result[key] = + typeof provideDefault === "function" + ? provideDefault.call(vm) + : provideDefault; } else { - warn(("Injection \"" + key + "\" not found"), vm); + warn('Injection "' + key + '" not found', vm); } } } - return result + return result; } } /* */ - - /** * Runtime helper for resolving raw children VNodes into a slot object. */ - function resolveSlots ( - children, - context - ) { + function resolveSlots(children, context) { if (!children || !children.length) { - return {} + return {}; } var slots = {}; for (var i = 0, l = children.length; i < l; i++) { @@ -2513,12 +2594,14 @@ } // named slots should only be respected if the vnode was rendered in the // same context. - if ((child.context === context || child.fnContext === context) && - data && data.slot != null + if ( + (child.context === context || child.fnContext === context) && + data && + data.slot != null ) { var name = data.slot; - var slot = (slots[name] || (slots[name] = [])); - if (child.tag === 'template') { + var slot = slots[name] || (slots[name] = []); + if (child.tag === "template") { slot.push.apply(slot, child.children || []); } else { slot.push(child); @@ -2533,20 +2616,16 @@ delete slots[name$1]; } } - return slots + return slots; } - function isWhitespace (node) { - return (node.isComment && !node.asyncFactory) || node.text === ' ' + function isWhitespace(node) { + return (node.isComment && !node.asyncFactory) || node.text === " "; } /* */ - function normalizeScopedSlots ( - slots, - normalSlots, - prevSlots - ) { + function normalizeScopedSlots(slots, normalSlots, prevSlots) { var res; var hasNormalSlots = Object.keys(normalSlots).length > 0; var isStable = slots ? !!slots.$stable : !hasNormalSlots; @@ -2555,7 +2634,7 @@ res = {}; } else if (slots._normalized) { // fast path 1: child component re-render only, parent did not change - return slots._normalized + return slots._normalized; } else if ( isStable && prevSlots && @@ -2566,11 +2645,11 @@ ) { // fast path 2: stable scoped slots w/ no normal slots to proxy, // only need to normalize once - return prevSlots + return prevSlots; } else { res = {}; for (var key$1 in slots) { - if (slots[key$1] && key$1[0] !== '$') { + if (slots[key$1] && key$1[0] !== "$") { res[key$1] = normalizeScopedSlot(normalSlots, key$1, slots[key$1]); } } @@ -2584,25 +2663,25 @@ // avoriaz seems to mock a non-extensible $scopedSlots object // and when that is passed down this would cause an error if (slots && Object.isExtensible(slots)) { - (slots)._normalized = res; + slots._normalized = res; } - def(res, '$stable', isStable); - def(res, '$key', key); - def(res, '$hasNormal', hasNormalSlots); - return res + def(res, "$stable", isStable); + def(res, "$key", key); + def(res, "$hasNormal", hasNormalSlots); + return res; } function normalizeScopedSlot(normalSlots, key, fn) { var normalized = function () { var res = arguments.length ? fn.apply(null, arguments) : fn({}); - res = res && typeof res === 'object' && !Array.isArray(res) - ? [res] // single vnode - : normalizeChildren(res); - return res && ( - res.length === 0 || - (res.length === 1 && res[0].isComment) // #9658 - ) ? undefined - : res + res = + res && typeof res === "object" && !Array.isArray(res) + ? [res] // single vnode + : normalizeChildren(res); + return res && + (res.length === 0 || (res.length === 1 && res[0].isComment)) // #9658 + ? undefined + : res; }; // this is a slot using the new v-slot syntax without scope. although it is // compiled as a scoped slot, render fn users would expect it to be present @@ -2611,14 +2690,16 @@ Object.defineProperty(normalSlots, key, { get: normalized, enumerable: true, - configurable: true + configurable: true, }); } - return normalized + return normalized; } function proxyNormalSlot(slots, key) { - return function () { return slots[key]; } + return function () { + return slots[key]; + }; } /* */ @@ -2626,17 +2707,14 @@ /** * Runtime helper for rendering v-for lists. */ - function renderList ( - val, - render - ) { + function renderList(val, render) { var ret, i, l, keys, key; - if (Array.isArray(val) || typeof val === 'string') { + if (Array.isArray(val) || typeof val === "string") { ret = new Array(val.length); for (i = 0, l = val.length; i < l; i++) { ret[i] = render(val[i], i); } - } else if (typeof val === 'number') { + } else if (typeof val === "number") { ret = new Array(val); for (i = 0; i < val; i++) { ret[i] = render(i + 1, i); @@ -2662,8 +2740,8 @@ if (!isDef(ret)) { ret = []; } - (ret)._isVList = true; - return ret + ret._isVList = true; + return ret; } /* */ @@ -2671,22 +2749,15 @@ /** * Runtime helper for rendering <slot> */ - function renderSlot ( - name, - fallback, - props, - bindObject - ) { + function renderSlot(name, fallback, props, bindObject) { var scopedSlotFn = this.$scopedSlots[name]; var nodes; - if (scopedSlotFn) { // scoped slot + if (scopedSlotFn) { + // scoped slot props = props || {}; if (bindObject) { if (!isObject(bindObject)) { - warn( - 'slot v-bind without argument expects an Object', - this - ); + warn("slot v-bind without argument expects an Object", this); } props = extend(extend({}, bindObject), props); } @@ -2697,9 +2768,9 @@ var target = props && props.slot; if (target) { - return this.$createElement('template', { slot: target }, nodes) + return this.$createElement("template", { slot: target }, nodes); } else { - return nodes + return nodes; } } @@ -2708,17 +2779,17 @@ /** * Runtime helper for resolving filters */ - function resolveFilter (id) { - return resolveAsset(this.$options, 'filters', id, true) || identity + function resolveFilter(id) { + return resolveAsset(this.$options, "filters", id, true) || identity; } /* */ - function isKeyNotMatch (expect, actual) { + function isKeyNotMatch(expect, actual) { if (Array.isArray(expect)) { - return expect.indexOf(actual) === -1 + return expect.indexOf(actual) === -1; } else { - return expect !== actual + return expect !== actual; } } @@ -2727,7 +2798,7 @@ * exposed as Vue.prototype._k * passing in eventKeyName as last argument separately for backwards compat */ - function checkKeyCodes ( + function checkKeyCodes( eventKeyCode, key, builtInKeyCode, @@ -2736,11 +2807,11 @@ ) { var mappedKeyCode = config.keyCodes[key] || builtInKeyCode; if (builtInKeyName && eventKeyName && !config.keyCodes[key]) { - return isKeyNotMatch(builtInKeyName, eventKeyName) + return isKeyNotMatch(builtInKeyName, eventKeyName); } else if (mappedKeyCode) { - return isKeyNotMatch(mappedKeyCode, eventKeyCode) + return isKeyNotMatch(mappedKeyCode, eventKeyCode); } else if (eventKeyName) { - return hyphenate(eventKeyName) !== key + return hyphenate(eventKeyName) !== key; } } @@ -2749,36 +2820,24 @@ /** * Runtime helper for merging v-bind="object" into a VNode's data. */ - function bindObjectProps ( - data, - tag, - value, - asProp, - isSync - ) { + function bindObjectProps(data, tag, value, asProp, isSync) { if (value) { if (!isObject(value)) { - warn( - 'v-bind without argument expects an Object or Array value', - this - ); + warn("v-bind without argument expects an Object or Array value", this); } else { if (Array.isArray(value)) { value = toObject(value); } var hash; - var loop = function ( key ) { - if ( - key === 'class' || - key === 'style' || - isReservedAttribute(key) - ) { + var loop = function (key) { + if (key === "class" || key === "style" || isReservedAttribute(key)) { hash = data; } else { var type = data.attrs && data.attrs.type; - hash = asProp || config.mustUseProp(tag, type, key) - ? data.domProps || (data.domProps = {}) - : data.attrs || (data.attrs = {}); + hash = + asProp || config.mustUseProp(tag, type, key) + ? data.domProps || (data.domProps = {}) + : data.attrs || (data.attrs = {}); } var camelizedKey = camelize(key); var hyphenatedKey = hyphenate(key); @@ -2787,17 +2846,17 @@ if (isSync) { var on = data.on || (data.on = {}); - on[("update:" + key)] = function ($event) { + on["update:" + key] = function ($event) { value[key] = $event; }; } } }; - for (var key in value) loop( key ); + for (var key in value) loop(key); } } - return data + return data; } /* */ @@ -2805,16 +2864,13 @@ /** * Runtime helper for rendering static trees. */ - function renderStatic ( - index, - isInFor - ) { + function renderStatic(index, isInFor) { var cached = this._staticTrees || (this._staticTrees = []); var tree = cached[index]; // if has already-rendered static tree and not inside v-for, // we can reuse the same tree. if (tree && !isInFor) { - return tree + return tree; } // otherwise, render a fresh tree. tree = cached[index] = this.$options.staticRenderFns[index].call( @@ -2822,32 +2878,24 @@ null, this // for render fns generated for functional component templates ); - markStatic(tree, ("__static__" + index), false); - return tree + markStatic(tree, "__static__" + index, false); + return tree; } /** * Runtime helper for v-once. * Effectively it means marking the node as static with a unique key. */ - function markOnce ( - tree, - index, - key - ) { - markStatic(tree, ("__once__" + index + (key ? ("_" + key) : "")), true); - return tree + function markOnce(tree, index, key) { + markStatic(tree, "__once__" + index + (key ? "_" + key : ""), true); + return tree; } - function markStatic ( - tree, - key, - isOnce - ) { + function markStatic(tree, key, isOnce) { if (Array.isArray(tree)) { for (var i = 0; i < tree.length; i++) { - if (tree[i] && typeof tree[i] !== 'string') { - markStaticNode(tree[i], (key + "_" + i), isOnce); + if (tree[i] && typeof tree[i] !== "string") { + markStaticNode(tree[i], key + "_" + i, isOnce); } } } else { @@ -2855,7 +2903,7 @@ } } - function markStaticNode (node, key, isOnce) { + function markStaticNode(node, key, isOnce) { node.isStatic = true; node.key = key; node.isOnce = isOnce; @@ -2863,15 +2911,12 @@ /* */ - function bindObjectListeners (data, value) { + function bindObjectListeners(data, value) { if (value) { if (!isPlainObject(value)) { - warn( - 'v-on without argument expects an Object value', - this - ); + warn("v-on without argument expects an Object value", this); } else { - var on = data.on = data.on ? extend({}, data.on) : {}; + var on = (data.on = data.on ? extend({}, data.on) : {}); for (var key in value) { var existing = on[key]; var ours = value[key]; @@ -2879,12 +2924,12 @@ } } } - return data + return data; } /* */ - function resolveScopedSlots ( + function resolveScopedSlots( fns, // see flow/vnode res, // the following are added in 2.6 @@ -2905,39 +2950,40 @@ } } if (contentHashKey) { - (res).$key = contentHashKey; + res.$key = contentHashKey; } - return res + return res; } /* */ - function bindDynamicKeys (baseObj, values) { + function bindDynamicKeys(baseObj, values) { for (var i = 0; i < values.length; i += 2) { var key = values[i]; - if (typeof key === 'string' && key) { + if (typeof key === "string" && key) { baseObj[values[i]] = values[i + 1]; - } else if (key !== '' && key !== null) { + } else if (key !== "" && key !== null) { // null is a special value for explicitly removing a binding warn( - ("Invalid value for dynamic directive argument (expected string or null): " + key), + "Invalid value for dynamic directive argument (expected string or null): " + + key, this ); } } - return baseObj + return baseObj; } // helper to dynamically append modifier runtime markers to event names. // ensure only append when value is already string, otherwise it will be cast // to string and cause the type check to miss. - function prependModifier (value, symbol) { - return typeof value === 'string' ? symbol + value : value + function prependModifier(value, symbol) { + return typeof value === "string" ? symbol + value : value; } /* */ - function installRenderHelpers (target) { + function installRenderHelpers(target) { target._o = markOnce; target._n = toNumber; target._s = toString; @@ -2959,20 +3005,14 @@ /* */ - function FunctionalRenderContext ( - data, - props, - children, - parent, - Ctor - ) { + function FunctionalRenderContext(data, props, children, parent, Ctor) { var this$1 = this; var options = Ctor.options; // ensure the createElement function in functional components // gets a unique context - this is necessary for correct named slot check var contextVm; - if (hasOwn(parent, '_uid')) { + if (hasOwn(parent, "_uid")) { contextVm = Object.create(parent); // $flow-disable-line contextVm._original = parent; @@ -2997,18 +3037,18 @@ if (!this$1.$slots) { normalizeScopedSlots( data.scopedSlots, - this$1.$slots = resolveSlots(children, parent) + (this$1.$slots = resolveSlots(children, parent)) ); } - return this$1.$slots + return this$1.$slots; }; - Object.defineProperty(this, 'scopedSlots', ({ + Object.defineProperty(this, "scopedSlots", { enumerable: true, - get: function get () { - return normalizeScopedSlots(data.scopedSlots, this.slots()) - } - })); + get: function get() { + return normalizeScopedSlots(data.scopedSlots, this.slots()); + }, + }); // support for compiled functional template if (isCompiled) { @@ -3026,16 +3066,18 @@ vnode.fnScopeId = options._scopeId; vnode.fnContext = parent; } - return vnode + return vnode; }; } else { - this._c = function (a, b, c, d) { return createElement(contextVm, a, b, c, d, needNormalization); }; + this._c = function (a, b, c, d) { + return createElement(contextVm, a, b, c, d, needNormalization); + }; } } installRenderHelpers(FunctionalRenderContext.prototype); - function createFunctionalComponent ( + function createFunctionalComponent( Ctor, propsData, data, @@ -3050,8 +3092,12 @@ props[key] = validateProp(key, propOptions, propsData || emptyObject); } } else { - if (isDef(data.attrs)) { mergeProps(props, data.attrs); } - if (isDef(data.props)) { mergeProps(props, data.props); } + if (isDef(data.attrs)) { + mergeProps(props, data.attrs); + } + if (isDef(data.props)) { + mergeProps(props, data.props); + } } var renderContext = new FunctionalRenderContext( @@ -3065,18 +3111,36 @@ var vnode = options.render.call(null, renderContext._c, renderContext); if (vnode instanceof VNode) { - return cloneAndMarkFunctionalResult(vnode, data, renderContext.parent, options, renderContext) + return cloneAndMarkFunctionalResult( + vnode, + data, + renderContext.parent, + options, + renderContext + ); } else if (Array.isArray(vnode)) { var vnodes = normalizeChildren(vnode) || []; var res = new Array(vnodes.length); for (var i = 0; i < vnodes.length; i++) { - res[i] = cloneAndMarkFunctionalResult(vnodes[i], data, renderContext.parent, options, renderContext); + res[i] = cloneAndMarkFunctionalResult( + vnodes[i], + data, + renderContext.parent, + options, + renderContext + ); } - return res + return res; } } - function cloneAndMarkFunctionalResult (vnode, data, contextVm, options, renderContext) { + function cloneAndMarkFunctionalResult( + vnode, + data, + contextVm, + options, + renderContext + ) { // #7817 clone node before setting fnContext, otherwise if the node is reused // (e.g. it was from a cached normal slot) the fnContext causes named slots // that should not be matched to match. @@ -3084,15 +3148,16 @@ clone.fnContext = contextVm; clone.fnOptions = options; { - (clone.devtoolsMeta = clone.devtoolsMeta || {}).renderContext = renderContext; + (clone.devtoolsMeta = clone.devtoolsMeta || {}).renderContext = + renderContext; } if (data.slot) { (clone.data || (clone.data = {})).slot = data.slot; } - return clone + return clone; } - function mergeProps (to, from) { + function mergeProps(to, from) { for (var key in from) { to[camelize(key)] = from[key]; } @@ -3108,7 +3173,7 @@ // inline hooks to be invoked on component VNodes during patch var componentVNodeHooks = { - init: function init (vnode, hydrating) { + init: function init(vnode, hydrating) { if ( vnode.componentInstance && !vnode.componentInstance._isDestroyed && @@ -3118,17 +3183,17 @@ var mountedNode = vnode; // work around flow componentVNodeHooks.prepatch(mountedNode, mountedNode); } else { - var child = vnode.componentInstance = createComponentInstanceForVnode( + var child = (vnode.componentInstance = createComponentInstanceForVnode( vnode, activeInstance - ); + )); child.$mount(hydrating ? vnode.elm : undefined, hydrating); } }, - prepatch: function prepatch (oldVnode, vnode) { + prepatch: function prepatch(oldVnode, vnode) { var options = vnode.componentOptions; - var child = vnode.componentInstance = oldVnode.componentInstance; + var child = (vnode.componentInstance = oldVnode.componentInstance); updateChildComponent( child, options.propsData, // updated props @@ -3138,12 +3203,12 @@ ); }, - insert: function insert (vnode) { + insert: function insert(vnode) { var context = vnode.context; var componentInstance = vnode.componentInstance; if (!componentInstance._isMounted) { componentInstance._isMounted = true; - callHook(componentInstance, 'mounted'); + callHook(componentInstance, "mounted"); } if (vnode.data.keepAlive) { if (context._isMounted) { @@ -3159,7 +3224,7 @@ } }, - destroy: function destroy (vnode) { + destroy: function destroy(vnode) { var componentInstance = vnode.componentInstance; if (!componentInstance._isDestroyed) { if (!vnode.data.keepAlive) { @@ -3168,20 +3233,14 @@ deactivateChildComponent(componentInstance, true /* direct */); } } - } + }, }; var hooksToMerge = Object.keys(componentVNodeHooks); - function createComponent ( - Ctor, - data, - context, - children, - tag - ) { + function createComponent(Ctor, data, context, children, tag) { if (isUndef(Ctor)) { - return + return; } var baseCtor = context.$options._base; @@ -3193,11 +3252,11 @@ // if at this stage it's not a constructor or an async component factory, // reject. - if (typeof Ctor !== 'function') { + if (typeof Ctor !== "function") { { - warn(("Invalid Component definition: " + (String(Ctor))), context); + warn("Invalid Component definition: " + String(Ctor), context); } - return + return; } // async component @@ -3215,7 +3274,7 @@ context, children, tag - ) + ); } } @@ -3235,7 +3294,13 @@ // functional component if (isTrue(Ctor.options.functional)) { - return createFunctionalComponent(Ctor, propsData, data, context, children) + return createFunctionalComponent( + Ctor, + propsData, + data, + context, + children + ); } // extract listeners, since these needs to be treated as @@ -3263,23 +3328,33 @@ // return a placeholder vnode var name = Ctor.options.name || tag; var vnode = new VNode( - ("vue-component-" + (Ctor.cid) + (name ? ("-" + name) : '')), - data, undefined, undefined, undefined, context, - { Ctor: Ctor, propsData: propsData, listeners: listeners, tag: tag, children: children }, + "vue-component-" + Ctor.cid + (name ? "-" + name : ""), + data, + undefined, + undefined, + undefined, + context, + { + Ctor: Ctor, + propsData: propsData, + listeners: listeners, + tag: tag, + children: children, + }, asyncFactory ); - return vnode + return vnode; } - function createComponentInstanceForVnode ( + function createComponentInstanceForVnode( vnode, // we know it's MountedComponentVNode but flow doesn't parent // activeInstance in lifecycle state ) { var options = { _isComponent: true, _parentVnode: vnode, - parent: parent + parent: parent, }; // check inline-template render functions var inlineTemplate = vnode.data.inlineTemplate; @@ -3287,10 +3362,10 @@ options.render = inlineTemplate.render; options.staticRenderFns = inlineTemplate.staticRenderFns; } - return new vnode.componentOptions.Ctor(options) + return new vnode.componentOptions.Ctor(options); } - function installComponentHooks (data) { + function installComponentHooks(data) { var hooks = data.hook || (data.hook = {}); for (var i = 0; i < hooksToMerge.length; i++) { var key = hooksToMerge[i]; @@ -3302,22 +3377,22 @@ } } - function mergeHook$1 (f1, f2) { + function mergeHook$1(f1, f2) { var merged = function (a, b) { // flow complains about extra args which is why we use any f1(a, b); f2(a, b); }; merged._merged = true; - return merged + return merged; } // transform component v-model info (value and callback) into // prop and event handler respectively. - function transformModel (options, data) { - var prop = (options.model && options.model.prop) || 'value'; - var event = (options.model && options.model.event) || 'input' - ;(data.attrs || (data.attrs = {}))[prop] = data.model.value; + function transformModel(options, data) { + var prop = (options.model && options.model.prop) || "value"; + var event = (options.model && options.model.event) || "input"; + (data.attrs || (data.attrs = {}))[prop] = data.model.value; var on = data.on || (data.on = {}); var existing = on[event]; var callback = data.model.callback; @@ -3341,7 +3416,7 @@ // wrapper function for providing a more flexible interface // without getting yelled at by flow - function createElement ( + function createElement( context, tag, data, @@ -3357,23 +3432,19 @@ if (isTrue(alwaysNormalize)) { normalizationType = ALWAYS_NORMALIZE; } - return _createElement(context, tag, data, children, normalizationType) + return _createElement(context, tag, data, children, normalizationType); } - function _createElement ( - context, - tag, - data, - children, - normalizationType - ) { - if (isDef(data) && isDef((data).__ob__)) { + function _createElement(context, tag, data, children, normalizationType) { + if (isDef(data) && isDef(data.__ob__)) { warn( - "Avoid using observed data object as vnode data: " + (JSON.stringify(data)) + "\n" + - 'Always create fresh vnode data objects in each render!', + "Avoid using observed data object as vnode data: " + + JSON.stringify(data) + + "\n" + + "Always create fresh vnode data objects in each render!", context ); - return createEmptyVNode() + return createEmptyVNode(); } // object syntax in v-bind if (isDef(data) && isDef(data.is)) { @@ -3381,23 +3452,20 @@ } if (!tag) { // in case of component :is set to falsy value - return createEmptyVNode() + return createEmptyVNode(); } // warn against non-primitive key - if (isDef(data) && isDef(data.key) && !isPrimitive(data.key) - ) { + if (isDef(data) && isDef(data.key) && !isPrimitive(data.key)) { { warn( - 'Avoid using non-primitive value as key, ' + - 'use string/number value instead.', + "Avoid using non-primitive value as key, " + + "use string/number value instead.", context ); } } // support single function children as default scoped slot - if (Array.isArray(children) && - typeof children[0] === 'function' - ) { + if (Array.isArray(children) && typeof children[0] === "function") { data = data || {}; data.scopedSlots = { default: children[0] }; children.length = 0; @@ -3408,51 +3476,61 @@ children = simpleNormalizeChildren(children); } var vnode, ns; - if (typeof tag === 'string') { + if (typeof tag === "string") { var Ctor; ns = (context.$vnode && context.$vnode.ns) || config.getTagNamespace(tag); if (config.isReservedTag(tag)) { // platform built-in elements if (isDef(data) && isDef(data.nativeOn)) { warn( - ("The .native modifier for v-on is only valid on components but it was used on <" + tag + ">."), + "The .native modifier for v-on is only valid on components but it was used on <" + + tag + + ">.", context ); } vnode = new VNode( - config.parsePlatformTagName(tag), data, children, - undefined, undefined, context + config.parsePlatformTagName(tag), + data, + children, + undefined, + undefined, + context ); - } else if ((!data || !data.pre) && isDef(Ctor = resolveAsset(context.$options, 'components', tag))) { + } else if ( + (!data || !data.pre) && + isDef((Ctor = resolveAsset(context.$options, "components", tag))) + ) { // component vnode = createComponent(Ctor, data, context, children, tag); } else { // unknown or unlisted namespaced elements // check at runtime because it may get assigned a namespace when its // parent normalizes children - vnode = new VNode( - tag, data, children, - undefined, undefined, context - ); + vnode = new VNode(tag, data, children, undefined, undefined, context); } } else { // direct component options / constructor vnode = createComponent(tag, data, context, children); } if (Array.isArray(vnode)) { - return vnode + return vnode; } else if (isDef(vnode)) { - if (isDef(ns)) { applyNS(vnode, ns); } - if (isDef(data)) { registerDeepBindings(data); } - return vnode + if (isDef(ns)) { + applyNS(vnode, ns); + } + if (isDef(data)) { + registerDeepBindings(data); + } + return vnode; } else { - return createEmptyVNode() + return createEmptyVNode(); } } - function applyNS (vnode, ns, force) { + function applyNS(vnode, ns, force) { vnode.ns = ns; - if (vnode.tag === 'foreignObject') { + if (vnode.tag === "foreignObject") { // use default namespace inside foreignObject ns = undefined; force = true; @@ -3460,8 +3538,10 @@ if (isDef(vnode.children)) { for (var i = 0, l = vnode.children.length; i < l; i++) { var child = vnode.children[i]; - if (isDef(child.tag) && ( - isUndef(child.ns) || (isTrue(force) && child.tag !== 'svg'))) { + if ( + isDef(child.tag) && + (isUndef(child.ns) || (isTrue(force) && child.tag !== "svg")) + ) { applyNS(child, ns, force); } } @@ -3471,7 +3551,7 @@ // ref #5318 // necessary to ensure parent re-render when deep bindings like :style and // :class are used on slot nodes - function registerDeepBindings (data) { + function registerDeepBindings(data) { if (isObject(data.style)) { traverse(data.style); } @@ -3482,11 +3562,11 @@ /* */ - function initRender (vm) { + function initRender(vm) { vm._vnode = null; // the root of the child tree vm._staticTrees = null; // v-once cached trees var options = vm.$options; - var parentVnode = vm.$vnode = options._parentVnode; // the placeholder node in parent tree + var parentVnode = (vm.$vnode = options._parentVnode); // the placeholder node in parent tree var renderContext = parentVnode && parentVnode.context; vm.$slots = resolveSlots(options._renderChildren, renderContext); vm.$scopedSlots = emptyObject; @@ -3494,10 +3574,14 @@ // so that we get proper render context inside it. // args order: tag, data, children, normalizationType, alwaysNormalize // internal version is used by render functions compiled from templates - vm._c = function (a, b, c, d) { return createElement(vm, a, b, c, d, false); }; + vm._c = function (a, b, c, d) { + return createElement(vm, a, b, c, d, false); + }; // normalization is always applied for the public version, used in // user-written render functions. - vm.$createElement = function (a, b, c, d) { return createElement(vm, a, b, c, d, true); }; + vm.$createElement = function (a, b, c, d) { + return createElement(vm, a, b, c, d, true); + }; // $attrs & $listeners are exposed for easier HOC creation. // they need to be reactive so that HOCs using them are always updated @@ -3505,23 +3589,35 @@ /* istanbul ignore else */ { - defineReactive$$1(vm, '$attrs', parentData && parentData.attrs || emptyObject, function () { - !isUpdatingChildComponent && warn("$attrs is readonly.", vm); - }, true); - defineReactive$$1(vm, '$listeners', options._parentListeners || emptyObject, function () { - !isUpdatingChildComponent && warn("$listeners is readonly.", vm); - }, true); + defineReactive$$1( + vm, + "$attrs", + (parentData && parentData.attrs) || emptyObject, + function () { + !isUpdatingChildComponent && warn("$attrs is readonly.", vm); + }, + true + ); + defineReactive$$1( + vm, + "$listeners", + options._parentListeners || emptyObject, + function () { + !isUpdatingChildComponent && warn("$listeners is readonly.", vm); + }, + true + ); } } var currentRenderingInstance = null; - function renderMixin (Vue) { + function renderMixin(Vue) { // install runtime convenience helpers installRenderHelpers(Vue.prototype); Vue.prototype.$nextTick = function (fn) { - return nextTick(fn, this) + return nextTick(fn, this); }; Vue.prototype._render = function () { @@ -3556,7 +3652,11 @@ /* istanbul ignore else */ if (vm.$options.renderError) { try { - vnode = vm.$options.renderError.call(vm._renderProxy, vm.$createElement, e); + vnode = vm.$options.renderError.call( + vm._renderProxy, + vm.$createElement, + e + ); } catch (e) { handleError(e, vm, "renderError"); vnode = vm._vnode; @@ -3575,8 +3675,8 @@ if (!(vnode instanceof VNode)) { if (Array.isArray(vnode)) { warn( - 'Multiple root nodes returned from render function. Render function ' + - 'should return a single root node.', + "Multiple root nodes returned from render function. Render function " + + "should return a single root node.", vm ); } @@ -3584,70 +3684,70 @@ } // set parent vnode.parent = _parentVnode; - return vnode + return vnode; }; } /* */ - function ensureCtor (comp, base) { + function ensureCtor(comp, base) { if ( comp.__esModule || - (hasSymbol && comp[Symbol.toStringTag] === 'Module') + (hasSymbol && comp[Symbol.toStringTag] === "Module") ) { comp = comp.default; } - return isObject(comp) - ? base.extend(comp) - : comp + return isObject(comp) ? base.extend(comp) : comp; } - function createAsyncPlaceholder ( - factory, - data, - context, - children, - tag - ) { + function createAsyncPlaceholder(factory, data, context, children, tag) { var node = createEmptyVNode(); node.asyncFactory = factory; - node.asyncMeta = { data: data, context: context, children: children, tag: tag }; - return node + node.asyncMeta = { + data: data, + context: context, + children: children, + tag: tag, + }; + return node; } - function resolveAsyncComponent ( - factory, - baseCtor - ) { + function resolveAsyncComponent(factory, baseCtor) { if (isTrue(factory.error) && isDef(factory.errorComp)) { - return factory.errorComp + return factory.errorComp; } if (isDef(factory.resolved)) { - return factory.resolved + return factory.resolved; } var owner = currentRenderingInstance; - if (owner && isDef(factory.owners) && factory.owners.indexOf(owner) === -1) { + if ( + owner && + isDef(factory.owners) && + factory.owners.indexOf(owner) === -1 + ) { // already pending factory.owners.push(owner); } if (isTrue(factory.loading) && isDef(factory.loadingComp)) { - return factory.loadingComp + return factory.loadingComp; } if (owner && !isDef(factory.owners)) { - var owners = factory.owners = [owner]; + var owners = (factory.owners = [owner]); var sync = true; var timerLoading = null; - var timerTimeout = null + var timerTimeout = null; - ;(owner).$on('hook:destroyed', function () { return remove(owners, owner); }); + owner.$on("hook:destroyed", function () { + return remove(owners, owner); + }); var forceRender = function (renderCompleted) { for (var i = 0, l = owners.length; i < l; i++) { - (owners[i]).$forceUpdate(); + owners[i].$forceUpdate(); } if (renderCompleted) { @@ -3677,8 +3777,9 @@ var reject = once(function (reason) { warn( - "Failed to resolve async component: " + (String(factory)) + - (reason ? ("\nReason: " + reason) : '') + "Failed to resolve async component: " + + String(factory) + + (reason ? "\nReason: " + reason : "") ); if (isDef(factory.errorComp)) { factory.error = true; @@ -3720,9 +3821,7 @@ timerTimeout = setTimeout(function () { timerTimeout = null; if (isUndef(factory.resolved)) { - reject( - "timeout (" + (res.timeout) + "ms)" - ); + reject("timeout (" + res.timeout + "ms)"); } }, res.timeout); } @@ -3731,26 +3830,24 @@ sync = false; // return in case resolved synchronously - return factory.loading - ? factory.loadingComp - : factory.resolved + return factory.loading ? factory.loadingComp : factory.resolved; } } /* */ - function isAsyncPlaceholder (node) { - return node.isComment && node.asyncFactory + function isAsyncPlaceholder(node) { + return node.isComment && node.asyncFactory; } /* */ - function getFirstComponentChild (children) { + function getFirstComponentChild(children) { if (Array.isArray(children)) { for (var i = 0; i < children.length; i++) { var c = children[i]; if (isDef(c) && (isDef(c.componentOptions) || isAsyncPlaceholder(c))) { - return c + return c; } } } @@ -3760,7 +3857,7 @@ /* */ - function initEvents (vm) { + function initEvents(vm) { vm._events = Object.create(null); vm._hasHookEvent = false; // init parent attached events @@ -3772,35 +3869,38 @@ var target; - function add (event, fn) { + function add(event, fn) { target.$on(event, fn); } - function remove$1 (event, fn) { + function remove$1(event, fn) { target.$off(event, fn); } - function createOnceHandler (event, fn) { + function createOnceHandler(event, fn) { var _target = target; - return function onceHandler () { + return function onceHandler() { var res = fn.apply(null, arguments); if (res !== null) { _target.$off(event, onceHandler); } - } + }; } - function updateComponentListeners ( - vm, - listeners, - oldListeners - ) { + function updateComponentListeners(vm, listeners, oldListeners) { target = vm; - updateListeners(listeners, oldListeners || {}, add, remove$1, createOnceHandler, vm); + updateListeners( + listeners, + oldListeners || {}, + add, + remove$1, + createOnceHandler, + vm + ); target = undefined; } - function eventsMixin (Vue) { + function eventsMixin(Vue) { var hookRE = /^hook:/; Vue.prototype.$on = function (event, fn) { var vm = this; @@ -3816,18 +3916,18 @@ vm._hasHookEvent = true; } } - return vm + return vm; }; Vue.prototype.$once = function (event, fn) { var vm = this; - function on () { + function on() { vm.$off(event, on); fn.apply(vm, arguments); } on.fn = fn; vm.$on(event, on); - return vm + return vm; }; Vue.prototype.$off = function (event, fn) { @@ -3835,23 +3935,23 @@ // all if (!arguments.length) { vm._events = Object.create(null); - return vm + return vm; } // array of events if (Array.isArray(event)) { for (var i$1 = 0, l = event.length; i$1 < l; i$1++) { vm.$off(event[i$1], fn); } - return vm + return vm; } // specific event var cbs = vm._events[event]; if (!cbs) { - return vm + return vm; } if (!fn) { vm._events[event] = null; - return vm + return vm; } // specific handler var cb; @@ -3860,10 +3960,10 @@ cb = cbs[i]; if (cb === fn || cb.fn === fn) { cbs.splice(i, 1); - break + break; } } - return vm + return vm; }; Vue.prototype.$emit = function (event) { @@ -3872,11 +3972,20 @@ var lowerCaseEvent = event.toLowerCase(); if (lowerCaseEvent !== event && vm._events[lowerCaseEvent]) { tip( - "Event \"" + lowerCaseEvent + "\" is emitted in component " + - (formatComponentName(vm)) + " but the handler is registered for \"" + event + "\". " + - "Note that HTML attributes are case-insensitive and you cannot use " + - "v-on to listen to camelCase events when using in-DOM templates. " + - "You should probably use \"" + (hyphenate(event)) + "\" instead of \"" + event + "\"." + 'Event "' + + lowerCaseEvent + + '" is emitted in component ' + + formatComponentName(vm) + + ' but the handler is registered for "' + + event + + '". ' + + "Note that HTML attributes are case-insensitive and you cannot use " + + "v-on to listen to camelCase events when using in-DOM templates. " + + 'You should probably use "' + + hyphenate(event) + + '" instead of "' + + event + + '".' ); } } @@ -3884,12 +3993,12 @@ if (cbs) { cbs = cbs.length > 1 ? toArray(cbs) : cbs; var args = toArray(arguments, 1); - var info = "event handler for \"" + event + "\""; + var info = 'event handler for "' + event + '"'; for (var i = 0, l = cbs.length; i < l; i++) { invokeWithErrorHandling(cbs[i], vm, args, vm, info); } } - return vm + return vm; }; } @@ -3903,10 +4012,10 @@ activeInstance = vm; return function () { activeInstance = prevActiveInstance; - } + }; } - function initLifecycle (vm) { + function initLifecycle(vm) { var options = vm.$options; // locate first non-abstract parent @@ -3932,7 +4041,7 @@ vm._isBeingDestroyed = false; } - function lifecycleMixin (Vue) { + function lifecycleMixin(Vue) { Vue.prototype._update = function (vnode, hydrating) { var vm = this; var prevEl = vm.$el; @@ -3974,9 +4083,9 @@ Vue.prototype.$destroy = function () { var vm = this; if (vm._isBeingDestroyed) { - return + return; } - callHook(vm, 'beforeDestroy'); + callHook(vm, "beforeDestroy"); vm._isBeingDestroyed = true; // remove self from parent var parent = vm.$parent; @@ -4001,7 +4110,7 @@ // invoke destroy hooks on current rendered tree vm.__patch__(vm._vnode, null); // fire destroyed hook - callHook(vm, 'destroyed'); + callHook(vm, "destroyed"); // turn off all instance listeners. vm.$off(); // remove __vue__ reference @@ -4015,33 +4124,32 @@ }; } - function mountComponent ( - vm, - el, - hydrating - ) { + function mountComponent(vm, el, hydrating) { vm.$el = el; if (!vm.$options.render) { vm.$options.render = createEmptyVNode; { /* istanbul ignore if */ - if ((vm.$options.template && vm.$options.template.charAt(0) !== '#') || - vm.$options.el || el) { + if ( + (vm.$options.template && vm.$options.template.charAt(0) !== "#") || + vm.$options.el || + el + ) { warn( - 'You are using the runtime-only build of Vue where the template ' + - 'compiler is not available. Either pre-compile the templates into ' + - 'render functions, or use the compiler-included build.', + "You are using the runtime-only build of Vue where the template " + + "compiler is not available. Either pre-compile the templates into " + + "render functions, or use the compiler-included build.", vm ); } else { warn( - 'Failed to mount component: template or render function not defined.', + "Failed to mount component: template or render function not defined.", vm ); } } } - callHook(vm, 'beforeMount'); + callHook(vm, "beforeMount"); var updateComponent; /* istanbul ignore if */ @@ -4055,12 +4163,12 @@ mark(startTag); var vnode = vm._render(); mark(endTag); - measure(("vue " + name + " render"), startTag, endTag); + measure("vue " + name + " render", startTag, endTag); mark(startTag); vm._update(vnode, hydrating); mark(endTag); - measure(("vue " + name + " patch"), startTag, endTag); + measure("vue " + name + " patch", startTag, endTag); }; } else { updateComponent = function () { @@ -4071,25 +4179,31 @@ // we set this to vm._watcher inside the watcher's constructor // since the watcher's initial patch may call $forceUpdate (e.g. inside child // component's mounted hook), which relies on vm._watcher being already defined - new Watcher(vm, updateComponent, noop, { - before: function before () { - if (vm._isMounted && !vm._isDestroyed) { - callHook(vm, 'beforeUpdate'); - } - } - }, true /* isRenderWatcher */); + new Watcher( + vm, + updateComponent, + noop, + { + before: function before() { + if (vm._isMounted && !vm._isDestroyed) { + callHook(vm, "beforeUpdate"); + } + }, + }, + true /* isRenderWatcher */ + ); hydrating = false; // manually mounted instance, call mounted on self // mounted is called for render-created child components in its inserted hook if (vm.$vnode == null) { vm._isMounted = true; - callHook(vm, 'mounted'); + callHook(vm, "mounted"); } - return vm + return vm; } - function updateChildComponent ( + function updateChildComponent( vm, propsData, listeners, @@ -4118,15 +4232,16 @@ // update. Dynamic scoped slots may also have changed. In such cases, a forced // update is necessary to ensure correctness. var needsForceUpdate = !!( - renderChildren || // has new static slots - vm.$options._renderChildren || // has old static slots + renderChildren || // has new static slots + vm.$options._renderChildren || // has old static slots hasDynamicScopedSlot ); vm.$options._parentVnode = parentVnode; vm.$vnode = parentVnode; // update vm's placeholder node without re-render - if (vm._vnode) { // update child tree's parent + if (vm._vnode) { + // update child tree's parent vm._vnode.parent = parentVnode; } vm.$options._renderChildren = renderChildren; @@ -4169,36 +4284,38 @@ } } - function isInInactiveTree (vm) { + function isInInactiveTree(vm) { while (vm && (vm = vm.$parent)) { - if (vm._inactive) { return true } + if (vm._inactive) { + return true; + } } - return false + return false; } - function activateChildComponent (vm, direct) { + function activateChildComponent(vm, direct) { if (direct) { vm._directInactive = false; if (isInInactiveTree(vm)) { - return + return; } } else if (vm._directInactive) { - return + return; } if (vm._inactive || vm._inactive === null) { vm._inactive = false; for (var i = 0; i < vm.$children.length; i++) { activateChildComponent(vm.$children[i]); } - callHook(vm, 'activated'); + callHook(vm, "activated"); } } - function deactivateChildComponent (vm, direct) { + function deactivateChildComponent(vm, direct) { if (direct) { vm._directInactive = true; if (isInInactiveTree(vm)) { - return + return; } } if (!vm._inactive) { @@ -4206,11 +4323,11 @@ for (var i = 0; i < vm.$children.length; i++) { deactivateChildComponent(vm.$children[i]); } - callHook(vm, 'deactivated'); + callHook(vm, "deactivated"); } } - function callHook (vm, hook) { + function callHook(vm, hook) { // #7573 disable dep collection when invoking lifecycle hooks pushTarget(); var handlers = vm.$options[hook]; @@ -4221,7 +4338,7 @@ } } if (vm._hasHookEvent) { - vm.$emit('hook:' + hook); + vm.$emit("hook:" + hook); } popTarget(); } @@ -4241,7 +4358,7 @@ /** * Reset the scheduler's state. */ - function resetSchedulerState () { + function resetSchedulerState() { index = queue.length = activatedChildren.length = 0; has = {}; { @@ -4270,21 +4387,23 @@ var performance = window.performance; if ( performance && - typeof performance.now === 'function' && - getNow() > document.createEvent('Event').timeStamp + typeof performance.now === "function" && + getNow() > document.createEvent("Event").timeStamp ) { // if the event timestamp, although evaluated AFTER the Date.now(), is // smaller than it, it means the event is using a hi-res timestamp, // and we need to use the hi-res version for event listener timestamps as // well. - getNow = function () { return performance.now(); }; + getNow = function () { + return performance.now(); + }; } } /** * Flush both queues and run the watchers. */ - function flushSchedulerQueue () { + function flushSchedulerQueue() { currentFlushTimestamp = getNow(); flushing = true; var watcher, id; @@ -4297,7 +4416,9 @@ // user watchers are created before the render watcher) // 3. If a component is destroyed during a parent component's watcher run, // its watchers can be skipped. - queue.sort(function (a, b) { return a.id - b.id; }); + queue.sort(function (a, b) { + return a.id - b.id; + }); // do not cache length because more watchers might be pushed // as we run existing watchers @@ -4314,14 +4435,13 @@ circular[id] = (circular[id] || 0) + 1; if (circular[id] > MAX_UPDATE_COUNT) { warn( - 'You may have an infinite update loop ' + ( - watcher.user - ? ("in watcher with expression \"" + (watcher.expression) + "\"") - : "in a component render function." - ), + "You may have an infinite update loop " + + (watcher.user + ? 'in watcher with expression "' + watcher.expression + '"' + : "in a component render function."), watcher.vm ); - break + break; } } } @@ -4339,17 +4459,17 @@ // devtool hook /* istanbul ignore if */ if (devtools && config.devtools) { - devtools.emit('flush'); + devtools.emit("flush"); } } - function callUpdatedHooks (queue) { + function callUpdatedHooks(queue) { var i = queue.length; while (i--) { var watcher = queue[i]; var vm = watcher.vm; if (vm._watcher === watcher && vm._isMounted && !vm._isDestroyed) { - callHook(vm, 'updated'); + callHook(vm, "updated"); } } } @@ -4358,14 +4478,14 @@ * Queue a kept-alive component that was activated during patch. * The queue will be processed after the entire tree has been patched. */ - function queueActivatedComponent (vm) { + function queueActivatedComponent(vm) { // setting _inactive to false here so that a render function can // rely on checking whether it's in an inactive tree (e.g. router-view) vm._inactive = false; activatedChildren.push(vm); } - function callActivatedHooks (queue) { + function callActivatedHooks(queue) { for (var i = 0; i < queue.length; i++) { queue[i]._inactive = true; activateChildComponent(queue[i], true /* true */); @@ -4377,7 +4497,7 @@ * Jobs with duplicate IDs will be skipped unless it's * pushed when the queue is being flushed. */ - function queueWatcher (watcher) { + function queueWatcher(watcher) { var id = watcher.id; if (has[id] == null) { has[id] = true; @@ -4398,7 +4518,7 @@ if (!config.async) { flushSchedulerQueue(); - return + return; } nextTick(flushSchedulerQueue); } @@ -4407,8 +4527,6 @@ /* */ - - var uid$2 = 0; /** @@ -4416,13 +4534,7 @@ * and fires callback when the expression value changes. * This is used for both the $watch() api and directives. */ - var Watcher = function Watcher ( - vm, - expOrFn, - cb, - options, - isRenderWatcher - ) { + var Watcher = function Watcher(vm, expOrFn, cb, options, isRenderWatcher) { this.vm = vm; if (isRenderWatcher) { vm._watcher = this; @@ -4448,29 +4560,29 @@ this.newDepIds = new _Set(); this.expression = expOrFn.toString(); // parse expression for getter - if (typeof expOrFn === 'function') { + if (typeof expOrFn === "function") { this.getter = expOrFn; } else { this.getter = parsePath(expOrFn); if (!this.getter) { this.getter = noop; warn( - "Failed watching path: \"" + expOrFn + "\" " + - 'Watcher only accepts simple dot-delimited paths. ' + - 'For full control, use a function instead.', + 'Failed watching path: "' + + expOrFn + + '" ' + + "Watcher only accepts simple dot-delimited paths. " + + "For full control, use a function instead.", vm ); } } - this.value = this.lazy - ? undefined - : this.get(); + this.value = this.lazy ? undefined : this.get(); }; /** * Evaluate the getter, and re-collect dependencies. */ - Watcher.prototype.get = function get () { + Watcher.prototype.get = function get() { pushTarget(this); var value; var vm = this.vm; @@ -4478,9 +4590,9 @@ value = this.getter.call(vm, vm); } catch (e) { if (this.user) { - handleError(e, vm, ("getter for watcher \"" + (this.expression) + "\"")); + handleError(e, vm, 'getter for watcher "' + this.expression + '"'); } else { - throw e + throw e; } } finally { // "touch" every property so they are all tracked as @@ -4491,13 +4603,13 @@ popTarget(); this.cleanupDeps(); } - return value + return value; }; /** * Add a dependency to this directive. */ - Watcher.prototype.addDep = function addDep (dep) { + Watcher.prototype.addDep = function addDep(dep) { var id = dep.id; if (!this.newDepIds.has(id)) { this.newDepIds.add(id); @@ -4511,7 +4623,7 @@ /** * Clean up for dependency collection. */ - Watcher.prototype.cleanupDeps = function cleanupDeps () { + Watcher.prototype.cleanupDeps = function cleanupDeps() { var i = this.deps.length; while (i--) { var dep = this.deps[i]; @@ -4533,7 +4645,7 @@ * Subscriber interface. * Will be called when a dependency changes. */ - Watcher.prototype.update = function update () { + Watcher.prototype.update = function update() { /* istanbul ignore else */ if (this.lazy) { this.dirty = true; @@ -4548,7 +4660,7 @@ * Scheduler job interface. * Will be called by the scheduler. */ - Watcher.prototype.run = function run () { + Watcher.prototype.run = function run() { if (this.active) { var value = this.get(); if ( @@ -4566,7 +4678,11 @@ try { this.cb.call(this.vm, value, oldValue); } catch (e) { - handleError(e, this.vm, ("callback for watcher \"" + (this.expression) + "\"")); + handleError( + e, + this.vm, + 'callback for watcher "' + this.expression + '"' + ); } } else { this.cb.call(this.vm, value, oldValue); @@ -4579,7 +4695,7 @@ * Evaluate the value of the watcher. * This only gets called for lazy watchers. */ - Watcher.prototype.evaluate = function evaluate () { + Watcher.prototype.evaluate = function evaluate() { this.value = this.get(); this.dirty = false; }; @@ -4587,7 +4703,7 @@ /** * Depend on all deps collected by this watcher. */ - Watcher.prototype.depend = function depend () { + Watcher.prototype.depend = function depend() { var i = this.deps.length; while (i--) { this.deps[i].depend(); @@ -4597,7 +4713,7 @@ /** * Remove self from all dependencies' subscriber list. */ - Watcher.prototype.teardown = function teardown () { + Watcher.prototype.teardown = function teardown() { if (this.active) { // remove self from vm's watcher list // this is a somewhat expensive operation so we skip it @@ -4619,56 +4735,66 @@ enumerable: true, configurable: true, get: noop, - set: noop + set: noop, }; - function proxy (target, sourceKey, key) { - sharedPropertyDefinition.get = function proxyGetter () { - return this[sourceKey][key] + function proxy(target, sourceKey, key) { + sharedPropertyDefinition.get = function proxyGetter() { + return this[sourceKey][key]; }; - sharedPropertyDefinition.set = function proxySetter (val) { + sharedPropertyDefinition.set = function proxySetter(val) { this[sourceKey][key] = val; }; Object.defineProperty(target, key, sharedPropertyDefinition); } - function initState (vm) { + function initState(vm) { vm._watchers = []; var opts = vm.$options; - if (opts.props) { initProps(vm, opts.props); } - if (opts.methods) { initMethods(vm, opts.methods); } + if (opts.props) { + initProps(vm, opts.props); + } + if (opts.methods) { + initMethods(vm, opts.methods); + } if (opts.data) { initData(vm); } else { - observe(vm._data = {}, true /* asRootData */); + observe((vm._data = {}), true /* asRootData */); + } + if (opts.computed) { + initComputed(vm, opts.computed); } - if (opts.computed) { initComputed(vm, opts.computed); } if (opts.watch && opts.watch !== nativeWatch) { initWatch(vm, opts.watch); } } - function initProps (vm, propsOptions) { + function initProps(vm, propsOptions) { var propsData = vm.$options.propsData || {}; - var props = vm._props = {}; + var props = (vm._props = {}); // cache prop keys so that future props updates can iterate using Array // instead of dynamic object key enumeration. - var keys = vm.$options._propKeys = []; + var keys = (vm.$options._propKeys = []); var isRoot = !vm.$parent; // root instance props should be converted if (!isRoot) { toggleObserving(false); } - var loop = function ( key ) { + var loop = function (key) { keys.push(key); var value = validateProp(key, propsOptions, propsData, vm); /* istanbul ignore else */ { var hyphenatedKey = hyphenate(key); - if (isReservedAttribute(hyphenatedKey) || - config.isReservedAttr(hyphenatedKey)) { + if ( + isReservedAttribute(hyphenatedKey) || + config.isReservedAttr(hyphenatedKey) + ) { warn( - ("\"" + hyphenatedKey + "\" is a reserved attribute and cannot be used as component prop."), + '"' + + hyphenatedKey + + '" is a reserved attribute and cannot be used as component prop.', vm ); } @@ -4676,9 +4802,11 @@ if (!isRoot && !isUpdatingChildComponent) { warn( "Avoid mutating a prop directly since the value will be " + - "overwritten whenever the parent component re-renders. " + - "Instead, use a data or computed property based on the prop's " + - "value. Prop being mutated: \"" + key + "\"", + "overwritten whenever the parent component re-renders. " + + "Instead, use a data or computed property based on the prop's " + + 'value. Prop being mutated: "' + + key + + '"', vm ); } @@ -4692,20 +4820,19 @@ } }; - for (var key in propsOptions) loop( key ); + for (var key in propsOptions) loop(key); toggleObserving(true); } - function initData (vm) { + function initData(vm) { var data = vm.$options.data; - data = vm._data = typeof data === 'function' - ? getData(data, vm) - : data || {}; + data = vm._data = + typeof data === "function" ? getData(data, vm) : data || {}; if (!isPlainObject(data)) { data = {}; warn( - 'data functions should return an object:\n' + - 'https://vuejs.org/v2/guide/components.html#data-Must-Be-a-Function', + "data functions should return an object:\n" + + "https://vuejs.org/v2/guide/components.html#data-Must-Be-a-Function", vm ); } @@ -4719,15 +4846,17 @@ { if (methods && hasOwn(methods, key)) { warn( - ("Method \"" + key + "\" has already been defined as a data property."), + 'Method "' + key + '" has already been defined as a data property.', vm ); } } if (props && hasOwn(props, key)) { warn( - "The data property \"" + key + "\" is already declared as a prop. " + - "Use prop default value instead.", + 'The data property "' + + key + + '" is already declared as a prop. ' + + "Use prop default value instead.", vm ); } else if (!isReserved(key)) { @@ -4738,14 +4867,14 @@ observe(data, true /* asRootData */); } - function getData (data, vm) { + function getData(data, vm) { // #7573 disable dep collection when invoking data getters pushTarget(); try { - return data.call(vm, vm) + return data.call(vm, vm); } catch (e) { handleError(e, vm, "data()"); - return {} + return {}; } finally { popTarget(); } @@ -4753,20 +4882,17 @@ var computedWatcherOptions = { lazy: true }; - function initComputed (vm, computed) { + function initComputed(vm, computed) { // $flow-disable-line - var watchers = vm._computedWatchers = Object.create(null); + var watchers = (vm._computedWatchers = Object.create(null)); // computed properties are just getters during SSR var isSSR = isServerRendering(); for (var key in computed) { var userDef = computed[key]; - var getter = typeof userDef === 'function' ? userDef : userDef.get; + var getter = typeof userDef === "function" ? userDef : userDef.get; if (getter == null) { - warn( - ("Getter is missing for computed property \"" + key + "\"."), - vm - ); + warn('Getter is missing for computed property "' + key + '".', vm); } if (!isSSR) { @@ -4786,21 +4912,23 @@ defineComputed(vm, key, userDef); } else { if (key in vm.$data) { - warn(("The computed property \"" + key + "\" is already defined in data."), vm); + warn( + 'The computed property "' + key + '" is already defined in data.', + vm + ); } else if (vm.$options.props && key in vm.$options.props) { - warn(("The computed property \"" + key + "\" is already defined as a prop."), vm); + warn( + 'The computed property "' + key + '" is already defined as a prop.', + vm + ); } } } } - function defineComputed ( - target, - key, - userDef - ) { + function defineComputed(target, key, userDef) { var shouldCache = !isServerRendering(); - if (typeof userDef === 'function') { + if (typeof userDef === "function") { sharedPropertyDefinition.get = shouldCache ? createComputedGetter(key) : createGetterInvoker(userDef); @@ -4816,7 +4944,9 @@ if (sharedPropertyDefinition.set === noop) { sharedPropertyDefinition.set = function () { warn( - ("Computed property \"" + key + "\" was assigned to but it has no setter."), + 'Computed property "' + + key + + '" was assigned to but it has no setter.', this ); }; @@ -4824,8 +4954,8 @@ Object.defineProperty(target, key, sharedPropertyDefinition); } - function createComputedGetter (key) { - return function computedGetter () { + function createComputedGetter(key) { + return function computedGetter() { var watcher = this._computedWatchers && this._computedWatchers[key]; if (watcher) { if (watcher.dirty) { @@ -4834,46 +4964,50 @@ if (Dep.target) { watcher.depend(); } - return watcher.value + return watcher.value; } - } + }; } function createGetterInvoker(fn) { - return function computedGetter () { - return fn.call(this, this) - } + return function computedGetter() { + return fn.call(this, this); + }; } - function initMethods (vm, methods) { + function initMethods(vm, methods) { var props = vm.$options.props; for (var key in methods) { { - if (typeof methods[key] !== 'function') { + if (typeof methods[key] !== "function") { warn( - "Method \"" + key + "\" has type \"" + (typeof methods[key]) + "\" in the component definition. " + - "Did you reference the function correctly?", + 'Method "' + + key + + '" has type "' + + typeof methods[key] + + '" in the component definition. ' + + "Did you reference the function correctly?", vm ); } if (props && hasOwn(props, key)) { - warn( - ("Method \"" + key + "\" has already been defined as a prop."), - vm - ); + warn('Method "' + key + '" has already been defined as a prop.', vm); } - if ((key in vm) && isReserved(key)) { + if (key in vm && isReserved(key)) { warn( - "Method \"" + key + "\" conflicts with an existing Vue instance method. " + - "Avoid defining component methods that start with _ or $." + 'Method "' + + key + + '" conflicts with an existing Vue instance method. ' + + "Avoid defining component methods that start with _ or $." ); } } - vm[key] = typeof methods[key] !== 'function' ? noop : bind(methods[key], vm); + vm[key] = + typeof methods[key] !== "function" ? noop : bind(methods[key], vm); } } - function initWatch (vm, watch) { + function initWatch(vm, watch) { for (var key in watch) { var handler = watch[key]; if (Array.isArray(handler)) { @@ -4886,35 +5020,34 @@ } } - function createWatcher ( - vm, - expOrFn, - handler, - options - ) { + function createWatcher(vm, expOrFn, handler, options) { if (isPlainObject(handler)) { options = handler; handler = handler.handler; } - if (typeof handler === 'string') { + if (typeof handler === "string") { handler = vm[handler]; } - return vm.$watch(expOrFn, handler, options) + return vm.$watch(expOrFn, handler, options); } - function stateMixin (Vue) { + function stateMixin(Vue) { // flow somehow has problems with directly declared definition object // when using Object.defineProperty, so we have to procedurally build up // the object here. var dataDef = {}; - dataDef.get = function () { return this._data }; + dataDef.get = function () { + return this._data; + }; var propsDef = {}; - propsDef.get = function () { return this._props }; + propsDef.get = function () { + return this._props; + }; { dataDef.set = function () { warn( - 'Avoid replacing instance root $data. ' + - 'Use nested data properties instead.', + "Avoid replacing instance root $data. " + + "Use nested data properties instead.", this ); }; @@ -4922,20 +5055,16 @@ warn("$props is readonly.", this); }; } - Object.defineProperty(Vue.prototype, '$data', dataDef); - Object.defineProperty(Vue.prototype, '$props', propsDef); + Object.defineProperty(Vue.prototype, "$data", dataDef); + Object.defineProperty(Vue.prototype, "$props", propsDef); Vue.prototype.$set = set; Vue.prototype.$delete = del; - Vue.prototype.$watch = function ( - expOrFn, - cb, - options - ) { + Vue.prototype.$watch = function (expOrFn, cb, options) { var vm = this; if (isPlainObject(cb)) { - return createWatcher(vm, expOrFn, cb, options) + return createWatcher(vm, expOrFn, cb, options); } options = options || {}; options.user = true; @@ -4944,12 +5073,16 @@ try { cb.call(vm, watcher.value); } catch (error) { - handleError(error, vm, ("callback for immediate watcher \"" + (watcher.expression) + "\"")); + handleError( + error, + vm, + 'callback for immediate watcher "' + watcher.expression + '"' + ); } } - return function unwatchFn () { + return function unwatchFn() { watcher.teardown(); - } + }; }; } @@ -4957,7 +5090,7 @@ var uid$3 = 0; - function initMixin (Vue) { + function initMixin(Vue) { Vue.prototype._init = function (options) { var vm = this; // a uid @@ -4966,8 +5099,8 @@ var startTag, endTag; /* istanbul ignore if */ if (config.performance && mark) { - startTag = "vue-perf-start:" + (vm._uid); - endTag = "vue-perf-end:" + (vm._uid); + startTag = "vue-perf-start:" + vm._uid; + endTag = "vue-perf-end:" + vm._uid; mark(startTag); } @@ -4995,17 +5128,17 @@ initLifecycle(vm); initEvents(vm); initRender(vm); - callHook(vm, 'beforeCreate'); + callHook(vm, "beforeCreate"); initInjections(vm); // resolve injections before data/props initState(vm); initProvide(vm); // resolve provide after data/props - callHook(vm, 'created'); + callHook(vm, "created"); /* istanbul ignore if */ if (config.performance && mark) { vm._name = formatComponentName(vm, false); mark(endTag); - measure(("vue " + (vm._name) + " init"), startTag, endTag); + measure("vue " + vm._name + " init", startTag, endTag); } if (vm.$options.el) { @@ -5014,8 +5147,8 @@ }; } - function initInternalComponent (vm, options) { - var opts = vm.$options = Object.create(vm.constructor.options); + function initInternalComponent(vm, options) { + var opts = (vm.$options = Object.create(vm.constructor.options)); // doing this because it's faster than dynamic enumeration. var parentVnode = options._parentVnode; opts.parent = options.parent; @@ -5033,7 +5166,7 @@ } } - function resolveConstructorOptions (Ctor) { + function resolveConstructorOptions(Ctor) { var options = Ctor.options; if (Ctor.super) { var superOptions = resolveConstructorOptions(Ctor.super); @@ -5054,26 +5187,27 @@ } } } - return options + return options; } - function resolveModifiedOptions (Ctor) { + function resolveModifiedOptions(Ctor) { var modified; var latest = Ctor.options; var sealed = Ctor.sealedOptions; for (var key in latest) { if (latest[key] !== sealed[key]) { - if (!modified) { modified = {}; } + if (!modified) { + modified = {}; + } modified[key] = latest[key]; } } - return modified + return modified; } - function Vue (options) { - if (!(this instanceof Vue) - ) { - warn('Vue is a constructor and should be called with the `new` keyword'); + function Vue(options) { + if (!(this instanceof Vue)) { + warn("Vue is a constructor and should be called with the `new` keyword"); } this._init(options); } @@ -5086,38 +5220,39 @@ /* */ - function initUse (Vue) { + function initUse(Vue) { Vue.use = function (plugin) { - var installedPlugins = (this._installedPlugins || (this._installedPlugins = [])); + var installedPlugins = + this._installedPlugins || (this._installedPlugins = []); if (installedPlugins.indexOf(plugin) > -1) { - return this + return this; } // additional parameters var args = toArray(arguments, 1); args.unshift(this); - if (typeof plugin.install === 'function') { + if (typeof plugin.install === "function") { plugin.install.apply(plugin, args); - } else if (typeof plugin === 'function') { + } else if (typeof plugin === "function") { plugin.apply(null, args); } installedPlugins.push(plugin); - return this + return this; }; } /* */ - function initMixin$1 (Vue) { + function initMixin$1(Vue) { Vue.mixin = function (mixin) { this.options = mergeOptions(this.options, mixin); - return this + return this; }; } /* */ - function initExtend (Vue) { + function initExtend(Vue) { /** * Each instance constructor, including Vue, has a unique * cid. This enables us to create wrapped "child @@ -5135,7 +5270,7 @@ var SuperId = Super.cid; var cachedCtors = extendOptions._Ctor || (extendOptions._Ctor = {}); if (cachedCtors[SuperId]) { - return cachedCtors[SuperId] + return cachedCtors[SuperId]; } var name = extendOptions.name || Super.options.name; @@ -5143,17 +5278,14 @@ validateComponentName(name); } - var Sub = function VueComponent (options) { + var Sub = function VueComponent(options) { this._init(options); }; Sub.prototype = Object.create(Super.prototype); Sub.prototype.constructor = Sub; Sub.cid = cid++; - Sub.options = mergeOptions( - Super.options, - extendOptions - ); - Sub['super'] = Super; + Sub.options = mergeOptions(Super.options, extendOptions); + Sub["super"] = Super; // For props and computed properties, we define the proxy getters on // the Vue instances at extension time, on the extended prototype. This @@ -5189,18 +5321,18 @@ // cache constructor cachedCtors[SuperId] = Sub; - return Sub + return Sub; }; } - function initProps$1 (Comp) { + function initProps$1(Comp) { var props = Comp.options.props; for (var key in props) { proxy(Comp.prototype, "_props", key); } } - function initComputed$1 (Comp) { + function initComputed$1(Comp) { var computed = Comp.options.computed; for (var key in computed) { defineComputed(Comp.prototype, key, computed[key]); @@ -5209,31 +5341,28 @@ /* */ - function initAssetRegisters (Vue) { + function initAssetRegisters(Vue) { /** * Create asset registration methods. */ ASSET_TYPES.forEach(function (type) { - Vue[type] = function ( - id, - definition - ) { + Vue[type] = function (id, definition) { if (!definition) { - return this.options[type + 's'][id] + return this.options[type + "s"][id]; } else { /* istanbul ignore if */ - if (type === 'component') { + if (type === "component") { validateComponentName(id); } - if (type === 'component' && isPlainObject(definition)) { + if (type === "component" && isPlainObject(definition)) { definition.name = definition.name || id; definition = this.options._base.extend(definition); } - if (type === 'directive' && typeof definition === 'function') { + if (type === "directive" && typeof definition === "function") { definition = { bind: definition, update: definition }; } - this.options[type + 's'][id] = definition; - return definition + this.options[type + "s"][id] = definition; + return definition; } }; }); @@ -5241,25 +5370,23 @@ /* */ - - - function getComponentName (opts) { - return opts && (opts.Ctor.options.name || opts.tag) + function getComponentName(opts) { + return opts && (opts.Ctor.options.name || opts.tag); } - function matches (pattern, name) { + function matches(pattern, name) { if (Array.isArray(pattern)) { - return pattern.indexOf(name) > -1 - } else if (typeof pattern === 'string') { - return pattern.split(',').indexOf(name) > -1 + return pattern.indexOf(name) > -1; + } else if (typeof pattern === "string") { + return pattern.split(",").indexOf(name) > -1; } else if (isRegExp(pattern)) { - return pattern.test(name) + return pattern.test(name); } /* istanbul ignore next */ - return false + return false; } - function pruneCache (keepAliveInstance, filter) { + function pruneCache(keepAliveInstance, filter) { var cache = keepAliveInstance.cache; var keys = keepAliveInstance.keys; var _vnode = keepAliveInstance._vnode; @@ -5274,12 +5401,7 @@ } } - function pruneCacheEntry ( - cache, - key, - keys, - current - ) { + function pruneCacheEntry(cache, key, keys, current) { var cached$$1 = cache[key]; if (cached$$1 && (!current || cached$$1.tag !== current.tag)) { cached$$1.componentInstance.$destroy(); @@ -5291,38 +5413,42 @@ var patternTypes = [String, RegExp, Array]; var KeepAlive = { - name: 'keep-alive', + name: "keep-alive", abstract: true, props: { include: patternTypes, exclude: patternTypes, - max: [String, Number] + max: [String, Number], }, - created: function created () { + created: function created() { this.cache = Object.create(null); this.keys = []; }, - destroyed: function destroyed () { + destroyed: function destroyed() { for (var key in this.cache) { pruneCacheEntry(this.cache, key, this.keys); } }, - mounted: function mounted () { + mounted: function mounted() { var this$1 = this; - this.$watch('include', function (val) { - pruneCache(this$1, function (name) { return matches(val, name); }); + this.$watch("include", function (val) { + pruneCache(this$1, function (name) { + return matches(val, name); + }); }); - this.$watch('exclude', function (val) { - pruneCache(this$1, function (name) { return !matches(val, name); }); + this.$watch("exclude", function (val) { + pruneCache(this$1, function (name) { + return !matches(val, name); + }); }); }, - render: function render () { + render: function render() { var slot = this.$slots.default; var vnode = getFirstComponentChild(slot); var componentOptions = vnode && vnode.componentOptions; @@ -5338,17 +5464,19 @@ // excluded (exclude && name && matches(exclude, name)) ) { - return vnode + return vnode; } var ref$1 = this; var cache = ref$1.cache; var keys = ref$1.keys; - var key = vnode.key == null - // same constructor may get registered as different local components - // so cid alone is not enough (#3269) - ? componentOptions.Ctor.cid + (componentOptions.tag ? ("::" + (componentOptions.tag)) : '') - : vnode.key; + var key = + vnode.key == null + ? // same constructor may get registered as different local components + // so cid alone is not enough (#3269) + componentOptions.Ctor.cid + + (componentOptions.tag ? "::" + componentOptions.tag : "") + : vnode.key; if (cache[key]) { vnode.componentInstance = cache[key].componentInstance; // make current key freshest @@ -5365,28 +5493,30 @@ vnode.data.keepAlive = true; } - return vnode || (slot && slot[0]) - } + return vnode || (slot && slot[0]); + }, }; var builtInComponents = { - KeepAlive: KeepAlive + KeepAlive: KeepAlive, }; /* */ - function initGlobalAPI (Vue) { + function initGlobalAPI(Vue) { // config var configDef = {}; - configDef.get = function () { return config; }; + configDef.get = function () { + return config; + }; { configDef.set = function () { warn( - 'Do not replace the Vue.config object, set individual fields instead.' + "Do not replace the Vue.config object, set individual fields instead." ); }; } - Object.defineProperty(Vue, 'config', configDef); + Object.defineProperty(Vue, "config", configDef); // exposed util methods. // NOTE: these are not considered part of the public API - avoid relying on @@ -5395,7 +5525,7 @@ warn: warn, extend: extend, mergeOptions: mergeOptions, - defineReactive: defineReactive$$1 + defineReactive: defineReactive$$1, }; Vue.set = set; @@ -5405,12 +5535,12 @@ // 2.6 explicit observable API Vue.observable = function (obj) { observe(obj); - return obj + return obj; }; Vue.options = Object.create(null); ASSET_TYPES.forEach(function (type) { - Vue.options[type + 's'] = Object.create(null); + Vue.options[type + "s"] = Object.create(null); }); // this is used to identify the "base" constructor to extend all plain-object @@ -5427,80 +5557,82 @@ initGlobalAPI(Vue); - Object.defineProperty(Vue.prototype, '$isServer', { - get: isServerRendering + Object.defineProperty(Vue.prototype, "$isServer", { + get: isServerRendering, }); - Object.defineProperty(Vue.prototype, '$ssrContext', { - get: function get () { + Object.defineProperty(Vue.prototype, "$ssrContext", { + get: function get() { /* istanbul ignore next */ - return this.$vnode && this.$vnode.ssrContext - } + return this.$vnode && this.$vnode.ssrContext; + }, }); // expose FunctionalRenderContext for ssr runtime helper installation - Object.defineProperty(Vue, 'FunctionalRenderContext', { - value: FunctionalRenderContext + Object.defineProperty(Vue, "FunctionalRenderContext", { + value: FunctionalRenderContext, }); - Vue.version = '2.6.12'; + Vue.version = "2.6.12"; /* */ // these are reserved for web because they are directly compiled away // during template compilation - var isReservedAttr = makeMap('style,class'); + var isReservedAttr = makeMap("style,class"); // attributes that should be using props for binding - var acceptValue = makeMap('input,textarea,option,select,progress'); + var acceptValue = makeMap("input,textarea,option,select,progress"); var mustUseProp = function (tag, type, attr) { return ( - (attr === 'value' && acceptValue(tag)) && type !== 'button' || - (attr === 'selected' && tag === 'option') || - (attr === 'checked' && tag === 'input') || - (attr === 'muted' && tag === 'video') - ) + (attr === "value" && acceptValue(tag) && type !== "button") || + (attr === "selected" && tag === "option") || + (attr === "checked" && tag === "input") || + (attr === "muted" && tag === "video") + ); }; - var isEnumeratedAttr = makeMap('contenteditable,draggable,spellcheck'); + var isEnumeratedAttr = makeMap("contenteditable,draggable,spellcheck"); - var isValidContentEditableValue = makeMap('events,caret,typing,plaintext-only'); + var isValidContentEditableValue = makeMap( + "events,caret,typing,plaintext-only" + ); var convertEnumeratedValue = function (key, value) { - return isFalsyAttrValue(value) || value === 'false' - ? 'false' - // allow arbitrary string value for contenteditable - : key === 'contenteditable' && isValidContentEditableValue(value) - ? value - : 'true' + return isFalsyAttrValue(value) || value === "false" + ? "false" + : // allow arbitrary string value for contenteditable + key === "contenteditable" && isValidContentEditableValue(value) + ? value + : "true"; }; var isBooleanAttr = makeMap( - 'allowfullscreen,async,autofocus,autoplay,checked,compact,controls,declare,' + - 'default,defaultchecked,defaultmuted,defaultselected,defer,disabled,' + - 'enabled,formnovalidate,hidden,indeterminate,inert,ismap,itemscope,loop,multiple,' + - 'muted,nohref,noresize,noshade,novalidate,nowrap,open,pauseonexit,readonly,' + - 'required,reversed,scoped,seamless,selected,sortable,translate,' + - 'truespeed,typemustmatch,visible' + "allowfullscreen,async,autofocus,autoplay,checked,compact,controls,declare," + + "default,defaultchecked,defaultmuted,defaultselected,defer,disabled," + + "enabled,formnovalidate,hidden,indeterminate,inert,ismap,itemscope,loop,multiple," + + "muted,nohref,noresize,noshade,novalidate,nowrap,open,pauseonexit,readonly," + + "required,reversed,scoped,seamless,selected,sortable,translate," + + "truespeed,typemustmatch,visible" ); - var xlinkNS = 'http://www.w3.org/1999/xlink'; + var xlinkNS = "http://www.w3.org/1999/xlink"; var isXlink = function (name) { - return name.charAt(5) === ':' && name.slice(0, 5) === 'xlink' + return name.charAt(5) === ":" && name.slice(0, 5) === "xlink"; }; var getXlinkProp = function (name) { - return isXlink(name) ? name.slice(6, name.length) : '' + return isXlink(name) ? name.slice(6, name.length) : ""; }; var isFalsyAttrValue = function (val) { - return val == null || val === false + return val == null || val === false; }; /* */ - function genClassForVnode (vnode) { + function genClassForVnode(vnode) { var data = vnode.data; var parentNode = vnode; var childNode = vnode; @@ -5510,229 +5642,236 @@ data = mergeClassData(childNode.data, data); } } - while (isDef(parentNode = parentNode.parent)) { + while (isDef((parentNode = parentNode.parent))) { if (parentNode && parentNode.data) { data = mergeClassData(data, parentNode.data); } } - return renderClass(data.staticClass, data.class) + return renderClass(data.staticClass, data.class); } - function mergeClassData (child, parent) { + function mergeClassData(child, parent) { return { staticClass: concat(child.staticClass, parent.staticClass), - class: isDef(child.class) - ? [child.class, parent.class] - : parent.class - } + class: isDef(child.class) ? [child.class, parent.class] : parent.class, + }; } - function renderClass ( - staticClass, - dynamicClass - ) { + function renderClass(staticClass, dynamicClass) { if (isDef(staticClass) || isDef(dynamicClass)) { - return concat(staticClass, stringifyClass(dynamicClass)) + return concat(staticClass, stringifyClass(dynamicClass)); } /* istanbul ignore next */ - return '' + return ""; } - function concat (a, b) { - return a ? b ? (a + ' ' + b) : a : (b || '') + function concat(a, b) { + return a ? (b ? a + " " + b : a) : b || ""; } - function stringifyClass (value) { + function stringifyClass(value) { if (Array.isArray(value)) { - return stringifyArray(value) + return stringifyArray(value); } if (isObject(value)) { - return stringifyObject(value) + return stringifyObject(value); } - if (typeof value === 'string') { - return value + if (typeof value === "string") { + return value; } /* istanbul ignore next */ - return '' + return ""; } - function stringifyArray (value) { - var res = ''; + function stringifyArray(value) { + var res = ""; var stringified; for (var i = 0, l = value.length; i < l; i++) { - if (isDef(stringified = stringifyClass(value[i])) && stringified !== '') { - if (res) { res += ' '; } + if ( + isDef((stringified = stringifyClass(value[i]))) && + stringified !== "" + ) { + if (res) { + res += " "; + } res += stringified; } } - return res + return res; } - function stringifyObject (value) { - var res = ''; + function stringifyObject(value) { + var res = ""; for (var key in value) { if (value[key]) { - if (res) { res += ' '; } + if (res) { + res += " "; + } res += key; } } - return res + return res; } /* */ var namespaceMap = { - svg: 'http://www.w3.org/2000/svg', - math: 'http://www.w3.org/1998/Math/MathML' + svg: "http://www.w3.org/2000/svg", + math: "http://www.w3.org/1998/Math/MathML", }; var isHTMLTag = makeMap( - 'html,body,base,head,link,meta,style,title,' + - 'address,article,aside,footer,header,h1,h2,h3,h4,h5,h6,hgroup,nav,section,' + - 'div,dd,dl,dt,figcaption,figure,picture,hr,img,li,main,ol,p,pre,ul,' + - 'a,b,abbr,bdi,bdo,br,cite,code,data,dfn,em,i,kbd,mark,q,rp,rt,rtc,ruby,' + - 's,samp,small,span,strong,sub,sup,time,u,var,wbr,area,audio,map,track,video,' + - 'embed,object,param,source,canvas,script,noscript,del,ins,' + - 'caption,col,colgroup,table,thead,tbody,td,th,tr,' + - 'button,datalist,fieldset,form,input,label,legend,meter,optgroup,option,' + - 'output,progress,select,textarea,' + - 'details,dialog,menu,menuitem,summary,' + - 'content,element,shadow,template,blockquote,iframe,tfoot' + "html,body,base,head,link,meta,style,title," + + "address,article,aside,footer,header,h1,h2,h3,h4,h5,h6,hgroup,nav,section," + + "div,dd,dl,dt,figcaption,figure,picture,hr,img,li,main,ol,p,pre,ul," + + "a,b,abbr,bdi,bdo,br,cite,code,data,dfn,em,i,kbd,mark,q,rp,rt,rtc,ruby," + + "s,samp,small,span,strong,sub,sup,time,u,var,wbr,area,audio,map,track,video," + + "embed,object,param,source,canvas,script,noscript,del,ins," + + "caption,col,colgroup,table,thead,tbody,td,th,tr," + + "button,datalist,fieldset,form,input,label,legend,meter,optgroup,option," + + "output,progress,select,textarea," + + "details,dialog,menu,menuitem,summary," + + "content,element,shadow,template,blockquote,iframe,tfoot" ); // this map is intentionally selective, only covering SVG elements that may // contain child elements. var isSVG = makeMap( - 'svg,animate,circle,clippath,cursor,defs,desc,ellipse,filter,font-face,' + - 'foreignObject,g,glyph,image,line,marker,mask,missing-glyph,path,pattern,' + - 'polygon,polyline,rect,switch,symbol,text,textpath,tspan,use,view', + "svg,animate,circle,clippath,cursor,defs,desc,ellipse,filter,font-face," + + "foreignObject,g,glyph,image,line,marker,mask,missing-glyph,path,pattern," + + "polygon,polyline,rect,switch,symbol,text,textpath,tspan,use,view", true ); - var isPreTag = function (tag) { return tag === 'pre'; }; + var isPreTag = function (tag) { + return tag === "pre"; + }; var isReservedTag = function (tag) { - return isHTMLTag(tag) || isSVG(tag) + return isHTMLTag(tag) || isSVG(tag); }; - function getTagNamespace (tag) { + function getTagNamespace(tag) { if (isSVG(tag)) { - return 'svg' + return "svg"; } // basic support for MathML // note it doesn't support other MathML elements being component roots - if (tag === 'math') { - return 'math' + if (tag === "math") { + return "math"; } } var unknownElementCache = Object.create(null); - function isUnknownElement (tag) { + function isUnknownElement(tag) { /* istanbul ignore if */ if (!inBrowser) { - return true + return true; } if (isReservedTag(tag)) { - return false + return false; } tag = tag.toLowerCase(); /* istanbul ignore if */ if (unknownElementCache[tag] != null) { - return unknownElementCache[tag] + return unknownElementCache[tag]; } var el = document.createElement(tag); - if (tag.indexOf('-') > -1) { + if (tag.indexOf("-") > -1) { // http://stackoverflow.com/a/28210364/1070244 - return (unknownElementCache[tag] = ( + return (unknownElementCache[tag] = el.constructor === window.HTMLUnknownElement || - el.constructor === window.HTMLElement - )) + el.constructor === window.HTMLElement); } else { - return (unknownElementCache[tag] = /HTMLUnknownElement/.test(el.toString())) + return (unknownElementCache[tag] = /HTMLUnknownElement/.test( + el.toString() + )); } } - var isTextInputType = makeMap('text,number,password,search,email,tel,url'); + var isTextInputType = makeMap("text,number,password,search,email,tel,url"); /* */ /** * Query an element selector if it's not an element already. */ - function query (el) { - if (typeof el === 'string') { + function query(el) { + if (typeof el === "string") { var selected = document.querySelector(el); if (!selected) { - warn( - 'Cannot find element: ' + el - ); - return document.createElement('div') + warn("Cannot find element: " + el); + return document.createElement("div"); } - return selected + return selected; } else { - return el + return el; } } /* */ - function createElement$1 (tagName, vnode) { + function createElement$1(tagName, vnode) { var elm = document.createElement(tagName); - if (tagName !== 'select') { - return elm + if (tagName !== "select") { + return elm; } // false or null will remove the attribute but undefined will not - if (vnode.data && vnode.data.attrs && vnode.data.attrs.multiple !== undefined) { - elm.setAttribute('multiple', 'multiple'); + if ( + vnode.data && + vnode.data.attrs && + vnode.data.attrs.multiple !== undefined + ) { + elm.setAttribute("multiple", "multiple"); } - return elm + return elm; } - function createElementNS (namespace, tagName) { - return document.createElementNS(namespaceMap[namespace], tagName) + function createElementNS(namespace, tagName) { + return document.createElementNS(namespaceMap[namespace], tagName); } - function createTextNode (text) { - return document.createTextNode(text) + function createTextNode(text) { + return document.createTextNode(text); } - function createComment (text) { - return document.createComment(text) + function createComment(text) { + return document.createComment(text); } - function insertBefore (parentNode, newNode, referenceNode) { + function insertBefore(parentNode, newNode, referenceNode) { parentNode.insertBefore(newNode, referenceNode); } - function removeChild (node, child) { + function removeChild(node, child) { node.removeChild(child); } - function appendChild (node, child) { + function appendChild(node, child) { node.appendChild(child); } - function parentNode (node) { - return node.parentNode + function parentNode(node) { + return node.parentNode; } - function nextSibling (node) { - return node.nextSibling + function nextSibling(node) { + return node.nextSibling; } - function tagName (node) { - return node.tagName + function tagName(node) { + return node.tagName; } - function setTextContent (node, text) { + function setTextContent(node, text) { node.textContent = text; } - function setStyleScope (node, scopeId) { - node.setAttribute(scopeId, ''); + function setStyleScope(node, scopeId) { + node.setAttribute(scopeId, ""); } - var nodeOps = /*#__PURE__*/Object.freeze({ + var nodeOps = /*#__PURE__*/ Object.freeze({ createElement: createElement$1, createElementNS: createElementNS, createTextNode: createTextNode, @@ -5744,29 +5883,31 @@ nextSibling: nextSibling, tagName: tagName, setTextContent: setTextContent, - setStyleScope: setStyleScope + setStyleScope: setStyleScope, }); /* */ var ref = { - create: function create (_, vnode) { + create: function create(_, vnode) { registerRef(vnode); }, - update: function update (oldVnode, vnode) { + update: function update(oldVnode, vnode) { if (oldVnode.data.ref !== vnode.data.ref) { registerRef(oldVnode, true); registerRef(vnode); } }, - destroy: function destroy (vnode) { + destroy: function destroy(vnode) { registerRef(vnode, true); - } + }, }; - function registerRef (vnode, isRemoval) { + function registerRef(vnode, isRemoval) { var key = vnode.data.ref; - if (!isDef(key)) { return } + if (!isDef(key)) { + return; + } var vm = vnode.context; var ref = vnode.componentInstance || vnode.elm; @@ -5803,46 +5944,48 @@ * of making flow understand it is not worth it. */ - var emptyNode = new VNode('', {}, []); + var emptyNode = new VNode("", {}, []); - var hooks = ['create', 'activate', 'update', 'remove', 'destroy']; + var hooks = ["create", "activate", "update", "remove", "destroy"]; - function sameVnode (a, b) { + function sameVnode(a, b) { return ( - a.key === b.key && ( - ( - a.tag === b.tag && - a.isComment === b.isComment && - isDef(a.data) === isDef(b.data) && - sameInputType(a, b) - ) || ( - isTrue(a.isAsyncPlaceholder) && + a.key === b.key && + ((a.tag === b.tag && + a.isComment === b.isComment && + isDef(a.data) === isDef(b.data) && + sameInputType(a, b)) || + (isTrue(a.isAsyncPlaceholder) && a.asyncFactory === b.asyncFactory && - isUndef(b.asyncFactory.error) - ) - ) - ) + isUndef(b.asyncFactory.error))) + ); } - function sameInputType (a, b) { - if (a.tag !== 'input') { return true } + function sameInputType(a, b) { + if (a.tag !== "input") { + return true; + } var i; - var typeA = isDef(i = a.data) && isDef(i = i.attrs) && i.type; - var typeB = isDef(i = b.data) && isDef(i = i.attrs) && i.type; - return typeA === typeB || isTextInputType(typeA) && isTextInputType(typeB) + var typeA = isDef((i = a.data)) && isDef((i = i.attrs)) && i.type; + var typeB = isDef((i = b.data)) && isDef((i = i.attrs)) && i.type; + return ( + typeA === typeB || (isTextInputType(typeA) && isTextInputType(typeB)) + ); } - function createKeyToOldIdx (children, beginIdx, endIdx) { + function createKeyToOldIdx(children, beginIdx, endIdx) { var i, key; var map = {}; for (i = beginIdx; i <= endIdx; ++i) { key = children[i].key; - if (isDef(key)) { map[key] = i; } + if (isDef(key)) { + map[key] = i; + } } - return map + return map; } - function createPatchFunction (backend) { + function createPatchFunction(backend) { var i, j; var cbs = {}; @@ -5858,21 +6001,27 @@ } } - function emptyNodeAt (elm) { - return new VNode(nodeOps.tagName(elm).toLowerCase(), {}, [], undefined, elm) + function emptyNodeAt(elm) { + return new VNode( + nodeOps.tagName(elm).toLowerCase(), + {}, + [], + undefined, + elm + ); } - function createRmCb (childElm, listeners) { - function remove$$1 () { + function createRmCb(childElm, listeners) { + function remove$$1() { if (--remove$$1.listeners === 0) { removeNode(childElm); } } remove$$1.listeners = listeners; - return remove$$1 + return remove$$1; } - function removeNode (el) { + function removeNode(el) { var parent = nodeOps.parentNode(el); // element may have already been removed due to v-html / v-text if (isDef(parent)) { @@ -5880,7 +6029,7 @@ } } - function isUnknownElement$$1 (vnode, inVPre) { + function isUnknownElement$$1(vnode, inVPre) { return ( !inVPre && !vnode.ns && @@ -5889,16 +6038,16 @@ config.ignoredElements.some(function (ignore) { return isRegExp(ignore) ? ignore.test(vnode.tag) - : ignore === vnode.tag + : ignore === vnode.tag; }) ) && config.isUnknownElement(vnode.tag) - ) + ); } var creatingElmInVPre = 0; - function createElm ( + function createElm( vnode, insertedVnodeQueue, parentElm, @@ -5918,7 +6067,7 @@ vnode.isRootInsert = !nested; // for transition enter check if (createComponent(vnode, insertedVnodeQueue, parentElm, refElm)) { - return + return; } var data = vnode.data; @@ -5931,9 +6080,11 @@ } if (isUnknownElement$$1(vnode, creatingElmInVPre)) { warn( - 'Unknown custom element: <' + tag + '> - did you ' + - 'register the component correctly? For recursive components, ' + - 'make sure to provide the "name" option.', + "Unknown custom element: <" + + tag + + "> - did you " + + "register the component correctly? For recursive components, " + + 'make sure to provide the "name" option.', vnode.context ); } @@ -5965,11 +6116,11 @@ } } - function createComponent (vnode, insertedVnodeQueue, parentElm, refElm) { + function createComponent(vnode, insertedVnodeQueue, parentElm, refElm) { var i = vnode.data; if (isDef(i)) { var isReactivated = isDef(vnode.componentInstance) && i.keepAlive; - if (isDef(i = i.hook) && isDef(i = i.init)) { + if (isDef((i = i.hook)) && isDef((i = i.init))) { i(vnode, false /* hydrating */); } // after calling the init hook, if the vnode is a child component @@ -5982,14 +6133,17 @@ if (isTrue(isReactivated)) { reactivateComponent(vnode, insertedVnodeQueue, parentElm, refElm); } - return true + return true; } } } - function initComponent (vnode, insertedVnodeQueue) { + function initComponent(vnode, insertedVnodeQueue) { if (isDef(vnode.data.pendingInsert)) { - insertedVnodeQueue.push.apply(insertedVnodeQueue, vnode.data.pendingInsert); + insertedVnodeQueue.push.apply( + insertedVnodeQueue, + vnode.data.pendingInsert + ); vnode.data.pendingInsert = null; } vnode.elm = vnode.componentInstance.$el; @@ -6005,7 +6159,7 @@ } } - function reactivateComponent (vnode, insertedVnodeQueue, parentElm, refElm) { + function reactivateComponent(vnode, insertedVnodeQueue, parentElm, refElm) { var i; // hack for #4339: a reactivated component with inner transition // does not trigger because the inner node's created hooks are not called @@ -6014,12 +6168,12 @@ var innerNode = vnode; while (innerNode.componentInstance) { innerNode = innerNode.componentInstance._vnode; - if (isDef(i = innerNode.data) && isDef(i = i.transition)) { + if (isDef((i = innerNode.data)) && isDef((i = i.transition))) { for (i = 0; i < cbs.activate.length; ++i) { cbs.activate[i](emptyNode, innerNode); } insertedVnodeQueue.push(innerNode); - break + break; } } // unlike a newly created component, @@ -6027,7 +6181,7 @@ insert(parentElm, vnode.elm, refElm); } - function insert (parent, elm, ref$$1) { + function insert(parent, elm, ref$$1) { if (isDef(parent)) { if (isDef(ref$$1)) { if (nodeOps.parentNode(ref$$1) === parent) { @@ -6039,98 +6193,137 @@ } } - function createChildren (vnode, children, insertedVnodeQueue) { + function createChildren(vnode, children, insertedVnodeQueue) { if (Array.isArray(children)) { { checkDuplicateKeys(children); } for (var i = 0; i < children.length; ++i) { - createElm(children[i], insertedVnodeQueue, vnode.elm, null, true, children, i); + createElm( + children[i], + insertedVnodeQueue, + vnode.elm, + null, + true, + children, + i + ); } } else if (isPrimitive(vnode.text)) { - nodeOps.appendChild(vnode.elm, nodeOps.createTextNode(String(vnode.text))); + nodeOps.appendChild( + vnode.elm, + nodeOps.createTextNode(String(vnode.text)) + ); } } - function isPatchable (vnode) { + function isPatchable(vnode) { while (vnode.componentInstance) { vnode = vnode.componentInstance._vnode; } - return isDef(vnode.tag) + return isDef(vnode.tag); } - function invokeCreateHooks (vnode, insertedVnodeQueue) { + function invokeCreateHooks(vnode, insertedVnodeQueue) { for (var i$1 = 0; i$1 < cbs.create.length; ++i$1) { cbs.create[i$1](emptyNode, vnode); } i = vnode.data.hook; // Reuse variable if (isDef(i)) { - if (isDef(i.create)) { i.create(emptyNode, vnode); } - if (isDef(i.insert)) { insertedVnodeQueue.push(vnode); } + if (isDef(i.create)) { + i.create(emptyNode, vnode); + } + if (isDef(i.insert)) { + insertedVnodeQueue.push(vnode); + } } } // set scope id attribute for scoped CSS. // this is implemented as a special case to avoid the overhead // of going through the normal attribute patching process. - function setScope (vnode) { + function setScope(vnode) { var i; - if (isDef(i = vnode.fnScopeId)) { + if (isDef((i = vnode.fnScopeId))) { nodeOps.setStyleScope(vnode.elm, i); } else { var ancestor = vnode; while (ancestor) { - if (isDef(i = ancestor.context) && isDef(i = i.$options._scopeId)) { + if ( + isDef((i = ancestor.context)) && + isDef((i = i.$options._scopeId)) + ) { nodeOps.setStyleScope(vnode.elm, i); } ancestor = ancestor.parent; } } // for slot content they should also get the scopeId from the host instance. - if (isDef(i = activeInstance) && + if ( + isDef((i = activeInstance)) && i !== vnode.context && i !== vnode.fnContext && - isDef(i = i.$options._scopeId) + isDef((i = i.$options._scopeId)) ) { nodeOps.setStyleScope(vnode.elm, i); } } - function addVnodes (parentElm, refElm, vnodes, startIdx, endIdx, insertedVnodeQueue) { + function addVnodes( + parentElm, + refElm, + vnodes, + startIdx, + endIdx, + insertedVnodeQueue + ) { for (; startIdx <= endIdx; ++startIdx) { - createElm(vnodes[startIdx], insertedVnodeQueue, parentElm, refElm, false, vnodes, startIdx); + createElm( + vnodes[startIdx], + insertedVnodeQueue, + parentElm, + refElm, + false, + vnodes, + startIdx + ); } } - function invokeDestroyHook (vnode) { + function invokeDestroyHook(vnode) { var i, j; var data = vnode.data; if (isDef(data)) { - if (isDef(i = data.hook) && isDef(i = i.destroy)) { i(vnode); } - for (i = 0; i < cbs.destroy.length; ++i) { cbs.destroy[i](vnode); } + if (isDef((i = data.hook)) && isDef((i = i.destroy))) { + i(vnode); + } + for (i = 0; i < cbs.destroy.length; ++i) { + cbs.destroy[i](vnode); + } } - if (isDef(i = vnode.children)) { + if (isDef((i = vnode.children))) { for (j = 0; j < vnode.children.length; ++j) { invokeDestroyHook(vnode.children[j]); } } } - function removeVnodes (vnodes, startIdx, endIdx) { + function removeVnodes(vnodes, startIdx, endIdx) { for (; startIdx <= endIdx; ++startIdx) { var ch = vnodes[startIdx]; if (isDef(ch)) { if (isDef(ch.tag)) { removeAndInvokeRemoveHook(ch); invokeDestroyHook(ch); - } else { // Text node + } else { + // Text node removeNode(ch.elm); } } } } - function removeAndInvokeRemoveHook (vnode, rm) { + function removeAndInvokeRemoveHook(vnode, rm) { if (isDef(rm) || isDef(vnode.data)) { var i; var listeners = cbs.remove.length + 1; @@ -6143,13 +6336,17 @@ rm = createRmCb(vnode.elm, listeners); } // recursively invoke hooks on child component root node - if (isDef(i = vnode.componentInstance) && isDef(i = i._vnode) && isDef(i.data)) { + if ( + isDef((i = vnode.componentInstance)) && + isDef((i = i._vnode)) && + isDef(i.data) + ) { removeAndInvokeRemoveHook(i, rm); } for (i = 0; i < cbs.remove.length; ++i) { cbs.remove[i](vnode, rm); } - if (isDef(i = vnode.data.hook) && isDef(i = i.remove)) { + if (isDef((i = vnode.data.hook)) && isDef((i = i.remove))) { i(vnode, rm); } else { rm(); @@ -6159,7 +6356,13 @@ } } - function updateChildren (parentElm, oldCh, newCh, insertedVnodeQueue, removeOnly) { + function updateChildren( + parentElm, + oldCh, + newCh, + insertedVnodeQueue, + removeOnly + ) { var oldStartIdx = 0; var newStartIdx = 0; var oldEndIdx = oldCh.length - 1; @@ -6185,53 +6388,124 @@ } else if (isUndef(oldEndVnode)) { oldEndVnode = oldCh[--oldEndIdx]; } else if (sameVnode(oldStartVnode, newStartVnode)) { - patchVnode(oldStartVnode, newStartVnode, insertedVnodeQueue, newCh, newStartIdx); + patchVnode( + oldStartVnode, + newStartVnode, + insertedVnodeQueue, + newCh, + newStartIdx + ); oldStartVnode = oldCh[++oldStartIdx]; newStartVnode = newCh[++newStartIdx]; } else if (sameVnode(oldEndVnode, newEndVnode)) { - patchVnode(oldEndVnode, newEndVnode, insertedVnodeQueue, newCh, newEndIdx); + patchVnode( + oldEndVnode, + newEndVnode, + insertedVnodeQueue, + newCh, + newEndIdx + ); oldEndVnode = oldCh[--oldEndIdx]; newEndVnode = newCh[--newEndIdx]; - } else if (sameVnode(oldStartVnode, newEndVnode)) { // Vnode moved right - patchVnode(oldStartVnode, newEndVnode, insertedVnodeQueue, newCh, newEndIdx); - canMove && nodeOps.insertBefore(parentElm, oldStartVnode.elm, nodeOps.nextSibling(oldEndVnode.elm)); + } else if (sameVnode(oldStartVnode, newEndVnode)) { + // Vnode moved right + patchVnode( + oldStartVnode, + newEndVnode, + insertedVnodeQueue, + newCh, + newEndIdx + ); + canMove && + nodeOps.insertBefore( + parentElm, + oldStartVnode.elm, + nodeOps.nextSibling(oldEndVnode.elm) + ); oldStartVnode = oldCh[++oldStartIdx]; newEndVnode = newCh[--newEndIdx]; - } else if (sameVnode(oldEndVnode, newStartVnode)) { // Vnode moved left - patchVnode(oldEndVnode, newStartVnode, insertedVnodeQueue, newCh, newStartIdx); - canMove && nodeOps.insertBefore(parentElm, oldEndVnode.elm, oldStartVnode.elm); + } else if (sameVnode(oldEndVnode, newStartVnode)) { + // Vnode moved left + patchVnode( + oldEndVnode, + newStartVnode, + insertedVnodeQueue, + newCh, + newStartIdx + ); + canMove && + nodeOps.insertBefore(parentElm, oldEndVnode.elm, oldStartVnode.elm); oldEndVnode = oldCh[--oldEndIdx]; newStartVnode = newCh[++newStartIdx]; } else { - if (isUndef(oldKeyToIdx)) { oldKeyToIdx = createKeyToOldIdx(oldCh, oldStartIdx, oldEndIdx); } + if (isUndef(oldKeyToIdx)) { + oldKeyToIdx = createKeyToOldIdx(oldCh, oldStartIdx, oldEndIdx); + } idxInOld = isDef(newStartVnode.key) ? oldKeyToIdx[newStartVnode.key] : findIdxInOld(newStartVnode, oldCh, oldStartIdx, oldEndIdx); - if (isUndef(idxInOld)) { // New element - createElm(newStartVnode, insertedVnodeQueue, parentElm, oldStartVnode.elm, false, newCh, newStartIdx); + if (isUndef(idxInOld)) { + // New element + createElm( + newStartVnode, + insertedVnodeQueue, + parentElm, + oldStartVnode.elm, + false, + newCh, + newStartIdx + ); } else { vnodeToMove = oldCh[idxInOld]; if (sameVnode(vnodeToMove, newStartVnode)) { - patchVnode(vnodeToMove, newStartVnode, insertedVnodeQueue, newCh, newStartIdx); + patchVnode( + vnodeToMove, + newStartVnode, + insertedVnodeQueue, + newCh, + newStartIdx + ); oldCh[idxInOld] = undefined; - canMove && nodeOps.insertBefore(parentElm, vnodeToMove.elm, oldStartVnode.elm); + canMove && + nodeOps.insertBefore( + parentElm, + vnodeToMove.elm, + oldStartVnode.elm + ); } else { // same key but different element. treat as new element - createElm(newStartVnode, insertedVnodeQueue, parentElm, oldStartVnode.elm, false, newCh, newStartIdx); + createElm( + newStartVnode, + insertedVnodeQueue, + parentElm, + oldStartVnode.elm, + false, + newCh, + newStartIdx + ); } } newStartVnode = newCh[++newStartIdx]; } } if (oldStartIdx > oldEndIdx) { - refElm = isUndef(newCh[newEndIdx + 1]) ? null : newCh[newEndIdx + 1].elm; - addVnodes(parentElm, refElm, newCh, newStartIdx, newEndIdx, insertedVnodeQueue); + refElm = isUndef(newCh[newEndIdx + 1]) + ? null + : newCh[newEndIdx + 1].elm; + addVnodes( + parentElm, + refElm, + newCh, + newStartIdx, + newEndIdx, + insertedVnodeQueue + ); } else if (newStartIdx > newEndIdx) { removeVnodes(oldCh, oldStartIdx, oldEndIdx); } } - function checkDuplicateKeys (children) { + function checkDuplicateKeys(children) { var seenKeys = {}; for (var i = 0; i < children.length; i++) { var vnode = children[i]; @@ -6239,7 +6513,9 @@ if (isDef(key)) { if (seenKeys[key]) { warn( - ("Duplicate keys detected: '" + key + "'. This may cause an update error."), + "Duplicate keys detected: '" + + key + + "'. This may cause an update error.", vnode.context ); } else { @@ -6249,14 +6525,16 @@ } } - function findIdxInOld (node, oldCh, start, end) { + function findIdxInOld(node, oldCh, start, end) { for (var i = start; i < end; i++) { var c = oldCh[i]; - if (isDef(c) && sameVnode(node, c)) { return i } + if (isDef(c) && sameVnode(node, c)) { + return i; + } } } - function patchVnode ( + function patchVnode( oldVnode, vnode, insertedVnodeQueue, @@ -6265,7 +6543,7 @@ removeOnly ) { if (oldVnode === vnode) { - return + return; } if (isDef(vnode.elm) && isDef(ownerArray)) { @@ -6273,7 +6551,7 @@ vnode = ownerArray[index] = cloneVNode(vnode); } - var elm = vnode.elm = oldVnode.elm; + var elm = (vnode.elm = oldVnode.elm); if (isTrue(oldVnode.isAsyncPlaceholder)) { if (isDef(vnode.asyncFactory.resolved)) { @@ -6281,57 +6559,68 @@ } else { vnode.isAsyncPlaceholder = true; } - return + return; } // reuse element for static trees. // note we only do this if the vnode is cloned - // if the new node is not cloned it means the render functions have been // reset by the hot-reload-api and we need to do a proper re-render. - if (isTrue(vnode.isStatic) && + if ( + isTrue(vnode.isStatic) && isTrue(oldVnode.isStatic) && vnode.key === oldVnode.key && (isTrue(vnode.isCloned) || isTrue(vnode.isOnce)) ) { vnode.componentInstance = oldVnode.componentInstance; - return + return; } var i; var data = vnode.data; - if (isDef(data) && isDef(i = data.hook) && isDef(i = i.prepatch)) { + if (isDef(data) && isDef((i = data.hook)) && isDef((i = i.prepatch))) { i(oldVnode, vnode); } var oldCh = oldVnode.children; var ch = vnode.children; if (isDef(data) && isPatchable(vnode)) { - for (i = 0; i < cbs.update.length; ++i) { cbs.update[i](oldVnode, vnode); } - if (isDef(i = data.hook) && isDef(i = i.update)) { i(oldVnode, vnode); } + for (i = 0; i < cbs.update.length; ++i) { + cbs.update[i](oldVnode, vnode); + } + if (isDef((i = data.hook)) && isDef((i = i.update))) { + i(oldVnode, vnode); + } } if (isUndef(vnode.text)) { if (isDef(oldCh) && isDef(ch)) { - if (oldCh !== ch) { updateChildren(elm, oldCh, ch, insertedVnodeQueue, removeOnly); } + if (oldCh !== ch) { + updateChildren(elm, oldCh, ch, insertedVnodeQueue, removeOnly); + } } else if (isDef(ch)) { { checkDuplicateKeys(ch); } - if (isDef(oldVnode.text)) { nodeOps.setTextContent(elm, ''); } + if (isDef(oldVnode.text)) { + nodeOps.setTextContent(elm, ""); + } addVnodes(elm, null, ch, 0, ch.length - 1, insertedVnodeQueue); } else if (isDef(oldCh)) { removeVnodes(oldCh, 0, oldCh.length - 1); } else if (isDef(oldVnode.text)) { - nodeOps.setTextContent(elm, ''); + nodeOps.setTextContent(elm, ""); } } else if (oldVnode.text !== vnode.text) { nodeOps.setTextContent(elm, vnode.text); } if (isDef(data)) { - if (isDef(i = data.hook) && isDef(i = i.postpatch)) { i(oldVnode, vnode); } + if (isDef((i = data.hook)) && isDef((i = i.postpatch))) { + i(oldVnode, vnode); + } } } - function invokeInsertHook (vnode, queue, initial) { + function invokeInsertHook(vnode, queue, initial) { // delay insert hooks for component root nodes, invoke them after the // element is really inserted if (isTrue(initial) && isDef(vnode.parent)) { @@ -6348,10 +6637,10 @@ // are already rendered on the client or has no need for initialization // Note: style is excluded because it relies on initial clone for future // deep updates (#7063). - var isRenderedModule = makeMap('attrs,class,staticClass,staticStyle,key'); + var isRenderedModule = makeMap("attrs,class,staticClass,staticStyle,key"); // Note: this is a browser-only function so we can assume elms are DOM nodes. - function hydrate (elm, vnode, insertedVnodeQueue, inVPre) { + function hydrate(elm, vnode, insertedVnodeQueue, inVPre) { var i; var tag = vnode.tag; var data = vnode.data; @@ -6361,20 +6650,22 @@ if (isTrue(vnode.isComment) && isDef(vnode.asyncFactory)) { vnode.isAsyncPlaceholder = true; - return true + return true; } // assert node match { if (!assertNodeMatch(elm, vnode, inVPre)) { - return false + return false; } } if (isDef(data)) { - if (isDef(i = data.hook) && isDef(i = i.init)) { i(vnode, true /* hydrating */); } - if (isDef(i = vnode.componentInstance)) { + if (isDef((i = data.hook)) && isDef((i = i.init))) { + i(vnode, true /* hydrating */); + } + if (isDef((i = vnode.componentInstance))) { // child component. it should have hydrated its own tree. initComponent(vnode, insertedVnodeQueue); - return true + return true; } } if (isDef(tag)) { @@ -6384,27 +6675,32 @@ createChildren(vnode, children, insertedVnodeQueue); } else { // v-html and domProps: innerHTML - if (isDef(i = data) && isDef(i = i.domProps) && isDef(i = i.innerHTML)) { + if ( + isDef((i = data)) && + isDef((i = i.domProps)) && + isDef((i = i.innerHTML)) + ) { if (i !== elm.innerHTML) { /* istanbul ignore if */ - if (typeof console !== 'undefined' && - !hydrationBailed - ) { + if (typeof console !== "undefined" && !hydrationBailed) { hydrationBailed = true; - console.warn('Parent: ', elm); - console.warn('server innerHTML: ', i); - console.warn('client innerHTML: ', elm.innerHTML); + console.warn("Parent: ", elm); + console.warn("server innerHTML: ", i); + console.warn("client innerHTML: ", elm.innerHTML); } - return false + return false; } } else { // iterate and compare children lists var childrenMatch = true; var childNode = elm.firstChild; for (var i$1 = 0; i$1 < children.length; i$1++) { - if (!childNode || !hydrate(childNode, children[i$1], insertedVnodeQueue, inVPre)) { + if ( + !childNode || + !hydrate(childNode, children[i$1], insertedVnodeQueue, inVPre) + ) { childrenMatch = false; - break + break; } childNode = childNode.nextSibling; } @@ -6412,14 +6708,16 @@ // longer than the virtual children list. if (!childrenMatch || childNode) { /* istanbul ignore if */ - if (typeof console !== 'undefined' && - !hydrationBailed - ) { + if (typeof console !== "undefined" && !hydrationBailed) { hydrationBailed = true; - console.warn('Parent: ', elm); - console.warn('Mismatching childNodes vs. VNodes: ', elm.childNodes, children); + console.warn("Parent: ", elm); + console.warn( + "Mismatching childNodes vs. VNodes: ", + elm.childNodes, + children + ); } - return false + return false; } } } @@ -6430,35 +6728,39 @@ if (!isRenderedModule(key)) { fullInvoke = true; invokeCreateHooks(vnode, insertedVnodeQueue); - break + break; } } - if (!fullInvoke && data['class']) { + if (!fullInvoke && data["class"]) { // ensure collecting deps for deep class bindings for future updates - traverse(data['class']); + traverse(data["class"]); } } } else if (elm.data !== vnode.text) { elm.data = vnode.text; } - return true + return true; } - function assertNodeMatch (node, vnode, inVPre) { + function assertNodeMatch(node, vnode, inVPre) { if (isDef(vnode.tag)) { - return vnode.tag.indexOf('vue-component') === 0 || ( - !isUnknownElement$$1(vnode, inVPre) && - vnode.tag.toLowerCase() === (node.tagName && node.tagName.toLowerCase()) - ) + return ( + vnode.tag.indexOf("vue-component") === 0 || + (!isUnknownElement$$1(vnode, inVPre) && + vnode.tag.toLowerCase() === + (node.tagName && node.tagName.toLowerCase())) + ); } else { - return node.nodeType === (vnode.isComment ? 8 : 3) + return node.nodeType === (vnode.isComment ? 8 : 3); } } - return function patch (oldVnode, vnode, hydrating, removeOnly) { + return function patch(oldVnode, vnode, hydrating, removeOnly) { if (isUndef(vnode)) { - if (isDef(oldVnode)) { invokeDestroyHook(oldVnode); } - return + if (isDef(oldVnode)) { + invokeDestroyHook(oldVnode); + } + return; } var isInitialPatch = false; @@ -6472,7 +6774,14 @@ var isRealElement = isDef(oldVnode.nodeType); if (!isRealElement && sameVnode(oldVnode, vnode)) { // patch existing root node - patchVnode(oldVnode, vnode, insertedVnodeQueue, null, null, removeOnly); + patchVnode( + oldVnode, + vnode, + insertedVnodeQueue, + null, + null, + removeOnly + ); } else { if (isRealElement) { // mounting to a real element @@ -6485,14 +6794,14 @@ if (isTrue(hydrating)) { if (hydrate(oldVnode, vnode, insertedVnodeQueue)) { invokeInsertHook(vnode, insertedVnodeQueue, true); - return oldVnode + return oldVnode; } else { warn( - 'The client-side rendered virtual DOM tree is not matching ' + - 'server-rendered content. This is likely caused by incorrect ' + - 'HTML markup, for example nesting block-level elements inside ' + - '<p>, or missing <tbody>. Bailing hydration and performing ' + - 'full client-side render.' + "The client-side rendered virtual DOM tree is not matching " + + "server-rendered content. This is likely caused by incorrect " + + "HTML markup, for example nesting block-level elements inside " + + "<p>, or missing <tbody>. Bailing hydration and performing " + + "full client-side render." ); } } @@ -6556,8 +6865,8 @@ } invokeInsertHook(vnode, insertedVnodeQueue, isInitialPatch); - return vnode.elm - } + return vnode.elm; + }; } /* */ @@ -6565,21 +6874,24 @@ var directives = { create: updateDirectives, update: updateDirectives, - destroy: function unbindDirectives (vnode) { + destroy: function unbindDirectives(vnode) { updateDirectives(vnode, emptyNode); - } + }, }; - function updateDirectives (oldVnode, vnode) { + function updateDirectives(oldVnode, vnode) { if (oldVnode.data.directives || vnode.data.directives) { _update(oldVnode, vnode); } } - function _update (oldVnode, vnode) { + function _update(oldVnode, vnode) { var isCreate = oldVnode === emptyNode; var isDestroy = vnode === emptyNode; - var oldDirs = normalizeDirectives$1(oldVnode.data.directives, oldVnode.context); + var oldDirs = normalizeDirectives$1( + oldVnode.data.directives, + oldVnode.context + ); var newDirs = normalizeDirectives$1(vnode.data.directives, vnode.context); var dirsWithInsert = []; @@ -6591,7 +6903,7 @@ dir = newDirs[key]; if (!oldDir) { // new directive, bind - callHook$1(dir, 'bind', vnode, oldVnode); + callHook$1(dir, "bind", vnode, oldVnode); if (dir.def && dir.def.inserted) { dirsWithInsert.push(dir); } @@ -6599,7 +6911,7 @@ // existing directive, update dir.oldValue = oldDir.value; dir.oldArg = oldDir.arg; - callHook$1(dir, 'update', vnode, oldVnode); + callHook$1(dir, "update", vnode, oldVnode); if (dir.def && dir.def.componentUpdated) { dirsWithPostpatch.push(dir); } @@ -6609,20 +6921,20 @@ if (dirsWithInsert.length) { var callInsert = function () { for (var i = 0; i < dirsWithInsert.length; i++) { - callHook$1(dirsWithInsert[i], 'inserted', vnode, oldVnode); + callHook$1(dirsWithInsert[i], "inserted", vnode, oldVnode); } }; if (isCreate) { - mergeVNodeHook(vnode, 'insert', callInsert); + mergeVNodeHook(vnode, "insert", callInsert); } else { callInsert(); } } if (dirsWithPostpatch.length) { - mergeVNodeHook(vnode, 'postpatch', function () { + mergeVNodeHook(vnode, "postpatch", function () { for (var i = 0; i < dirsWithPostpatch.length; i++) { - callHook$1(dirsWithPostpatch[i], 'componentUpdated', vnode, oldVnode); + callHook$1(dirsWithPostpatch[i], "componentUpdated", vnode, oldVnode); } }); } @@ -6631,7 +6943,7 @@ for (key in oldDirs) { if (!newDirs[key]) { // no longer present, unbind - callHook$1(oldDirs[key], 'unbind', oldVnode, oldVnode, isDestroy); + callHook$1(oldDirs[key], "unbind", oldVnode, oldVnode, isDestroy); } } } @@ -6639,14 +6951,11 @@ var emptyModifiers = Object.create(null); - function normalizeDirectives$1 ( - dirs, - vm - ) { + function normalizeDirectives$1(dirs, vm) { var res = Object.create(null); if (!dirs) { // $flow-disable-line - return res + return res; } var i, dir; for (i = 0; i < dirs.length; i++) { @@ -6656,41 +6965,44 @@ dir.modifiers = emptyModifiers; } res[getRawDirName(dir)] = dir; - dir.def = resolveAsset(vm.$options, 'directives', dir.name, true); + dir.def = resolveAsset(vm.$options, "directives", dir.name, true); } // $flow-disable-line - return res + return res; } - function getRawDirName (dir) { - return dir.rawName || ((dir.name) + "." + (Object.keys(dir.modifiers || {}).join('.'))) + function getRawDirName(dir) { + return ( + dir.rawName || dir.name + "." + Object.keys(dir.modifiers || {}).join(".") + ); } - function callHook$1 (dir, hook, vnode, oldVnode, isDestroy) { + function callHook$1(dir, hook, vnode, oldVnode, isDestroy) { var fn = dir.def && dir.def[hook]; if (fn) { try { fn(vnode.elm, dir, vnode, oldVnode, isDestroy); } catch (e) { - handleError(e, vnode.context, ("directive " + (dir.name) + " " + hook + " hook")); + handleError( + e, + vnode.context, + "directive " + dir.name + " " + hook + " hook" + ); } } } - var baseModules = [ - ref, - directives - ]; + var baseModules = [ref, directives]; /* */ - function updateAttrs (oldVnode, vnode) { + function updateAttrs(oldVnode, vnode) { var opts = vnode.componentOptions; if (isDef(opts) && opts.Ctor.options.inheritAttrs === false) { - return + return; } if (isUndef(oldVnode.data.attrs) && isUndef(vnode.data.attrs)) { - return + return; } var key, cur, old; var elm = vnode.elm; @@ -6712,7 +7024,7 @@ // #6666: IE/Edge forces progress value down to 1 before setting a max /* istanbul ignore if */ if ((isIE || isEdge) && attrs.value !== oldAttrs.value) { - setAttr(elm, 'value', attrs.value); + setAttr(elm, "value", attrs.value); } for (key in oldAttrs) { if (isUndef(attrs[key])) { @@ -6725,8 +7037,8 @@ } } - function setAttr (el, key, value) { - if (el.tagName.indexOf('-') > -1) { + function setAttr(el, key, value) { + if (el.tagName.indexOf("-") > -1) { baseSetAttr(el, key, value); } else if (isBooleanAttr(key)) { // set attribute for blank value @@ -6736,9 +7048,8 @@ } else { // technically allowfullscreen is a boolean attribute for <iframe>, // but Flash expects a value of "true" when used on <embed> tag - value = key === 'allowfullscreen' && el.tagName === 'EMBED' - ? 'true' - : key; + value = + key === "allowfullscreen" && el.tagName === "EMBED" ? "true" : key; el.setAttribute(key, value); } } else if (isEnumeratedAttr(key)) { @@ -6754,7 +7065,7 @@ } } - function baseSetAttr (el, key, value) { + function baseSetAttr(el, key, value) { if (isFalsyAttrValue(value)) { el.removeAttribute(key); } else { @@ -6763,15 +7074,18 @@ // immediately. /* istanbul ignore if */ if ( - isIE && !isIE9 && - el.tagName === 'TEXTAREA' && - key === 'placeholder' && value !== '' && !el.__ieph + isIE && + !isIE9 && + el.tagName === "TEXTAREA" && + key === "placeholder" && + value !== "" && + !el.__ieph ) { var blocker = function (e) { e.stopImmediatePropagation(); - el.removeEventListener('input', blocker); + el.removeEventListener("input", blocker); }; - el.addEventListener('input', blocker); + el.addEventListener("input", blocker); // $flow-disable-line el.__ieph = true; /* IE placeholder patched */ } @@ -6781,25 +7095,22 @@ var attrs = { create: updateAttrs, - update: updateAttrs + update: updateAttrs, }; /* */ - function updateClass (oldVnode, vnode) { + function updateClass(oldVnode, vnode) { var el = vnode.elm; var data = vnode.data; var oldData = oldVnode.data; if ( isUndef(data.staticClass) && - isUndef(data.class) && ( - isUndef(oldData) || ( - isUndef(oldData.staticClass) && - isUndef(oldData.class) - ) - ) + isUndef(data.class) && + (isUndef(oldData) || + (isUndef(oldData.staticClass) && isUndef(oldData.class))) ) { - return + return; } var cls = genClassForVnode(vnode); @@ -6812,21 +7123,21 @@ // set the class if (cls !== el._prevClass) { - el.setAttribute('class', cls); + el.setAttribute("class", cls); el._prevClass = cls; } } var klass = { create: updateClass, - update: updateClass + update: updateClass, }; /* */ var validDivisionCharRE = /[\w).+\-_$\]]/; - function parseFilters (exp) { + function parseFilters(exp) { var inSingle = false; var inDouble = false; var inTemplateString = false; @@ -6841,18 +7152,28 @@ prev = c; c = exp.charCodeAt(i); if (inSingle) { - if (c === 0x27 && prev !== 0x5C) { inSingle = false; } + if (c === 0x27 && prev !== 0x5c) { + inSingle = false; + } } else if (inDouble) { - if (c === 0x22 && prev !== 0x5C) { inDouble = false; } + if (c === 0x22 && prev !== 0x5c) { + inDouble = false; + } } else if (inTemplateString) { - if (c === 0x60 && prev !== 0x5C) { inTemplateString = false; } + if (c === 0x60 && prev !== 0x5c) { + inTemplateString = false; + } } else if (inRegex) { - if (c === 0x2f && prev !== 0x5C) { inRegex = false; } + if (c === 0x2f && prev !== 0x5c) { + inRegex = false; + } } else if ( - c === 0x7C && // pipe - exp.charCodeAt(i + 1) !== 0x7C && - exp.charCodeAt(i - 1) !== 0x7C && - !curly && !square && !paren + c === 0x7c && // pipe + exp.charCodeAt(i + 1) !== 0x7c && + exp.charCodeAt(i - 1) !== 0x7c && + !curly && + !square && + !paren ) { if (expression === undefined) { // first filter, end of expression @@ -6863,23 +7184,44 @@ } } else { switch (c) { - case 0x22: inDouble = true; break // " - case 0x27: inSingle = true; break // ' - case 0x60: inTemplateString = true; break // ` - case 0x28: paren++; break // ( - case 0x29: paren--; break // ) - case 0x5B: square++; break // [ - case 0x5D: square--; break // ] - case 0x7B: curly++; break // { - case 0x7D: curly--; break // } - } - if (c === 0x2f) { // / + case 0x22: + inDouble = true; + break; // " + case 0x27: + inSingle = true; + break; // ' + case 0x60: + inTemplateString = true; + break; // ` + case 0x28: + paren++; + break; // ( + case 0x29: + paren--; + break; // ) + case 0x5b: + square++; + break; // [ + case 0x5d: + square--; + break; // ] + case 0x7b: + curly++; + break; // { + case 0x7d: + curly--; + break; // } + } + if (c === 0x2f) { + // / var j = i - 1; - var p = (void 0); + var p = void 0; // find first non-whitespace prev char for (; j >= 0; j--) { p = exp.charAt(j); - if (p !== ' ') { break } + if (p !== " ") { + break; + } } if (!p || !validDivisionCharRE.test(p)) { inRegex = true; @@ -6894,7 +7236,7 @@ pushFilter(); } - function pushFilter () { + function pushFilter() { (filters || (filters = [])).push(exp.slice(lastFilterIndex, i).trim()); lastFilterIndex = i + 1; } @@ -6905,60 +7247,65 @@ } } - return expression + return expression; } - function wrapFilter (exp, filter) { - var i = filter.indexOf('('); + function wrapFilter(exp, filter) { + var i = filter.indexOf("("); if (i < 0) { // _f: resolveFilter - return ("_f(\"" + filter + "\")(" + exp + ")") + return '_f("' + filter + '")(' + exp + ")"; } else { var name = filter.slice(0, i); var args = filter.slice(i + 1); - return ("_f(\"" + name + "\")(" + exp + (args !== ')' ? ',' + args : args)) + return '_f("' + name + '")(' + exp + (args !== ")" ? "," + args : args); } } /* */ - - /* eslint-disable no-unused-vars */ - function baseWarn (msg, range) { - console.error(("[Vue compiler]: " + msg)); + function baseWarn(msg, range) { + console.error("[Vue compiler]: " + msg); } /* eslint-enable no-unused-vars */ - function pluckModuleFunction ( - modules, - key - ) { + function pluckModuleFunction(modules, key) { return modules - ? modules.map(function (m) { return m[key]; }).filter(function (_) { return _; }) - : [] + ? modules + .map(function (m) { + return m[key]; + }) + .filter(function (_) { + return _; + }) + : []; } - function addProp (el, name, value, range, dynamic) { - (el.props || (el.props = [])).push(rangeSetItem({ name: name, value: value, dynamic: dynamic }, range)); + function addProp(el, name, value, range, dynamic) { + (el.props || (el.props = [])).push( + rangeSetItem({ name: name, value: value, dynamic: dynamic }, range) + ); el.plain = false; } - function addAttr (el, name, value, range, dynamic) { + function addAttr(el, name, value, range, dynamic) { var attrs = dynamic - ? (el.dynamicAttrs || (el.dynamicAttrs = [])) - : (el.attrs || (el.attrs = [])); - attrs.push(rangeSetItem({ name: name, value: value, dynamic: dynamic }, range)); + ? el.dynamicAttrs || (el.dynamicAttrs = []) + : el.attrs || (el.attrs = []); + attrs.push( + rangeSetItem({ name: name, value: value, dynamic: dynamic }, range) + ); el.plain = false; } // add a raw attr (use this in preTransforms) - function addRawAttr (el, name, value, range) { + function addRawAttr(el, name, value, range) { el.attrsMap[name] = value; el.attrsList.push(rangeSetItem({ name: name, value: value }, range)); } - function addDirective ( + function addDirective( el, name, rawName, @@ -6968,24 +7315,27 @@ modifiers, range ) { - (el.directives || (el.directives = [])).push(rangeSetItem({ - name: name, - rawName: rawName, - value: value, - arg: arg, - isDynamicArg: isDynamicArg, - modifiers: modifiers - }, range)); + (el.directives || (el.directives = [])).push( + rangeSetItem( + { + name: name, + rawName: rawName, + value: value, + arg: arg, + isDynamicArg: isDynamicArg, + modifiers: modifiers, + }, + range + ) + ); el.plain = false; } - function prependModifierMarker (symbol, name, dynamic) { - return dynamic - ? ("_p(" + name + ",\"" + symbol + "\")") - : symbol + name // mark the event as captured + function prependModifierMarker(symbol, name, dynamic) { + return dynamic ? "_p(" + name + ',"' + symbol + '")' : symbol + name; // mark the event as captured } - function addHandler ( + function addHandler( el, name, value, @@ -6998,13 +7348,10 @@ modifiers = modifiers || emptyObject; // warn prevent and passive modifier /* istanbul ignore if */ - if ( - warn && - modifiers.prevent && modifiers.passive - ) { + if (warn && modifiers.prevent && modifiers.passive) { warn( - 'passive and prevent can\'t be used together. ' + - 'Passive handler can\'t prevent default event.', + "passive and prevent can't be used together. " + + "Passive handler can't prevent default event.", range ); } @@ -7015,31 +7362,31 @@ if (modifiers.right) { if (dynamic) { name = "(" + name + ")==='click'?'contextmenu':(" + name + ")"; - } else if (name === 'click') { - name = 'contextmenu'; + } else if (name === "click") { + name = "contextmenu"; delete modifiers.right; } } else if (modifiers.middle) { if (dynamic) { name = "(" + name + ")==='click'?'mouseup':(" + name + ")"; - } else if (name === 'click') { - name = 'mouseup'; + } else if (name === "click") { + name = "mouseup"; } } // check capture modifier if (modifiers.capture) { delete modifiers.capture; - name = prependModifierMarker('!', name, dynamic); + name = prependModifierMarker("!", name, dynamic); } if (modifiers.once) { delete modifiers.once; - name = prependModifierMarker('~', name, dynamic); + name = prependModifierMarker("~", name, dynamic); } /* istanbul ignore if */ if (modifiers.passive) { delete modifiers.passive; - name = prependModifierMarker('&', name, dynamic); + name = prependModifierMarker("&", name, dynamic); } var events; @@ -7050,7 +7397,10 @@ events = el.events || (el.events = {}); } - var newHandler = rangeSetItem({ value: value.trim(), dynamic: dynamic }, range); + var newHandler = rangeSetItem( + { value: value.trim(), dynamic: dynamic }, + range + ); if (modifiers !== emptyObject) { newHandler.modifiers = modifiers; } @@ -7060,7 +7410,9 @@ if (Array.isArray(handlers)) { important ? handlers.unshift(newHandler) : handlers.push(newHandler); } else if (handlers) { - events[name] = important ? [newHandler, handlers] : [handlers, newHandler]; + events[name] = important + ? [newHandler, handlers] + : [handlers, newHandler]; } else { events[name] = newHandler; } @@ -7068,29 +7420,24 @@ el.plain = false; } - function getRawBindingAttr ( - el, - name - ) { - return el.rawAttrsMap[':' + name] || - el.rawAttrsMap['v-bind:' + name] || + function getRawBindingAttr(el, name) { + return ( + el.rawAttrsMap[":" + name] || + el.rawAttrsMap["v-bind:" + name] || el.rawAttrsMap[name] + ); } - function getBindingAttr ( - el, - name, - getStatic - ) { + function getBindingAttr(el, name, getStatic) { var dynamicValue = - getAndRemoveAttr(el, ':' + name) || - getAndRemoveAttr(el, 'v-bind:' + name); + getAndRemoveAttr(el, ":" + name) || + getAndRemoveAttr(el, "v-bind:" + name); if (dynamicValue != null) { - return parseFilters(dynamicValue) + return parseFilters(dynamicValue); } else if (getStatic !== false) { var staticValue = getAndRemoveAttr(el, name); if (staticValue != null) { - return JSON.stringify(staticValue) + return JSON.stringify(staticValue); } } } @@ -7099,45 +7446,35 @@ // doesn't get processed by processAttrs. // By default it does NOT remove it from the map (attrsMap) because the map is // needed during codegen. - function getAndRemoveAttr ( - el, - name, - removeFromMap - ) { + function getAndRemoveAttr(el, name, removeFromMap) { var val; if ((val = el.attrsMap[name]) != null) { var list = el.attrsList; for (var i = 0, l = list.length; i < l; i++) { if (list[i].name === name) { list.splice(i, 1); - break + break; } } } if (removeFromMap) { delete el.attrsMap[name]; } - return val + return val; } - function getAndRemoveAttrByRegex ( - el, - name - ) { + function getAndRemoveAttrByRegex(el, name) { var list = el.attrsList; for (var i = 0, l = list.length; i < l; i++) { var attr = list[i]; if (name.test(attr.name)) { list.splice(i, 1); - return attr + return attr; } } } - function rangeSetItem ( - item, - range - ) { + function rangeSetItem(item, range) { if (range) { if (range.start != null) { item.start = range.start; @@ -7146,7 +7483,7 @@ item.end = range.end; } } - return item + return item; } /* */ @@ -7154,22 +7491,24 @@ /** * Cross-platform code generation for component v-model */ - function genComponentModel ( - el, - value, - modifiers - ) { + function genComponentModel(el, value, modifiers) { var ref = modifiers || {}; var number = ref.number; var trim = ref.trim; - var baseValueExpression = '$$v'; + var baseValueExpression = "$$v"; var valueExpression = baseValueExpression; if (trim) { valueExpression = - "(typeof " + baseValueExpression + " === 'string'" + - "? " + baseValueExpression + ".trim()" + - ": " + baseValueExpression + ")"; + "(typeof " + + baseValueExpression + + " === 'string'" + + "? " + + baseValueExpression + + ".trim()" + + ": " + + baseValueExpression + + ")"; } if (number) { valueExpression = "_n(" + valueExpression + ")"; @@ -7177,24 +7516,21 @@ var assignment = genAssignmentCode(value, valueExpression); el.model = { - value: ("(" + value + ")"), + value: "(" + value + ")", expression: JSON.stringify(value), - callback: ("function (" + baseValueExpression + ") {" + assignment + "}") + callback: "function (" + baseValueExpression + ") {" + assignment + "}", }; } /** * Cross-platform codegen helper for generating v-model value assignment code. */ - function genAssignmentCode ( - value, - assignment - ) { + function genAssignmentCode(value, assignment) { var res = parseModel(value); if (res.key === null) { - return (value + "=" + assignment) + return value + "=" + assignment; } else { - return ("$set(" + (res.exp) + ", " + (res.key) + ", " + assignment + ")") + return "$set(" + res.exp + ", " + res.key + ", " + assignment + ")"; } } @@ -7215,26 +7551,24 @@ var len, str, chr, index$1, expressionPos, expressionEndPos; - - - function parseModel (val) { + function parseModel(val) { // Fix https://github.com/vuejs/vue/pull/7730 // allow v-model="obj.val " (trailing whitespace) val = val.trim(); len = val.length; - if (val.indexOf('[') < 0 || val.lastIndexOf(']') < len - 1) { - index$1 = val.lastIndexOf('.'); + if (val.indexOf("[") < 0 || val.lastIndexOf("]") < len - 1) { + index$1 = val.lastIndexOf("."); if (index$1 > -1) { return { exp: val.slice(0, index$1), - key: '"' + val.slice(index$1 + 1) + '"' - } + key: '"' + val.slice(index$1 + 1) + '"', + }; } else { return { exp: val, - key: null - } + key: null, + }; } } @@ -7246,53 +7580,57 @@ /* istanbul ignore if */ if (isStringStart(chr)) { parseString(chr); - } else if (chr === 0x5B) { + } else if (chr === 0x5b) { parseBracket(chr); } } return { exp: val.slice(0, expressionPos), - key: val.slice(expressionPos + 1, expressionEndPos) - } + key: val.slice(expressionPos + 1, expressionEndPos), + }; } - function next () { - return str.charCodeAt(++index$1) + function next() { + return str.charCodeAt(++index$1); } - function eof () { - return index$1 >= len + function eof() { + return index$1 >= len; } - function isStringStart (chr) { - return chr === 0x22 || chr === 0x27 + function isStringStart(chr) { + return chr === 0x22 || chr === 0x27; } - function parseBracket (chr) { + function parseBracket(chr) { var inBracket = 1; expressionPos = index$1; while (!eof()) { chr = next(); if (isStringStart(chr)) { parseString(chr); - continue + continue; + } + if (chr === 0x5b) { + inBracket++; + } + if (chr === 0x5d) { + inBracket--; } - if (chr === 0x5B) { inBracket++; } - if (chr === 0x5D) { inBracket--; } if (inBracket === 0) { expressionEndPos = index$1; - break + break; } } } - function parseString (chr) { + function parseString(chr) { var stringQuote = chr; while (!eof()) { chr = next(); if (chr === stringQuote) { - break + break; } } } @@ -7303,14 +7641,10 @@ // in some cases, the event used has to be determined at runtime // so we used some reserved tokens during compile. - var RANGE_TOKEN = '__r'; - var CHECKBOX_RADIO_TOKEN = '__c'; + var RANGE_TOKEN = "__r"; + var CHECKBOX_RADIO_TOKEN = "__c"; - function model ( - el, - dir, - _warn - ) { + function model(el, dir, _warn) { warn$1 = _warn; var value = dir.value; var modifiers = dir.modifiers; @@ -7320,11 +7654,15 @@ { // inputs with type="file" are read only and setting the input's // value will throw an error. - if (tag === 'input' && type === 'file') { + if (tag === "input" && type === "file") { warn$1( - "<" + (el.tag) + " v-model=\"" + value + "\" type=\"file\">:\n" + - "File inputs are read only. Use a v-on:change listener instead.", - el.rawAttrsMap['v-model'] + "<" + + el.tag + + ' v-model="' + + value + + '" type="file">:\n' + + "File inputs are read only. Use a v-on:change listener instead.", + el.rawAttrsMap["v-model"] ); } } @@ -7332,110 +7670,135 @@ if (el.component) { genComponentModel(el, value, modifiers); // component v-model doesn't need extra runtime - return false - } else if (tag === 'select') { + return false; + } else if (tag === "select") { genSelect(el, value, modifiers); - } else if (tag === 'input' && type === 'checkbox') { + } else if (tag === "input" && type === "checkbox") { genCheckboxModel(el, value, modifiers); - } else if (tag === 'input' && type === 'radio') { + } else if (tag === "input" && type === "radio") { genRadioModel(el, value, modifiers); - } else if (tag === 'input' || tag === 'textarea') { + } else if (tag === "input" || tag === "textarea") { genDefaultModel(el, value, modifiers); } else if (!config.isReservedTag(tag)) { genComponentModel(el, value, modifiers); // component v-model doesn't need extra runtime - return false + return false; } else { warn$1( - "<" + (el.tag) + " v-model=\"" + value + "\">: " + - "v-model is not supported on this element type. " + - 'If you are working with contenteditable, it\'s recommended to ' + - 'wrap a library dedicated for that purpose inside a custom component.', - el.rawAttrsMap['v-model'] + "<" + + el.tag + + ' v-model="' + + value + + '">: ' + + "v-model is not supported on this element type. " + + "If you are working with contenteditable, it's recommended to " + + "wrap a library dedicated for that purpose inside a custom component.", + el.rawAttrsMap["v-model"] ); } // ensure runtime directive metadata - return true + return true; } - function genCheckboxModel ( - el, - value, - modifiers - ) { + function genCheckboxModel(el, value, modifiers) { var number = modifiers && modifiers.number; - var valueBinding = getBindingAttr(el, 'value') || 'null'; - var trueValueBinding = getBindingAttr(el, 'true-value') || 'true'; - var falseValueBinding = getBindingAttr(el, 'false-value') || 'false'; - addProp(el, 'checked', - "Array.isArray(" + value + ")" + - "?_i(" + value + "," + valueBinding + ")>-1" + ( - trueValueBinding === 'true' - ? (":(" + value + ")") - : (":_q(" + value + "," + trueValueBinding + ")") - ) + var valueBinding = getBindingAttr(el, "value") || "null"; + var trueValueBinding = getBindingAttr(el, "true-value") || "true"; + var falseValueBinding = getBindingAttr(el, "false-value") || "false"; + addProp( + el, + "checked", + "Array.isArray(" + + value + + ")" + + "?_i(" + + value + + "," + + valueBinding + + ")>-1" + + (trueValueBinding === "true" + ? ":(" + value + ")" + : ":_q(" + value + "," + trueValueBinding + ")") ); - addHandler(el, 'change', - "var $$a=" + value + "," + - '$$el=$event.target,' + - "$$c=$$el.checked?(" + trueValueBinding + "):(" + falseValueBinding + ");" + - 'if(Array.isArray($$a)){' + - "var $$v=" + (number ? '_n(' + valueBinding + ')' : valueBinding) + "," + - '$$i=_i($$a,$$v);' + - "if($$el.checked){$$i<0&&(" + (genAssignmentCode(value, '$$a.concat([$$v])')) + ")}" + - "else{$$i>-1&&(" + (genAssignmentCode(value, '$$a.slice(0,$$i).concat($$a.slice($$i+1))')) + ")}" + - "}else{" + (genAssignmentCode(value, '$$c')) + "}", - null, true + addHandler( + el, + "change", + "var $$a=" + + value + + "," + + "$$el=$event.target," + + "$$c=$$el.checked?(" + + trueValueBinding + + "):(" + + falseValueBinding + + ");" + + "if(Array.isArray($$a)){" + + "var $$v=" + + (number ? "_n(" + valueBinding + ")" : valueBinding) + + "," + + "$$i=_i($$a,$$v);" + + "if($$el.checked){$$i<0&&(" + + genAssignmentCode(value, "$$a.concat([$$v])") + + ")}" + + "else{$$i>-1&&(" + + genAssignmentCode(value, "$$a.slice(0,$$i).concat($$a.slice($$i+1))") + + ")}" + + "}else{" + + genAssignmentCode(value, "$$c") + + "}", + null, + true ); } - function genRadioModel ( - el, - value, - modifiers - ) { + function genRadioModel(el, value, modifiers) { var number = modifiers && modifiers.number; - var valueBinding = getBindingAttr(el, 'value') || 'null'; - valueBinding = number ? ("_n(" + valueBinding + ")") : valueBinding; - addProp(el, 'checked', ("_q(" + value + "," + valueBinding + ")")); - addHandler(el, 'change', genAssignmentCode(value, valueBinding), null, true); + var valueBinding = getBindingAttr(el, "value") || "null"; + valueBinding = number ? "_n(" + valueBinding + ")" : valueBinding; + addProp(el, "checked", "_q(" + value + "," + valueBinding + ")"); + addHandler( + el, + "change", + genAssignmentCode(value, valueBinding), + null, + true + ); } - function genSelect ( - el, - value, - modifiers - ) { + function genSelect(el, value, modifiers) { var number = modifiers && modifiers.number; - var selectedVal = "Array.prototype.filter" + + var selectedVal = + "Array.prototype.filter" + ".call($event.target.options,function(o){return o.selected})" + - ".map(function(o){var val = \"_value\" in o ? o._value : o.value;" + - "return " + (number ? '_n(val)' : 'val') + "})"; + '.map(function(o){var val = "_value" in o ? o._value : o.value;' + + "return " + + (number ? "_n(val)" : "val") + + "})"; - var assignment = '$event.target.multiple ? $$selectedVal : $$selectedVal[0]'; + var assignment = + "$event.target.multiple ? $$selectedVal : $$selectedVal[0]"; var code = "var $$selectedVal = " + selectedVal + ";"; - code = code + " " + (genAssignmentCode(value, assignment)); - addHandler(el, 'change', code, null, true); + code = code + " " + genAssignmentCode(value, assignment); + addHandler(el, "change", code, null, true); } - function genDefaultModel ( - el, - value, - modifiers - ) { + function genDefaultModel(el, value, modifiers) { var type = el.attrsMap.type; // warn if v-bind:value conflicts with v-model // except for inputs with v-bind:type { - var value$1 = el.attrsMap['v-bind:value'] || el.attrsMap[':value']; - var typeBinding = el.attrsMap['v-bind:type'] || el.attrsMap[':type']; + var value$1 = el.attrsMap["v-bind:value"] || el.attrsMap[":value"]; + var typeBinding = el.attrsMap["v-bind:type"] || el.attrsMap[":type"]; if (value$1 && !typeBinding) { - var binding = el.attrsMap['v-bind:value'] ? 'v-bind:value' : ':value'; + var binding = el.attrsMap["v-bind:value"] ? "v-bind:value" : ":value"; warn$1( - binding + "=\"" + value$1 + "\" conflicts with v-model on the same element " + - 'because the latter already expands to a value binding internally', + binding + + '="' + + value$1 + + '" conflicts with v-model on the same element ' + + "because the latter already expands to a value binding internally", el.rawAttrsMap[binding] ); } @@ -7445,14 +7808,10 @@ var lazy = ref.lazy; var number = ref.number; var trim = ref.trim; - var needCompositionGuard = !lazy && type !== 'range'; - var event = lazy - ? 'change' - : type === 'range' - ? RANGE_TOKEN - : 'input'; - - var valueExpression = '$event.target.value'; + var needCompositionGuard = !lazy && type !== "range"; + var event = lazy ? "change" : type === "range" ? RANGE_TOKEN : "input"; + + var valueExpression = "$event.target.value"; if (trim) { valueExpression = "$event.target.value.trim()"; } @@ -7465,10 +7824,10 @@ code = "if($event.target.composing)return;" + code; } - addProp(el, 'value', ("(" + value + ")")); + addProp(el, "value", "(" + value + ")"); addHandler(el, event, code, null, true); if (trim || number) { - addHandler(el, 'blur', '$forceUpdate()'); + addHandler(el, "blur", "$forceUpdate()"); } } @@ -7478,11 +7837,11 @@ // it's important to place the event as the first in the array because // the whole point is ensuring the v-model callback gets called before // user-attached handlers. - function normalizeEvents (on) { + function normalizeEvents(on) { /* istanbul ignore if */ if (isDef(on[RANGE_TOKEN])) { // IE input[type=range] only supports `change` event - var event = isIE ? 'change' : 'input'; + var event = isIE ? "change" : "input"; on[event] = [].concat(on[RANGE_TOKEN], on[event] || []); delete on[RANGE_TOKEN]; } @@ -7497,14 +7856,14 @@ var target$1; - function createOnceHandler$1 (event, handler, capture) { + function createOnceHandler$1(event, handler, capture) { var _target = target$1; // save current target element in closure - return function onceHandler () { + return function onceHandler() { var res = handler.apply(null, arguments); if (res !== null) { remove$2(event, onceHandler, capture, _target); } - } + }; } // #9446: Firefox <= 53 (in particular, ESR 52) has incorrect Event.timeStamp @@ -7512,12 +7871,7 @@ // safe to exclude. var useMicrotaskFix = isUsingMicroTask && !(isFF && Number(isFF[1]) <= 53); - function add$1 ( - name, - handler, - capture, - passive - ) { + function add$1(name, handler, capture, passive) { // async edge case #6566: inner click event triggers patch, event handler // attached to outer element during patch, and triggered again. This // happens because browsers fire microtask ticks between event propagation. @@ -7544,25 +7898,18 @@ // starting reference e.target.ownerDocument !== document ) { - return original.apply(this, arguments) + return original.apply(this, arguments); } }; } target$1.addEventListener( name, handler, - supportsPassive - ? { capture: capture, passive: passive } - : capture + supportsPassive ? { capture: capture, passive: passive } : capture ); } - function remove$2 ( - name, - handler, - capture, - _target - ) { + function remove$2(name, handler, capture, _target) { (_target || target$1).removeEventListener( name, handler._wrapper || handler, @@ -7570,30 +7917,37 @@ ); } - function updateDOMListeners (oldVnode, vnode) { + function updateDOMListeners(oldVnode, vnode) { if (isUndef(oldVnode.data.on) && isUndef(vnode.data.on)) { - return + return; } var on = vnode.data.on || {}; var oldOn = oldVnode.data.on || {}; target$1 = vnode.elm; normalizeEvents(on); - updateListeners(on, oldOn, add$1, remove$2, createOnceHandler$1, vnode.context); + updateListeners( + on, + oldOn, + add$1, + remove$2, + createOnceHandler$1, + vnode.context + ); target$1 = undefined; } var events = { create: updateDOMListeners, - update: updateDOMListeners + update: updateDOMListeners, }; /* */ var svgContainer; - function updateDOMProps (oldVnode, vnode) { + function updateDOMProps(oldVnode, vnode) { if (isUndef(oldVnode.data.domProps) && isUndef(vnode.data.domProps)) { - return + return; } var key, cur; var elm = vnode.elm; @@ -7606,7 +7960,7 @@ for (key in oldProps) { if (!(key in props)) { - elm[key] = ''; + elm[key] = ""; } } @@ -7615,9 +7969,13 @@ // ignore children if the node has textContent or innerHTML, // as these will throw away existing DOM nodes and cause removal errors // on subsequent patches (#3360) - if (key === 'textContent' || key === 'innerHTML') { - if (vnode.children) { vnode.children.length = 0; } - if (cur === oldProps[key]) { continue } + if (key === "textContent" || key === "innerHTML") { + if (vnode.children) { + vnode.children.length = 0; + } + if (cur === oldProps[key]) { + continue; + } // #6601 work around Chrome version <= 55 bug where single textNode // replaced by innerHTML/textContent retains its parentNode property if (elm.childNodes.length === 1) { @@ -7625,18 +7983,22 @@ } } - if (key === 'value' && elm.tagName !== 'PROGRESS') { + if (key === "value" && elm.tagName !== "PROGRESS") { // store value as _value as well since // non-string values will be stringified elm._value = cur; // avoid resetting cursor position when value is the same - var strCur = isUndef(cur) ? '' : String(cur); + var strCur = isUndef(cur) ? "" : String(cur); if (shouldUpdateValue(elm, strCur)) { elm.value = strCur; } - } else if (key === 'innerHTML' && isSVG(elm.tagName) && isUndef(elm.innerHTML)) { + } else if ( + key === "innerHTML" && + isSVG(elm.tagName) && + isUndef(elm.innerHTML) + ) { // IE doesn't support innerHTML for SVG elements - svgContainer = svgContainer || document.createElement('div'); + svgContainer = svgContainer || document.createElement("div"); svgContainer.innerHTML = "<svg>" + cur + "</svg>"; var svg = svgContainer.firstChild; while (elm.firstChild) { @@ -7663,42 +8025,44 @@ // check platforms/web/util/attrs.js acceptValue + function shouldUpdateValue(elm, checkVal) { + return ( + !elm.composing && + (elm.tagName === "OPTION" || + isNotInFocusAndDirty(elm, checkVal) || + isDirtyWithModifiers(elm, checkVal)) + ); + } - function shouldUpdateValue (elm, checkVal) { - return (!elm.composing && ( - elm.tagName === 'OPTION' || - isNotInFocusAndDirty(elm, checkVal) || - isDirtyWithModifiers(elm, checkVal) - )) - } - - function isNotInFocusAndDirty (elm, checkVal) { + function isNotInFocusAndDirty(elm, checkVal) { // return true when textbox (.number and .trim) loses focus and its value is // not equal to the updated value var notInFocus = true; // #6157 // work around IE bug when accessing document.activeElement in an iframe - try { notInFocus = document.activeElement !== elm; } catch (e) {} - return notInFocus && elm.value !== checkVal + try { + notInFocus = document.activeElement !== elm; + } catch (e) {} + return notInFocus && elm.value !== checkVal; } - function isDirtyWithModifiers (elm, newVal) { + function isDirtyWithModifiers(elm, newVal) { var value = elm.value; var modifiers = elm._vModifiers; // injected by v-model runtime if (isDef(modifiers)) { if (modifiers.number) { - return toNumber(value) !== toNumber(newVal) + return toNumber(value) !== toNumber(newVal); } if (modifiers.trim) { - return value.trim() !== newVal.trim() + return value.trim() !== newVal.trim(); } } - return value !== newVal + return value !== newVal; } var domProps = { create: updateDOMProps, - update: updateDOMProps + update: updateDOMProps, }; /* */ @@ -7713,35 +8077,33 @@ tmp.length > 1 && (res[tmp[0].trim()] = tmp[1].trim()); } }); - return res + return res; }); // merge static and dynamic style data on the same vnode - function normalizeStyleData (data) { + function normalizeStyleData(data) { var style = normalizeStyleBinding(data.style); // static style is pre-processed into an object during compilation // and is always a fresh object, so it's safe to merge into it - return data.staticStyle - ? extend(data.staticStyle, style) - : style + return data.staticStyle ? extend(data.staticStyle, style) : style; } // normalize possible array / string values into Object - function normalizeStyleBinding (bindingStyle) { + function normalizeStyleBinding(bindingStyle) { if (Array.isArray(bindingStyle)) { - return toObject(bindingStyle) + return toObject(bindingStyle); } - if (typeof bindingStyle === 'string') { - return parseStyleText(bindingStyle) + if (typeof bindingStyle === "string") { + return parseStyleText(bindingStyle); } - return bindingStyle + return bindingStyle; } /** * parent component style should be after child's * so that parent component's style could override it */ - function getStyle (vnode, checkChild) { + function getStyle(vnode, checkChild) { var res = {}; var styleData; @@ -7750,7 +8112,8 @@ while (childNode.componentInstance) { childNode = childNode.componentInstance._vnode; if ( - childNode && childNode.data && + childNode && + childNode.data && (styleData = normalizeStyleData(childNode.data)) ) { extend(res, styleData); @@ -7764,11 +8127,14 @@ var parentNode = vnode; while ((parentNode = parentNode.parent)) { - if (parentNode.data && (styleData = normalizeStyleData(parentNode.data))) { + if ( + parentNode.data && + (styleData = normalizeStyleData(parentNode.data)) + ) { extend(res, styleData); } } - return res + return res; } /* */ @@ -7780,7 +8146,11 @@ if (cssVarRE.test(name)) { el.style.setProperty(name, val); } else if (importantRE.test(val)) { - el.style.setProperty(hyphenate(name), val.replace(importantRE, ''), 'important'); + el.style.setProperty( + hyphenate(name), + val.replace(importantRE, ""), + "important" + ); } else { var normalizedName = normalize(name); if (Array.isArray(val)) { @@ -7796,32 +8166,35 @@ } }; - var vendorNames = ['Webkit', 'Moz', 'ms']; + var vendorNames = ["Webkit", "Moz", "ms"]; var emptyStyle; var normalize = cached(function (prop) { - emptyStyle = emptyStyle || document.createElement('div').style; + emptyStyle = emptyStyle || document.createElement("div").style; prop = camelize(prop); - if (prop !== 'filter' && (prop in emptyStyle)) { - return prop + if (prop !== "filter" && prop in emptyStyle) { + return prop; } var capName = prop.charAt(0).toUpperCase() + prop.slice(1); for (var i = 0; i < vendorNames.length; i++) { var name = vendorNames[i] + capName; if (name in emptyStyle) { - return name + return name; } } }); - function updateStyle (oldVnode, vnode) { + function updateStyle(oldVnode, vnode) { var data = vnode.data; var oldData = oldVnode.data; - if (isUndef(data.staticStyle) && isUndef(data.style) && - isUndef(oldData.staticStyle) && isUndef(oldData.style) + if ( + isUndef(data.staticStyle) && + isUndef(data.style) && + isUndef(oldData.staticStyle) && + isUndef(oldData.style) ) { - return + return; } var cur, name; @@ -7845,21 +8218,21 @@ for (name in oldStyle) { if (isUndef(newStyle[name])) { - setProp(el, name, ''); + setProp(el, name, ""); } } for (name in newStyle) { cur = newStyle[name]; if (cur !== oldStyle[name]) { // ie9 setting to null has no effect, must use empty string - setProp(el, name, cur == null ? '' : cur); + setProp(el, name, cur == null ? "" : cur); } } } var style = { create: updateStyle, - update: updateStyle + update: updateStyle, }; /* */ @@ -7870,23 +8243,25 @@ * Add class with compatibility for SVG since classList is not supported on * SVG elements in IE */ - function addClass (el, cls) { + function addClass(el, cls) { /* istanbul ignore if */ if (!cls || !(cls = cls.trim())) { - return + return; } /* istanbul ignore else */ if (el.classList) { - if (cls.indexOf(' ') > -1) { - cls.split(whitespaceRE).forEach(function (c) { return el.classList.add(c); }); + if (cls.indexOf(" ") > -1) { + cls.split(whitespaceRE).forEach(function (c) { + return el.classList.add(c); + }); } else { el.classList.add(cls); } } else { - var cur = " " + (el.getAttribute('class') || '') + " "; - if (cur.indexOf(' ' + cls + ' ') < 0) { - el.setAttribute('class', (cur + cls).trim()); + var cur = " " + (el.getAttribute("class") || "") + " "; + if (cur.indexOf(" " + cls + " ") < 0) { + el.setAttribute("class", (cur + cls).trim()); } } } @@ -7895,89 +8270,93 @@ * Remove class with compatibility for SVG since classList is not supported on * SVG elements in IE */ - function removeClass (el, cls) { + function removeClass(el, cls) { /* istanbul ignore if */ if (!cls || !(cls = cls.trim())) { - return + return; } /* istanbul ignore else */ if (el.classList) { - if (cls.indexOf(' ') > -1) { - cls.split(whitespaceRE).forEach(function (c) { return el.classList.remove(c); }); + if (cls.indexOf(" ") > -1) { + cls.split(whitespaceRE).forEach(function (c) { + return el.classList.remove(c); + }); } else { el.classList.remove(cls); } if (!el.classList.length) { - el.removeAttribute('class'); + el.removeAttribute("class"); } } else { - var cur = " " + (el.getAttribute('class') || '') + " "; - var tar = ' ' + cls + ' '; + var cur = " " + (el.getAttribute("class") || "") + " "; + var tar = " " + cls + " "; while (cur.indexOf(tar) >= 0) { - cur = cur.replace(tar, ' '); + cur = cur.replace(tar, " "); } cur = cur.trim(); if (cur) { - el.setAttribute('class', cur); + el.setAttribute("class", cur); } else { - el.removeAttribute('class'); + el.removeAttribute("class"); } } } /* */ - function resolveTransition (def$$1) { + function resolveTransition(def$$1) { if (!def$$1) { - return + return; } /* istanbul ignore else */ - if (typeof def$$1 === 'object') { + if (typeof def$$1 === "object") { var res = {}; if (def$$1.css !== false) { - extend(res, autoCssTransition(def$$1.name || 'v')); + extend(res, autoCssTransition(def$$1.name || "v")); } extend(res, def$$1); - return res - } else if (typeof def$$1 === 'string') { - return autoCssTransition(def$$1) + return res; + } else if (typeof def$$1 === "string") { + return autoCssTransition(def$$1); } } var autoCssTransition = cached(function (name) { return { - enterClass: (name + "-enter"), - enterToClass: (name + "-enter-to"), - enterActiveClass: (name + "-enter-active"), - leaveClass: (name + "-leave"), - leaveToClass: (name + "-leave-to"), - leaveActiveClass: (name + "-leave-active") - } + enterClass: name + "-enter", + enterToClass: name + "-enter-to", + enterActiveClass: name + "-enter-active", + leaveClass: name + "-leave", + leaveToClass: name + "-leave-to", + leaveActiveClass: name + "-leave-active", + }; }); var hasTransition = inBrowser && !isIE9; - var TRANSITION = 'transition'; - var ANIMATION = 'animation'; + var TRANSITION = "transition"; + var ANIMATION = "animation"; // Transition property/event sniffing - var transitionProp = 'transition'; - var transitionEndEvent = 'transitionend'; - var animationProp = 'animation'; - var animationEndEvent = 'animationend'; + var transitionProp = "transition"; + var transitionEndEvent = "transitionend"; + var animationProp = "animation"; + var animationEndEvent = "animationend"; if (hasTransition) { /* istanbul ignore if */ - if (window.ontransitionend === undefined && + if ( + window.ontransitionend === undefined && window.onwebkittransitionend !== undefined ) { - transitionProp = 'WebkitTransition'; - transitionEndEvent = 'webkitTransitionEnd'; + transitionProp = "WebkitTransition"; + transitionEndEvent = "webkitTransitionEnd"; } - if (window.onanimationend === undefined && + if ( + window.onanimationend === undefined && window.onwebkitanimationend !== undefined ) { - animationProp = 'WebkitAnimation'; - animationEndEvent = 'webkitAnimationEnd'; + animationProp = "WebkitAnimation"; + animationEndEvent = "webkitAnimationEnd"; } } @@ -7986,39 +8365,40 @@ ? window.requestAnimationFrame ? window.requestAnimationFrame.bind(window) : setTimeout - : /* istanbul ignore next */ function (fn) { return fn(); }; + : /* istanbul ignore next */ function (fn) { + return fn(); + }; - function nextFrame (fn) { + function nextFrame(fn) { raf(function () { raf(fn); }); } - function addTransitionClass (el, cls) { - var transitionClasses = el._transitionClasses || (el._transitionClasses = []); + function addTransitionClass(el, cls) { + var transitionClasses = + el._transitionClasses || (el._transitionClasses = []); if (transitionClasses.indexOf(cls) < 0) { transitionClasses.push(cls); addClass(el, cls); } } - function removeTransitionClass (el, cls) { + function removeTransitionClass(el, cls) { if (el._transitionClasses) { remove(el._transitionClasses, cls); } removeClass(el, cls); } - function whenTransitionEnds ( - el, - expectedType, - cb - ) { + function whenTransitionEnds(el, expectedType, cb) { var ref = getTransitionInfo(el, expectedType); var type = ref.type; var timeout = ref.timeout; var propCount = ref.propCount; - if (!type) { return cb() } + if (!type) { + return cb(); + } var event = type === TRANSITION ? transitionEndEvent : animationEndEvent; var ended = 0; var end = function () { @@ -8042,14 +8422,18 @@ var transformRE = /\b(transform|all)(,|$)/; - function getTransitionInfo (el, expectedType) { + function getTransitionInfo(el, expectedType) { var styles = window.getComputedStyle(el); // JSDOM may return undefined for transition properties - var transitionDelays = (styles[transitionProp + 'Delay'] || '').split(', '); - var transitionDurations = (styles[transitionProp + 'Duration'] || '').split(', '); + var transitionDelays = (styles[transitionProp + "Delay"] || "").split(", "); + var transitionDurations = (styles[transitionProp + "Duration"] || "").split( + ", " + ); var transitionTimeout = getTimeout(transitionDelays, transitionDurations); - var animationDelays = (styles[animationProp + 'Delay'] || '').split(', '); - var animationDurations = (styles[animationProp + 'Duration'] || '').split(', '); + var animationDelays = (styles[animationProp + "Delay"] || "").split(", "); + var animationDurations = (styles[animationProp + "Duration"] || "").split( + ", " + ); var animationTimeout = getTimeout(animationDelays, animationDurations); var type; @@ -8070,11 +8454,12 @@ } } else { timeout = Math.max(transitionTimeout, animationTimeout); - type = timeout > 0 - ? transitionTimeout > animationTimeout - ? TRANSITION - : ANIMATION - : null; + type = + timeout > 0 + ? transitionTimeout > animationTimeout + ? TRANSITION + : ANIMATION + : null; propCount = type ? type === TRANSITION ? transitionDurations.length @@ -8083,37 +8468,40 @@ } var hasTransform = type === TRANSITION && - transformRE.test(styles[transitionProp + 'Property']); + transformRE.test(styles[transitionProp + "Property"]); return { type: type, timeout: timeout, propCount: propCount, - hasTransform: hasTransform - } + hasTransform: hasTransform, + }; } - function getTimeout (delays, durations) { + function getTimeout(delays, durations) { /* istanbul ignore next */ while (delays.length < durations.length) { delays = delays.concat(delays); } - return Math.max.apply(null, durations.map(function (d, i) { - return toMs(d) + toMs(delays[i]) - })) + return Math.max.apply( + null, + durations.map(function (d, i) { + return toMs(d) + toMs(delays[i]); + }) + ); } // Old versions of Chromium (below 61.0.3163.100) formats floating pointer numbers // in a locale-dependent way, using a comma instead of a dot. // If comma is not replaced with a dot, the input will be rounded down (i.e. acting // as a floor function) causing unexpected behaviors - function toMs (s) { - return Number(s.slice(0, -1).replace(',', '.')) * 1000 + function toMs(s) { + return Number(s.slice(0, -1).replace(",", ".")) * 1000; } /* */ - function enter (vnode, toggleDisplay) { + function enter(vnode, toggleDisplay) { var el = vnode.elm; // call leave callback now @@ -8124,12 +8512,12 @@ var data = resolveTransition(vnode.data.transition); if (isUndef(data)) { - return + return; } /* istanbul ignore if */ if (isDef(el._enterCb) || el.nodeType !== 1) { - return + return; } var css = data.css; @@ -8163,47 +8551,38 @@ var isAppear = !context._isMounted || !vnode.isRootInsert; - if (isAppear && !appear && appear !== '') { - return + if (isAppear && !appear && appear !== "") { + return; } - var startClass = isAppear && appearClass - ? appearClass - : enterClass; - var activeClass = isAppear && appearActiveClass - ? appearActiveClass - : enterActiveClass; - var toClass = isAppear && appearToClass - ? appearToClass - : enterToClass; + var startClass = isAppear && appearClass ? appearClass : enterClass; + var activeClass = + isAppear && appearActiveClass ? appearActiveClass : enterActiveClass; + var toClass = isAppear && appearToClass ? appearToClass : enterToClass; - var beforeEnterHook = isAppear - ? (beforeAppear || beforeEnter) - : beforeEnter; + var beforeEnterHook = isAppear ? beforeAppear || beforeEnter : beforeEnter; var enterHook = isAppear - ? (typeof appear === 'function' ? appear : enter) + ? typeof appear === "function" + ? appear + : enter : enter; - var afterEnterHook = isAppear - ? (afterAppear || afterEnter) - : afterEnter; + var afterEnterHook = isAppear ? afterAppear || afterEnter : afterEnter; var enterCancelledHook = isAppear - ? (appearCancelled || enterCancelled) + ? appearCancelled || enterCancelled : enterCancelled; var explicitEnterDuration = toNumber( - isObject(duration) - ? duration.enter - : duration + isObject(duration) ? duration.enter : duration ); if (explicitEnterDuration != null) { - checkDuration(explicitEnterDuration, 'enter', vnode); + checkDuration(explicitEnterDuration, "enter", vnode); } var expectsCSS = css !== false && !isIE9; var userWantsControl = getHookArgumentsLength(enterHook); - var cb = el._enterCb = once(function () { + var cb = (el._enterCb = once(function () { if (expectsCSS) { removeTransitionClass(el, toClass); removeTransitionClass(el, activeClass); @@ -8217,14 +8596,16 @@ afterEnterHook && afterEnterHook(el); } el._enterCb = null; - }); + })); if (!vnode.data.show) { // remove pending leave element on enter by injecting an insert hook - mergeVNodeHook(vnode, 'insert', function () { + mergeVNodeHook(vnode, "insert", function () { var parent = el.parentNode; - var pendingNode = parent && parent._pending && parent._pending[vnode.key]; - if (pendingNode && + var pendingNode = + parent && parent._pending && parent._pending[vnode.key]; + if ( + pendingNode && pendingNode.tag === vnode.tag && pendingNode.elm._leaveCb ) { @@ -8264,7 +8645,7 @@ } } - function leave (vnode, rm) { + function leave(vnode, rm) { var el = vnode.elm; // call enter callback now @@ -8275,12 +8656,12 @@ var data = resolveTransition(vnode.data.transition); if (isUndef(data) || el.nodeType !== 1) { - return rm() + return rm(); } /* istanbul ignore if */ if (isDef(el._leaveCb)) { - return + return; } var css = data.css; @@ -8299,16 +8680,14 @@ var userWantsControl = getHookArgumentsLength(leave); var explicitLeaveDuration = toNumber( - isObject(duration) - ? duration.leave - : duration + isObject(duration) ? duration.leave : duration ); if (isDef(explicitLeaveDuration)) { - checkDuration(explicitLeaveDuration, 'leave', vnode); + checkDuration(explicitLeaveDuration, "leave", vnode); } - var cb = el._leaveCb = once(function () { + var cb = (el._leaveCb = once(function () { if (el.parentNode && el.parentNode._pending) { el.parentNode._pending[vnode.key] = null; } @@ -8326,7 +8705,7 @@ afterLeave && afterLeave(el); } el._leaveCb = null; - }); + })); if (delayLeave) { delayLeave(performLeave); @@ -8334,14 +8713,15 @@ performLeave(); } - function performLeave () { + function performLeave() { // the delayed leave may have already been cancelled if (cb.cancelled) { - return + return; } // record leaving element if (!vnode.data.show && el.parentNode) { - (el.parentNode._pending || (el.parentNode._pending = {}))[(vnode.key)] = vnode; + (el.parentNode._pending || (el.parentNode._pending = {}))[vnode.key] = + vnode; } beforeLeave && beforeLeave(el); if (expectsCSS) { @@ -8369,24 +8749,30 @@ } // only used in dev mode - function checkDuration (val, name, vnode) { - if (typeof val !== 'number') { + function checkDuration(val, name, vnode) { + if (typeof val !== "number") { warn( - "<transition> explicit " + name + " duration is not a valid number - " + - "got " + (JSON.stringify(val)) + ".", + "<transition> explicit " + + name + + " duration is not a valid number - " + + "got " + + JSON.stringify(val) + + ".", vnode.context ); } else if (isNaN(val)) { warn( - "<transition> explicit " + name + " duration is NaN - " + - 'the duration expression might be incorrect.', + "<transition> explicit " + + name + + " duration is NaN - " + + "the duration expression might be incorrect.", vnode.context ); } } - function isValidDuration (val) { - return typeof val === 'number' && !isNaN(val) + function isValidDuration(val) { + return typeof val === "number" && !isNaN(val); } /** @@ -8395,50 +8781,43 @@ * - a wrapped component method (check ._length) * - a plain function (.length) */ - function getHookArgumentsLength (fn) { + function getHookArgumentsLength(fn) { if (isUndef(fn)) { - return false + return false; } var invokerFns = fn.fns; if (isDef(invokerFns)) { // invoker return getHookArgumentsLength( - Array.isArray(invokerFns) - ? invokerFns[0] - : invokerFns - ) + Array.isArray(invokerFns) ? invokerFns[0] : invokerFns + ); } else { - return (fn._length || fn.length) > 1 + return (fn._length || fn.length) > 1; } } - function _enter (_, vnode) { + function _enter(_, vnode) { if (vnode.data.show !== true) { enter(vnode); } } - var transition = inBrowser ? { - create: _enter, - activate: _enter, - remove: function remove$$1 (vnode, rm) { - /* istanbul ignore else */ - if (vnode.data.show !== true) { - leave(vnode, rm); - } else { - rm(); + var transition = inBrowser + ? { + create: _enter, + activate: _enter, + remove: function remove$$1(vnode, rm) { + /* istanbul ignore else */ + if (vnode.data.show !== true) { + leave(vnode, rm); + } else { + rm(); + } + }, } - } - } : {}; + : {}; - var platformModules = [ - attrs, - klass, - events, - domProps, - style, - transition - ]; + var platformModules = [attrs, klass, events, domProps, style, transition]; /* */ @@ -8456,36 +8835,36 @@ /* istanbul ignore if */ if (isIE9) { // http://www.matts411.com/post/internet-explorer-9-oninput/ - document.addEventListener('selectionchange', function () { + document.addEventListener("selectionchange", function () { var el = document.activeElement; if (el && el.vmodel) { - trigger(el, 'input'); + trigger(el, "input"); } }); } var directive = { - inserted: function inserted (el, binding, vnode, oldVnode) { - if (vnode.tag === 'select') { + inserted: function inserted(el, binding, vnode, oldVnode) { + if (vnode.tag === "select") { // #6903 if (oldVnode.elm && !oldVnode.elm._vOptions) { - mergeVNodeHook(vnode, 'postpatch', function () { + mergeVNodeHook(vnode, "postpatch", function () { directive.componentUpdated(el, binding, vnode); }); } else { setSelected(el, binding, vnode.context); } el._vOptions = [].map.call(el.options, getValue); - } else if (vnode.tag === 'textarea' || isTextInputType(el.type)) { + } else if (vnode.tag === "textarea" || isTextInputType(el.type)) { el._vModifiers = binding.modifiers; if (!binding.modifiers.lazy) { - el.addEventListener('compositionstart', onCompositionStart); - el.addEventListener('compositionend', onCompositionEnd); + el.addEventListener("compositionstart", onCompositionStart); + el.addEventListener("compositionend", onCompositionEnd); // Safari < 10.2 & UIWebView doesn't fire compositionend when // switching focus before confirming composition choice // this also fixes the issue where some browsers e.g. iOS Chrome // fires "change" instead of "input" on autocomplete. - el.addEventListener('change', onCompositionEnd); + el.addEventListener("change", onCompositionEnd); /* istanbul ignore if */ if (isIE9) { el.vmodel = true; @@ -8494,30 +8873,37 @@ } }, - componentUpdated: function componentUpdated (el, binding, vnode) { - if (vnode.tag === 'select') { + componentUpdated: function componentUpdated(el, binding, vnode) { + if (vnode.tag === "select") { setSelected(el, binding, vnode.context); // in case the options rendered by v-for have changed, // it's possible that the value is out-of-sync with the rendered options. // detect such cases and filter out values that no longer has a matching // option in the DOM. var prevOptions = el._vOptions; - var curOptions = el._vOptions = [].map.call(el.options, getValue); - if (curOptions.some(function (o, i) { return !looseEqual(o, prevOptions[i]); })) { + var curOptions = (el._vOptions = [].map.call(el.options, getValue)); + if ( + curOptions.some(function (o, i) { + return !looseEqual(o, prevOptions[i]); + }) + ) { // trigger change event if // no matching option found for at least one value var needReset = el.multiple - ? binding.value.some(function (v) { return hasNoMatchingOption(v, curOptions); }) - : binding.value !== binding.oldValue && hasNoMatchingOption(binding.value, curOptions); + ? binding.value.some(function (v) { + return hasNoMatchingOption(v, curOptions); + }) + : binding.value !== binding.oldValue && + hasNoMatchingOption(binding.value, curOptions); if (needReset) { - trigger(el, 'change'); + trigger(el, "change"); } } } - } + }, }; - function setSelected (el, binding, vm) { + function setSelected(el, binding, vm) { actuallySetSelected(el, binding, vm); /* istanbul ignore if */ if (isIE || isEdge) { @@ -8527,16 +8913,19 @@ } } - function actuallySetSelected (el, binding, vm) { + function actuallySetSelected(el, binding, vm) { var value = binding.value; var isMultiple = el.multiple; if (isMultiple && !Array.isArray(value)) { warn( - "<select multiple v-model=\"" + (binding.expression) + "\"> " + - "expects an Array value for its binding, but got " + (Object.prototype.toString.call(value).slice(8, -1)), + '<select multiple v-model="' + + binding.expression + + '"> ' + + "expects an Array value for its binding, but got " + + Object.prototype.toString.call(value).slice(8, -1), vm ); - return + return; } var selected, option; for (var i = 0, l = el.options.length; i < l; i++) { @@ -8551,7 +8940,7 @@ if (el.selectedIndex !== i) { el.selectedIndex = i; } - return + return; } } } @@ -8560,29 +8949,31 @@ } } - function hasNoMatchingOption (value, options) { - return options.every(function (o) { return !looseEqual(o, value); }) + function hasNoMatchingOption(value, options) { + return options.every(function (o) { + return !looseEqual(o, value); + }); } - function getValue (option) { - return '_value' in option - ? option._value - : option.value + function getValue(option) { + return "_value" in option ? option._value : option.value; } - function onCompositionStart (e) { + function onCompositionStart(e) { e.target.composing = true; } - function onCompositionEnd (e) { + function onCompositionEnd(e) { // prevent triggering an input event for no reason - if (!e.target.composing) { return } + if (!e.target.composing) { + return; + } e.target.composing = false; - trigger(e.target, 'input'); + trigger(e.target, "input"); } - function trigger (el, type) { - var e = document.createEvent('HTMLEvents'); + function trigger(el, type) { + var e = document.createEvent("HTMLEvents"); e.initEvent(type, true, true); el.dispatchEvent(e); } @@ -8590,36 +8981,38 @@ /* */ // recursively search for possible transition defined inside the component root - function locateNode (vnode) { + function locateNode(vnode) { return vnode.componentInstance && (!vnode.data || !vnode.data.transition) ? locateNode(vnode.componentInstance._vnode) - : vnode + : vnode; } var show = { - bind: function bind (el, ref, vnode) { + bind: function bind(el, ref, vnode) { var value = ref.value; vnode = locateNode(vnode); var transition$$1 = vnode.data && vnode.data.transition; - var originalDisplay = el.__vOriginalDisplay = - el.style.display === 'none' ? '' : el.style.display; + var originalDisplay = (el.__vOriginalDisplay = + el.style.display === "none" ? "" : el.style.display); if (value && transition$$1) { vnode.data.show = true; enter(vnode, function () { el.style.display = originalDisplay; }); } else { - el.style.display = value ? originalDisplay : 'none'; + el.style.display = value ? originalDisplay : "none"; } }, - update: function update (el, ref, vnode) { + update: function update(el, ref, vnode) { var value = ref.value; var oldValue = ref.oldValue; /* istanbul ignore if */ - if (!value === !oldValue) { return } + if (!value === !oldValue) { + return; + } vnode = locateNode(vnode); var transition$$1 = vnode.data && vnode.data.transition; if (transition$$1) { @@ -8630,30 +9023,24 @@ }); } else { leave(vnode, function () { - el.style.display = 'none'; + el.style.display = "none"; }); } } else { - el.style.display = value ? el.__vOriginalDisplay : 'none'; + el.style.display = value ? el.__vOriginalDisplay : "none"; } }, - unbind: function unbind ( - el, - binding, - vnode, - oldVnode, - isDestroy - ) { + unbind: function unbind(el, binding, vnode, oldVnode, isDestroy) { if (!isDestroy) { el.style.display = el.__vOriginalDisplay; } - } + }, }; var platformDirectives = { model: directive, - show: show + show: show, }; /* */ @@ -8673,21 +9060,21 @@ appearClass: String, appearActiveClass: String, appearToClass: String, - duration: [Number, String, Object] + duration: [Number, String, Object], }; // in case the child is also an abstract component, e.g. <keep-alive> // we want to recursively retrieve the real component to be rendered - function getRealChild (vnode) { + function getRealChild(vnode) { var compOptions = vnode && vnode.componentOptions; if (compOptions && compOptions.Ctor.options.abstract) { - return getRealChild(getFirstComponentChild(compOptions.children)) + return getRealChild(getFirstComponentChild(compOptions.children)); } else { - return vnode + return vnode; } } - function extractTransitionData (comp) { + function extractTransitionData(comp) { var data = {}; var options = comp.$options; // props @@ -8700,58 +9087,62 @@ for (var key$1 in listeners) { data[camelize(key$1)] = listeners[key$1]; } - return data + return data; } - function placeholder (h, rawChild) { + function placeholder(h, rawChild) { if (/\d-keep-alive$/.test(rawChild.tag)) { - return h('keep-alive', { - props: rawChild.componentOptions.propsData - }) + return h("keep-alive", { + props: rawChild.componentOptions.propsData, + }); } } - function hasParentTransition (vnode) { + function hasParentTransition(vnode) { while ((vnode = vnode.parent)) { if (vnode.data.transition) { - return true + return true; } } } - function isSameChild (child, oldChild) { - return oldChild.key === child.key && oldChild.tag === child.tag + function isSameChild(child, oldChild) { + return oldChild.key === child.key && oldChild.tag === child.tag; } - var isNotTextNode = function (c) { return c.tag || isAsyncPlaceholder(c); }; + var isNotTextNode = function (c) { + return c.tag || isAsyncPlaceholder(c); + }; - var isVShowDirective = function (d) { return d.name === 'show'; }; + var isVShowDirective = function (d) { + return d.name === "show"; + }; var Transition = { - name: 'transition', + name: "transition", props: transitionProps, abstract: true, - render: function render (h) { + render: function render(h) { var this$1 = this; var children = this.$slots.default; if (!children) { - return + return; } // filter out text nodes (possible whitespaces) children = children.filter(isNotTextNode); /* istanbul ignore if */ if (!children.length) { - return + return; } // warn multiple elements if (children.length > 1) { warn( - '<transition> can only be used on a single element. Use ' + - '<transition-group> for lists.', + "<transition> can only be used on a single element. Use " + + "<transition-group> for lists.", this.$parent ); } @@ -8759,12 +9150,8 @@ var mode = this.mode; // warn invalid mode - if (mode && mode !== 'in-out' && mode !== 'out-in' - ) { - warn( - 'invalid <transition> mode: ' + mode, - this.$parent - ); + if (mode && mode !== "in-out" && mode !== "out-in") { + warn("invalid <transition> mode: " + mode, this.$parent); } var rawChild = children[0]; @@ -8772,7 +9159,7 @@ // if this is a component root node and the component's // parent container node also has transition, skip. if (hasParentTransition(this.$vnode)) { - return rawChild + return rawChild; } // apply transition data to child @@ -8780,32 +9167,39 @@ var child = getRealChild(rawChild); /* istanbul ignore if */ if (!child) { - return rawChild + return rawChild; } if (this._leaving) { - return placeholder(h, rawChild) + return placeholder(h, rawChild); } // ensure a key that is unique to the vnode type and to this transition // component instance. This key will be used to remove pending leaving nodes // during entering. - var id = "__transition-" + (this._uid) + "-"; - child.key = child.key == null - ? child.isComment - ? id + 'comment' - : id + child.tag - : isPrimitive(child.key) - ? (String(child.key).indexOf(id) === 0 ? child.key : id + child.key) + var id = "__transition-" + this._uid + "-"; + child.key = + child.key == null + ? child.isComment + ? id + "comment" + : id + child.tag + : isPrimitive(child.key) + ? String(child.key).indexOf(id) === 0 + ? child.key + : id + child.key : child.key; - var data = (child.data || (child.data = {})).transition = extractTransitionData(this); + var data = ((child.data || (child.data = {})).transition = + extractTransitionData(this)); var oldRawChild = this._vnode; var oldChild = getRealChild(oldRawChild); // mark v-show // so that the transition module can hand over the control to the directive - if (child.data.directives && child.data.directives.some(isVShowDirective)) { + if ( + child.data.directives && + child.data.directives.some(isVShowDirective) + ) { child.data.show = true; } @@ -8815,49 +9209,59 @@ !isSameChild(child, oldChild) && !isAsyncPlaceholder(oldChild) && // #6687 component root is a comment node - !(oldChild.componentInstance && oldChild.componentInstance._vnode.isComment) + !( + oldChild.componentInstance && + oldChild.componentInstance._vnode.isComment + ) ) { // replace old child transition data with fresh one // important for dynamic transitions! - var oldData = oldChild.data.transition = extend({}, data); + var oldData = (oldChild.data.transition = extend({}, data)); // handle transition mode - if (mode === 'out-in') { + if (mode === "out-in") { // return placeholder node and queue update when leave finishes this._leaving = true; - mergeVNodeHook(oldData, 'afterLeave', function () { + mergeVNodeHook(oldData, "afterLeave", function () { this$1._leaving = false; this$1.$forceUpdate(); }); - return placeholder(h, rawChild) - } else if (mode === 'in-out') { + return placeholder(h, rawChild); + } else if (mode === "in-out") { if (isAsyncPlaceholder(child)) { - return oldRawChild + return oldRawChild; } var delayedLeave; - var performLeave = function () { delayedLeave(); }; - mergeVNodeHook(data, 'afterEnter', performLeave); - mergeVNodeHook(data, 'enterCancelled', performLeave); - mergeVNodeHook(oldData, 'delayLeave', function (leave) { delayedLeave = leave; }); + var performLeave = function () { + delayedLeave(); + }; + mergeVNodeHook(data, "afterEnter", performLeave); + mergeVNodeHook(data, "enterCancelled", performLeave); + mergeVNodeHook(oldData, "delayLeave", function (leave) { + delayedLeave = leave; + }); } } - return rawChild - } + return rawChild; + }, }; /* */ - var props = extend({ - tag: String, - moveClass: String - }, transitionProps); + var props = extend( + { + tag: String, + moveClass: String, + }, + transitionProps + ); delete props.mode; var TransitionGroup = { props: props, - beforeMount: function beforeMount () { + beforeMount: function beforeMount() { var this$1 = this; var update = this._update; @@ -8876,25 +9280,25 @@ }; }, - render: function render (h) { - var tag = this.tag || this.$vnode.data.tag || 'span'; + render: function render(h) { + var tag = this.tag || this.$vnode.data.tag || "span"; var map = Object.create(null); - var prevChildren = this.prevChildren = this.children; + var prevChildren = (this.prevChildren = this.children); var rawChildren = this.$slots.default || []; - var children = this.children = []; + var children = (this.children = []); var transitionData = extractTransitionData(this); for (var i = 0; i < rawChildren.length; i++) { var c = rawChildren[i]; if (c.tag) { - if (c.key != null && String(c.key).indexOf('__vlist') !== 0) { + if (c.key != null && String(c.key).indexOf("__vlist") !== 0) { children.push(c); - map[c.key] = c - ;(c.data || (c.data = {})).transition = transitionData; + map[c.key] = c; + (c.data || (c.data = {})).transition = transitionData; } else { var opts = c.componentOptions; - var name = opts ? (opts.Ctor.options.name || opts.tag || '') : c.tag; - warn(("<transition-group> children must be keyed: <" + name + ">")); + var name = opts ? opts.Ctor.options.name || opts.tag || "" : c.tag; + warn("<transition-group> children must be keyed: <" + name + ">"); } } } @@ -8916,14 +9320,14 @@ this.removed = removed; } - return h(tag, null, children) + return h(tag, null, children); }, - updated: function updated () { + updated: function updated() { var children = this.prevChildren; - var moveClass = this.moveClass || ((this.name || 'v') + '-move'); + var moveClass = this.moveClass || (this.name || "v") + "-move"; if (!children.length || !this.hasMove(children[0].elm, moveClass)) { - return + return; } // we divide the work into three loops to avoid mixing DOM reads and writes @@ -8942,30 +9346,33 @@ var el = c.elm; var s = el.style; addTransitionClass(el, moveClass); - s.transform = s.WebkitTransform = s.transitionDuration = ''; - el.addEventListener(transitionEndEvent, el._moveCb = function cb (e) { - if (e && e.target !== el) { - return - } - if (!e || /transform$/.test(e.propertyName)) { - el.removeEventListener(transitionEndEvent, cb); - el._moveCb = null; - removeTransitionClass(el, moveClass); - } - }); + s.transform = s.WebkitTransform = s.transitionDuration = ""; + el.addEventListener( + transitionEndEvent, + (el._moveCb = function cb(e) { + if (e && e.target !== el) { + return; + } + if (!e || /transform$/.test(e.propertyName)) { + el.removeEventListener(transitionEndEvent, cb); + el._moveCb = null; + removeTransitionClass(el, moveClass); + } + }) + ); } }); }, methods: { - hasMove: function hasMove (el, moveClass) { + hasMove: function hasMove(el, moveClass) { /* istanbul ignore if */ if (!hasTransition) { - return false + return false; } /* istanbul ignore if */ if (this._hasMove) { - return this._hasMove + return this._hasMove; } // Detect whether an element with the move class applied has // CSS transitions. Since the element may be inside an entering @@ -8974,19 +9381,21 @@ // is applied. var clone = el.cloneNode(); if (el._transitionClasses) { - el._transitionClasses.forEach(function (cls) { removeClass(clone, cls); }); + el._transitionClasses.forEach(function (cls) { + removeClass(clone, cls); + }); } addClass(clone, moveClass); - clone.style.display = 'none'; + clone.style.display = "none"; this.$el.appendChild(clone); var info = getTransitionInfo(clone); this.$el.removeChild(clone); - return (this._hasMove = info.hasTransform) - } - } + return (this._hasMove = info.hasTransform); + }, + }, }; - function callPendingCbs (c) { + function callPendingCbs(c) { /* istanbul ignore if */ if (c.elm._moveCb) { c.elm._moveCb(); @@ -8997,11 +9406,11 @@ } } - function recordPosition (c) { + function recordPosition(c) { c.data.newPos = c.elm.getBoundingClientRect(); } - function applyTranslation (c) { + function applyTranslation(c) { var oldPos = c.data.pos; var newPos = c.data.newPos; var dx = oldPos.left - newPos.left; @@ -9010,13 +9419,13 @@ c.data.moved = true; var s = c.elm.style; s.transform = s.WebkitTransform = "translate(" + dx + "px," + dy + "px)"; - s.transitionDuration = '0s'; + s.transitionDuration = "0s"; } } var platformComponents = { Transition: Transition, - TransitionGroup: TransitionGroup + TransitionGroup: TransitionGroup, }; /* */ @@ -9036,12 +9445,9 @@ Vue.prototype.__patch__ = inBrowser ? patch : noop; // public mount method - Vue.prototype.$mount = function ( - el, - hydrating - ) { + Vue.prototype.$mount = function (el, hydrating) { el = el && inBrowser ? query(el) : undefined; - return mountComponent(this, el, hydrating) + return mountComponent(this, el, hydrating); }; // devtools global hook @@ -9050,21 +9456,19 @@ setTimeout(function () { if (config.devtools) { if (devtools) { - devtools.emit('init', Vue); + devtools.emit("init", Vue); } else { - console[console.info ? 'info' : 'log']( - 'Download the Vue Devtools extension for a better development experience:\n' + - 'https://github.com/vuejs/vue-devtools' + console[console.info ? "info" : "log"]( + "Download the Vue Devtools extension for a better development experience:\n" + + "https://github.com/vuejs/vue-devtools" ); } } - if (config.productionTip !== false && - typeof console !== 'undefined' - ) { - console[console.info ? 'info' : 'log']( + if (config.productionTip !== false && typeof console !== "undefined") { + console[console.info ? "info" : "log"]( "You are running Vue in development mode.\n" + - "Make sure to turn on production mode when deploying for production.\n" + - "See more tips at https://vuejs.org/guide/deployment.html" + "Make sure to turn on production mode when deploying for production.\n" + + "See more tips at https://vuejs.org/guide/deployment.html" ); } }, 0); @@ -9076,134 +9480,133 @@ var regexEscapeRE = /[-.*+?^${}()|[\]\/\\]/g; var buildRegex = cached(function (delimiters) { - var open = delimiters[0].replace(regexEscapeRE, '\\$&'); - var close = delimiters[1].replace(regexEscapeRE, '\\$&'); - return new RegExp(open + '((?:.|\\n)+?)' + close, 'g') + var open = delimiters[0].replace(regexEscapeRE, "\\$&"); + var close = delimiters[1].replace(regexEscapeRE, "\\$&"); + return new RegExp(open + "((?:.|\\n)+?)" + close, "g"); }); - - - function parseText ( - text, - delimiters - ) { + function parseText(text, delimiters) { var tagRE = delimiters ? buildRegex(delimiters) : defaultTagRE; if (!tagRE.test(text)) { - return + return; } var tokens = []; var rawTokens = []; - var lastIndex = tagRE.lastIndex = 0; + var lastIndex = (tagRE.lastIndex = 0); var match, index, tokenValue; while ((match = tagRE.exec(text))) { index = match.index; // push text token if (index > lastIndex) { - rawTokens.push(tokenValue = text.slice(lastIndex, index)); + rawTokens.push((tokenValue = text.slice(lastIndex, index))); tokens.push(JSON.stringify(tokenValue)); } // tag token var exp = parseFilters(match[1].trim()); - tokens.push(("_s(" + exp + ")")); - rawTokens.push({ '@binding': exp }); + tokens.push("_s(" + exp + ")"); + rawTokens.push({ "@binding": exp }); lastIndex = index + match[0].length; } if (lastIndex < text.length) { - rawTokens.push(tokenValue = text.slice(lastIndex)); + rawTokens.push((tokenValue = text.slice(lastIndex))); tokens.push(JSON.stringify(tokenValue)); } return { - expression: tokens.join('+'), - tokens: rawTokens - } + expression: tokens.join("+"), + tokens: rawTokens, + }; } /* */ - function transformNode (el, options) { + function transformNode(el, options) { var warn = options.warn || baseWarn; - var staticClass = getAndRemoveAttr(el, 'class'); + var staticClass = getAndRemoveAttr(el, "class"); if (staticClass) { var res = parseText(staticClass, options.delimiters); if (res) { warn( - "class=\"" + staticClass + "\": " + - 'Interpolation inside attributes has been removed. ' + - 'Use v-bind or the colon shorthand instead. For example, ' + - 'instead of <div class="{{ val }}">, use <div :class="val">.', - el.rawAttrsMap['class'] + 'class="' + + staticClass + + '": ' + + "Interpolation inside attributes has been removed. " + + "Use v-bind or the colon shorthand instead. For example, " + + 'instead of <div class="{{ val }}">, use <div :class="val">.', + el.rawAttrsMap["class"] ); } } if (staticClass) { el.staticClass = JSON.stringify(staticClass); } - var classBinding = getBindingAttr(el, 'class', false /* getStatic */); + var classBinding = getBindingAttr(el, "class", false /* getStatic */); if (classBinding) { el.classBinding = classBinding; } } - function genData (el) { - var data = ''; + function genData(el) { + var data = ""; if (el.staticClass) { - data += "staticClass:" + (el.staticClass) + ","; + data += "staticClass:" + el.staticClass + ","; } if (el.classBinding) { - data += "class:" + (el.classBinding) + ","; + data += "class:" + el.classBinding + ","; } - return data + return data; } var klass$1 = { - staticKeys: ['staticClass'], + staticKeys: ["staticClass"], transformNode: transformNode, - genData: genData + genData: genData, }; /* */ - function transformNode$1 (el, options) { + function transformNode$1(el, options) { var warn = options.warn || baseWarn; - var staticStyle = getAndRemoveAttr(el, 'style'); + var staticStyle = getAndRemoveAttr(el, "style"); if (staticStyle) { /* istanbul ignore if */ { var res = parseText(staticStyle, options.delimiters); if (res) { warn( - "style=\"" + staticStyle + "\": " + - 'Interpolation inside attributes has been removed. ' + - 'Use v-bind or the colon shorthand instead. For example, ' + - 'instead of <div style="{{ val }}">, use <div :style="val">.', - el.rawAttrsMap['style'] + 'style="' + + staticStyle + + '": ' + + "Interpolation inside attributes has been removed. " + + "Use v-bind or the colon shorthand instead. For example, " + + 'instead of <div style="{{ val }}">, use <div :style="val">.', + el.rawAttrsMap["style"] ); } } el.staticStyle = JSON.stringify(parseStyleText(staticStyle)); } - var styleBinding = getBindingAttr(el, 'style', false /* getStatic */); + var styleBinding = getBindingAttr(el, "style", false /* getStatic */); if (styleBinding) { el.styleBinding = styleBinding; } } - function genData$1 (el) { - var data = ''; + function genData$1(el) { + var data = ""; if (el.staticStyle) { - data += "staticStyle:" + (el.staticStyle) + ","; + data += "staticStyle:" + el.staticStyle + ","; } if (el.styleBinding) { - data += "style:(" + (el.styleBinding) + "),"; + data += "style:(" + el.styleBinding + "),"; } - return data + return data; } var style$1 = { - staticKeys: ['staticStyle'], + staticKeys: ["staticStyle"], transformNode: transformNode$1, - genData: genData$1 + genData: genData$1, }; /* */ @@ -9211,34 +9614,34 @@ var decoder; var he = { - decode: function decode (html) { - decoder = decoder || document.createElement('div'); + decode: function decode(html) { + decoder = decoder || document.createElement("div"); decoder.innerHTML = html; - return decoder.textContent - } + return decoder.textContent; + }, }; /* */ var isUnaryTag = makeMap( - 'area,base,br,col,embed,frame,hr,img,input,isindex,keygen,' + - 'link,meta,param,source,track,wbr' + "area,base,br,col,embed,frame,hr,img,input,isindex,keygen," + + "link,meta,param,source,track,wbr" ); // Elements that you can, intentionally, leave open // (and which close themselves) var canBeLeftOpenTag = makeMap( - 'colgroup,dd,dt,li,options,p,td,tfoot,th,thead,tr,source' + "colgroup,dd,dt,li,options,p,td,tfoot,th,thead,tr,source" ); // HTML5 tags https://html.spec.whatwg.org/multipage/indices.html#elements-3 // Phrasing Content https://html.spec.whatwg.org/multipage/dom.html#phrasing-content var isNonPhrasingTag = makeMap( - 'address,article,aside,base,blockquote,body,caption,col,colgroup,dd,' + - 'details,dialog,div,dl,dt,fieldset,figcaption,figure,footer,form,' + - 'h1,h2,h3,h4,h5,h6,head,header,hgroup,hr,html,legend,li,menuitem,meta,' + - 'optgroup,option,param,rp,rt,source,style,summary,tbody,td,tfoot,th,thead,' + - 'title,tr,track' + "address,article,aside,base,blockquote,body,caption,col,colgroup,dd," + + "details,dialog,div,dl,dt,fieldset,figcaption,figure,footer,form," + + "h1,h2,h3,h4,h5,h6,head,header,hgroup,hr,html,legend,li,menuitem,meta," + + "optgroup,option,param,rp,rt,source,style,summary,tbody,td,tfoot,th,thead," + + "title,tr,track" ); /** @@ -9246,44 +9649,50 @@ */ // Regular Expressions for parsing tags and attributes - var attribute = /^\s*([^\s"'<>\/=]+)(?:\s*(=)\s*(?:"([^"]*)"+|'([^']*)'+|([^\s"'=<>`]+)))?/; - var dynamicArgAttribute = /^\s*((?:v-[\w-]+:|@|:|#)\[[^=]+\][^\s"'<>\/=]*)(?:\s*(=)\s*(?:"([^"]*)"+|'([^']*)'+|([^\s"'=<>`]+)))?/; - var ncname = "[a-zA-Z_][\\-\\.0-9_a-zA-Z" + (unicodeRegExp.source) + "]*"; + var attribute = + /^\s*([^\s"'<>\/=]+)(?:\s*(=)\s*(?:"([^"]*)"+|'([^']*)'+|([^\s"'=<>`]+)))?/; + var dynamicArgAttribute = + /^\s*((?:v-[\w-]+:|@|:|#)\[[^=]+\][^\s"'<>\/=]*)(?:\s*(=)\s*(?:"([^"]*)"+|'([^']*)'+|([^\s"'=<>`]+)))?/; + var ncname = "[a-zA-Z_][\\-\\.0-9_a-zA-Z" + unicodeRegExp.source + "]*"; var qnameCapture = "((?:" + ncname + "\\:)?" + ncname + ")"; - var startTagOpen = new RegExp(("^<" + qnameCapture)); + var startTagOpen = new RegExp("^<" + qnameCapture); var startTagClose = /^\s*(\/?)>/; - var endTag = new RegExp(("^<\\/" + qnameCapture + "[^>]*>")); + var endTag = new RegExp("^<\\/" + qnameCapture + "[^>]*>"); var doctype = /^<!DOCTYPE [^>]+>/i; // #7298: escape - to avoid being passed as HTML comment when inlined in page var comment = /^<!\--/; var conditionalComment = /^<!\[/; // Special Elements (can contain anything) - var isPlainTextElement = makeMap('script,style,textarea', true); + var isPlainTextElement = makeMap("script,style,textarea", true); var reCache = {}; var decodingMap = { - '<': '<', - '>': '>', - '"': '"', - '&': '&', - ' ': '\n', - '	': '\t', - ''': "'" + "<": "<", + ">": ">", + """: '"', + "&": "&", + " ": "\n", + "	": "\t", + "'": "'", }; var encodedAttr = /&(?:lt|gt|quot|amp|#39);/g; var encodedAttrWithNewLines = /&(?:lt|gt|quot|amp|#39|#10|#9);/g; // #5992 - var isIgnoreNewlineTag = makeMap('pre,textarea', true); - var shouldIgnoreFirstNewline = function (tag, html) { return tag && isIgnoreNewlineTag(tag) && html[0] === '\n'; }; + var isIgnoreNewlineTag = makeMap("pre,textarea", true); + var shouldIgnoreFirstNewline = function (tag, html) { + return tag && isIgnoreNewlineTag(tag) && html[0] === "\n"; + }; - function decodeAttr (value, shouldDecodeNewlines) { + function decodeAttr(value, shouldDecodeNewlines) { var re = shouldDecodeNewlines ? encodedAttrWithNewLines : encodedAttr; - return value.replace(re, function (match) { return decodingMap[match]; }) + return value.replace(re, function (match) { + return decodingMap[match]; + }); } - function parseHTML (html, options) { + function parseHTML(html, options) { var stack = []; var expectHTML = options.expectHTML; var isUnaryTag$$1 = options.isUnaryTag || no; @@ -9294,28 +9703,32 @@ last = html; // Make sure we're not in a plaintext content element like script/style if (!lastTag || !isPlainTextElement(lastTag)) { - var textEnd = html.indexOf('<'); + var textEnd = html.indexOf("<"); if (textEnd === 0) { // Comment: if (comment.test(html)) { - var commentEnd = html.indexOf('-->'); + var commentEnd = html.indexOf("-->"); if (commentEnd >= 0) { if (options.shouldKeepComment) { - options.comment(html.substring(4, commentEnd), index, index + commentEnd + 3); + options.comment( + html.substring(4, commentEnd), + index, + index + commentEnd + 3 + ); } advance(commentEnd + 3); - continue + continue; } } // http://en.wikipedia.org/wiki/Conditional_comment#Downlevel-revealed_conditional_comment if (conditionalComment.test(html)) { - var conditionalEnd = html.indexOf(']>'); + var conditionalEnd = html.indexOf("]>"); if (conditionalEnd >= 0) { advance(conditionalEnd + 2); - continue + continue; } } @@ -9323,7 +9736,7 @@ var doctypeMatch = html.match(doctype); if (doctypeMatch) { advance(doctypeMatch[0].length); - continue + continue; } // End tag: @@ -9332,7 +9745,7 @@ var curIndex = index; advance(endTagMatch[0].length); parseEndTag(endTagMatch[1], curIndex, index); - continue + continue; } // Start tag: @@ -9342,11 +9755,13 @@ if (shouldIgnoreFirstNewline(startTagMatch.tagName, html)) { advance(1); } - continue + continue; } } - var text = (void 0), rest = (void 0), next = (void 0); + var text = void 0, + rest = void 0, + next = void 0; if (textEnd >= 0) { rest = html.slice(textEnd); while ( @@ -9356,8 +9771,10 @@ !conditionalComment.test(rest) ) { // < in plain text, be forgiving and treat it as text - next = rest.indexOf('<', 1); - if (next < 0) { break } + next = rest.indexOf("<", 1); + if (next < 0) { + break; + } textEnd += next; rest = html.slice(textEnd); } @@ -9378,13 +9795,18 @@ } else { var endTagLength = 0; var stackedTag = lastTag.toLowerCase(); - var reStackedTag = reCache[stackedTag] || (reCache[stackedTag] = new RegExp('([\\s\\S]*?)(</' + stackedTag + '[^>]*>)', 'i')); + var reStackedTag = + reCache[stackedTag] || + (reCache[stackedTag] = new RegExp( + "([\\s\\S]*?)(</" + stackedTag + "[^>]*>)", + "i" + )); var rest$1 = html.replace(reStackedTag, function (all, text, endTag) { endTagLength = endTag.length; - if (!isPlainTextElement(stackedTag) && stackedTag !== 'noscript') { + if (!isPlainTextElement(stackedTag) && stackedTag !== "noscript") { text = text - .replace(/<!\--([\s\S]*?)-->/g, '$1') // #7298 - .replace(/<!\[CDATA\[([\s\S]*?)]]>/g, '$1'); + .replace(/<!\--([\s\S]*?)-->/g, "$1") // #7298 + .replace(/<!\[CDATA\[([\s\S]*?)]]>/g, "$1"); } if (shouldIgnoreFirstNewline(stackedTag, text)) { text = text.slice(1); @@ -9392,7 +9814,7 @@ if (options.chars) { options.chars(text); } - return '' + return ""; }); index += html.length - rest$1.length; html = rest$1; @@ -9402,31 +9824,36 @@ if (html === last) { options.chars && options.chars(html); if (!stack.length && options.warn) { - options.warn(("Mal-formatted tag at end of template: \"" + html + "\""), { start: index + html.length }); + options.warn('Mal-formatted tag at end of template: "' + html + '"', { + start: index + html.length, + }); } - break + break; } } // Clean up any remaining tags parseEndTag(); - function advance (n) { + function advance(n) { index += n; html = html.substring(n); } - function parseStartTag () { + function parseStartTag() { var start = html.match(startTagOpen); if (start) { var match = { tagName: start[1], attrs: [], - start: index + start: index, }; advance(start[0].length); var end, attr; - while (!(end = html.match(startTagClose)) && (attr = html.match(dynamicArgAttribute) || html.match(attribute))) { + while ( + !(end = html.match(startTagClose)) && + (attr = html.match(dynamicArgAttribute) || html.match(attribute)) + ) { attr.start = index; advance(attr[0].length); attr.end = index; @@ -9436,17 +9863,17 @@ match.unarySlash = end[1]; advance(end[0].length); match.end = index; - return match + return match; } } } - function handleStartTag (match) { + function handleStartTag(match) { var tagName = match.tagName; var unarySlash = match.unarySlash; if (expectHTML) { - if (lastTag === 'p' && isNonPhrasingTag(tagName)) { + if (lastTag === "p" && isNonPhrasingTag(tagName)) { parseEndTag(lastTag); } if (canBeLeftOpenTag$$1(tagName) && lastTag === tagName) { @@ -9460,13 +9887,14 @@ var attrs = new Array(l); for (var i = 0; i < l; i++) { var args = match.attrs[i]; - var value = args[3] || args[4] || args[5] || ''; - var shouldDecodeNewlines = tagName === 'a' && args[1] === 'href' - ? options.shouldDecodeNewlinesForHref - : options.shouldDecodeNewlines; + var value = args[3] || args[4] || args[5] || ""; + var shouldDecodeNewlines = + tagName === "a" && args[1] === "href" + ? options.shouldDecodeNewlinesForHref + : options.shouldDecodeNewlines; attrs[i] = { name: args[1], - value: decodeAttr(value, shouldDecodeNewlines) + value: decodeAttr(value, shouldDecodeNewlines), }; if (options.outputSourceRange) { attrs[i].start = args.start + args[0].match(/^\s*/).length; @@ -9475,7 +9903,13 @@ } if (!unary) { - stack.push({ tag: tagName, lowerCasedTag: tagName.toLowerCase(), attrs: attrs, start: match.start, end: match.end }); + stack.push({ + tag: tagName, + lowerCasedTag: tagName.toLowerCase(), + attrs: attrs, + start: match.start, + end: match.end, + }); lastTag = tagName; } @@ -9484,17 +9918,21 @@ } } - function parseEndTag (tagName, start, end) { + function parseEndTag(tagName, start, end) { var pos, lowerCasedTagName; - if (start == null) { start = index; } - if (end == null) { end = index; } + if (start == null) { + start = index; + } + if (end == null) { + end = index; + } // Find the closest opened tag of the same type if (tagName) { lowerCasedTagName = tagName.toLowerCase(); for (pos = stack.length - 1; pos >= 0; pos--) { if (stack[pos].lowerCasedTag === lowerCasedTagName) { - break + break; } } } else { @@ -9505,11 +9943,9 @@ if (pos >= 0) { // Close all the open elements, up the stack for (var i = stack.length - 1; i >= pos; i--) { - if (i > pos || !tagName && - options.warn - ) { + if (i > pos || (!tagName && options.warn)) { options.warn( - ("tag <" + (stack[i].tag) + "> has no matching end tag."), + "tag <" + stack[i].tag + "> has no matching end tag.", { start: stack[i].start, end: stack[i].end } ); } @@ -9521,11 +9957,11 @@ // Remove the open elements from the stack stack.length = pos; lastTag = pos && stack[pos - 1].tag; - } else if (lowerCasedTagName === 'br') { + } else if (lowerCasedTagName === "br") { if (options.start) { options.start(tagName, [], true, start, end); } - } else if (lowerCasedTagName === 'p') { + } else if (lowerCasedTagName === "p") { if (options.start) { options.start(tagName, [], false, start, end); } @@ -9571,11 +10007,7 @@ var platformGetTagNamespace; var maybeComponent; - function createASTElement ( - tag, - attrs, - parent - ) { + function createASTElement(tag, attrs, parent) { return { type: 1, tag: tag, @@ -9583,28 +10015,27 @@ attrsMap: makeAttrsMap(attrs), rawAttrsMap: {}, parent: parent, - children: [] - } + children: [], + }; } /** * Convert HTML string to AST. */ - function parse ( - template, - options - ) { + function parse(template, options) { warn$2 = options.warn || baseWarn; platformIsPreTag = options.isPreTag || no; platformMustUseProp = options.mustUseProp || no; platformGetTagNamespace = options.getTagNamespace || no; var isReservedTag = options.isReservedTag || no; - maybeComponent = function (el) { return !!el.component || !isReservedTag(el.tag); }; + maybeComponent = function (el) { + return !!el.component || !isReservedTag(el.tag); + }; - transforms = pluckModuleFunction(options.modules, 'transformNode'); - preTransforms = pluckModuleFunction(options.modules, 'preTransformNode'); - postTransforms = pluckModuleFunction(options.modules, 'postTransformNode'); + transforms = pluckModuleFunction(options.modules, "transformNode"); + preTransforms = pluckModuleFunction(options.modules, "preTransformNode"); + postTransforms = pluckModuleFunction(options.modules, "postTransformNode"); delimiters = options.delimiters; @@ -9617,14 +10048,14 @@ var inPre = false; var warned = false; - function warnOnce (msg, range) { + function warnOnce(msg, range) { if (!warned) { warned = true; warn$2(msg, range); } } - function closeElement (element) { + function closeElement(element) { trimEndingWhitespace(element); if (!inVPre && !element.processed) { element = processElement(element, options); @@ -9638,13 +10069,13 @@ } addIfCondition(root, { exp: element.elseif, - block: element + block: element, }); } else { warnOnce( "Component template should contain exactly one root element. " + - "If you are using v-if on multiple elements, " + - "use v-else-if to chain them instead.", + "If you are using v-if on multiple elements, " + + "use v-else-if to chain them instead.", { start: element.start } ); } @@ -9657,8 +10088,10 @@ // scoped slot // keep it in the children list so that v-else(-if) conditions can // find it as the prev node. - var name = element.slotTarget || '"default"' - ;(currentParent.scopedSlots || (currentParent.scopedSlots = {}))[name] = element; + var name = element.slotTarget || '"default"'; + (currentParent.scopedSlots || (currentParent.scopedSlots = {}))[ + name + ] = element; } currentParent.children.push(element); element.parent = currentParent; @@ -9667,7 +10100,9 @@ // final children cleanup // filter out scoped slots - element.children = element.children.filter(function (c) { return !(c).slotScope; }); + element.children = element.children.filter(function (c) { + return !c.slotScope; + }); // remove trailing whitespace node again trimEndingWhitespace(element); @@ -9684,33 +10119,35 @@ } } - function trimEndingWhitespace (el) { + function trimEndingWhitespace(el) { // remove trailing whitespace node if (!inPre) { var lastNode; while ( (lastNode = el.children[el.children.length - 1]) && lastNode.type === 3 && - lastNode.text === ' ' + lastNode.text === " " ) { el.children.pop(); } } } - function checkRootConstraints (el) { - if (el.tag === 'slot' || el.tag === 'template') { + function checkRootConstraints(el) { + if (el.tag === "slot" || el.tag === "template") { warnOnce( - "Cannot use <" + (el.tag) + "> as component root element because it may " + - 'contain multiple nodes.', + "Cannot use <" + + el.tag + + "> as component root element because it may " + + "contain multiple nodes.", { start: el.start } ); } - if (el.attrsMap.hasOwnProperty('v-for')) { + if (el.attrsMap.hasOwnProperty("v-for")) { warnOnce( - 'Cannot use v-for on stateful component root element because ' + - 'it renders multiple elements.', - el.rawAttrsMap['v-for'] + "Cannot use v-for on stateful component root element because " + + "it renders multiple elements.", + el.rawAttrsMap["v-for"] ); } } @@ -9724,14 +10161,15 @@ shouldDecodeNewlinesForHref: options.shouldDecodeNewlinesForHref, shouldKeepComment: options.comments, outputSourceRange: options.outputSourceRange, - start: function start (tag, attrs, unary, start$1, end) { + start: function start(tag, attrs, unary, start$1, end) { // check namespace. // inherit parent ns if there is one - var ns = (currentParent && currentParent.ns) || platformGetTagNamespace(tag); + var ns = + (currentParent && currentParent.ns) || platformGetTagNamespace(tag); // handle IE svg bug /* istanbul ignore if */ - if (isIE && ns === 'svg') { + if (isIE && ns === "svg") { attrs = guardIESVGBug(attrs); } @@ -9744,19 +10182,23 @@ if (options.outputSourceRange) { element.start = start$1; element.end = end; - element.rawAttrsMap = element.attrsList.reduce(function (cumulated, attr) { + element.rawAttrsMap = element.attrsList.reduce(function ( + cumulated, + attr + ) { cumulated[attr.name] = attr; - return cumulated - }, {}); + return cumulated; + }, + {}); } attrs.forEach(function (attr) { if (invalidAttributeRE.test(attr.name)) { warn$2( "Invalid dynamic argument expression: attribute names cannot contain " + - "spaces, quotes, <, >, / or =.", + "spaces, quotes, <, >, / or =.", { start: attr.start + attr.name.indexOf("["), - end: attr.start + attr.name.length + end: attr.start + attr.name.length, } ); } @@ -9766,9 +10208,12 @@ if (isForbiddenTag(element) && !isServerRendering()) { element.forbidden = true; warn$2( - 'Templates should only be responsible for mapping the state to the ' + - 'UI. Avoid placing tags with side-effects in your templates, such as ' + - "<" + tag + ">" + ', as they will not be parsed.', + "Templates should only be responsible for mapping the state to the " + + "UI. Avoid placing tags with side-effects in your templates, such as " + + "<" + + tag + + ">" + + ", as they will not be parsed.", { start: element.start } ); } @@ -9811,7 +10256,7 @@ } }, - end: function end (tag, start, end$1) { + end: function end(tag, start, end$1) { var element = stack[stack.length - 1]; // pop stack stack.length -= 1; @@ -9822,66 +10267,71 @@ closeElement(element); }, - chars: function chars (text, start, end) { + chars: function chars(text, start, end) { if (!currentParent) { { if (text === template) { warnOnce( - 'Component template requires a root element, rather than just text.', + "Component template requires a root element, rather than just text.", { start: start } ); } else if ((text = text.trim())) { warnOnce( - ("text \"" + text + "\" outside root element will be ignored."), + 'text "' + text + '" outside root element will be ignored.', { start: start } ); } } - return + return; } // IE textarea placeholder bug /* istanbul ignore if */ - if (isIE && - currentParent.tag === 'textarea' && + if ( + isIE && + currentParent.tag === "textarea" && currentParent.attrsMap.placeholder === text ) { - return + return; } var children = currentParent.children; if (inPre || text.trim()) { text = isTextTag(currentParent) ? text : decodeHTMLCached(text); } else if (!children.length) { // remove the whitespace-only node right after an opening tag - text = ''; + text = ""; } else if (whitespaceOption) { - if (whitespaceOption === 'condense') { + if (whitespaceOption === "condense") { // in condense mode, remove the whitespace node if it contains // line break, otherwise condense to a single space - text = lineBreakRE.test(text) ? '' : ' '; + text = lineBreakRE.test(text) ? "" : " "; } else { - text = ' '; + text = " "; } } else { - text = preserveWhitespace ? ' ' : ''; + text = preserveWhitespace ? " " : ""; } if (text) { - if (!inPre && whitespaceOption === 'condense') { + if (!inPre && whitespaceOption === "condense") { // condense consecutive whitespaces into single space - text = text.replace(whitespaceRE$1, ' '); + text = text.replace(whitespaceRE$1, " "); } var res; var child; - if (!inVPre && text !== ' ' && (res = parseText(text, delimiters))) { + if (!inVPre && text !== " " && (res = parseText(text, delimiters))) { child = { type: 2, expression: res.expression, tokens: res.tokens, - text: text + text: text, }; - } else if (text !== ' ' || !children.length || children[children.length - 1].text !== ' ') { + } else if ( + text !== " " || + !children.length || + children[children.length - 1].text !== " " + ) { child = { type: 3, - text: text + text: text, }; } if (child) { @@ -9893,14 +10343,14 @@ } } }, - comment: function comment (text, start, end) { + comment: function comment(text, start, end) { // adding anything as a sibling to the root node is forbidden // comments should still be allowed, but ignored if (currentParent) { var child = { type: 3, text: text, - isComment: true + isComment: true, }; if (options.outputSourceRange) { child.start = start; @@ -9908,26 +10358,26 @@ } currentParent.children.push(child); } - } + }, }); - return root + return root; } - function processPre (el) { - if (getAndRemoveAttr(el, 'v-pre') != null) { + function processPre(el) { + if (getAndRemoveAttr(el, "v-pre") != null) { el.pre = true; } } - function processRawAttrs (el) { + function processRawAttrs(el) { var list = el.attrsList; var len = list.length; if (len) { - var attrs = el.attrs = new Array(len); + var attrs = (el.attrs = new Array(len)); for (var i = 0; i < len; i++) { attrs[i] = { name: list[i].name, - value: JSON.stringify(list[i].value) + value: JSON.stringify(list[i].value), }; if (list[i].start != null) { attrs[i].start = list[i].start; @@ -9940,19 +10390,13 @@ } } - function processElement ( - element, - options - ) { + function processElement(element, options) { processKey(element); // determine whether this is a plain element after // removing structural attributes - element.plain = ( - !element.key && - !element.scopedSlots && - !element.attrsList.length - ); + element.plain = + !element.key && !element.scopedSlots && !element.attrsList.length; processRef(element); processSlotContent(element); @@ -9962,27 +10406,32 @@ element = transforms[i](element, options) || element; } processAttrs(element); - return element + return element; } - function processKey (el) { - var exp = getBindingAttr(el, 'key'); + function processKey(el) { + var exp = getBindingAttr(el, "key"); if (exp) { { - if (el.tag === 'template') { + if (el.tag === "template") { warn$2( "<template> cannot be keyed. Place the key on real elements instead.", - getRawBindingAttr(el, 'key') + getRawBindingAttr(el, "key") ); } if (el.for) { var iterator = el.iterator2 || el.iterator1; var parent = el.parent; - if (iterator && iterator === exp && parent && parent.tag === 'transition-group') { + if ( + iterator && + iterator === exp && + parent && + parent.tag === "transition-group" + ) { warn$2( "Do not use v-for index as key on <transition-group> children, " + - "this is the same as not using keys.", - getRawBindingAttr(el, 'key'), + "this is the same as not using keys.", + getRawBindingAttr(el, "key"), true /* tip */ ); } @@ -9992,40 +10441,37 @@ } } - function processRef (el) { - var ref = getBindingAttr(el, 'ref'); + function processRef(el) { + var ref = getBindingAttr(el, "ref"); if (ref) { el.ref = ref; el.refInFor = checkInFor(el); } } - function processFor (el) { + function processFor(el) { var exp; - if ((exp = getAndRemoveAttr(el, 'v-for'))) { + if ((exp = getAndRemoveAttr(el, "v-for"))) { var res = parseFor(exp); if (res) { extend(el, res); } else { - warn$2( - ("Invalid v-for expression: " + exp), - el.rawAttrsMap['v-for'] - ); + warn$2("Invalid v-for expression: " + exp, el.rawAttrsMap["v-for"]); } } } - - - function parseFor (exp) { + function parseFor(exp) { var inMatch = exp.match(forAliasRE); - if (!inMatch) { return } + if (!inMatch) { + return; + } var res = {}; res.for = inMatch[2].trim(); - var alias = inMatch[1].trim().replace(stripParensRE, ''); + var alias = inMatch[1].trim().replace(stripParensRE, ""); var iteratorMatch = alias.match(forIteratorRE); if (iteratorMatch) { - res.alias = alias.replace(forIteratorRE, '').trim(); + res.alias = alias.replace(forIteratorRE, "").trim(); res.iterator1 = iteratorMatch[1].trim(); if (iteratorMatch[2]) { res.iterator2 = iteratorMatch[2].trim(); @@ -10033,54 +10479,60 @@ } else { res.alias = alias; } - return res + return res; } - function processIf (el) { - var exp = getAndRemoveAttr(el, 'v-if'); + function processIf(el) { + var exp = getAndRemoveAttr(el, "v-if"); if (exp) { el.if = exp; addIfCondition(el, { exp: exp, - block: el + block: el, }); } else { - if (getAndRemoveAttr(el, 'v-else') != null) { + if (getAndRemoveAttr(el, "v-else") != null) { el.else = true; } - var elseif = getAndRemoveAttr(el, 'v-else-if'); + var elseif = getAndRemoveAttr(el, "v-else-if"); if (elseif) { el.elseif = elseif; } } } - function processIfConditions (el, parent) { + function processIfConditions(el, parent) { var prev = findPrevElement(parent.children); if (prev && prev.if) { addIfCondition(prev, { exp: el.elseif, - block: el + block: el, }); } else { warn$2( - "v-" + (el.elseif ? ('else-if="' + el.elseif + '"') : 'else') + " " + - "used on element <" + (el.tag) + "> without corresponding v-if.", - el.rawAttrsMap[el.elseif ? 'v-else-if' : 'v-else'] + "v-" + + (el.elseif ? 'else-if="' + el.elseif + '"' : "else") + + " " + + "used on element <" + + el.tag + + "> without corresponding v-if.", + el.rawAttrsMap[el.elseif ? "v-else-if" : "v-else"] ); } } - function findPrevElement (children) { + function findPrevElement(children) { var i = children.length; while (i--) { if (children[i].type === 1) { - return children[i] + return children[i]; } else { - if (children[i].text !== ' ') { + if (children[i].text !== " ") { warn$2( - "text \"" + (children[i].text.trim()) + "\" between v-if and v-else(-if) " + - "will be ignored.", + 'text "' + + children[i].text.trim() + + '" between v-if and v-else(-if) ' + + "will be ignored.", children[i] ); } @@ -10089,15 +10541,15 @@ } } - function addIfCondition (el, condition) { + function addIfCondition(el, condition) { if (!el.ifConditions) { el.ifConditions = []; } el.ifConditions.push(condition); } - function processOnce (el) { - var once$$1 = getAndRemoveAttr(el, 'v-once'); + function processOnce(el) { + var once$$1 = getAndRemoveAttr(el, "v-once"); if (once$$1 != null) { el.once = true; } @@ -10105,30 +10557,32 @@ // handle content being passed to a component as slot, // e.g. <template slot="xxx">, <div slot-scope="xxx"> - function processSlotContent (el) { + function processSlotContent(el) { var slotScope; - if (el.tag === 'template') { - slotScope = getAndRemoveAttr(el, 'scope'); + if (el.tag === "template") { + slotScope = getAndRemoveAttr(el, "scope"); /* istanbul ignore if */ if (slotScope) { warn$2( - "the \"scope\" attribute for scoped slots have been deprecated and " + - "replaced by \"slot-scope\" since 2.5. The new \"slot-scope\" attribute " + - "can also be used on plain elements in addition to <template> to " + - "denote scoped slots.", - el.rawAttrsMap['scope'], + 'the "scope" attribute for scoped slots have been deprecated and ' + + 'replaced by "slot-scope" since 2.5. The new "slot-scope" attribute ' + + "can also be used on plain elements in addition to <template> to " + + "denote scoped slots.", + el.rawAttrsMap["scope"], true ); } - el.slotScope = slotScope || getAndRemoveAttr(el, 'slot-scope'); - } else if ((slotScope = getAndRemoveAttr(el, 'slot-scope'))) { + el.slotScope = slotScope || getAndRemoveAttr(el, "slot-scope"); + } else if ((slotScope = getAndRemoveAttr(el, "slot-scope"))) { /* istanbul ignore if */ - if (el.attrsMap['v-for']) { + if (el.attrsMap["v-for"]) { warn$2( - "Ambiguous combined usage of slot-scope and v-for on <" + (el.tag) + "> " + - "(v-for takes higher priority). Use a wrapper <template> for the " + - "scoped slot to make it clearer.", - el.rawAttrsMap['slot-scope'], + "Ambiguous combined usage of slot-scope and v-for on <" + + el.tag + + "> " + + "(v-for takes higher priority). Use a wrapper <template> for the " + + "scoped slot to make it clearer.", + el.rawAttrsMap["slot-scope"], true ); } @@ -10136,34 +10590,33 @@ } // slot="xxx" - var slotTarget = getBindingAttr(el, 'slot'); + var slotTarget = getBindingAttr(el, "slot"); if (slotTarget) { el.slotTarget = slotTarget === '""' ? '"default"' : slotTarget; - el.slotTargetDynamic = !!(el.attrsMap[':slot'] || el.attrsMap['v-bind:slot']); + el.slotTargetDynamic = !!( + el.attrsMap[":slot"] || el.attrsMap["v-bind:slot"] + ); // preserve slot as an attribute for native shadow DOM compat // only for non-scoped slots. - if (el.tag !== 'template' && !el.slotScope) { - addAttr(el, 'slot', slotTarget, getRawBindingAttr(el, 'slot')); + if (el.tag !== "template" && !el.slotScope) { + addAttr(el, "slot", slotTarget, getRawBindingAttr(el, "slot")); } } // 2.6 v-slot syntax { - if (el.tag === 'template') { + if (el.tag === "template") { // v-slot on <template> var slotBinding = getAndRemoveAttrByRegex(el, slotRE); if (slotBinding) { { if (el.slotTarget || el.slotScope) { - warn$2( - "Unexpected mixed usage of different slot syntaxes.", - el - ); + warn$2("Unexpected mixed usage of different slot syntaxes.", el); } if (el.parent && !maybeComponent(el.parent)) { warn$2( "<template v-slot> can only appear at the root level inside " + - "the receiving component", + "the receiving component", el ); } @@ -10187,15 +10640,12 @@ ); } if (el.slotScope || el.slotTarget) { - warn$2( - "Unexpected mixed usage of different slot syntaxes.", - el - ); + warn$2("Unexpected mixed usage of different slot syntaxes.", el); } if (el.scopedSlots) { warn$2( "To avoid scope ambiguity, the default slot should also use " + - "<template> syntax when there are other named slots.", + "<template> syntax when there are other named slots.", slotBinding$1 ); } @@ -10205,13 +10655,17 @@ var ref$1 = getSlotName(slotBinding$1); var name$1 = ref$1.name; var dynamic$1 = ref$1.dynamic; - var slotContainer = slots[name$1] = createASTElement('template', [], el); + var slotContainer = (slots[name$1] = createASTElement( + "template", + [], + el + )); slotContainer.slotTarget = name$1; slotContainer.slotTargetDynamic = dynamic$1; slotContainer.children = el.children.filter(function (c) { if (!c.slotScope) { c.parent = slotContainer; - return true + return true; } }); slotContainer.slotScope = slotBinding$1.value || emptySlotScopeToken; @@ -10224,51 +10678,48 @@ } } - function getSlotName (binding) { - var name = binding.name.replace(slotRE, ''); + function getSlotName(binding) { + var name = binding.name.replace(slotRE, ""); if (!name) { - if (binding.name[0] !== '#') { - name = 'default'; + if (binding.name[0] !== "#") { + name = "default"; } else { - warn$2( - "v-slot shorthand syntax requires a slot name.", - binding - ); + warn$2("v-slot shorthand syntax requires a slot name.", binding); } } return dynamicArgRE.test(name) - // dynamic [name] - ? { name: name.slice(1, -1), dynamic: true } - // static name - : { name: ("\"" + name + "\""), dynamic: false } + ? // dynamic [name] + { name: name.slice(1, -1), dynamic: true } + : // static name + { name: '"' + name + '"', dynamic: false }; } // handle <slot/> outlets - function processSlotOutlet (el) { - if (el.tag === 'slot') { - el.slotName = getBindingAttr(el, 'name'); + function processSlotOutlet(el) { + if (el.tag === "slot") { + el.slotName = getBindingAttr(el, "name"); if (el.key) { warn$2( "`key` does not work on <slot> because slots are abstract outlets " + - "and can possibly expand into multiple elements. " + - "Use the key on a wrapping element instead.", - getRawBindingAttr(el, 'key') + "and can possibly expand into multiple elements. " + + "Use the key on a wrapping element instead.", + getRawBindingAttr(el, "key") ); } } } - function processComponent (el) { + function processComponent(el) { var binding; - if ((binding = getBindingAttr(el, 'is'))) { + if ((binding = getBindingAttr(el, "is"))) { el.component = binding; } - if (getAndRemoveAttr(el, 'inline-template') != null) { + if (getAndRemoveAttr(el, "inline-template") != null) { el.inlineTemplate = true; } } - function processAttrs (el) { + function processAttrs(el) { var list = el.attrsList; var i, l, name, rawName, value, modifiers, syncGen, isDynamic; for (i = 0, l = list.length; i < l; i++) { @@ -10278,29 +10729,32 @@ // mark element as dynamic el.hasBindings = true; // modifiers - modifiers = parseModifiers(name.replace(dirRE, '')); + modifiers = parseModifiers(name.replace(dirRE, "")); // support .foo shorthand syntax for the .prop modifier if (modifiers) { - name = name.replace(modifierRE, ''); + name = name.replace(modifierRE, ""); } - if (bindRE.test(name)) { // v-bind - name = name.replace(bindRE, ''); + if (bindRE.test(name)) { + // v-bind + name = name.replace(bindRE, ""); value = parseFilters(value); isDynamic = dynamicArgRE.test(name); if (isDynamic) { name = name.slice(1, -1); } - if ( - value.trim().length === 0 - ) { + if (value.trim().length === 0) { warn$2( - ("The value for a v-bind expression cannot be empty. Found in \"v-bind:" + name + "\"") + 'The value for a v-bind expression cannot be empty. Found in "v-bind:' + + name + + '"' ); } if (modifiers) { if (modifiers.prop && !isDynamic) { name = camelize(name); - if (name === 'innerHtml') { name = 'innerHTML'; } + if (name === "innerHtml") { + name = "innerHTML"; + } } if (modifiers.camel && !isDynamic) { name = camelize(name); @@ -10310,7 +10764,7 @@ if (!isDynamic) { addHandler( el, - ("update:" + (camelize(name))), + "update:" + camelize(name), syncGen, null, false, @@ -10320,7 +10774,7 @@ if (hyphenate(name) !== camelize(name)) { addHandler( el, - ("update:" + (hyphenate(name))), + "update:" + hyphenate(name), syncGen, null, false, @@ -10332,7 +10786,7 @@ // handler w/ dynamic event name addHandler( el, - ("\"update:\"+(" + name + ")"), + '"update:"+(' + name + ")", syncGen, null, false, @@ -10343,22 +10797,35 @@ } } } - if ((modifiers && modifiers.prop) || ( - !el.component && platformMustUseProp(el.tag, el.attrsMap.type, name) - )) { + if ( + (modifiers && modifiers.prop) || + (!el.component && + platformMustUseProp(el.tag, el.attrsMap.type, name)) + ) { addProp(el, name, value, list[i], isDynamic); } else { addAttr(el, name, value, list[i], isDynamic); } - } else if (onRE.test(name)) { // v-on - name = name.replace(onRE, ''); + } else if (onRE.test(name)) { + // v-on + name = name.replace(onRE, ""); isDynamic = dynamicArgRE.test(name); if (isDynamic) { name = name.slice(1, -1); } - addHandler(el, name, value, modifiers, false, warn$2, list[i], isDynamic); - } else { // normal directives - name = name.replace(dirRE, ''); + addHandler( + el, + name, + value, + modifiers, + false, + warn$2, + list[i], + isDynamic + ); + } else { + // normal directives + name = name.replace(dirRE, ""); // parse arg var argMatch = name.match(argRE); var arg = argMatch && argMatch[1]; @@ -10370,8 +10837,17 @@ isDynamic = true; } } - addDirective(el, name, rawName, value, arg, isDynamic, modifiers, list[i]); - if (name === 'model') { + addDirective( + el, + name, + rawName, + value, + arg, + isDynamic, + modifiers, + list[i] + ); + if (name === "model") { checkForAliasModel(el, value); } } @@ -10381,10 +10857,13 @@ var res = parseText(value, delimiters); if (res) { warn$2( - name + "=\"" + value + "\": " + - 'Interpolation inside attributes has been removed. ' + - 'Use v-bind or the colon shorthand instead. For example, ' + - 'instead of <div id="{{ val }}">, use <div :id="val">.', + name + + '="' + + value + + '": ' + + "Interpolation inside attributes has been removed. " + + "Use v-bind or the colon shorthand instead. For example, " + + 'instead of <div id="{{ val }}">, use <div :id="val">.', list[i] ); } @@ -10392,90 +10871,94 @@ addAttr(el, name, JSON.stringify(value), list[i]); // #6887 firefox doesn't update muted state if set via attribute // even immediately after element creation - if (!el.component && - name === 'muted' && - platformMustUseProp(el.tag, el.attrsMap.type, name)) { - addProp(el, name, 'true', list[i]); + if ( + !el.component && + name === "muted" && + platformMustUseProp(el.tag, el.attrsMap.type, name) + ) { + addProp(el, name, "true", list[i]); } } } } - function checkInFor (el) { + function checkInFor(el) { var parent = el; while (parent) { if (parent.for !== undefined) { - return true + return true; } parent = parent.parent; } - return false + return false; } - function parseModifiers (name) { + function parseModifiers(name) { var match = name.match(modifierRE); if (match) { var ret = {}; - match.forEach(function (m) { ret[m.slice(1)] = true; }); - return ret + match.forEach(function (m) { + ret[m.slice(1)] = true; + }); + return ret; } } - function makeAttrsMap (attrs) { + function makeAttrsMap(attrs) { var map = {}; for (var i = 0, l = attrs.length; i < l; i++) { - if ( - map[attrs[i].name] && !isIE && !isEdge - ) { - warn$2('duplicate attribute: ' + attrs[i].name, attrs[i]); + if (map[attrs[i].name] && !isIE && !isEdge) { + warn$2("duplicate attribute: " + attrs[i].name, attrs[i]); } map[attrs[i].name] = attrs[i].value; } - return map + return map; } // for script (e.g. type="x/template") or style, do not decode content - function isTextTag (el) { - return el.tag === 'script' || el.tag === 'style' + function isTextTag(el) { + return el.tag === "script" || el.tag === "style"; } - function isForbiddenTag (el) { + function isForbiddenTag(el) { return ( - el.tag === 'style' || - (el.tag === 'script' && ( - !el.attrsMap.type || - el.attrsMap.type === 'text/javascript' - )) - ) + el.tag === "style" || + (el.tag === "script" && + (!el.attrsMap.type || el.attrsMap.type === "text/javascript")) + ); } var ieNSBug = /^xmlns:NS\d+/; var ieNSPrefix = /^NS\d+:/; /* istanbul ignore next */ - function guardIESVGBug (attrs) { + function guardIESVGBug(attrs) { var res = []; for (var i = 0; i < attrs.length; i++) { var attr = attrs[i]; if (!ieNSBug.test(attr.name)) { - attr.name = attr.name.replace(ieNSPrefix, ''); + attr.name = attr.name.replace(ieNSPrefix, ""); res.push(attr); } } - return res + return res; } - function checkForAliasModel (el, value) { + function checkForAliasModel(el, value) { var _el = el; while (_el) { if (_el.for && _el.alias === value) { warn$2( - "<" + (el.tag) + " v-model=\"" + value + "\">: " + - "You are binding v-model directly to a v-for iteration alias. " + - "This will not be able to modify the v-for source array because " + - "writing to the alias is like modifying a function local variable. " + - "Consider using an array of objects and use v-model on an object property instead.", - el.rawAttrsMap['v-model'] + "<" + + el.tag + + ' v-model="' + + value + + '">: ' + + "You are binding v-model directly to a v-for iteration alias. " + + "This will not be able to modify the v-for source array because " + + "writing to the alias is like modifying a function local variable. " + + "Consider using an array of objects and use v-model on an object property instead.", + el.rawAttrsMap["v-model"] ); } _el = _el.parent; @@ -10484,55 +10967,55 @@ /* */ - function preTransformNode (el, options) { - if (el.tag === 'input') { + function preTransformNode(el, options) { + if (el.tag === "input") { var map = el.attrsMap; - if (!map['v-model']) { - return + if (!map["v-model"]) { + return; } var typeBinding; - if (map[':type'] || map['v-bind:type']) { - typeBinding = getBindingAttr(el, 'type'); + if (map[":type"] || map["v-bind:type"]) { + typeBinding = getBindingAttr(el, "type"); } - if (!map.type && !typeBinding && map['v-bind']) { - typeBinding = "(" + (map['v-bind']) + ").type"; + if (!map.type && !typeBinding && map["v-bind"]) { + typeBinding = "(" + map["v-bind"] + ").type"; } if (typeBinding) { - var ifCondition = getAndRemoveAttr(el, 'v-if', true); - var ifConditionExtra = ifCondition ? ("&&(" + ifCondition + ")") : ""; - var hasElse = getAndRemoveAttr(el, 'v-else', true) != null; - var elseIfCondition = getAndRemoveAttr(el, 'v-else-if', true); + var ifCondition = getAndRemoveAttr(el, "v-if", true); + var ifConditionExtra = ifCondition ? "&&(" + ifCondition + ")" : ""; + var hasElse = getAndRemoveAttr(el, "v-else", true) != null; + var elseIfCondition = getAndRemoveAttr(el, "v-else-if", true); // 1. checkbox var branch0 = cloneASTElement(el); // process for on the main node processFor(branch0); - addRawAttr(branch0, 'type', 'checkbox'); + addRawAttr(branch0, "type", "checkbox"); processElement(branch0, options); branch0.processed = true; // prevent it from double-processed branch0.if = "(" + typeBinding + ")==='checkbox'" + ifConditionExtra; addIfCondition(branch0, { exp: branch0.if, - block: branch0 + block: branch0, }); // 2. add radio else-if condition var branch1 = cloneASTElement(el); - getAndRemoveAttr(branch1, 'v-for', true); - addRawAttr(branch1, 'type', 'radio'); + getAndRemoveAttr(branch1, "v-for", true); + addRawAttr(branch1, "type", "radio"); processElement(branch1, options); addIfCondition(branch0, { exp: "(" + typeBinding + ")==='radio'" + ifConditionExtra, - block: branch1 + block: branch1, }); // 3. other var branch2 = cloneASTElement(el); - getAndRemoveAttr(branch2, 'v-for', true); - addRawAttr(branch2, ':type', typeBinding); + getAndRemoveAttr(branch2, "v-for", true); + addRawAttr(branch2, ":type", typeBinding); processElement(branch2, options); addIfCondition(branch0, { exp: ifCondition, - block: branch2 + block: branch2, }); if (hasElse) { @@ -10541,45 +11024,41 @@ branch0.elseif = elseIfCondition; } - return branch0 + return branch0; } } } - function cloneASTElement (el) { - return createASTElement(el.tag, el.attrsList.slice(), el.parent) + function cloneASTElement(el) { + return createASTElement(el.tag, el.attrsList.slice(), el.parent); } var model$1 = { - preTransformNode: preTransformNode + preTransformNode: preTransformNode, }; - var modules$1 = [ - klass$1, - style$1, - model$1 - ]; + var modules$1 = [klass$1, style$1, model$1]; /* */ - function text (el, dir) { + function text(el, dir) { if (dir.value) { - addProp(el, 'textContent', ("_s(" + (dir.value) + ")"), dir); + addProp(el, "textContent", "_s(" + dir.value + ")", dir); } } /* */ - function html (el, dir) { + function html(el, dir) { if (dir.value) { - addProp(el, 'innerHTML', ("_s(" + (dir.value) + ")"), dir); + addProp(el, "innerHTML", "_s(" + dir.value + ")", dir); } } var directives$1 = { model: model, text: text, - html: html + html: html, }; /* */ @@ -10594,7 +11073,7 @@ canBeLeftOpenTag: canBeLeftOpenTag, isReservedTag: isReservedTag, getTagNamespace: getTagNamespace, - staticKeys: genStaticKeys(modules$1) + staticKeys: genStaticKeys(modules$1), }; /* */ @@ -10615,9 +11094,11 @@ * create fresh nodes for them on each re-render; * 2. Completely skip them in the patching process. */ - function optimize (root, options) { - if (!root) { return } - isStaticKey = genStaticKeysCached(options.staticKeys || ''); + function optimize(root, options) { + if (!root) { + return; + } + isStaticKey = genStaticKeysCached(options.staticKeys || ""); isPlatformReservedTag = options.isReservedTag || no; // first pass: mark all non-static nodes. markStatic$1(root); @@ -10625,14 +11106,14 @@ markStaticRoots(root, false); } - function genStaticKeys$1 (keys) { + function genStaticKeys$1(keys) { return makeMap( - 'type,tag,attrsList,attrsMap,plain,parent,children,attrs,start,end,rawAttrsMap' + - (keys ? ',' + keys : '') - ) + "type,tag,attrsList,attrsMap,plain,parent,children,attrs,start,end,rawAttrsMap" + + (keys ? "," + keys : "") + ); } - function markStatic$1 (node) { + function markStatic$1(node) { node.static = isStatic(node); if (node.type === 1) { // do not make component slot content static. this avoids @@ -10640,10 +11121,10 @@ // 2. static slot content fails for hot-reloading if ( !isPlatformReservedTag(node.tag) && - node.tag !== 'slot' && - node.attrsMap['inline-template'] == null + node.tag !== "slot" && + node.attrsMap["inline-template"] == null ) { - return + return; } for (var i = 0, l = node.children.length; i < l; i++) { var child = node.children[i]; @@ -10664,7 +11145,7 @@ } } - function markStaticRoots (node, isInFor) { + function markStaticRoots(node, isInFor) { if (node.type === 1) { if (node.static || node.once) { node.staticInFor = isInFor; @@ -10672,12 +11153,13 @@ // For a node to qualify as a static root, it should have children that // are not just static text. Otherwise the cost of hoisting out will // outweigh the benefits and it's better off to just always render it fresh. - if (node.static && node.children.length && !( - node.children.length === 1 && - node.children[0].type === 3 - )) { + if ( + node.static && + node.children.length && + !(node.children.length === 1 && node.children[0].type === 3) + ) { node.staticRoot = true; - return + return; } else { node.staticRoot = false; } @@ -10694,41 +11176,46 @@ } } - function isStatic (node) { - if (node.type === 2) { // expression - return false + function isStatic(node) { + if (node.type === 2) { + // expression + return false; } - if (node.type === 3) { // text - return true + if (node.type === 3) { + // text + return true; } - return !!(node.pre || ( - !node.hasBindings && // no dynamic bindings - !node.if && !node.for && // not v-if or v-for or v-else - !isBuiltInTag(node.tag) && // not a built-in - isPlatformReservedTag(node.tag) && // not a component - !isDirectChildOfTemplateFor(node) && - Object.keys(node).every(isStaticKey) - )) + return !!( + node.pre || + (!node.hasBindings && // no dynamic bindings + !node.if && + !node.for && // not v-if or v-for or v-else + !isBuiltInTag(node.tag) && // not a built-in + isPlatformReservedTag(node.tag) && // not a component + !isDirectChildOfTemplateFor(node) && + Object.keys(node).every(isStaticKey)) + ); } - function isDirectChildOfTemplateFor (node) { + function isDirectChildOfTemplateFor(node) { while (node.parent) { node = node.parent; - if (node.tag !== 'template') { - return false + if (node.tag !== "template") { + return false; } if (node.for) { - return true + return true; } } - return false + return false; } /* */ var fnExpRE = /^([\w$_]+|\([^)]*?\))\s*=>|^function(?:\s+[\w$]+)?\s*\(/; var fnInvokeRE = /\([^)]*?\);*$/; - var simplePathRE = /^[A-Za-z_$][\w$]*(?:\.[A-Za-z_$][\w$]*|\['[^']*?']|\["[^"]*?"]|\[\d+]|\[[A-Za-z_$][\w$]*])*$/; + var simplePathRE = + /^[A-Za-z_$][\w$]*(?:\.[A-Za-z_$][\w$]*|\['[^']*?']|\["[^"]*?"]|\[\d+]|\[[A-Za-z_$][\w$]*])*$/; // KeyboardEvent.keyCode aliases var keyCodes = { @@ -10740,34 +11227,36 @@ left: 37, right: 39, down: 40, - 'delete': [8, 46] + delete: [8, 46], }; // KeyboardEvent.key aliases var keyNames = { // #7880: IE11 and Edge use `Esc` for Escape key name. - esc: ['Esc', 'Escape'], - tab: 'Tab', - enter: 'Enter', + esc: ["Esc", "Escape"], + tab: "Tab", + enter: "Enter", // #9112: IE11 uses `Spacebar` for Space key name. - space: [' ', 'Spacebar'], + space: [" ", "Spacebar"], // #7806: IE11 uses key names without `Arrow` prefix for arrow keys. - up: ['Up', 'ArrowUp'], - left: ['Left', 'ArrowLeft'], - right: ['Right', 'ArrowRight'], - down: ['Down', 'ArrowDown'], + up: ["Up", "ArrowUp"], + left: ["Left", "ArrowLeft"], + right: ["Right", "ArrowRight"], + down: ["Down", "ArrowDown"], // #9112: IE11 uses `Del` for Delete key name. - 'delete': ['Backspace', 'Delete', 'Del'] + delete: ["Backspace", "Delete", "Del"], }; // #4868: modifiers that prevent the execution of the listener // need to explicitly return null so that we can determine whether to remove // the listener for .once - var genGuard = function (condition) { return ("if(" + condition + ")return null;"); }; + var genGuard = function (condition) { + return "if(" + condition + ")return null;"; + }; var modifierCode = { - stop: '$event.stopPropagation();', - prevent: '$event.preventDefault();', + stop: "$event.stopPropagation();", + prevent: "$event.preventDefault();", self: genGuard("$event.target !== $event.currentTarget"), ctrl: genGuard("!$event.ctrlKey"), shift: genGuard("!$event.shiftKey"), @@ -10775,14 +11264,11 @@ meta: genGuard("!$event.metaKey"), left: genGuard("'button' in $event && $event.button !== 0"), middle: genGuard("'button' in $event && $event.button !== 1"), - right: genGuard("'button' in $event && $event.button !== 2") + right: genGuard("'button' in $event && $event.button !== 2"), }; - function genHandlers ( - events, - isNative - ) { - var prefix = isNative ? 'nativeOn:' : 'on:'; + function genHandlers(events, isNative) { + var prefix = isNative ? "nativeOn:" : "on:"; var staticHandlers = ""; var dynamicHandlers = ""; for (var name in events) { @@ -10790,38 +11276,59 @@ if (events[name] && events[name].dynamic) { dynamicHandlers += name + "," + handlerCode + ","; } else { - staticHandlers += "\"" + name + "\":" + handlerCode + ","; + staticHandlers += '"' + name + '":' + handlerCode + ","; } } - staticHandlers = "{" + (staticHandlers.slice(0, -1)) + "}"; + staticHandlers = "{" + staticHandlers.slice(0, -1) + "}"; if (dynamicHandlers) { - return prefix + "_d(" + staticHandlers + ",[" + (dynamicHandlers.slice(0, -1)) + "])" + return ( + prefix + + "_d(" + + staticHandlers + + ",[" + + dynamicHandlers.slice(0, -1) + + "])" + ); } else { - return prefix + staticHandlers + return prefix + staticHandlers; } } - function genHandler (handler) { + function genHandler(handler) { if (!handler) { - return 'function(){}' + return "function(){}"; } if (Array.isArray(handler)) { - return ("[" + (handler.map(function (handler) { return genHandler(handler); }).join(',')) + "]") + return ( + "[" + + handler + .map(function (handler) { + return genHandler(handler); + }) + .join(",") + + "]" + ); } var isMethodPath = simplePathRE.test(handler.value); var isFunctionExpression = fnExpRE.test(handler.value); - var isFunctionInvocation = simplePathRE.test(handler.value.replace(fnInvokeRE, '')); + var isFunctionInvocation = simplePathRE.test( + handler.value.replace(fnInvokeRE, "") + ); if (!handler.modifiers) { if (isMethodPath || isFunctionExpression) { - return handler.value + return handler.value; } - return ("function($event){" + (isFunctionInvocation ? ("return " + (handler.value)) : handler.value) + "}") // inline statement + return ( + "function($event){" + + (isFunctionInvocation ? "return " + handler.value : handler.value) + + "}" + ); // inline statement } else { - var code = ''; - var genModifierCode = ''; + var code = ""; + var genModifierCode = ""; var keys = []; for (var key in handler.modifiers) { if (modifierCode[key]) { @@ -10830,13 +11337,17 @@ if (keyCodes[key]) { keys.push(key); } - } else if (key === 'exact') { - var modifiers = (handler.modifiers); + } else if (key === "exact") { + var modifiers = handler.modifiers; genModifierCode += genGuard( - ['ctrl', 'shift', 'alt', 'meta'] - .filter(function (keyModifier) { return !modifiers[keyModifier]; }) - .map(function (keyModifier) { return ("$event." + keyModifier + "Key"); }) - .join('||') + ["ctrl", "shift", "alt", "meta"] + .filter(function (keyModifier) { + return !modifiers[keyModifier]; + }) + .map(function (keyModifier) { + return "$event." + keyModifier + "Key"; + }) + .join("||") ); } else { keys.push(key); @@ -10850,57 +11361,74 @@ code += genModifierCode; } var handlerCode = isMethodPath - ? ("return " + (handler.value) + "($event)") + ? "return " + handler.value + "($event)" : isFunctionExpression - ? ("return (" + (handler.value) + ")($event)") - : isFunctionInvocation - ? ("return " + (handler.value)) - : handler.value; - return ("function($event){" + code + handlerCode + "}") + ? "return (" + handler.value + ")($event)" + : isFunctionInvocation + ? "return " + handler.value + : handler.value; + return "function($event){" + code + handlerCode + "}"; } } - function genKeyFilter (keys) { + function genKeyFilter(keys) { return ( // make sure the key filters only apply to KeyboardEvents // #9441: can't use 'keyCode' in $event because Chrome autofill fires fake // key events that do not have keyCode property... "if(!$event.type.indexOf('key')&&" + - (keys.map(genFilterCode).join('&&')) + ")return null;" - ) + keys.map(genFilterCode).join("&&") + + ")return null;" + ); } - function genFilterCode (key) { + function genFilterCode(key) { var keyVal = parseInt(key, 10); if (keyVal) { - return ("$event.keyCode!==" + keyVal) + return "$event.keyCode!==" + keyVal; } var keyCode = keyCodes[key]; var keyName = keyNames[key]; return ( "_k($event.keyCode," + - (JSON.stringify(key)) + "," + - (JSON.stringify(keyCode)) + "," + + JSON.stringify(key) + + "," + + JSON.stringify(keyCode) + + "," + "$event.key," + - "" + (JSON.stringify(keyName)) + + "" + + JSON.stringify(keyName) + ")" - ) + ); } /* */ - function on (el, dir) { + function on(el, dir) { if (dir.modifiers) { warn("v-on without argument does not support modifiers."); } - el.wrapListeners = function (code) { return ("_g(" + code + "," + (dir.value) + ")"); }; + el.wrapListeners = function (code) { + return "_g(" + code + "," + dir.value + ")"; + }; } /* */ - function bind$1 (el, dir) { + function bind$1(el, dir) { el.wrapData = function (code) { - return ("_b(" + code + ",'" + (el.tag) + "'," + (dir.value) + "," + (dir.modifiers && dir.modifiers.prop ? 'true' : 'false') + (dir.modifiers && dir.modifiers.sync ? ',true' : '') + ")") + return ( + "_b(" + + code + + ",'" + + el.tag + + "'," + + dir.value + + "," + + (dir.modifiers && dir.modifiers.prop ? "true" : "false") + + (dir.modifiers && dir.modifiers.sync ? ",true" : "") + + ")" + ); }; } @@ -10909,59 +11437,52 @@ var baseDirectives = { on: on, bind: bind$1, - cloak: noop + cloak: noop, }; /* */ - - - - - var CodegenState = function CodegenState (options) { + var CodegenState = function CodegenState(options) { this.options = options; this.warn = options.warn || baseWarn; - this.transforms = pluckModuleFunction(options.modules, 'transformCode'); - this.dataGenFns = pluckModuleFunction(options.modules, 'genData'); + this.transforms = pluckModuleFunction(options.modules, "transformCode"); + this.dataGenFns = pluckModuleFunction(options.modules, "genData"); this.directives = extend(extend({}, baseDirectives), options.directives); var isReservedTag = options.isReservedTag || no; - this.maybeComponent = function (el) { return !!el.component || !isReservedTag(el.tag); }; + this.maybeComponent = function (el) { + return !!el.component || !isReservedTag(el.tag); + }; this.onceId = 0; this.staticRenderFns = []; this.pre = false; }; - - - function generate ( - ast, - options - ) { + function generate(ast, options) { var state = new CodegenState(options); var code = ast ? genElement(ast, state) : '_c("div")'; return { - render: ("with(this){return " + code + "}"), - staticRenderFns: state.staticRenderFns - } + render: "with(this){return " + code + "}", + staticRenderFns: state.staticRenderFns, + }; } - function genElement (el, state) { + function genElement(el, state) { if (el.parent) { el.pre = el.pre || el.parent.pre; } if (el.staticRoot && !el.staticProcessed) { - return genStatic(el, state) + return genStatic(el, state); } else if (el.once && !el.onceProcessed) { - return genOnce(el, state) + return genOnce(el, state); } else if (el.for && !el.forProcessed) { - return genFor(el, state) + return genFor(el, state); } else if (el.if && !el.ifProcessed) { - return genIf(el, state) - } else if (el.tag === 'template' && !el.slotTarget && !state.pre) { - return genChildren(el, state) || 'void 0' - } else if (el.tag === 'slot') { - return genSlot(el, state) + return genIf(el, state); + } else if (el.tag === "template" && !el.slotTarget && !state.pre) { + return genChildren(el, state) || "void 0"; + } else if (el.tag === "slot") { + return genSlot(el, state); } else { // component or element var code; @@ -10974,18 +11495,24 @@ } var children = el.inlineTemplate ? null : genChildren(el, state, true); - code = "_c('" + (el.tag) + "'" + (data ? ("," + data) : '') + (children ? ("," + children) : '') + ")"; + code = + "_c('" + + el.tag + + "'" + + (data ? "," + data : "") + + (children ? "," + children : "") + + ")"; } // module transforms for (var i = 0; i < state.transforms.length; i++) { code = state.transforms[i](el, code); } - return code + return code; } } // hoist static sub-trees out - function genStatic (el, state) { + function genStatic(el, state) { el.staticProcessed = true; // Some elements (templates) need to behave differently inside of a v-pre // node. All pre nodes are static roots, so we can use this as a location to @@ -10994,123 +11521,143 @@ if (el.pre) { state.pre = el.pre; } - state.staticRenderFns.push(("with(this){return " + (genElement(el, state)) + "}")); + state.staticRenderFns.push( + "with(this){return " + genElement(el, state) + "}" + ); state.pre = originalPreState; - return ("_m(" + (state.staticRenderFns.length - 1) + (el.staticInFor ? ',true' : '') + ")") + return ( + "_m(" + + (state.staticRenderFns.length - 1) + + (el.staticInFor ? ",true" : "") + + ")" + ); } // v-once - function genOnce (el, state) { + function genOnce(el, state) { el.onceProcessed = true; if (el.if && !el.ifProcessed) { - return genIf(el, state) + return genIf(el, state); } else if (el.staticInFor) { - var key = ''; + var key = ""; var parent = el.parent; while (parent) { if (parent.for) { key = parent.key; - break + break; } parent = parent.parent; } if (!key) { state.warn( "v-once can only be used inside v-for that is keyed. ", - el.rawAttrsMap['v-once'] + el.rawAttrsMap["v-once"] ); - return genElement(el, state) + return genElement(el, state); } - return ("_o(" + (genElement(el, state)) + "," + (state.onceId++) + "," + key + ")") + return ( + "_o(" + genElement(el, state) + "," + state.onceId++ + "," + key + ")" + ); } else { - return genStatic(el, state) + return genStatic(el, state); } } - function genIf ( - el, - state, - altGen, - altEmpty - ) { + function genIf(el, state, altGen, altEmpty) { el.ifProcessed = true; // avoid recursion - return genIfConditions(el.ifConditions.slice(), state, altGen, altEmpty) + return genIfConditions(el.ifConditions.slice(), state, altGen, altEmpty); } - function genIfConditions ( - conditions, - state, - altGen, - altEmpty - ) { + function genIfConditions(conditions, state, altGen, altEmpty) { if (!conditions.length) { - return altEmpty || '_e()' + return altEmpty || "_e()"; } var condition = conditions.shift(); if (condition.exp) { - return ("(" + (condition.exp) + ")?" + (genTernaryExp(condition.block)) + ":" + (genIfConditions(conditions, state, altGen, altEmpty))) + return ( + "(" + + condition.exp + + ")?" + + genTernaryExp(condition.block) + + ":" + + genIfConditions(conditions, state, altGen, altEmpty) + ); } else { - return ("" + (genTernaryExp(condition.block))) + return "" + genTernaryExp(condition.block); } // v-if with v-once should generate code like (a)?_m(0):_m(1) - function genTernaryExp (el) { + function genTernaryExp(el) { return altGen ? altGen(el, state) : el.once - ? genOnce(el, state) - : genElement(el, state) + ? genOnce(el, state) + : genElement(el, state); } } - function genFor ( - el, - state, - altGen, - altHelper - ) { + function genFor(el, state, altGen, altHelper) { var exp = el.for; var alias = el.alias; - var iterator1 = el.iterator1 ? ("," + (el.iterator1)) : ''; - var iterator2 = el.iterator2 ? ("," + (el.iterator2)) : ''; + var iterator1 = el.iterator1 ? "," + el.iterator1 : ""; + var iterator2 = el.iterator2 ? "," + el.iterator2 : ""; - if (state.maybeComponent(el) && - el.tag !== 'slot' && - el.tag !== 'template' && + if ( + state.maybeComponent(el) && + el.tag !== "slot" && + el.tag !== "template" && !el.key ) { state.warn( - "<" + (el.tag) + " v-for=\"" + alias + " in " + exp + "\">: component lists rendered with " + - "v-for should have explicit keys. " + - "See https://vuejs.org/guide/list.html#key for more info.", - el.rawAttrsMap['v-for'], + "<" + + el.tag + + ' v-for="' + + alias + + " in " + + exp + + '">: component lists rendered with ' + + "v-for should have explicit keys. " + + "See https://vuejs.org/guide/list.html#key for more info.", + el.rawAttrsMap["v-for"], true /* tip */ ); } el.forProcessed = true; // avoid recursion - return (altHelper || '_l') + "((" + exp + ")," + - "function(" + alias + iterator1 + iterator2 + "){" + - "return " + ((altGen || genElement)(el, state)) + - '})' + return ( + (altHelper || "_l") + + "((" + + exp + + ")," + + "function(" + + alias + + iterator1 + + iterator2 + + "){" + + "return " + + (altGen || genElement)(el, state) + + "})" + ); } - function genData$2 (el, state) { - var data = '{'; + function genData$2(el, state) { + var data = "{"; // directives first. // directives may mutate the el's other properties before they are generated. var dirs = genDirectives(el, state); - if (dirs) { data += dirs + ','; } + if (dirs) { + data += dirs + ","; + } // key if (el.key) { - data += "key:" + (el.key) + ","; + data += "key:" + el.key + ","; } // ref if (el.ref) { - data += "ref:" + (el.ref) + ","; + data += "ref:" + el.ref + ","; } if (el.refInFor) { data += "refInFor:true,"; @@ -11121,7 +11668,7 @@ } // record original tag name for components using "is" attribute if (el.component) { - data += "tag:\"" + (el.tag) + "\","; + data += 'tag:"' + el.tag + '",'; } // module data generation functions for (var i = 0; i < state.dataGenFns.length; i++) { @@ -11129,31 +11676,38 @@ } // attributes if (el.attrs) { - data += "attrs:" + (genProps(el.attrs)) + ","; + data += "attrs:" + genProps(el.attrs) + ","; } // DOM props if (el.props) { - data += "domProps:" + (genProps(el.props)) + ","; + data += "domProps:" + genProps(el.props) + ","; } // event handlers if (el.events) { - data += (genHandlers(el.events, false)) + ","; + data += genHandlers(el.events, false) + ","; } if (el.nativeEvents) { - data += (genHandlers(el.nativeEvents, true)) + ","; + data += genHandlers(el.nativeEvents, true) + ","; } // slot target // only for non-scoped slots if (el.slotTarget && !el.slotScope) { - data += "slot:" + (el.slotTarget) + ","; + data += "slot:" + el.slotTarget + ","; } // scoped slots if (el.scopedSlots) { - data += (genScopedSlots(el, el.scopedSlots, state)) + ","; + data += genScopedSlots(el, el.scopedSlots, state) + ","; } // component v-model if (el.model) { - data += "model:{value:" + (el.model.value) + ",callback:" + (el.model.callback) + ",expression:" + (el.model.expression) + "},"; + data += + "model:{value:" + + el.model.value + + ",callback:" + + el.model.callback + + ",expression:" + + el.model.expression + + "},"; } // inline-template if (el.inlineTemplate) { @@ -11162,12 +11716,13 @@ data += inlineTemplate + ","; } } - data = data.replace(/,$/, '') + '}'; + data = data.replace(/,$/, "") + "}"; // v-bind dynamic argument wrap // v-bind with dynamic arguments must be applied using the same v-bind object // merge helper so that class/style/mustUseProp attrs are handled correctly. if (el.dynamicAttrs) { - data = "_b(" + data + ",\"" + (el.tag) + "\"," + (genProps(el.dynamicAttrs)) + ")"; + data = + "_b(" + data + ',"' + el.tag + '",' + genProps(el.dynamicAttrs) + ")"; } // v-bind data wrap if (el.wrapData) { @@ -11177,13 +11732,15 @@ if (el.wrapListeners) { data = el.wrapListeners(data); } - return data + return data; } - function genDirectives (el, state) { + function genDirectives(el, state) { var dirs = el.directives; - if (!dirs) { return } - var res = 'directives:['; + if (!dirs) { + return; + } + var res = "directives:["; var hasRuntime = false; var i, l, dir, needRuntime; for (i = 0, l = dirs.length; i < l; i++) { @@ -11197,46 +11754,70 @@ } if (needRuntime) { hasRuntime = true; - res += "{name:\"" + (dir.name) + "\",rawName:\"" + (dir.rawName) + "\"" + (dir.value ? (",value:(" + (dir.value) + "),expression:" + (JSON.stringify(dir.value))) : '') + (dir.arg ? (",arg:" + (dir.isDynamicArg ? dir.arg : ("\"" + (dir.arg) + "\""))) : '') + (dir.modifiers ? (",modifiers:" + (JSON.stringify(dir.modifiers))) : '') + "},"; + res += + '{name:"' + + dir.name + + '",rawName:"' + + dir.rawName + + '"' + + (dir.value + ? ",value:(" + + dir.value + + "),expression:" + + JSON.stringify(dir.value) + : "") + + (dir.arg + ? ",arg:" + (dir.isDynamicArg ? dir.arg : '"' + dir.arg + '"') + : "") + + (dir.modifiers ? ",modifiers:" + JSON.stringify(dir.modifiers) : "") + + "},"; } } if (hasRuntime) { - return res.slice(0, -1) + ']' + return res.slice(0, -1) + "]"; } } - function genInlineTemplate (el, state) { + function genInlineTemplate(el, state) { var ast = el.children[0]; if (el.children.length !== 1 || ast.type !== 1) { state.warn( - 'Inline-template components must have exactly one child element.', + "Inline-template components must have exactly one child element.", { start: el.start } ); } if (ast && ast.type === 1) { var inlineRenderFns = generate(ast, state.options); - return ("inlineTemplate:{render:function(){" + (inlineRenderFns.render) + "},staticRenderFns:[" + (inlineRenderFns.staticRenderFns.map(function (code) { return ("function(){" + code + "}"); }).join(',')) + "]}") + return ( + "inlineTemplate:{render:function(){" + + inlineRenderFns.render + + "},staticRenderFns:[" + + inlineRenderFns.staticRenderFns + .map(function (code) { + return "function(){" + code + "}"; + }) + .join(",") + + "]}" + ); } } - function genScopedSlots ( - el, - slots, - state - ) { + function genScopedSlots(el, slots, state) { // by default scoped slots are considered "stable", this allows child // components with only scoped slots to skip forced updates from parent. // but in some cases we have to bail-out of this optimization // for example if the slot contains dynamic names, has v-if or v-for on them... - var needsForceUpdate = el.for || Object.keys(slots).some(function (key) { - var slot = slots[key]; - return ( - slot.slotTargetDynamic || - slot.if || - slot.for || - containsSlotChild(slot) // is passing down slot from parent which may be dynamic - ) - }); + var needsForceUpdate = + el.for || + Object.keys(slots).some(function (key) { + var slot = slots[key]; + return ( + slot.slotTargetDynamic || + slot.if || + slot.for || + containsSlotChild(slot) // is passing down slot from parent which may be dynamic + ); + }); // #9534: if a component with scoped slots is inside a conditional branch, // it's possible for the same component to be reused but with different @@ -11257,7 +11838,7 @@ parent.for ) { needsForceUpdate = true; - break + break; } if (parent.if) { needsKey = true; @@ -11267,82 +11848,113 @@ } var generatedSlots = Object.keys(slots) - .map(function (key) { return genScopedSlot(slots[key], state); }) - .join(','); + .map(function (key) { + return genScopedSlot(slots[key], state); + }) + .join(","); - return ("scopedSlots:_u([" + generatedSlots + "]" + (needsForceUpdate ? ",null,true" : "") + (!needsForceUpdate && needsKey ? (",null,false," + (hash(generatedSlots))) : "") + ")") + return ( + "scopedSlots:_u([" + + generatedSlots + + "]" + + (needsForceUpdate ? ",null,true" : "") + + (!needsForceUpdate && needsKey + ? ",null,false," + hash(generatedSlots) + : "") + + ")" + ); } function hash(str) { var hash = 5381; var i = str.length; - while(i) { + while (i) { hash = (hash * 33) ^ str.charCodeAt(--i); } - return hash >>> 0 + return hash >>> 0; } - function containsSlotChild (el) { + function containsSlotChild(el) { if (el.type === 1) { - if (el.tag === 'slot') { - return true + if (el.tag === "slot") { + return true; } - return el.children.some(containsSlotChild) + return el.children.some(containsSlotChild); } - return false + return false; } - function genScopedSlot ( - el, - state - ) { - var isLegacySyntax = el.attrsMap['slot-scope']; + function genScopedSlot(el, state) { + var isLegacySyntax = el.attrsMap["slot-scope"]; if (el.if && !el.ifProcessed && !isLegacySyntax) { - return genIf(el, state, genScopedSlot, "null") + return genIf(el, state, genScopedSlot, "null"); } if (el.for && !el.forProcessed) { - return genFor(el, state, genScopedSlot) - } - var slotScope = el.slotScope === emptySlotScopeToken - ? "" - : String(el.slotScope); - var fn = "function(" + slotScope + "){" + - "return " + (el.tag === 'template' + return genFor(el, state, genScopedSlot); + } + var slotScope = + el.slotScope === emptySlotScopeToken ? "" : String(el.slotScope); + var fn = + "function(" + + slotScope + + "){" + + "return " + + (el.tag === "template" ? el.if && isLegacySyntax - ? ("(" + (el.if) + ")?" + (genChildren(el, state) || 'undefined') + ":undefined") - : genChildren(el, state) || 'undefined' - : genElement(el, state)) + "}"; + ? "(" + + el.if + + ")?" + + (genChildren(el, state) || "undefined") + + ":undefined" + : genChildren(el, state) || "undefined" + : genElement(el, state)) + + "}"; // reverse proxy v-slot without scope on this.$slots var reverseProxy = slotScope ? "" : ",proxy:true"; - return ("{key:" + (el.slotTarget || "\"default\"") + ",fn:" + fn + reverseProxy + "}") + return ( + "{key:" + + (el.slotTarget || '"default"') + + ",fn:" + + fn + + reverseProxy + + "}" + ); } - function genChildren ( - el, - state, - checkSkip, - altGenElement, - altGenNode - ) { + function genChildren(el, state, checkSkip, altGenElement, altGenNode) { var children = el.children; if (children.length) { var el$1 = children[0]; // optimize single v-for - if (children.length === 1 && + if ( + children.length === 1 && el$1.for && - el$1.tag !== 'template' && - el$1.tag !== 'slot' + el$1.tag !== "template" && + el$1.tag !== "slot" ) { var normalizationType = checkSkip - ? state.maybeComponent(el$1) ? ",1" : ",0" + ? state.maybeComponent(el$1) + ? ",1" + : ",0" : ""; - return ("" + ((altGenElement || genElement)(el$1, state)) + normalizationType) + return ( + "" + (altGenElement || genElement)(el$1, state) + normalizationType + ); } var normalizationType$1 = checkSkip ? getNormalizationType(children, state.maybeComponent) : 0; var gen = altGenNode || genNode; - return ("[" + (children.map(function (c) { return gen(c, state); }).join(',')) + "]" + (normalizationType$1 ? ("," + normalizationType$1) : '')) + return ( + "[" + + children + .map(function (c) { + return gen(c, state); + }) + .join(",") + + "]" + + (normalizationType$1 ? "," + normalizationType$1 : "") + ); } } @@ -11350,66 +11962,82 @@ // 0: no normalization needed // 1: simple normalization needed (possible 1-level deep nested array) // 2: full normalization needed - function getNormalizationType ( - children, - maybeComponent - ) { + function getNormalizationType(children, maybeComponent) { var res = 0; for (var i = 0; i < children.length; i++) { var el = children[i]; if (el.type !== 1) { - continue + continue; } - if (needsNormalization(el) || - (el.ifConditions && el.ifConditions.some(function (c) { return needsNormalization(c.block); }))) { + if ( + needsNormalization(el) || + (el.ifConditions && + el.ifConditions.some(function (c) { + return needsNormalization(c.block); + })) + ) { res = 2; - break + break; } - if (maybeComponent(el) || - (el.ifConditions && el.ifConditions.some(function (c) { return maybeComponent(c.block); }))) { + if ( + maybeComponent(el) || + (el.ifConditions && + el.ifConditions.some(function (c) { + return maybeComponent(c.block); + })) + ) { res = 1; } } - return res + return res; } - function needsNormalization (el) { - return el.for !== undefined || el.tag === 'template' || el.tag === 'slot' + function needsNormalization(el) { + return el.for !== undefined || el.tag === "template" || el.tag === "slot"; } - function genNode (node, state) { + function genNode(node, state) { if (node.type === 1) { - return genElement(node, state) + return genElement(node, state); } else if (node.type === 3 && node.isComment) { - return genComment(node) + return genComment(node); } else { - return genText(node) + return genText(node); } } - function genText (text) { - return ("_v(" + (text.type === 2 - ? text.expression // no need for () because already wrapped in _s() - : transformSpecialNewlines(JSON.stringify(text.text))) + ")") + function genText(text) { + return ( + "_v(" + + (text.type === 2 + ? text.expression // no need for () because already wrapped in _s() + : transformSpecialNewlines(JSON.stringify(text.text))) + + ")" + ); } - function genComment (comment) { - return ("_e(" + (JSON.stringify(comment.text)) + ")") + function genComment(comment) { + return "_e(" + JSON.stringify(comment.text) + ")"; } - function genSlot (el, state) { + function genSlot(el, state) { var slotName = el.slotName || '"default"'; var children = genChildren(el, state); - var res = "_t(" + slotName + (children ? ("," + children) : ''); - var attrs = el.attrs || el.dynamicAttrs - ? genProps((el.attrs || []).concat(el.dynamicAttrs || []).map(function (attr) { return ({ - // slot props are camelized - name: camelize(attr.name), - value: attr.value, - dynamic: attr.dynamic - }); })) - : null; - var bind$$1 = el.attrsMap['v-bind']; + var res = "_t(" + slotName + (children ? "," + children : ""); + var attrs = + el.attrs || el.dynamicAttrs + ? genProps( + (el.attrs || []).concat(el.dynamicAttrs || []).map(function (attr) { + return { + // slot props are camelized + name: camelize(attr.name), + value: attr.value, + dynamic: attr.dynamic, + }; + }) + ) + : null; + var bind$$1 = el.attrsMap["v-bind"]; if ((attrs || bind$$1) && !children) { res += ",null"; } @@ -11417,90 +12045,103 @@ res += "," + attrs; } if (bind$$1) { - res += (attrs ? '' : ',null') + "," + bind$$1; + res += (attrs ? "" : ",null") + "," + bind$$1; } - return res + ')' + return res + ")"; } // componentName is el.component, take it as argument to shun flow's pessimistic refinement - function genComponent ( - componentName, - el, - state - ) { + function genComponent(componentName, el, state) { var children = el.inlineTemplate ? null : genChildren(el, state, true); - return ("_c(" + componentName + "," + (genData$2(el, state)) + (children ? ("," + children) : '') + ")") + return ( + "_c(" + + componentName + + "," + + genData$2(el, state) + + (children ? "," + children : "") + + ")" + ); } - function genProps (props) { + function genProps(props) { var staticProps = ""; var dynamicProps = ""; for (var i = 0; i < props.length; i++) { var prop = props[i]; var value = transformSpecialNewlines(prop.value); if (prop.dynamic) { - dynamicProps += (prop.name) + "," + value + ","; + dynamicProps += prop.name + "," + value + ","; } else { - staticProps += "\"" + (prop.name) + "\":" + value + ","; + staticProps += '"' + prop.name + '":' + value + ","; } } - staticProps = "{" + (staticProps.slice(0, -1)) + "}"; + staticProps = "{" + staticProps.slice(0, -1) + "}"; if (dynamicProps) { - return ("_d(" + staticProps + ",[" + (dynamicProps.slice(0, -1)) + "])") + return "_d(" + staticProps + ",[" + dynamicProps.slice(0, -1) + "])"; } else { - return staticProps + return staticProps; } } // #3895, #4268 - function transformSpecialNewlines (text) { - return text - .replace(/\u2028/g, '\\u2028') - .replace(/\u2029/g, '\\u2029') + function transformSpecialNewlines(text) { + return text.replace(/\u2028/g, "\\u2028").replace(/\u2029/g, "\\u2029"); } /* */ - - // these keywords should not appear inside expressions, but operators like // typeof, instanceof and in are allowed - var prohibitedKeywordRE = new RegExp('\\b' + ( - 'do,if,for,let,new,try,var,case,else,with,await,break,catch,class,const,' + - 'super,throw,while,yield,delete,export,import,return,switch,default,' + - 'extends,finally,continue,debugger,function,arguments' - ).split(',').join('\\b|\\b') + '\\b'); + var prohibitedKeywordRE = new RegExp( + "\\b" + + ( + "do,if,for,let,new,try,var,case,else,with,await,break,catch,class,const," + + "super,throw,while,yield,delete,export,import,return,switch,default," + + "extends,finally,continue,debugger,function,arguments" + ) + .split(",") + .join("\\b|\\b") + + "\\b" + ); // these unary operators should not be used as property/method names - var unaryOperatorsRE = new RegExp('\\b' + ( - 'delete,typeof,void' - ).split(',').join('\\s*\\([^\\)]*\\)|\\b') + '\\s*\\([^\\)]*\\)'); + var unaryOperatorsRE = new RegExp( + "\\b" + + "delete,typeof,void".split(",").join("\\s*\\([^\\)]*\\)|\\b") + + "\\s*\\([^\\)]*\\)" + ); // strip strings in expressions - var stripStringRE = /'(?:[^'\\]|\\.)*'|"(?:[^"\\]|\\.)*"|`(?:[^`\\]|\\.)*\$\{|\}(?:[^`\\]|\\.)*`|`(?:[^`\\]|\\.)*`/g; + var stripStringRE = + /'(?:[^'\\]|\\.)*'|"(?:[^"\\]|\\.)*"|`(?:[^`\\]|\\.)*\$\{|\}(?:[^`\\]|\\.)*`|`(?:[^`\\]|\\.)*`/g; // detect problematic expressions in a template - function detectErrors (ast, warn) { + function detectErrors(ast, warn) { if (ast) { checkNode(ast, warn); } } - function checkNode (node, warn) { + function checkNode(node, warn) { if (node.type === 1) { for (var name in node.attrsMap) { if (dirRE.test(name)) { var value = node.attrsMap[name]; if (value) { var range = node.rawAttrsMap[name]; - if (name === 'v-for') { - checkFor(node, ("v-for=\"" + value + "\""), warn, range); - } else if (name === 'v-slot' || name[0] === '#') { - checkFunctionParameterExpression(value, (name + "=\"" + value + "\""), warn, range); + if (name === "v-for") { + checkFor(node, 'v-for="' + value + '"', warn, range); + } else if (name === "v-slot" || name[0] === "#") { + checkFunctionParameterExpression( + value, + name + '="' + value + '"', + warn, + range + ); } else if (onRE.test(name)) { - checkEvent(value, (name + "=\"" + value + "\""), warn, range); + checkEvent(value, name + '="' + value + '"', warn, range); } else { - checkExpression(value, (name + "=\"" + value + "\""), warn, range); + checkExpression(value, name + '="' + value + '"', warn, range); } } } @@ -11515,72 +12156,89 @@ } } - function checkEvent (exp, text, warn, range) { - var stripped = exp.replace(stripStringRE, ''); + function checkEvent(exp, text, warn, range) { + var stripped = exp.replace(stripStringRE, ""); var keywordMatch = stripped.match(unaryOperatorsRE); - if (keywordMatch && stripped.charAt(keywordMatch.index - 1) !== '$') { + if (keywordMatch && stripped.charAt(keywordMatch.index - 1) !== "$") { warn( "avoid using JavaScript unary operator as property name: " + - "\"" + (keywordMatch[0]) + "\" in expression " + (text.trim()), + '"' + + keywordMatch[0] + + '" in expression ' + + text.trim(), range ); } checkExpression(exp, text, warn, range); } - function checkFor (node, text, warn, range) { - checkExpression(node.for || '', text, warn, range); - checkIdentifier(node.alias, 'v-for alias', text, warn, range); - checkIdentifier(node.iterator1, 'v-for iterator', text, warn, range); - checkIdentifier(node.iterator2, 'v-for iterator', text, warn, range); + function checkFor(node, text, warn, range) { + checkExpression(node.for || "", text, warn, range); + checkIdentifier(node.alias, "v-for alias", text, warn, range); + checkIdentifier(node.iterator1, "v-for iterator", text, warn, range); + checkIdentifier(node.iterator2, "v-for iterator", text, warn, range); } - function checkIdentifier ( - ident, - type, - text, - warn, - range - ) { - if (typeof ident === 'string') { + function checkIdentifier(ident, type, text, warn, range) { + if (typeof ident === "string") { try { - new Function(("var " + ident + "=_")); + new Function("var " + ident + "=_"); } catch (e) { - warn(("invalid " + type + " \"" + ident + "\" in expression: " + (text.trim())), range); + warn( + "invalid " + type + ' "' + ident + '" in expression: ' + text.trim(), + range + ); } } } - function checkExpression (exp, text, warn, range) { + function checkExpression(exp, text, warn, range) { try { - new Function(("return " + exp)); + new Function("return " + exp); } catch (e) { - var keywordMatch = exp.replace(stripStringRE, '').match(prohibitedKeywordRE); + var keywordMatch = exp + .replace(stripStringRE, "") + .match(prohibitedKeywordRE); if (keywordMatch) { warn( "avoid using JavaScript keyword as property name: " + - "\"" + (keywordMatch[0]) + "\"\n Raw expression: " + (text.trim()), + '"' + + keywordMatch[0] + + '"\n Raw expression: ' + + text.trim(), range ); } else { warn( - "invalid expression: " + (e.message) + " in\n\n" + - " " + exp + "\n\n" + - " Raw expression: " + (text.trim()) + "\n", + "invalid expression: " + + e.message + + " in\n\n" + + " " + + exp + + "\n\n" + + " Raw expression: " + + text.trim() + + "\n", range ); } } } - function checkFunctionParameterExpression (exp, text, warn, range) { + function checkFunctionParameterExpression(exp, text, warn, range) { try { - new Function(exp, ''); + new Function(exp, ""); } catch (e) { warn( - "invalid function parameter expression: " + (e.message) + " in\n\n" + - " " + exp + "\n\n" + - " Raw expression: " + (text.trim()) + "\n", + "invalid function parameter expression: " + + e.message + + " in\n\n" + + " " + + exp + + "\n\n" + + " Raw expression: " + + text.trim() + + "\n", range ); } @@ -11590,13 +12248,9 @@ var range = 2; - function generateCodeFrame ( - source, - start, - end - ) { - if ( start === void 0 ) start = 0; - if ( end === void 0 ) end = source.length; + function generateCodeFrame(source, start, end) { + if (start === void 0) start = 0; + if (end === void 0) end = source.length; var lines = source.split(/\r?\n/); var count = 0; @@ -11605,8 +12259,16 @@ count += lines[i].length + 1; if (count >= start) { for (var j = i - range; j <= i + range || end > count; j++) { - if (j < 0 || j >= lines.length) { continue } - res.push(("" + (j + 1) + (repeat$1(" ", 3 - String(j + 1).length)) + "| " + (lines[j]))); + if (j < 0 || j >= lines.length) { + continue; + } + res.push( + "" + + (j + 1) + + repeat$1(" ", 3 - String(j + 1).length) + + "| " + + lines[j] + ); var lineLength = lines[j].length; if (j === i) { // push underline @@ -11621,46 +12283,45 @@ count += lineLength + 1; } } - break + break; } } - return res.join('\n') + return res.join("\n"); } - function repeat$1 (str, n) { - var result = ''; + function repeat$1(str, n) { + var result = ""; if (n > 0) { - while (true) { // eslint-disable-line - if (n & 1) { result += str; } + while (true) { + // eslint-disable-line + if (n & 1) { + result += str; + } n >>>= 1; - if (n <= 0) { break } + if (n <= 0) { + break; + } str += str; } } - return result + return result; } /* */ - - - function createFunction (code, errors) { + function createFunction(code, errors) { try { - return new Function(code) + return new Function(code); } catch (err) { errors.push({ err: err, code: code }); - return noop + return noop; } } - function createCompileToFunctionFn (compile) { + function createCompileToFunctionFn(compile) { var cache = Object.create(null); - return function compileToFunctions ( - template, - options, - vm - ) { + return function compileToFunctions(template, options, vm) { options = extend({}, options); var warn$$1 = options.warn || warn; delete options.warn; @@ -11669,15 +12330,15 @@ { // detect possible CSP restriction try { - new Function('return 1'); + new Function("return 1"); } catch (e) { if (e.toString().match(/unsafe-eval|CSP/)) { warn$$1( - 'It seems you are using the standalone build of Vue.js in an ' + - 'environment with Content Security Policy that prohibits unsafe-eval. ' + - 'The template compiler cannot work in this environment. Consider ' + - 'relaxing the policy to allow unsafe-eval or pre-compiling your ' + - 'templates into render functions.' + "It seems you are using the standalone build of Vue.js in an " + + "environment with Content Security Policy that prohibits unsafe-eval. " + + "The template compiler cannot work in this environment. Consider " + + "relaxing the policy to allow unsafe-eval or pre-compiling your " + + "templates into render functions." ); } } @@ -11688,7 +12349,7 @@ ? String(options.delimiters) + template : template; if (cache[key]) { - return cache[key] + return cache[key]; } // compile @@ -11700,24 +12361,37 @@ if (options.outputSourceRange) { compiled.errors.forEach(function (e) { warn$$1( - "Error compiling template:\n\n" + (e.msg) + "\n\n" + - generateCodeFrame(template, e.start, e.end), + "Error compiling template:\n\n" + + e.msg + + "\n\n" + + generateCodeFrame(template, e.start, e.end), vm ); }); } else { warn$$1( - "Error compiling template:\n\n" + template + "\n\n" + - compiled.errors.map(function (e) { return ("- " + e); }).join('\n') + '\n', + "Error compiling template:\n\n" + + template + + "\n\n" + + compiled.errors + .map(function (e) { + return "- " + e; + }) + .join("\n") + + "\n", vm ); } } if (compiled.tips && compiled.tips.length) { if (options.outputSourceRange) { - compiled.tips.forEach(function (e) { return tip(e.msg, vm); }); + compiled.tips.forEach(function (e) { + return tip(e.msg, vm); + }); } else { - compiled.tips.forEach(function (msg) { return tip(msg, vm); }); + compiled.tips.forEach(function (msg) { + return tip(msg, vm); + }); } } } @@ -11727,7 +12401,7 @@ var fnGenErrors = []; res.render = createFunction(compiled.render, fnGenErrors); res.staticRenderFns = compiled.staticRenderFns.map(function (code) { - return createFunction(code, fnGenErrors) + return createFunction(code, fnGenErrors); }); // check function generation errors. @@ -11735,32 +12409,34 @@ // mostly for codegen development use /* istanbul ignore if */ { - if ((!compiled.errors || !compiled.errors.length) && fnGenErrors.length) { + if ( + (!compiled.errors || !compiled.errors.length) && + fnGenErrors.length + ) { warn$$1( "Failed to generate render function:\n\n" + - fnGenErrors.map(function (ref) { - var err = ref.err; - var code = ref.code; - - return ((err.toString()) + " in\n\n" + code + "\n"); - }).join('\n'), + fnGenErrors + .map(function (ref) { + var err = ref.err; + var code = ref.code; + + return err.toString() + " in\n\n" + code + "\n"; + }) + .join("\n"), vm ); } } - return (cache[key] = res) - } + return (cache[key] = res); + }; } /* */ - function createCompilerCreator (baseCompile) { - return function createCompiler (baseOptions) { - function compile ( - template, - options - ) { + function createCompilerCreator(baseCompile) { + return function createCompiler(baseOptions) { + function compile(template, options) { var finalOptions = Object.create(baseOptions); var errors = []; var tips = []; @@ -11789,8 +12465,9 @@ } // merge custom modules if (options.modules) { - finalOptions.modules = - (baseOptions.modules || []).concat(options.modules); + finalOptions.modules = (baseOptions.modules || []).concat( + options.modules + ); } // merge custom directives if (options.directives) { @@ -11801,7 +12478,7 @@ } // copy other options for (var key in options) { - if (key !== 'modules' && key !== 'directives') { + if (key !== "modules" && key !== "directives") { finalOptions[key] = options[key]; } } @@ -11815,14 +12492,14 @@ } compiled.errors = errors; compiled.tips = tips; - return compiled + return compiled; } return { compile: compile, - compileToFunctions: createCompileToFunctionFn(compile) - } - } + compileToFunctions: createCompileToFunctionFn(compile), + }; + }; } /* */ @@ -11830,7 +12507,7 @@ // `createCompilerCreator` allows creating compilers that use alternative // parser/optimizer/codegen, e.g the SSR optimizing compiler. // Here we just export a default compiler using the default parts. - var createCompiler = createCompilerCreator(function baseCompile ( + var createCompiler = createCompilerCreator(function baseCompile( template, options ) { @@ -11842,8 +12519,8 @@ return { ast: ast, render: code.render, - staticRenderFns: code.staticRenderFns - } + staticRenderFns: code.staticRenderFns, + }; }); /* */ @@ -11856,10 +12533,10 @@ // check whether current browser encodes a char inside attribute values var div; - function getShouldDecode (href) { - div = div || document.createElement('div'); - div.innerHTML = href ? "<a href=\"\n\"/>" : "<div a=\"\n\"/>"; - return div.innerHTML.indexOf(' ') > 0 + function getShouldDecode(href) { + div = div || document.createElement("div"); + div.innerHTML = href ? '<a href="\n"/>' : '<div a="\n"/>'; + return div.innerHTML.indexOf(" ") > 0; } // #3663: IE encodes newlines inside attribute values while other browsers don't @@ -11871,14 +12548,11 @@ var idToTemplate = cached(function (id) { var el = query(id); - return el && el.innerHTML + return el && el.innerHTML; }); var mount = Vue.prototype.$mount; - Vue.prototype.$mount = function ( - el, - hydrating - ) { + Vue.prototype.$mount = function (el, hydrating) { el = el && query(el); /* istanbul ignore if */ @@ -11886,7 +12560,7 @@ warn( "Do not mount Vue to <html> or <body> - mount to normal elements instead." ); - return this + return this; } var options = this.$options; @@ -11894,13 +12568,13 @@ if (!options.render) { var template = options.template; if (template) { - if (typeof template === 'string') { - if (template.charAt(0) === '#') { + if (typeof template === "string") { + if (template.charAt(0) === "#") { template = idToTemplate(template); /* istanbul ignore if */ if (!template) { warn( - ("Template element not found or is empty: " + (options.template)), + "Template element not found or is empty: " + options.template, this ); } @@ -11909,9 +12583,9 @@ template = template.innerHTML; } else { { - warn('invalid template option:' + template, this); + warn("invalid template option:" + template, this); } - return this + return this; } } else if (el) { template = getOuterHTML(el); @@ -11919,16 +12593,20 @@ if (template) { /* istanbul ignore if */ if (config.performance && mark) { - mark('compile'); + mark("compile"); } - var ref = compileToFunctions(template, { - outputSourceRange: "development" !== 'production', - shouldDecodeNewlines: shouldDecodeNewlines, - shouldDecodeNewlinesForHref: shouldDecodeNewlinesForHref, - delimiters: options.delimiters, - comments: options.comments - }, this); + var ref = compileToFunctions( + template, + { + outputSourceRange: "development" !== "production", + shouldDecodeNewlines: shouldDecodeNewlines, + shouldDecodeNewlinesForHref: shouldDecodeNewlinesForHref, + delimiters: options.delimiters, + comments: options.comments, + }, + this + ); var render = ref.render; var staticRenderFns = ref.staticRenderFns; options.render = render; @@ -11936,30 +12614,29 @@ /* istanbul ignore if */ if (config.performance && mark) { - mark('compile end'); - measure(("vue " + (this._name) + " compile"), 'compile', 'compile end'); + mark("compile end"); + measure("vue " + this._name + " compile", "compile", "compile end"); } } } - return mount.call(this, el, hydrating) + return mount.call(this, el, hydrating); }; /** * Get outerHTML of elements, taking care * of SVG elements in IE as well. */ - function getOuterHTML (el) { + function getOuterHTML(el) { if (el.outerHTML) { - return el.outerHTML + return el.outerHTML; } else { - var container = document.createElement('div'); + var container = document.createElement("div"); container.appendChild(el.cloneNode(true)); - return container.innerHTML + return container.innerHTML; } } Vue.compile = compileToFunctions; return Vue; - -})); +}); diff --git a/notemyprogress/lang/en/local_notemyprogress.php b/notemyprogress/lang/en/local_notemyprogress.php index f1c2e8ceaa951e6fc3f9306450c95ce71cbca924..09b1db563af55074186c091963095889b4d907ff 100644 --- a/notemyprogress/lang/en/local_notemyprogress.php +++ b/notemyprogress/lang/en/local_notemyprogress.php @@ -775,6 +775,7 @@ $string['fml_settings_bddname_label'] = 'Name of the database'; $string['fml_settings_bddname_description'] = 'This parameter designates the name of the MongoDB database in which the information will be stored.'; $string['fml_settings_bddname_default'] = 'Empty'; +<<<<<<< HEAD //Planning /* Global */ $string['pagination'] = "Week:"; @@ -1093,4 +1094,78 @@ $string['group_allstudent'] = "All students"; /* Admin Settings */ $string['nmp_use_navbar_menu'] = 'Activate new menu'; $string['nmp_use_navbar_menu_desc'] = 'Display the plugin menu in the top navigation bar, otherwise it will include the menu in the navigation block.'; +======= +/* Gamification */ +$string['EnableGame']="Disable/Enable :"; +$string['studentRanking1']="Do you want to appear in the Ranking Board ?"; +$string['studentRanking2']=" /!\ All the registered in this course having accepted you will see. Accepting is final:"; +$string['studentRanking3']="Accept"; +$string['gamification_denied'] = 'gamification has been desactivated by your teacher'; +$string['tg_colon'] = '{$a->a}: {$a->b}'; +$string['tg_section_title'] = 'Course gamification settings'; +$string['tg_section_help_title'] = 'Course gamification settings'; +$string['tg_section_help_description'] = 'You can give the option of gamification to the students of the course.'; +$string['tg_save_warning_title'] = "Are you sure you want to save the changes?"; +$string['tg_save_warning_content'] = "If you change the settings for the gamification when the course has already started, data may be lost..."; +$string['tg_confirm_ok'] = "Save"; +$string['tg_confirm_cancel'] = "Cancel"; +$string['tg_save'] = "Save configuration"; +$string['tg_section_preview'] = 'Preview'; +$string['tg_section_experience'] = 'Experience points'; +$string['tg_section_information'] = 'Information'; +$string['tg_section_ranking'] = 'Ranking/Report'; +$string['tg_section_settings'] = 'Settings'; + +$string['tg_section_points'] = 'points'; +$string['tg_section_description'] = 'Description'; +$string['tg_section_no_description'] = 'No description'; +$string['tg_section_no_name'] = 'No name'; + +$string['tg_section_preview_next_level'] = 'to the next level'; +$string['tg_section_ranking_ranking_text'] = 'Ranking'; +$string['tg_section_ranking_level'] = 'Level'; +$string['tg_section_ranking_student'] = 'Student'; +$string['tg_section_ranking_total'] = 'Total'; +$string['tg_section_ranking_progress'] = 'Progress %'; + +$string['tg_section_settings_appearance'] = 'Appearance'; +$string['tg_section_settings_appearance_title'] = 'Title'; +$string['tg_section_settings_levels'] = 'Level settings'; +$string['tg_section_settings_levels_quantity'] = 'Levels'; +$string['tg_section_settings_levels_base_points'] = 'Base Points'; +$string['tg_section_settings_levels_calculated'] = 'Automatic'; +$string['tg_section_settings_levels_manually'] = 'Manually'; +$string['tg_section_settings_levels_name'] = 'Name'; +$string['tg_section_settings_levels_required'] = 'Points required'; +$string['tg_section_settings_rules'] = 'Rules setting'; +$string['tg_section_settings_add_rule'] = 'Add new rule'; +$string['tg_section_settings_earn'] = 'For this event win:'; +$string['tg_section_settings_select_event'] = 'Select an event'; +$string['gm_Chart_Title']='Spreading chart'; +$string['gm_Chart_Y']='Students'; + +$string['tg_timenow'] = 'Just now'; +$string['tg_timeseconds'] = '{$a}s ago'; +$string['tg_timeminutes'] = '{$a}m ago'; +$string['tg_timehours'] = '{$a}h ago'; +$string['tg_timedays'] = '{$a}d ago'; +$string['tg_timeweeks'] = '{$a}w ago'; +$string['tg_timewithinayearformat'] = '%b %e'; +$string['tg_timeolderyearformat'] = '%b %Y'; + +/* General Errors */ +$string['fml_api_error_network'] = "An error has occurred in communication with the server."; +$string['fml_api_invalid_data'] = 'Incorrect data'; +$string['fml_api_json_decode_error'] = 'Error Decoding sent data'; +$string['fml_api_invalid_token_error'] = 'The token sent in the transaction is invalid, please refresh the page'; +$string['fml_api_invalid_transaction'] = 'The request is incorrect'; +$string['fml_api_invalid_profile'] = 'You cannot do this action, your profile is incorrect'; +$string['fml_api_save_successful'] = 'The data has been successfully saved on the server'; +$string['fml_api_cancel_action'] = 'You have canceled the action'; +$string['overview']='Overview : '; +$string['game_point_error']='Points are required'; +$string['game_event_error']='Event is required'; +$string['game_name_error']='Name required'; + +>>>>>>> 42271d072b5508617432803ceb2659d2d3067682 diff --git a/notemyprogress/lang/es/local_notemyprogress.php b/notemyprogress/lang/es/local_notemyprogress.php index 79899c07d9190a6bfcf527c1b858de22117a74cd..400b3415a3483f77d728561b9965dcc694f295fb 100644 --- a/notemyprogress/lang/es/local_notemyprogress.php +++ b/notemyprogress/lang/es/local_notemyprogress.php @@ -714,6 +714,7 @@ $string['fml_settings_bddport_default'] = '27017'; $string['fml_settings_bddname_label'] = 'Nombre de la base de datos'; $string['fml_settings_bddname_description'] = 'Este parámetro designa el nombre de la base de datos MongoDB en la que se guardará la información.'; $string['fml_settings_bddname_default'] = 'Vacío'; +<<<<<<< HEAD //Planning /* Global */ @@ -1094,3 +1095,76 @@ $string['group_allstudent'] = 'Todos los estudiantes'; /* Admin Settings */ $string['nmp_use_navbar_menu'] = 'Habilitar nuevo menú'; $string['nmp_use_navbar_menu_desc'] = 'Despliega el menú del plugin en la barra de navegación superior, del contrario incluirá el menú en el bloque de navegación.'; +======= +/* Gamification */ +$string['EnableGame']="Desactivar/Activar :"; +$string['studentRanking1']="¿Quieres aparecer en el ranking ? "; +$string['studentRanking2']="/!\ Te verán todos los inscritos en este curso que hayan aceptado. Aceptar es definitivo: "; +$string['studentRanking3']="Acceptar"; +$string['gamification_denied'] = 'La gamificación ha sido desactivada por su maestro'; +$string['tg_colon'] = '{$a->a}: {$a->b}'; +$string['tg_section_title'] = 'Configuración de gamificación del curso'; +$string['tg_section_help_title'] = 'Configuración de gamificación del curso'; +$string['tg_section_help_description'] = 'Puede dar la opción de gamificación a los estudiantes del curso.'; +$string['tg_save_warning_title'] = "¿Estás seguro de que quieres guardar los cambios?"; +$string['tg_save_warning_content'] = "Si cambia la configuración de la gamificación cuando el curso ya ha comenzado, los datos pueden perderse ..."; +$string['tg_confirm_ok'] = "Guardar"; +$string['tg_confirm_cancel'] = "Cancelar"; +$string['tg_save'] = "Guardar configuración"; +$string['tg_section_preview'] = 'Avance'; +$string['tg_section_experience'] = 'Puntos de experiencia'; +$string['tg_section_information'] = 'Información'; +$string['tg_section_ranking'] = 'Clasificación/informe'; +$string['tg_section_settings'] = 'Ajustes'; + +$string['tg_section_points'] = 'puntos'; +$string['tg_section_description'] = 'Descripción'; +$string['tg_section_no_description'] = 'Sin descripción'; +$string['tg_section_no_name'] = 'Sin nombre'; + +$string['tg_section_preview_next_level'] = 'al siguiente nivel'; +$string['tg_section_ranking_ranking_text'] = 'Clasificación'; +$string['tg_section_ranking_level'] = 'Nivel'; +$string['tg_section_ranking_student'] = 'Alumna'; +$string['tg_section_ranking_total'] = 'Total'; +$string['tg_section_ranking_progress'] = 'Progreso %'; + +$string['tg_section_settings_appearance'] = 'Apariencia'; +$string['tg_section_settings_appearance_title'] = 'Título'; +$string['tg_section_settings_levels'] = 'Configuración de nivel'; +$string['tg_section_settings_levels_quantity'] = 'Nivel'; +$string['tg_section_settings_levels_base_points'] = 'Puntos base'; +$string['tg_section_settings_levels_calculated'] = 'automático'; +$string['tg_section_settings_levels_manually'] = 'A mano'; +$string['tg_section_settings_levels_name'] = 'Nombre'; +$string['tg_section_settings_levels_required'] = 'Se requieren puntos'; +$string['tg_section_settings_rules'] = 'Establecimiento de reglas'; +$string['tg_section_settings_add_rule'] = 'Agregar nueva regla'; +$string['tg_section_settings_earn'] = 'Para este evento, gane:'; +$string['tg_section_settings_select_event'] = 'Seleccione un evento'; +$string['gm_Chart_Title']='Tabla de esparcimiento'; +$string['gm_Chart_Y']='Alumno'; + +$string['tg_timenow'] = 'Justo ahora'; +$string['tg_timeseconds'] = '{$a}s atrás'; +$string['tg_timeminutes'] = '{$a}m atrás'; +$string['tg_timehours'] = '{$a}h atrás'; +$string['tg_timedays'] = '{$a}d atrás'; +$string['tg_timeweeks'] = '{$a}w atrás'; +$string['tg_timewithinayearformat'] = '%b %e'; +$string['tg_timeolderyearformat'] = '%b %Y'; + +/* General Errors */ +$string['fml_api_error_network'] = "Se ha producido un error en la comunicación con el servidor."; +$string['fml_api_invalid_data'] = 'Datos Incorrectos'; +$string['fml_api_json_decode_error'] = 'Error en decodificación de datos enviados'; +$string['fml_api_invalid_token_error'] = 'El token enviado en la transacción no es válido, actualice la página'; +$string['fml_api_invalid_transaction'] = 'La solicitud es incorrecta'; +$string['fml_api_invalid_profile'] = 'No puedes hacer esta acción, tu perfil es incorrecto'; +$string['fml_api_save_successful'] = 'Los datos se han guardado correctamente en el servidor'; +$string['fml_api_cancel_action'] = 'Has cancelado la acción'; +$string['overview']='Visión de conjunto : '; +$string['game_point_error']='Los puntos son requeridos'; +$string['game_event_error']='El evento es requerido'; +$string['game_name_error']='Se requiere el nombre'; +>>>>>>> 42271d072b5508617432803ceb2659d2d3067682 diff --git a/notemyprogress/lang/fr/local_notemyprogress.php b/notemyprogress/lang/fr/local_notemyprogress.php index bda740ecf1def50b47f641564576156088fe5cde..2bec6abd81ca5e228d815eef004c39b4dd62987d 100644 --- a/notemyprogress/lang/fr/local_notemyprogress.php +++ b/notemyprogress/lang/fr/local_notemyprogress.php @@ -718,6 +718,7 @@ $string['fml_settings_bddport_default'] = '27017'; $string['fml_settings_bddname_label'] = 'Nom de la base de données'; $string['fml_settings_bddname_description'] = 'Ce paramètre désigne le nom de la base de données MongoDB dans laquelle vont être enregistrées les informations.'; +<<<<<<< HEAD $string['fml_settings_bddname_default'] = 'Vide'; //Planning @@ -1093,3 +1094,77 @@ $string['group_allstudent'] = "Tous les étudiants"; /* Admin Settings */ $string['nmp_use_navbar_menu'] = 'Activer le nouveau menu'; $string['nmp_use_navbar_menu_desc'] = 'Afficher le menu du plugin dans la barre de navigation supérieure, sinon il inclura le menu dans le bloc de navigation.'; +======= + +/* Gamification */ +$string['EnableGame']="Désactiver/Activer :"; +$string['studentRanking1']="Voulez vous apparaitre dans le ranking board ? "; +$string['studentRanking2']= "/!\ Tout les inscrits à ce cours ayant accepté vous verrons. Accepter est définitif:"; +$string['studentRanking3']="Accepter"; +$string['gamification_denied'] = 'La gamification a été désactivée par votre professeur'; +$string['tg_colon'] = '{$a->a}: {$a->b}'; +$string['tg_section_title'] = 'Gamification :'; +$string['tg_section_help_title'] = 'Paramètres de gamification des cours'; +$string['tg_section_help_description'] = 'Vous pouvez donner la possibilité de gamification aux étudiants du cours.'; +$string['tg_save_warning_title'] = "Êtes-vous sûr de vouloir enregistrer les modifications?"; +$string['tg_save_warning_content'] = "Si vous modifiez les paramètres de la gamification au début du cours, les données peuvent être perdues ..."; +$string['tg_confirm_ok'] = "Sauver"; +$string['tg_confirm_cancel'] = "Annuler"; +$string['tg_save'] = "Enregistrer la configuration"; +$string['tg_section_preview'] = 'Point de vue étudiant'; +$string['tg_section_experience'] = 'Points d\'experience'; +$string['tg_section_information'] = 'Information'; +$string['tg_section_ranking'] = 'Classement / rapport'; +$string['tg_section_settings'] = 'Réglages'; + +$string['tg_section_points'] = 'points'; +$string['tg_section_description'] = 'Description'; +$string['tg_section_no_description'] = 'Pas de description'; +$string['tg_section_no_name'] = 'Sans nom'; + +$string['tg_section_preview_next_level'] = 'au niveau supérieur'; +$string['tg_section_ranking_ranking_text'] = 'Classement'; +$string['tg_section_ranking_level'] = 'Niveau'; +$string['tg_section_ranking_student'] = 'Élève'; +$string['tg_section_ranking_total'] = 'Total'; +$string['tg_section_ranking_progress'] ='Progréssion %'; + +$string['tg_section_settings_appearance'] = 'Apparence'; +$string['tg_section_settings_appearance_title'] = 'Titre'; +$string['tg_section_settings_levels'] = 'Paramètres de niveau'; +$string['tg_section_settings_levels_quantity'] = 'Niveaux'; +$string['tg_section_settings_levels_base_points'] = 'Points de base'; +$string['tg_section_settings_levels_calculated'] = 'Automatique'; +$string['tg_section_settings_levels_manually'] = 'Manuellement'; +$string['tg_section_settings_levels_name'] = 'Nom'; +$string['tg_section_settings_levels_required'] = 'Points requis'; +$string['tg_section_settings_rules'] = 'Liste des régles'; +$string['tg_section_settings_add_rule'] = 'Nouvelle règle'; +$string['tg_section_settings_earn'] = 'Pour cet événement, victoire:'; +$string['tg_section_settings_select_event'] = 'Sélectionnez un événement'; +$string['gm_Chart_Title']='Graphique de répartion'; +$string['gm_Chart_Y']='Etudiants'; + +$string['tg_timenow'] = 'Juste maintenant'; +$string['tg_timeseconds'] = 'il y a {$a}s '; +$string['tg_timeminutes'] = 'il y a {$a}m '; +$string['tg_timehours'] = 'il y a {$a}h '; +$string['tg_timedays'] = 'il y a {$a}d '; +$string['tg_timeweeks'] = 'il y a {$a}w '; +$string['tg_timewithinayearformat'] = '%b %e'; +$string['tg_timeolderyearformat'] = '%b %Y'; + +/* General Errors */ +$string['fml_api_error_network'] = "Une erreur s'est produite dans la communication avec le serveur."; +$string['fml_api_invalid_data'] = 'Données incorrectes'; +$string['fml_api_json_decode_error'] = 'Décodage d erreur de données envoyées'; +$string['fml_api_invalid_token_error'] = 'Le jeton envoyé dans la transaction n\'est pas valide, veuillez actualiser la page'; +$string['fml_api_invalid_transaction'] = 'La demande est incorrecte'; +$string['fml_api_invalid_profile'] = 'Vous ne pouvez pas faire cette action, votre profil est incorrect'; +$string['fml_api_save_successful'] = 'Les données ont été enregistrées avec succès sur le serveur'; +$string['fml_api_cancel_action'] = 'Vous avez annulé l\'action'; +$string['overview']='Vue d\'ensemble : '; +$string['game_point_error']='Veuillez saisir les points'; +$string['game_event_error']='Veuillez saisir l\'évènement'; +$string['game_name_error']='Le nom est requis'; +>>>>>>> 42271d072b5508617432803ceb2659d2d3067682 diff --git a/notemyprogress/lib.php b/notemyprogress/lib.php index bae1b722ef8c9a293c1e90ede045de5e435aaa92..b398bb158ce96de7b8248683955bbf1c5855bb94 100644 --- a/notemyprogress/lib.php +++ b/notemyprogress/lib.php @@ -107,13 +107,19 @@ function local_notemyprogress_render_navbar_output(\renderer_base $renderer) array_push($items, local_notemyprogress_new_menu_item(s($text), $url)); } +<<<<<<< HEAD //ADD if (has_capability('local/notemyprogress:logs', $context) && $configuration_is_set) { +======= + //ADD menu items + if(has_capability('local/notemyprogress:logs', $context) && $configuration_is_set){ +>>>>>>> 42271d072b5508617432803ceb2659d2d3067682 $text = get_string('menu_logs', 'local_notemyprogress'); $url = new moodle_url('/local/notemyprogress/logs.php?courseid=' . $COURSE->id); array_push($items, local_notemyprogress_new_menu_item(s($text), $url)); } +<<<<<<< HEAD if (has_capability('local/notemyprogress:teacher_planning', $context) && $configuration_is_set) { $text = get_string('menu_planning', 'local_notemyprogress'); $url = new moodle_url('/local/notemyprogress/metareflexion.php?courseid=' . $COURSE->id); @@ -128,6 +134,19 @@ function local_notemyprogress_render_navbar_output(\renderer_base $renderer) +======= + if(has_capability('local/notemyprogress:teacher_gamification', $context) && $configuration_is_set){ + $text = 'Gamification'; + $url = new moodle_url('/local/notemyprogress/gamification.php?courseid='.$COURSE->id); + array_push($items, local_notemyprogress_new_menu_item(s($text), $url)); + } + if(has_capability('local/notemyprogress:student_gamification', $context) && !is_siteadmin() && $configuration_is_set){ + $text = 'Gamification'; + $url = new moodle_url('/local/notemyprogress/student_gamification.php?courseid='.$COURSE->id); + array_push($items, local_notemyprogress_new_menu_item(s($text), $url)); + } + +>>>>>>> 42271d072b5508617432803ceb2659d2d3067682 $params = [ "title" => get_string('menu_main_title', 'local_notemyprogress'), "items" => $items diff --git a/notemyprogress/locallib.php b/notemyprogress/locallib.php index 8c78722ebc231653fa3640e3dff1e7a4fdf1e06f..680c1a3ab9db09a36003e13184969201369e667a 100644 --- a/notemyprogress/locallib.php +++ b/notemyprogress/locallib.php @@ -124,3 +124,119 @@ function local_notemyprogress_add_selected_property($groups, $groupid = null){ } return $groups; } + +//////////////////////////////////// +// Gamification function /// +//////////////////////////////////// +function local_notemyprogress_generate_token($courseid, $userid, $profile){ + $key = local_notemyprogress_get_token_signature(); + $payload = array( + "uid" => $userid, + "cid" => $courseid, + "pro" => $profile, + ); + $time = local_notemyprogress_get_token_time_valid(); + if ($time) { + $date = new DateTime(); + $date = $date->format('U'); + $payload['exp'] = intval($date) + $time; + } + return \local_notemyprogress\jwt\JWT::encode($payload, $key); +} +function local_notemyprogress_get_token_signature() { + $key = get_config("local_notemyprogress", "token_signature"); + if (empty($key)) { + $key = "m73YvSn2mhFVeXtut5UY"; // default signature + } + return $key; +} + +function local_notemyprogress_get_token_time_valid() { + return intval(get_config("local_notemyprogress", "token_time_valid")); +} + +function local_notemyprogress_validate_token($token){ + try { + global $DB; + $key = local_notemyprogress_get_token_signature(); + + $token = validate_param($token, PARAM_TEXT); + + $decoded = \local_notemyprogress\jwt\JWT::decode($token, $key, array('HS256')); + + $userid = validate_param($decoded->uid, PARAM_INT); + $courseid = validate_param($decoded->cid, PARAM_INT); + + $COURSE = $DB->get_record('course', array('id' => $courseid), '*', MUST_EXIST); + $USER = $DB->get_record('user', array('id' => $userid), '*', MUST_EXIST); + + require_login($COURSE, false); + $context = context_course::instance($courseid); + require_capability('local/notemyprogress:ajax', $context); + + $result = new stdClass(); + $result->courseid = $COURSE->id; + $result->userid = $USER->id; + $result->profile = $decoded->pro; + + return $result; + } catch (Exception $e) { + $message = get_string('fml_api_invalid_token_error', 'local_notemyprogress'); + local_notemyprogress_ajax_response(null, $message, false, 403); + } + function local_notemyprogress_save_gamification_config($courseid, $userid, $rules, $levels, $settings, $url,$enable){ + // \local_notemyprogress\logs::create( + // "setgamification", + // "configweeks", + // "saved", + // "weeks_settings", + // $url, + // 4, + // $userid, + // $courseid + // ); + $logs = new \local_notemyprogress\logs($courseid, $userid); + $logs->addLogsNMP("Saved", "section", "CONFIGURATION_GAMIFICATION", "configuration_gamification", $url, "GamificationSaved"); + + $configLevels = new \local_notemyprogress\configgamification($courseid, $userid); + $configLevels->save_levels($levels, $settings, $rules); + $configLevels->save_enable($enable); + $message = get_string('fml_api_save_successful', 'local_notemyprogress'); + local_notemyprogress_ajax_response(true, $message); + } + + function local_notemyprogress_validate_action_and_profile($action, $profile){ + $message = ""; + + // Validate action + try { + $action = validate_param($action, PARAM_ALPHA); + } catch (Exception $e) { + $message = get_string('fml_api_invalid_transaction', 'local_notemyprogress'); + } + + // Validate profile + if ($profile == "teacher") { + if ($action != "saveconfigweek" && $action != "changegroup" && $action != "worksessions" && + $action != "assignments" && $action != "sendmail" && $action != "quiz" && + $action != "wordcloud" && $action != "dropoutdata" && $action != "downloadlogs" && + $action != "saveinteraction" && $action != "saveconfiggamification") { + $message = get_string('fml_api_invalid_transaction', 'local_notemyprogress'); + } + } elseif ($profile == "student") { + if ($action != "studentsessions" && $action != "studentassigns" && + $action != "studenttimes" && $action != "saveinteraction") { + $message = get_string('fml_api_invalid_transaction', 'local_notemyprogress'); + } + } else { + $message = get_string('fml_api_invalid_profile', 'local_notemyprogress'); + } + + if ($message != "") { + local_notemyprogress_ajax_response(null, $message, false, 400); + } + + return $action; + } +} + diff --git a/notemyprogress/pix/badge.png b/notemyprogress/pix/badge.png new file mode 100644 index 0000000000000000000000000000000000000000..a8967018c82681ff21d40c98ba76980a64c70ca6 Binary files /dev/null and b/notemyprogress/pix/badge.png differ diff --git a/notemyprogress/pix/rankImage.jpg b/notemyprogress/pix/rankImage.jpg new file mode 100644 index 0000000000000000000000000000000000000000..d76465c8405a7cbe5825e39e070d0709e5d4b493 Binary files /dev/null and b/notemyprogress/pix/rankImage.jpg differ diff --git a/notemyprogress/prueba.php b/notemyprogress/prueba.php index f20ae14939f78114f144ac7374c4086c3e2918ce..5c3f44e44f9e2fb696965e09136be37c3ecc701e 100644 --- a/notemyprogress/prueba.php +++ b/notemyprogress/prueba.php @@ -47,7 +47,7 @@ $content = [ -$PAGE->requires->js_call_amd('local_notemyprogress/prueba','init', ['content' => $content]); +$PAGE->requires->js_call_amd('local_notemyprogress/prueba', 'init', ['content' => $content]); echo $OUTPUT->header(); echo $OUTPUT->render_from_template('local_notemyprogress/prueba', ['content' => $content]); -echo $OUTPUT->footer(); \ No newline at end of file +echo $OUTPUT->footer(); diff --git a/notemyprogress/student_gamification.php b/notemyprogress/student_gamification.php new file mode 100644 index 0000000000000000000000000000000000000000..0ebb905fc2ae58fef0871d6bb6171302f16129ea --- /dev/null +++ b/notemyprogress/student_gamification.php @@ -0,0 +1,109 @@ +<?php +// This file is part of Moodle - http://moodle.org/ +// +// Moodle is free software: you can redistribute it and/or modify +// it under the terms of the GNU General Public License as published by +// the Free Software Foundation, either version 3 of the License, or +// (at your option) any later version. +// +// Moodle is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +// GNU General Public License for more details. +// +// You should have received a copy of the GNU General Public License +// along with Moodle. If not, see <http://www.gnu.org/licenses/>. + +/** + * local notemyprogress + * + * @package local_notemyprogress + * @copyright 2020 Edisson Sigua <edissonf.sigua@gmail.com>, Bryan Aguilar <bryan.aguilar6174@gmail.com> + * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later + */ +require_once('locallib.php'); +global $DB, $COURSE, $USER, $PAGE, $OUTPUT; + +$courseid = required_param('courseid', PARAM_INT); +$course = $DB->get_record('course', array('id' => $courseid), '*', MUST_EXIST); +$context = context_course::instance($course->id); + +$url = '/local/notemyprogress/student_gamification.php'; +local_notemyprogress_set_page($course, $url); + +require_capability('local/notemyprogress:usepluggin', $context); +require_capability('local/notemyprogress:student_gamification', $context); + +$configgamification = new \local_notemyprogress\configgamification($COURSE, $USER); +$es = new \local_notemyprogress\event_strategy($COURSE, $USER); + +$userid=$es->get_user_info()->uid; + +$selectRankable = "SELECT rankable from {notemyprogress_xp} where courseid=? AND userid=? "; +$rankable = $DB->get_record_sql($selectRankable, array("courseid="=>($courseid),"timecreated="=>$userid)); +if($rankable->rankable =='1'){ + $rankableSend = "true"; +} +$content = [ + 'strings' =>[ + 'title' => get_string('tg_section_title', 'local_notemyprogress'), + 'help_title' => get_string('tg_section_help_title', 'local_notemyprogress'), + 'help_description' => get_string('tg_section_help_description', 'local_notemyprogress'), + 'helplabel' => get_string("helplabel","local_notemyprogress"), + 'error_network' => get_string('fml_api_error_network', 'local_notemyprogress'), + 'save_successful' => get_string('fml_api_save_successful', 'local_notemyprogress'), + 'cancel_action' => get_string('fml_api_cancel_action', 'local_notemyprogress'), + 'save_warning_title' => get_string('tg_save_warning_title', 'local_notemyprogress'), + 'save_warning_content' => get_string('tg_save_warning_content', 'local_notemyprogress'), + 'confirm_ok' => get_string('tg_confirm_ok', 'local_notemyprogress'), + 'confirm_cancel' => get_string('tg_confirm_cancel', 'local_notemyprogress'), + 'exitbutton' => get_string("exitbutton","local_notemyprogress"), + 'save' => get_string("tg_save","local_notemyprogress"), + 'experience' => get_string("tg_section_experience","local_notemyprogress"), + 'information' => get_string("tg_section_information","local_notemyprogress"), + 'ranking' => get_string("tg_section_ranking","local_notemyprogress"), + 'points' => get_string("tg_section_points","local_notemyprogress"), + 'no_description' => get_string("tg_section_no_description","local_notemyprogress"), + 'description' => get_string("tg_section_description","local_notemyprogress"), + 'to_next_level' => get_string("tg_section_preview_next_level","local_notemyprogress"), + 'ranking_text' => get_string("tg_section_ranking_ranking_text","local_notemyprogress"), + 'level' => get_string("tg_section_ranking_level","local_notemyprogress"), + 'student' => get_string("tg_section_ranking_student","local_notemyprogress"), + 'total' => get_string("tg_section_ranking_total","local_notemyprogress"), + 'progress' => get_string("tg_section_ranking_progress","local_notemyprogress"), + 'rankable'=> $rankableSend, + 'studentRanking1'=>get_string("studentRanking1","local_notemyprogress"), + 'studentRanking2'=>get_string("studentRanking2","local_notemyprogress"), + 'studentRanking3'=>get_string("studentRanking3","local_notemyprogress"), + 'overview'=>get_string("overview","local_notemyprogress"), + ], + 'levels_data' => $configgamification->get_levels_data(), + 'indicators' => $es->get_user_info(), + 'ranking' => $es->get_ranking(1), + +]; + +$templatecontext = [ + 'image' => $OUTPUT->image_url('badge', 'local_notemyprogress'), + 'rankImage' => $OUTPUT->image_url('rankImage', 'local_notemyprogress') +]; + +$maxTimeSql = "SELECT MAX(timecreated) as maximum from {notemyprogress_gamification} where courseid=? "; +$timecrated = $DB->get_record_sql($maxTimeSql, array("courseid="=>($courseid))); + +$sql = "SELECT enablegamification from {notemyprogress_gamification} where courseid=? AND timecreated=? "; +$value = $DB->get_record_sql($sql, array("courseid="=>($courseid),"timecreated="=>$timecrated->maximum)); + +$PAGE->requires->js_call_amd('local_notemyprogress/student_gamification','init', ['content' => $content]); +echo $OUTPUT->header(); +if ($value->enablegamification == 0){ + // echo " non available gamification value : "; + // echo $value->enablegamification; + // echo " timecrated :"; + // echo $timecrated->maximum; + echo get_string("gamification_denied","local_notemyprogress"); +}else{ + echo $OUTPUT->render_from_template('local_notemyprogress/student_gamification', $templatecontext); +} + +echo $OUTPUT->footer(); \ No newline at end of file diff --git a/notemyprogress/templates/gamification.mustache b/notemyprogress/templates/gamification.mustache new file mode 100644 index 0000000000000000000000000000000000000000..c40a8ac215b5265c43df7a50cc3a46dba30f9185 --- /dev/null +++ b/notemyprogress/templates/gamification.mustache @@ -0,0 +1,257 @@ +<v-app id="gamification" class="notemyprogress"> + <v-main> + <pageheader :pagetitle="strings.title" + :helptitle="strings.helplabel" + :exitbutton="strings.exitbutton" + :helpcontents="get_help_content()" + :token="token" + @open_help_section_modal="openHelpSectionModalEvent"> + </pageheader> + <template> + <v-container pa-8> + <!-- Server message --> + <v-row class="justify-center" v-if="notifications.length > 0"> + <v-col cols="8"> + <v-alert v-for="(value, index, key) in notifications" + :type="value.type" + class="text-center" dense text dismissible> + <span v-text="value.message"></span> + </v-alert> + </v-col> + </v-row> + <v-card + class="align-center text-center flex" + height="100" + elevation ="1"> + <h4 v-text="strings.enable"><h4> + <v-switch + v-model ="swDisableEnable" + inset + color="red darken-3" + class="pt-800 px-800 justify-center" + @Change = disableEnable(swDisableEnable); + ></v-switch> + </v-card> + <v-row> + <v-col> + <v-tabs v-model="tab" background-color="transparent"> + <v-tab v-text="strings.settings_level"></v-tab> + <v-tab v-text="strings.preview"></v-tab> + <v-tab v-text="strings.settings"></v-tab> + </v-tabs> + <v-tabs-items v-model="tab"> + <v-tab-item> <!-- Level and settings --> + <v-row class="pt-8 px-8 justify-center"> + <v-row> + <v-col cols="6" sm="4" md="3" lg="5"> + <v-text-field + type="number" + readonly + :label="strings.quantity" + v-model="levelsData.length" + append-outer-icon="mdi-plus-circle" + prepend-icon="mdi-minus-circle" + @click:append-outer="addLevel()" + @click:prepend="removeLevel()" + ></v-text-field> + </v-col> + <v-col cols="6" sm="4" md="3" lg="2"> + <v-text-field :label="strings.base_points" v-model="pointsBase" type="number"> + </v-text-field> + </v-col> + <v-col cols="12" sm="4" md="4" lg="3"> + <v-btn-toggle v-model="setPointsOption" tile group> + <v-btn value="calculated" v-text="strings.calculated"></v-btn> + <v-btn value="manually" v-text="strings.manually"></v-btn> + </v-btn-toggle> + </v-col> + </v-row> + </v-row> + <v-row class="pb-5 px-8"> + <v-row v-for="(level, index) in levelsData" cols="12" sm="6" md="4" lg="3"> + <v-card class="pt-5 align-center text-center"> + <v-col :content="level.lvl" bottom offset-x="20" offset-y="20"> + <v-avatar size="100"> + <v-img src="{{{image}}}"></v-img> + </v-avatar> + </v-col> + <v-card-text class="text--primary text-center"> + <v-text-field :label="strings.name" :rules="[v => !!v || strings.nameError]" required v-model="level.nam" type="text"> + </v-text-field> + <v-text-field :label="strings.description" v-model="level.des" type="text"> + </v-text-field> + <v-text-field :disabled="setPointsOption === 'calculated'" :label="strings.levels_required" v-model="calculatePoints(index)" type="number"> + </v-text-field> + </v-card-text> + </v-card> + </v-row> + </v-row> + <v-row class="pb-10 justify-center"> + <v-btn @click="save_changes('levelsEdit')" v-text="strings.save" class="white--text" color="#118AB2"></v-btn> + </v-row> + </v-tab-item> + <v-tab-item> <!-- Student preview tab --> + <v-row class="justify-center"> + <v-col cols="12" sm="11" md="7" lg="6" class="d-flex py-10"> + <v-card class="align-center text-center flex"> + <h4 class="py-5" v-text="settings.tit"></h4> + <p v-if="levelsData[0].nam" v-text="levelsData[0].nam"></p> + <v-badge + :content="levelsData[0].lvl" + bottom + offset-x="20" + offset-y="20" + > + <v-avatar size="100"> + <v-img src="{{{image}}}"></v-img> + </v-avatar> + </v-badge> + <v-card-text class="py-5"> + <small class="d-inline" v-text="levelsData[1].points"></small> + <sup>xp</sup> + <small v-text="strings.to_next_level"></small> + <v-progress-linear + color="#118AB2" + :value="0" + height="8" + > + </v-progress-linear> + <p v-if="levelsData[0].des" class="pt-5" v-text="levelsData[0].des"></p> + <h3 :class="[ !levelsData[0].des ? 'pt-5' : 'pt-0']" + v-text="levelsData[0].points +' '+strings.points"></h3> + </v-card-text> + <v-card-actions> + <p class="py-0 px-2" v-text="settings.des"></p> + </v-card-actions> + </v-card> + </v-col> + </v-row> <!-- Change the preview --> + <v-row class="pt-5 px-8 justify-center"> + <v-col cols="12" md="12"> + <h4 v-text="strings.appearance"></h4> + </v-col> + <v-col cols="12" md="12" class=""> + <v-row class="justify-center"> + <v-col cols="12" xs="10" md="6"> + <v-text-field :label="strings.appearance_title" v-model="settings.tit"></v-text-field> + </v-col> + </v-row> + <v-row class="justify-center"> + <v-col cols="12" xs="10" md="6"> + <v-textarea :label="strings.description" auto-grow v-model="settings.des"></v-textarea> + </v-col> + </v-row> + </v-col> + </v-row> + <v-row class="pb-10 justify-center"> + <v-btn @click="save_changes('studentSideEdit')" v-text="strings.save" class="white--text" color="#118AB2"></v-btn> + </v-row> + </v-tab-item> + <v-tab-item> + <v-row class="pt-5 px-8 justify-center justify-sm-space-between "> + <v-col cols="12" sm="6" md="5" lg="5"> + <h4 v-text="strings.rules"></h4> + </v-col> + <v-col cols="6" sm="5" md="4" lg="4"> + <v-btn + block v-text="strings.add_rule" + @click="addRule()" + class="white--text" + color="#118AB2"> + </v-btn> + </v-col> + </v-row> + <v-row class="pt-5 pb-5 px-8"> + <v-col v-for="(rule, index) in rulesData" cols="12" md="12"> + <v-card class="align-center text-center"> + <v-card-text class="text--primary text-center"> + <v-row class="align-center justify-space-around"> + <v-col cols="12" sm="4" md="3"> + <v-text-field + v-model="rule.points" + :label="strings.earn" + :rules="[v => !!v || strings.pointError]" + :suffix="strings.points" + type="number"> + </v-text-field> + </v-col> + <v-col cols="12" sm="6" md="7"> + <v-select + v-model="rule.rule" + attach + :menu-props="{ top: true, offsetY: true }" + :items="events" + item-text='name' + item-value='event' + :label="strings.select_event" + :rules="[v => !!v || strings.eventError]" + required> + </v-select> + </v-col> + <v-col cols="12" sm="2" md="1"> + <v-btn :disabled="rulesData.length < 3" icon @click="removeRule(index)"> + <v-icon>mdi-delete</v-icon> + </v-btn> + </v-col> + </v-row> + </v-card-text> + </v-card> + </v-col> + + </v-row> + <v-row class="pb-10 justify-center"> + <v-btn @click="save_changes('rulesEdit')" v-text="strings.save" class="white--text" color="#118AB2"></v-btn> + </v-row> + </v-tab-item> + </v-tabs-items> + </v-col> + + <v-col> + <v-row class="py-5 px-8"> + <v-col cols="12" md="12"> + <v-data-table + :headers="table_headers()" + :items="ranking" + item-key="id" + :items-per-page="7" + > + <template v-slot:item.level="{ item }"> + <v-badge + inline + bordered + :content="item.level" + > + <v-avatar size="30"> + <img src="{{{image}}}"> + </v-avatar> + </v-badge> + </template> + <template v-slot:item.progress_percentage="{ item }"> + <v-progress-linear + color="#118AB2" + :value="item.progress_percentage" + height="8" + > + </v-progress-linear> + </template> + <template v-slot:item.total="{ item }"> + <p class="d-inline" v-text="item.total"></p> + <sup>xp</sup> + </template> + </v-data-table> + </v-col> + </v-row> + <v-row> + <chart + :container="'week_resourcess'" + :chart="chart_spread()" + :lang="strings.chart" + ></chart> + </v-row> + </v-col> + </v-row> + + </v-container> + </template> + </v-main> +</v-app> \ No newline at end of file diff --git a/notemyprogress/templates/student_gamification.mustache b/notemyprogress/templates/student_gamification.mustache new file mode 100644 index 0000000000000000000000000000000000000000..e464216de1cc646ed7a5d23197bbb90db37e66a2 --- /dev/null +++ b/notemyprogress/templates/student_gamification.mustache @@ -0,0 +1,161 @@ +<v-app id="student_gamification" class="notemyprogress"> + <v-main> + <pageheader :pagetitle="strings.title" + :helptitle="strings.helplabel" + :exitbutton="strings.exitbutton" + :helpcontents="get_help_content()" + :token="token" + @open_help_section_modal="openHelpSectionModalEvent"> + </pageheader> + <template> + <v-card> + <v-row> + <v-col cols=12 lg="6"> + <v-row class="justify-center"> + <v-col cols="12" sm="11" md="7" lg="6" class="d-flex py-10"> + <v-card class="align-center text-center flex"> + <h4 class="py-5" v-text="settings.tit"></h4> + <p v-if="levelInfo.nam" v-text="levelInfo.nam"></p> + <v-badge + :content="indicators.level" + bottom + offset-x="20" + offset-y="20"> + <v-avatar size="100"> + <v-img src="{{{image}}}"></v-img> + </v-avatar> + </v-badge> + <v-card-text> + <small class="d-inline" v-text="indicators.pointsToNext"></small> + <sup>xp</sup> + <small v-text="strings.to_next_level"></small> + <v-progress-linear + color="#118AB2" + :value="indicators.progress" + height="8" + > + </v-progress-linear> + <p v-if="levelInfo.des" class="pt-5" v-text="levelInfo.des"></p> + <h3 :class="[ !levelInfo.des ? 'pt-5' : 'pt-0']" + v-text="indicators.points +' '+strings.points"></h3> + <v-row class="justify-center text-left" v-for="action in activity" > + <v-col cols="5"> + <small v-text="action.description"></small> + </v-col> + <v-col cols="3"> + <small v-text="action.timeago"></small> + </v-col> + <v-col cols="3" sm="2"> + <small v-text="action.points + ' '+strings.points"></small> + </v-col> + </v-row> + </v-card-text> + <v-card-actions> + <p class="py-0 px-2" v-text="settings.des"></p> + </v-card-actions> + </v-card> + </v-col> + </v-row> + <v-col> + <h4 v-text=strings.overview></h4> + <v-row class="py-5 px-8"> + <v-col v-for="(level, index) in levelsData" cols="12" sm="6" md="3" class="d-flex"> + <v-card class="pt-5 align-center text-center flex"> + <v-badge + :content="level.lvl" + bottom + offset-x="20" + offset-y="20" + > + <v-avatar size="100"> + <v-img src="{{{image}}}"></v-img> + </v-avatar> + </v-badge> + <v-card-text class="text--primary text-center"> + <h6 v-if="level.nam" v-text="level.nam"></h6> + <p v-if="level.des" class="pt-4 text-left" v-text="level.des"></p> + <p class="mb-0 pb-0" v-text="level.points+' '+strings.points"></p> + </v-card-text> + </v-card> + </v-col> + </v-row> + </v-col> + </v-col> + <v-col cols=12 lg="6"> + <v-row v-if="strings.rankable"class="py-5 px-8"> + <v-col cols="12" md="12"> + <v-data-table + :headers="table_headers()" + :items="ranking" + item-key="id" + :items-per-page="7" + > + <template v-slot:item.level="{ item }"> + <v-badge + inline + bordered + :content="item.level" + > + <v-avatar size="30"> + <v-img src="{{{image}}}"></v-img> + </v-avatar> + </v-badge> + </template> + <template v-slot:item.progress_percentage="{ item }"> + <v-progress-linear + color="#118AB2" + :value="item.progress_percentage" + height="8" + > + </v-progress-linear> + </template> + <template v-slot:item.total="{ item }"> + <p class="d-inline" v-text="item.total"></p> + <sup>xp</sup> + </template> + </v-data-table> + + + + </v-col> + </v-row> + <v-row v-else> + <v-card + class="mx-auto" + max-width="90%" + outlined + > + <v-list-item three-line> + <v-list-item-content> + <v-list-item-title class="text-h5 mb-1" v-text=strings.studentRanking1> + </v-list-item-title> + <v-list-item-subtitle v-text=strings.studentRanking2></v-list-item-subtitle> + </v-list-item-content> + + <v-list-item-avatar + tile + size="80" + color="red" + + ><v-img src="{{{rankImage}}}"></v-img></v-list-item-avatar> + </v-list-item> + + <v-card-actions> + <v-btn + outlined + rounded + text + @click=activateRanking() + v-text=strings.studentRanking3 + > + </v-btn> + </v-card-actions> + </v-card> + </v-row> + </v-col> + </v-row> + </v-card> + + </template> + </v-main> +</v-app> \ No newline at end of file