var filiInfo = { css: null, exports: { onBeforeMount(props, state) { }, updateFiliStats() { let list = this.props.schoolList; let avg = list.reduce((s, e) => s + e.fields.moyenne, 0) / list.length; let avgCap = list.reduce((s, e) => s + e.fields.capa_fin, 0) / list.length; let avgSlc = list.reduce((s, e) => s + (e.fields.taux_acces_ens || 0), 0) / list.filter(e => e.fields.taux_acces_ens).length; this.state.courseNumber = list.length; this.state.average = Math.round(avg * 100) / 100; this.state.capacity = Math.floor(avgCap); this.state.selectivity = Math.floor(avgSlc); let pctFemmes = Math.round(list.reduce((s, e) => s + (e.fields.pct_f || 0), 0) / list.filter(e => e.fields.pct_f).length); this.state.genreStats = [{ name: "Hommes", short: "H", value: 100 - pctFemmes }, { name: "Femmes", short: "F", value: pctFemmes }]; let pctBG = Math.round(list.reduce((s, e) => s + (e.fields.part_acces_gen || 0), 0) / list.filter(e => e.fields.part_acces_gen).length); let pctBT = Math.round(list.reduce((s, e) => s + (e.fields.part_acces_tec || 0), 0) / list.filter(e => e.fields.part_acces_tec).length); let pctBP = Math.round(list.reduce((s, e) => s + (e.fields.part_acces_pro || 0), 0) / list.filter(e => e.fields.part_acces_pro).length); if (!pctBG) pctBG = 0; if (!pctBT) pctBT = 0; if (!pctBP) pctBP = 0; this.state.bacStats = [{ name: "Général", short: "Gen.", value: pctBG }, { name: "Technologique", short: "Tech.", value: pctBT }, { name: "Professionnel", short: "Pro.", value: pctBP }, { name: "Autre", short: "Au.", value: 100 - (pctBG + pctBT + pctBP) }]; let pctSM = Math.round(list.reduce((s, e) => s + e.fields.pct_sansmention, 0) / list.length); let pctAB = Math.round(list.reduce((s, e) => s + e.fields.pct_ab, 0) / list.length); let pctB = Math.round(list.reduce((s, e) => s + e.fields.pct_b, 0) / list.length); let pctTB = Math.round(list.reduce((s, e) => s + e.fields.pct_tb, 0) / list.length); let pctTBF = Math.round(list.reduce((s, e) => s + e.fields.pct_tbf, 0) / list.length); this.state.mentionStats = [{ name: "Sans Mention", short: "SM", value: pctSM }, { name: "Assez Bien", short: "AB", value: pctAB }, { name: "Bien", short: "B", value: pctB }, { name: "Très Bien", short: "TB", value: pctTB }, { name: "Très Bien + Félicitations", short: "TBF", value: pctTBF }, { name: "Non Spécifié", short: "NS", value: 100 - (pctSM + pctAB + pctB + pctTB + pctTBF) }]; }, onBeforeUpdate(props, state) { if (!props.schoolList || !props.schoolList.length) return; this.updateFiliStats(); } }, template: (template, expressionTypes, bindingTypes, getComponent) => template('
', [{ type: bindingTypes.IF, evaluate: _scope => _scope.props.shouldShowInfos, redundantAttribute: 'expr2138', selector: '[expr2138]', template: template('

/ \n / \n

Moyenne des admis

Nombre de formations

Capacité

', [{ redundantAttribute: 'expr2139', selector: '[expr2139]', expressions: [{ type: expressionTypes.TEXT, childNodeIndex: 0, evaluate: _scope => _scope.props.course.fili }] }, { redundantAttribute: 'expr2140', selector: '[expr2140]', expressions: [{ type: expressionTypes.TEXT, childNodeIndex: 0, evaluate: _scope => _scope.props.course.sousfili }] }, { redundantAttribute: 'expr2141', selector: '[expr2141]', expressions: [{ type: expressionTypes.TEXT, childNodeIndex: 0, evaluate: _scope => _scope.props.course.soussousfili }] }, { redundantAttribute: 'expr2142', selector: '[expr2142]', expressions: [{ type: expressionTypes.TEXT, childNodeIndex: 0, evaluate: _scope => _scope.state.average }] }, { redundantAttribute: 'expr2143', selector: '[expr2143]', expressions: [{ type: expressionTypes.TEXT, childNodeIndex: 0, evaluate: _scope => _scope.state.courseNumber }] }, { redundantAttribute: 'expr2144', selector: '[expr2144]', expressions: [{ type: expressionTypes.TEXT, childNodeIndex: 0, evaluate: _scope => _scope.state.capacity }] }, { type: bindingTypes.TAG, getComponent: getComponent, evaluate: _scope => 'title-progress', slots: [], attributes: [{ type: expressionTypes.ATTRIBUTE, name: 'title', evaluate: _scope => "Sélectivité" }, { type: expressionTypes.ATTRIBUTE, name: 'value', evaluate: _scope => _scope.state.selectivity }], redundantAttribute: 'expr2145', selector: '[expr2145]' }, { type: bindingTypes.TAG, getComponent: getComponent, evaluate: _scope => 'line-graph', slots: [], attributes: [{ type: expressionTypes.ATTRIBUTE, name: 'data', evaluate: _scope => _scope.state.genreStats }], redundantAttribute: 'expr2146', selector: '[expr2146]' }, { type: bindingTypes.TAG, getComponent: getComponent, evaluate: _scope => 'line-graph', slots: [], attributes: [{ type: expressionTypes.ATTRIBUTE, name: 'data', evaluate: _scope => _scope.state.bacStats }], redundantAttribute: 'expr2147', selector: '[expr2147]' }, { type: bindingTypes.TAG, getComponent: getComponent, evaluate: _scope => 'line-graph', slots: [], attributes: [{ type: expressionTypes.ATTRIBUTE, name: 'data', evaluate: _scope => _scope.state.mentionStats }], redundantAttribute: 'expr2148', selector: '[expr2148]' }]) }]), name: 'fili-info' }; export { filiInfo as default };