Publicador de Conteúdos e Mídias

Um erro ocorreu enquanto processava o modelo.
The following has evaluated to null or missing:
==> isEMED  [in template "20102#20129#438394" at line 4056, column 15]

----
Tip: If the failing expression is known to legally refer to something that's sometimes null or missing, either specify a default value like myOptionalVar!myDefault, or use <#if myOptionalVar??>when-present<#else>when-missing</#if>. (These only cover the last step of the expression; to cover the whole expression, use parenthesis: (myOptionalVar.foo)!myDefault, (myOptionalVar.foo)??
----

----
FTL stack trace ("~" means nesting-related):
	- Failed at: #if !isEMED  [in template "20102#20129#438394" at line 4056, column 9]
----
1<#assign 
2  isEditMode = themeDisplay.getURLCurrent()?contains('p_l_mode=edit') 
3/> 
4<!-- Essa verificação é necessária para que não encaminhe erros de freemarker ao KIBANA ao acessar a página de edição dos componentes --> 
5<#if isEditMode > 
6  <h3>Modo de edição identificado</h3> 
7<#else> 
8 
9<style> 
10 
11  .ssp:not(.liferay-instance) .ssp-como-me-matricular__passo-passo-card { 
12      background: white; 
13      width: 100%; 
14      padding: 32px 52px; 
15      box-shadow: 2px 5px 12px #00000040; 
16      border-radius: 20px; 
17      display: flex; 
18      flex-wrap: nowrap; 
19      justify-content: space-between; 
20      align-items: center; 
21
22 
23  .ssp:not(.liferay-instance) .ssp-como-me-matricular__passo-passo-card .item-passo-icone { 
24      max-width: 100%; 
25      height: 72px; 
26      margin-bottom: 10px; 
27
28 
29  .ssp:not(.liferay-instance) .ssp-como-me-matricular__section { 
30      background: #472247; 
31      border-top: 18px solid #792F7A; 
32      text-align: center; 
33      padding-bottom: 60px; 
34
35 
36  .ssp:not(.liferay-instance) .ssp-como-me-matricular__section .title-section-white::after { 
37       
38      
39      display: none; 
40      
41       
42
43   
44  .ssp:not(.liferay-instance) .ssp-como-me-matricular__section .title-section-white { 
45      color: white; 
46      font-size: 44px !important; 
47      margin-bottom: 32px !important; 
48      text-align:unset; 
49
50   
51  .ssp:not(.liferay-instance) .ssp-como-me-matricular__passo-passo-card .item-passo-title { 
52      font-size: 28px; 
53      color: #B767C2; 
54      font-weight: bold; 
55      line-height: 28px; 
56      margin: 0; 
57      margin-bottom:.5rem; 
58
59   
60 
61.ssp:not(.liferay-instance) .ssp-card-modal-forma-pagamento__icon-credit-card::after { 
62     
63  font-size: 18px; 
64     
65
66 
67.ssp:not(.liferay-instance) .ssp-card-modal-forma-pagamento__icon-boleto::after { 
68    
69  font-size: 18px; 
70   
71
72 
73.ssp:not(.liferay-instance) .ssp-card-modal-forma-pagamento__header { 
74  align-items:center; 
75  color:#454F63; 
76
77 
78.ssp:not(.liferay-instance) .ssp-card-modal-forma-pagamento__btn-close::after { 
79    font-family: "Font Awesome 6 Pro"; 
80    font-weight: normal; 
81    content: "\f00d"; 
82    font-style: normal; 
83    font-size:30px; 
84    cursor: pointer; 
85
86 
87.ssp:not(.liferay-instance) .ssp-card-modal-forma-pagamento__body { 
88     
89  padding:0 15px; 
90
91 
92.ssp-card-modal-forma-pagamento__tipos-content p { 
93 
94  color: #454F63!important; 
95  font-size: 14px!important; 
96
97 
98.ssp-card-modal-forma-pagamento__tipos-content strong { 
99 
100  font-weight: bold!important; 
101
102 
103.txt-desconto-oito{ 
104 
105  font-weight: 600!important; 
106  border: 1px solid #f2f2f2; 
107  border-right: 0; 
108  border-left: 0; 
109  padding: 10px 0; 
110
111 
112.next-mobile{ 
113    color: white; 
114    display: flex; 
115    align-items: center; 
116    text-decoration: none!important; 
117
118 
119.next-mobile:hover{ 
120    color: white; 
121    font-weight: normal!important; 
122
123 
124.next-mobile::before{ 
125    font-family: "Montserrat", sans-serif; 
126    content: "Próxima"; 
127    font-size: 14px; 
128    font-weight: 600; 
129    display: block; 
130    margin-right: 9px; 
131    color: white; 
132
133 
134.next-mobile.slick-arrow.slick-disabled{ 
135    opacity: 0.4; 
136
137 
138 
139/* Prev Mobile button */ 
140 
141 
142.prev-mobile{ 
143    color: white; 
144    display: flex; 
145    align-items: center; 
146    text-decoration: none; 
147    text-decoration: none!important; 
148
149 
150.prev-mobile:hover{ 
151    color: white; 
152    font-weight: normal!important; 
153
154 
155.prev-mobile::after{ 
156    font-family: "Montserrat", sans-serif; 
157    content: "Anterior"; 
158    font-weight: 600; 
159    font-size: 14px; 
160    display: block; 
161    margin-left: 9px; 
162    color: white; 
163
164 
165.prev-mobile.slick-arrow.slick-disabled{ 
166    opacity: 0.4; 
167
168 
169 
170.icon-ao-vivo{ 
171  font-size: 15px!important; 
172  margin: 0 3px; 
173
174 
175.ssp-card-detalhe-curso__tag-ao-vivo{ 
176  font-family: "Montserrat"; 
177  font-size: 19px; 
178  letter-spacing: 0px; 
179  color: #F77A3B; 
180
181 
182.selecione-unidade-title-custom{ 
183     
184  width:100%!important; 
185 
186
187 
188.recalcular{ 
189  background:#F6921E!important; 
190  border: solid 1px #F6921E!important; 
191
192 
193.ssp-card-detalhe-curso__description{ 
194 
195  font-family: "Montserrat"; 
196  max-width: 800px; 
197  font-size: 20px; 
198  font-weight: 500; 
199  font-stretch: normal; 
200  font-style: normal; 
201  line-height: 1.23; 
202  letter-spacing: normal; 
203  margin: 10px 0; 
204  text-align: left; 
205  color: #4f596f; 
206 
207
208 
209/* nova formatação para registro de interesse */ 
210.ssp:not(.liferay-instance) .ssp-aviso-novas-turmas__content { 
211    display: flex; 
212    flex-wrap: nowrap; 
213    justify-content: center; 
214    align-items: center; 
215    padding: 10px 0; 
216
217 
218/* Novas tags para formato de curso */ 
219 
220.ssp-card-detalhe-curso__tag-formato{ 
221   
222  font-size:18px; 
223  font-weight:600; 
224   
225
226 
227.icon-formato{ 
228  margin-right:7px; 
229
230 
231.online-aovivo{ 
232  position:relative; 
233   
234
235 
236.icon-small-wifi { 
237    font-size: 13px; 
238    position: absolute; 
239    left: -12px; 
240    top: -5px; 
241
242 
243.ssp-desconto-2022 .modal-extensao_txteconomiza { 
244  font-size: 14px !important; 
245  font-weight: 100 !important; 
246
247.ssp-desconto-2022 .ssp-card-oferta-curso__desconto-content .ssp-card-oferta-curso__valor-desconto { 
248  font-weight: 100 !important; 
249
250.ssp-desconto-2022 .modal-extensao-btn-conheca { 
251  border: 1px solid #474F61 !important; 
252  border-radius: 4px; 
253  color: #474F61 !important; 
254  font-size: 15px; 
255  height: 50px; 
256  margin-left: 0; 
257  display: flex; 
258  align-items: center; 
259  justify-content: center; 
260
261 
262.ssp-card-modal-forma-pagamento.ssp-desconto-2022 { 
263  color: #454F63; 
264
265.ssp-card-oferta-curso__item-valor-investimento.ssp-desconto-2022 { 
266  font-size: 22px !important; 
267
268.ssp-card-oferta-curso__item-valor-investimento.ssp-desconto-2022 span { 
269  font-size: 13px !important; 
270
271.ssp-desconto-2022 span { 
272  padding: 0 !important; 
273
274 
275.ssp:not(.liferay-instance) .ssp-card-registro-interesse__select { 
276  appearance: none !important; 
277  -webkit-appearance: none !important; 
278  -moz-appearance: none !important; 
279 
280  background-size: 25px 25px !important; 
281  background-image: url(); 
282  background-repeat: no-repeat !important; 
283  background-position-x: 99% !important; 
284  background-position-y: 50% !important; 
285
286 
287@media only screen and (max-width: 768px){ 
288 
289  .ssp-card-detalhe-curso__tag-ao-vivo{ 
290    font-size: 14px; 
291    display: none; 
292
293  .ssp:not(.liferay-instance) .ssp-aviso-novas-turmas__content { 
294     
295    flex-wrap: wrap!important; 
296     
297
298.ssp-card-modal-forma-pagamento__tipos-content p { 
299   
300  font-size: 12px!important; 
301
302     
303  
304  .ssp:not(.liferay-instance) .ssp-section-selecione-unidade { 
305      padding: 30px 0!important; 
306      padding-bottom: 30px !important; 
307      background-color: #2a2e43; 
308
309   
310  .ssp:not(.liferay-instance) .ssp-aviso-novas-turmas__title { 
311      padding-bottom: 1.25rem !important; 
312
313 
314  .selecione-unidade-title-custom{ 
315    width:100%!important; 
316 
317  }  
318   
319  .ssp-card-detalhe-curso__description{ 
320    width: 100%; 
321    font-size: 15px; 
322 
323
324  .ssp-como-me-matricular__passo-passo-card {     
325    padding: 30px 24px!important; 
326     
327
328 
329  .emed-select-group { 
330        box-shadow: none!important; 
331        border: none !important; 
332        border-bottom: 1px solid #6E6E6E!important; 
333        border-radius: 0 !important; 
334        padding: 0 !important; 
335        margin: 1rem 0 !important; 
336
337 
338    .emed .ssp-card-registro-interesse__title-modal{ 
339      font-size: 20px!important; 
340
341    .emed .ssp-card-registro-interesse__title-section-itens { 
342      font-size: 15px!important; 
343      margin-top: 0px!important; 
344      margin-bottom: 0px!important; 
345      color: #2a2e43; 
346
347    .ssp-card-registro-interesse.emed [type="checkbox"] { 
348        transform: scale(0.6); 
349        margin-left: 2px; 
350
351 
352    .ssp-card-registro-interesse.emed label { 
353      margin-left: 0px; 
354      margin-right: 3px; 
355
356
357 
358.ssp-card-oferta-curso__local-realizacao-content__title { 
359  font-family: "Open Sans", sans-serif; 
360    font-size: 10pt; 
361    font-weight: normal; 
362    color: #00488c; 
363    font-weight: bold; 
364    text-decoration: none!important; 
365    padding-left: 10px; 
366
367 
368 @media screen and (min-width: 767px){ 
369   
370  .ssp-modal-local-realizacao{ 
371      width: 480px!important; 
372
373   .ssp-card-modal-forma-pagamento__header {     
374    margin-bottom: 20px; 
375
376    
377   .ssp-modal-local-realizacao__title{ 
378    color:#01488C !important; 
379    text-align: center!important; 
380        margin-left: -23px!important; 
381
382   
383  .ssp:not(.liferay-instance) .ssp-modal-local-realizacao__title { 
384      font-size: 14pt; 
385
386  .ssp:not(.liferay-instance) [data-info="data-para-matricula"] { 
387    font-size: 14px !important; 
388    text-align: left;    
389
390  .ssp-modal-emed-txt-desconto-oito { 
391    padding: 10px 0 0px!important; 
392
393  .ssp:not(.liferay-instance) .ssp-modal-emed-info-valor-matricula { 
394    color: #4F596F; 
395    font-size: 15px!important; 
396    text-align: center; 
397    font-weight: 500!important; 
398
399
400  
401@media screen and (max-width: 767px){ 
402  .ssp:not(.liferay-instance) .ssp-modal-local-realizacao { 
403      width: 347px; 
404      padding: 22px; 
405
406  .ssp-modal {     
407    padding-top: 72px!important; 
408  }   
409  .ssp-card-modal-forma-pagamento { 
410    max-width: 335px!important; 
411
412  .ssp-card-modal-forma-pagamento__body { 
413    padding: 0px!important; 
414
415  .ssp-modal-emed-txt-desconto-oito { 
416    font-size: 12px !important; 
417
418  .ssp-card-modal-forma-pagamento__header { 
419    margin-bottom: 20px!important; 
420
421  .txt-desconto-oito i { 
422    font-size: 12px!important; 
423    padding-top: 3px; 
424
425  .txt-pague-vista { 
426    font-size: 12px!important; 
427
428  .txt-ganhe-mais { 
429    font-size: 12px!important; 
430
431  .ssp-modal-emed-info-valor-matricula { 
432    color: #2A2E43!important; 
433    font-size: 12px!important; 
434    font-weight: 500!important; 
435  }   
436  .ssp:not(.liferay-instance) [data-info="data-para-matricula"] { 
437    font-size: 12px !important; 
438    line-height: 1.5; 
439    text-align: left; 
440
441   
442  .ssp-desconto-2022 .txt-desconto-oito { 
443    font-size: 14px !important; 
444
445
446 
447@media screen and (max-width: 767px){ 
448  .ssp:not(.liferay-instance) .ssp-modal-local-realizacao__title { 
449      font-size: 16pt; 
450
451
452 
453.container-local-realizacao{ 
454  padding: 6px; 
455    border: 0.5pt solid #cdd0d8; 
456    border-radius: 5px; 
457    width: 260px; 
458    margin: 10px auto; 
459    box-shadow: 1px 1px 1px #0000000F; 
460
461 
462.idioma-online{ 
463  border:0!important; 
464  box-shadow:none!important; 
465
466 
467.btn-idiomas__aula-online .fa-wifi{ 
468  margin-right: 7px 
469
470 
471.ssp-modal-local-realizacao__title{ 
472  color:#01488C !important; 
473  text-align: center!important; 
474
475 
476h6.ssp-modal-local-realizacao__title::after { 
477    content: ""; 
478    display: block; 
479    width: 20%; 
480    padding-top: 10px; 
481    border-bottom: 1px solid #01488C; 
482    transition: .5s; 
483    margin:auto; 
484
485 
486.ssp:not(.liferay-instance) .ssp-card-oferta-curso__local-realizacao-content__icon-wifi::after { 
487  font-family: "Font Awesome 5 Free"; 
488    content: '\f1eb'; 
489    font-weight: 600; 
490    color: #00488c; 
491    font-size: 8px; 
492    font-style: normal; 
493    margin-left: 2px; 
494
495 
496.ssp:not(.liferay-instance) .ssp-card-oferta-curso__local-realizacao-content__icon-chalkboard-teacher::after { 
497    font-family: "Font Awesome 5 Free"; 
498    content: '\f51c'; 
499    font-weight: 600; 
500    color: #00488c; 
501    font-size: 13px; 
502    font-style: normal; 
503
504 
505.ssp-card-oferta-curso__local-realizacao-content__icon-wifi{ 
506    display: flex; 
507    margin-top: 0px; 
508    margin-bottom: -10px; 
509
510 
511.ssp:not(.liferay-instance) .ssp-modal__local-realizacao-content__icon-wifi::after { 
512  font-family: "Font Awesome 5 Free"; 
513    content: '\f1eb'; 
514    font-weight: 600; 
515    color: #00488c; 
516    font-size: 9pt; 
517    font-style: normal; 
518    margin-right: 10px; 
519
520 
521.ssp:not(.liferay-instance) .ssp-modal__local-realizacao-content__icon-chalkboard-teacher::after { 
522    font-family: "Font Awesome 5 Free"; 
523    content: '\f51c'; 
524    font-weight: 600; 
525    color: #00488c; 
526    font-size: 16pt; 
527    font-style: normal; 
528    margin-left: -16px; 
529
530 
531.ssp-modal__local-realizacao-content__icon-wifi{ 
532    display: flex; 
533    margin-right: 2px 
534
535 
536.ssp-modal-local-realizacao__texto{ 
537  text-align:center!important; 
538
539 
540.texto-modal-emed{ 
541	text-align:left; 
542
543 
544.nextPrevOpacity{ 
545  opacity: 0.3; 
546
547 
548   
549   .modal-extensao { 
550              display: block; 
551              position: fixed; 
552              z-index: 2000; 
553              padding-top: 100px; 
554              left: 0; 
555              top: 0; 
556              width: 100%; 
557              height: 100%; 
558              overflow: auto; 
559              background-color: black; 
560              background-color: rgba(0, 0, 0, 0.6); 
561              font-family: Montserrat; 
562
563          .modal-extensao_content { 
564              max-width: 700px; 
565              width: 100%; 
566              background: white; 
567              border-radius: 12px; 
568              padding: 30px 60px; 
569              position: relative; 
570              text-align: center; 
571              margin: auto; 
572              -webkit-animation-name: animatetop; 
573              -webkit-animation-duration: 0.4s; 
574              animation-name: animatetop; 
575              animation-duration: 0.4s; 
576          }     
577          .modal-extensao-condicoes__title { 
578              color: #000!important; 
579              text-transform: uppercase!important; 
580              font-size: 18px!important; 
581   
582
583          .modal-extensao-condicoes__subtitle { 
584              color: #000!important;             
585              font-size: 18px!important; 
586              margin-bottom: 0px!important; 
587   
588
589          .modal-extensao__btn { 
590              background-color: #5ACC75!important; 
591              font-size: 14px; 
592              float: right; 
593              color: #ffffff; 
594              min-width: 165px; 
595
596          .modal-extensao__btn:hover { 
597              background-color: #3fb25c!important; 
598              border-color: transparent; 
599              color: #ffffff; 
600          }     
601          .modal-extensao_subtitle { 
602              font-size: 13.7px!important; 
603              color: #2A2E43!important; 
604              font-family: Montserrat, semi-bold!important; 
605              font-weight: 600!important; 
606
607          .modal-extensao_subtitle::after { 
608              content: " "; 
609              display: block; 
610              width: 126px; 
611              height: 2px; 
612              background: #707070; 
613              margin: 0 auto; 
614              margin-top: 5px;  
615
616          .modal-extensao_preco { 
617              color: #454F63; 
618              font-size: 25px; 
619              font-family: Montserrat;             
620              font-weight: bold; 
621
622          .modal-extensao_ctboleto { 
623              width: 50%; 
624              float: left; 
625              border-color: #D7D7DB; 
626              border-style: solid; 
627              border-width: 1px; 
628              border-left: none; 
629              font-size: 21px; 
630              color: #454F63 
631                               
632
633          .modal-extensao_ctcard { 
634              width: 50%; 
635              float: left; 
636              border-color: #D7D7DB; 
637              border-style: solid; 
638              border-width: 1px; 
639              border-right: none;  
640              border-left: none; 
641              font-size: 21px;   
642              color: #454F63; 
643          }  
644          
645          .modal-extensao_txtPag { 
646              color:#2A2E43;   
647              font-size: 9px;  
648              font-family: Montserrat; 
649              font-weight: 600; 
650              display: block; 
651
652          .modal-extensao_txteconomiza { 
653              display: block; 
654              font-size: 12px; 
655
656          .modal-extensao_txtverde { 
657              color: #5ACC75; 
658
659          .modal-extensao_txtParcela { 
660              color:#2A2E43;   
661              font-size: 12px;  
662              font-family: Montserrat; 
663              font-weight: normal; 
664              display: block; 
665
666          .modal-extensao_txtporcent{ 
667              font-size: 9px; 
668              color: #5ACC75; 
669              font-weight: 600; 
670
671          .modal-extensao-btn-conheca { 
672              color: #2967F4 !important; 
673              background-color: transparent; 
674              border-color: #2967F4 !important; 
675              box-shadow: none !important; 
676              font-size: 14px !important; 
677              margin-left: 10px; 
678              transition: 0.3s; 
679              float: left; 
680
681           .modal-extensao-btn-conferir { 
682              color: #2967F4 !important; 
683              background-color: transparent; 
684              border-color: #2967F4 !important; 
685              box-shadow: none !important; 
686              font-size: 14px !important; 
687              margin-left: 10px; 
688              transition: 0.3s; 
689              min-width: 330px; 
690              min-height: 50px;             
691
692            .modal-extensao-btn-conferir:hover { 
693              color: #ffffff!important; 
694
695             
696           .modal-extensao-btn-conheca:hover, .modal-extensao-btn-conheca:focus { 
697              color: #ffffff!important; 
698           }  
699           .modal-extensao-btn-aluno-sim-nao { 
700              color: #000000; 
701              background-color: transparent; 
702              border-color: #000000 !important; 
703              box-shadow: none !important; 
704              font-size: 14px !important; 
705              margin-left: 10px; 
706              transition: 0.3s;  
707              min-width: 95px;            
708
709           .modal-extensao-btn-aluno-sim-ativo { 
710              color: #ffffff!important; 
711              background-color: #3969EB!important; 
712              border-color: #3969EB !important; 
713           }  
714           .modal-extensao-btn-aluno-sim-nao:hover { 
715              background-color: transparent; 
716              border-color: #3969EB !important; 
717              color: #3969EB!important;         }    
718           .modal-extensao-voltar-icon,.modal-extensao-fechar { 
719              font-size: 13px; 
720              position: absolute; 
721              top: 30px; 
722              right: 20px; 
723              cursor: pointer; 
724              color: #000; 
725
726  
727           .modal-extensao-voltar-txticon { 
728              color: #000; 
729              font-size: 9px; 
730              font-family: Montserrat; 
731              font-weight: 600; 
732              padding-left: 5px; 
733
734           .modal-extensao-ico-check { 
735              color: #5ACC75; 
736              font-size: 65px; 
737
738           .modal-extensao-aluno_txtcontent { 
739              font-size: 18px!important; 
740              color: #000; 
741
742           .modal-extensao-aluno__btn { 
743              background-color: #5ACC75!important; 
744              font-size: 14px;             
745              color: #ffffff; 
746              min-width: 330px; 
747              text-transform: uppercase; 
748              min-height: 50px; 
749           }  
750           .modal-extensao-aluno__btn:hover { 
751              color: #fff; 
752              background-color: #3fb25c!important; 
753              border-color: transparent; 
754              color: #ffffff;     
755
756           .modal-extensao-ico-percent { 
757              background-color: blue; 
758              color: #fff; 
759              font-size: 48px; 
760              border-radius: 50%; 
761              padding: 10px 18px;      
762
763   
764          .btn-preco-ex-aluno,.btn-preco-padrao{ 
765   
766            background:none; 
767            border: none; 
768            width: 100%; 
769            display: flex; 
770            align-items: center; 
771            justify-content: space-between; 
772            text-align: left; 
773            font-size: 14px; 
774
775   
776          .custom-icon-right{ 
777            transform: rotate(0); 
778            transition: all 0.5s; 
779
780   
781          .custom-icon-right-active{ 
782          transform: rotate(90deg);             
783
784   
785          .ssp-divisor{ 
786            width: 100%; 
787            color: #D7D7DB; 
788            margin: 15px 0; 
789
790   
791   
792          @media only screen and (max-width: 768px){ 
793   
794              .modal-extensao_content{ 
795                width:336px; 
796                padding: 60px 20px 20px 20px; 
797
798   
799              .modal-extensao__btn{ 
800                width: 100%; 
801
802   
803              .modal-extensao-modal-extensao__btn { 
804                  float: initial; 
805                  width: 234px; 
806
807              .modal-extensao-btn-conheca { 
808                  float: initial; 
809                  width: 100%; 
810                  margin-left: 0px; 
811
812              .modal-extensao-aluno__btn { 
813                  min-width: 234px; 
814
815              .modal-extensao-btn-conferir{ 
816                  min-width: 234px; 
817                  margin-left: 0px; 
818
819          }     
820 
821 
822/* Emed */ 
823.ssp-btn-emed__voltar-curso { 
824  border: 1px solid #474F61; 
825  color: #474F61; 
826  max-width: 372px; 
827  margin-left: 60px; 
828  height: 50px; 
829  padding: 12px!important; 
830
831 
832@media (max-width: 768px) { 
833  .ssp-btn-emed__voltar-curso { 
834    font-size: 14px; 
835    margin-left: 0px!important; 
836
837
838 
839@media only screen and (max-width: 767px){ 
840  .ssp:not(.liferay-instance) .ssp-emed-visita-text { 
841      margin: 0; 
842      transform: none; 
843      margin-left: 10px; 
844
845
846 
847.ssp:not(.liferay-instance) .icon-map-adress::after { 
848  padding: 0 8px 0 0; 
849
850 
851.ssp:not(.liferay-instance) .ssp-card-oferta-curso__mensagem-legal { 
852    margin: 5px 0; 
853
854 
855.ssp:not(.liferay-instance) .ssp-ofertas-emed__card-info-investimento .btn-card-investimento { 
856    width: 100%; 
857    color: white !important; 
858    font-size: 15px; 
859    font-weight: 600; 
860    margin: 10px 0; 
861
862 
863.ssp-modal-emed-info-txt-matricula { 
864  display: inline-block; 
865
866.ssp:not(.liferay-instance) .btn-card-investimento.--inscreva-se.disabled, .ssp:not(.liferay-instance) a.btn.btn-success.disabled.manutencao { 
867    background: #BFC3C9 !important; 
868    color: #454F63!important; 
869    opacity: 1!important; 
870    font-size: 14px; 
871    border:none; 
872
873 
874.ssp:not(.liferay-instance) .ssp-ofertas-emed__card-info-investimento .btn-card-investimento.--bolsas.disabled { 
875    background: #E5E8ED; 
876    color: #454F63!important; 
877    opacity: 1; 
878    font-size: 14px; 
879
880 
881.ssp:not(.liferay-instance) .ssp-ofertas-emed__card-info-investimento .btn-card-investimento.--inscreva-se { 
882    background-color: #5acc75; 
883    text-transform: none; 
884
885 
886.ssp:not(.liferay-instance) .ssp-ofertas-emed__card-info-investimento .link-descontos-parcelamentos { 
887    font-weight: 600; 
888
889 
890.ssp:not(.liferay-instance) .ssp-card-oferta-curso__sem-vaga-title { 
891    margin: 0; 
892
893 
894.ssp:not(.liferay-instance) .ssp-ofertas-emed__card-container { 
895 
896  padding: 0; 
897 
898
899 
900.ssp:not(.liferay-instance) .ssp-ofertas-emed__filtro-content { 
901    padding: 40px 0; 
902
903 
904.ssp:not(.liferay-instance) .ssp-ofertas-emed__card-info-investimento .txt-boleto-cartao { 
905    text-align: center; 
906
907.ssp-card-modal-emed-lineou { 
908height: 1px; 
909    background-color: #FC7834; 
910    text-align: center;     
911    width: 50%;     
912    margin: 0px auto; 
913    margin-bottom: 15px; 
914
915.ssp-card-modal-emed-lineou span { 
916background-color: white; 
917    position: relative; 
918    top: -0.8em; 
919    padding: 0 19px; 
920    font-weight: bold; 
921    color: #2A2E43; 
922    font-size: 15px; 
923
924.ssp-modal-emed-txtValor { 
925    font-size: 16px; 
926    color: #04488C; 
927    font-weight: bold; 
928
929.ssp-card-modal-emed-centralizaPagtos{ 
930max-width: 285px;margin:0 auto; margin-top: 18px!important; 
931
932.ssp-card-modal-forma-pagamento__tipos-content p { 
933  font-weight: 500!important; 
934
935.textoCartoesAceitos { 
936  font-weight: 500!important; 
937
938.ssp-card-modal-emed-valorObs { 
939    color: #004A8C; 
940    display: flex;     
941    justify-content: center; 
942    font-weight: 500; 
943    padding-top: 11px; 
944    font-size: 14px; 
945
946.ssp-card-modal-emed-boxDesconto{ 
947    border: 0!important; 
948    font-weight: 500!important; 
949    background-color: #F7F7F7; 
950    border-radius: 13px; 
951    padding: 20px 40px!important; 
952    margin-bottom: 0!important; 
953
954.ssp-modal-emed-boxoito { 
955    padding: 5px 45px!important; 
956    text-align: center;  
957    border-bottom: 0px!important; 
958
959.ssp-modal-emed-btfechar { 
960    position: absolute; 
961    right: 0; 
962    display: flex; 
963    flex-direction: column; 
964    text-align: center; 
965    line-height: 0.9; 
966    top: -48px; 
967    color: #E4E8F0; 
968    font-weight: 500; 
969    font-size: 14px; 
970
971.ssp-card-modal-forma-pagamento__btn-close:hover { 
972    opacity: .6; 
973
974.ssp-card-modal-emed-ano { 
975    font-weight: 500; 
976    font-size: 22px; 
977    color: #454F63; 
978}  
979.ssp:not(.liferay-instance) [data-info="msg-20-desconto"] {  
980    font-weight: 500!important; 
981 
982}  
983.ssp-card-modal-emed-valorObs i { 
984    padding-top: 2px; 
985    padding-right: 3px; 
986}   
987button[id^="btnComprarEmedModal_"] { 
988    height: 50px; 
989    font-weight: 600; 
990    max-width: 372px; 
991    width: 100%;     
992    margin: 0 auto; 
993    /* margin-left: 60px; */ 
994    display: block; 
995    height: 50px; 
996    padding: 12px !important; 
997 
998
999.obsspan { 
1000    justify-content: left; 
1001    padding-bottom: 10px; 
1002
1003 
1004 
1005 
1006 
1007@media only screen and (max-width: 767px){ 
1008 
1009    .ssp:not(.liferay-instance) .ssp-card-oferta-curso__mensagem-legal { 
1010      width: 100%; 
1011
1012 
1013    .ssp-card-modal-emed-valorObs { 
1014      font-size: 12px; 
1015    }  
1016    .obsspan { 
1017    justify-content: left; 
1018    margin-left: -14px!important; 
1019
1020    .ssp-modal-emed-boxoito { 
1021    padding: 5px 0px!important; 
1022
1023    .ssp-modal-emed-info-txt-matricula { 
1024    display: inherit; 
1025
1026    .ssp-card-modal-emed-boxDesconto{ 
1027      padding: 20px 20px!important; 
1028      font-size: 12px!important; 
1029   }   
1030   .ssp:not(.liferay-instance) [data-info="msg-20-desconto"] { 
1031    font-size: 12px !important; 
1032    font-weight: 500!important; 
1033  }  
1034  .ssp-modal-emed-btfechar { 
1035    font-size: 12px; 
1036 
1037  }   
1038  button[id^="btnComprarEmedModal_"] { 
1039    height: 50px;     
1040    padding: 10px; 
1041    border-radius: 4px; 
1042    margin-left: 0px!important 
1043
1044  button[id^="btnComprarEmedModal_"] span { 
1045    font-size: 15px; 
1046    font-weight: 600; 
1047
1048  .ssp-btn-emed__voltar-curso_0 { 
1049    font-weight: 600!important; 
1050    height: 50px; 
1051    border-radius: 4px!important; 
1052    padding: 14px!important; 
1053
1054     
1055 
1056}   
1057 
1058@media screen and (min-width: 1200px){ 
1059  .ssp-col-lg-without { 
1060    flex: unset; 
1061    width: unset; 
1062
1063
1064@media screen and (max-width: 1199px){ 
1065  .ssp-desconto-2022 .modal-extensao_txteconomiza { 
1066    font-size: 12px !important; 
1067
1068  .ssp-filters-px { 
1069    padding: 0 !important; 
1070
1071  .ssp-switch-label { 
1072    margin: auto 0 !important; 
1073
1074  .ssp-switch-label-message { 
1075    margin-top: 10px; 
1076    margin-bottom: 10px; 
1077    padding-right: 0 !important; 
1078    padding-left: 0 !important; 
1079
1080  .ssp-container-selecione-unidade [name="unidades-ofertas"] { 
1081    max-width: 316px!important; 
1082
1083  .ssp-detalhe-curso-titulo-filter { 
1084    font-size: 16px !important; 
1085
1086
1087 
1088 
1089.ssp-filters-px { 
1090  padding: 0 80px; 
1091
1092/* !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! */ 
1093/* !!!!!!! CSS Destinado ao switch(toggle) !!!!!!! */ 
1094/* !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! */ 
1095.ssp-switch { 
1096  position: relative; 
1097  display: inline-block; 
1098  width: 63px; 
1099  height: 32px; 
1100
1101 
1102.ssp-switch input {  
1103  opacity: 0; 
1104  width: 0; 
1105  height: 0; 
1106
1107 
1108.ssp-switch-label { 
1109  margin: auto 15px; 
1110  font: normal normal 600 16px/19px Montserrat; 
1111  letter-spacing: 0px; 
1112  color: #FFFFFF; 
1113  white-space: nowrap; 
1114
1115 
1116.ssp-switch-label-section { 
1117  font: normal normal 600 18px/22px Montserrat; 
1118  margin-bottom: 11px; 
1119
1120 
1121.ssp-switch-label-message { 
1122  font: normal normal medium 16px/19px Montserrat !important; 
1123  letter-spacing: 0px; 
1124  color: #FFFFFF; 
1125  margin-top: 16px; 
1126  padding-left: 25px; 
1127  padding-right: 25px; 
1128
1129 
1130.ssp-switch-divider { 
1131  border-bottom: 1px solid #4a4d5f; 
1132  width: 100%; 
1133
1134 
1135.ssp:not(.liferay-instance) .ssp-detalhe-curso-titulo-filter.ssp-detalhe-curso-titulo-filter { 
1136  font-size: 21px; 
1137
1138 
1139.ssp-switch-slider { 
1140  position: absolute; 
1141  cursor: pointer; 
1142  top: 0; 
1143  left: 0; 
1144  right: 0; 
1145  bottom: 0; 
1146  background-color: #00000000; 
1147  border: 1px solid #FFFFFF; 
1148  -webkit-transition: .4s; 
1149  transition: .4s; 
1150
1151 
1152.ssp-switch-slider:before { 
1153  position: absolute; 
1154  content: ""; 
1155  height: 21px; 
1156  width: 21px; 
1157  left: 4px; 
1158  bottom: 4px; 
1159  background-color: white; 
1160  -webkit-transition: .4s; 
1161  transition: .4s; 
1162
1163 
1164input:checked + .ssp-switch-slider { 
1165  background-color: #5ACC75; 
1166  border: 1px solid #5ACC75; 
1167
1168input:checked + .ssp-switch-slider-secondary { 
1169  background-color: #2967F4; 
1170  border: 1px solid #2967F4; 
1171
1172 
1173input:focus + .ssp-switch-slider { 
1174  box-shadow: 0 0 1px #5ACC75; 
1175
1176input:focus + .ssp-switch-slider-secondary { 
1177  box-shadow: 0 0 1px #2967F4; 
1178
1179 
1180input:checked + .ssp-switch-slider:before { 
1181  -webkit-transform: translateX(33px); 
1182  -ms-transform: translateX(33px); 
1183  transform: translateX(33px); 
1184
1185 
1186/* Rounded sliders */ 
1187.ssp-switch-slider.round { 
1188  border-radius: 34px; 
1189
1190 
1191.ssp-switch-slider.round:before { 
1192  border-radius: 50%; 
1193
1194 
1195/*Utilizado no modal de registro de interesse #9309*/ 
1196option[value=""][disabled] { 
1197  display: none; 
1198
1199/* Css para botao de idiomas online */ 
1200 
1201.btn-idiomas__aula-online{ 
1202  background:#5382FF; 
1203  color:white!important; 
1204  text-decoration:none!important; 
1205  padding:11px 14px; 
1206  border-radius:4px; 
1207  font-size:13px; 
1208  font-weight:600; 
1209  transition:.3s; 
1210
1211 
1212.btn-idiomas__aula-online:hover{ 
1213  background:#5275D1; 
1214  font-weight:600!important; 
1215
1216 
1217.title-idioma-online__modal,.icon-wifi-title__modal{ 
1218  color:#5382FF!important; 
1219  font-size:25px!important; 
1220  margin:0!important; 
1221  margin-right:5px!important; 
1222
1223 
1224.btn-modal-entendi__idioma-online{ 
1225  font-size:16px!important; 
1226  font-weight:600!important; 
1227  color:#5382FF!important; 
1228  border:#5382FF 1px solid!important; 
1229  padding:15px 142px; 
1230  width:auto!important; 
1231
1232 
1233.btn-modal-entendi__idioma-online:hover{ 
1234  font-size:16px!important; 
1235  font-weight:600!important; 
1236  color:#5382FF!important; 
1237  border:#5382FF 1px solid!important; 
1238  background:white!important; 
1239
1240 
1241@media only screen and (max-width: 768px){ 
1242   
1243  .title-idioma-online__modal,.icon-wifi-title__modal{ 
1244    color:#5382FF!important; 
1245    font-size:21px!important; 
1246    margin:0!important; 
1247    margin-right:5px!important; 
1248
1249   
1250  .btn-modal-entendi__idioma-online{ 
1251    font-size:16px!important; 
1252    font-weight:600!important; 
1253    color:#5382FF!important; 
1254    border:#5382FF 1px solid!important; 
1255    padding:12px 30%; 
1256    width:auto!important; 
1257
1258     
1259
1260 
1261.btn-emed-lista-espera{ 
1262  background-color:#C560C7!important; 
1263
1264 
1265.ssp:not(.liferay-instance) .ssp-container__form-select { 
1266    max-width: 430px; 
1267    width:100%; 
1268
1269 
1270 
1271@media (max-width: 768px){ 
1272  .ssp:not(.liferay-instance) .ssp-ofertas-emed__card { 
1273    margin: 10px 20px; 
1274    max-width: 335px; 
1275
1276
1277 
1278/* css EMED Registro de interesse */ 
1279 
1280.emed #periodo-registro-interesse,.emed #turmas-registro-interesse{ 
1281 
1282  display: flex; 
1283  align-items: center; 
1284  padding: 0.625rem 0; 
1285  width: 85%; 
1286  justify-content: space-between; 
1287  margin: 0 auto; 
1288 
1289
1290 
1291.ssp-card-registro-interesse__title-section-itens{ 
1292  margin: 10px 0 11.5px 0 !important; 
1293  font-size: 20px; 
1294  flex-basis: 120px; 
1295
1296 
1297.ssp-card-registro-interesse__check-itens-content { 
1298  display: flex!important; 
1299  justify-content: center!important; 
1300  flex: 0 1 90%!important; 
1301
1302.ssp-card-registro-interesse__check-item { 
1303  display: flex; 
1304  align-items: center; 
1305  flex-basis: 100px; 
1306
1307 
1308.ssp-card-registro-interesse label { 
1309  margin-right: 0!important; 
1310
1311 
1312.ssp-card-registro-interesse [type="checkbox"] { 
1313box-shadow: 0px 0px 6px #00000029; 
1314
1315 
1316#cursos-registro-interesse,#unidades-registro-interesse{ 
1317padding: 10px 0; 
1318
1319 
1320.emed-select-group{ 
1321 
1322box-shadow: 0px 0px 12px #00000010; 
1323border: 1px solid #6E6E6E; 
1324border-radius: 4px; 
1325padding: 1.0rem 1.125rem; 
1326margin: 1rem 0; 
1327 
1328
1329 
1330.ssp:not(.liferay-instance) .ssp-card-registro-interesse__add-mais > a { 
1331      color: #457eff !important; 
1332
1333 
1334.emed .ssp-card-registro-interesse__btn-enviar { 
1335background-color: #C560C7 !important; 
1336
1337 
1338.ssp-card-registro-interesse__title-modal{ 
1339color:#C560C7 !important; 
1340font-size: 35px !important; 
1341font-weight: bold !important; 
1342margin: 0 !important; 
1343
1344 
1345#msg-transferencia-emed{ 
1346display: flex; 
1347justify-content: center; 
1348flex: wrap; 
1349flex-direction: column; 
1350align-items: center; 
1351padding: 1rem 0; 
1352
1353 
1354.transferencia-emed-title { 
1355  color: #d266d4; 
1356  display: flex; 
1357  gap: 10px; 
1358  font-size: 16px; 
1359  font-weight: bold; 
1360  align-items:center; 
1361
1362 
1363.transferencia-emed-title p { 
1364  margin: 0 !important; 
1365  font-weight: bold !important; 
1366  font-size: 16px!important; 
1367
1368 
1369.transferencia-emed-link a{ 
1370  font-size: 15px; 
1371  font-weight: 500!important; 
1372  color: #792F7A; 
1373  display: block; 
1374  text-align: center; 
1375
1376 
1377.transferencia-emed-link a:hover { 
1378  font-weight: 500!important; 
1379  color: #792F7A; 
1380
1381 
1382.emed .ssp-card-registro-interesse__label-curso-selecionado{ 
1383color:#2A2E43!important; 
1384font-weight: bold!important; 
1385font-size: 28px; 
1386
1387 
1388 
1389/* css para registro de interesse atual */ 
1390 
1391#periodo-registro-interesse,#dias-registro-interesse{ 
1392padding: .625rem 0; 
1393
1394 
1395/* css card sem turma e registro de interesse emed*/ 
1396 
1397.slick-area-emed { 
1398    display: -webkit-box !important; 
1399    display: -ms-flexbox !important; 
1400    display: flex !important; 
1401    -webkit-box-align: center; 
1402    -ms-flex-align: center; 
1403    align-items: center; 
1404    -webkit-box-pack: center; 
1405        -ms-flex-pack: center; 
1406            justify-content: center; 
1407    font-size: 0; 
1408    -ms-flex-wrap: nowrap; 
1409        flex-wrap: nowrap; 
1410
1411   
1412  .slick-area-emed .slick-track, .slick-area-emed .slick-list { 
1413    width: 100%; 
1414
1415 
1416  @media only screen and (max-width: 1199px) and (min-width: 768px) { 
1417    .slick-area-emed--md-bleed { 
1418      width: 100vw; 
1419      left: calc(-1 * calc(50vw - (740px / 2) + 37px))!important; 
1420
1421    .slick-area-emed--md-bleed .slick-list { 
1422      padding-left: calc(calc(50vw - (768px / 2) + 37px)); 
1423      padding-right: calc(calc(50vw - (768px / 2) + 37px)); 
1424
1425    .slick-area-emed--md-bleed .slick-arrow { 
1426      display: none !important; 
1427
1428
1429   
1430  @media only screen and (min-width: 376px) and (max-width: 1024px) { 
1431    .slick-area-emed--md-bleed { 
1432      width: 100vw; 
1433      left: calc(-1 * (calc(100vw / 2) - calc(310px / 2) - 3px)); 
1434
1435    .slick-area-emed--md-bleed .slick-list { 
1436      padding-left: 2px; 
1437
1438    .slick-area-emed--md-bleed .slick-arrow { 
1439      display: none !important; 
1440
1441
1442   
1443  @media only screen and (max-width: 375px) { 
1444     
1445    .ssp-emed__card-slider-body { 
1446    padding: 25px 30px; 
1447
1448    
1449     
1450    .slick-area-emed--md-bleed { 
1451      width: 100vw; 
1452      left: calc(-1 * (calc(100vw / 2) - calc(310px / 2) - 3px)); 
1453
1454    /* .slick-area-emed--md-bleed .slick-list { 
1455      padding-left: 20px; 
1456 
1457    } */ 
1458    .slick-area-emed--md-bleed .slick-arrow { 
1459      display: none !important; 
1460
1461
1462 
1463  .slick-area__item { 
1464    display: flex; 
1465    flex-basis: auto; 
1466
1467 
1468  .ssp-emed__section__textCard { 
1469  margin: 20px 0 0 0; 
1470
1471 
1472  .ssp-emed__card-slider-body { 
1473    padding: 25px 50px; 
1474    min-height: 350px; 
1475    display: flex; 
1476    flex-direction: column; 
1477
1478 
1479  .slick-area__item { 
1480    display: flex; 
1481    flex-basis: auto; 
1482
1483 
1484  .ssp-emed__card-slider-body a { 
1485    text-decoration: none!important; 
1486    font-weight: normal; 
1487    color: #78849E 
1488
1489 
1490  .ssp-emed__card-slider-body a:hover {   
1491    font-weight: bold!important; 
1492    color: #2a2e43 
1493
1494 
1495  .ssp-emed__card-slider { 
1496      border-radius: 12px; 
1497      background: transparent; 
1498      -webkit-box-shadow: 0 0 12px 0 rgb(0 0 0 / 16%); 
1499      box-shadow: 0 0 12px 0 rgb(0 0 0 / 16%); 
1500      margin: 12px; 
1501      position: relative; 
1502      overflow: hidden; 
1503      color: #ffffff!important; 
1504      border: 1px solid #fff; 
1505      min-height: 350px; 
1506
1507 
1508  .slick-initialized .slick-track { 
1509      display: flex; 
1510
1511 
1512    .slick-initialized .slick-slide { 
1513      height: inherit!important; 
1514      display: flex; 
1515
1516 
1517  .ssp-emed__section__titleCard { 
1518  font-size: 28px !important; 
1519  color: #ffffff !important; 
1520  margin: 0 !important; 
1521  display: flex !important; 
1522  justify-content: flex-start !important; 
1523  flex-direction: row !important; 
1524  align-items: start !important; 
1525  flex-basis: 60px; 
1526
1527 
1528.ssp-emed__section__titleCard i { 
1529  font-size: 28px; 
1530  color: #ffffff; 
1531  margin: 0 0.85rem 0 0; 
1532  line-height: 30px; 
1533
1534 
1535.ssp-emed__section__titleCard i.fa-envelope { 
1536  margin-top: 0px;   
1537
1538 
1539.ssp-emed__section__titleCard i.fa-users-class { 
1540  margin-top:2px; 
1541
1542 
1543.ssp-emed__section__titleCard div { 
1544  text-decoration: underline; 
1545  font-size: 28px !important; 
1546  font-weight: bold; 
1547  margin: 0!important; 
1548  transform:translateY(-2px) 
1549
1550 
1551  .ssp-emed__section__introCard { 
1552    display: block; 
1553    font: 28px/30px 'Montserrat'; 
1554    font-weight: 600; 
1555    margin: 20px 0; 
1556    color: #ffffff;  
1557
1558 
1559  .ssp-emed__section__introCardCTA { 
1560    font: 34px/36px 'Montserrat'; 
1561    font-weight: bold; 
1562    display: block; 
1563    margin: 20px 0; 
1564    color: #ffffff;  
1565
1566 
1567  .ssp-emed__section__textCard { 
1568    font: 22px/30px 'Montserrat'; 
1569    color: #ffffff;  
1570    display: block; 
1571    margin: 20px 0 0 0; 
1572    position: relative; 
1573
1574 
1575  .ssp-emed__iconWrapper { 
1576    display: inline-block; 
1577    width: 50px; 
1578    color: #B053B2; 
1579    position: absolute; 
1580    bottom: 0; 
1581    right: 0; 
1582
1583 
1584  .ssp-emed__btn { 
1585    background-color: #B053B2 ; 
1586      color: #fff!important; 
1587      font: normal normal 600 18px/22px Montserrat; 
1588      box-shadow: 0px 4px 16px #455B6314; 
1589      width: 100%; 
1590      transition: .3s; 
1591      padding:10px!important; 
1592
1593 
1594  .ssp-emed__btn:hover { 
1595      opacity: 0.7; 
1596  }     
1597 
1598  /*mobile emed*/ 
1599  @media only screen and (max-width: 1024px) { 
1600    .slick-area-emed .slick-dots li.slick-active button:before { 
1601      opacity: .75; 
1602      color: #707070; 
1603
1604   
1605    .slick-area-emed .slick-dots li button:before { 
1606      color: blue; 
1607
1608 
1609    .ssp-card-detalhe-curso__secundary-info-carga-horaria { 
1610      min-width: 35%; 
1611      text-align: end; 
1612
1613
1614   
1615  @media only screen and (max-width: 1199px) and (min-width: 768px) { 
1616    .slick-area-emed--md-bleed { 
1617      width: 100vw; 
1618      left: calc(-1 * calc(50vw - (740px / 2) + 37px))!important; 
1619
1620    .slick-area-emed--md-bleed .slick-list { 
1621      padding-left: calc(calc(50vw - (768px / 2) + 37px)); 
1622      padding-right: calc(calc(50vw - (768px / 2) + 37px)); 
1623
1624    .slick-area-emed--md-bleed .slick-arrow { 
1625      display: none !important; 
1626
1627
1628   
1629  @media only screen and (min-width: 375px) and (max-width: 1024px) { 
1630      .slick-area-emed--md-bleed { 
1631        width: 100vw; 
1632        left: calc(-1 * (calc(100vw / 2) - calc(310px / 2) - 3px)); 
1633
1634      .slick-area-emed--md-bleed .slick-list { 
1635        padding-left: 2px; 
1636
1637      .slick-area-emed--md-bleed .slick-arrow { 
1638        display: none !important; 
1639
1640      .ssp-emed__section__titleCard { 
1641      align-items: start !important; 
1642
1643 
1644    .ssp-emed__section__titleCard div { 
1645      font-weight: bold !important; 
1646
1647 
1648    .ssp-emed__section__titleCard i { 
1649      font-weight: 300 !important; 
1650      font-size: 28px !important; 
1651      margin: 3px 0.85rem 0 0; 
1652
1653 
1654    .transferencia-emed-title { 
1655      font-size: 12px; 
1656
1657 
1658    .ssp:not(.liferay-instance) .ssp-card-registro-interesse__select { 
1659      background-size: 15px 15px !important; 
1660      padding: 0 10px; 
1661
1662
1663   
1664  @media only screen and (max-width: 550px) { 
1665 
1666    .ssp-emed__section__introCardCTA{ 
1667      font-size: 28px; 
1668
1669 
1670    #msg-transferencia-emed{ 
1671    gap:12px; 
1672
1673     
1674    
1675     
1676    .ssp-emed__card-slider { 
1677      width:335px; 
1678      min-height: 440px; 
1679
1680 
1681    .slick-initialized .slick-track { 
1682      display: flex; 
1683
1684 
1685    .slick-initialized .slick-slide { 
1686      height: inherit!important; 
1687      display: flex; 
1688      min-height: 440px; 
1689
1690 
1691  .ssp-emed__card-slider-body { 
1692    padding: 25px 30px; 
1693
1694 
1695  .ssp-emed__section__titleCard div { 
1696      transform: translateY(-5%); 
1697      font-size: 24px!important; 
1698
1699     
1700    .slick-area-emed--md-bleed { 
1701      width: 100vw; 
1702      left: calc(-1 * (calc(100vw / 2) - calc(310px / 2) - 3px)); 
1703
1704    .slick-area-emed--md-bleed .slick-list { 
1705      padding-left: 20px; 
1706
1707    .slick-area-emed--md-bleed .slick-arrow { 
1708      display: none !important; 
1709
1710 
1711    .ssp-card-registro-interesse__title-section-itens { 
1712    flex-basis: 80px; 
1713
1714 
1715  .emed #periodo-registro-interesse, .emed #turmas-registro-interesse { 
1716    width: 95%; 
1717
1718 
1719  .emed .ssp:not(.liferay-instance) .ssp-card-registro-interesse label { 
1720    margin: 0!important; 
1721
1722 
1723  .emed .ssp-card-registro-interesse.emed [type="checkbox"] { 
1724    margin-left: 0!important; 
1725
1726 
1727  .emed .ssp-card-registro-interesse__check-item { 
1728    flex-basis: 100px; 
1729
1730
1731 
1732  .emed-select-group { 
1733    box-shadow: 0px 0px 12px #00000010; 
1734    border: 1px solid #6E6E6E; 
1735    border-radius: 4px; 
1736    margin: 1rem 0; 
1737
1738 
1739.emed-select-group h4 { 
1740    margin: 15px 0 10px 0; 
1741
1742.ssp-emed__section__textCard { 
1743  margin: 20px 0 0 0; 
1744
1745 
1746.ssp-card-msg-sucesso__btn{ 
1747  font-size: 20px; 
1748
1749 
1750.ssp:not(.liferay-instance) .ssp-card-oferta-curso { 
1751  height:fit-content; 
1752
1753 
1754.ssp-card-duvida__bolsa-estudo{ 
1755 
1756background:#DCE8FF; 
1757padding: 30px; 
1758max-width: 683px; 
1759width: 100%; 
1760border-radius: 14px; 
1761display:flex; 
1762justify-content:center; 
1763align-items: center; 
1764gap: 20px;  
1765margin: 1rem auto; 
1766 
1767
1768 
1769.ssp-card-duvida__bolsa-estudo p{ 
1770 
1771font-size: 16px!important; 
1772font-weight: bold!important; 
1773color: #2967F4!important; 
1774margin: 0!important;; 
1775 
1776
1777 
1778.ssp-card-duvida__bolsa-estudo a{ 
1779 
1780border:1px solid #2967F4!important; 
1781font-size: 14px!important; 
1782font-weight: 600; 
1783text-decoration: none!important; 
1784color: #2967F4!important; 
1785padding:14px 27px; 
1786border-radius:6px; 
1787transition: .3s; 
1788 
1789
1790 
1791.ssp:not(.liferay-instance) .ssp-card-duvida__bolsa-estudo a:hover{ 
1792 
1793font-size: 14px!important; 
1794font-weight: 600!important; 
1795background: #2967F4!important; 
1796color:white !important; 
1797opacity:1!important; 
1798 
1799
1800 
1801@media only screen and (max-width: 768px){ 
1802 
1803.ssp-card-duvida__bolsa-estudo{ 
1804 
1805    background:#DCE8FF; 
1806    padding: 20px; 
1807    flex-flow: column; 
1808    width:90%; 
1809 
1810
1811 
1812.ssp-card-duvida__bolsa-estudo p{ 
1813 
1814    max-width:200px; 
1815    text-align: center; 
1816 
1817
1818 
1819.ssp-card-duvida__bolsa-estudo a{ 
1820 
1821    padding:16px 27px;          
1822 
1823
1824 
1825
1826 
1827/* Novo Card de Oferta */ 
1828 
1829  /* ajustes no card existente */ 
1830 
1831  .ssp:not(.liferay-instance) .ssp-card-oferta__info-turma{ 
1832    margin-bottom: 30px; 
1833
1834 
1835  .ssp:not(.liferay-instance) .ssp-card-oferta__info-turma-content { 
1836      margin-bottom: 5px; 
1837
1838 
1839  .ssp:not(.liferay-instance) .ssp-card-oferta-curso__item-data-periodo{ 
1840    margin: 5px 0 10px 0; 
1841
1842 
1843  .ssp:not(.liferay-instance) .ssp-card-oferta-curso__dia-hora-item { 
1844      border-radius: 0; 
1845      background-color: unset; 
1846      padding: 0; 
1847      max-width: 100%; 
1848      width: 100%; 
1849      margin: 0; 
1850
1851 
1852  .ssp:not(.liferay-instance) .ssp-card-oferta-curso__dia-hora_content{ 
1853      margin:0; 
1854      opacity: 0; 
1855      transition: 0.3s; 
1856
1857 
1858  .ssp:not(.liferay-instance) .ssp-card-oferta-curso__dia-hora-item__dia { 
1859      margin: 0; 
1860      font-size: 17px; 
1861      font-weight: bold; 
1862      font-stretch: normal; 
1863      font-style: normal; 
1864      line-height: 1.23; 
1865      letter-spacing: normal; 
1866      text-align: center; 
1867
1868 
1869  .ssp:not(.liferay-instance) .ssp-card-oferta-curso__dia-hora-item__hora { 
1870      margin: 0; 
1871      font-size: 17px; 
1872      font-weight: bold; 
1873      font-stretch: normal; 
1874      font-style: normal; 
1875      line-height: 1.3; 
1876      letter-spacing: normal; 
1877      text-align: center; 
1878
1879 
1880  .modal-extensao_txteconomiza{ 
1881      font-size: 14px; 
1882      color: #454F63; 
1883      font-weight: 400; 
1884
1885 
1886  .btn.btn-lg { 
1887      padding:.7rem; 
1888 
1889
1890 
1891  .ssp:not(.liferay-instance) .ssp-card-oferta-curso__desconto-content p{ 
1892    font-size: 17px; 
1893
1894 
1895  .ssp-card-oferta-curso__item-valor-investimento{ 
1896    font-size: 38px; 
1897
1898 
1899  .ssp:not(.liferay-instance) .ssp-card-oferta-curso__formas-pagamento-content .ssp-card-oferta-curso__formas-pagamento-content__title{ 
1900    color: #454F63; 
1901    font-weight: bold!important; 
1902    font-size: 14px; 
1903
1904 
1905.ssp:not(.liferay-instance) .ssp-card-oferta-curso__formas-pagamento-content .ssp-card-oferta-curso__formas-pagamento-content__icon-credit-card::after{ 
1906    color: #454F63!important; 
1907    font-size: 14px; 
1908
1909 
1910 
1911.ssp:not(.liferay-instance) .ssp-card-oferta-curso__formas-pagamento-content span{ 
1912    color:#454F63; 
1913    font-size: 14px; 
1914    font-weight: 400; 
1915
1916 
1917.ssp:not(.liferay-instance) .ssp-card-oferta-curso__formas-pagamento-content { 
1918    padding-bottom: 0; 
1919
1920 
1921  /* local realizacao */ 
1922 
1923  .ssp:not(.liferay-instance) .ssp-card-oferta-curso__local-realizacao-content__title { 
1924    font-size: 13px; 
1925    color: #00488C; 
1926    font-weight: 600; 
1927    text-decoration: none!important; 
1928    border: 1px solid #00488C; 
1929    padding: 11px 14px; 
1930    transition:.3s; 
1931    border-radius: 4px; 
1932    display: flex; 
1933    gap: 5px; 
1934    align-items: center; 
1935
1936   
1937  .ssp:not(.liferay-instance) .ssp-card-oferta-curso__local-realizacao-content__title:hover { 
1938      color: white; 
1939      font-weight: 600!important; 
1940      background: #08488C; 
1941  }  
1942     
1943  .container-local-realizacao { 
1944      padding:0; 
1945      border:0; 
1946      border-radius: unset; 
1947      width: 100%; 
1948      margin: 10px 0 0 0; 
1949      box-shadow: none; 
1950      display: flex; 
1951      justify-content:center; 
1952      align-items: flex-end; 
1953
1954 
1955  .icon-local-realizacao{ 
1956      color: #00488C; 
1957      font-size: 13px; 
1958  }  
1959   
1960   
1961  @media only screen and (max-width: 768px){ 
1962 
1963    .ssp:not(.liferay-instance) .ssp-card-oferta-curso__dia-hora-item__dia {  
1964        font-size: 16px; 
1965
1966 
1967    .ssp:not(.liferay-instance) .ssp-card-oferta-curso__title-item { 
1968        font-size: 14px!important; 
1969
1970 
1971    .ssp:not(.liferay-instance) .ssp-card-oferta-curso__valor-desconto{ 
1972        font-size: 15px; 
1973
1974 
1975    .ssp:not(.liferay-instance) .ssp-card-oferta-curso__item-valor-investimento { 
1976      font-size: 33px; 
1977
1978 
1979    .icon-local-realizacao { 
1980        font-size: 12px; 
1981
1982 
1983    .modal-extensao_txteconomiza { 
1984        font-size: 12px; 
1985
1986 
1987    .content-valores-descontos { 
1988        padding-bottom: 8px!important; 
1989
1990 
1991    .ssp:not(.liferay-instance) .ssp-card-oferta-curso__desconto-content p{ 
1992        font-size: 14px!important; 
1993
1994 
1995 
1996
1997 
1998     
1999     
2000 
2001/* final ajustes no card existente */ 
2002 
2003 
2004/* Novos elementos */ 
2005 
2006.content-data-dias{ 
2007    padding:20px; 
2008    padding-top:0; 
2009    border-bottom: none !important; 
2010
2011 
2012.content-valores-descontos{ 
2013    padding:20px 0 0 0; 
2014    opacity: 1; 
2015    height:auto; 
2016    transition: 0.3s; 
2017    overflow: hidden; 
2018    border-top: 1px #E4E8F0 solid;     
2019
2020 
2021.content-valores-descontos.hide-price{ 
2022     
2023    padding:0; 
2024    opacity: 0; 
2025    height:0; 
2026     
2027
2028 
2029.content-btn-bolsa{ 
2030 
2031    border-top: 1px #E4E8F0 solid; 
2032    padding-top:20px;     
2033 
2034
2035 
2036.content-btn-bolsa.modifier-content-show{ 
2037 
2038    padding-bottom: 20px; 
2039 
2040
2041 
2042.content-btn-bolsa.modifier-content-show .ou-separator-desconto{ 
2043    display:none; 
2044
2045 
2046.content-btn-bolsa.modifier-content-show .btn-show-price{ 
2047    display:none; 
2048
2049 
2050.content-buttons{ 
2051 
2052    padding:20px 0 0 0; 
2053 
2054
2055 
2056.block-valor-desconto{ 
2057 
2058  background-color:#F2F6FF; 
2059  padding: 30px 10px 15px 10px; 
2060  border-radius:12px; 
2061  position: relative; 
2062 
2063
2064 
2065.block-valor-desconto .ssp-card-oferta-curso__item-valor-investimento span { 
2066  font-size: 18px; 
2067
2068 
2069.block-valor-total{ 
2070 
2071  background-color:#F2F6FF; 
2072  padding:15px 10px; 
2073  border-radius:12px; 
2074  position: relative; 
2075 
2076
2077 
2078.block-valor-total .ssp-card-oferta-curso__title-item{ 
2079  font-size: 16px!important; 
2080  color: #454F63!important; 
2081  font-weight:500!important; 
2082
2083 
2084.block-valor-total .ssp-card-oferta-curso__item-valor-investimento{ 
2085  font-size:22px; 
2086
2087 
2088.block-valor-total .ssp-card-oferta-curso__item-valor-investimento span{ 
2089    font-size:11px; 
2090
2091 
2092.block-valor-total .ssp-card-oferta-curso__desconto-content p{ 
2093    font-size:14px; 
2094    font-weight: 500; 
2095
2096 
2097.tag-label-desconto{ 
2098 
2099background-color:#B6FDCF; 
2100border-radius: 15px; 
2101padding:5px; 
2102margin: -50px 20px 10px 20px; 
2103 
2104
2105 
2106.tag-label-desconto span, .tag-label-desconto small{ 
2107font-size: 16px!important; 
2108font-weight: bold!important; 
2109color: #454F63!important; 
2110
2111 
2112 
2113 
2114.ou-separator-desconto{ 
2115    font-size: 16px; 
2116    color: #454F63; 
2117    font-weight: bold; 
2118    display:flex; 
2119    flex-wrap: nowrap; 
2120    align-items: center; 
2121    justify-content:space-between; 
2122    gap: 15px; 
2123    padding:20px 0; 
2124
2125 
2126.ou-separator-desconto::after{ 
2127    content: ""; 
2128    height:2px; 
2129    background-color:#E4E8F0; 
2130    width: 100%; 
2131    display: block; 
2132
2133 
2134.ou-separator-desconto::before{ 
2135  content: ""; 
2136  height:2px; 
2137  background-color:#E4E8F0; 
2138  width: 100%; 
2139  display: block; 
2140
2141 
2142.btn-show-price{ 
2143 
2144  background: unset; 
2145  border: 0; 
2146  font-size: 14px!important; 
2147  color: #454F63!important; 
2148 
2149
2150 
2151.btn-show-price p{ 
2152  margin: 0 !important; 
2153
2154 
2155.btn-show-price span{ 
2156  text-decoration: underline; 
2157  font-weight: bold; 
2158
2159 
2160@media only screen and (max-width: 768px){ 
2161 
2162  .content-data-dias{ 
2163 
2164    padding:20px 0; 
2165 
2166
2167 
2168  .ssp-card-oferta-curso__local-realizacao-content__title { 
2169 
2170      font-size: 14px; 
2171      display:flex; 
2172      align-items: center; 
2173      gap: 5px; 
2174      padding: 10px 13px; 
2175
2176 
2177  .ssp-card-oferta-curso__local-realizacao-content__title i{ 
2178 
2179      font-size: 11px; 
2180
2181 
2182  .tag-label-desconto span, .tag-label-desconto small { 
2183      font-size: 13px!important; 
2184
2185 
2186  .tag-label-desconto { 
2187      padding: 5px; 
2188      margin: -50px 12px 10px 12px; 
2189
2190 
2191  .block-valor-desconto .ssp-card-oferta-curso__item-valor-investimento span { 
2192      font-size: 18px; 
2193
2194 
2195  .content-buttons { 
2196      padding: 10px 0 0 0; 
2197
2198 
2199 
2200
2201 
2202/*final Novo card de ofertas*/ 
2203 
2204/* form aprendizagem */ 
2205 
2206[data-modal="modal"]{ 
2207  background-color: rgba(0,0,0,0.7); 
2208  backdrop-filter: blur(10px); 
2209  display:none; 
2210
2211 
2212[data-modal="close-form-modal"]{ 
2213   
2214  font-size: 22px; 
2215  background: unset!important; 
2216  color: white!important; 
2217  display: flex; 
2218  align-items: center; 
2219  margin: 0; 
2220  padding: 0; 
2221  position:absolute; 
2222  right:0; 
2223  border:0; 
2224  gap:5px; 
2225  right: 2%; 
2226  top: -2%; 
2227   
2228
2229 
2230[data-modal="close-form-modal"] i{ 
2231   
2232  font-size:43px; 
2233  height:fit-content; 
2234   
2235
2236 
2237.open-modal-form{ 
2238  position: fixed; 
2239  top: 0; 
2240  width: 100%; 
2241  height: 100%; 
2242  z-index: 100; 
2243  display: flex; 
2244  justify-content: center; 
2245  align-items: center; 
2246  overflow:auto; 
2247 
2248
2249 
2250.open-modal-form .ssp_ct_form_programe{ 
2251    animation-name: animatetop; 
2252    animation-duration: .4s; 
2253    position:relative; 
2254
2255 
2256label .reference-mark { 
2257color:#78849e; 
2258
2259.lexicon-icon-asterisk { 
2260  color:#78849e; 
2261
2262.lexicon-icon-reload { 
2263  margin-left:10px; 
2264
2265.ssp_title_form_programe{ 
2266    font-size: 42px!important; 
2267    color: #ffffff!important; 
2268    font-family: "Montserrat",sans-serif; 
2269    font-weight:600; 
2270    text-align:left; 
2271
2272.ssp_subtitle_form_programe { 
2273  margin-top:0px!important; 
2274   
2275
2276.ssp_subtitle_form_programe{ 
2277  font-size: 20px!important; 
2278    color: #ffffff!important; 
2279    font-family: "Montserrat",sans-serif; 
2280    font-weight:600; 
2281    text-align:left; 
2282
2283.lfr-ddm-form-page { 
2284background-color: #fff; 
2285border-radius: 12px 12px 0px 0px; 
2286padding: 35px 15px!important; 
2287
2288.ssp:not(.liferay-instance) .form-group label { 
2289 color: #78849E; 
2290 font: normal normal 600 16px/19px Montserrat; 
2291 padding-bottom: 10px; 
2292
2293.lfr-ddm-form-page-description {  
2294display: none!important; 
2295
2296.lfr-ddm-form-page-title { 
2297display: none!important; 
2298
2299.lfr-ddm-form-submit { 
2300background-color: #0380F0; 
2301    text-align: center; 
2302    float: none!important; 
2303    border: 1px solid #0380F0; 
2304    border-radius: 6px; 
2305    font-size: 16px; 
2306    width: 245px; 
2307    height: 50px; 
2308
2309.lfr-ddm-form-pagination-controls { 
2310background-color: #fff; 
2311    text-align: center; 
2312    border-radius: 0px 0px 12px 12px; 
2313    padding-bottom: 25px; 
2314
2315.ddm-form-name { 
2316display: none!important; 
2317
2318.ddm-form-description { 
2319display: none!important; 
2320
2321.ddm-form-builder-app { 
2322margin-top:35px; 
2323
2324.taglib-captcha { 
2325  display: flex; 
2326
2327.input-text-wrapper { 
2328  left: 20px; 
2329
2330.lfr-ddm-form-pagination-controls { 
2331  padding-top:0px!important; 
2332  display:flex; 
2333  justify-content:center; 
2334  align-items: center; 
2335  flex-flow:column; 
2336
2337@media only screen and (max-width: 1024px) { 
2338   
2339.open-modal-form{ 
2340   
2341  align-items: flex-start; 
2342   
2343}   
2344 
2345.ddm-form-builder-app { 
2346    margin-top: 15px; 
2347
2348   
2349.ssp_title_form_programe{ 
2350font-size: 34px!important; 
2351line-height: 1.2!important; 
2352
2353.ssp_subtitle_form_programe{ 
2354font-size:18px!important; 
2355
2356.taglib-captcha { 
2357  display:block; 
2358
2359.input-text-wrapper { 
2360  left:0; 
2361
2362.ssp_ct_form_programe { 
2363  padding:0px; 
2364  max-width:100%; 
2365  padding:40px 20px; 
2366
2367 
2368[data-modal="close-form-modal"]{ 
2369   
2370  right: 20px; 
2371  top: 0; 
2372   
2373
2374 
2375
2376 
2377.ssp:not(.liferay-instance) a.btn.btn-success.disabled{ 
2378	pointer-events: none; 
2379	opacity: 0.5 !important; 
2380	color: #FFF !important; 
2381	background-color: #4CBF69 !important; 
2382	cursor: not-allowed; 
2383	border: none !important; 
2384	font-size: 0.9rem !important; 
2385
2386 
2387.slick-list.draggable { 
2388  height: auto !important; 
2389
2390 
2391.ssp:not(.liferay-instance) .ssp-image-opacity { 
2392 
2393  opacity: 1; 
2394  object-fit: cover; 
2395  object-position: center; 
2396 
2397
2398 
2399.ssp-option-group { 
2400  text-align: left; 
2401  font: normal normal 600 15px/19px Montserrat; 
2402  letter-spacing: 0px; 
2403  color: #004A8C; 
2404
2405.ssp-option { 
2406  text-align: left; 
2407  font: normal normal normal 15px/19px Montserrat; 
2408  letter-spacing: 0px; 
2409  color: #656565; 
2410
2411@media only screen and (max-width: 768px){ 
2412  .ssp-option-group { 
2413    font: normal normal 600 15px/19px Montserrat; 
2414
2415  .ssp-option { 
2416    font: normal normal normal 15px/19px Montserrat; 
2417
2418
2419 
2420.open-modal-form.lfr-ddm__default-page-header{ 
2421    display:none; 
2422
2423 
2424/* css para funcionalidade de híbrido */ 
2425 
2426.ssp-emed__vantagens-content.livre span{ 
2427  color: #FF9057!important; 
2428
2429.ssp-emed__vantagens-content.livre a:hover { 
2430    color: white; 
2431    background-color: #FF9057!important;; 
2432    border: 1px solid #FF9057!important;; 
2433
2434.ssp-emed__vantagens-content.tecnico span{ 
2435  color: #F7BD23!important; 
2436
2437.ssp-emed__vantagens-content.tecnico a:hover { 
2438    color: white; 
2439    background-color: #F7BD23!important;; 
2440    border: 1px solid #F7BD23!important;; 
2441
2442.ssp-emed__vantagens-content.ensino-medio-tecnico span{ 
2443  color: #C761CB!important; 
2444
2445.ssp-emed__vantagens-content.ensino-medio-tecnico a:hover{ 
2446    color: white; 
2447    background-color: #C761CB!important;; 
2448    border: 1px solid #C761CB!important;; 
2449
2450.ssp-emed__vantagens-content.extensao span{ 
2451  color: #3ECCA6!important; 
2452
2453.ssp-emed__vantagens-content.extensao a:hover{ 
2454    color: white; 
2455    background-color: #3ECCA6!important; 
2456    border: 1px solid #3ECCA6!important; 
2457
2458 
2459/* Transferencias EMED */ 
2460 
2461.emed-transferencias-space{ 
2462  max-width: 772px; 
2463
2464 
2465.card-transferencias-emed { 
2466  text-align: left; 
2467
2468 
2469.card-transferencias-emed .ssp-emed__card-slider-body{ 
2470  padding: 30px; 
2471
2472 
2473.card-pre-inscricao { 
2474  text-align: center; 
2475
2476 
2477.card-pre-inscricao .ssp-emed__card-slider-body{ 
2478  justify-content: space-evenly; 
2479
2480 
2481.footer-card-card-pre-inscricao{ 
2482      margin-top: 48px; 
2483
2484 
2485.card-transferencias-emed, .card-pre-inscricao{ 
2486  span, strong{ 
2487    font-size: 24px; 
2488
2489  span{ 
2490    font-weight: 500; 
2491
2492  strong{ 
2493    font-weight: 700; 
2494
2495  .transferencias-emed-rodape{ 
2496    margin-top:25px; 
2497    span{ 
2498      font-size:0.9rem; 
2499      font-weight: 400; 
2500
2501
2502
2503 
2504@media only screen and (max-width: 768px){ 
2505  .card-pre-inscricao { 
2506    text-align: left; 
2507
2508 
2509  .footer-card-card-pre-inscricao{ 
2510      margin-top: 24px; 
2511
2512 
2513  .footer-card-card-pre-inscricao strong{ 
2514      margin-top: 24px; 
2515      font-size: 24px!important; 
2516
2517 
2518  .card-pre-inscricao .ssp-emed__card-slider { 
2519        width: 100%; 
2520        max-width: 329px; 
2521        min-height: 390px; 
2522        margin: 0; 
2523
2524 
2525  .card-pre-inscricao .ssp-emed__card-slider:nth-child(n+2){ 
2526        margin: 12px; 
2527
2528 
2529  .card-transferencias-emed, .card-pre-inscricao{ 
2530    span, strong{ 
2531      font-size: 16px; 
2532
2533    .ssp-emed__section__titleCard{ 
2534      flex-basis: 0; 
2535      margin-bottom: 24px!important; 
2536      align-items: center!important; 
2537    }  
2538 
2539    .ssp-emed__section__titleCard i{ 
2540      font-size: 24px!important; 
2541
2542 
2543    .ssp-emed__section__titleCard div{ 
2544      font-size: 20px !important; 
2545
2546
2547 
2548  .slick-area__item.card-pre-inscricao{ 
2549    min-height: 390px!important; 
2550
2551 
2552  .card-transferencias-emed .ssp-emed__card-slider{ 
2553    margin: 0; 
2554
2555 
2556  .card-transferencias-emed .ssp-emed__card-slider{ 
2557    margin: 0; 
2558    min-height: 300px; 
2559
2560 
2561  .card-transferencias-emed .col-md-12{ 
2562    padding: 0; 
2563
2564 
2565  .card-transferencias-emed .transferencias-emed-rodape span{ 
2566    font-size: 12px; 
2567
2568 
2569  .ssp-ofertas-emed__filtro-content .btn-filtro{ 
2570    width:156px !important; 
2571    font-size:14px !important; 
2572
2573 
2574  #titulo-emed{ 
2575    text-transform: uppercase; 
2576
2577 
2578  .emed-transferencias-space div:nth-child(n+2){ 
2579    padding-left:0; 
2580
2581 
2582  .emed-transferencias-space .slick-area-emed--md-bleed{ 
2583    position: inherit; 
2584
2585 
2586
2587 
2588</style> 
2589                
2590	 
2591  <#assign 
2592     
2593    prefix = "ssp" 
2594    nomeVocabularioTipoCurso = 'tipo-de-curso' 
2595     
2596   
2597    nomeVocabularioUnidades = 'unidades' 
2598     
2599    nomeVocabularioFormato = 'formato' 
2600     
2601    nomeFormato = ""   
2602    nomeVocabularioModalidade = 'modalidade' 
2603     
2604    nomeModalidade = ""   
2605     
2606    normalizer = serviceLocator.findService("com.liferay.portal.kernel.util.FriendlyURLNormalizer") 
2607   
2608    journalArticle = getJournalArticle() 
2609  /> 
2610   
2611  <#if journalArticle?contains("#erro#")> 
2612    erro 
2613  <#else> 
2614   
2615    <#assign 
2616   
2617      categories = getCategorias(journalArticle.getResourcePrimKey()) 
2618  
2619      document = saxReaderUtil.read(journalArticle.getContent()).getRootElement() 
2620   
2621      xPathSelector = saxReaderUtil.createXPath("dynamic-element[@field-reference='dataEfetivaFTFieldSet']") 
2622			dataEfetivaFTFieldSet	= xPathSelector.selectSingleNode(document) 
2623        
2624		  xPathSelector = saxReaderUtil.createXPath("//dynamic-element[@field-reference='dataEfetivaFT']") 
2625			dataEfetiva = xPathSelector.selectSingleNode(document) 
2626						  
2627			dataEfetivaSTR = dataEfetiva.elementText("dynamic-content")?string 
2628   
2629      articleId = journalArticle.getArticleId() 
2630   
2631      codigoFT = getStringValue(document,'codigoFT') 
2632   
2633      tituloComercial = journalArticle.getTitle() 
2634   
2635      objetivo = getStringValue(dataEfetivaFTFieldSet, 'objetivoComercial') 
2636       
2637      cargaHoraria = getStringValue(dataEfetivaFTFieldSet, 'cargaHorariaTotalFT') 
2638   
2639      oQueVouAprenderComercial = getStringValue(dataEfetivaFTFieldSet, 'oQueVouAprenderComercial') 
2640   
2641      comoVouAprenderComercial = getStringValue(dataEfetivaFTFieldSet, 'comoVouAprenderComercial') 
2642			 
2643			possoFazerEsteCursoComercial = getStringValue(dataEfetivaFTFieldSet, 'possoFazerEsteCursoComercial') 
2644						  
2645      tereiCertificadoComercial = getStringValue(dataEfetivaFTFieldSet, 'tereiCertificadoComercial') 
2646   
2647      tereiDiplomaComercial = getStringValue(dataEfetivaFTFieldSet, 'tereiDiplomaComercial') 
2648   
2649      precisoEstagiarComercial = getStringValue(dataEfetivaFTFieldSet, 'precisoEstagiarComercial') 
2650   
2651      comoMeMatricularComercial = getStringValue(dataEfetivaFTFieldSet, 'comoMeMatricularComercial') 
2652   
2653      oQueMaisPrecisoSaberComercial = getStringValue(dataEfetivaFTFieldSet, 'oQueMaisPrecisoSaberComercial') 
2654       
2655      normalizedModalidadeName  = "" 
2656   
2657    /> 
2658	 
2659    <div style="display: none;">ElasticSearchNaoRetornarFiltro </div> 
2660    <input type="hidden" name="codigoFT" value="${codigoFT}" /> 
2661    <input type="hidden" name="articleId" value="${articleId}" /> 
2662   
2663    <input type="hidden" name="dataEfetivaSTR" value="${dataEfetivaSTR}" /> 
2664     
2665    <input type="hidden" name="codUnidadeSelecionada" value="" /> 
2666   
2667    <#list categories as category> 
2668       
2669      <#assign 
2670        vocabulary = getVocabulary(category.getVocabularyId()) 
2671      /> 
2672   
2673      <#if normalizer.normalize(vocabulary.getName()) == nomeVocabularioTipoCurso> 
2674   
2675        <#assign 
2676          categoriaTipoCurso = category 
2677          normalizedCategoryName = normalizer.normalize(category.getName()) 
2678        /> 
2679         
2680        <input type="hidden" name="tipoCurso" value="${normalizedCategoryName}" /> 
2681         
2682      <#elseif normalizer.normalize(vocabulary.getName()) == nomeVocabularioUnidades> 
2683   
2684        <input type="hidden" name="unidades" value="${category.getCategoryId()}" data-unidade="${category.getName()}" /> 
2685       
2686      <#elseif normalizer.normalize(vocabulary.getName()) == nomeVocabularioModalidade> 
2687     
2688      <#assign 
2689          categoriaModalidade = category 
2690          normalizedModalidadeName = normalizer.normalize(category.getName()) 
2691           
2692        /> 
2693         
2694        <input type="hidden" name="modalidades" value="${normalizedModalidadeName}" /> 
2695         
2696      <#elseif normalizer.normalize(vocabulary.getName()) == nomeVocabularioFormato> 
2697      <#assign 
2698        nomeFormato = category.getName() 
2699      /> 
2700        
2701        
2702       <#assign idFormato = category.getCategoryId() /> 
2703        <#if nomeFormato == "Presencial + EAD" > 
2704            <input type="hidden" name="formato" value="${category.getCategoryId()}" data-formato="Presencial + EAD" /> 
2705        <#else> 
2706        	<input type="hidden" name="formato" value="${category.getCategoryId()}" data-formato="${category.getName()}" /> 
2707        </#if> 
2708      </#if> 
2709    </#list> 
2710   
2711    <#assign xPathSelector = saxReaderUtil.createXPath("//dynamic-element[@field-reference='imagemComercial']")> 
2712   
2713    <#if xPathSelector.selectSingleNode(dataEfetivaFTFieldSet)?? > 
2714   
2715      <#assign imagemStr = xPathSelector.selectSingleNode(dataEfetivaFTFieldSet).getStringValue()> 
2716      <#if imagemStr?contains("{") > 
2717        <#assign 
2718          imagemJson = jsonFactoryUtil.createJSONObject(imagemStr) 
2719          imagemId = getterUtil.getInteger(imagemJson.get('fileEntryId')) 
2720          dl = serviceLocator.findService("com.liferay.document.library.kernel.service.DLAppService") 
2721          dlURLHelper = serviceLocator.findService("com.liferay.document.library.util.DLURLHelper") 
2722          fileEntry = dl.getFileEntry(imagemId) 
2723          imagemAlt = imagemJson.get('alt') 
2724          imagemUrl = dlURLHelper.getDownloadURL(fileEntry, fileEntry.getFileVersion(), themeDisplay,null) 
2725        /> 
2726      <#else> 
2727        <#assign imagemUrl = ""> 
2728      </#if>   
2729   
2730    <#else> 
2731      <#assign imagemUrl = ""> 
2732    </#if> 
2733    
2734    
2735    <#assign  
2736          
2737        URLCodec = staticUtil["com.liferay.portal.kernel.util.URLCodec"]  
2738        HtmlUtil = staticUtil["com.liferay.portal.kernel.util.HtmlUtil"]  
2739       StringPool = staticUtil["com.liferay.petra.string.StringPool"]  
2740       dlFileEntryLocalService = serviceLocator.findService("com.liferay.document.library.kernel.service.DLFileEntryLocalService")  
2741        
2742         xPathSelector = saxReaderUtil.createXPath("//dynamic-element[@field-reference='quaisMateriaisComercial']") 
2743         quaisMateriaisComercialPDFStr = xPathSelector.selectSingleNode(dataEfetivaFTFieldSet).getStringValue() 
2744     /> 
2745	 
2746    <#if quaisMateriaisComercialPDFStr?contains('classPK') > 
2747     
2748      <#assign  
2749         
2750       PDFJson = jsonFactoryUtil.createJSONObject(quaisMateriaisComercialPDFStr) 
2751       classPKNumber = PDFJson.classPK?number 
2752       fileEntry = dlFileEntryLocalService.getDLFileEntry(classPKNumber) 
2753       folderId = fileEntry.getFolderId() 
2754       title = fileEntry.getTitle() 
2755        
2756       quaisMateriaisComercialPDFUrl = themeDisplay.getPortalURL() + themeDisplay.getPathContext() + "/documents/" + themeDisplay.getScopeGroupId() + StringPool.SLASH + folderId +  StringPool.SLASH + URLCodec.encodeURL(HtmlUtil.unescape(title)) 
2757       /> 
2758     
2759    <#else> 
2760      <#assign quaisMateriaisComercialPDFUrl = ""> 
2761    </#if> 
2762     
2763    <#function getFirstArticleStructure categoryId structureName> 
2764                <#attempt> 
2765                        <#assign searchImpl = serviceLocator.findService("br.senac.search.api.Search")> 
2766                        <#assign companyId = themeDisplay.getCompanyId()> 
2767                        <#assign groupId = themeDisplay.getScopeGroupId()> 
2768                        <#assign articles = searchImpl.findArticlesByCategoryIds(companyId, groupId, structureName, (categoryId gt 0)?then([categoryId],[]), true, 0, 1)> 
2769                        <#if articles?size gt 0> 
2770                                <#return articles?first> 
2771                        </#if> 
2772                        <#return ''> 
2773                <#recover> 
2774                                <#return ''> 
2775                </#attempt> 
2776        </#function> 
2777 
2778  
2779  <#assign  
2780    nomeTipoCurso = categoriaTipoCurso.getName() 
2781    nomeCategoriaTipoCurso = categoriaTipoCurso.getName() 
2782    idTipoCurso = categoriaTipoCurso.getCategoryId() 
2783         /> 
2784         <input type="hidden" name="nomeCategoriaTipoCurso" value="${nomeCategoriaTipoCurso}" /> 
2785 
2786      <#if nomeTipoCurso?contains("Ensino Médio Técnico")> 
2787 
2788        <#assign  
2789        nomeTipoCurso = categoriaTipoCurso.getName() 
2790        />  
2791         
2792        <input type="hidden" name="idTipoCurso" value="${idTipoCurso}" /> 
2793 
2794        <#elseif (nomeTipoCurso?contains("cnico") && !nomeTipoCurso?contains("EAD") ) || nomeTipoCurso?contains("Livre") > 
2795 
2796        <#assign  
2797         nomeTipoCurso = "Cursos "+ categoriaTipoCurso.getName() + "s" 
2798        /> 
2799 
2800      <#else> 
2801          <#assign  
2802              nomeTipoCurso = categoriaTipoCurso.getName() 
2803          />  
2804        <#assign nomeTipoCurso = categoriaTipoCurso.getName()/>  
2805    
2806    </#if> 
2807     
2808    <#--  Caso o curso seja do formato hibrido, busca o webcontent da pasta Onde as aulas vão acontecer - hibrido  --> 
2809    <#if nomeFormato == "Presencial + EAD"> 
2810        <#assign 
2811                hibridoStructure = getFirstArticleStructure(idFormato,"formato-hibrido") 
2812                documentHibrido = saxReaderUtil.read(hibridoStructure.getContent()) 
2813                rootElement = documentHibrido.getRootElement() 
2814                xPathSelector = saxReaderUtil.createXPath("dynamic-element[@field-reference='textoFormatoHibrido']") 
2815        /> 
2816        <#if xPathSelector.selectSingleNode(rootElement)?? > 
2817              <#assign txtHibrido = xPathSelector.selectSingleNode(rootElement).getStringValue()?trim /> 
2818              <input type="hidden" name="textoFormatoHibrido" value="${txtHibrido}"/> 
2819        </#if>               
2820  	</#if>               
2821     
2822     
2823    <#--  dados de compartilhamento  --> 
2824    <@liferay_util["html-top"]> 
2825        <meta name="image" property="og:image" content="${imagemUrl}"> 
2826        <meta property="og:image:width" content="1024"> 
2827    </@> 
2828    <#--  dados de compartilhamento  --> 
2829       
2830     
2831    <#assign  
2832      webContentServiceUtil = serviceLocator.findService("br.senac.services.service.WebContentServiceUtil") 
2833 
2834      temasMercadologicos = webContentServiceUtil.getTemasPorArticleId(themeDisplay.getScopeGroupId(), journalArticle) 
2835      categoriesIdiomas = temasMercadologicos?filter(c -> c.getName()?lower_case?contains("idioma")) 
2836      hasIdiomas = categoriesIdiomas?has_content 
2837      hasEMED = normalizedModalidadeName?contains("ensino-medio") 
2838    /> 
2839 
2840    <#function getManutencao> 
2841 
2842      <#assign manutencaoStructure = getFirstArticleStructure(idTipoCurso,"manutencoes") /> 
2843      <#if manutencaoStructure == ""> 
2844        <#return {"bolsa":"", "compra":"", "rodape":""} /> 
2845      </#if> 
2846      <#assign  
2847        txtBolsa = "" 
2848        txtCompra = "" 
2849        txtRodape = "" 
2850        content = saxReaderUtil.read(manutencaoStructure.getContent()) 
2851        rootElement = content.getRootElement() 
2852      /> 
2853      <#assign xPathSelector = saxReaderUtil.createXPath("dynamic-element[@field-reference='chkManutencaoBolsa']") /> 
2854      <#if xPathSelector.selectSingleNode(rootElement).getStringValue()?trim == "true" > 
2855        <#assign xPathSelector = saxReaderUtil.createXPath("dynamic-element[@field-reference='txtManutencaoBolsa']") /> 
2856        <#assign txtBolsa = xPathSelector.selectSingleNode(rootElement).getStringValue()?trim /> 
2857      </#if> 
2858      <#assign xPathSelector = saxReaderUtil.createXPath("dynamic-element[@field-reference='chkManutencaoCompra']") /> 
2859      <#if xPathSelector.selectSingleNode(rootElement).getStringValue()?trim == "true" > 
2860        <#assign xPathSelector = saxReaderUtil.createXPath("dynamic-element[@field-reference='txtManutencaoCompra']") /> 
2861        <#assign txtCompra = xPathSelector.selectSingleNode(rootElement).getStringValue()?trim /> 
2862      </#if> 
2863      <#if txtCompra != "" || txtBolsa != ""> 
2864        <#assign xPathSelector = saxReaderUtil.createXPath("dynamic-element[@field-reference='txtManutencaoRodape']") />   
2865        <#assign txtRodape = xPathSelector.selectSingleNode(rootElement).getStringValue()?trim /> 
2866      </#if> 
2867 
2868      <#return {"bolsa": txtBolsa, "compra": txtCompra, "rodape": txtRodape} /> 
2869 
2870    </#function> 
2871 
2872    <#assign manutencao = getManutencao() /> 
2873    <input type="hidden" id="manutencao-compra" value="${manutencao.compra}" /> 
2874    <input type="hidden" id="manutencao-bolsa" value="${manutencao.bolsa}" /> 
2875     
2876    <div class="${prefix}-header-curso__image"> 
2877      <img class="ssp-image-opacity" src="${imagemUrl}" <#if imagemAlt?length != 0> alt="${imagemAlt}"</#if> loading="lazy"> 
2878      <div class="${prefix}-header-curso__tag-formato bg-nivel-${normalizedCategoryName}"> 
2879        <#if hasIdiomas> 
2880          <span>${nomeTipoCurso}</span> 
2881        <#else> 
2882          <span>${nomeTipoCurso} | ${nomeFormato}</span> 
2883        </#if> 
2884      </div> 
2885    </div> 
2886   
2887    <section id="curso-info"> 
2888      <div class="ssp-card-detalhe-curso__container"> 
2889   
2890          <div class="ssp-card-detalhe-curso"> 
2891   
2892          <div class="ssp-card-detalhe-curso__tag-color-tipo bg-nivel-${normalizedCategoryName}"></div> 
2893   
2894            <div class="container"> 
2895            
2896              <#if nomeFormato?contains("ao-vivo") > 
2897                  <span class="ssp-card-detalhe-curso__tag-ao-vivo">Senac Online<i class="fas fa-signal-stream icon-ao-vivo" aria-hidden="true"></i>ao vivo</span> 
2898                   
2899              </#if> 
2900 
2901              <div class="ssp-card-detalhe-curso__content"> 
2902                <div> 
2903 
2904                    <!-- <#if nomeTipoCurso?contains("Ensino Médio Técnico")> 
2905 
2906                     <p class="ssp-txt-emed__inscricoes-aberta">Inscrições abertas</p> 
2907 
2908                    </#if> --> 
2909 
2910                    <!-- rever a lógica da chama de inscricoes abertas --> 
2911 
2912                    <h1 class="ssp-card-detalhe-curso__title">${tituloComercial}</h1> 
2913                    <input type="hidden" name="tituloComercial" value="${tituloComercial}" /> 
2914 
2915                    <div class="ssp-card-detalhe-curso__description">${objetivo}</div> 
2916                </div> 
2917                <div class="ssp-card-detalhe-curso__secunday-info-content"> 
2918 
2919                  <#if nomeFormato?contains("ao-vivo") > 
2920                    <span class="d-md-none"> 
2921                      <a class="ssp-card-detalhe-curso__secunday-info-back-link" href="#" style="color: #ff9057;">${categoriaTipoCurso.getName()}</a> 
2922                      <#if !hasIdiomas> 
2923                        <span> | ${nomeFormato}</span> 
2924                      </#if> 
2925                    </span> 
2926 
2927                  <#else> 
2928                    <span class="d-md-none"> 
2929                      <a class="ssp-card-detalhe-curso__secunday-info-back-link" href="#">${categoriaTipoCurso.getName()}</a>  
2930                      <#if !hasIdiomas> 
2931                        <span> | ${nomeFormato}</span> 
2932                      </#if> 
2933                    </span> 
2934 
2935                  </#if> 
2936 
2937                  <p class="ssp-card-detalhe-curso__secundary-info-carga-horaria">${cargaHoraria} horas</p> 
2938                </div> 
2939              </div> 
2940              <div class="ssp-saiba-mais-curso-accordion"> 
2941   
2942                  <#if (possoFazerEsteCursoComercial?length > 0)> 
2943                    <div class="ssp-saiba-mais-curso-accordion__body"> 
2944                        <div class="ssp-saiba-mais-curso-accordion__heading" role="button">Posso fazer este curso?</div> 
2945                        <div class="ssp-saiba-mais-curso-accordion__contents">${possoFazerEsteCursoComercial}</div> 
2946                    </div> 
2947									 
2948                  </#if> 
2949   
2950                   <#if (oQueVouAprenderComercial?length > 0) > 
2951                    <div class="ssp-saiba-mais-curso-accordion__body"> 
2952                        <div class="ssp-saiba-mais-curso-accordion__heading" role="button">O que vou aprender?</div> 
2953                        <div class="ssp-saiba-mais-curso-accordion__contents" id="plano-curso">${oQueVouAprenderComercial}</div> 
2954                    </div> 
2955                  </#if> 
2956   
2957                  <#if (comoVouAprenderComercial?length > 0)> 
2958                    <div class="ssp-saiba-mais-curso-accordion__body"> 
2959                        <div class="ssp-saiba-mais-curso-accordion__heading" role="button">Como vou aprender?</div> 
2960                        <div class="ssp-saiba-mais-curso-accordion__contents">${comoVouAprenderComercial}</div> 
2961                    </div> 
2962                  </#if> 
2963                   
2964                                  
2965                  <div class="ssp-saiba-mais-curso-accordion__body"> 
2966                      <div class="ssp-saiba-mais-curso-accordion__heading" role="button">Quais materiais vou precisar?</div> 
2967                      <#if nomeTipoCurso?contains("Ensino Médio Técnico") > 
2968                        <div class="ssp-saiba-mais-curso-accordion__contents"> 
2969                          Desenvolvemos os materiais e disponibilizamos tudo para você!<br/><br/>Também temos bibliotecas físicas e virtuais, além de parceria com a Microsoft, que garante acesso à plataforma Teams para conferir aulas, avisos e materiais da sua turma. 
2970                        </div> 
2971                      <#else> 
2972                        <#if (quaisMateriaisComercialPDFUrl?length > 0)> 
2973                          <div class="ssp-saiba-mais-curso-accordion__contents"> 
2974                            <a href="${quaisMateriaisComercialPDFUrl}" target="_blank"><i class="fa fa-download" aria-hidden="true"></i> Confira os materiais que você precisará.</a> 
2975                          </div> 
2976                        <#else> 
2977                          <div class="ssp-saiba-mais-curso-accordion__contents">Inicialmente, não há lista de materiais para este curso. Mas confirme em aula se será necessário comprar algum item.</div> 
2978                        </#if> 
2979                    </#if> 
2980                  </div> 
2981   
2982                  <#if (tereiDiplomaComercial?length > 0)> 
2983                    <div class="ssp-saiba-mais-curso-accordion__body"> 
2984                        <div class="ssp-saiba-mais-curso-accordion__heading" role="button">Terei diploma?</div> 
2985                        <div class="ssp-saiba-mais-curso-accordion__contents">${tereiDiplomaComercial}</div> 
2986                    </div> 
2987                  </#if> 
2988                   
2989                  <#if (tereiCertificadoComercial?length > 0)> 
2990                    <div class="ssp-saiba-mais-curso-accordion__body"> 
2991                        <div class="ssp-saiba-mais-curso-accordion__heading" role="button">Terei certificado?</div> 
2992                        <div class="ssp-saiba-mais-curso-accordion__contents">${tereiCertificadoComercial}</div> 
2993                    </div> 
2994                  </#if> 
2995   
2996                  <#if (comoMeMatricularComercial?length > 0)> 
2997                    <div class="ssp-saiba-mais-curso-accordion__body"> 
2998                        <div class="ssp-saiba-mais-curso-accordion__heading" role="button">Como me matricular?</div> 
2999                        <div class="ssp-saiba-mais-curso-accordion__contents">${comoMeMatricularComercial}</div> 
3000                    </div> 
3001                  </#if> 
3002   
3003                  <#if (precisoEstagiarComercial?length > 0)> 
3004                    <div class="ssp-saiba-mais-curso-accordion__body"> 
3005                        <div class="ssp-saiba-mais-curso-accordion__heading" role="button">Preciso estagiar?</div> 
3006                        <div class="ssp-saiba-mais-curso-accordion__contents">${precisoEstagiarComercial}</div> 
3007                    </div> 
3008                  </#if> 
3009   
3010   
3011                  <#if (oQueMaisPrecisoSaberComercial?length > 0)> 
3012                    <div class="ssp-saiba-mais-curso-accordion__body"> 
3013                    <#if nomeTipoCurso?contains("Ensino Médio Técnico") > 
3014                        <div class="ssp-saiba-mais-curso-accordion__heading" role="button">Estudo em outra escola, como funciona a transferência?</div> 
3015                    <#else> 
3016                      <div class="ssp-saiba-mais-curso-accordion__heading" role="button">O que mais preciso saber?</div> 
3017                    </#if> 
3018                        <div class="ssp-saiba-mais-curso-accordion__contents">${oQueMaisPrecisoSaberComercial}</div> 
3019                    </div> 
3020                  </#if> 
3021 
3022                  <!-- Info para EMED --> 
3023 
3024                  <#if nomeTipoCurso?contains("Ensino Médio Técnico") > 
3025 
3026                    <div class="ssp-emed__vantagens-content"> 
3027                                                                                                         
3028                      <p>Conheça <span>mais vantagens</span> do Ensino Médio Técnico no Senac.</p> 
3029                      <a href="/ensino-medio-tecnico" class="btn">Saiba mais</a> 
3030                   
3031                    </div> 
3032   
3033                  <#elseif nomeFormato?contains("Presencial") && nomeFormato?contains("EAD") && !nomeTipoCurso?contains("Idioma")> 
3034   
3035                    <!-- Info para híbrido --> 
3036   
3037                    <div class="ssp-emed__vantagens-content ${normalizedCategoryName}"> 
3038                                                                                                         
3039                      <p>Quer saber mais sobre nossos <span>cursos com aulas presenciais e a distância</span>?</p> 
3040                      <a href="/presencial-ead" class="btn">Saiba mais</a> 
3041                   
3042                    </div> 
3043                     
3044                  <#else> 
3045                     
3046                    <!-- <div class="ssp-emed__vantagens-content ${normalizedCategoryName}"> 
3047                                                                                                         
3048                      <p>Conheça <span>mais vantagens</span>?</p> 
3049                      <a href="#" class="btn">Saiba mais</a> 
3050                   
3051                    </div> --> 
3052                     
3053                  </#if> 
3054                                    
3055   
3056                  <!-- Slider para cursos de Cozinheiro e Garçom --> 
3057       
3058                  <#if codigoFT=="14125"> 
3059       
3060                    <div> 
3061   
3062                      <h6 style="font-family: Montserrat;font-size: 20px;font-weight: 600;color: #2a2e43;padding: 15px;border-top: 1px solid #e7e7e7;">Quer participar do processo seletivo? Confira todas as etapas:</h6> 
3063   
3064           
3065                      <div class="slider-passo-passo__cursos-cozinha"> 
3066           
3067                          <div class="ssp-passo-passo-cozinheiro_card"> 
3068                           
3069                              <div> 
3070   
3071                                  <h6 class="ssp-passo-passo-cozinheiro_card-title">Abertura do processo</h6> 
3072   
3073                                  <p class="ssp-passo-passo-cozinheiro_card-txt">Primeiro, confirme se você atende aos pré-requisitos para se inscrever em <a class="ssp-passo-passo-cozinheiro_card-link" href="/bolsas-de-estudo">bolsas de estudo</a>. Depois, confira no campo "Como me matricular?" o cronograma de abertura das inscrições do processo seletivo. </p> 
3074               
3075                              </div> 
3076                             
3077               
3078                          </div> 
3079               
3080                          <div class="ssp-passo-passo-cozinheiro_card"> 
3081               
3082                              <div> 
3083               
3084                                  <h6 class="ssp-passo-passo-cozinheiro_card-title">Inscrições</h6> 
3085               
3086                                  <p class="ssp-passo-passo-cozinheiro_card-txt">Quando o processo seletivo abrir, faça login no site, acesse a página do curso, selecione a unidade e realize a inscrição, que é gratuita. As inscrições podem ser encerradas antes da data divulgada, quando alcançarmos 10 inscrições por vaga.</p> 
3087               
3088                              </div> 
3089                                   
3090                          </div> 
3091           
3092                          <div class="ssp-passo-passo-cozinheiro_card"> 
3093               
3094                              <div> 
3095               
3096                                  <h6 class="ssp-passo-passo-cozinheiro_card-title">Convocação para entrevista</h6> 
3097               
3098                                  <p class="ssp-passo-passo-cozinheiro_card-txt"> 
3099                                    Ao finalizar sua inscrição no processo seletivo, você receberá uma confirmação no e-mail que cadastrou no nosso site. Também vamos enviar para o seu e-mail o convite para a entrevista e as orientações sobre envio dos documentos necessários. 
3100                                  </p> 
3101                                 
3102               
3103                              </div> 
3104                                   
3105                          </div> 
3106   
3107                          <div class="ssp-passo-passo-cozinheiro_card"> 
3108               
3109                            <div> 
3110             
3111                                <h6 class="ssp-passo-passo-cozinheiro_card-title">Entrevista</h6> 
3112             
3113                                <p class="ssp-passo-passo-cozinheiro_card-txt">A entrevista será realizada presencialmente nos hotéis-escola Senac. Se você não participar, sua inscrição é cancelada automaticamente. Lembre-se: antes da entrevista, envie por e-mail os documentos necessários. 
3114                                    </p> 
3115                               
3116             
3117                            </div> 
3118                                 
3119                        </div> 
3120           
3121                          <div class="ssp-passo-passo-cozinheiro_card"> 
3122               
3123                              <div> 
3124               
3125                                  <h6 class="ssp-passo-passo-cozinheiro_card-title">Resultado</h6> 
3126               
3127                                  <p class="ssp-passo-passo-cozinheiro_card-txt"> 
3128                                    Até 7 dias depois de ter feito a entrevista, você receberá a resposta por e-mail sobre o resultado do processo seletivo.  
3129                                  </p> 
3130               
3131                              </div> 
3132                                   
3133                          </div> 
3134               
3135                          <div class="ssp-passo-passo-cozinheiro_card"> 
3136               
3137                              <div> 
3138               
3139                                  <h6 class="ssp-passo-passo-cozinheiro_card-title">Matrícula</h6> 
3140               
3141                                  <p class="ssp-passo-passo-cozinheiro_card-txt"> 
3142                                    Se receber a aprovação, a próxima etapa é fazer a matrícula. Lembre-se de enviar os documentos, inclusive os exames solicitados no e-mail.                            
3143                                  </p> 
3144               
3145                              </div> 
3146                                   
3147                          </div> 
3148           
3149                          <div class="ssp-passo-passo-cozinheiro_card"> 
3150               
3151                              <div> 
3152               
3153                                  <h6 class="ssp-passo-passo-cozinheiro_card-title">Início do curso!</h6> 
3154               
3155                                  <p class="ssp-passo-passo-cozinheiro_card-txt"> 
3156                                    Teve aprovação em todas as etapas? Parabéns! 
3157   
3158                                    Sua jornada de transformação profissional 
3159                                     
3160                                    começará com o início das aulas. Mas se não 
3161                                     
3162                                    conseguiu dessa vez, não desanime. Sempre estamos com 
3163                                     
3164                                    vagas abertas para diversos cursos.                                                           
3165                                  </p> 
3166               
3167                              </div> 
3168                                   
3169                          </div> 
3170               
3171                           
3172                      </div> 
3173           
3174                    </div> 
3175   
3176                    <#elseif codigoFT=="15390" > 
3177   
3178                    <div> 
3179   
3180                      <h6 style="font-family: Montserrat;font-size: 20px;font-weight: 600;color: #2a2e43;padding: 15px;border-top: 1px solid #e7e7e7;">Quer participar do processo seletivo? Confira todas as etapas:</h6> 
3181           
3182                      <div class="slider-passo-passo__cursos-cozinha"> 
3183           
3184                        <div class="ssp-passo-passo-cozinheiro_card"> 
3185                         
3186                          <div> 
3187   
3188                                  <h6 class="ssp-passo-passo-cozinheiro_card-title">Abertura do processo</h6> 
3189   
3190                                  <p class="ssp-passo-passo-cozinheiro_card-txt">Primeiro, confirme se você atende aos pré-requisitos para se inscrever em <a class="ssp-passo-passo-cozinheiro_card-link" href="/bolsas-de-estudo">bolsas de estudo</a>. Depois, confira no campo "Como me matricular?" o cronograma de abertura das inscrições do processo seletivo. </p> 
3191               
3192                              </div> 
3193                           
3194             
3195                        </div> 
3196             
3197                        <div class="ssp-passo-passo-cozinheiro_card"> 
3198             
3199                              <div> 
3200               
3201                                  <h6 class="ssp-passo-passo-cozinheiro_card-title">Inscrições</h6> 
3202               
3203                                  <p class="ssp-passo-passo-cozinheiro_card-txt">Quando o processo seletivo abrir, faça login no site, acesse a página do curso, selecione a unidade e realize a inscrição, que é gratuita. As inscrições podem ser encerradas antes da data divulgada, quando alcançarmos 10 inscrições por vaga.</p> 
3204               
3205                              </div> 
3206                                 
3207                        </div> 
3208         
3209                        <div class="ssp-passo-passo-cozinheiro_card"> 
3210             
3211                              <div> 
3212               
3213                                  <h6 class="ssp-passo-passo-cozinheiro_card-title">Convocação para entrevista</h6> 
3214               
3215                                  <p class="ssp-passo-passo-cozinheiro_card-txt"> 
3216                                    Ao finalizar sua inscrição no processo seletivo, você receberá uma confirmação no e-mail que cadastrou no nosso site. Também vamos enviar para o seu e-mail o convite para a entrevista e as orientações sobre envio dos documentos necessários. 
3217                                  </p> 
3218                                 
3219               
3220                              </div> 
3221                                 
3222                        </div> 
3223   
3224                        <div class="ssp-passo-passo-cozinheiro_card"> 
3225             
3226                            <div> 
3227             
3228                                <h6 class="ssp-passo-passo-cozinheiro_card-title">Entrevista</h6> 
3229             
3230                                <p class="ssp-passo-passo-cozinheiro_card-txt">A entrevista será realizada presencialmente nos hotéis-escola Senac. Se você não participar, sua inscrição é cancelada automaticamente. Lembre-se: antes da entrevista, envie por e-mail os documentos necessários. 
3231                                    </p> 
3232                               
3233             
3234                            </div> 
3235                               
3236                      </div> 
3237         
3238                        <div class="ssp-passo-passo-cozinheiro_card"> 
3239             
3240                            <div> 
3241             
3242                                <h6 class="ssp-passo-passo-cozinheiro_card-title">Resultado</h6> 
3243             
3244                                <p class="ssp-passo-passo-cozinheiro_card-txt"> 
3245                                  Até 7 dias depois de ter feito a entrevista, você receberá a resposta por e-mail sobre o resultado do processo seletivo.  
3246                                </p> 
3247             
3248                            </div> 
3249                                 
3250                        </div> 
3251             
3252                        <div class="ssp-passo-passo-cozinheiro_card"> 
3253             
3254                            <div> 
3255             
3256                                <h6 class="ssp-passo-passo-cozinheiro_card-title">Matrícula</h6> 
3257             
3258                                <p class="ssp-passo-passo-cozinheiro_card-txt"> 
3259                                  Se receber a aprovação, a próxima etapa é fazer a matrícula. Lembre-se de enviar os documentos, inclusive os exames solicitados no e-mail.                            
3260                                </p> 
3261             
3262                            </div> 
3263                                 
3264                        </div> 
3265         
3266                        <div class="ssp-passo-passo-cozinheiro_card"> 
3267             
3268                            <div> 
3269             
3270                                <h6 class="ssp-passo-passo-cozinheiro_card-title">Início do curso!</h6> 
3271             
3272                                <p class="ssp-passo-passo-cozinheiro_card-txt"> 
3273                                  Teve aprovação em todas as etapas? Parabéns! 
3274   
3275                                  Sua jornada de transformação profissional 
3276                                   
3277                                  começará com o início das aulas. Mas se não 
3278                                   
3279                                  conseguiu dessa vez, não desanime. Sempre estamos com 
3280                                   
3281                                  vagas abertas para diversos cursos.                                                           
3282                                </p> 
3283             
3284                            </div> 
3285                                 
3286                        </div> 
3287             
3288                         
3289                    </div> 
3290   
3291                  </div> 
3292   
3293                  </#if> 
3294                   
3295                  <!-- Final Slider para cursos de Cozinheiro e Garçom --> 
3296   
3297              </div> 
3298            </div> 
3299          </div> 
3300      </div> 
3301    </section> 
3302  <#assign  
3303    dNoneSelectUnidade = ''  
3304    mostrarUnidades = !nomeFormato?contains("ao-vivo") 
3305    isEMED = normalizedCategoryName?contains("ensino-medio-tecnico") 
3306    isAprendizagem = normalizedCategoryName?contains("jovem-aprendiz") 
3307  /> 
3308 
3309  <#if nomeFormato?contains("ao-vivo") > 
3310     <#assign dNoneSelectUnidade = 'd-none' /> 
3311  </#if> 
3312 
3313  <#-- Obter data matricula emed --> 
3314  <#if isEMED> 
3315    <#function getMatriculaEMED > 
3316      <#assign emedTags = getFirstArticleStructure(0,"emed-tags") 
3317        document = saxReaderUtil.read(emedTags.getContent()) 
3318        rootElement = document.getRootElement() 
3319        xPathSelector = saxReaderUtil.createXPath("dynamic-element[@field-reference='dataInicioPeriodoMatricula']") /> 
3320      <#if xPathSelector.selectSingleNode(rootElement)?? > 
3321        <#assign dataInicio = xPathSelector.selectSingleNode(rootElement).getStringValue()?trim /> 
3322      </#if> 
3323      <#assign xPathSelector = saxReaderUtil.createXPath("dynamic-element[@field-reference='horaInicioMatricula']") /> 
3324      <#if xPathSelector.selectSingleNode(rootElement)?? > 
3325        <#assign horaInicio = xPathSelector.selectSingleNode(rootElement).getStringValue()?trim /> 
3326      </#if> 
3327 
3328      <#setting time_zone="America/Sao_Paulo"> 
3329      <#assign today = .now?datetime /> 
3330      <#assign emeddatetime = (dataInicio + " " + horaInicio)?datetime["yyyy-MM-dd HH:mm"] /> 
3331      <#assign matriculaAberta = today gt emeddatetime />     
3332 
3333      <#return {"dataInicio" : dataInicio, "horaInicio" : horaInicio, "aberta" : matriculaAberta}> 
3334    </#function> 
3335 
3336    <#assign matriculaEMED = getMatriculaEMED() /> 
3337 
3338  </#if> 
3339 
3340  <#if isEMED || isAprendizagem> 
3341    <section class="ssp-section-selecione-unidade ssp-section ${dNoneSelectUnidade}" style="background:#2B2E41"> 
3342      <div class="container"> 
3343 
3344        <div class="ssp-container-selecione-unidade" style="max-width: 815px; margin: auto;"> 
3345          <div class="ssp-container_ofertas__title"> 
3346            <h3 class="ssp-aviso-novas-turmas__title selecione-unidade-title-custom"> 
3347               
3348              Selecione uma unidade para conhecer as próximas turmas: 
3349 
3350            </h3> 
3351          </div> 
3352 
3353          <div class="ssp-container__form-select"> 
3354            <select id="unidades-ofertas" class="form-control" name="unidades-ofertas"> 
3355              <option value="">Selecione uma unidade</option> 
3356            </select> 
3357          </div> 
3358 
3359        </div> 
3360 
3361        <div class="ssp-ofertas__box-endereco-unidade"> 
3362          <i class="icon-map-adress"></i> 
3363          <a href="" target="_blank" class="ssp-ofertas__endereco-unidade"></a> 
3364        </div> 
3365 
3366      </div> 
3367 
3368    </section> 
3369  <#else> 
3370    <section class="ssp-section-selecione-unidade ssp-section" style="background:#2B2E41"> 
3371        <div class="container"> 
3372          <div class="ssp-container-selecione-unidade ${dNoneSelectUnidade} row no-gutters mb-lg-8"> 
3373            <div class="ssp-container_ofertas__title"> 
3374              <h3 class="ssp-aviso-novas-turmas__title selecione-unidade-title-custom ssp-detalhe-curso-titulo-filter">Escolha a unidade e conheça as turmas disponíveis:</h3> 
3375            </div> 
3376          </div> 
3377          <div class="row ssp-filters-px justify-content-center"> 
3378            <div class="col-12 col-lg ${dNoneSelectUnidade} px-md-0 order-1"> 
3379              <div class="ssp-container-selecione-unidade row no-gutters"> 
3380                <div class="col-12"> 
3381                  <div class="ssp-container__form-select mx-auto"> 
3382                    <label for="unidades-ofertas" class="ssp-switch-label ssp-switch-label-section mx-0 d-none d-lg-block">Selecione uma unidade:</label>   
3383                    <select id="unidades-ofertas" class="form-control" name="unidades-ofertas"></select> 
3384                  </div> 
3385                </div> 
3386              </div> 
3387            </div> 
3388             
3389            <div id="ssp-alternadores" class="col mt-5 mt-lg-0 ${(isEMED || isAprendizagem)?then('d-none', '')} px-md-0 order-3 order-lg-2" style="max-width: 480px; display: none;"> 
3390              <div class="row no-gutters ssp-switch-label ssp-switch-label-section mx-0">Filtre por:</div> 
3391              <div class="row no-gutters mt-4"> 
3392                <#assign 
3393                  mostrarFiltroInscricao = (nomeTipoCurso?contains("Técnico") && !nomeTipoCurso?contains("Ensino Médio")) || nomeTipoCurso?contains("Livre") || nomeTipoCurso?contains("Extensão") 
3394                  mostrarFiltroBolsa = (nomeTipoCurso?contains("Técnico") && !nomeTipoCurso?contains("Ensino Médio")) || nomeTipoCurso?contains("Livre") 
3395                /> 
3396                 
3397                 
3398                <#if mostrarFiltroInscricao && mostrarFiltroBolsa> 
3399                  <div class="ssp-switch-divider d-md-none my-4"></div> 
3400                </#if> 
3401                 
3402                <#if mostrarFiltroInscricao> 
3403                  <div class="col-12 col-lg"> 
3404                    <div class="d-flex justify-content-between justify-content-lg-start"> 
3405                      <label class="ssp-switch order-2 order-lg-1"> 
3406                        <input type="checkbox" id="chkInscricao"> 
3407                        <span class="ssp-switch-slider round"></span> 
3408                      </label> 
3409                      <label for="chkInscricao" class="ssp-switch-label order-1 order-lg-2">Comprar agora</label>   
3410                    </div> 
3411                  </div> 
3412                </#if> 
3413                 
3414 
3415                <#if mostrarFiltroBolsa> 
3416                  <div class="col-12 col-lg"> 
3417                    <div class="d-flex justify-content-between justify-content-lg-start"> 
3418                      <label class="ssp-switch order-2 order-lg-1">             
3419                        <input type="checkbox" id="chkBolsa"> 
3420                        <span class="ssp-switch-slider ssp-switch-slider-secondary round"></span> 
3421                      </label> 
3422                      <label for="chkBolsa" class="ssp-switch-label order-1 order-lg-2">Bolsas de estudo</label> 
3423                    </div> 
3424                  </div> 
3425                </#if> 
3426              </div> 
3427            </div> 
3428 
3429            <div class="col-12 order-2 order-lg-3"> 
3430              <div class="row ${mostrarUnidades?then('text-center text-lg-left', 'text-center')}"> 
3431                <div id="msgFiltroAplicado" class="col-12 ssp-switch-label-message" style="display: none;"> 
3432                  <div class="row no-gutters"> 
3433                    <span class="col-12 ssp-col-lg-without ${mostrarUnidades?then('', 'ml-auto')}">Filtro aplicado com sucesso.&nbsp;</span> 
3434                    <span class="col-12 ssp-col-lg-without ${mostrarUnidades?then('', 'mr-auto')}">Confira o resultado.</span> 
3435                  </div> 
3436                </div> 
3437              </div> 
3438            </div> 
3439          </div>      
3440             
3441          <div class="ssp-ofertas__box-endereco-unidade ${dNoneSelectUnidade}"> 
3442            <i class="icon-map-adress"></i> 
3443            <a href="" target="_blank" class="ssp-ofertas__endereco-unidade"></a> 
3444          </div> 
3445     
3446        </div> 
3447     
3448      </section> 
3449    </#if> 
3450   
3451     
3452      <!--  EMED	 --> 
3453      <section class="ssp-ofertas-emed__section d-none"> 
3454 
3455        <h2 class="title-section-white" id="titulo-emed"></h2> 
3456 
3457        <div class="ssp-ofertas-emed__filtro-content container"> 
3458 
3459            <button type="button" value="0010" class="btn btn-filtro btn--filtro-ativo">Turmas - 1º ano</button> 
3460 
3461            <button type="button" value="0" class="btn btn-filtro">Transferências</button> 
3462 
3463        </div> 
3464         
3465        <div class="ssp-ofertas-emed__card-container"> 
3466 
3467          <div class="ssp-slick-ofertas-emed"> 
3468           
3469          </div> 
3470         
3471        </div> 
3472       
3473      </section> 
3474       
3475      <!-- FIM EMED -->	 
3476   
3477    <section id="ssp-section-response" class="ssp-section" style="background: #2a2e43; position: relative;"> 
3478   
3479      <div id="turmas-container" class="container"> 
3480   
3481        <div id="informe-novas-turmas"> 
3482          <div style="display: flex; flex-wrap: nowrap;"> 
3483   
3484            <a class="prev-mobile d-lg-none d-xl-none nextPrevOpacity" href="#" > 
3485              <i class="fas fa-chevron-left"></i> 
3486            </a> 
3487   
3488            <h2 id="ssp-h3-turmas" class="ssp-section-title ssp-card-oferta-curso__section-title text-capitalize" style="font-weight: bold;text-transform: uppercase; display: none;">Turmas</h2> 
3489   
3490            <a href="#" class="next-mobile d-lg-none d-xl-none" > 
3491              <i class="fas fa-chevron-right"></i> 
3492            </a> 
3493   
3494          </div> 
3495           
3496       
3497          <div  class="oferta-slick-area oferta-slick-area--md-bleed slider-container"> 
3498     
3499          </div> 
3500        </div> 
3501          
3502        <#if !isEMED> 
3503            <div class="ssp-card-oferta-curso__sem-vaga d-none" style="margin: auto;"> 
3504       
3505              <h3 class="ssp-card-oferta-curso__sem-vaga-title"> 
3506                Estude com a gente na próxima turma! 
3507              </h3> 
3508           
3509              <p class="ssp-card-oferta-curso__sem-vaga-description"> 
3510                Registre seu interesse e avisaremos você quando surgirem novas vagas. 
3511              </p> 
3512            </div> 
3513        <#else> 
3514 
3515          <div class="card-transferencias-emed container p-0 d-none emed-transferencias-space"> 
3516            <div> 
3517              <div class="col-md-12 col-xs-12 pb-10"> 
3518                <div> 
3519                  <div class="slick-area__item"> 
3520           
3521                    <div class="ssp-emed__card-slider"> 
3522       
3523                      <div class="ssp-emed__card-slider-body"> 
3524                        <h2 class="ssp-emed__section__titleCard"> 
3525                          <i class="fal fa-users-class"></i> 
3526                          <div><lfr-editable type="rich-text">Turmas</lfr-editable></div> 
3527                        </h2> 
3528                        <lfr-editable type="rich-text"> 
3529                          <div> 
3530                            <strong>Transferências: estudantes de outras escolas e estudantes Senac</strong> 
3531                            <div style="display:grid;gap:20px;"> 
3532                              <span></span> 
3533                              <span>1º e 2º ano: a partir de 2025</span> 
3534                              <span></span> 
3535                            </div> 
3536                          </div> 
3537 
3538                          <div class="transferencias-emed-rodape"> 
3539                            <span>As vagas serão abertas mediante disponibilidade e as datas para transferências divulgadas em breve.</span> 
3540                          </div> 
3541                         
3542                        </lfr-editable> 
3543                        </a> 
3544                      </div> 
3545       
3546                    </div> 
3547       
3548                  </div> 
3549                </div> 
3550              </div> 
3551            </div> 
3552          </div> 
3553 
3554          <#if matriculaEMED.aberta> <div class="sem-vaga-emed container p-0 d-none"> 
3555          <#else> <div class="sem-vaga-emed container p-0 d-none emed-transferencias-space"> 
3556          </#if> 
3557              <div> 
3558                <div class="col-md-12 col-xs-12 pb-10"> 
3559         
3560                  <!--slick slider--> 
3561                  <div class="slick-area-emed slick-area-emed--md-bleed"> 
3562                     
3563                    <#if matriculaEMED.aberta> 
3564                      <div class="slick-area__item"> 
3565           
3566                        <div class="ssp-emed__card-slider"> 
3567           
3568                          <div class="ssp-emed__card-slider-body"> 
3569                            <h2 class="ssp-emed__section__titleCard"> 
3570                              <i class="fal fa-users-class"></i> 
3571                              <div><lfr-editable type="rich-text">Turmas</lfr-editable></div> 
3572                            </h2> 
3573                            <lfr-editable type="rich-text"> 
3574                              <div class="ssp-emed__section__introCard"><strong>Estude com a gente na próxima turma!</strong></div> 
3575                              <div class="ssp-emed__section__textCard"> 
3576                                <span class="texto"> 
3577                                  Registre seu interesse e avisaremos você sobre a abertura das inscrições para o próximo ano. 
3578                                </span> 
3579                                <span class="ssp-emed__iconWrapper animate__animated animate__fadeOutRight animate__infinite"><i 
3580                                    class="fas fa-chevron-right"></i></span> 
3581                              </div> 
3582                            </lfr-editable> 
3583                            </a> 
3584                          </div> 
3585           
3586                        </div> 
3587           
3588                      </div> 
3589         
3590                      <div class="slick-area__item"> 
3591           
3592                        <div class="ssp-emed__card-slider"> 
3593                          <div class="ssp-emed__card-slider-body"> 
3594           
3595                            <h2 class="ssp-emed__section__titleCard"> 
3596                              <i class="far fa-envelope"></i> 
3597                              <div><lfr-editable id="emed-precos-title" type="rich-text">Registro de Interesse</lfr-editable></div> 
3598                            </h2> 
3599                            <lfr-editable id="txt_emed_boleto" type="rich-text"> 
3600                              <div class="ssp-emed__section__introCardCTA"> 
3601                                Quer receber um aviso sobre as turmas do próximo ano? 
3602                              </div> 
3603                            </lfr-editable> 
3604                            </a> 
3605                            <a class="ssp-emed__btn btn btn-lg w-100 mt-3 ssp-card-modal-selecionar-outro__btn-close_10" 
3606                              id="btnOptin" href="javascript:;">Sim, me avise.</a> 
3607                          </div> 
3608                        </div> 
3609                      </div> 
3610                    <#else> 
3611                      <#-- pre inscricao emed --> 
3612                      <div class="slick-area__item card-pre-inscricao"> 
3613           
3614                        <div class="ssp-emed__card-slider"> 
3615           
3616                          <div class="ssp-emed__card-slider-body"> 
3617                            <h2 class="ssp-emed__section__titleCard"> 
3618                              <i class="fal fa-users-class"></i> 
3619                              <div><lfr-editable id="emed-aulas-title" type="rich-text">Turmas</lfr-editable></div> 
3620                            </h2> 
3621                            <lfr-editable id="txt_emed_aulas" type="rich-text"> 
3622                              <div> 
3623                                <strong>Matrículas e inscrições para bolsas de estudo:</strong><br/> 
3624                                <span style="font-weight: 400;"> 
3625                                  a partir de ${matriculaEMED.dataInicio?split("-")?reverse?join("/")}, às ${matriculaEMED.horaInicio?split(":")?first} horas 
3626                                  <#if matriculaEMED.horaInicio?split(":")?last != "00"> 
3627                                    e ${matriculaEMED.horaInicio?split(":")?last} minutos 
3628                                  </#if> 
3629                                </span> 
3630                              </div> 
3631 
3632                              <div class="footer-card-card-pre-inscricao"> 
3633                                <strong> 
3634                                  Estude com a gente na próxima turma!<br/> 
3635                                  Esperamos por você! 
3636                                </strong> 
3637                              </div> 
3638                            </lfr-editable> 
3639                            </a> 
3640                          </div> 
3641           
3642                        </div> 
3643           
3644                      </div> 
3645 
3646                    </#if> 
3647         
3648                  </div> 
3649                  <!--/slick slider--> 
3650         
3651                </div> 
3652              </div> 
3653            </div> 
3654        </#if> 
3655        <div class="oferta-slick-area_modal"> 
3656        </div> 
3657         
3658        <#if manutencao.rodape != ""> 
3659          <p class="ssp-card-oferta-curso__mensagem-legal">${manutencao.rodape}</p> 
3660        <#else> 
3661            <#if isEMED> 
3662              <p class="ssp-card-oferta-curso__mensagem-legal">O Senac reserva-se o direito de alterar o número de vagas, datas, horários ou cancelar o programa.</p> 
3663            <#else> 
3664              <p class="ssp-card-oferta-curso__mensagem-legal">A turma pode ser cancelada ou ter alterações do número de vagas, datas e horários.</p> 
3665            </#if> 
3666        </#if> 
3667   
3668      </div> 
3669   
3670      <div id="ssp-abrir-pagina-bolsa" class="ssp-card-duvida__bolsa-estudo d-none" style="margin-top: 44px;"> 
3671 
3672        <p>Tem dúvidas sobre bolsas de estudo?</p> 
3673        <a href="/bolsas-de-estudo/como-funciona">Saiba como funciona</a> 
3674						 
3675    </div> 
3676                       
3677   
3678      </section> 
3679 
3680      <section id="section-registro-interesse" class="ssp-section-novas-turmas"> 
3681   
3682          <div class="container"> 
3683   
3684              <div class="ssp-aviso-novas-turmas__content"> 
3685   
3686                  <!-- <div class="pb-sm-5 pb-md-5" > --> 
3687                  <div> 
3688   
3689                      <h6 class="ssp-aviso-novas-turmas__title">Quer receber um aviso por e-mail sobre novas turmas?</h6> 
3690                      <!-- p class="ssp-aviso-novas-turmas__description">Selecione a unidade e registre seu interesse.</p --> 
3691   
3692                  </div> 
3693   
3694          <!--  
3695                  <div class="ssp-container__form-select"> 
3696   
3697                      <select class="form-control select-large select-registro-interesse" id="select-registro-interesse"> 
3698                          <option value="">Selecione uma unidade</option> 
3699                      </select> 
3700   
3701                  </div> 
3702          --> 
3703                  <div class="ssp-btn-group__content-teste"> 
3704   
3705                      <a class="btn btn-primary btn-custom" id="btn-aviso-novas-turmas">Sim, me avise</a> 
3706   
3707                  </div> 
3708   
3709   
3710   
3711              </div> 
3712   
3713   
3714          </div> 
3715   
3716   
3717      </section> 
3718       
3719      <section id="modal-backpack-error" class="ssp-modal-registro-interesse d-none"> 
3720   
3721          <div class="ssp-card-msg-erro"> 
3722   
3723              <div class="ssp-card-msg-sucesso__content"> 
3724                  <i class="fas fa-exclamation-circle" style="color: #ec3a3a;"></i> 
3725                   <p>Houve um erro ao inserir curso na mochila!</p> 
3726                   <p>Por favor, tente novamente!</p> 
3727              </div> 
3728   
3729              <div> 
3730                  <button id="btn-voltar-modal-backpack-error" class="btn btn-nivel ssp-card-msg-sucesso__btn">Voltar</button> 
3731              </div> 
3732   
3733          </div> 
3734   
3735      </section> 
3736       
3737	<section id="modal-backpack-success" class="ssp-modal-registro-interesse d-none"> 
3738	 
3739		<div class="ssp-modal-mochila-curso"> 
3740	 
3741			<div class="ssp-modal-mochila-curso__header"> 
3742	 
3743				<button class="modal-btn-close" type="button"> 
3744	 
3745					<i class="fal fa-times"></i> 
3746	 
3747				</button> 
3748	 
3749				<h2 class="modal-title">Curso adicionado à mochila!</h2> 
3750				<p class="modal-subtitle">Você incluiu na sua mochila de compras o curso 
3751					<span id="modal-backpack-success__nome-curso"></span> 
3752				</p> 
3753	 
3754			</div> 
3755	 
3756			<div class="ssp-modal-mochila-curso__body"> 
3757	 
3758				<p>A sua vaga só é garantida nesta turma quando você finaliza a 
3759					compra. Deseja concluir agora?</p> 
3760	 
3761			</div> 
3762	 
3763			<div class="ssp-modal-mochila-curso__block-btn-items block-btn-items"> 
3764 
3765				<a class="btn-finalizar-compra btn-mochila-finalizar-compra-success" href="#"> 
3766                    Finalizar compra 
3767                </a> 
3768	 
3769				<button class="btn-continuar-site btn-mochila-continuar-site-success"> 
3770					Continuar no site 
3771				</button>				 
3772	 
3773			</div> 
3774	 
3775	 
3776		</div> 
3777	 
3778	</section> 
3779      
3780</#if> 
3781 
3782<#if nomeTipoCurso?has_content && nomeTipoCurso?contains("Ensino Médio Técnico") > 
3783  <!-- Agende a sua visita -->     
3784  <#assign searchImpl = serviceLocator.findService("br.senac.search.api.Search") /> 
3785  <#assign articles = searchImpl.search("EMED - Agende sua visita", {}, themeDisplay.getCompanyId(), themeDisplay.getScopeGroupId(), themeDisplay.getUserId(), false) /> 
3786 
3787  <section id="ssp-emed-visita-sector"> 
3788    <div class="container py-5 pt-lg-0" style="display:none;"> 
3789      <div data-emed="ssp-emed-visita-wrapper" class="ssp-emed-visita-wrapper"> 
3790        <#list articles![] as article> 
3791          <#assign document = saxReaderUtil.read(article.getContent()) /> 
3792          <#assign rootElement = document.getRootElement() /> 
3793 
3794          <#assign 
3795              xPathSelector = saxReaderUtil.createXPath("dynamic-element[@field-reference='textoDoBotao']") 
3796              textoDoBotao = xPathSelector.selectSingleNode(rootElement).getStringValue() 
3797                 
3798              xPathSelector = saxReaderUtil.createXPath("dynamic-element[@field-reference='linkBotao']") 
3799              linkBotao = xPathSelector.selectSingleNode(rootElement).getStringValue() 
3800 
3801              xPathSelector = saxReaderUtil.createXPath("dynamic-element[@field-reference='ativarBotao']") 
3802              ativarBotao = xPathSelector.selectSingleNode(rootElement).getStringValue()                 
3803          /> 
3804 
3805          <#if ativarBotao?trim == "true"> 
3806            <script>$('#ssp-emed-visita-sector').children().show()</script> 
3807            <div data-emed="ssp-emed-visita-text" class="ssp-emed-visita-text"> 
3808                 
3809                <a href="${linkBotao}">${textoDoBotao}</a> 
3810                 
3811            </div> 
3812            <div class="ssp-emed-visita-icon"> 
3813                <i class="fas fa-route"></i> 
3814            </div> 
3815          </#if> 
3816        </#list> 
3817      </div> 
3818    </div> 
3819  </section> 
3820 
3821 
3822    <!-- Como me matricular EMED --> 
3823 
3824    <section class="ssp-como-me-matricular__section"> 
3825 
3826      <h2 class="title-section-white">Como me matricular?</h2> 
3827 
3828      <div class="container"> 
3829 
3830          <div class="ssp-como-me-matricular__passo-passo-card"> 
3831 
3832              <div class="item-passo"> 
3833                  <img class="item-passo-icone" src="/o/senac-theme/images/icon-escolha-curso.svg" alt=""> 
3834                  <p class="item-passo-title">Escolha o curso</p> 
3835                  <span>Selecione o curso, a unidade do seu interesse e confira as turmas disponíveis.</span> 
3836              </div> 
3837 
3838              <img class="item-passo-icone-seta" src="/o/senac-theme/images/icon-seta-passo.svg" alt=""> 
3839 
3840              <div class="item-passo"> 
3841                  <img class="item-passo-icone" src="/o/senac-theme/images/icon-realize-inscricao.svg" alt=""> 
3842                  <p class="item-passo-title">Adicione à Mochila</p> 
3843                  <span>Faça login ou crie uma conta em nosso site e continue a compra.</span> 
3844              </div> 
3845 
3846              <img class="item-passo-icone-seta" src="/o/senac-theme/images/icon-seta-passo.svg" alt=""> 
3847 
3848              <div class="item-passo"> 
3849                  <img class="item-passo-icone" src="/o/senac-theme/images/icon-aguarde-contato.svg" alt=""> 
3850                  <p class="item-passo-title">Faça a matrícula</p> 
3851                  <span>Todas as etapas são on-line. Para garantir a vaga, preencha todas as informações.</span> 
3852              </div> 
3853 
3854          </div> 
3855 
3856 
3857      </div> 
3858 
3859    </section> 
3860 
3861  </#if> 
3862 
3863   
3864  <div class="ssp-section ssp-section-lg-bottom-slider d-none" id="section-cursos-voce-pode-gostar" style="background-color: #f2f2f2"> 
3865    <div class="container"> 
3866        <h2 class="ssp-section-title"> 
3867          <lfr-editable id="cursos-voce-pode-gostar-title" type="rich-text"> 
3868              Cursos que você pode gostar 
3869          </lfr-editable> 
3870        </h2> 
3871 
3872        <div id="slider-curso"> 
3873 
3874        </div> 
3875 
3876    </div> 
3877  </div> 
3878 
3879 
3880   
3881   
3882  <#-- Section para o item de curso--> 
3883  <div id="curso-item-template"  class="d-none slick-area__item"> 
3884   
3885    <div class="ssp-card-curso" style="height: 288px;"> 
3886   
3887      <a class="ssp-absolute-link ck-curso" href="#a"></a> 
3888   
3889      <div class="ssp-card-curso__image"> 
3890   
3891        <div class="ssp-image-container"> 
3892            <img src="" /> 
3893   
3894        </div> 
3895   
3896      </div> 
3897   
3898      <div class="ssp-card-curso__body"> 
3899   
3900        <div class="ssp-card-curso__color-tag-modalidade"></div> 
3901   
3902        <div class="ssp-card-curso__tags"> 
3903   
3904          <span class="ssp-card-curso__tag-formato-title"></span> 
3905           
3906          <span class="tag-modalidade-title__senac-online d-none">Senac Online - ao vivo</span> 
3907   
3908        </div> 
3909   
3910        <h6 class="ssp-card-curso__title"> 
3911   
3912        </h6> 
3913   
3914        <div class="ssp-card-curso__info"> 
3915   
3916          <span class="ssp-tag bg-white border-nivel-extensao text-nivel-extensao mr-1 btn-inscricoes-abertas">Inscrições abertas</span> 
3917          <span class="ssp-tag bg-white border-primary text-primary btn-bolsas">Bolsas</span> 
3918   
3919        </div> 
3920   
3921      </div> 
3922   
3923    </div> 
3924   
3925  </div> 
3926   
3927  <#function getJournalArticle> 
3928   
3929     
3930    <#assign journalArticleService = serviceLocator.findService("com.liferay.journal.service.JournalArticleLocalService") /> 
3931    <#assign friendlyURL = themeDisplay.getURLCurrent()?split("/")?last?split("?")?first> 
3932    <#assign groupId = themeDisplay.getSiteGroupId()> 
3933    <#attempt> 
3934   
3935      <#if !friendlyURL?contains("fragment_collections") > 
3936         
3937        <#return journalArticleService.getArticleByUrlTitle(groupId,friendlyURL)> 
3938      <#else> 
3939         
3940        <#return '#erro#'> 
3941      </#if> 
3942       
3943    <#recover> 
3944         
3945      <#return '#erro#'> 
3946    </#attempt> 
3947  </#function> 
3948   
3949  <#function getCategorias primaryKey> 
3950   
3951    <#assign categoryService = serviceLocator.findService("com.liferay.asset.kernel.service.AssetCategoryLocalService") /> 
3952    <#attempt> 
3953   
3954        <#return categoryService.getCategories("com.liferay.journal.model.JournalArticle", primaryKey)> 
3955   
3956    <#recover> 
3957       
3958      <#return '#erro#'> 
3959    </#attempt> 
3960  </#function> 
3961   
3962  <#function getVocabulary vocabularyId> 
3963   
3964    <#assign vocabularyService = serviceLocator.findService("com.liferay.asset.kernel.service.AssetVocabularyService") /> 
3965    <#attempt> 
3966   
3967        <#return vocabularyService.getVocabulary(vocabularyId)> 
3968   
3969    <#recover> 
3970       
3971      <#return '#erro#'> 
3972    </#attempt> 
3973  </#function> 
3974   
3975  <#function getStringValue dom name> 
3976    <#assign 
3977      seletorSTR = "dynamic-element[@field-reference='"+name+"']" 
3978      xPathSelector = saxReaderUtil.createXPath(seletorSTR) 
3979    /> 
3980    <#if xPathSelector.selectSingleNode(dom)?? > 
3981      <#assign 
3982        valueSTR = xPathSelector.selectSingleNode(dom).getStringValue()?trim 
3983      /> 
3984      <#return valueSTR> 
3985    </#if> 
3986    <#return ''> 
3987  </#function> 
3988   
3989      <!--Modal de Login --> 
3990           
3991      <section id="modal-login" class="ssp-modal-registro-interesse d-none"> 
3992   
3993          <div class="dropdown-menu-modal dropdown-menu-right" id="js-login-dropdown-menu-2" style="width: 340px; max-width: 340px; display: block;"> 
3994   
3995              <div class="px-5"> 
3996                  <i id="btn-close-loginModal" class="fas fa-times btn-close__modal-login"></i> 
3997                  <div class="text-darker-gray py-3">Faça login na sua conta</div> 
3998              </div> 
3999         
4000              <div class="dropdown-divider"></div> 
4001   
4002              <div class="dropdown-menu-arrow"></div> 
4003   
4004              <form id="login_form" class="px-5 py-4" method="post"> 
4005               
4006              <div class="alert alert-danger py-3 d-none" id="mensagem-erro-login" style="background:#f8d7da;border-color:#f5c6cb; color:#a94442"></div> 
4007         
4008                  <div class="form-group"> 
4009                       
4010                      <label for="login-email">E-mail</label> 
4011                      <div class="input-group mb-2"> 
4012                          <div class="input-group-prepend"> 
4013                              <span class="input-group-text"><i class="icon-envelope"></i></span> 
4014                          </div> 
4015                          <input type="text" class="form-control" id="login-email-modal" name="_com_liferay_login_web_portlet_LoginPortlet_login" placeholder="Digite seu e-mail" aria-label="Email" aria-describedby="login-email"> 
4016                      </div> 
4017   
4018                  </div> 
4019   
4020                  <div class="form-group"> 
4021   
4022                      <label for="login-password">Senha</label> 
4023                      <div class="input-group mb-2"> 
4024                          <div class="input-group-prepend"> 
4025                              <span class="input-group-text"><i class="icon-key"></i></span> 
4026                          </div> 
4027                          <input type="password" class="form-control" id="login-password-modal" name="_com_liferay_login_web_portlet_LoginPortlet_password" placeholder="Digite sua senha" aria-label="Password" aria-describedby="login-password"> 
4028                      </div> 
4029   
4030                  </div> 
4031                   
4032                  <div class="pt-1 pb-3"> 
4033                  <small><a href="http://www.sp.senac.br/login-unico/SendPassword" target="_blank">Esqueceu sua senha?</a></small> 
4034                  </div> 
4035                 
4036                  <button type="button" class="btn btn-primary w-100" id="btnLogin" data-login="btnLogin">Entrar</button> 
4037              </form> 
4038               
4039              <div class="dropdown-divider"></div> 
4040   
4041              <div class="px-5 pb-4"> 
4042                  <div class="text-darker-gray py-3">Não tem cadastro?</div> 
4043                  <a href="https://www.sp.senac.br/usuario-unico/InsertUser?destino=${themeDisplay.getPortalURL()+themeDisplay.getURLCurrent()}" target="_blank" class="btn bg-btn-cadastre btn-nivel-livre text-white w-100 ">Cadastre-se</a> 
4044              </div> 
4045   
4046               
4047          </div> 
4048   
4049      </section> 
4050   
4051    <!-- modal registro interesse --> 
4052   
4053 
4054      <section id="modal-registro-interesse" class="ssp-modal-registro-interesse d-none"> 
4055         
4056        <#if !isEMED> 
4057            <div class="ssp-card-registro-interesse"> 
4058       
4059              <i id="btn-close-Modal-registro-interesse" class="fas fa-times btn-close__modal-login"></i> 
4060 
4061              <p class="ssp-card-registro-interesse__label-curso-selecionado">Curso selecionado:</p> 
4062              <h3 class="ssp-card-registro-interesse__nome-curso"></h3> 
4063 
4064              <div id="unidades-registro-interesse"> 
4065 
4066                  <h4 class="ssp-card-registro-interesse__title-section-itens">Unidade:</h4> 
4067         
4068            <div id="select-unidades-registro-interesse"> 
4069                    <select class="ssp-card-registro-interesse__select unidades" id="select_0"><option value="" disabled="" selected="">Selecione uma unidade</option></select> 
4070                  </div> 
4071 
4072                  <div class="ssp-card-registro-interesse__add-mais"> 
4073                      <a class="" id="add-unidade-regsitro-interesse" href="#a"><i class="fas fa-plus mr-1"></i>Adicionar unidade</a> 
4074                       
4075                      &nbsp; 
4076                       
4077                      <a class="" id="remove-unidade-regsitro-interesse" href="#a"><i class="fas fa-times mr-1"></i>Remover unidade</a> 
4078                  </div> 
4079 
4080              </div> 
4081 
4082              <div id="dias-registro-interesse"> 
4083                  <h4 class="ssp-card-registro-interesse__title-section-itens text-center">Dias da Semana</h4> 
4084 
4085                  <div class="ssp-card-registro-interesse__week-content"> 
4086                      <span id="todosDias" class="ssp-week-day">Todos</span> 
4087                      <span class="ssp-week-day">Seg</span> 
4088                      <span class="ssp-week-day">Ter</span> 
4089                      <span class="ssp-week-day">Qua</span> 
4090                      <span class="ssp-week-day">Qui</span> 
4091                      <span class="ssp-week-day">Sex</span> 
4092                      <span class="ssp-week-day">Sab</span> 
4093                  </div> 
4094 
4095              </div> 
4096 
4097              <div id="periodo-registro-interesse"> 
4098 
4099                  <h4 class="ssp-card-registro-interesse__title-section-itens text-center">Período:</h4> 
4100 
4101                  <div class="ssp-card-registro-interesse__check-itens-content periodos-registro-interesse">  
4102 
4103                      <div class="ssp-card-registro-interesse__check-item" id="div-campo-todos"> 
4104                          <input type="checkbox" name="" value="" id="check-todos-periodos"> 
4105                          <label for="check-todos-periodos">Todos</label> 
4106                      </div> 
4107 
4108                      <div class="ssp-card-registro-interesse__check-item"> 
4109                          <input type="checkbox" name="" value="M" id="periodo-m"> 
4110                          <label for="periodo-m">Manhã</label> 
4111                      </div> 
4112 
4113                      <div class="ssp-card-registro-interesse__check-item"> 
4114                          <input type="checkbox" name="" value="T" id="periodo-t"> 
4115                          <label for="periodo-t">Tarde</label> 
4116                      </div> 
4117 
4118                      <div class="ssp-card-registro-interesse__check-item"> 
4119                          <input type="checkbox" name="" value="N" id="periodo-n"> 
4120                          <label for="periodo-n" "="">Noite</label> 
4121                      </div> 
4122 
4123 
4124                  </div> 
4125 
4126              </div> 
4127 
4128              <div class="ssp-card-registro-interesse__card-politica"> 
4129 
4130                  <p class="ssp-card-registro-interesse__card-politica-title"><strong>Política de Privacidade</strong></p> 
4131 
4132                  <p class="ssp-card-registro-interesse__card-politica-text">O Serviço Nacional de Aprendizagem Comercial - Senac, Administração Regional no Estado de São Paulo, inscrito no CNPJ sob nº 03.709.814/0001-98, com sede na Rua Dr. Vila Nova, 228, 7º andar, na cidade de São Paulo, Estado de São Paulo ("Senac São Paulo") atua de maneira transparente e responsável para garantir a proteção dos seus dados pessoais. Por isso, é muito importante para nós que você conheça nossa Política de Privacidade. </p> 
4133 
4134 
4135                  <p class="ssp-card-registro-interesse__card-politica-text"> 
4136                  <b>1. O que é a Política de Privacidade do Senac São Paulo? </b><br> 
4137 
4138                  É o documento que apresenta informações sobre a maneira como coletamos, utilizamos e compartilhamos seus dados pessoais, bem como descreve o conjunto de regras e procedimentos adotados pelo Senac São Paulo para garantir a proteção desses dados. Os seus dados pessoais são coletados quando você se cadastra em nosso site (www.sp.senac.br) para registrar interesse em cursos, participar de eventos, fazer sua matrícula ou se inscrever em bolsas de estudo.  
4139                   
4140                  Nossa Política de Privacidade é pautada pela Lei Geral de Proteção de Dados Pessoais (LGPD), nº 13.709/2018. Comprometemo-nos a cumprir estritamente seus termos assim que ela entrar em vigor. Caso queria saber mais sobre a LGPD, confira.  
4141                  <br><br> 
4142                  <b>2. Como o Senac coleta meus dados pessoais?</b><br> 
4143                   
4144                  Por meio de cadastro em nosso site ou em nossas unidades. Para realizá-lo, você notará que algumas informações são obrigatórias, pois atendem padrões estabelecidos por órgãos da administração pública, como o Ministério da Educação. Além desses dados, as outras informações solicitadas nos ajudam a entender melhor seus interesses e personalizar, ainda mais, seu atendimento.  
4145                  <br><br> 
4146                  <b>3. É possível acessar este site sem fornecer meus dados pessoais?</b><br> 
4147                   
4148                  Sim. Neste caso, podemos coletar dados técnicos da sua navegação como endereço de Protocolo de Internet (endereço IP), registro de acesso, geolocalização do endereço IP, tipo do navegador utilizado, versão do sistema operacional, modelo e características do aparelho utilizado para o acesso, banda de internet, operadora, comportamento de pageview e páginas visitadas, de acordo com cookies liberados ou não por você. (<a href="https://www.sp.senac.br/politica-de-cookies">Conhecer nossa Política de Cookies.</a>) 
4149                  <br><br> 
4150                  <b>4. No caso de acesso com cadastro, quais informações o Senac poderá solicitar? </b><br> 
4151                   
4152                  Nossa coleta de dados pessoais varia de acordo com o tipo de interação que você terá em nosso site, quais produtos ou serviços está procurando.  
4153                   
4154                  Para você saber, relacionamos a seguir os dados  pessoais que podem ser solicitados por nós:  <br> 
4155                   
4156                      - Dados sobre identificação: nome civil, nome social, filiação, nacionalidade, naturalidade, data de nascimento, sexo, estado civil, número e cópia do documento de identificação (CPF, RG/RNE ou outro)<br> 
4157                      - Dados sobre contato: endereço postal, endereço de e-mail, número de telefone<br> 
4158                      - Dados acadêmicos: estabelecimentos de ensino anteriores, certificados e diplomas acadêmicos, histórico escolar, nota do ENEM<br> 
4159                      - Dados profissionais: emprego atual, profissão<br> 
4160                      - Dados de pagamento: nome do titular da conta e número do cartão de crédito<br> 
4161                      - Dados de responsáveis: nome, telefone e número de documento de identidade do responsável legal (em casos de estudante menor de idade) e/ou financeiro <br> 
4162                      - Dados de saúde: informação sobre deficiência física e atestados médicos<br> 
4163                      - Dados de imagem: foto<br> 
4164                      - Dados de renda familiar: situação de emprego e salário de membros da mesma família<br> 
4165                      - Dados técnicos da sua navegação: endereço de Protocolo de Internet (endereço IP), registro de acesso, geolocalização do endereço IP, tipo do navegador utilizado, versão do sistema operacional, modelo e características do aparelho utilizado para o acesso, banda de internet, operadora, comportamento de pageview e páginas visitadas, de acordo com cookies liberados ou não por você. (<a href="https://www.sp.senac.br/politica-de-cookies">Conhecer nossa Política de Cookies</a>)<br> 
4166                   
4167                  <br><br> 
4168                  <b>5. Quantos e quais tipos de cadastros podem ser realizados?</b><br> 
4169                   
4170                  São três tipos de cadastro realizado. Como já comentamos (pergunta 4), eles variam de acordo com a sua experiência e o seu objetivo em nosso site. Por exemplo, se seu objetivo agora é apenas registrar interesse em algum curso livre, você terá que preencher seus dados de identificação e contato, caso queira fazer sua matrícula, deverá preencher também informações sobre pagamento, mas, se optar por se inscrever para bolsa de estudo, terá que fornecer outros documentos específicos, como comprovantes de renda. Confira:<br> 
4171                   
4172                      - Cadastro simples: poderemos coletar dados de identificação e de contato.<br> 
4173                      - Cadastro e inscrição em cursos e outros eventos:  quando você se inscreve em nossos cursos, eventos e até mesmo para participar do nosso vestibular e efetivar a sua matrícula em cursos livres, técnicos, de formação continuada ou superior, por exemplo, poderemos coletar dados dos responsáveis, de identificação, de contato, dados acadêmicos, profissionais, de saúde, de pagamento e de imagem.<br> 
4174                      Importante: também poderemos solicitar o envio de cópia de documentos, de acordo com o curso escolhido por você.<br> 
4175                      - Cadastro e inscrição para bolsas de estudos: poderemos coletar dados de identificação, contato e renda familiar.<br> 
4176                      Importante: também poderemos solicitar o envio de cópia de documentos para comprovar as informações fornecidas.<br> 
4177                   
4178                  <br><br> 
4179                  <b>6. Para quais finalidades meus dados podem ser utilizados?</b><br> 
4180                   
4181                      - Em procedimentos internos relacionados aos nossos serviços e produtos para que você tenha uma experiência positiva durante sua jornada no Senac. Afinal, você precisa ter informações sobre nossos serviços, ter acesso a nossa infraestrutura, ou, por exemplo, poder emprestar livros nas nossas bibliotecas,  realizar pagamentos, enviar reclamações, sugestões, pedidos, entre outros. <br> 
4182                      - Para cumprir obrigações legais a que estamos sujeitos, por exemplo: o pagamento de impostos, fazer o gerenciamento de matrícula, providenciar o reconhecimento de equivalências e de documentos que conferem graus e títulos acadêmicos, emitir certificados e diplomas, realizar o controle de assiduidade e registro de informações acadêmicas.<br> 
4183                      - Para permitir a realização de auditoria de órgãos da administração pública<br> 
4184                      - Em investigações sobre possíveis violações de leis ou de nossas políticas internas<br> 
4185                      - Para estabelecer rede de conexões entre ex-estudantes<br> 
4186                      - Para melhorar sua experiência com o Senac São Paulo, como, por exemplo, disponibilizar intérpretes, fornecer melhores ferramentas ou aprimorar nossos ambientes<br> 
4187                      - Para defender direitos em conflitos judiciais ou extrajudiciais e para proteger nossos direitos e de terceiros e, ainda, para outras finalidades que exijam o seu consentimento, que será solicitado nos termos da legislação vigente. <br> 
4188                   
4189                   
4190                  <b>Importante:</b> usaremos seus dados pessoais somente para atender aos objetivos descritos nesta Política. Se necessário, seus dados poderão ser usados para outras finalidades não conflitantes às finalidades apresentadas nesta Política.  
4191                  <br><br> 
4192                  <b>7. Com quem o Senac pode compartilhar meus dados?</b><br> 
4193                   
4194                      - Com órgãos da administração pública (Ministério da Educação, Secretaria Estadual da Educação, Tribunal de Contas da União, Controladoria Geral da União e demais órgãos relacionados a esses) para cumprimento de obrigações legais e regulatórias.<br> 
4195                      - Com instituições do setor bancário e seguradoras, para gestão e processamento de pagamentos.<br> 
4196                      - Com empresas que tenhamos contratos, parceria e/ou acordos de cooperação, por exemplo, gráficas, para a emissão de cartões e provas.<br> 
4197                      - Com instituições de ensino para validar a autenticidade de documentos.<br> 
4198                      Importante: informaremos você quando houver o compartilhamento de dados para outras finalidades que possam ser incompatíveis com o descrito nesta Política, sempre que exigido pela legislação. 
4199                   
4200                  <br><br> 
4201                  <b>8. Por quanto tempo meus dados serão armazenados?</b> <br> 
4202                   
4203                  Pelo período necessário para que você tenha uma experiência positiva dentro da instituição, atendendo seus interesses e solicitações.  
4204                   
4205                  <b>Importante:</b> poderemos preservar os seus dados por um período superior sempre que exista uma obrigação legal, por exemplo, em relação aos dados utilizados na gestão acadêmica, ou se existirem razões de interesse público (arquivo, investigação científica e histórica, ou para censos educacionais). Nessas ocasiões, sempre que possível, seus dados serão tratados de forma que seja possível manter o seu anonimato.  
4206                  <br><br> 
4207                  <b>9. Quais são as medidas de segurança utilizadas para garantir a proteção dos meus dados pessoais?</b><br> 
4208                   
4209                  Atuamos de maneira transparente e responsável, por meio de padrões de segurança e prevenção confiáveis. Adotamos medidas administrativas, técnicas e físicas para proteger dados pessoais contra perda, roubo, uso indevido, bem como, contra acesso não autorizado, divulgação, alteração e destruição de informações.  
4210                   
4211                  Confira nossas medidas de segurança da informação que buscam garantir a confidencialidade, a integridade e a disponibilidade dos dados coletados: <br> 
4212                   
4213                      - Controlar o acesso a informações, considerando a necessidade de nossos funcionários obterem determinado dado<br> 
4214                      - Proteger infraestruturas tecnológicas contra acessos não autorizados<br> 
4215                      - Monitorar constantemente toda nossa infraestrutura tecnológica <br> 
4216                      - Política de troca de senhas<br> 
4217                      - Política de confidencialidade com funcionários e terceiros<br> 
4218                   
4219                  <br><br> 
4220                  <b>10. É possível que meus dados sejam transferidos para fora do país?</b><br> 
4221                   
4222                  Sim, pois temos parcerias em nível global. Portanto, dados pessoais talvez precisem ser transferidos para outros países, seja em razão dessas parcerias (por exemplo, em caso de intercâmbio de estudantes) ou pela necessidade de armazenamento de dados em servidores estrangeiros, por meio da utilização de servidores em nuvem (cloud). 
4223                   
4224                  Caso seus dados pessoais sejam transferidos para fora do Brasil, adotaremos todos os cuidados para assegurar que essa transferência obedeça às normas e preserve o sigilo de todas as informações coletadas.  
4225                  <br><br> 
4226                  <b>11. Quais são os meus direitos em relação aos dados pessoais fornecidos?</b><br> 
4227                   
4228                  Agora que você já sabe como coletamos, utilizamos e compartilhamos seus dados, é igualmente importante para nós que você conheça quais são os direitos que possui quando nos fornece seus dados pessoais. Caso queira, você poderá: 
4229                   
4230                      - Corrigir seus dados pessoais que estejam incompletos, inexatos ou desatualizados<br> 
4231                      Caso você identifique algum erro em relação aos dados fornecidos, basta solicitar a alteração para nossa equipe. Isso é importante para que as informações sejam utilizadas da maneira correta e seu cadastro fique sempre atualizado. <br> 
4232                      - Cancelar ou revogar o seu consentimento de utilização de dados <br> 
4233                      Você poderá cancelar, a qualquer momento, o consentimento em relação ao uso, pelo Senac São Paulo, dos seus dados pessoais. <br> 
4234                   
4235                   
4236                  <b>Importante:</b> deixaremos de usar seus dados pessoais quando a revogação do seu consentimento for concluída. Sendo assim, qualquer utilização de seus dados pessoais antes da efetivação do cancelamento/revogação é entendido por nós como legal, verdadeiro e autorizado por você.  
4237                   
4238                  Caso queira fazer algum pedido referente a este campo, você deve entrar em contato via e-mail pelo privacidade@sp.senac.br. Poderemos solicitar informações para confirmar sua identidade e seu direito de acesso aos dados solicitados. 
4239                   
4240                  Tenha certeza, trabalharemos sempre de maneira ágil e responsável para atender suas solicitações o mais breve possível, sendo que observaremos os prazos legais quando da vigência da LGPD.  
4241                  <br><br> 
4242                  <b>12. E se essa Política for atualizada?</b><br> 
4243                   
4244                  Caso existam alterações significativas, iremos avisar você o mais breve possível, ou, antes que a nova política entre em vigor. Por isso, recomendamos que consulte este documento sempre que possível e verifique a data da sua última atualização, informada no rodapé desta página.  
4245                  <br><br> 
4246                  <b>13. Como posso tirar minhas dúvidas sobre esta Política?</b><br> 
4247                   
4248                  Fique à vontade para nos enviar qualquer tipo de dúvida sobre esta Política, em privacidade@sp.senac.br. Será um prazer falar com você! 
4249                   
4250                  <br><br> 
4251                   
4252                  <b>Encarregado de Dados do Senac (DPO):</b> 
4253                   
4254                  <br><br> 
4255                  <b>Fernando Sátiro Pereira </b>| Gerente de Tecnologia da Informação do Senac São Paulo 
4256                   
4257                  <br> 
4258                  <b>Contato: privacidade@sp.senac.br</b> 
4259              </p> 
4260                   
4261 
4262              </div> 
4263 
4264              <div class="ssp-card-registro-interesse__check-item"> 
4265                  <input type="checkbox" name="" value="" id="check-politica-privacidade"> 
4266                  <label for="check-politica-privacidade">Aceito a Política de Privacidade</label> 
4267              </div> 
4268 
4269              <div class="text-center mt-5"> 
4270 
4271                  <button class="btn btn-nivel ssp-card-registro-interesse__btn-enviar btn-with-loading" href="#a" id="enviar-registro-interesse-btn" disabled="disabled">Enviar</button> 
4272 
4273                  <p class="ssp-card-registro-interesse__aviso"><strong>Importante:</strong> O registro de interesse não garante a vaga.</p> 
4274 
4275              </div> 
4276 
4277          </div>     
4278   
4279        <#else> 
4280 
4281            <div class="ssp-card-registro-interesse emed"> 
4282 
4283              <i id="btn-close-Modal-registro-interesse" class="fas fa-times btn-close__modal-login"></i> 
4284 
4285              <p class="ssp-card-registro-interesse__label-curso-selecionado">Curso selecionado:</p> 
4286 
4287              <div class="emed-select-group"> 
4288 
4289                  <h3 class="ssp-card-registro-interesse__title-modal"></h3> 
4290                   
4291                  <div id="unidades-registro-interesse"> 
4292       
4293                      <h4 class="ssp-card-registro-interesse__title-section-itens">Escolha uma unidade</h4> 
4294             
4295                      <div id="select-unidades-registro-interesse"> 
4296                        <select class="ssp-card-registro-interesse__select unidades" id="select_0"><option value="" disabled="" selected="">Selecione uma unidade</option></select> 
4297                      </div> 
4298       
4299                      <div class="ssp-card-registro-interesse__add-mais"> 
4300                          <a class="" id="add-unidade-regsitro-interesse" href="#a"><i class="fas fa-plus mr-1"></i>Adicionar unidade</a> 
4301                           
4302                          &nbsp; 
4303                           
4304                          <a class="" id="remove-unidade-regsitro-interesse" href="#a"><i class="fas fa-times mr-1"></i>Remover unidade</a> 
4305                      </div> 
4306       
4307                  </div> 
4308 
4309              </div> 
4310 
4311               
4312              <div id="periodo-registro-interesse"> 
4313 
4314                  <p class="ssp-card-registro-interesse__title-section-itens">Período:</p> 
4315 
4316                  <div class="ssp-card-registro-interesse__check-itens-content periodos-registro-interesse">                   
4317                      <div class="ssp-card-registro-interesse__check-item"> 
4318                          <input type="checkbox" name="" value="M" id="periodo-m"> 
4319                          <label for="periodo-m">Manhã</label> 
4320                      </div> 
4321                       
4322                      <div class="ssp-card-registro-interesse__check-item"> 
4323                          <input type="checkbox" name="" value="T" id="periodo-t"> 
4324                          <label for="periodo-t">Tarde</label> 
4325                      </div> 
4326                       
4327                      <div class="ssp-card-registro-interesse__check-item" id="div-campo-todos"> 
4328                          <input type="checkbox" name="" value="" id="check-todos-periodos"> 
4329                          <label for="check-todos-periodos">Todos</label> 
4330                      </div> 
4331 
4332                  </div> 
4333 
4334              </div> 
4335 
4336              <div id="turmas-registro-interesse"> 
4337 
4338                  <p class="ssp-card-registro-interesse__title-section-itens">Turma:</p> 
4339 
4340                  <div class="ssp-card-registro-interesse__check-itens-content turmas-registro-interesse">  
4341 
4342                      <div class="ssp-card-registro-interesse__check-item"> 
4343                          <input type="checkbox" name="" value="1" id="primeiro"> 
4344                          <label for="primeiro">1º ano</label> 
4345                      </div> 
4346 
4347                      <div class="ssp-card-registro-interesse__check-item"> 
4348                          <input type="checkbox" name="" value="2" id="segundo"> 
4349                          <label for="segundo">2º ano</label> 
4350                      </div> 
4351 
4352                      <div class="ssp-card-registro-interesse__check-item"> 
4353                          <input type="checkbox" name="" value="3" id="terceiro"> 
4354                          <label for="terceiro">3º ano</label> 
4355                      </div> 
4356 
4357                  </div> 
4358 
4359              </div> 
4360 
4361              <div id="msg-transferencia-emed"> 
4362 
4363                  <div class="transferencia-emed-title"> 
4364                      <i class="fas fa-comment-exclamation"></i> 
4365                      <p>Quer se transferir de escola?</p> 
4366                  </div> 
4367 
4368                  <div class="transferencia-emed-link"> 
4369                      <a href="#">Fale direto com a unidade de interesse.</a> 
4370                  </div> 
4371 
4372              </div> 
4373 
4374              <div class="ssp-card-registro-interesse__card-politica"> 
4375 
4376                  <p class="ssp-card-registro-interesse__card-politica-title"><strong>Política de Privacidade</strong></p> 
4377 
4378                  <p class="ssp-card-registro-interesse__card-politica-text">O Serviço Nacional de Aprendizagem Comercial - Senac, Administração Regional no Estado de São Paulo, inscrito no CNPJ sob nº 03.709.814/0001-98, com sede na Rua Dr. Vila Nova, 228, 7º andar, na cidade de São Paulo, Estado de São Paulo ("Senac São Paulo") atua de maneira transparente e responsável para garantir a proteção dos seus dados pessoais. Por isso, é muito importante para nós que você conheça nossa Política de Privacidade. </p> 
4379 
4380                  <p class="ssp-card-registro-interesse__card-politica-text"> 
4381 
4382                      <b>1. O que é a Política de Privacidade do Senac São Paulo? </b><br> 
4383 
4384                      É o documento que apresenta informações sobre a maneira como coletamos, utilizamos e compartilhamos seus dados pessoais, bem como descreve o conjunto de regras e procedimentos adotados pelo Senac São Paulo para garantir a proteção desses dados. Os seus dados pessoais são coletados quando você se cadastra em nosso site (www.sp.senac.br) para registrar interesse em cursos, participar de eventos, fazer sua matrícula ou se inscrever em bolsas de estudo.  
4385 
4386                      Nossa Política de Privacidade é pautada pela Lei Geral de Proteção de Dados Pessoais (LGPD), nº 13.709/2018. Comprometemo-nos a cumprir estritamente seus termos assim que ela entrar em vigor. Caso queria saber mais sobre a LGPD, confira.  
4387                      <br><br> 
4388                      <b>2. Como o Senac coleta meus dados pessoais?</b><br> 
4389                       
4390                      Por meio de cadastro em nosso site ou em nossas unidades. Para realizá-lo, você notará que algumas informações são obrigatórias, pois atendem padrões estabelecidos por órgãos da administração pública, como o Ministério da Educação. Além desses dados, as outras informações solicitadas nos ajudam a entender melhor seus interesses e personalizar, ainda mais, seu atendimento.  
4391                      <br><br> 
4392                      <b>3. É possível acessar este site sem fornecer meus dados pessoais?</b><br> 
4393                       
4394                      Sim. Neste caso, podemos coletar dados técnicos da sua navegação como endereço de Protocolo de Internet (endereço IP), registro de acesso, geolocalização do endereço IP, tipo do navegador utilizado, versão do sistema operacional, modelo e características do aparelho utilizado para o acesso, banda de internet, operadora, comportamento de pageview e páginas visitadas, de acordo com cookies liberados ou não por você. (<a href="https://www.sp.senac.br/politica-de-cookies">Conhecer nossa Política de Cookies.</a>) 
4395                      <br><br> 
4396                      <b>4. No caso de acesso com cadastro, quais informações o Senac poderá solicitar? </b><br> 
4397                       
4398                      Nossa coleta de dados pessoais varia de acordo com o tipo de interação que você terá em nosso site, quais produtos ou serviços está procurando.  
4399                       
4400                      Para você saber, relacionamos a seguir os dados  pessoais que podem ser solicitados por nós:  <br> 
4401                       
4402                          - Dados sobre identificação: nome civil, nome social, filiação, nacionalidade, naturalidade, data de nascimento, sexo, estado civil, número e cópia do documento de identificação (CPF, RG/RNE ou outro)<br> 
4403                          - Dados sobre contato: endereço postal, endereço de e-mail, número de telefone<br> 
4404                          - Dados acadêmicos: estabelecimentos de ensino anteriores, certificados e diplomas acadêmicos, histórico escolar, nota do ENEM<br> 
4405                          - Dados profissionais: emprego atual, profissão<br> 
4406                          - Dados de pagamento: nome do titular da conta e número do cartão de crédito<br> 
4407                          - Dados de responsáveis: nome, telefone e número de documento de identidade do responsável legal (em casos de estudante menor de idade) e/ou financeiro <br> 
4408                          - Dados de saúde: informação sobre deficiência física e atestados médicos<br> 
4409                          - Dados de imagem: foto<br> 
4410                          - Dados de renda familiar: situação de emprego e salário de membros da mesma família<br> 
4411                          - Dados técnicos da sua navegação: endereço de Protocolo de Internet (endereço IP), registro de acesso, geolocalização do endereço IP, tipo do navegador utilizado, versão do sistema operacional, modelo e características do aparelho utilizado para o acesso, banda de internet, operadora, comportamento de pageview e páginas visitadas, de acordo com cookies liberados ou não por você. (<a href="https://www.sp.senac.br/politica-de-cookies">Conhecer nossa Política de Cookies</a>)<br> 
4412                       
4413                      <br><br> 
4414                      <b>5. Quantos e quais tipos de cadastros podem ser realizados?</b><br> 
4415                       
4416                      São três tipos de cadastro realizado. Como já comentamos (pergunta 4), eles variam de acordo com a sua experiência e o seu objetivo em nosso site. Por exemplo, se seu objetivo agora é apenas registrar interesse em algum curso livre, você terá que preencher seus dados de identificação e contato, caso queira fazer sua matrícula, deverá preencher também informações sobre pagamento, mas, se optar por se inscrever para bolsa de estudo, terá que fornecer outros documentos específicos, como comprovantes de renda. Confira:<br> 
4417                       
4418                          - Cadastro simples: poderemos coletar dados de identificação e de contato.<br> 
4419                          - Cadastro e inscrição em cursos e outros eventos:  quando você se inscreve em nossos cursos, eventos e até mesmo para participar do nosso vestibular e efetivar a sua matrícula em cursos livres, técnicos, de formação continuada ou superior, por exemplo, poderemos coletar dados dos responsáveis, de identificação, de contato, dados acadêmicos, profissionais, de saúde, de pagamento e de imagem.<br> 
4420                          Importante: também poderemos solicitar o envio de cópia de documentos, de acordo com o curso escolhido por você.<br> 
4421                          - Cadastro e inscrição para bolsas de estudos: poderemos coletar dados de identificação, contato e renda familiar.<br> 
4422                          Importante: também poderemos solicitar o envio de cópia de documentos para comprovar as informações fornecidas.<br> 
4423                       
4424                      <br><br> 
4425                      <b>6. Para quais finalidades meus dados podem ser utilizados?</b><br> 
4426                       
4427                          - Em procedimentos internos relacionados aos nossos serviços e produtos para que você tenha uma experiência positiva durante sua jornada no Senac. Afinal, você precisa ter informações sobre nossos serviços, ter acesso a nossa infraestrutura, ou, por exemplo, poder emprestar livros nas nossas bibliotecas,  realizar pagamentos, enviar reclamações, sugestões, pedidos, entre outros. <br> 
4428                          - Para cumprir obrigações legais a que estamos sujeitos, por exemplo: o pagamento de impostos, fazer o gerenciamento de matrícula, providenciar o reconhecimento de equivalências e de documentos que conferem graus e títulos acadêmicos, emitir certificados e diplomas, realizar o controle de assiduidade e registro de informações acadêmicas.<br> 
4429                          - Para permitir a realização de auditoria de órgãos da administração pública<br> 
4430                          - Em investigações sobre possíveis violações de leis ou de nossas políticas internas<br> 
4431                          - Para estabelecer rede de conexões entre ex-estudantes<br> 
4432                          - Para melhorar sua experiência com o Senac São Paulo, como, por exemplo, disponibilizar intérpretes, fornecer melhores ferramentas ou aprimorar nossos ambientes<br> 
4433                          - Para defender direitos em conflitos judiciais ou extrajudiciais e para proteger nossos direitos e de terceiros e, ainda, para outras finalidades que exijam o seu consentimento, que será solicitado nos termos da legislação vigente. <br> 
4434                       
4435                       
4436                      <b>Importante:</b> usaremos seus dados pessoais somente para atender aos objetivos descritos nesta Política. Se necessário, seus dados poderão ser usados para outras finalidades não conflitantes às finalidades apresentadas nesta Política.  
4437                      <br><br> 
4438                      <b>7. Com quem o Senac pode compartilhar meus dados?</b><br> 
4439                       
4440                          - Com órgãos da administração pública (Ministério da Educação, Secretaria Estadual da Educação, Tribunal de Contas da União, Controladoria Geral da União e demais órgãos relacionados a esses) para cumprimento de obrigações legais e regulatórias.<br> 
4441                          - Com instituições do setor bancário e seguradoras, para gestão e processamento de pagamentos.<br> 
4442                          - Com empresas que tenhamos contratos, parceria e/ou acordos de cooperação, por exemplo, gráficas, para a emissão de cartões e provas.<br> 
4443                          - Com instituições de ensino para validar a autenticidade de documentos.<br> 
4444                          Importante: informaremos você quando houver o compartilhamento de dados para outras finalidades que possam ser incompatíveis com o descrito nesta Política, sempre que exigido pela legislação. 
4445                       
4446                      <br><br> 
4447                      <b>8. Por quanto tempo meus dados serão armazenados?</b> <br> 
4448                       
4449                      Pelo período necessário para que você tenha uma experiência positiva dentro da instituição, atendendo seus interesses e solicitações.  
4450                       
4451                      <b>Importante:</b> poderemos preservar os seus dados por um período superior sempre que exista uma obrigação legal, por exemplo, em relação aos dados utilizados na gestão acadêmica, ou se existirem razões de interesse público (arquivo, investigação científica e histórica, ou para censos educacionais). Nessas ocasiões, sempre que possível, seus dados serão tratados de forma que seja possível manter o seu anonimato.  
4452                      <br><br> 
4453                      <b>9. Quais são as medidas de segurança utilizadas para garantir a proteção dos meus dados pessoais?</b><br> 
4454                       
4455                      Atuamos de maneira transparente e responsável, por meio de padrões de segurança e prevenção confiáveis. Adotamos medidas administrativas, técnicas e físicas para proteger dados pessoais contra perda, roubo, uso indevido, bem como, contra acesso não autorizado, divulgação, alteração e destruição de informações.  
4456                       
4457                      Confira nossas medidas de segurança da informação que buscam garantir a confidencialidade, a integridade e a disponibilidade dos dados coletados: <br> 
4458                       
4459                          - Controlar o acesso a informações, considerando a necessidade de nossos funcionários obterem determinado dado<br> 
4460                          - Proteger infraestruturas tecnológicas contra acessos não autorizados<br> 
4461                          - Monitorar constantemente toda nossa infraestrutura tecnológica <br> 
4462                          - Política de troca de senhas<br> 
4463                          - Política de confidencialidade com funcionários e terceiros<br> 
4464                       
4465                      <br><br> 
4466                      <b>10. É possível que meus dados sejam transferidos para fora do país?</b><br> 
4467                       
4468                      Sim, pois temos parcerias em nível global. Portanto, dados pessoais talvez precisem ser transferidos para outros países, seja em razão dessas parcerias (por exemplo, em caso de intercâmbio de estudantes) ou pela necessidade de armazenamento de dados em servidores estrangeiros, por meio da utilização de servidores em nuvem (cloud). 
4469                       
4470                      Caso seus dados pessoais sejam transferidos para fora do Brasil, adotaremos todos os cuidados para assegurar que essa transferência obedeça às normas e preserve o sigilo de todas as informações coletadas.  
4471                      <br><br> 
4472                      <b>11. Quais são os meus direitos em relação aos dados pessoais fornecidos?</b><br> 
4473                       
4474                      Agora que você já sabe como coletamos, utilizamos e compartilhamos seus dados, é igualmente importante para nós que você conheça quais são os direitos que possui quando nos fornece seus dados pessoais. Caso queira, você poderá: 
4475                       
4476                          - Corrigir seus dados pessoais que estejam incompletos, inexatos ou desatualizados<br> 
4477                          Caso você identifique algum erro em relação aos dados fornecidos, basta solicitar a alteração para nossa equipe. Isso é importante para que as informações sejam utilizadas da maneira correta e seu cadastro fique sempre atualizado. <br> 
4478                          - Cancelar ou revogar o seu consentimento de utilização de dados <br> 
4479                          Você poderá cancelar, a qualquer momento, o consentimento em relação ao uso, pelo Senac São Paulo, dos seus dados pessoais. <br> 
4480                       
4481                       
4482                      <b>Importante:</b> deixaremos de usar seus dados pessoais quando a revogação do seu consentimento for concluída. Sendo assim, qualquer utilização de seus dados pessoais antes da efetivação do cancelamento/revogação é entendido por nós como legal, verdadeiro e autorizado por você.  
4483                       
4484                      Caso queira fazer algum pedido referente a este campo, você deve entrar em contato via e-mail pelo privacidade@sp.senac.br. Poderemos solicitar informações para confirmar sua identidade e seu direito de acesso aos dados solicitados. 
4485                       
4486                      Tenha certeza, trabalharemos sempre de maneira ágil e responsável para atender suas solicitações o mais breve possível, sendo que observaremos os prazos legais quando da vigência da LGPD.  
4487                      <br><br> 
4488                      <b>12. E se essa Política for atualizada?</b><br> 
4489                       
4490                      Caso existam alterações significativas, iremos avisar você o mais breve possível, ou, antes que a nova política entre em vigor. Por isso, recomendamos que consulte este documento sempre que possível e verifique a data da sua última atualização, informada no rodapé desta página.  
4491                      <br><br> 
4492                      <b>13. Como posso tirar minhas dúvidas sobre esta Política?</b><br> 
4493                       
4494                      Fique à vontade para nos enviar qualquer tipo de dúvida sobre esta Política, em privacidade@sp.senac.br. Será um prazer falar com você! 
4495                       
4496                      <br><br> 
4497                       
4498                      <b>Encarregado de Dados do Senac (DPO):</b> 
4499                       
4500                      <br><br> 
4501                      <b>Fernando Sátiro Pereira </b>| Gerente de Tecnologia da Informação do Senac São Paulo 
4502                       
4503                      <br> 
4504                      <b>Contato: privacidade@sp.senac.br</b> 
4505 
4506                  </p> 
4507 
4508              </div> 
4509 
4510              <div class="ssp-card-registro-interesse__check-item"> 
4511                  <input type="checkbox" name="" value="" id="check-politica-privacidade"> 
4512                  <label for="check-politica-privacidade">Aceito a Política de Privacidade</label> 
4513              </div> 
4514 
4515              <div class="text-center mt-5"> 
4516 
4517                  <button class="btn btn-nivel ssp-card-registro-interesse__btn-enviar btn-with-loading" href="#a" id="enviar-registro-interesse-btn" disabled="disabled">Enviar</button> 
4518 
4519                  <p class="ssp-card-registro-interesse__aviso"><strong>Importante:</strong> O registro de interesse não garante a vaga.</p> 
4520 
4521              </div> 
4522 
4523            </div>    
4524 
4525        </#if> 
4526      </section> 
4527 
4528      <section id="modal-registro-interesse-sucesso" class="ssp-modal-registro-interesse d-none"> 
4529   
4530          <div class="ssp-card-msg-sucesso"> 
4531   
4532              <div class="ssp-card-msg-sucesso__content"> 
4533                  <i class="fas fa-exclamation-circle"></i> 
4534                  <p>Obrigado por registrar seu interesse!</p> 
4535                  <p>Acompanhe seu e-mail para ficar por dentro das novidades!</p> 
4536              </div> 
4537   
4538              <div> 
4539                  <a class="btn btn-nivel ssp-card-msg-sucesso__btn" href="#" id="btn-voltar-home">Voltar para a home</a> 
4540              </div> 
4541   
4542          </div> 
4543   
4544      </section> 
4545   
4546    <section id="modal-registro-interesse-erro" class="ssp-modal-registro-interesse d-none"> 
4547   
4548          <div class="ssp-card-msg-erro"> 
4549   
4550              <div class="ssp-card-msg-sucesso__content"> 
4551                  <i class="fas fa-exclamation-circle" style="color: #ec3a3a;"></i> 
4552                  <p>Houve um erro ao registrar seu interesse!</p> 
4553                  <p>Por favor, tente novamente!</p> 
4554              </div> 
4555   
4556              <div> 
4557                  <a class="btn btn-nivel ssp-card-msg-sucesso__btn" href="#">Voltar para a home</a> 
4558              </div> 
4559   
4560          </div> 
4561   
4562      </section> 
4563       
4564      <!-- Aviso para curso de aprendizagem --> 
4565   
4566    <div id="aviso-curso-aprendizagem" class="ssp-bolsa-formulario__card-aviso-atencao d-none" style="width: 100%;"> 
4567                     
4568        <i class="fas fa-exclamation-circle ssp-bolsa-formulario__card-aviso-atencao-icon" aria-hidden="true"></i> 
4569     
4570        <div class="ssp-bolsa-formulario__card-aviso-texto"> 
4571          <p>O programa é gratuito para empresas contribuintes do Senac.</p>  
4572          <p>Para contratar aprendiz, preencha o formulário e entraremos em contato.</p> 
4573        </div> 
4574     
4575     </div> 
4576 
4577     <!-- modal form de aprendizagem --> 
4578 
4579    <#if isAprendizagem> 
4580     
4581      <#assign formId = 48097883 /> 
4582      <!-- formInstanceId é variável de acordo com o ID do formulário --> 
4583      <#assign formPreferences = {"displayDepth": "1", "portletSetupPortletDecoratorId": "barebone", "formInstanceId": "formId"}/> 
4584 
4585      <section data-lfr-background-image-id="bg-programe-form" class="ssp-section ssp-section-lg-bottom" data-modal="modal"> 
4586     
4587        <div class="container ssp_ct_form_programe"> 
4588 
4589          <button type="button" data-modal="close-form-modal"> 
4590            fechar 
4591            <i class="fas fa-times"></i> 
4592          </button> 
4593         
4594          <@liferay_portlet["runtime"] 
4595            portletName="com_liferay_dynamic_data_mapping_form_web_portlet_DDMFormPortlet" 
4596            defaultPreferences=freeMarkerPortletPreferences.getPreferences(formPreferences) 
4597          />   
4598               
4599        </div>    
4600 
4601      </section> 
4602 
4603    </#if> 
4604   
4605    <div id="avisoTrampolim" class="ssp-bolsa-formulario__card-aviso-atencao container text-left d-none" style="width: 100%;">                   
4606         <i class="fas fa-exclamation-circle ssp-bolsa-formulario__card-aviso-atencao-icon" aria-hidden="true"></i>   
4607         <div class="ssp-bolsa-formulario__card-aviso-texto"><p>Para informações sobre preço do curso e matrícula, entre em contato a unidade.</p> 
4608         </div> 
4609 
4610       </div> 
4611          
4612         
4613         <!--modal forma pagto extensao-->   
4614        <section id="modalFormaPagtoExt" class="modal-extensao ssp-modal"> 
4615         <div class="modal-extensao_content"> 
4616            <i class="fas fa-undo modal-extensao-voltar-icon"><span class="modal-extensao-voltar-txticon">Voltar</span></i> 
4617            <h1 class="modal-extensao-condicoes__title">Descontos e Parcelamento</h1> 
4618            <div class="row"> 
4619   
4620              <!-- <button class="btn-preco-padrao d-xs-flex d-sm-flex d-lg-none d-xl-none"> 
4621                Preço Padrão 
4622                <i class="fas fa-chevron-right custom-icon-right"></i> 
4623              </button> --> 
4624   
4625             <div class="col-lg-6 col-sm-12 col-xs-12"> 
4626   
4627                <h2 class="modal-extensao_subtitle">Investimento</h2> 
4628   
4629                <span class="modal-extensao_preco">R$ <span class="precoVendaOferta"></span></span> 
4630                <span class="modal-extensao_txteconomiza">.<b class="modal-extensao_txtverde"></b></span> 
4631                <div class="modal-extensao_ctboleto pt-2 pb-2 mb-3"> 
4632                   <i class="fas fa-barcode" aria-hidden="true"></i>   
4633                   <span class="modal-extensao_txtPag">Boleto Bancário</span>   
4634                   <span class="modal-extensao_txtParcela"><b><span class="numParcelaBoleto"></span>x de R$ <span class="precoParcelaBoleto"></span></b></span>         
4635                   <span class="modal-extensao_txtParcela">sem juros</span> 
4636                </div> 
4637                <div class="modal-extensao_ctcard pt-2 pb-2 mb-3"> 
4638                   <i class="far fa-credit-card" aria-hidden="true"></i> 
4639                   <span class="modal-extensao_txtPag">Cartão de Crédito</span> 
4640                   <span class="modal-extensao_txtParcela"><b><span class="numParcelaCartoes"></span>x de R$ <span class="precoParcelaCartoes"></span></b></span>         
4641                   <span class="modal-extensao_txtParcela">sem juros</span> 
4642                </div> 
4643                <p class="modal-extensao_txtParcela pt-5"><b>À vista:</b> R$ <span class="precoAVistaPadraoExt"></span> <span class="modal-extensao_txtporcent">(-8%)</span></p> 
4644             </div> 
4645   
4646             <!-- <hr class="ssp-divisor d-xs-block d-sm-block d-lg-none d-xl-none"> --> 
4647   
4648             <!-- <button class="btn-preco-ex-aluno d-xs-flex d-sm-flex d-lg-none d-xl-none"> 
4649              Preço para Contribuintes,<br>alunos e ex-alunos* 
4650              <i class="fas fa-chevron-right custom-icon-right"></i> 
4651            </button> --> 
4652   
4653             <div class="col-lg-6 col-sm-12 col-xs-12"> 
4654                <h2 class="modal-extensao_subtitle mt-4">Valor com 20% de desconto para alunos, ex-alunos e contribuintes Senac</h2> 
4655                <span class="modal-extensao_preco">R$ <span class="precoContrExt"></span></span> 
4656                <span class="modal-extensao_txteconomiza">Você economiza <b class="modal-extensao_txtverde">R$ <span class="economiaExt"></span> (-20%)</b></span> 
4657                <div class="modal-extensao_ctboleto pt-2 pb-2 mb-3"> 
4658                   <i class="fas fa-barcode" aria-hidden="true"></i>   
4659                   <span class="modal-extensao_txtPag">Boleto Bancário</span>   
4660                   <span class="modal-extensao_txtParcela"><b><span class="numParcelaBoleto"></span>x de R$ <span class="precoParcelaBoletoExt"></span></b></span>         
4661                   <span class="modal-extensao_txtParcela">sem juros</span>     
4662                </div> 
4663                <div class="modal-extensao_ctcard pt-2 pb-2 mb-3"> 
4664                   <i class="far fa-credit-card" aria-hidden="true"></i> 
4665                   <span class="modal-extensao_txtPag">Cartão de Crédito</span> 
4666                   <span class="modal-extensao_txtParcela"><b><span class="numParcelaCartoes"></span>x de R$ <span class="precoParcelaCartoesExt"></span></b></span>         
4667                   <span class="modal-extensao_txtParcela">sem juros</span> 
4668                </div> 
4669                <p class="modal-extensao_txtParcela pt-5"><b>À vista:</b> R$ <span class="precoAVistaContrExt"></span> <span class="modal-extensao_txtporcent">(-8%)</span></p> 
4670             </div> 
4671             <div class="col-lg-6 col-sm-12 col-xs-12"> 
4672                <a target="_blank" href="#"> 
4673                <button class="btn modal-extensao__btn mt-3 text-uppercase">Comprar</button> 
4674                </a> 
4675             </div> 
4676             <div class="col-lg-6 col-sm-12 col-xs-12"> 
4677                <button class="btn btn-primary modal-extensao-btn-conheca mt-3" >Conheça os descontos</button> 
4678             </div> 
4679          </div> 
4680         </div> 
4681 
4682         <div class="modal-extensao_content modal-pergunta-aluno-ext d-none"> 
4683            
4684            <i class="fal fa-times modal-extensao-voltar-icon" style="font-size:25px;"></i> 
4685            <h1 class="modal-extensao-condicoes__title">Você é nosso aluno?</h1> 
4686            <div class="row"> 
4687               <div class="col-6 text-right"> 
4688                   
4689                  <button class="btn btn-primary modal-extensao-btn-aluno-sim-nao sim mt-3">Sim</button> 
4690           
4691	</div> 
4692               <div class="col-6 text-left"> 
4693                   
4694                  <button class="btn btn-primary modal-extensao-btn-aluno-sim-nao nao mt-3">Não</button> 
4695                   
4696               </div> 
4697            </div> 
4698            <div class="row d-none msg-alunoSim"> 
4699               <div class="col-12 text-center mt-10"> 
4700                  <i class="fas fa-check-circle modal-extensao-ico-check"></i> 
4701                  <h2 class="modal-extensao-condicoes__subtitle">Boa notícia!</h2> 
4702                  <p class="modal-extensao-aluno_txtcontent">Você tem 20% de desconto neste curso.<br> Faça seu login e preencha os dados solicitados.</p> 
4703                  <p class="mb-0"> 
4704                     <a target="_blank" href="#"> 
4705                     <button class="btn modal-extensao-aluno__btn ok mt-3">Fazer Inscrição</button> 
4706                     </a> 
4707                  </p> 
4708                  <p class="mt-0"> 
4709                     <a href="https://www.sp.senac.br/descontos-e-parcelamentos/pos-e-extensao-universitaria"> 
4710                     <button class="btn btn-primary modal-extensao-btn-conferir mt-3" id="btn-conferir-regras">Conferir Regras</button> 
4711                     </a> 
4712                  </p> 
4713               </div> 
4714            </div> 
4715            <div class="row d-none msg-alunoNao"> 
4716               <div class="col-12 text-center mt-10"> 
4717                  <i class="fas fa-percentage modal-extensao-ico-percent"></i> 
4718                  <h2 class="modal-extensao-condicoes__subtitle">Poxa! Não fique triste...</h2> 
4719                  <p class="modal-extensao-aluno_txtcontent">Você não tem direito ao desconto de 20% neste curso. Mas você tem direito ao desconto de pontualidade (melhorar texto)</p> 
4720                  <p class="mb-0"> 
4721                     <a target="_blank" href="#"> 
4722                     <button class="btn modal-extensao-aluno__btn not mt-3">Fazer Inscrição</button> 
4723                     </a> 
4724                  </p> 
4725                  <p class="mt-0"> 
4726                     <a href="https://www.sp.senac.br/descontos-e-parcelamentos/pos-e-extensao-universitaria"> 
4727                     <button class="btn btn-primary modal-extensao-btn-conferir mt-3" id="btn-conferir-regras">Conferir Regras</button> 
4728                     </a> 
4729                  </p> 
4730               </div> 
4731            </div> 
4732         </div> 
4733      </section> 
4734     	 
4735	 
4736	<!-- Modal Descontos e Parcelamento EMED --> 
4737	<div id="modalPagtoEmed" class="ssp-modal"> 
4738	 
4739	        <div class="ssp-card-modal-forma-pagamento"> 
4740 
4741            <div class="ssp-card-modal-forma-pagamento__header"> 
4742               <h6 class="ssp-card-modal-forma-pagamento__header-title font-weight-bold text-center" style="color:#454F63">Descontos e parcelamentos</h6> 
4743               <div class="ssp-modal-emed-btfechar"> 
4744               <i class="ssp-card-modal-forma-pagamento__btn-close ssp-card-modal-forma-pagamento__btn-close_0"></i> 
4745               <span>Fechar</span> 
4746              </div> 
4747            </div> 
4748 
4749            <div class="ssp-card-modal-forma-pagamento__body"> 
4750 
4751              <p class="ssp-modal-emed-info-valor-matricula"><span class="ssp-modal-emed-info-txt-matricula">1ª parcela de R$ <span class="precoParcelaEmedModal"></span> <span>+ <span class="numParcelaEmedModal"></span> mensalidades de R$ <span class="precoParcelaEmedModal"></span></span></p>          
4752 
4753               <p class="ssp-card-modal-forma-pagamento__valor-desconto ssp-modal-emed-valor-total-txt"> <span class="ssp-modal-emed-txtValor">Valor total:</span> <span class="precoVendaOferta ssp-modal-emed-valor-total">R$ 414,40</span> 
4754                <span class="ssp-card-modal-emed-ano">/ano</span></p> 
4755 
4756               <p class="txt-desconto-oito ssp-modal-emed-txt-desconto-oito text-center" style="border-bottom: 0px;"><i class="fas fa-badge-percent"></i> <span class="txt-pague-vista">Pague à vista e</span> <span class="txt-ganhe-mais" style="color:#FC7834;font-weight:bold"> ganhe mais 8% de desconto.</span></p> 
4757               <div class="ssp-card-modal-emed-lineou"><span>ou</span></div> 
4758 
4759               <small class="ssp-card-oferta-curso__title-item font-weight-bold" style="margin:0;font-size:14px;text-align: center;">Ganhe fôlego: parcele seu curso!</small> 
4760 
4761               <div class="ssp-card-modal-forma-pagamento__tipos"> 
4762                
4763               <div class="ssp-card-modal-forma-pagamento__tipos-content align-items-start ssp-card-modal-emed-centralizaPagtos" style="margin:0 auto" > 
4764                     <i class="ssp-card-modal-forma-pagamento__icon-boleto-cartao"></i> 
4765                     <div class="ssp-card-modal-forma-pagamento__info-cartao"> 
4766                        <p><strong>Cartão de Crédito +</strong></p> 
4767                        <p><strong>Boleto Bancário</strong></p> 
4768                        <!-- <p>1ª parcela em <span>até 4x de R$ <span class="valorParcelaEntradaCartoesBoleto">265,50</span></span> sem juros no cartão</p> --> 
4769                        <p>1ª parcela no cartão</p> 
4770                        <p>Valor restante em <span>até <span class="numParcelaCartoesBoleto"></span>x de <br>R$ <span class="precoParcelaCartoesBoleto"></span></span> sem juros no boleto</p>                        
4771                     </div> 
4772                  </div> 
4773                
4774 
4775                  <div class="ssp-card-modal-forma-pagamento__tipos-content align-items-start ssp-card-modal-emed-centralizaPagtos" style="margin:0 auto" > 
4776                     <i class="ssp-card-modal-forma-pagamento__icon-credit-card"></i> 
4777                     <div class="ssp-card-modal-forma-pagamento__info-cartao"> 
4778                        <p><strong>Cartão de Crédito</strong></p> 
4779                        <p>(<span class="textoCartoesAceitos">Mastercard, Visa, Elo, American Express, Hipercard</span>)</p> 
4780                        <p>Em até <span><span class="numParcelaCartoes">12</span>x de R$ <span class="precoParcelaCartoes">34,53</span></span> sem juros</p> 
4781                     </div> 
4782                  </div> 
4783 
4784                  <div class="ssp-card-modal-forma-pagamento__tipos-content align-items-start mt-4 ssp-card-modal-emed-centralizaPagtos" style="margin:0 auto" id="content_boleto_0"> 
4785                     <i class="ssp-card-modal-forma-pagamento__icon-boleto"></i> 
4786                     <div class="ssp-card-modal-forma-pagamento__info-cartao"> 
4787                        <p><strong>Boleto Bancário</strong></p> 
4788                        <p>Em até <span><span class="numParcelaBoleto">12</span>x de R$ <span class="precoParcelaBoleto">34,53</span></span> sem juros</p> 
4789                     </div> 
4790                  </div> 
4791                   
4792                  <p class="txt-desconto-oito ssp-modal-emed-txt-desconto-oito ssp-modal-emed-boxoito" data-info="data-para-matricula"><span class="ssp-card-modal-emed-valorObs obsspan"><i class="fas fa-exclamation-circle"></i>As vagas são limitadas e por ordem de chegada!</span>Garanta seu lugar! Matricule-se agora.</p> 
4793 
4794                  <p class="txt-desconto-oito ssp-modal-emed-txt-desconto-oito ssp-card-modal-emed-boxDesconto" data-info="msg-20-desconto"><strong>E você ainda tem</strong><span style="color:#FC7834;font-weight:bold"> 20% desconto na mensalidade se:</span><br> 
4795                    - Estuda ou estudou no Senac<br>  
4796                    - É dependente de quem trabalha em empresa contribuinte do Senac<br>  
4797                    - Estuda ou estudou na rede pública de ensino 
4798                </p> 
4799 
4800               </div> 
4801 
4802            </div> 
4803             
4804 
4805            <a href="#a" class="btn btn-lg w-100 ssp-btn-emed__voltar-curso" style="margin-top: 20px;font-weight:600" id="" data-espaco-ex="true" data-unidade="" data-evento="" data-destino-compra="" data-index=""><span class="">Voltar para página do curso</span></a> 
4806 
4807             
4808             
4809    </div> 
4810  </div> 
4811 
4812  <#if isEMED> 
4813    <div id="modalAntesCompraEmed" class="ssp-modal"> 
4814      <div class="ssp-modal-local-realizacao"> 
4815        <div class="ssp-modal-local-realizacao__title-content"> 
4816          <h6 class="ssp-modal-local-realizacao__title" style="padding-left:10%;">IMPORTANTE!</h6> 
4817            <i class="ssp-card-modal-antes-compra__btn-close ssp-card-modal-forma-pagamento__btn-close"></i> 
4818        </div> 
4819        <div class="ssp-modal-local-realizacao__texto"> 
4820          <p class="texto-modal-emed textoEmedModalAntesCompra0010 d-none"> 
4821           
4822            Esta matrícula é válida apenas para a compra do curso de acordo com a escola e o horário já selecionados.<br/> 
4823           
4824          </p> 
4825          <p class="texto-modal-emed textoEmedModalAntesCompra0010Espera d-none"> 
4826           
4827            Saiba como funciona a inscrição para a lista de espera:<br/><br/> 
4828            - É válida somente para a <b>compra do curso</b><br/> 
4829            - Não garante vaga para o estudante<br/> 
4830            - É válida apenas para o curso, horário e escola selecionados<br/> 
4831            - Caso surjam vagas, você receberá um e-mail para fazer a matrícula<br/> 
4832           
4833          </p> 
4834          <p class="texto-modal-emed textoEmedModalAntesCompra0020e0030 d-none"> 
4835                       
4836            - Essa inscrição é para uma lista de espera de transferência para 2º ou 3º ano do Ensino Médio Técnico, por isso, ao realizá-la não garantimos a vaga<br/><br/> 
4837            - A inscrição só pode ser solicitada para quem deseja estudar no Senac realizando a compra do curso<br/><br/> 
4838            - Se a turma escolhida tiver vagas, você receberá um e-mail com orientações sobre a entrega de documentos e as formas de pagamento para efetivar a transferência 
4839                       
4840          </p> 
4841          <div class="btn ssp-modal-local-realizacao__btn-content"> 
4842            <button class="btn btn-lg btn-success w-100 mt-3" offercode="" id="btnCompraLocalEmed">Continuar para compra</button> 
4843            <a class="ssp-modal-local-realizacao__btn btn btn-lg w-100 mt-3 ssp-card-modal-selecionar-outro__btn-close" href="#a">Voltar para o curso</a> 
4844          </div> 
4845        </div> 
4846      </div> 
4847    </div> 
4848         
4849  </#if> 
4850 
4851   
4852   
4853           
4854   <script> 
4855     let showedFilters = false 
4856     var groupId = themeDisplay.getScopeGroupId(); 
4857 
4858   var urlSearchCursosPorCategory = '/o/senac-curso-services/cursosPorCategoryIds/{groupId}?categoryIds={categoryId}&start=0&end={limit}'; 
4859    
4860   var urlSearchOferta = '/o/senac-oferta-services/ofertasPorCategoryIds/' + groupId 
4861 
4862   var urlSearchUnidade = '/o/senacsearch/Unidade/{companyId}/{groupId}/{userId}?q=codigoUnidade_pt_BR:{codigoUnidade}'; 
4863   var urlUnidadeInfoDetalhe = '/o/senac-content-services/unidadeInfoDetalhe/{companyId}/{codigoUnidade}'; 
4864   var urlSearchCursosPodeGostar = '/o/senac-content-services/cursosVocePodeGostar/{companyId}/{groupId}/{userId}/{articleId}/{limit}'; 
4865   var urlSearchCursoInfo = '/o/senac-content-services/cursosInfoDetalhe/{groupId}/{cursosInfo}?inscricaoAberta={inscricaoAberta}&bolsaAberta={bolsaAberta}'; 
4866   var urlRegistroInteresse = '/o/senac-content-services/registroInteresse/'; 
4867   var urlRegistroInteresseEmailInteressado = '/o/senac-content-services/envioEmailRegistroInteresse/'; 
4868   var cntSelectUnidades = 1; 
4869   var urlPlanoCurso = 'https://www.sp.senac.br/jsp/includeMatdid.jsp?file=/ha1shared/projects/matdid/{codigoFT}-{dataEfetiva}.html'; 
4870   var urlGetServerT = '/o/senac-content-services/getServerTime';  
4871   var urlSearchCursosPodeGostarEmed = '/o/senac-curso-services/cursosPorCategoryIdsFilterAndOr/{groupId}/?categoryIdsOr={tiposDeCurso}&start=0&end={limit}&articleId={articleId}'; 
4872   var todayG = ''; 
4873   var codigoFTCursoAprendizagem = 18984; 
4874   var globalGroupId = Liferay.ThemeDisplay.getCompanyGroupId(); 
4875   var isAoVivo = 0; 
4876   var nomeFormatoAoVivoDxp = 'Senac Online - ao vivo'; 
4877   var ofertaUnidadeMap = new Map(); 
4878   var ultimaUnidade = 0; 
4879   var regIndex = new RegExp('\{index\}', 'g'); 
4880   var linkBotaoCompra = 'http://www.sp.senac.br/login/Login?destino=/ecommerceFrontEnd/?vcw_unidade={codigoUnidade}&vcw_evento={codigoOferta}'; 
4881   var carregouUltimaOferta = false; 
4882   var ofertasMap = new Map(); 
4883   var codUnidadeSenacAoVivo = '108'; 
4884   var ofertasComBolsa = false; 
4885 
4886    //funcao para pegar host do ambiente, se eh teste ou prod (utilizado no servico da bolsa)- 9546 
4887    function getServiceEnvironmentHost(){ 
4888      if(!isAmbienteTeste()) 
4889        return window.location.origin 
4890      else 
4891        return 'https://gesportal.sp.senac.br' 
4892
4893 
4894    var hostBolsa = getServiceEnvironmentHost() 
4895 
4896   // Montar object push - google tag manager - 1 
4897   let itensEcommerce = null;  
4898   let ofertaSelecionada = null; 
4899 
4900   const today = new Date; 
4901    
4902   //categoryId -> cod unidade 
4903   var mapUnidadesIds = new Map(); 
4904   var objsTela = { 
4905     unidades: [], 
4906     unidadesRegistroInteresse: [], 
4907     categoriesIds:[], 
4908     ofertasAoVivoTodasUnidades: [], 
4909     primeiroChange: true 
4910   }; 
4911   var startOfertaParam = 0; 
4912   var endOfertaParam = 25; 
4913    
4914   var ehCursoTrampolim = false; 
4915    
4916   const isHibrido = $('input[name="formato"]').data('formato') === 'Presencial + EAD'; 
4917   
4918   var textoFormatoHibrido = ""; 
4919   var temTextoParaFormatoHibrido = false; 
4920   
4921   //Validar se o campo textoFormatoHibrido existe e se não está vazio 
4922   if(isHibrido){ 
4923                textoFormatoHibrido = $('input[name="textoFormatoHibrido"]').val(); 
4924                if(typeof textoFormatoHibrido !== 'undefined'){ 
4925                           if (textoFormatoHibrido.trim() !== '' ) { 
4926                                temTextoParaFormatoHibrido = true; 
4927                                textoFormatoHibrido += '<br>'; 
4928
4929
4930
4931    
4932   const HOST = window.location.origin; 
4933   const URLGeral = window.location.href; 
4934    
4935   //EMED 
4936   const anoTurmaEmed = '2025'; 
4937 
4938   const tipoCursoNome = function(){ return $('.ssp-header-curso__tag-formato').text().trim(); } 
4939    
4940   const isEmed = (tipoCursoNome().indexOf('Ensino Médio Técnico') > -1); 
4941 
4942   const statusEmed = Object.freeze({ 
4943		NAO_ENCONTRADA: 0, 
4944    INSCRICAO: 1, 
4945		ESPERA: 2, 
4946		ESGOTADO: 3 
4947	}); 
4948    
4949   let unidadesToURL = [] 
4950    
4951   const localLivreOnline = function(textoLocal){  
4952     textoLocal = textoLocal || '' 
4953     textoLocal = textoLocal.replaceAll('online', 'on-line') 
4954 
4955     const textoOnline = 'Nesta turma, todas as aulas serão on-line e ao vivo pela plataforma digital Microsoft Teams'; 
4956      
4957     return textoLocal.toUpperCase().includes(textoOnline.toUpperCase()); 
4958
4959    
4960   const linkBolsa = function(oferta){ 
4961	    
4962      let tiposCurso = new Map(); 
4963      tiposCurso.set('livre', 'L'); 
4964      tiposCurso.set('tecnico', 'T'); 
4965      tiposCurso.set('aprendizagem', 'A'); 
4966      let letraTipoCurso = tiposCurso.get($('[name="tipoCurso"]').val()) || ''; 
4967  
4968      // verifica o campo destinoBolsa da oferta - 9546 
4969      var destinoBolsa = "" 
4970      if(oferta.destinoBolsa){ 
4971        destinoBolsa = parseInt(oferta.destinoBolsa,10)  
4972
4973      	 
4974      return hostBolsa+'/login/Login?origem=bolsas&destino=/jsp/default.jsp?template=2464.dwt&testeira=1540&idcourse='+ 
4975	      $('[name="codigoFT"]').val()+ 
4976	      '&cod_evento='+ 
4977	      oferta.codigoOferta+ 
4978	      '&cod_u='+ 
4979	      codigoUnidade+ 
4980	      '&nvg='+ 
4981	      oferta.qtdeTotalVagasPSG+ 
4982	      '&type='+ 
4983	      letraTipoCurso+ 
4984	      '&sel_unit=&ft=y'+ 
4985	      (destinoBolsa ? '&destino='+destinoBolsa : '');      
4986
4987    
4988    
4989   $('.ssp-ofertas-emed__filtro-content .btn').on('click', function(){ 
4990      
4991     var classAtivo = 'btn--filtro-ativo'; 
4992      
4993     if(!$(this).hasClass(classAtivo)){ 
4994      
4995       $(this).siblings().removeClass(classAtivo); 
4996        
4997       $(this).addClass(classAtivo); 
4998 
4999       const $cardTransferencias = $('.card-transferencias-emed'); 
5000        
5001       if($(this).val() == '0'){ 
5002        hideCardSemTurmas(true); 
5003        $('.ssp-slick-ofertas-emed').empty(); 
5004        if(!$('.ssp-slick-ofertas-emed').hasClass('d-none')) $('.ssp-slick-ofertas-emed').addClass('d-none'); 
5005        $('.prev-mobile, .next-mobile').addClass('d-none'); 
5006        $cardTransferencias.removeClass('d-none'); 
5007       } else{ 
5008        if(!$cardTransferencias.hasClass('d-none')) $cardTransferencias.addClass('d-none'); 
5009        $('.ssp-slick-ofertas-emed').removeClass('d-none'); 
5010        populaOfertas(objsTela.ofertas); 
5011
5012        
5013
5014      
5015   }); 
5016    
5017   //Cronometro 
5018	var hidden, visibilityChange; 
5019	var restartTimeout = null; 
5020	var interval01, interval15; 
5021	 
5022	if (typeof document.hidden !== "undefined") { // Opera 12.10 and Firefox 18 and later support 
5023		hidden = "hidden"; 
5024		visibilityChange = "visibilitychange"; 
5025	} else if (typeof document.msHidden !== "undefined") { 
5026		hidden = "msHidden"; 
5027		visibilityChange = "msvisibilitychange"; 
5028	} else if (typeof document.webkitHidden !== "undefined") { 
5029		hidden = "webkitHidden"; 
5030		visibilityChange = "webkitvisibilitychange"; 
5031
5032	 
5033	// Verifica suporte a Visibility API 
5034	if (typeof document.addEventListener === "undefined" || hidden === undefined) { 
5035		console.log("Navegador incompativel com page visibility api"); 
5036	} else { 
5037		// Evento para quando a visibilidade da pagina mudar 
5038		document.addEventListener(visibilityChange, handleVisibilityChange, false); 
5039
5040    
5041   $(".ssp-saiba-mais-curso-accordion").on("click", ".ssp-saiba-mais-curso-accordion__heading", function() { 
5042   
5043       $(this).toggleClass("active").next().slideToggle(); 
5044   
5045       $(".sp-saiba-mais-curso-accordion__contents").not($(this).next()).slideUp(300); 
5046   
5047       $(this).siblings().removeClass("active"); 
5048   }); 
5049   
5050  function loadUnidadesRegistroInteresse(urlCursoInfo) { 
5051    if(objsTela.unidadesRegistroInteresse && objsTela.unidadesRegistroInteresse.length) 
5052      return 
5053 
5054    let urlUnidades = new URL(window.location.origin + urlCursoInfo) 
5055    let paramsUnidades = new URLSearchParams(urlUnidades.search) 
5056    paramsUnidades.delete('inscricaoAberta') 
5057    paramsUnidades.delete('bolsaAberta') 
5058    urlUnidades.search = '?' + paramsUnidades.toString() 
5059    urlUnidades = urlUnidades.href 
5060 
5061    $.ajax({ 
5062      url: urlUnidades, 
5063      method:'get', 
5064      async: false 
5065    }).done(function(data){ 
5066      if(data.length > 0){ 
5067        const cursoInfo = JSON.parse(data); 
5068        const unidadesOfertantes = cursoInfo.unidadesOfertantes; 
5069         
5070        $.each(unidadesOfertantes, function(k,item){ 
5071          var unidade = {}; 
5072          unidade['categoryId'] = item['categoryId']; 
5073          unidade['codigoUnidade'] = item['codigoUnidade']; 
5074          unidade['nome'] = item['nomeUnidade']; 
5075          unidade['enderecoUnidade'] =item['enderecoUnidade']; 
5076          unidade['numero'] =item['numEnderecoUnidade']; 
5077          unidade['complemento'] = item['complementoEnderecoUnidade']; 
5078          unidade['bairro'] = item['bairroUnidade']; 
5079          unidade['googlemapsUnidade'] = item['googlemapsUnidade']; 
5080          unidade['friendlyURL'] = item['friendlyURL']; 
5081          unidade['selecionado'] = false; 
5082          unidade['selectSelecionado'] = ""; 
5083          unidade['ofertas'] = []; 
5084               
5085          if(!objsTela.unidadesRegistroInteresse.filter(uni => uni['categoryId'] == unidade['categoryId']).length) 
5086            objsTela.unidadesRegistroInteresse.push(unidade) 
5087          }); 
5088
5089    }); 
5090
5091   
5092   function loadUnidades(showOptions, unidadeValue){ 
5093     //Busca as unidades do curso 
5094      
5095    const urlCursoInfo = urlSearchCursoInfo 
5096      .replace('\{groupId\}', groupId) 
5097      .replace('\{cursosInfo\}', $('[name="articleId"]').val()) 
5098      .replace('\{inscricaoAberta\}', $('#chkInscricao').prop('checked')) 
5099      .replace('\{bolsaAberta\}', $('#chkBolsa').prop('checked')); 
5100 
5101      loadUnidadesRegistroInteresse(urlCursoInfo) 
5102 
5103      $.ajax({ 
5104          url:urlCursoInfo, 
5105          method:'get', 
5106          async: false, 
5107        beforeSend: function () { 
5108          loading('.oferta-slick-area'); 
5109
5110        }).done( 
5111          function(data){ 
5112             
5113            if(data.length > 0){ 
5114               
5115              if(!isAoVivo) 
5116                $('.ssp-container-selecione-unidade').removeClass('d-none') 
5117               
5118              const cursoInfo = JSON.parse(data); 
5119               
5120                                       
5121              //GCR pediu para voltarmos no combo as unidades vinculadas e não somente as que possuem ofertas 
5122              //const unidades = cursoInfo.unidadesComOferta; 
5123              const unidades = cursoInfo.unidadesOfertantes; 
5124               
5125              objsTela.unidades = [] 
5126              mapUnidadesIds = new Map(); 
5127               
5128              $.each(unidades, function(k,item){ 
5129                   
5130                  var unidade = cloneObj(item) 
5131                  unidade['nome'] = item['nomeUnidade']; 
5132                  unidade['numero'] =item['numEnderecoUnidade']; 
5133                  unidade['complemento'] = item['complementoEnderecoUnidade']; 
5134                  unidade['bairro'] = item['bairroUnidade']; 
5135                  unidade['ofertas'] = []; 
5136                       
5137                    objsTela.unidades.push(unidade); 
5138                       
5139                      mapUnidadesIds.set(unidade['categoryId'], unidade['codigoUnidade']); 
5140 
5141                    objsTela.unidades.forEach(unidade => unidadesToURL.filter(u => u.friendlyURL == unidade.friendlyURL).length ? '' : unidadesToURL.push(unidade)) 
5142                }); 
5143                       
5144                             
5145              populaSelectUnidades(undefined, showOptions, unidadeValue);  
5146    
5147
5148      }); 
5149       
5150
5151   
5152function getOfertaObjectFromJson(ofertaJSON,index){ 
5153   
5154 
5155  var oferta =  {}; 
5156        var xml =  $($.parseXML(ofertaJSON.content)); 
5157          oferta['ordenar'] = paramOrdem(xml); 
5158          oferta['vagasTotal'] = xml.find('[name="vagasTotal"]').text().trim(); 
5159          var dataInicio = xml.find('[name="dataInicioOferta"]').text().split('-'); 
5160          var dataFim =xml.find('[name="dataFimOferta"]').text().split('-'); 
5161          oferta['dataInicio'] = dataInicio[2].trim()+'/'+dataInicio[1].trim()+'/'+dataInicio[0].trim(); 
5162          oferta['dataFim'] = dataFim[2].trim()+'/'+dataFim[1].trim()+'/'+dataFim[0].trim(); 
5163          oferta['horaInicio'] = xml.find('[name="horaInicioOferta"]').text(); 
5164          oferta['codigoOferta'] = xml.find('[name="codigoOferta"]').text().trim(); 
5165          var dias = []; 
5166          oferta['horaFimOferta'] = xml.find('[name="horaFimOferta"]').text().trim(); 
5167          xml.find('[name="diasDaSemanaOferta"]').find('option').each(function(index,dia){ 
5168            dias.push($(dia).text()); 
5169          }); 
5170          oferta['diasDaSemanaOferta'] = dias; 
5171          oferta['periodoDiaOferta'] = xml.find('[name="periodoDiaOferta"]').text().trim(); 
5172          oferta['precoCheioOferta'] = xml.find('[name="precoCheioOferta"]').text().trim(); 
5173          oferta['precoVendaOferta'] = xml.find('[name="precoVendaOferta"]').text().trim(); 
5174          oferta['numeroMaxParcelasOferta'] = xml.find('[name="numeroMaxParcelasOferta"]').text().trim(); 
5175           
5176          oferta['textoCartoesAceitos'] =  pegarTextoCartoesAceitos(xml.find('[name="formaDePagamentoCartaoOferta"]').text().trim()); 
5177          oferta['numParcelaCartoes'] =  pegaNumParcela(xml.find('[name="formaDePagamentoCartaoOferta"]').text().trim()); 
5178          oferta['precoParcelaCartoes'] =  pegaValorParcela(xml.find('[name="formaDePagamentoCartaoOferta"]').text().trim()); 
5179          oferta['numParcelaBoleto'] =  pegaNumParcela(xml.find('[name="formaDePagamentoBoletoOferta"]').text().trim()); 
5180          oferta['precoParcelaBoleto'] =  pegaValorParcela(xml.find('[name="formaDePagamentoBoletoOferta"]').text().trim()); 
5181           
5182          oferta['precoVendaMaxParcelaOferta'] = xml.find('[name="precoVendaMaxParcelaOferta"]').text().trim(); 
5183          oferta['formaDePagamentoOferta'] = xml.find('[name="formaDePagamentoOferta"]').text().trim(); 
5184          oferta['botaoCompraOferta'] = xml.find('[name="botaoCompraOferta"]').text().trim(); 
5185          oferta['vagasParaCompraOferta'] = xml.find('[name="vagasParaCompraOferta"]').text().trim(); 
5186          oferta['botaoBolsaOferta'] = xml.find('[name="botaoBolsaOferta"]').text().trim(); 
5187          oferta['vagasBolsaOferta'] = xml.find('[name="vagasBolsaOferta"]').text().trim(); 
5188          oferta['dataAberturaBolsaOferta'] = xml.find('[name="dataAberturaBolsaOferta"]').text().trim(); 
5189          oferta['horaAberturaBolsaOferta'] = xml.find('[name="horaAberturaBolsaOferta"]').text().trim(); 
5190          oferta['espacoExterno'] = xml.find('[name="espacoExterno"]').text().trim(); 
5191          oferta['localEspacoExterno'] = xml.find('[name="localEspacoExterno"]').text().trim(); 
5192          oferta['ruaEspacoExterno'] = xml.find('[name="ruaEspacoExterno"]').text().trim(); 
5193          oferta['numeroEspacoExterno'] = xml.find('[name="numeroEspacoExterno"]').text().trim(); 
5194          oferta['complementoEspacoExterno'] = xml.find('[name="complementoEspacoExterno"]').text().trim(); 
5195          oferta['bairroEspacoExterno'] = xml.find('[name="bairroEspacoExterno"]').text().trim(); 
5196          oferta['cidadeEspacoExterno'] = xml.find('[name="cidadeEspacoExterno"]').text().trim(); 
5197          oferta['ufEspacoExterno'] = xml.find('[name="ufEspacoExterno"]').text().trim(); 
5198          oferta['cepEspacoExterno'] = xml.find('[name="cepEspacoExterno"]').text().trim(); 
5199          oferta['qtdeTotalVagas'] = xml.find('[name="qtdeTotalVagas"]').text().trim(); 
5200          oferta['qtdeTotalVagasPSG'] = xml.find('[name="qtdeTotalVagasPSG"]').text().trim(); 
5201          oferta['horariosAllOferta'] = xml.find('[name="horariosAllOferta"]').text().trim(); 
5202          oferta['formaDePagamentoCartaoOferta'] = xml.find('[name="formaDePagamentoCartaoOferta"]').text().trim(); 
5203          oferta['formaDePagamentoBoletoOferta'] = xml.find('[name="formaDePagamentoBoletoOferta"]').text().trim(); 
5204          oferta['dtLimiteMatricula'] = xml.find('[name="dtLimiteMatricula"]').text().trim(); 
5205          oferta['dataAberturaMatricula'] = xml.find('[name="dataAberturaMatricula"]').text().trim(); 
5206          oferta['etapa'] = xml.find('[name="etapa"]').text().trim(); 
5207          oferta['destinoCompra'] = xml.find('[name="destinoCompra"]').text().trim();  
5208          //adicao do destinoBolsa na oferta - 9546 - 11/07/2022 
5209          oferta['destinoBolsa'] = xml.find('[name="destinoBolsa"]').text().trim(); 
5210 
5211          	if(isEmed){ 
5212		  		//EMED utilizar data matricula para bolsa 
5213		  	  	oferta['dataAberturaBolsaOferta'] = oferta['dataAberturaMatricula'];  
5214 
5215
5216           
5217         return oferta;  
5218
5219   
5220  const getStatusEmed = (oferta) => { 
5221 
5222	    const urlStatusEsperaEmed = () => { 
5223	  		let url = (isAmbienteTeste()) ?  
5224		  		'https://hinscricao-educacional-backend.sp.senac.br/api/lista-espera/' 
5225			    : 'https://inscricao-educacional-ms.sp.senac.br/api/lista-espera/'; 
5226	  		 
5227  	  		return url + oferta.codigoOferta; 
5228
5229  	  	 
5230  	  const callTl = async () => { 
5231	  		if(getCookie('tl') == null){ 
5232	  			return await $.ajax({ 
5233	  				url: '/o/senac-content-services/geraTokenServicosSenac', 
5234	  				method: 'GET' 
5235	  			}); 
5236
5237	  		return getCookie('tl'); 
5238
5239 
5240      const callListaEspera = async () => { 
5241  	    	var tl = ''; 
5242	    	  try{ 
5243  	    		tl = await callTl(); 
5244  	    		if(getCookie('tl') == null){ 
5245  	    			tl = JSON.parse(tl).token; 
5246  	    			writeCookie('tl', tl, 6, ''); 
5247
5248  	    	}catch(err){ 
5249  	    		console.error(err); 
5250  	    		return {}; 
5251
5252  	    	 
5253  	    	return $.ajax({ 
5254              url: urlStatusEsperaEmed(), 
5255              method: 'GET', 
5256  	        	beforeSend: function (xhr) { 
5257  	        		xhr.setRequestHeader("Authorization", tl); 
5258
5259  			  }) 
5260
5261 
5262      return new Promise(async function (resolve, reject) { 
5263        const resp = await callListaEspera(); 
5264        if(typeof resp !== 'object') resp = JSON.parse(resp); 
5265        let status = resp.STATUS; 
5266        resolve(status); 
5267      }); 
5268	  	 
5269
5270   
5271 function getOfertasAoVivo(codigoFT, dataEfetivaOferta, categoryIds){ 
5272       
5273  if(categoryIds && categoryIds.length) { 
5274    var params = new URLSearchParams(); 
5275    params.set('codigoFTOferta',codigoFT) 
5276    params.set('dataEfetivaOferta',dataEfetivaOferta) 
5277    params.set('categoryIds',categoryIds) 
5278    params.set('start',startOfertaParam) 
5279    params.set('end',endOfertaParam) 
5280    params.set('inscricaoAberta', $('#chkInscricao').prop('checked')) 
5281    params.set('bolsaAberta', $('#chkBolsa').prop('checked')) 
5282    params.set('cursoArticleId', $('[name="articleId"]').val() || ''); 
5283 
5284    if($('#chkBolsa').prop('checked')){ 
5285    	params.set('considerarDataBolsaFutura', true) 
5286
5287    const url = urlSearchOferta + '?' + params.toString() 
5288       
5289    $.ajax({ 
5290      url:url, 
5291      method:'get', 
5292      dataType:'json', 
5293      async: false 
5294    }).done( 
5295      function(data){ 
5296         
5297        if(data.length > 0){ 
5298         $('#ssp-alternadores').show() 
5299         showedFilters = true 
5300   
5301         objsTela.ofertasAoVivoTodasUnidades = [] 
5302           
5303          data.forEach(function(ofertaJSON,index){ 
5304   
5305            var oferta = getOfertaObjectFromJson(ofertaJSON,index); 
5306             
5307            //guardo em um map a oferta e qual unidade é, para utilizar depois no populaOferta para o aoVivo                
5308            ofertaUnidadeMap.set(oferta['codigoOferta'],mapUnidadesIds.get(parseInt(ofertaJSON.unidadeCategoryIds)));                
5309            objsTela.ofertasAoVivoTodasUnidades.push(oferta); 
5310   
5311          }); 
5312        } else { 
5313         loadAlternadores(data) 
5314
5315   
5316        populaOfertas(objsTela.ofertasAoVivoTodasUnidades); 
5317        addEventBolsa() 
5318
5319    ).fail(function(e) { 
5320      console.error(e) 
5321      populaOfertas(objsTela.ofertasAoVivoTodasUnidades = []); 
5322    }) 
5323  } else { 
5324    loadAlternadores([]) 
5325    populaOfertas(objsTela.ofertasAoVivoTodasUnidades = []) 
5326
5327 
5328  if(isAoVivo) { 
5329     if(objsTela.ofertasAoVivoTodasUnidades && objsTela.ofertasAoVivoTodasUnidades.length) 
5330       hideCardSemTurmas(true) 
5331     else 
5332       hideCardSemTurmas(false) 
5333
5334
5335    
5336  function mudouToggleOferta(ofertas) { 
5337    const oferta = ofertas && ofertas[0] 
5338    if(!oferta) 
5339      return true 
5340 
5341    const selecaoInscricao = $('#chkInscricao').prop('checked') 
5342    const selecaoBolsa = $('#chkBolsa').prop('checked') 
5343 
5344    return oferta.selecaoInscricao != selecaoInscricao || oferta.selecaoBolsa != selecaoBolsa 
5345
5346 
5347  function loadAlternadores(ofertas) { 
5348    if(showedFilters) { 
5349      $('#ssp-alternadores').show() 
5350      return 
5351
5352 
5353    if($('#unidades-ofertas').is(":hidden") || $('#unidades-ofertas option').length <= 1) { 
5354      if(isAoVivo) { 
5355        if(ofertas && ofertas.length) 
5356          $('#ssp-alternadores').show() 
5357        else { 
5358          if(!$('#chkInscricao').prop('checked') && !$('#chkBolsa').prop('checked')) 
5359            $('#ssp-alternadores').hide() 
5360          else 
5361            $('#ssp-alternadores').show() 
5362
5363      } else { 
5364        if(!$('#chkInscricao').prop('checked') && !$('#chkBolsa').prop('checked')) 
5365          $('#ssp-alternadores').hide() 
5366        else 
5367          $('#ssp-alternadores').show() 
5368
5369    } else 
5370      $('#ssp-alternadores').show() 
5371 
5372    showedFilters = showedFilters || $('#ssp-alternadores').is(":visible") 
5373
5374 
5375  function getOfertas(codigoFT, dataEfetivaOferta, categoryId){ 
5376       
5377    var indiceUnidade = -1; 
5378    const selecaoInscricao = $('#chkInscricao').prop('checked') 
5379    const selecaoBolsa = $('#chkBolsa').prop('checked') 
5380      
5381     for(var i = 0; i < objsTela.unidades.length; i++) 
5382         if(objsTela.unidades[i].categoryId == categoryId) 
5383           indiceUnidade = i; 
5384      
5385    ultimaUnidade = indiceUnidade; 
5386           
5387     if( !objsTela.categoriesIds.includes(categoryId) || mudouToggleOferta(objsTela.unidades[indiceUnidade]['ofertas'])){ 
5388       objsTela.unidades[indiceUnidade]['ofertas'] = [] 
5389        
5390        var params = new URLSearchParams(); 
5391        params.set('codigoFTOferta',codigoFT) 
5392        params.set('dataEfetivaOferta',dataEfetivaOferta) 
5393        params.set('categoryIds',categoryId) 
5394        params.set('start',startOfertaParam) 
5395        params.set('end',endOfertaParam) 
5396        params.set('inscricaoAberta', $('#chkInscricao').prop('checked')) 
5397        params.set('bolsaAberta', $('#chkBolsa').prop('checked')) 
5398        params.set('cursoArticleId', $('[name="articleId"]').val() || ''); 
5399 
5400        if($('#chkBolsa').prop('checked')){ 
5401        	params.set('considerarDataBolsaFutura', true) 
5402
5403         
5404        const url = urlSearchOferta + '?' + params.toString() 
5405   
5406       $.ajax({ 
5407         url:url, 
5408         method:'get', 
5409         dataType:'json', 
5410         async: false 
5411       }).done( 
5412         function(data){ 
5413            
5414           if(data.length > 0){ 
5415             $('#ssp-alternadores').show() 
5416             showedFilters = true 
5417              
5418             $('.ssp-container-selecione-unidade').show(); 
5419             
5420             data.forEach(function(ofertaJSON,index){ 
5421   
5422               var oferta = getOfertaObjectFromJson(ofertaJSON,index); 
5423                
5424               //Preenche as ofertas da unidade              
5425               objsTela.unidades[indiceUnidade]['ofertas'].push(oferta); 
5426               objsTela.unidades[indiceUnidade]['ofertas'].forEach(o => { 
5427                 o.selecaoInscricao = selecaoInscricao 
5428                 o.selecaoBolsa = selecaoBolsa 
5429               }) 
5430   
5431             }); 
5432           } else { 
5433              loadAlternadores() 
5434
5435           objsTela.categoriesIds.push(categoryId); 
5436           populaOfertas(objsTela.unidades[indiceUnidade]['ofertas']); 
5437           addEventBolsa() 
5438
5439
5440   
5441       //Se estiver na cache, valida as ofertas 
5442     }else{ 
5443        
5444       populaOfertas(objsTela.unidades[indiceUnidade]['ofertas']); 
5445        
5446
5447
5448       
5449   function populaSelectUnidades(unidades, showOptions, unidadeValue){       
5450    var unidadePreSelecionada = false; 
5451    var categoryIdUnidadePreSelecionada = ''; 
5452     
5453    //Oredenacao 
5454    objsTela.unidades.sort(function (a, b) { 
5455    	return ordenar(a, b, 'nome'); 
5456    }); 
5457     
5458    objsTela.unidadesRegistroInteresse.sort(function (a, b) { 
5459    	return ordenar(a, b, 'nome'); 
5460      }); 
5461     
5462    //console.log(objsTela.unidades); 
5463     
5464    $.each(objsTela.unidades, function(k,item){ 
5465       
5466      if(getURLData().includes('/'+item.friendlyURL+'/')){ 
5467        unidadePreSelecionada= true; 
5468        categoryIdUnidadePreSelecionada = item['categoryId']; 
5469
5470    }); 
5471     
5472    //console.log('Unidade Pre '+unidadePreSelecionada); 
5473     
5474    if(objsTela.unidades.length == 0){ 
5475      if(!showOptions) 
5476        $('.ssp-container-selecione-unidade').addClass('d-none'); 
5477      $('.oferta-slick-area').empty(); 
5478      $('.prev-mobile').addClass('d-none'); 
5479      $('.next-mobile').addClass('d-none'); 
5480      //EMED remove msg registro interesse 
5481      //if(isEmed) $('.ssp-card-oferta-curso__sem-vaga-description').addClass('d-none'); 
5482
5483     
5484    if(isAoVivo){ 
5485       
5486        const codigoFT = $('[name="codigoFT"]').val(); 
5487    	const dataEfetivaOferta = $('[name="dataEfetivaSTR"]').val(); 
5488 
5489    	var unidadesCategoryAll = ''; 
5490     
5491    	$.each(objsTela.unidades, function(k,unidade){ 
5492      		unidadesCategoryAll += unidade['categoryId']+','; 
5493        }); 
5494       
5495    //tirando ultima virgula 
5496    unidadesCategoryAll = unidadesCategoryAll.substring(0,unidadesCategoryAll.length - 1); 
5497     
5498    getOfertasAoVivo(codigoFT, dataEfetivaOferta, unidadesCategoryAll);            
5499       
5500    }else{ 
5501      $('#unidades-ofertas').empty() 
5502 
5503      if(objsTela.unidades && objsTela.unidades.length){  
5504        if(isEmed) 
5505          $('#unidades-ofertas').append($('<option value="">Selecione uma unidade</option>')) 
5506        else 
5507          $('#unidades-ofertas').append($('<option value="">Clique na unidade de interesse</option>')) 
5508 
5509      } else 
5510        $('#unidades-ofertas').append($('<option value="">Nenhum resultado encontrado</option>')) 
5511 
5512      let unidadeFounded = criarOptionUnidadesPorRegiao(objsTela.unidades) 
5513       
5514      //Dispara o evento para primeira unidade ou pela friendlyURl da unidade 
5515      if(unidadeValue) { 
5516        $('#unidades-ofertas').val(unidadeValue); 
5517        $('#unidades-ofertas').change(); 
5518      } else if(unidadeFounded){	             
5519        $('#unidades-ofertas').val(unidadeFounded['categoryId']+"@"+unidadeFounded['codigoUnidade']); 
5520        $('#unidades-ofertas').change(); 
5521      } else if(!unidadePreSelecionada) { 
5522        $('#unidades-ofertas').change(); 
5523
5524       
5525      $('.ssp-card-registro-interesse__select.unidades').empty() 
5526      $('.ssp-card-registro-interesse__select.unidades').append('<option value="" disabled selected>Selecione uma unidade</option>') 
5527      $.each(objsTela.unidadesRegistroInteresse, function(k,unidade){ 
5528         
5529        $('.ssp-card-registro-interesse__select.unidades').append('<option value="'+unidade['codigoUnidade']+'">'+unidade['nome']+'</option>'); 
5530      }); 
5531
5532     
5533
5534 
5535   
5536   function mudarUnidade(ev){      
5537     startOfertaParam = 0; 
5538     endOfertaParam = 25; 
5539     carregouUltimaOferta = false; 
5540 
5541     var elem = $(ev.target); 
5542     var unidades = objsTela.unidades; 
5543      
5544     //verifica se selecionou alguma unidade 
5545     if(!elem.val()){ 
5546       $('#informe-novas-turmas, .ssp-ofertas-emed__section, .ssp-ofertas__box-endereco-unidade').addClass('d-none'); 
5547 
5548       if(isEmed) 
5549        $('#ssp-section-response').addClass('d-none') 
5550 
5551        hideCardSemTurmas($('#unidades-ofertas option').length > 1)        
5552 
5553        elem.val('') 
5554        habilitarRegistroInteresse(false) 
5555        //Zera variável que controla existência de ofertas com bolsa 
5556        ofertasComBolsa = false; 
5557        controlaPaginaBolsa(); 
5558        
5559       return; 
5560
5561      
5562     $('#informe-novas-turmas, .ssp-ofertas__box-endereco-unidade').removeClass('d-none'); 
5563     hideCardSemTurmas(true) 
5564     if(isEmed){ 
5565        $('.ssp-ofertas-emed__section').removeClass('d-none'); 
5566        $('#ssp-section-response').removeClass('d-none') 
5567        $('.ssp-card-oferta-curso__section-title').addClass('d-none'); 
5568        $('.prev-mobile, .next-mobile').addClass('d-none'); 
5569        var nomeUnidade = $('#unidades-ofertas option:selected').text(); 
5570        let tamScreen = $(window).width(); 
5571 
5572        if(tamScreen < 1024) 
5573	    	  $('#titulo-emed').text('Turmas ' + anoTurmaEmed ); 
5574        else 
5575        	$('#titulo-emed').text('Turmas ' + anoTurmaEmed + ' - ' + nomeUnidade); 
5576 
5577
5578      
5579     const codigoFT = $('[name="codigoFT"]').val(); 
5580     const dataEfetivaOferta = $('[name="dataEfetivaSTR"]').val(); 
5581      
5582     //colocamos dentro do option categoryId@codUnidade 
5583     splitted = elem.val().split("@"); 
5584     var categoryIdUnidade = splitted[0]; 
5585     var codUnidade = splitted[1]; 
5586           
5587     for(var i = 0; unidades.length > i ; i++){ 
5588        
5589       if(unidades[i].categoryId == categoryIdUnidade){ 
5590   
5591           var unidade = unidades[i]; 
5592            
5593           //Exibe o endereco da unidade 
5594           const urlBuscaUnidade = urlUnidadeInfoDetalhe 
5595         .replace('\{companyId\}',themeDisplay.getCompanyId()) 
5596         .replace('\{codigoUnidade\}', unidade.codigoUnidade); 
5597            
5598           $.ajax({ 
5599                 url :  urlBuscaUnidade, 
5600                 type : 'get', 
5601                 dataType: 'json', 
5602                 success: function( unidadeInfo ) { 
5603                   if(unidadeInfo != null && typeof unidadeInfo !== 'undefined'){ 
5604                       
5605                       var endereco = concatSTR(unidadeInfo.enderecoUnidade,unidadeInfo.numEnderecoUnidade,', '); 
5606                         endereco = concatSTR(endereco,unidadeInfo.complementoEnderecoUnidade, ' - '); 
5607                         endereco = concatSTR(endereco,unidadeInfo.bairroUnidade, ' - '); 
5608                 
5609                         $('.ssp-ofertas__endereco-unidade').text(endereco); 
5610                         $('.ssp-ofertas__endereco-unidade').attr('href',unidadeInfo.googlemapsUnidade); 
5611
5612                 }, 
5613                 error: function(data){ 
5614                   $('.ssp-ofertas__endereco-unidade').text(''); 
5615                   $('.ssp-ofertas__endereco-unidade').attr('href','#a'); 
5616                     console.log('Unidade não encontrada'); 
5617
5618             }) 
5619           
5620          getOfertas(codigoFT, dataEfetivaOferta, unidades[i].categoryId); 
5621            
5622          habilitarRegistroInteresse(!!(unidades && unidades.length)); 
5623            
5624
5625     }   
5626
5627     
5628   function pegarTextoCartoesAceitos(campo){ 
5629      indice = campo.indexOf(' em até '); 
5630      inicio = 0; 
5631      fim = indice; 
5632       
5633      return campo.substring(inicio, fim); 
5634
5635    
5636   function pegaNumParcela(campo){ 
5637    
5638      indice = campo.indexOf('até '); 
5639      inicio = indice + 4; 
5640      fim = indice +  6; 
5641       
5642      return campo.substring(inicio, fim); 
5643       
5644
5645    
5646   function pegaValorParcela(campo){ 
5647      
5648      indice = campo.indexOf('R$'); 
5649      inicio = indice+2;     
5650      valorAmericano = campo.substring(inicio) 
5651       
5652      return formataValor(valorAmericano); 
5653       
5654
5655    
5656   function montaHTMLOferta(oferta, index, codigoUnidade, posLoad){ 
5657	    
5658    var retornoDiasHorarios = processaDiasHorariosOferta(oferta.horariosAllOferta); 
5659    diasSemanaHTML = ""; 
5660	      
5661    for(var diaDaOferta of retornoDiasHorarios){ 
5662          diasSemanaHTML += htmlSlickAreaDiasSemana.replace('\{diasSemana\}',diaDaOferta.dias); 
5663          diasSemanaHTML = diasSemanaHTML.replace('\{horasSemana\}',diaDaOferta.horario) 
5664		      }    
5665		       
5666    var ofertaHTML = ""; 
5667		 
5668		if(isEmed){ 
5669			 
5670      ofertaHTML = htmlSlickAreaEmed(oferta); 
5671			$('[name="codUnidadeSelecionada"]').val(codigoUnidade); 
5672			 
5673			if(!posLoad) $('.ssp-slick-ofertas-emed').append(ofertaHTML) 
5674			else $('.ssp-slick-ofertas-emed').slick('slickAdd', ofertaHTML); 
5675		}else{ 
5676 
5677 
5678      ofertaHTML = htmlSlickArea(index, oferta, diasSemanaHTML, codigoUnidade) 
5679       
5680      if(!posLoad) 
5681        $('.oferta-slick-area').append(ofertaHTML); 
5682      else 
5683        $('.oferta-slick-area').slick('slickAdd', ofertaHTML); 
5684       
5685      ajustaTextoDiasHorarioOferta(oferta.codigoOferta); 
5686 
5687
5688 
5689    if(turmasIniciadas(oferta.dataInicio)) 
5690    	$("#aviso-turma-iniciada-"+index).show(); 
5691 
5692	//remove os botões/itens de compra/bolsa caso seja preciso 
5693    $('.oferta-slick-area').find('.d-none-btn').remove(); 
5694
5695 
5696 
5697  	//RECEBE A STRING DE HORARIOS E RETORNA UMA LISTA DE OBJETOS COM OS DIAS E HORARIOS FORMATADOS 
5698	//@horariosAllOferta String com os dias da semana em sigla seguido do horario da aula e separados por virgula EX: "Qui 12h às 13, Sex 12h às 13h"  
5699	function processaDiasHorariosOferta(horariosAllOferta){ 
5700 
5701   		var dias = horariosAllOferta.trim().split(','); 
5702   		let arrayDiasSemana = [{"Seg":"Segunda"},{"Ter":"Terça"},{"Qua":"Quarta"},{"Qui":"Quinta"},{"Sex":"Sexta"},{"Sab":"Sábado"},{"Dom":"Domingo"}] 
5703 
5704   		var arrayDia = []; 
5705   	   	if(dias.length >= 1){ 
5706   		    for(var k=0; dias.length > k; k++){ 
5707   		 		var diasSplit = dias[k].trim().split(' '); 
5708   	          	var diasSemana = diasSplit.shift() 
5709   		      	var ultimaPos = diasSplit.length-1; 
5710   	          	var horasStr = diasSplit[0] + ' às ' + diasSplit[ultimaPos]  
5711   	         	arrayDia.push({horasStr,diasSemana}); 
5712
5713
5714 
5715   		arrayDia = groupByArray(arrayDia, 'horasStr','diasSemana'); 
5716   		arrayDia = orderByArray(arrayDia,arrayDiasSemana); 
5717   		 
5718   		var ret = diaHorarioOfertaFormatado(arrayDia,arrayDiasSemana); 
5719			return ret; 
5720
5721 
5722   //cria um array de objetos Agrupando de acordo ao campo informado como chave.  
5723   //@arr = Array multidimensional que tenha os campos key e valueAdd 
5724   //@key = campo que será chave nesse array 
5725   //@valueAdd = campo que será agrupado caso tenha a mesma informação passada no campo key 
5726   const groupByArray = (arr, key,valueAdd) => { 
5727   		const initialValue = []; 
5728   		const retornoValue = []; 
5729   		arr.forEach((acc, cval) => { 
5730   			const myAttribute = cval[key]; 
5731   			acc[key] in retornoValue ? retornoValue[acc[key]].push(acc[valueAdd]):retornoValue[acc[key]]=[acc[valueAdd]]; 
5732   			return acc; 
5733     		}, initialValue); 
5734   	return retornoValue; 
5735   }; 
5736 
5737 
5738   //Cria um array de objetos a partir do primeiro array inserido e ordenados de acordo a ordem do segundo array informado.  
5739   //@arrayOrdena = Array de objetos que tenha os campos que precisa ser ordenados 
5740   //@ordem = array com a sequencia que queira ordenar - ex: seg, ter, qua, qua 
5741   const orderByArray = (arrayOrdena, ordem) => { 
5742 
5743   	let diasSem = []; 
5744   	const arrayOrdenado = []; 
5745   	let controle; 
5746   	 
5747   	//percorre cada campo existente no ordem e busca o mesmo no arrayOrdena, encontrando insere no arrayOrdenado 
5748   	for(let campo of ordem){	 
5749   		Object.entries(arrayOrdena).forEach(([key, value]) => { 
5750   			for(let diaOferta of value){ 
5751   				if(diaOferta===Object.keys(campo)[0]){ 
5752   					arrayOrdenado[key]=arrayOrdena[key]; 
5753
5754
5755   	    }) 
5756
5757   	return arrayOrdenado; 
5758   }; 
5759 
5760   //retorna o valor de um objeto dentro de um array 
5761   //@objetoBusca = array de objetos que sera buscado o valor 
5762   //@keyBusca = nome do campo a ser buscada no objeto para pegar o seu valor 
5763   function findValueInObject(objetoBusca, keyBusca){ 
5764   	var retorno = ""; 
5765   	Object.entries(objetoBusca).forEach(([horario, dias]) => { 
5766   		Object.entries(dias).forEach(([key,val]) => { 
5767   			if(key.trim()==keyBusca.trim()){ 
5768   				retorno = val; 
5769
5770   		}); 
5771   	}); 
5772   	return retorno; 
5773
5774 
5775   //Recebe um objeto com valores dos dias da semana e define se sao dias seguidos ou alternados.  
5776   //@arrayComDiasDaSemana = array com os dias da semana a serem validados - exemplo ['Qua','Qui','Sex'] 
5777   //@keyBusca = nome do campo a ser buscada no objeto para pegar o seu valor 
5778   function diasSequenciaisOuAlternados(arrayComDiasDaSemana, arrayDiasDaSemana){ 
5779   	 
5780   	let arrayValidador = []; 
5781   	 
5782   	//cria um array com o index dos dias das semanas encontrados [0 = seg, 1 = ter ... 6 = dom] 
5783   	for(let diaOferta of arrayComDiasDaSemana){ 
5784   		for(let i = 0; i < arrayDiasDaSemana.length; i++){ 
5785   			if(diaOferta === Object.keys(arrayDiasDaSemana[i])[0]){ 
5786   				arrayValidador[i] = true; 
5787   			}				 
5788
5789
5790 
5791   	let keyCompair = 99; 
5792   	var sequencial = true; 
5793 
5794   	//verifica quais posições foram criadas no array, e se os valores delas estão em sequencia. 
5795   	for(let keyValidator of Object.keys(arrayValidador)){ 
5796   		keyValidator = parseInt(keyValidator); 
5797   		if(keyCompair!==99){ 
5798   			if(keyValidator===keyCompair){ 
5799   				sequencial = true; 
5800   			}else{ 
5801   				sequencial = false; 
5802   				break; 
5803
5804
5805   		keyCompair = keyValidator+1; 
5806
5807   	return sequencial; 
5808
5809 
5810 
5811   //Exibe as informações de dia e horario de oferta de acordo a sua estrutura 
5812   //Caso os dias sejam sequenciais exibe a primeiro e ultimo dia da semana ligados com a letra 'a' Ex: Segunda a Quinta  
5813   //Caso os dias Nao sejam sequenciais exibem todos os dias separados por virgula  Ex: Segunda, terça, sexta e domingo 
5814   //@arrayAgrupadoEOrdenado = array de objetos que sera exibido 
5815   //@arrayDiasDaSemana = array com os dias da semana, sendo chave a sigla da semana (ex: Qua) e o valor o nome esperado (ex: Quarta) 
5816   function diaHorarioOfertaFormatado(arrayAgrupadoEOrdenado, arrayDiasDaSemana){ 
5817 
5818   	var stringAux = "";		 
5819   	var listRetorno = []; 
5820   		 
5821   	Object.entries(arrayAgrupadoEOrdenado).forEach(([key, value]) => {		 
5822 
5823   		var sequencial = diasSequenciaisOuAlternados(value, arrayDiasDaSemana); 
5824   		var stringAux = "";		 
5825   		var diaOferta = {}; 
5826 
5827   		if(sequencial){ 
5828   			switch (value.length) { 
5829       			case 1: 
5830   					stringAux = stringAux+findValueInObject(arrayDiasDaSemana,value[0])+": "; 
5831   					diaOferta.dias = stringAux.charAt(0).toUpperCase() + stringAux.slice(1).toLowerCase(); // somente a primeira maiúscula 
5832   					diaOferta.horario = key; 
5833   				break; 
5834   				case 2: 
5835   					stringAux = stringAux+findValueInObject(arrayDiasDaSemana,value[0])+" e "+findValueInObject(arrayDiasDaSemana,value[value.length-1])+": "; 
5836   					diaOferta.dias = stringAux.charAt(0).toUpperCase() + stringAux.slice(1).toLowerCase(); // somente a primeira maiúscula 
5837   					diaOferta.horario = key; 
5838   				break; 
5839   				default: 
5840          				stringAux = stringAux+findValueInObject(arrayDiasDaSemana,value[0])+" a "+findValueInObject(arrayDiasDaSemana,value[value.length-1])+": "; 
5841   					 
5842   					diaOferta.dias =  stringAux.charAt(0).toUpperCase() + stringAux.slice(1).toLowerCase(); // somente a primeira maiúscula 
5843   					diaOferta.horario = key; 
5844   				break; 
5845   			}	 
5846   		}else{ 
5847   			switch (value.length) { 
5848       			case 2: 
5849   					stringAux = stringAux+findValueInObject(arrayDiasDaSemana,value[0])+" e "+findValueInObject(arrayDiasDaSemana,value[value.length-1])+": "; 
5850   					diaOferta.dias =  stringAux.charAt(0).toUpperCase() + stringAux.slice(1).toLowerCase(); // somente a primeira maiúscula 
5851   					diaOferta.horario = key; 
5852   				break; 
5853   				default: 
5854   					var ct = 0; 
5855   					var stringDias=""; 
5856   					for(let v of value){ 
5857       					ct++; 
5858   						ct==value.length ? stringDias=stringDias.substring(0,stringDias.length - 2)+" e "+findValueInObject(arrayDiasDaSemana,v) : stringDias+=findValueInObject(arrayDiasDaSemana,v)+", "; 
5859
5860          				stringAux = stringAux+stringDias+": "; 
5861   					diaOferta.dias = stringAux.charAt(0).toUpperCase() + stringAux.slice(1).toLowerCase(); // somente a primeira maiúscula 
5862   					diaOferta.horario = key; 
5863   				break; 
5864
5865
5866 
5867   		listRetorno.push(diaOferta); 
5868   	}) 
5869   	return listRetorno; 
5870   }; 
5871 
5872 
5873   //Distribui dia e horario com quebra de linha entre eles ou nao dependendo da resolução de tela e tamanho da string 
5874   function ajustaTextoDiasHorarioOferta(codOferta){ 
5875 
5876	   var classOferta = ".codigoOferta_"+codOferta;  
5877	   let oferta = $(classOferta); 
5878 
5879	   let ofertaDiasSemana = $(oferta).find('*[data-dia-hora="dias-semana"]'); 
5880 
5881	   let widthDevice = window.screen.width; 
5882	   let tamLimDesktop = 185; 
5883	 
5884	   if(widthDevice <= 1024){ 
5885	       tamLimDesktop = 180; 
5886
5887	  
5888	   ofertaDiasSemana.each(function(index){ 
5889 
5890		   		   	 
5891	       let widthDiaSemana = $(this).width(); 
5892	 
5893	       let contentDiaHora = $(this).parent().parent().parent(); 
5894	   	 
5895	       if(!(widthDiaSemana <= tamLimDesktop)){ 
5896			   $(this).css("display","block"); 
5897
5898	 
5899		   if(ofertaDiasSemana.length == parseInt(index+1)){ 
5900		       contentDiaHora.css("opacity","1"); 
5901
5902 
5903   		})  
5904
5905 
5906   function getObjBtnComprar(oferta){ 
5907      let obj = {}; 
5908      obj['dataEspacoEx'] = (oferta.espacoExterno == 'true' || (isHibrido && temTextoParaFormatoHibrido)) ? 'true' : 'false'; 
5909      if($('#manutencao-compra').val()){ 
5910        obj['classeBotao'] = 'disabled manutencao'; 
5911        obj['textoBotao'] = $('#manutencao-compra').val(); 
5912      }  
5913      else{ 
5914        obj['classeBotao'] = oferta.botaoCompraOferta == 'true' ? (oferta.vagasParaCompraOferta == 'true' ? '' : 'disabled') : 'd-none-btn'; 
5915        obj['textoBotao'] = oferta.vagasParaCompraOferta == 'true' ? 'COMPRAR' : 'Vagas esgotadas para compra'; 
5916
5917      return obj; 
5918
5919    
5920     function getObjFormaPagto(oferta,index,tipoCurso,codigoUnidade){ 
5921        
5922       var formaPagtoObj = {}; 
5923	    
5924	     var regNumMaxParce = new RegExp('\{numeroMaxParcelasOferta\}', 'g'); 
5925         var regPrecMaxParce = new RegExp('\{precoVendaMaxParcelaOferta\}', 'g') 
5926 
5927       formaPagtoObj['regIndex']  = index; 
5928       formaPagtoObj['precoCheioOferta'] = formataValor(oferta.precoCheioOferta); 
5929       formaPagtoObj['textoCartoesAceitos'] = oferta.textoCartoesAceitos; 
5930 
5931       formaPagtoObj['numParcelaCartoes'] = oferta.numParcelaCartoes; 
5932       formaPagtoObj['precoParcelaCartoes'] = oferta.precoParcelaCartoes; 
5933       formaPagtoObj['numParcelaBoleto'] = oferta.numParcelaBoleto; 
5934       formaPagtoObj['precoParcelaBoleto'] = oferta.precoParcelaBoleto; 
5935       formaPagtoObj['precoVendaOferta'] = formataValor(oferta.precoVendaOferta); 
5936        
5937       formaPagtoObj['economia'] = formataValor(parseFloat(oferta.precoCheioOferta).toFixed(2) - parseFloat(oferta.precoVendaOferta).toFixed(2)); 
5938       formaPagtoObj['espacoExterno'] = oferta.espacoExterno == 'true' ? 'true' : 'false'; 
5939       formaPagtoObj['dataUnidade'] = codigoUnidade; 
5940       formaPagtoObj['dataEvento'] = oferta.codigoOferta; 
5941       formaPagtoObj['destinoCompra '] = oferta.destinoCompra; 
5942        
5943       //EMED nao restringe o botao 
5944       if(isEmed){ 
5945          let manutencao = $('#manutencao-compra').val();  
5946          formaPagtoObj['textoBotaoComprar'] = manutencao || 'COMPRAR'; 
5947           formaPagtoObj['classeBotaoComprar'] = manutencao ? 'disabled manutencao' : ''; 
5948       }else{ 
5949          let btnComprar = getObjBtnComprar(oferta);  
5950          formaPagtoObj['textoBotaoComprar'] = btnComprar.textoBotao; 
5951           formaPagtoObj['classeBotaoComprar'] = btnComprar.classeBotao; 
5952
5953 
5954       formaPagtoObj['regNumMaxParce'] = oferta.numeroMaxParcelasOferta; 
5955       formaPagtoObj['regPrecMaxParce'] = formataValor(oferta.precoVendaMaxParcelaOferta); 
5956        
5957       //valores extensao - como o modal de livre e tec nao tem as classes especificas de extensao, nao há problema criar os valores abaixo para qualquer tipo de curso  
5958       formaPagtoObj['precoAVistaPadraoExt'] = formataValor(oferta.precoVendaOferta); 
5959       var precoContribuinteExtensao = (parseFloat(oferta.precoVendaOferta).toFixed(2) * 0.80).toFixed(2); 
5960       formaPagtoObj['precoContrExt'] = formataValor(precoContribuinteExtensao); 
5961       formaPagtoObj['economiaExt'] = formataValor(parseFloat(oferta.precoVendaOferta).toFixed(2) - precoContribuinteExtensao); 
5962       formaPagtoObj['precoParcelaBoletoExt'] = formataValor( (precoContribuinteExtensao / oferta.numParcelaBoleto).toFixed(2)); 
5963       formaPagtoObj['precoParcelaCartoesExt'] = formataValor( (precoContribuinteExtensao / oferta.numParcelaCartoes).toFixed(2)); 
5964       formaPagtoObj['precoAVistaContrExt'] = formataValor( (precoContribuinteExtensao * 0.92).toFixed(2)); 
5965          
5966       return formaPagtoObj; 
5967
5968      
5969     function calculaPrecoAvista(precoVendaOferta){ 
5970      return (parseFloat(precoVendaOferta).toFixed(2) * 0.92).toFixed(2); 
5971
5972 
5973    function createModalFormaPagto(formaPagtoObj, oferta, index) { 
5974      let temDesconto = possuiCriteriosDesconto2022(oferta.dataInicio) 
5975      temDesconto = temDesconto && !possuiMensalidade99(oferta)       
5976       
5977      result = ` 
5978        <div id="modalFormaPagto" class="ssp-modal"> 
5979          <div class="ssp-card-modal-forma-pagamento ` + (temDesconto ? 'ssp-desconto-2022' : '') + `"> 
5980            <div class="ssp-card-modal-forma-pagamento__header" style="border: 0; margin-bottom: 0 !important;"> 
5981              <h6 class="ssp-card-modal-forma-pagamento__header-title font-weight-bold" style="color:#454F63">Descontos e ` + (temDesconto ? 'pagamento' : 'parcelamento') + `</h6> 
5982              <i class="ssp-card-modal-forma-pagamento__btn-close ssp-card-modal-forma-pagamento__btn-close_` + index + `"></i> 
5983            </div> 
5984
5985        + (temDesconto ? '' : '<div class="ssp-card-oferta-curso__line-divider mt-0 mb-5 mb-md-8"></div>') + 
5986
5987            <div class="ssp-card-modal-forma-pagamento__body">               
5988      `       
5989      if(temDesconto) { 
5990        result = result + ` 
5991             <div> 
5992                <p class="my-0"><strong>Valor com </strong> 
5993                  <span class="ssp-card-oferta-curso__valor-desconto mt-0 mb-0">50% de desconto*</span>                   
5994                </p> 
5995              </div> 
5996              <h6 class="ssp-card-oferta-curso__item-valor-investimento"><span>` + oferta.numeroMaxParcelasOferta + `x</span>R$ ` + formataValor(ajustarCasasDecimaisSemArredondar((strToFloat(oferta.precoVendaOferta)/strToFloat(oferta.numeroMaxParcelasOferta))/2, 2)) + `*</h6>` 
5997               
5998        if($('[name="tipoCurso"]').val() == 'extensao') { 
5999          result = result + `<p class="modal-extensao_txteconomiza my-0">*Desconto válido para quem tem ou trabalha em empresa do setor de comércio e serviços, estudantes ou ex-estudantes de cursos técnicos no Senac ou para quem já finalizou o Ensino Médio Técnico no Senac.</p>` 
6000        } else { 
6001          result = result + `<p class="modal-extensao_txteconomiza my-0">*Desconto válido para quem tem ou trabalha em empresa do setor de comércio e serviços.</p>` 
6002
6003               
6004         
6005        result = result + ` 
6006              <div class="ssp-card-oferta-curso__line-divider mb-5 mb-md-2 mt-2"></div> 
6007              <p class="my-0"><strong>Valor:</strong></p> 
6008              <h6 class="ssp-card-oferta-curso__item-valor-investimento ` + (temDesconto ? 'ssp-desconto-2022' : '') + `"><span>` + oferta.numeroMaxParcelasOferta + `x</span>R$ ` + formataValor(oferta.precoVendaMaxParcelaOferta) + `</h6> 
6009              <p class="mt-0 mb-0"><strong>Valor Total: </strong> ` + formataValor(ajustarCasasDecimaisSemArredondar(strToFloat(oferta.precoVendaOferta), 2)) + `</p> 
6010              <div class="ssp-card-oferta-curso__line-divider mt-4 mb-md-3 mb-4"></div> 
6011              <p class="my-0"><strong>Parcele e garanta mais tempo para pagar:</strong></p> 
6012
6013      } else { 
6014        if(formaPagtoObj.precoCheioOferta == formaPagtoObj.precoVendaOferta) { 
6015          result = result + ` 
6016              <p class="ssp-card-modal-forma-pagamento__valor-desconto mt-n3">R$ <span class="precoVendaOferta">` + formaPagtoObj.precoVendaOferta + `</span></p> 
6017              <p class="txt-desconto-oito">Pague à vista e <span style="color:#FC7834;font-weight:bold"> ganhe mais 8% de desconto.</span></p> 
6018              <small class="ssp-card-oferta-curso__title-item font-weight-bold" style="margin:0;font-size:16px">Se preferir, parcele e garanta muito mais tempo para pagar:</small> 
6019            </div> 
6020
6021        } else { 
6022          const textoDesc = temDesconto ? 'Valor com 30% de desconto:' : 'Valor com desconto:' 
6023           
6024          result = result + ` 
6025              <small class="ssp-card-oferta-curso__title-item font-weight-bold" style="margin:0;font-size:16px;">` + textoDesc + `</small> 
6026              <p class="ssp-card-modal-forma-pagamento__valor-cheio">R$ <span class="precoCheioOferta">` + formaPagtoObj.precoCheioOferta + `</span></p> 
6027              <p class="ssp-card-modal-forma-pagamento__valor-desconto">R$ <span class="precoVendaOferta">` + formaPagtoObj.precoVendaOferta + `</span></p> 
6028              <p class="ssp-card-modal-forma-pagamento__total-economia">Você economiza <span>R$ <span class="economia">` + formaPagtoObj.economia + `</span></span></p> 
6029              <p class="txt-desconto-oito">Pague à vista e <span style="color:#FC7834;font-weight:bold"> ganhe mais 8% de desconto.</span></p> 
6030              <small class="ssp-card-oferta-curso__title-item font-weight-bold" style="margin:0;font-size:16px">Se preferir, parcele e garanta muito mais tempo para pagar:</small> 
6031            </div> 
6032
6033
6034
6035 
6036      let textoParcelaCartoes, textoParcelaBoleto       
6037      if(temDesconto) { 
6038        const precoParcelaCartoes = formataValor(ajustarCasasDecimaisSemArredondar(strToFloat(formaPagtoObj.precoParcelaCartoes)/2, 2)) 
6039        const precoParcelaBoleto = formataValor(ajustarCasasDecimaisSemArredondar(strToFloat(formaPagtoObj.precoParcelaBoleto)/2, 2)) 
6040 
6041        if(formaPagtoObj.numParcelaCartoes) 
6042          textoParcelaCartoes = `<p>Em até <span><span class="numParcelaCartoes">` + formaPagtoObj.numParcelaCartoes + `</span>x</span> sem juros</p>` 
6043 
6044        if(formaPagtoObj.numParcelaBoleto) 
6045          textoParcelaBoleto = `<p>Em até <span><span class="numParcelaBoleto">` + formaPagtoObj.numParcelaBoleto + `</span>x</span> sem juros</p>` 
6046      } else { 
6047        if(formaPagtoObj.numParcelaCartoes) 
6048          textoParcelaCartoes = `<p>Em até <span><span class="numParcelaCartoes">` + formaPagtoObj.numParcelaCartoes + `</span>x de R$ <span class="precoParcelaCartoes">` + formaPagtoObj.precoParcelaCartoes + `</span></span> sem juros</p>` 
6049         
6050        if(formaPagtoObj.numParcelaBoleto) 
6051          textoParcelaBoleto = `<p>Em até <span><span class="numParcelaBoleto">` + formaPagtoObj.numParcelaBoleto + `</span>x de R$ <span class="precoParcelaBoleto">` + formaPagtoObj.precoParcelaBoleto + `</span></span> sem juros</p>` 
6052
6053 
6054      if(temDesconto) {  
6055        result = result + ` 
6056              <div class="ssp-card-modal-forma-pagamento__tipos">` 
6057 
6058        if(textoParcelaBoleto) 
6059          result = result + ` 
6060                <div class="ssp-card-modal-forma-pagamento__tipos-content align-items-start"> 
6061                  <i class="ssp-card-modal-forma-pagamento__icon-boleto"></i> 
6062                  <div class="ssp-card-modal-forma-pagamento__info-cartao"> 
6063                      <p><strong>Boleto Bancário</strong></p>` 
6064                      + textoParcelaBoleto +    
6065                  `</div> 
6066                </div>` 
6067 
6068        if(textoParcelaCartoes) 
6069          result = result + ` 
6070                <div class="ssp-card-modal-forma-pagamento__tipos-content align-items-start mt-4"> 
6071                  <i class="ssp-card-modal-forma-pagamento__icon-credit-card"></i> 
6072                  <div class="ssp-card-modal-forma-pagamento__info-cartao"> 
6073                      <p><strong>Cartões</strong></p> 
6074                      <p>(<span class="textoCartoesAceitos">` + formaPagtoObj.textoCartoesAceitos + `</span>)</p>` 
6075                      + textoParcelaCartoes +    
6076                  `</div> 
6077                </div> 
6078              </div> 
6079
6080      } else { 
6081        result = result + ` 
6082              <div class="ssp-card-modal-forma-pagamento__tipos">` 
6083 
6084        if(textoParcelaCartoes) 
6085          result = result + ` 
6086                <div class="ssp-card-modal-forma-pagamento__tipos-content align-items-start"> 
6087                  <i class="ssp-card-modal-forma-pagamento__icon-credit-card"></i> 
6088                  <div class="ssp-card-modal-forma-pagamento__info-cartao"> 
6089                      <p><strong>Cartões</strong></p> 
6090                      <p>(<span class="textoCartoesAceitos">` + formaPagtoObj.textoCartoesAceitos + `</span>)</p>` 
6091                      + textoParcelaCartoes +    
6092                  `</div> 
6093                </div>` 
6094 
6095        if(textoParcelaBoleto) 
6096          result = result + ` 
6097                <div class="ssp-card-modal-forma-pagamento__tipos-content align-items-start mt-4"> 
6098                  <i class="ssp-card-modal-forma-pagamento__icon-boleto"></i> 
6099                  <div class="ssp-card-modal-forma-pagamento__info-cartao"> 
6100                      <p><strong>Boleto Bancário</strong></p>` 
6101                      + textoParcelaBoleto +    
6102                  `</div> 
6103                </div> 
6104              </div> 
6105
6106
6107 
6108      if(temDesconto) {  
6109        result = result + ` 
6110            <p class="txt-desconto-oito my-0">Pague à vista e ganhe <span style="color:#5ACC75;font-weight:bold">8% de desconto.</span></p> 
6111
6112
6113 
6114      result = result + ` 
6115            <a href="#a" class="btn btn-lg btn-success w-100" style="margin-top: 20px;font-weight:600"><span class="textoBotaoComprar">` + formaPagtoObj.textoBotaoComprar + `</span></a>` 
6116     
6117      if(temDesconto) {  
6118        result = result + ` 
6119            <a class="btn btn-primary modal-extensao-btn-conheca mt-3" href="/descontos-e-parcelamentos" target="_blank">Conheça os descontos</a> 
6120
6121
6122           
6123      result = result + ` 
6124         </div> 
6125        </div> 
6126
6127 
6128      return result; 
6129
6130      
6131     function montaHTMLModalFormaPgto(oferta, index, codigoUnidade){ 
6132        
6133       var tipoCurso = $('[name="tipoCurso"]').val(); 
6134        
6135       var formaPagtoObj = getObjFormaPagto(oferta,index,tipoCurso,codigoUnidade); 
6136        
6137       var modalFormaPagto 
6138       if(tipoCurso == 'extensao' && !possuiCriteriosDesconto2022(oferta.dataInicio)) { 
6139          modalFormaPagto = $('#modalFormaPagtoExt').clone(); 
6140 
6141          $.each(formaPagtoObj, function(k,v){ 
6142            if(modalFormaPagto.find('.'+k).length > 0) 
6143              modalFormaPagto.find('.'+k).text(v); 
6144          }) 
6145        } else if(isEmed) { 
6146          modalFormaPagto = $('#modalPagtoEmed').clone(); 
6147 
6148          $.each(formaPagtoObj, function(k,v){ 
6149            if(modalFormaPagto.find('.'+k).length > 0) 
6150              modalFormaPagto.find('.'+k).text(v); 
6151          }) 
6152        } else 
6153           modalFormaPagto = $(createModalFormaPagto(formaPagtoObj, oferta, index)); 
6154          
6155       modalFormaPagto.removeAttr('id'); 
6156       modalFormaPagto.removeClass('d-none'); 
6157       modalFormaPagto.attr('id','myModal_'+index); 
6158        
6159       if(tipoCurso == 'extensao' && !possuiCriteriosDesconto2022(oferta.dataInicio)){ 
6160          
6161         var botoaoCompraOk = modalFormaPagto.find('.modal-extensao-aluno__btn.ok'); 
6162         botoaoCompraOk.attr('id','btnComprarConhecaDescontoOk_'+index); 
6163          
6164         botoaoCompraOk.attr('data-espaco-ex', formaPagtoObj.espacoExterno); 
6165         botoaoCompraOk.attr('data-unidade', formaPagtoObj.dataUnidade); 
6166         botoaoCompraOk.attr('data-evento', formaPagtoObj.dataEvento); 
6167         botoaoCompraOk.attr('data-destino-compra', formaPagtoObj.destinoCompra); 
6168         botoaoCompraOk.attr('data-index', index); 
6169         botoaoCompraOk.addClass(formaPagtoObj.classeBotaoComprar); 
6170          
6171         var botoaoCompraNot =modalFormaPagto.find('.modal-extensao-aluno__btn.not'); 
6172         botoaoCompraNot.attr('id','btnComprarConhecaDescontoNot_'+index); 
6173          
6174         botoaoCompraNot.attr('data-espaco-ex', formaPagtoObj.espacoExterno); 
6175         botoaoCompraNot.attr('data-unidade', formaPagtoObj.dataUnidade); 
6176         botoaoCompraNot.attr('data-evento', formaPagtoObj.dataEvento); 
6177         botoaoCompraNot.attr('data-destino-compra', formaPagtoObj.destinoCompra); 
6178         botoaoCompraNot.attr('data-index', index); 
6179         botoaoCompraNot.addClass(formaPagtoObj.classeBotaoComprar); 
6180          
6181         modalFormaPagto.find('.modal-extensao-btn-aluno-sim-nao.sim').attr('id','btn-aluno-sim_'+index); 
6182         modalFormaPagto.find('.modal-extensao-btn-aluno-sim-nao.nao').attr('id','btn-aluno-nao_'+index); 
6183          
6184         modalFormaPagto.find('.modal-extensao-voltar-icon').addClass('ssp-card-modal-forma-pagamento__btn-close_'+index); 
6185          
6186         modalFormaPagto.find('.modal-extensao-btn-conheca').attr('id','btnModalExtConheca_'+index); 
6187          
6188         modalFormaPagto.find('.modal-pergunta-aluno-ext').attr('id','modalExtAluno_'+index); 
6189          
6190         modalFormaPagto.find('.msg-alunoSim').attr('id','msg-alunoSim_'+index); 
6191         modalFormaPagto.find('.msg-alunoNao').attr('id','msg-alunoNao_'+index); 
6192          
6193         var botaoCompra = modalFormaPagto.find('.modal-extensao__btn.mt-3');  
6194      
6195       }else{ 
6196   
6197         modalFormaPagto.find('.mt-4').attr('id','content_boleto_'+index); 
6198         modalFormaPagto.find('.ssp-card-modal-forma-pagamento__btn-close').addClass('ssp-card-modal-forma-pagamento__btn-close_'+index); 
6199          
6200         var botaoCompra = modalFormaPagto.find('.btn.w-100'); 
6201   
6202
6203        
6204       if(isEmed){ 
6205          
6206    	   	var elementoPai = modalFormaPagto.find('.ssp-card-modal-forma-pagamento'); 
6207	    		  
6208          //Cria botao inscreva-se ajustado ao modal 
6209          var dadosAbertura = calculaTempoAberturaBolsa(oferta.dataAberturaBolsaOferta, oferta.horaAberturaBolsaOferta); 
6210          if($('#manutencao-compra').val()){ 
6211            textoBotao = $('#manutencao-compra').val(); 
6212            classeBotao = 'disabled manutencao'; 
6213          }else{ 
6214            if(oferta.permiteListaEspera == statusEmed.ESPERA && dadosAbertura.bolsaJaAberta){ 
6215              textoBotao = 'Lista de espera'; 
6216              classeBotao = 'btn-emed-lista-espera'; 
6217            }else{ 
6218                if (dadosAbertura.bolsaJaAberta || !oferta.dataAberturaBolsaOferta || oferta.dataAberturaBolsaOferta == ''){ 
6219                  if(oferta.etapa == '0020' || oferta.etapa == '0030'){ 
6220                    textoBotao = 'Lista de espera'; 
6221                    classeBotao = 'btn-emed-lista-espera'; 
6222                  }else{ 
6223                    textoBotao = 'Fazer matrícula'; 
6224                    classeBotao = ''; 
6225
6226                }else{ 
6227                  textoBotao = 'Matrícula em '+formataDataAberturaBolsa(oferta.dataAberturaBolsaOferta, oferta.horaAberturaBolsaOferta); 
6228                  classeBotao = 'disabled'; 
6229
6230
6231
6232          criaBotaoInscreverEmedModal(oferta, textoBotao, classeBotao, 'btnComprarEmedModal_' + index, elementoPai, index); 
6233          preencheDadosEmedModal(oferta, modalFormaPagto); 
6234          
6235       }else{ 
6236	       botaoCompra.attr('id', "btnComprarFormaPgto_"+index); 
6237	       botaoCompra.attr('data-espaco-ex', formaPagtoObj.espacoExterno); 
6238	       botaoCompra.attr('data-unidade', formaPagtoObj.dataUnidade); 
6239	       botaoCompra.attr('data-evento', formaPagtoObj.dataEvento); 
6240	       botaoCompra.attr('data-destino-compra', formaPagtoObj.destinoCompra); 
6241	       botaoCompra.attr('data-index', index); 
6242		   botaoCompra.addClass(formaPagtoObj.classeBotaoComprar); 
6243
6244        
6245       $('.oferta-slick-area_modal').append(modalFormaPagto); 
6246       $('.oferta-slick-area_modal').find('.d-none-btn').remove(); 
6247        
6248       //Evita o erro de exibição de Nan 
6249       if(oferta.numParcelaBoleto.length == 0){ 
6250    	   $('#content_boleto_'+index).remove(); 
6251
6252
6253 
6254    
6255   function montaHTMLModalLocalRealizacao(oferta, index){ 
6256      
6257     var tituloLocalRealizacao = (localLivreOnline(oferta.localEspacoExterno) && !isHibrido) ? 
6258          '<i class="fas fa-wifi icon-wifi-title__modal"></i> <h6 class="title-idioma-online__modal"> Aulas Online - ao vivo</h6>' 
6259           : '<i class="ssp-modal__local-realizacao-content__icon-wifi"></i> <i class="ssp-modal__local-realizacao-content__icon-chalkboard-teacher"></i> <h6 class="ssp-modal-local-realizacao__title"> ONDE AS AULAS VÃO ACONTECER?</h6>'; 
6260      
6261     if(textoFormatoHibrido.length>0 && oferta.espacoExterno=="true") 
6262             textoFormatoHibrido += '</br>'; 
6263                        
6264     var localRealizacaoHTMLModal = htmlModalLocalRealizacao 
6265         .replace('\{nomeUnidade\}',$('#unidades-ofertas option:selected').text()) 
6266         .replace('\{textoFormatoHibrido\}', textoFormatoHibrido ) 
6267         .replace('\{localEspacoExterno\}',  oferta.espacoExterno=="true"? oferta.localEspacoExterno: "" ) 
6268         .replace('\{classeTextoInfoLocalRealizacao\}', (oferta.ruaEspacoExterno != "" && !isHibrido) ? "" : "d-none") 
6269         .replace('\{classeEnderecoRealizacao\}',oferta.ruaEspacoExterno != "" ? "" : "d-none") 
6270         .replace('\{ruaEspacoExterno\}',oferta.ruaEspacoExterno) 
6271         .replace('\{numeroEspacoExterno\}',oferta.numeroEspacoExterno) 
6272         .replace('\{complementoEspacoExterno\}',oferta.complementoEspacoExterno) 
6273         .replace('\{classeBairroRealizacao\}', oferta.bairroEspacoExterno != "" && oferta.ruaEspacoExterno != "" ? "" : "d-none") 
6274         .replace('\{bairroEspacoExterno\}',oferta.bairroEspacoExterno) 
6275         .replace('\{classeCidadeRealizacao\}', oferta.cidadeEspacoExterno != "" && oferta.ruaEspacoExterno != "" ? "" : "d-none") 
6276         .replace('\{cidadeEspacoExterno\}',oferta.cidadeEspacoExterno) 
6277         .replace('\{classeCepRealizacao\}', oferta.cepEspacoExterno != "" && oferta.ruaEspacoExterno != "" ? "" : "d-none") 
6278         .replace('\{cepEspacoExterno\}',oferta.cepEspacoExterno) 
6279        .replace(regIndex, index) 
6280        .replace('\{tituloLocalRealizacao\}', tituloLocalRealizacao) 
6281        .replace('\{classeEntendi\}', (localLivreOnline(oferta.localEspacoExterno)) ? "btn-modal-entendi__idioma-online" : ""); 
6282 
6283        $('.oferta-slick-area_modal').append(localRealizacaoHTMLModal); 
6284        $('.oferta-slick-area_modal').find('.d-none-btn').remove(); 
6285 
6286        if(oferta.ruaEspacoExterno == "") 
6287           $('.localEspacoExternoTexto_'+index).removeClass('ssp-modal-local-realizacao__subtitle'); 
6288
6289    
6290   function  montaHTMLModalAntesCompra(oferta, index, codigoUnidade){ 
6291 
6292    if(isEmed){ 
6293              
6294      $('#modalAntesCompraEmed_' + oferta.indice).remove(); 
6295      const antesCompraHTMLModal = $('#modalAntesCompraEmed').clone(); 
6296      antesCompraHTMLModal.attr('id', 'modalAntesCompraEmed_' + oferta.indice); 
6297      antesCompraHTMLModal.find('.ssp-card-modal-antes-compra__btn-close').addClass('ssp-card-modal-antes-compra__btn-close_'+oferta.indice); 
6298      antesCompraHTMLModal.find('.ssp-card-modal-selecionar-outro__btn-close').addClass('ssp-card-modal-selecionar-outro__btn-close_'+oferta.indice); 
6299      antesCompraHTMLModal.insertAfter('#modalAntesCompraEmed'); 
6300       
6301      if(oferta.etapa == '0010'){ 
6302        if(oferta.permiteListaEspera == statusEmed.ESPERA){ 
6303          antesCompraHTMLModal.find('.textoEmedModalAntesCompra0010Espera').removeClass('d-none'); 
6304          antesCompraHTMLModal.find('#btnCompraLocalEmed').text('Ir para lista de espera'); 
6305        }else{ 
6306          antesCompraHTMLModal.find('.textoEmedModalAntesCompra0010').removeClass('d-none'); 
6307
6308      }else{ 
6309    	  antesCompraHTMLModal.find('.textoEmedModalAntesCompra0020e0030').removeClass('d-none'); 
6310
6311 
6312      const btnCompra = antesCompraHTMLModal.find('#btnCompraLocalEmed'); 
6313      btnCompra.attr('id', 'btnCompraLocalEmed_' + oferta.indice); 
6314      btnCompra.attr('offercode', oferta.codigoOferta); 
6315 
6316      btnCompra.on('click', function(ev){ 
6317        ev.preventDefault(); 
6318        execCompraEmed(oferta); 
6319      }); 
6320 
6321    }else{ 
6322    	 
6323   	 var dataEfetivaFormat = formataDataComBarra($('[name="dataEfetivaSTR"]').val()); 
6324 
6325   	 
6326     var antesCompraHTMLModal = htmlModalAntesCompra 
6327         .replace('\{nomeUnidade\}',$('#unidades-ofertas option:selected').text()) 
6328         .replace('\{textoFormatoHibrido\}', textoFormatoHibrido ) 
6329         .replace('\{localEspacoExterno\}', oferta.espacoExterno=="true"? oferta.localEspacoExterno:"" ) 
6330         .replace('\{classeTextoInfoLocalRealizacao\}', (oferta.ruaEspacoExterno != "" && !isHibrido) ? "" : "d-none") 
6331         .replace('\{classeEnderecoRealizacao\}', oferta.ruaEspacoExterno != ""  ? "" : "d-none") 
6332         .replace('\{ruaEspacoExterno\}',oferta.ruaEspacoExterno) 
6333         .replace('\{numeroEspacoExterno\}',oferta.numeroEspacoExterno) 
6334         .replace('\{complementoEspacoExterno\}',oferta.complementoEspacoExterno) 
6335         .replace('\{classeBairroRealizacao\}', oferta.bairroEspacoExterno != "" && oferta.ruaEspacoExterno != "" ? "" : "d-none") 
6336         .replace('\{bairroEspacoExterno\}',oferta.bairroEspacoExterno) 
6337         .replace('\{classeCidadeRealizacao\}', oferta.cidadeEspacoExterno != "" && oferta.ruaEspacoExterno != "" ? "" : "d-none") 
6338         .replace('\{cidadeEspacoExterno\}',oferta.cidadeEspacoExterno) 
6339         .replace('\{classeCepRealizacao\}', oferta.cepEspacoExterno != "" && oferta.ruaEspacoExterno != "" ? "" : "d-none") 
6340         .replace('\{cepEspacoExterno\}',oferta.cepEspacoExterno) 
6341         .replace('\{componentBuyConfirmation\}', componentBuyConfirmation(codigoUnidade, oferta, dataEfetivaFormat)) 
6342         .replace('\{linkBtnBolsa\}', linkBolsa(oferta)) 
6343        .replace(regIndex, index);   
6344 
6345        $('.oferta-slick-area_modal').append(antesCompraHTMLModal); 
6346        $('.oferta-slick-area_modal').find('.d-none-btn').remove(); 
6347
6348
6349    
6350   async function populaOfertas(ofertas){ 
6351     
6352     //Zera variável que controla existência de ofertas com bolsa 
6353    ofertasComBolsa = false; 
6354 
6355    objsTela.ofertas = ofertas; 
6356 
6357    if(ofertas && ofertas.length)  
6358      $('#ssp-h3-turmas').show() 
6359    else  
6360      $('#ssp-h3-turmas').hide() 
6361        
6362     if(isEmed){ 
6363 
6364      $('.btn-filtro[value="0"]').attr('disabled',''); 
6365      $('.ssp-slick-ofertas-emed').empty(); 
6366      // executa a class do slick slider 
6367      $('.ssp-slick-ofertas-emed').removeClass('slick-initialized slick-slider slick-dotted'); 
6368      ofertas = filtraOfertasEtapa(getEtapaSelecionadaEmed(), ofertas); 
6369       
6370
6371 
6372     if(ofertas.length == 0){ 
6373        
6374      if($('#unidades-ofertas').val() || $('#chkInscricao').prop('checked') || $('#chkBolsa').prop('checked')) 
6375        hideCardSemTurmas(false) 
6376        
6377       $('.oferta-slick-area').empty(); 
6378       $('.prev-mobile, .next-mobile').addClass('d-none'); 
6379        
6380       //Mostrar section registro interesse quando nao tiver oferta 
6381       habilitarRegistroInteresse(true); 
6382 
6383        controlaPaginaBolsa() 
6384        if(isEmed) $('.btn-filtro[value="0"]').removeAttr('disabled'); 
6385       return; 
6386     }else{ 
6387           hideCardSemTurmas(true) 
6388          if(!isEmed) $('.prev-mobile, .next-mobile').removeClass('d-none'); 
6389          habilitarRegistroInteresse(false); 
6390
6391     
6392     
6393     $('.oferta-slick-area').empty(); 
6394     $('.oferta-slick-area_modal').empty(); 
6395     ofertas = ofertas.sort(function(a, b){ 
6396       return ordenar(a, b, 'ordenar'); 
6397     }); 
6398     // executa a class do slick slider 
6399     $('.oferta-slick-area').removeClass('slick-initialized slick-slider slick-dotted'); 
6400      
6401     //busca o codigoUnidade para o link do ecommerce 
6402     if(!isAoVivo){ 
6403      var selectedUnidade = $('#unidades-ofertas').val().split('@')[0]; 
6404      for(var i=0;objsTela.unidades.length > i ;i++){ 
6405        if(selectedUnidade == objsTela.unidades[i].categoryId) 
6406          codigoUnidade = objsTela.unidades[i].codigoUnidade; 
6407
6408
6409      
6410    // Montar object push - google tag manager - 2 
6411    itensEcommerce = criaItensEcommerce(ofertas); 
6412    sendEventEcommerce("view_item_list", Array.from(itensEcommerce.values())); 
6413 
6414     for(var i=0;ofertas.length > i ;i++){ 
6415   
6416       var oferta = ofertas[i]; 
6417        
6418       //guardando a oferta no map para chamar ajax com infos de bolsa em tempo real 
6419       oferta['indice'] = i; 
6420       ofertasMap.set(oferta.codigoOferta, oferta); 
6421        
6422       if(isAoVivo) 
6423          codigoUnidade = ofertaUnidadeMap.get(oferta.codigoOferta); 
6424 
6425      if(isEmed && oferta.etapa == '0010'){ 
6426          try{ 
6427            let status = await getStatusEmed(oferta); 
6428            oferta['permiteListaEspera'] = status; 
6429          }catch(err){ 
6430            console.log(err); 
6431
6432
6433       montaHTMLOferta(oferta, i, codigoUnidade, false);  
6434       montaHTMLModalFormaPgto(oferta, i, codigoUnidade);  
6435       montaHTMLModalLocalRealizacao(oferta, i);  
6436       montaHTMLModalAntesCompra(oferta, i, codigoUnidade); 
6437       verificaBotaoBolsaSS(oferta); 
6438       verificaCursoAprendizagem(i); 
6439       verificaCursoTrampolim(i, oferta.codigoOferta); 
6440        
6441       associaEventoBtnFormaPagamento(i); 
6442       associaEventoBtnComprar(i);  
6443       associaEventoBtnComprarDentroFormaPgto(i); 
6444       associaEventoBtnLocalRealizacao(i); 
6445       associaEventosFecharModal(i); 
6446       
6447         if($('[name="tipoCurso"]').val() == 'extensao'){ 
6448             associaEventoBtnConheca(i);	 
6449             associaEventoBtnComprarConhecaDescontoOk(i); 
6450             associaEventoBtnComprarConhecaDescontoNot(i); 
6451             associaEventoBtnAlunoNao(i); 
6452             associaEventoBtnAlunoSim(i); 
6453
6454         
6455
6456   
6457     if(isEmed){ 
6458      sliderOfertasEmed(); 
6459      $('.btn-filtro[value="0"]').removeAttr('disabled'); 
6460
6461     else sliderOfertas(); 
6462 
6463     controlaPaginaBolsa() 
6464      
6465
6466 
6467   function hideCardSemTurmas(hide){ 
6468    if(!isEmed){ 
6469      if(hide) 
6470        $('.ssp-card-oferta-curso__sem-vaga').addClass('d-none'); 
6471      else 
6472        $('.ssp-card-oferta-curso__sem-vaga').removeClass('d-none'); 
6473    } else { 
6474      
6475 
6476      if(hide || getEtapaSelecionadaEmed() == "0"){ 
6477        $('.sem-vaga-emed').addClass('d-none'); 
6478      }else{ 
6479        $('.sem-vaga-emed').removeClass('d-none'); 
6480        if($('.sem-vaga-emed.emed-transferencias-space:not(.d-none)').length ) return; 
6481        var tamScreen = $(window).width(); 
6482        if(tamScreen < 768){ 
6483            $('.slick-area-emed').slick({ 
6484            slidesToShow: 2, 
6485            slidesToScroll: 2, 
6486            autoplay: false, 
6487            infinite: false, 
6488            dots: false, 
6489            arrows: false, 
6490            centerPadding: 0, 
6491                        centerMode: false, 
6492            responsive: [ 
6493
6494                    breakpoint: 768, 
6495                    settings: { 
6496                        slidesToShow: 1, 
6497                        slidesToScroll: 1, 
6498                        variableWidth: false, 
6499                        infinite: false, 
6500                        centerPadding: 0, 
6501                        centerMode: false, 
6502                        dots: true, 
6503
6504
6505
6506        }); 
6507
6508
6509
6510
6511    
6512   function verificaCursoAprendizagem(i){ 
6513 
6514      //Esconde elementsos quando o curso é aprendizagem 
6515      if($('[name="codigoFT"]').val() == codigoFTCursoAprendizagem){ 
6516         $('#btnComprar_'+i).remove(); 
6517         $('#container_investimento_'+i).remove(); 
6518         $('#container_forma_pgto_'+i).remove(); 
6519          
6520         var avisoAprendizagem = $('#aviso-curso-aprendizagem').clone(); 
6521         let btnFormAprendizagem = '<button class="btn btn-lg btn-success w-100 mt-3 btnModalAprendizagem" data-modal="open-modal" style="font-size:16px;background:#1FC923;font-weight: 600;">Preencher formulário</button>' 
6522         avisoAprendizagem.removeAttr('id'); 
6523         avisoAprendizagem.removeClass('d-none'); 
6524         $('.card_oferta_'+i+ ' .ssp-card-oferta-curso').append(avisoAprendizagem); 
6525         $('.card_oferta_'+i+ ' .ssp-card-oferta-curso').append(btnFormAprendizagem); 
6526
6527
6528    
6529   function verificaCursoTrampolim(i, codOferta){ 
6530     if(ehCursoTrampolim){ 
6531          $('#btnComprar_'+i).remove(); 
6532          $('#container_investimento_'+i).remove(); 
6533          $('#container_forma_pgto_'+i).remove(); 
6534          $('.ssp-card-oferta-curso .codigoOferta_'+codOferta).hide(); 
6535           
6536          var avisoTrampolim = $('#avisoTrampolim').clone(); 
6537          avisoTrampolim.removeAttr('id'); 
6538          avisoTrampolim.removeClass('d-none'); 
6539          $('.card_oferta_'+i+ ' .ssp-card-oferta-curso').append(avisoTrampolim); 
6540
6541
6542    
6543   function verificaBotoesEmed(dadosOferta, verificaBolsa){	            
6544          
6545       if(!verificaBolsa || !dadosOferta.dataAberturaBolsaOferta || dadosOferta.dataAberturaBolsaOferta == ''){ 
6546         dadosOferta.vagasBolsaOferta = false; 
6547         dadosOferta.botaoBolsaOferta = false; 
6548
6549 
6550       var elementoPai = $('.codigoOferta_'+dadosOferta.codigoOferta+' .ssp-ofertas-emed__card-info-investimento'); 
6551                  
6552            //calcula o tempo até abertura da bolsa, se houver (apenas depois das 08hrs) 
6553            var dadosAbertura = calculaTempoAberturaBolsa(dadosOferta.dataAberturaBolsaOferta, dadosOferta.horaAberturaBolsaOferta); 
6554              var textoBotao = 'Fazer matrícula'; 
6555              var textoBotaoBolsa = ''; 
6556              var classeBotao = ''; 
6557              var classeBotaoBolsa = ''; 
6558              var exibirBotaoBolsa = false; 
6559              var exibirContador = false; 
6560              var htmlBotaoBolsa = ''; 
6561              var htmlBotao = ''; 
6562                 
6563              //verifica se o botão de concorrer a bolsa deve aparecer 
6564              //Oferta EMED possui bolsa apenas no 1o ano 
6565              if(dadosOferta.etapa == '0010' && dadosOferta.botaoBolsaOferta && !dadosAbertura.exibirContador){ 
6566                exibirBotaoBolsa = true; 
6567                if($('#manutencao-bolsa').val()){ 
6568                  classeBotaoBolsa = 'disabled manutencao'; 
6569                  textoBotaoBolsa = $('#manutencao-bolsa').val(); 
6570                }else{ 
6571                  if(dadosOferta.vagasBolsaOferta){ 
6572                    classeBotaoBolsa = dadosAbertura.bolsaJaAberta ? '' : 'disabled'; 
6573                    textoBotaoBolsa = dadosAbertura.bolsaJaAberta ? 'Bolsa de estudo' : 'Bolsa em '+formataDataAberturaBolsa(dadosOferta.dataAberturaBolsaOferta, dadosOferta.horaAberturaBolsaOferta); 
6574                  }else{ 
6575                    classeBotaoBolsa = 'disabled'; 
6576                    textoBotaoBolsa = 'Bolsas de Estudo Esgotadas'; 
6577
6578
6579
6580                   
6581                  //Verifica se o botão do cronômetro deve aparecer 
6582                  if(dadosAbertura.exibirContador){ 
6583                    textoBotao = dadosAbertura.textoContador; 
6584                    textoBotaoBolsa = dadosAbertura.textoContador; 
6585                    exibirContador = true; 
6586                    exibirBotaoBolsa = false; 
6587                  }else{ 
6588                    if($('#manutencao-compra').val()){ 
6589                      textoBotao = $('#manutencao-compra').val(); 
6590                      classeBotao = 'disabled manutencao'; 
6591                    }else{ 
6592 
6593                      if(dadosOferta.permiteListaEspera == statusEmed.ESPERA && dadosAbertura.bolsaJaAberta){ 
6594                        textoBotao = 'Lista de espera'; 
6595                        classeBotao = 'btn-emed-lista-espera'; 
6596                      }else{ 
6597                        classeBotao = ''; 
6598                        if (dadosAbertura.bolsaJaAberta || !dadosOferta.dataAberturaBolsaOferta || dadosOferta.dataAberturaBolsaOferta == ''){ 
6599                          textoBotao = 'Fazer matrícula'; 
6600                           
6601                          if(dadosOferta.etapa == '0020' || dadosOferta.etapa == '0030'){ 
6602                            textoBotao = 'Lista de espera'; 
6603                            classeBotao = 'btn-emed-lista-espera'; 
6604
6605                           
6606                           
6607                        }else{ 
6608                          textoBotao = 'Matrícula em '+formataDataAberturaBolsa(dadosOferta.dataAberturaBolsaOferta, dadosOferta.horaAberturaBolsaOferta); 
6609
6610                        if(!dadosAbertura.bolsaJaAberta)  
6611                          classeBotao = 'disabled'; 
6612
6613                    }                                 
6614                     
6615                      criaBotaoInscreverEmed(dadosOferta, textoBotao, classeBotao, 'btnComprarEmed_' + dadosOferta.indice, elementoPai); 
6616
6617                 
6618              if(exibirBotaoBolsa){ 
6619                   
6620              if(!ofertasComBolsa) ofertasComBolsa = true; 
6621 
6622                criaBotaoBolsaEmed(dadosOferta, textoBotaoBolsa, classeBotaoBolsa); 
6623                     
6624              }else if(exibirContador){ 
6625 
6626                if(!ofertasComBolsa && dadosOferta.etapa == '0010') ofertasComBolsa = true; 
6627 
6628                //codigoOferta como index para usar o ofertasMap 
6629                htmlBotao = '<button id="btnContadorComprar_'+ dadosOferta.indice +'" data-index="'+ dadosOferta.codigoOferta +'" class="btn btn-card-investimento --inscreva-se">Matrícula em <span>'+textoBotao+'</span></button>'; 
6630                elementoPai.append(htmlBotao); 
6631                 
6632                if(dadosOferta.etapa == '0010' && dadosOferta.botaoBolsaOferta){ 
6633                    htmlBotao = '<button id="btnContadorBolsa_'+ dadosOferta.indice +'" data-index="'+ dadosOferta.codigoOferta +'" class="btn btn-card-investimento --bolsas">Bolsa em <span>'+textoBotaoBolsa+'</span></button>'; 
6634                    elementoPai.append(htmlBotao); 
6635
6636                   
6637
6638 
6639
6640    
6641   function criaBotaoInscreverEmedModal(oferta, textoBotao, classeBotao, idBotao, elementoPai, index){ 
6642     criaBotaoInscreverEmed(oferta, textoBotao, classeBotao, idBotao, elementoPai); 
6643     var btnInscr = elementoPai.find('#btnComprarEmedModal_' + index); 
6644     btnInscr.removeClass(btnInscr.classList); 
6645     btnInscr.addClass('btn btn-lg btn-success w-100'); 
6646     btnInscr.attr('style', 'margin-top: 20px;font-weight:600'); 
6647      
6648     //Reposiciona o botao voltar 
6649     var btnVoltar = elementoPai.find('.ssp-btn-emed__voltar-curso'); 
6650     elementoPai.find('.ssp-btn-emed__voltar-curso').remove(); 
6651     elementoPai.append(btnVoltar); 
6652     btnVoltar.addClass('ssp-btn-emed__voltar-curso_'+index); 
6653     btnVoltar.click(() => { 
6654    	 $('[id^="myModal_"]').each(function(index,modal){ 
6655			modal.style.display = "none"; 
6656		}) 
6657	}); 
6658
6659    
6660   function preencheDadosEmedModal(oferta,$modal){ 
6661	   const parcelaEntrada = 1; 
6662	   $modal.find('.numParcelaCartoesBoleto').text(oferta.numeroMaxParcelasOferta - parcelaEntrada); 
6663	   $modal.find('.precoParcelaCartoesBoleto').text(formataValor(oferta.precoVendaMaxParcelaOferta)); 
6664	   $modal.find('.numParcelaEmedModal').text(oferta.numeroMaxParcelasOferta - parcelaEntrada); 
6665	   $modal.find('.precoParcelaEmedModal').text(formataValor(oferta.precoVendaMaxParcelaOferta)); 
6666
6667 
6668    
6669   function criaBotaoInscreverEmed(oferta, textoBotao, classeBotao, idBotao, elementoPai){ 
6670      if(oferta.permiteListaEspera && oferta.permiteListaEspera == statusEmed.NAO_ENCONTRADA) return; 
6671       var htmlBotao = '<button id="'+ idBotao +'" data-index="'+ oferta.indice +'" class="btn btn-card-investimento --inscreva-se '+ classeBotao +'"><span>'+textoBotao+'</span></button>'; 
6672      elementoPai.append(htmlBotao); 
6673              
6674      if(!classeBotao.includes('disabled')){ 
6675       
6676        elementoPai.on("click", '#'+ idBotao, function(ev){ 
6677          ev.preventDefault(); 
6678          const _modal = $('#modalAntesCompraEmed_'+$(this).data('index')); 
6679          _modal.css('display','flex'); 
6680           
6681           
6682        }); 
6683         
6684
6685 
6686
6687    
6688   function criaBotaoBolsaEmed(oferta, textoBotaoBolsa, classeBotaoBolsa=""){ 
6689      
6690     var htmlBotao = '<a id="btnBolsa_'+ oferta.indice +'" data-index="'+ oferta.indice +'" class="btn btn-card-investimento --bolsas '+ classeBotaoBolsa +'">'+ textoBotaoBolsa +'</a>'; 
6691     $('.codigoOferta_'+oferta.codigoOferta+' .ssp-ofertas-emed__card-info-investimento').append(htmlBotao); 
6692       
6693     if(!classeBotaoBolsa.includes('disabled')){ 
6694       // Associa o evento de clique no botão de bolsa 
6695       $('#btnBolsa_'+oferta.indice).attr('href', linkBolsa(oferta)); 
6696       $('#btnBolsa_'+oferta.indice).attr('target', '_blank'); 
6697       //$('#btnBolsa_'+oferta.indice).attr('style', 'text-transform:uppercase;'); 
6698 
6699
6700
6701    
6702   function criaBotaoBolsa(oferta, textoBotaoBolsa, classeBotaoBolsa=""){ 
6703	    
6704	   const botao = $('<a>'+ textoBotaoBolsa +'</a>'); 
6705	   botao.attr('id', 'btnBolsa_' + oferta.indice); 
6706	   botao.attr('data-index', oferta.indice); 
6707	   botao.attr('class', 'btn btn-lg btn-info w-100 mt-3 ' + (classeBotaoBolsa || '')); 
6708	   botao.css('font-size', '14px'); 
6709	   botao.css('font-weight', '600'); 
6710	   botao.css('background-color', '#004EFF'); 
6711	   if(!classeBotaoBolsa.includes('disabled')){ 
6712		   if(oferta.espacoExterno == 'true' || (isHibrido && temTextoParaFormatoHibrido)){ 
6713			   botao.attr('data-espaco-ex', 'true'); 
6714			   botao.click((ev)=>{  
6715					 ev.preventDefault();  
6716			         $('#btnCompraLocal_'+oferta.indice).hide(); 
6717			         $('#btnBolsaLocal_'+oferta.indice).show(); 
6718			         const _modal = $('#modalAntesCompra_'+oferta.indice); 
6719			         _modal.css('display','flex'); 
6720				}); 
6721		   }else{ 
6722		   botao.attr('href', linkBolsa(oferta)); 
6723		   botao.attr('target', '_blank'); 
6724
6725
6726	    
6727	   return botao; 
6728    
6729
6730 
6731   function verificaBotaoBolsaSS(oferta, codigoUnidade){ 
6732 
6733      
6734     if(!isEmed && (!oferta.dataAberturaBolsaOferta || oferta.dataAberturaBolsaOferta == '') ) return; 
6735      
6736     if(!ehCursoTrampolim){ 
6737       $.ajax({ 
6738             url :  getUrlConsultaBolsa(oferta), 
6739             type : 'get', 
6740             dataType: 'json', 
6741             beforeSend: function (xhr) { 
6742             xhr.setRequestHeader ("Authorization", "KGG4KMW5s0CVowr7d6y6Ww=="); 
6743             }, 
6744         }) 
6745         .done(function(infosBolsa){ 
6746 
6747            
6748           if(infosBolsa != null && typeof infosBolsa !== 'undefined'){ 
6749        	    
6750             var codigoOfertaRetornoBolsa = infosBolsa.DATA[0].COD_EVENTO; 
6751             var retornoOfertaBolsaSenac = infosBolsa.DATA[0]; 
6752			  
6753			 //Sobrescreve as flags de bolsa com o retorno do serviço SS 
6754             ofertasMap.get(codigoOfertaRetornoBolsa).vagasBolsaOferta = retornoOfertaBolsaSenac.TEM_VAGA_BOLSA; 
6755             ofertasMap.get(codigoOfertaRetornoBolsa).botaoBolsaOferta = retornoOfertaBolsaSenac.BOTAO_BOLSA; 
6756			  
6757             var dadosOferta = ofertasMap.get(codigoOfertaRetornoBolsa); 
6758              
6759             //calcula o tempo até abertura da bolsa, se houver (apenas depois das 08hrs) 
6760             var dadosAberturaBolsa = calculaTempoAberturaBolsa(dadosOferta.dataAberturaBolsaOferta, dadosOferta.horaAberturaBolsaOferta, dadosOferta.botaoBolsaOferta); 
6761             var textoBotaoBolsa = ''; 
6762             var classeBotaoBolsa = ''; 
6763             var textoBotaoContadorBolsa = ''; 
6764             var exibirBotaoBolsa = false; 
6765             var exibirContadorBolsa = false; 
6766              
6767             //EMED 
6768           if(isEmed){ 
6769             verificaBotoesEmed(ofertasMap.get(codigoOfertaRetornoBolsa), true); 
6770             return; 
6771
6772              
6773             //Verifica o texto do botão de bolsa 
6774            if($('#manutencao-bolsa').val()) textoBotaoBolsa = $('#manutencao-bolsa').val(); 
6775            else{ 
6776 
6777              if(retornoOfertaBolsaSenac.TEM_VAGA_BOLSA){ 
6778                             
6779                if(dadosAberturaBolsa.bolsaJaAberta) 
6780                  textoBotaoBolsa = "Inscrever para bolsa de estudo"; 
6781                   
6782                else 
6783                  textoBotaoBolsa = "Inscrições para bolsas a partir de "+formataDataAberturaBolsa(dadosOferta.dataAberturaBolsaOferta, dadosOferta.horaAberturaBolsaOferta); 
6784 
6785                  if(!ofertasComBolsa){ ofertasComBolsa = true; 
6786
6787              }else 
6788                textoBotaoBolsa = "Vagas esgotadas para bolsas de estudo"; 
6789
6790                 
6791             //verifica se o botão de concorrer a bolsa deve aparecer 
6792             if(retornoOfertaBolsaSenac.BOTAO_BOLSA && !dadosAberturaBolsa.exibirContador){ 
6793                
6794               exibirBotaoBolsa = true; 
6795 
6796               if(!ofertasComBolsa) ofertasComBolsa = true; 
6797                
6798               if(retornoOfertaBolsaSenac.TEM_VAGA_BOLSA && dadosAberturaBolsa.bolsaJaAberta && !$('#manutencao-bolsa').val()){ 
6799                   classeBotaoBolsa = ''; 
6800               }else{ 
6801                   classeBotaoBolsa = 'disabled'; 
6802
6803
6804              
6805             //Verifica se o botão do cronômetro deve aparecer 
6806             if(dadosAberturaBolsa.exibirContador && !$('#manutencao-bolsa').val()){ 
6807               textoBotaoContadorBolsa = dadosAberturaBolsa.textoContador; 
6808               exibirContadorBolsa = true; 
6809
6810              
6811             if(exibirBotaoBolsa) 
6812                $('.codigoOferta_'+codigoOfertaRetornoBolsa+' .ssp-card-oferta-curso .ssp-container-botao-bolsa').append( criaBotaoBolsa(dadosOferta, textoBotaoBolsa, classeBotaoBolsa) ) 
6813             else if(exibirContadorBolsa) 
6814                $('.codigoOferta_'+codigoOfertaRetornoBolsa+' .ssp-card-oferta-curso .ssp-container-botao-bolsa').append('<a id="btnContadorBolsa_'+dadosOferta.indice+'" data-index="'+dadosOferta.indice+'"  class="btn btn-lg btn-info w-100 mt-3" >Você poderá se inscrever para bolsa em <span>'+textoBotaoContadorBolsa+'</span></a>') 
6815             else { 
6816                $('.codigoOferta_'+codigoOfertaRetornoBolsa+'.content-btn-bolsa').hide() 
6817                $('.show-price-content.codigoOferta_'+oferta.codigoOferta + ' .ou-separator-desconto').hide() 
6818             }      
6819                                   
6820           }else{ 
6821             //EMED 
6822              if(isEmed){ 
6823                verificaBotoesEmed(oferta, false); 
6824
6825
6826 
6827           controlaPaginaBolsa() 
6828         }) 
6829         .fail(function(){  
6830           $('.content-btn-bolsa.codigoOferta_'+oferta.codigoOferta).hide() 
6831           $('.show-price-content.codigoOferta_'+oferta.codigoOferta + ' .ou-separator-desconto').hide() 
6832 
6833             //EMED 
6834           if(isEmed){ 
6835             verificaBotoesEmed(oferta, false); 
6836
6837         }); 
6838          
6839          
6840
6841      
6842
6843 
6844   function controlaPaginaBolsa(){ 
6845    if(ofertasComBolsa) 
6846      $("#ssp-abrir-pagina-bolsa").removeClass("d-none") 
6847    else 
6848      $("#ssp-abrir-pagina-bolsa").addClass("d-none") 
6849
6850 
6851   function associaEventoBtnFormaPagamento(i){ 
6852      var modal = document.getElementById("myModal_"+i); 
6853 
6854      var btn = document.getElementById("myBtn_"+i); 
6855 
6856      if(btn!=null){ 
6857         btn.onclick = function(ev) { 
6858             event.preventDefault() 
6859               
6860               $('#modalExtAluno_'+i).addClass('d-none'); 
6861                
6862             var elem = $(ev.target); 
6863             var _modal = document.getElementById( 
6864                 'myModal_'+elem.data('index')); 
6865             _modal.style.display = "block"; 
6866               $('#myModal_'+i).find('.modal-extensao_content:first-child').removeClass('d-none'); 
6867                
6868
6869
6870      
6871       
6872      
6873       
6874
6875    
6876  	    
6877   function actionBtnComprar(elem){ 
6878            
6879        // Montar object push - google tag manager - 3 
6880        ofertaSelecionada = itensEcommerce.get(elem.attr('data-evento')) 
6881        sendEventEcommerce("select_item", ofertaSelecionada); 
6882        sendEventEcommerce("view_item", ofertaSelecionada); 
6883                
6884               //Verifica se deve exibir o modal com a localização 
6885               if(elem.attr('data-espaco-ex') == 'true'){ 
6886         $('#btnCompraLocal_'+elem.data('index')).show(); 
6887 
6888         //Limpa onclicks para nao repetir execucao 
6889         $('#modalAntesCompra_'+elem.data('index')).off('click', '#btnCompraLocal_'+elem.data('index')) 
6890         $('#modalAntesCompra_'+elem.data('index')).on('click', '#btnCompraLocal_'+elem.data('index'), function () { 
6891          // Montar object push - google tag manager - 4 
6892          sendEventEcommerce("add_to_cart", ofertaSelecionada); 
6893          if( elem.attr('data-destino-compra') != '2' ) 
6894            sendEventEcommerce("begin_checkout", ofertaSelecionada); 
6895         }) 
6896         $('#btnBolsaLocal_'+elem.data('index')).hide(); 
6897         const _modal = $('#modalAntesCompra_'+elem.data('index')); 
6898         _modal.css('display','flex'); 
6899               }else{ 
6900                 var urlCompra  = linkBotaoCompra.replace('\{codigoUnidade\}', elem.attr('data-unidade')).replace('\{codigoOferta\}', elem.attr('data-evento')); 
6901     
6902                 if( elem.attr('data-destino-compra') == '2' ){ 
6903                	 var dataEfetivaFormat = formataDataComBarra($('[name="dataEfetivaSTR"]').val()); 
6904	                  	 
6905                	 addItemBackpack(elem.attr('data-evento'), '#' + elem.attr('id'),elem.attr('data-unidade'), dataEfetivaFormat);    
6906    
6907                 }else{ 
6908                	 window.open(urlCompra, '_blank'); 
6909
6910
6911 
6912        
6913                  
6914
6915    
6916   function associaEventoBtnComprar(i){ 
6917	   var btnComprar = document.getElementById("btnComprar_"+i); 
6918	    
6919	   if(btnComprar != null && !btnComprar.classList.contains('disabled')){ 
6920         btnComprar.onclick = function(ev) { 
6921            
6922               ev.preventDefault() 
6923               var elem = $(ev.target); 
6924               actionBtnComprar(elem); 
6925                
6926
6927
6928
6929    
6930   function associaEventoBtnComprarDentroFormaPgto(i){ 
6931	   var btnComprarFormaPgto = document.getElementById("btnComprarFormaPgto_"+i); 
6932	    
6933	   if(btnComprarFormaPgto != null && !btnComprarFormaPgto.classList.contains('disabled')){ 
6934         btnComprarFormaPgto.onclick = function(ev) { 
6935               event.preventDefault() 
6936                 var elem =  $('#btnComprarFormaPgto_'+i); 
6937               actionBtnComprar(elem); 
6938
6939
6940
6941      
6942     function associaEventoBtnComprarConhecaDescontoOk(i){ 
6943       var btnComprarConhecaDescontoOk = document.getElementById("btnComprarConhecaDescontoOk_"+i); 
6944        
6945       if(btnComprarConhecaDescontoOk != null){ 
6946         btnComprarConhecaDescontoOk.onclick = function(ev) { 
6947                 event.preventDefault() 
6948               var elem = $(ev.target); 
6949                 actionBtnComprar(elem); 
6950
6951
6952
6953    
6954     function associaEventoBtnComprarConhecaDescontoNot(i){ 
6955       var btnComprarConhecaDescontoNot = document.getElementById("btnComprarConhecaDescontoNot_"+i); 
6956        
6957       if(btnComprarConhecaDescontoNot != null){ 
6958         btnComprarConhecaDescontoNot.onclick = function(ev) { 
6959                 event.preventDefault() 
6960                 var elem =  $(ev.target); 
6961                 actionBtnComprar(elem); 
6962
6963
6964
6965      
6966     function associaEventoBtnAlunoNao(i){ 
6967       var btnAlunoNao = document.getElementById("btn-aluno-nao_"+i); 
6968        
6969       if(btnAlunoNao != null){ 
6970         btnAlunoNao.onclick = function(ev) { 
6971                 event.preventDefault() 
6972                 var elem =  $(ev.target); 
6973                 elem.addClass('modal-extensao-btn-aluno-sim-ativo'), 
6974                 elem.closest('.sim').removeClass('modal-extensao-btn-aluno-sim-ativo'); 
6975                 elem.parent().siblings().find('button').removeClass('modal-extensao-btn-aluno-sim-ativo') 
6976                 $('#msg-alunoNao_'+i).removeClass('d-none'); 
6977                 $('#msg-alunoSim_'+i).addClass('d-none');      
6978
6979
6980
6981        
6982     function associaEventoBtnAlunoSim(i){ 
6983       var btnAlunoSim = document.getElementById("btn-aluno-sim_"+i); 
6984        
6985       if(btnAlunoSim != null){ 
6986         btnAlunoSim.onclick = function(ev) { 
6987                 event.preventDefault() 
6988                 var elem =  $(ev.target); 
6989                 elem.addClass('modal-extensao-btn-aluno-sim-ativo'), 
6990                 elem.closest('.nao').removeClass('modal-extensao-btn-aluno-sim-ativo'); 
6991                 elem.parent().siblings().find('button').removeClass('modal-extensao-btn-aluno-sim-ativo') 
6992                 $('#msg-alunoSim_'+i).removeClass('d-none'); 
6993                 $('#msg-alunoNao_'+i).addClass('d-none');              
6994                  
6995
6996
6997     }	    
6998      
6999     function associaEventoBtnConheca(i){ 
7000       var btnModalExtConheca = document.getElementById("btnModalExtConheca_"+i); 
7001        
7002       if(btnModalExtConheca != null){ 
7003         btnModalExtConheca.onclick = function(ev) { 
7004                 event.preventDefault(); 
7005                 var elem =  $(ev.target); 
7006                 elem.closest('.modal-extensao_content').addClass('d-none'); 
7007                 $('#modalExtAluno_'+i).removeClass('d-none'); 
7008                 $('#msg-alunoSim_'+i).addClass('d-none'); 
7009                 $('#msg-alunoNao_'+i).addClass('d-none'); 
7010                 $('#btn-aluno-sim_'+i).removeClass('modal-extensao-btn-aluno-sim-ativo'); 
7011                 $('#btn-aluno-nao_'+i).removeClass('modal-extensao-btn-aluno-sim-ativo'); 
7012 
7013
7014
7015
7016      
7017   function associaEventoBtnLocalRealizacao(i){ 
7018	   var btnLocalRealizacao = document.getElementById("btnLocalRealizacao_"+i); 
7019	    
7020	   if(btnLocalRealizacao!=null){ 
7021         btnLocalRealizacao.onclick = function(ev) { 
7022                 event.preventDefault(); 
7023               var elem = $(ev.target); 
7024               var _modal = document.getElementById( 
7025                   'modalLocalRealizacao_'+elem.data('index')); 
7026               _modal.style.display = "flex"; 
7027
7028
7029
7030 
7031   function associaEventosFecharModal(i){ 
7032 
7033      var span = document.getElementsByClassName("ssp-card-modal-forma-pagamento__btn-close_"+i); 
7034      var closeModalLocalRealizacao = document.getElementsByClassName("ssp-card-modal-local-realizacao__btn-close_"+i)[0]; 
7035       var closeModalAntesCompra = document.getElementsByClassName("ssp-card-modal-antes-compra__btn-close_"+i)[0]; 
7036       var closeModalSelecionarOutro = document.getElementsByClassName("ssp-card-modal-selecionar-outro__btn-close_"+i)[0]; 
7037       var btnEntendiLocalRealizacao = document.getElementsByClassName("ssp-modal-local-realizacao__btn_"+i)[0]; 
7038       var closeModalBotaoBolsa = document.getElementById("btnBolsaLocal_"+i) 
7039 
7040       if(isEmed){ 
7041    	   var closeModalFormaPagamento = document.getElementsByClassName("ssp-btn-emed__voltar-curso_"+i); 
7042   	      for (const val of closeModalFormaPagamento) {  
7043 
7044   	    	  val.onclick = function() { 
7045   	        	 $('[id^="myModal_"]').each(function(index,modal){ 
7046   	           	 	modal.style.display = "none"; 
7047   	        	 }); 
7048
7049   	      }; 
7050
7051        
7052	  //event close modal 
7053      for (const val of span) {  
7054 
7055    	  val.onclick = function() { 
7056        	 $('[id^="myModal_"]').each(function(index,modal){ 
7057           	 	modal.style.display = "none"; 
7058        	 }); 
7059
7060      }; 
7061   
7062      closeModalLocalRealizacao.onclick = function() { 
7063   
7064           $('[id^="modalLocalRealizacao_"]').each(function(index,modal){ 
7065             modal.style.display = "none"; 
7066              
7067           }); 
7068
7069 
7070       closeModalAntesCompra.onclick = function() { 
7071          
7072           $('[id^="modalAntesCompra_"], [id^="modalAntesCompraEmed_"]').each(function(index,modal){ 
7073             modal.style.display = "none"; 
7074           }); 
7075
7076 
7077       closeModalSelecionarOutro.onclick = function() { 
7078          
7079      $('[id^="modalAntesCompra_"], [id^="modalAntesCompraEmed_"]').each(function(index,modal){ 
7080          modal.style.display = "none"; 
7081        }); 
7082
7083          
7084       btnEntendiLocalRealizacao.onclick = function() { 
7085          
7086           $('[id^="modalLocalRealizacao_"]').each(function(index,modal){ 
7087             modal.style.display = "none"; 
7088           }); 
7089
7090		 
7091       if(closeModalBotaoBolsa != null){ 
7092	       closeModalBotaoBolsa.onclick = function() { 
7093	          
7094	         $('[id^="modalAntesCompra_"], [id^="modalAntesCompraEmed_"]').each(function(index,modal){ 
7095	             modal.style.display = "none"; 
7096	           }); 
7097
7098
7099 
7100       // When the user clicks anywhere outside of the modal, close it 
7101       window.onclick = function(event) { 
7102   
7103         $('[id^="myModal_"]').each(function(index,_modal){ 
7104             if (event.target == _modal)  
7105              _modal.style.display = "none"; 
7106         }); 
7107         $('[id^="modalLocalRealizacao_"]').each(function(index,_modal){ 
7108             if (event.target == _modal)  
7109              _modal.style.display = "none"; 
7110         }); 
7111          
7112         $('[id^="modalAntesCompra_"], [id^="modalAntesCompraEmed_"]').each(function(index,_modal){ 
7113             if (event.target == _modal)  
7114              _modal.style.display = "none"; 
7115         }); 
7116
7117
7118    
7119   function turmasIniciadas(dataInicioCurso){ 
7120     
7121      var hoje = new Date();  
7122      var dataInicioPartes = dataInicioCurso.split('/');  
7123      var dataInicioCursoOferta = new Date(dataInicioPartes[2], dataInicioPartes[1] - 1, dataInicioPartes[0] , hoje.getHours(),hoje.getMinutes(),hoje.getSeconds(),hoje.getMilliseconds()); 
7124 
7125      return dataInicioCursoOferta.getTime() <= hoje.getTime(); 
7126
7127    
7128    
7129   function concatSTR(str1, str2, separador){ 
7130   
7131     if(str2){ 
7132   
7133       return str1+separador+str2; 
7134
7135     return str1; 
7136
7137    
7138   //Formata exibicao de datas conforme especificacao GCR 
7139   function formataPeriodo(dataInicio, dataFim){ 
7140     
7141      var dtInicioPartes = dataInicio.split('/'); 
7142      var dtFimPartes = dataFim.split('/'); 
7143       
7144      //Não exibir o número zero antes dos números e o dia 1 como 1º 
7145      var dInicioFormatada = (parseInt(dtInicioPartes[0].trim()) == 1 ? '1º' : parseInt(dtInicioPartes[0].trim())) +'/'+parseInt(dtInicioPartes[1].trim())+'/'+dtInicioPartes[2].trim(); 
7146      var dFimFormatada = (parseInt(dtFimPartes[0].trim()) == 1 ? '1º' : parseInt(dtFimPartes[0].trim())) +'/'+parseInt(dtFimPartes[1].trim())+'/'+dtFimPartes[2].trim(); 
7147     
7148      //Quando um curso inicia e finaliza dentro do mesmo ano: 17/2 a 25/4/2020 
7149      if(dtInicioPartes[2].trim() == dtFimPartes[2].trim()){ 
7150         
7151        dInicioFormatada = (parseInt(dtInicioPartes[0].trim()) == 1 ? '1º' : parseInt(dtInicioPartes[0].trim()))+'/'+parseInt(dtInicioPartes[1].trim()); 
7152         
7153        //Quando um curso inicia e finaliza dentro do mesmo mês: 5 a 30/4/2020 
7154        if(dtInicioPartes[1].trim() == dtFimPartes[1].trim()) 
7155          dInicioFormatada = (parseInt(dtInicioPartes[0].trim()) == 1 ? '1º' : parseInt(dtInicioPartes[0].trim())); 
7156
7157     
7158    return dInicioFormatada + ' a ' + dFimFormatada; 
7159
7160    
7161  //Decrementa os contadores de abertudas de bolsa 
7162   function atualizaTempoAberturasBolsas() { 
7163   
7164	  var btnsContador = (isEmed) ? $('[id^="btnContadorBolsa_"], [id^="btnContadorComprar_"]') : $('[id^="btnContadorBolsa_"]'); 
7165	   
7166    btnsContador.each(function() { 
7167       
7168      var index = $(this).data('index'); 
7169      var btnContent = $(this).parent('.ssp-btn-group__content'); 
7170       
7171      if(isEmed){ 
7172     		//EMED filtra ofertas e usa outra lista para referenciar as ofertas carregadas 
7173    	  var dadosAberturaBolsa = calculaTempoAberturaBolsa(ofertasMap.get('' +index).dataAberturaBolsaOferta, ofertasMap.get('' + index).horaAberturaBolsaOferta); 
7174      }else{ 
7175          	//calcula o tempo até abertura da bolsa, se houver (apenas depois das 08hrs) 
7176      var dadosAberturaBolsa = calculaTempoAberturaBolsa(objsTela.ofertas[index].dataAberturaBolsaOferta, objsTela.ofertas[index].horaAberturaBolsaOferta, objsTela.ofertas[index].botaoBolsaOferta); 
7177
7178       
7179      $(this).find('span').text(dadosAberturaBolsa.hours+':'+dadosAberturaBolsa.minutes+':'+dadosAberturaBolsa.seconds); 
7180       
7181      //Se esgotou o contador 
7182      if(dadosAberturaBolsa.hours == 0 && dadosAberturaBolsa.minutes == 0 && dadosAberturaBolsa.seconds == 0){ 
7183         
7184    	var elId = $(this).attr('id'); 
7185    	   
7186        //remove o contador 
7187        $(this).remove(); 
7188         
7189        //Habilitar inscrição EMED 
7190        if(isEmed){ 
7191          var ofertaEmed = ofertasMap.get('' +index); 
7192        var elementoPai = $('.codigoOferta_'+ofertaEmed.codigoOferta+' .ssp-ofertas-emed__card-info-investimento'); 
7193         
7194          if(elId.indexOf('btnContadorBolsa') >= 0){ 
7195              if($('#manutencao-bolsa').val())   
7196                criaBotaoBolsaEmed(ofertaEmed, $('#manutencao-bolsa').val(), 'disabled manutencao'); 
7197              else if(ofertaEmed.vagasBolsaOferta == true || ofertaEmed.vagasBolsaOferta == "true") 
7198                criaBotaoBolsaEmed(ofertaEmed, 'Bolsa de estudo', ''); 
7199              else 
7200                criaBotaoBolsaEmed(ofertaEmed, 'Bolsas de Estudo Esgotadas', 'disabled'); 
7201          }else if(elId.indexOf('btnContadorComprar') >= 0){ 
7202	       		 
7203        	  	var textoBotao, classeBotao; 
7204        	   
7205              textoBotao = $('#manutencao-compra').val() || 'Fazer matrícula'; 
7206              classeBotao = $('#manutencao-compra').val() ? 'disabled manutencao' : ''; 
7207             
7208 
7209            criaBotaoInscreverEmed(ofertaEmed, textoBotao, classeBotao, 'btnComprarEmed_' + ofertaEmed.indice, elementoPai); 
7210             
7211            //Altera o botao do modal de pagamento 
7212            var btnIndex = elId.slice(elId.indexOf('_')+1); 
7213            var modal = $('#myModal_' + btnIndex).find('.ssp-card-modal-forma-pagamento'); 
7214            var btnModal = modal.find('#btnComprarEmedModal_' + btnIndex); 
7215            if(btnModal){ 
7216              btnModal.remove();					   
7217              criaBotaoInscreverEmedModal(ofertaEmed, textoBotao, classeBotao, 'btnComprarEmedModal_' + btnIndex, modal, btnIndex); 
7218              preencheDadosEmedModal(ofertaEmed,modal); 
7219
7220 
7221 
7222          }	         
7223           
7224        }else{ 
7225         
7226	        //Checa as condições das vagas do botão de bolsa 
7227          var btnBolsaHTML = null; 
7228          if($('#manutencao-bolsa').val())   
7229            btnBolsaHTML = criaBotaoBolsa(objsTela.ofertas[index], $('#manutencao-bolsa').val(), 'disabled manutencao'); 
7230	        else if(objsTela.ofertas[index].vagasBolsaOferta == true || objsTela.ofertas[index].vagasBolsaOferta == "true") 
7231        	  btnBolsaHTML = criaBotaoBolsa(objsTela.ofertas[index], 'Inscrever para bolsa de estudo'); 
7232	        else 
7233        	  btnBolsaHTML = criaBotaoBolsa(objsTela.ofertas[index], 'Vagas esgotadas para bolsas de estudo', 'disabled'); 
7234	         
7235            $('.codigoOferta_'+ objsTela.ofertas[index].codigoOferta +'.ssp-container-botao-bolsa').append(btnBolsaHTML); 
7236	         
7237 
7238
7239
7240       
7241    }); 
7242    
7243
7244    
7245   // Retorna um objeto com o tempo de abertura da bolsa, em horas, minutos e segundos 
7246    function calculaTempoAberturaBolsa(dataAberturaBolsa, horaAberturaBolsa, botaoBolsa){ 
7247       
7248        var dadosAberturaBolsa = { 
7249              days : '', 
7250            hours : '', 
7251            minutes : '', 
7252            seconds : '', 
7253            bolsaJaAberta: false, 
7254            exibirContador: false, 
7255            textoContador: '' 
7256          }; 
7257       
7258      if(dataAberturaBolsa.length == 0 || horaAberturaBolsa.length == 0) 
7259         return dadosAberturaBolsa; 
7260       
7261      var now = todayG; 
7262      var dia = now.getDate(); 
7263      var horarioDia = now.getHours(); 
7264         
7265      var tempoRestante= tempoRestanteAberturaBolsa(dataAberturaBolsa, horaAberturaBolsa); 
7266       
7267      //console.log('tempo restante '+tempoRestante); 
7268       
7269      var diaAberturaBolsa = dataAberturaBolsa.split('-')[2]; 
7270     
7271      var delta = tempoRestante / 1000; 
7272       
7273      var days = Math.floor(delta / 86400); 
7274       
7275      delta -= days * 86400; 
7276       
7277      var hours = Math.floor(delta / 3600) % 24; 
7278      delta -= hours * 3600; 
7279       
7280      var minutes = Math.floor(delta / 60) % 60; 
7281      delta -= minutes * 60; 
7282       
7283      var seconds = Math.floor(delta % 60); 
7284       
7285      //Zerar contador para data que ja passou 
7286      if(days < 0){ 
7287          dadosAberturaBolsa.days = 0; 
7288          dadosAberturaBolsa.hours = '00'; 
7289          dadosAberturaBolsa.minutes = '00'; 
7290          dadosAberturaBolsa.seconds = '00'; 
7291      }else{ 
7292          dadosAberturaBolsa.days = days; 
7293          dadosAberturaBolsa.hours = hours < 10 ? '0'+hours : hours; 
7294          dadosAberturaBolsa.minutes = minutes < 10 ? '0'+minutes : minutes; 
7295          dadosAberturaBolsa.seconds = seconds < 10 ? '0'+seconds : seconds; 
7296
7297 
7298      dadosAberturaBolsa.bolsaAberta = days <= 0 && hours <= 0 && minutes <= 0 && seconds <= 0; 
7299      var horaExibeContador = 8; 
7300      if(!isEmed && botaoBolsa == false){ 
7301    	  dadosAberturaBolsa.exibirContador = false; 
7302      }else{ 
7303          dadosAberturaBolsa.exibirContador = days == 0 && horarioDia >= horaExibeContador && !dadosAberturaBolsa.bolsaAberta && (diaAberturaBolsa == dia); 
7304          dadosAberturaBolsa.textoContador = dadosAberturaBolsa.hours + ':' + dadosAberturaBolsa.minutes + ":"+ dadosAberturaBolsa.seconds; 
7305
7306      dadosAberturaBolsa.bolsaJaAberta = tempoRestante < 0; 
7307       
7308      return dadosAberturaBolsa; 
7309   
7310
7311    
7312   // Verifica se uma oferrta já chegou sua data de abertura 
7313   function tempoRestanteAberturaBolsa(dataAberturaBolsa, horaAberturaBolsa){ 
7314     // console.log(dataAberturaBolsa); 
7315     // console.log(horaAberturaBolsa); 
7316       
7317      //var today = new Date(); 
7318       
7319       
7320      //console.log( "TodayG "+ todayG); 
7321       
7322      //Precisa fazer formatação nos horários pois pode estar como 9h ou 9h30 
7323      var partesHora = horaAberturaBolsa.split('h'); 
7324       
7325      var partesHora = partesHora.filter(function (el) { 
7326        return el != ""; 
7327      }); 
7328       
7329      //formato 9h 
7330      if(partesHora.length == 1) 
7331        var aberturaBolsa = new Date(dataAberturaBolsa+'T'+horaAberturaBolsa.replace('h', '').trim()+":00"); 
7332   
7333      else{ 
7334         
7335        //format 9h3 
7336        if(partesHora[1].length == 1) 
7337          var aberturaBolsa = new Date(dataAberturaBolsa+'T'+partesHora[0].replace('h', '').trim()+':'+partesHora[1] +'0'); 
7338           
7339        //formato 9h30 
7340        else 
7341          var aberturaBolsa = new Date(dataAberturaBolsa+'T'+partesHora[0].replace('h', '').trim()+':'+partesHora[1]); 
7342
7343        
7344     // console.log(aberturaBolsa); 
7345      return aberturaBolsa - todayG; 
7346
7347    
7348   function formataDataAberturaBolsa(dataAberturaBolsa, horaAberturaBolsa){ 
7349      var dataPartes = dataAberturaBolsa.split('-'); 
7350       
7351      return dataPartes[2]+'/'+dataPartes[1]+ ' às '+horaAberturaBolsa.replace('h', '').trim()+' horas'; 
7352       
7353
7354   
7355   function formataValor(valor){ 
7356       
7357      if(!valor.toString().includes(".")){ 
7358        valor = parseFloat(valor).toLocaleString('pt-BR')+",00"; 
7359      }else{ 
7360         valor = parseFloat(valor).toLocaleString('pt-BR'); 
7361          
7362         if(valor.split(",").length == 2){ 
7363            
7364           if(valor.split(",")[1].length == 1) 
7365              valor += "0"; 
7366            
7367         }else 
7368           valor += ",00"; 
7369
7370       
7371      return valor; 
7372
7373 
7374  function ajustarCasasDecimaisSemArredondar(numero, casas) { 
7375    const str = numero + '' 
7376    const arr = str.split('.') 
7377    return parseFloat(arr[0].concat('.').concat(arr[1] ? arr[1].substring(0, casas) : '0')) 
7378
7379 
7380  function possuiCriteriosDesconto2022(dt) { 
7381    return dt.substring(dt.lastIndexOf('/') + 1) >= 2022 
7382      && ( 
7383        $('[name="tipoCurso"]').val() == 'livre' 
7384        || ($('[name="tipoCurso"]').val() == 'tecnico' && $('[name="modalidades"]').val() == 'espec.-tecnica-de-nivel-medio') 
7385        || $('[name="tipoCurso"]').val() == 'extensao' 
7386
7387
7388 
7389  function strToFloat(str) { 
7390    const separator = str.includes(',') ? ',' : '.' 
7391 
7392    const numArr = str.split(separator) 
7393    const inteiro = numArr[0].replaceAll('.', '').replaceAll(',', '.') 
7394    const decimal = numArr[1] ? numArr[1].replaceAll('.', '').replaceAll(',', '.') : '' 
7395    return parseFloat(inteiro.concat('.').concat(decimal ? decimal : '0')) 
7396
7397 
7398  function possuiMensalidade99(oferta) { 
7399    if(!oferta.precoVendaMaxParcelaOferta  
7400    || (oferta.precoVendaMaxParcelaOferta != 99 
7401    && parseFloat(oferta.precoParcelaCartoes.replace(',','.')) != 99 
7402    && parseFloat(oferta.precoParcelaBoleto.replace(',','.')) != 99)) 
7403      return false 
7404 
7405    if($('[name="modalidades"]').val() == 'hab.-tecnica-de-nivel-medio') 
7406      return true 
7407 
7408    if($('[name="modalidades"]').val() == 'espec.-tecnica-de-nivel-medio') 
7409      return true 
7410 
7411    if($('[name="modalidades"]').val() == 'qualificacao-profissional') 
7412      return true 
7413     
7414    return false 
7415
7416    
7417  function htmlSlickArea(index, oferta, diasSemanaHTML, codigoUnidade) { 
7418    let temDesconto = possuiCriteriosDesconto2022(oferta.dataInicio) 
7419    temDesconto = temDesconto && !possuiMensalidade99(oferta) 
7420     
7421    const btnLocalReal = function(oferta){ 
7422       
7423      var btn = `<div class="container-local-realizacao ` + ((oferta.espacoExterno == 'true'|| (isHibrido && temTextoParaFormatoHibrido))  ? '' : 'd-none-btn') + (localLivreOnline(oferta.localEspacoExterno) ? ' idioma-online' : '') + `">`; 
7424       
7425      btn += (localLivreOnline(oferta.localEspacoExterno)) ? 
7426            `<a id="btnLocalRealizacao_` + index + `" data-index="` + index + `" class="btn-idiomas__aula-online" href="#"> 
7427            <i class="fas fa-wifi"></i>Aulas Online - ao vivo</a>` 
7428            : `<a id="btnLocalRealizacao_` + index + `" data-index="` + index + `" class="ssp-card-oferta-curso__local-realizacao-content__title" href="#"><i class="fas fa-user"></i>Onde as aulas vão acontecer?</a>`; 
7429       
7430        btn += `</div>`; 
7431         
7432      return btn; 
7433     
7434
7435 
7436    // Card Oferta 
7437     
7438    let result = ` 
7439        <div class="slick-area__item card_oferta_` + index + ` codigoOferta_` + oferta.codigoOferta + ` ` + (temDesconto ? 'ssp-desconto-2022' : '') + `"> 
7440 
7441          <div class="ssp-card-oferta-curso"> 
7442 
7443            <div class="content-data-dias"> 
7444 
7445              <div class="ssp-card-oferta__info-turma-iniciada" id="aviso-turma-iniciada-` + index + `" style="display:none"> 
7446                <h6 style="color:white;background-color:#ff7157;border-radius: 5px;padding: 8px 0px;width: 60%;font-size: 12px;margin-top: 0;"><strong>Turma iniciada, comece já!</strong></h6> 
7447              </div> 
7448 
7449 
7450              <div> 
7451                <small class="ssp-card-oferta-curso__title-item">Período:</small> 
7452                <h6 class="ssp-card-oferta-curso__item-data-periodo item-data-periodo_` + index + `">` + formataPeriodo(oferta.dataInicio, oferta.dataFim) + `</h6> 
7453	          </div> 
7454	 
7455              <div class="content-horario-dias-semana"> 
7456	 
7457                <div class="horario"> 
7458                  <small class="ssp-card-oferta-curso__title-item">Horário e dias das aulas:</small> 
7459                </div> ` + 
7460	 
7461                `<div class="ssp-card-oferta-curso__dia-hora_content"> 
7462                  ` + diasSemanaHTML + ` 
7463	              </div> 
7464	 
7465	          </div> 
7466	 
7467      ` + btnLocalReal(oferta); 
7468 
7469      result = result + ` 
7470        </div> 
7471
7472      
7473      //Regra adicionada em 04/01/22 devido aos cursos de Garçon e Cozinheiro. Definimos como regra geral que caso botaoCompra seja falso, não faz sentido mostrar os valores 
7474      //Adicionada a validação dos preços da oferta em 07/06/2022 - Tarefa 9498 
7475      const estaSemValorOferta =   oferta.botaoCompraOferta == ''  
7476                          || oferta.botaoCompraOferta == 'false'  
7477                          || !oferta.precoVendaOferta  
7478                          || !oferta.precoCheioOferta  
7479                          || !oferta.precoVendaMaxParcelaOferta 
7480                          || strToFloat(oferta.precoVendaOferta) == 0 
7481                          || strToFloat(oferta.precoCheioOferta)  == 0 
7482                          || strToFloat(oferta.precoVendaMaxParcelaOferta)  == 0 
7483      
7484      //Trecho inicial do Bolsa de estudo 
7485      result += `<div class="content-btn-bolsa codigoOferta_` + oferta.codigoOferta + (estaSemValorOferta ? ' pb-0' : '') + `"> 
7486                  <div class="ssp-card-oferta__info-turma-content"> 
7487                    <h6 class="ssp-card-oferta__info-turma mb-0">Bolsas de estudo</h6> 
7488                  </div> 
7489                  <div class="codigoOferta_` + oferta.codigoOferta + ` ssp-container-botao-bolsa"></div>    
7490                </div>                
7491
7492     
7493    if(estaSemValorOferta) { 
7494      result = result + ` 
7495      		<div class="content-buttons hide"> 
7496			  </div> 
7497
7498      return result; 
7499
7500 
7501	 
7502    //Trecho final do Bolsa de estudo e inclusao de botao de expansao do "Valores para compra" 
7503    result += ` <div class="show-price-content codigoOferta_` + oferta.codigoOferta + `"> 
7504                  <div class="ou-separator-desconto">Ou</div> 
7505                  <button type="button" class="btn-show-price"> 
7506                    <p>Saiba mais sobre:</p> 
7507                    <div onclick="togglePriceCard('codigoOferta_` + oferta.codigoOferta + `')"> 
7508                      <i class="fas fa-money-bill"></i> 
7509                      <span>Valores para compra</span> 
7510                    </div> 
7511                  </button> 
7512                </div> 
7513
7514 
7515    result = result + ` 
7516          <div class="content-valores-descontos hide-price codigoOferta_` + oferta.codigoOferta + `"> 
7517
7518         
7519    if( temDesconto && !ehCursoTrampolim ) { 
7520      result = result + ` 
7521            <div class="ssp-card-oferta__info-turma-content"> 
7522              <h6 class="ssp-card-oferta__info-turma">Valores para compra</h6> 
7523            </div> 
7524	 
7525            <div class="block-valor-desconto"> 
7526	          	 
7527            <div class="tag-label-desconto"> 
7528              <small class="ssp-card-oferta-curso__title-item">Valor com </small> 
7529              <span class="ssp-card-oferta-curso__valor-desconto">50% de desconto*</span> 
7530	      </div> 
7531	 
7532            <h6 class="ssp-card-oferta-curso__item-valor-investimento"><span>` + oferta.numeroMaxParcelasOferta + `x</span>R$ ` + formataValor(ajustarCasasDecimaisSemArredondar((strToFloat(oferta.precoVendaOferta)/strToFloat(oferta.numeroMaxParcelasOferta))/2, 2)) + `</h6> 
7533 
7534            <div class="ssp-card-oferta-curso__desconto-content"> 
7535              <p>De: <span class="ssp-card-oferta-curso__valor-antigo">R$ ` + formataValor(ajustarCasasDecimaisSemArredondar(strToFloat(oferta.precoVendaOferta), 2)) + `</span></p> 
7536              <p>Por: <span class="ssp-card-oferta-curso__valor-desconto">R$ ` + formataValor(ajustarCasasDecimaisSemArredondar(strToFloat(oferta.precoVendaOferta)/2, 2)) + `</span></p> 
7537            </div> 
7538
7539           
7540      if($('[name="tipoCurso"]').val() == 'extensao') { 
7541        result = result + `<p class="modal-extensao_txteconomiza my-2">* Válido para quem trabalha ou tem sua própria empresa no setor de comércio e serviços, estudantes ou ex-estudantes de cursos técnicos no Senac ou para quem já finalizou o Ensino Médio Técnico no Senac.</p></div>` 
7542      } else { 
7543        result = result + `<p class="modal-extensao_txteconomiza my-2">*Válido para quem trabalha ou tem sua própria empresa no setor de comércio e serviços.</p></div>` 
7544
7545   
7546      result = result + ` 
7547          <div class="ou-separator-desconto">Ou</div> 
7548       
7549          <div class="block-valor-total"> 
7550 
7551            <small class="ssp-card-oferta-curso__title-item">Valor sem desconto:</small> 
7552 
7553            <h6 class="ssp-card-oferta-curso__item-valor-investimento"><span>` + oferta.numeroMaxParcelasOferta + `x</span>R$ ` + formataValor(oferta.precoVendaMaxParcelaOferta) + `</h6> 
7554 
7555            <div class="ssp-card-oferta-curso__desconto-content"> 
7556              <p>Valor total: <strong>R$ ` + formataValor(strToFloat(oferta.precoVendaOferta)) + `</strong></p> 
7557            </div> 
7558             
7559          </div> 
7560
7561                 		 }else{ 
7562                 			 
7563      // itens que são diferentes entre técnico e livres comprado a extensão 
7564      if($('[name="tipoCurso"]').val() == 'extensao'){ 
7565        result = result + ` 
7566 
7567          <div class="block-valor-total"> 
7568 
7569            <div class="investimento" id="container_investimento_` + index + `"> 
7570 
7571              <small class="ssp-card-oferta-curso__title-item">Investimento:</small> 
7572 
7573              <h6 class="ssp-card-oferta-curso__item-valor-investimento"><span>` + oferta.numeroMaxParcelasOferta + `x</span>R$ ` + formataValor(ajustarCasasDecimaisSemArredondar(strToFloat(oferta.precoVendaMaxParcelaOferta))) + `</h6> 
7574 
7575              <div class="ssp-card-oferta-curso__desconto-content"> 
7576                <p>Ou: <span class="ssp-card-oferta-curso__valor-antigo text-decoration-none">R$ ` + formataValor(oferta.precoVendaOferta) + `</span> à vista</p> 
7577              </div> 
7578 
7579            </div>   
7580 
7581          </div> 
7582
7583      } else { 
7584        result = result + ` 
7585          <div class="block-valor-total"> 
7586            <div class="investimento" id="container_investimento_` + index + `"> 
7587
7588   
7589        // Não mostrar mensagem de 30% de desconto em casos especificos 
7590        if(temDesconto){ 
7591          result = result + ` 
7592              <small class="ssp-card-oferta-curso__title-item font-weight-bold">Valor com 30% de desconto:</small> 
7593
7594
7595   
7596        if(oferta.precoCheioOferta == oferta.precoVendaOferta) {        
7597          result = result + ` 
7598              <small class="ssp-card-oferta-curso__title-item">Valor do curso:</small> 
7599              <h6 class="ssp-card-oferta-curso__item-valor-investimento"><span>` + oferta.numeroMaxParcelasOferta + `x</span>R$ ` + formataValor(oferta.precoVendaMaxParcelaOferta) + `</h6> 
7600 
7601              <div class="ssp-card-oferta-curso__desconto-content"> 
7602                <p>Ou <span class="ssp-card-oferta-curso__valor-antigo text-decoration-none">R$ ` + formataValor(oferta.precoVendaOferta) + `</span></p> 
7603              </div> 
7604            </div> 
7605            </div> 
7606          `   
7607        } else { 
7608          result = result + ` 
7609              <small class="ssp-card-oferta-curso__title-item">Investimento:</small> 
7610              <h6 class="ssp-card-oferta-curso__item-valor-investimento"><span>` + oferta.numeroMaxParcelasOferta + `x</span>R$ ` + formataValor(oferta.precoVendaMaxParcelaOferta) + `</h6> 
7611 
7612              <div class="ssp-card-oferta-curso__desconto-content"> 
7613                <p>De: <span class="ssp-card-oferta-curso__valor-antigo">R$ ` + formataValor(oferta.precoCheioOferta) + `</span></p> 
7614                <p>Por: <span class="ssp-card-oferta-curso__valor-desconto">R$ ` + formataValor(oferta.precoVendaOferta) + `</span></p> 
7615              </div> 
7616            </div> 
7617            </div> 
7618          `    
7619
7620
7621
7622 
7623    let dataBtnComprar = getObjBtnComprar(oferta); 
7624     
7625    // itens que são diferentes entre técnico e livres comprado a extensão   
7626    result = result + ` 
7627 
7628              <div class="ssp-card-oferta-curso__formas-pagamento-content"  id="container_forma_pgto_` + index + `"> 
7629                 
7630                <span>Saiba mais sobre:</span> 
7631 
7632                <div> 
7633                  <i class="ssp-card-oferta-curso__formas-pagamento-content__icon-credit-card"></i> 
7634                  <a id="myBtn_` + index + `" data-index="` + index + `" class="ssp-card-oferta-curso__formas-pagamento-content__title" style="font-weight: 600;" href="#">` + (temDesconto ? 'Descontos e pagamento' : 'Descontos e parcelamento') + `</a> 
7635                </div> 
7636 
7637              </div> 
7638 
7639            <div class="content-buttons"> 
7640 
7641              <div class="ssp-btn-group__content botoes-oferta-container_` + index + `"> 
7642 
7643                <a href="#a" id="btnComprar_` + index + `" data-espaco-ex="` + dataBtnComprar.dataEspacoEx + `" data-unidade="` + codigoUnidade + `" data-evento="` + oferta.codigoOferta + `" data-destino-compra="` + oferta.destinoCompra + `" data-index="` + index + `"  class="btn btn-lg btn-success w-100 mt-3 ` + dataBtnComprar.classeBotao + `" style="font-size:16px;font-weight: 600;">` + dataBtnComprar.textoBotao + `</a> 
7644 
7645              </div> 
7646 
7647            </div> 
7648 
7649          </div> 
7650 
7651        </div> 
7652
7653 
7654    return result 
7655
7656   
7657  var htmlModalLocalRealizacao = '<div id="modalLocalRealizacao_{index}" class="ssp-modal">' 
7658     htmlModalLocalRealizacao += '<div class="ssp-modal-local-realizacao">' 
7659     htmlModalLocalRealizacao += '<div class="ssp-modal-local-realizacao__title-content">' 
7660 
7661    htmlModalLocalRealizacao += '{tituloLocalRealizacao}' 
7662          
7663    htmlModalLocalRealizacao += '<i class="ssp-card-modal-local-realizacao__btn-close_{index} ssp-card-modal-forma-pagamento__btn-close"></i>' 
7664    htmlModalLocalRealizacao += '</div>' 
7665    htmlModalLocalRealizacao += '<div class="ssp-modal-local-realizacao__texto">' 
7666    htmlModalLocalRealizacao += '<p class="{classeTextoInfoLocalRealizacao}">A unidade {nomeUnidade} realizará as aulas em outro endereço, conforme informações abaixo:</p>' 
7667    htmlModalLocalRealizacao += '<p><span class="ssp-modal-local-realizacao__subtitle localEspacoExternoTexto_{index}">{textoFormatoHibrido}{localEspacoExterno}</span></p>' 
7668    htmlModalLocalRealizacao += '<address>' 
7669    htmlModalLocalRealizacao += '<span id="endereco_realizacao_{index}" class="{classeEnderecoRealizacao}">{ruaEspacoExterno}, {numeroEspacoExterno} {complementoEspacoExterno}<br></span>' 
7670    htmlModalLocalRealizacao += '<span id="bairro_realizacao_{index}" class="{classeBairroRealizacao}">Bairro: {bairroEspacoExterno}<br></span>' 
7671    htmlModalLocalRealizacao += '<span id="cidade_realizacao_{index}" class="{classeCidadeRealizacao}">Cidade: {cidadeEspacoExterno} - SP<br></span>' 
7672    htmlModalLocalRealizacao += '<span id="cep_realizacao_{index}" class="{classeCepRealizacao}">CEP: {cepEspacoExterno}</span>' 
7673    htmlModalLocalRealizacao += '</address>' 
7674    htmlModalLocalRealizacao += '<div class="btn ssp-modal-local-realizacao__btn-content">' 
7675    htmlModalLocalRealizacao += '<a class="btn ssp-modal-local-realizacao__btn {classeEntendi} ssp-modal-local-realizacao__btn_{index}" href="#a">Entendi</a>' 
7676    htmlModalLocalRealizacao +='</div>' 
7677    htmlModalLocalRealizacao +='</div>' 
7678    htmlModalLocalRealizacao +='</div>' 
7679    htmlModalLocalRealizacao +='</div>'; 
7680   
7681    var htmlModalAntesCompra = '<div id="modalAntesCompra_{index}" class="ssp-modal">' 
7682      htmlModalAntesCompra += '<div class="ssp-modal-local-realizacao">' 
7683    htmlModalAntesCompra += '<div class="ssp-modal-local-realizacao__title-content">' 
7684    htmlModalAntesCompra += '<h6 class="ssp-modal-local-realizacao__title"> LEMBRETE IMPORTANTE!</h6>' 
7685    htmlModalAntesCompra += '<i class="ssp-card-modal-antes-compra__btn-close_{index} ssp-card-modal-forma-pagamento__btn-close"></i>' 
7686    htmlModalAntesCompra += '</div>' 
7687    htmlModalAntesCompra += '<div class="ssp-modal-local-realizacao__texto">' 
7688    htmlModalAntesCompra += '<p class="{classeTextoInfoLocalRealizacao}">A unidade {nomeUnidade} realizará as aulas em outro endereço, conforme informações abaixo:</p>' 
7689    htmlModalAntesCompra += '<p><span class="ssp-modal-local-realizacao__subtitle localEspacoExternoTexto_{index}">{textoFormatoHibrido}{localEspacoExterno}</span></p>' 
7690    htmlModalAntesCompra += '<address>' 
7691    htmlModalAntesCompra += '<span id="endereco_realizacao_{index}" class="{classeEnderecoRealizacao}">{ruaEspacoExterno}, {numeroEspacoExterno} {complementoEspacoExterno}<br></span>' 
7692    htmlModalAntesCompra += '<span id="bairro_realizacao_{index}" class="{classeBairroRealizacao}">Bairro: {bairroEspacoExterno}<br></span>' 
7693    htmlModalAntesCompra += '<span id="cidade_realizacao_{index}" class="{classeCidadeRealizacao}">Cidade: {cidadeEspacoExterno} - SP<br></span>' 
7694    htmlModalAntesCompra += '<span id="cep_realizacao_{index}" class="{classeCepRealizacao}">CEP: {cepEspacoExterno}</span>' 
7695    htmlModalAntesCompra += '</address>' 
7696    htmlModalAntesCompra += '<div class="btn ssp-modal-local-realizacao__btn-content">' 
7697    htmlModalAntesCompra += '{componentBuyConfirmation}' 
7698    htmlModalAntesCompra += '<a id="btnBolsaLocal_{index}" class="btn btn-lg btn-info w-100 mt-3" href="{linkBtnBolsa}" target="_blank" style="display:none;">OK, inscrever para bolsa</a>' 
7699    htmlModalAntesCompra += '<a class="ssp-modal-local-realizacao__btn btn btn-lg w-100 mt-3 ssp-card-modal-selecionar-outro__btn-close_{index}" href="#a" >Selecionar outra turma</a>' 
7700    htmlModalAntesCompra +='</div>' 
7701    htmlModalAntesCompra +='</div>' 
7702    htmlModalAntesCompra +='</div>' 
7703    htmlModalAntesCompra +='</div>'; 
7704          
7705   var htmlSlickAreaDiasSemana = '<div class="ssp-card-oferta-curso__dia-hora-item">' 
7706   	 htmlSlickAreaDiasSemana +='<p class="ssp-card-oferta-curso__dia-hora-item__dia">'  
7707     htmlSlickAreaDiasSemana += '<span data-dia-hora="dias-semana">{diasSemana}</span>' 
7708     htmlSlickAreaDiasSemana += '<span data-dia-hora="horário">{horasSemana}</span>' 
7709     htmlSlickAreaDiasSemana += '</p>' 
7710   	 htmlSlickAreaDiasSemana += '</div>'; 
7711    	         
7712      
7713  //Montar object push - google tag manager - 5 
7714  function criaItensEcommerce(ofertas){ 
7715 
7716    let nomeUnidadeSelecionada = objsTela.unidades[ultimaUnidade].nome 
7717 
7718    let dadosCurso = { 
7719      //Pegar do freemarker  
7720        tituloComercial : $('[name="tituloComercial"]').val(), 
7721        tipoCurso : $('[name="nomeCategoriaTipoCurso"]').val(), 
7722        formato : $('[name="formato"]').data("formato") 
7723
7724 
7725    let ecommerceObject = { 
7726 
7727      item_id: "", //codOferta - oferta, 
7728			item_name: "", //Nome do curso - curso, 
7729			affiliation: "", //nome da unidade - oferta, 
7730			currency: "BRL", //Moeda - "BRL", 
7731			discount: "", //desconto - oferta, 
7732			index: "", //indice da lista - i, 
7733			item_brand: "Senac SP", //"Senac SP", 
7734			item_category: "", //categoria do curso - curso, 
7735			item_list_id: "", //"60", 
7736			item_list_name: "", //"São Carlos" - Oferta, 
7737			item_variant: "", //modalidade - curso, 
7738			price: "", //preco cheio - oferta, 
7739			quantity: 1 
7740 
7741
7742 
7743    let itensEcommerce = new Map(); 
7744 
7745    for(var i = 0; i < ofertas.length; i++){ 
7746 
7747      itensEcommerce.set(ofertas[i].codigoOferta, { 
7748 
7749            item_id: ofertas[i].codigoOferta, //codOferta - oferta, 
7750            item_name: dadosCurso.tituloComercial, //Nome do curso - curso, 
7751            affiliation: nomeUnidadeSelecionada, //nome da unidade - oferta, 
7752            currency: "BRL", //Moeda - "BRL", 
7753            discount: parseFloat(ofertas[i].precoCheioOferta - ofertas[i].precoVendaOferta).toFixed(2), //desconto - oferta, 
7754            index: i, //indice da lista - i, 
7755            item_brand: "Senac SP", //"Senac SP", 
7756            item_category: dadosCurso.tipoCurso, //categoria do curso - curso, 
7757            item_list_id: objsTela.unidades[ultimaUnidade].codigoUnidade, //"60", 
7758            item_list_name: nomeUnidadeSelecionada, //"São Carlos" - Oferta, 
7759            item_variant: dadosCurso.formato, //modalidade - curso, 
7760            price: parseFloat(ofertas[i].precoCheioOferta).toFixed(2), //preco cheio - oferta, 
7761            quantity: 1 
7762 
7763
7764
7765
7766 
7767    return itensEcommerce; 
7768
7769   
7770  //EMED - ELEMENTOS DINAMICOS 
7771  const htmlSlickAreaEmed = function(oferta){ 
7772    var btnid = 'myBtn_' + oferta.indice; 
7773    const diasHorarios = function(oferta){ 
7774      return oferta.diasDaSemanaOferta.join(', ').toLowerCase();  
7775       
7776
7777 
7778 
7779    return ` 
7780        <div class="ssp-ofertas-emed__card codigoOferta_`+ oferta.codigoOferta + `"> 
7781   
7782        <div class="ssp-ofertas-emed__card-info-turma"> 
7783   
7784            <div class="item-content"> 
7785                <i class="fas fa-calendar-alt calendar-icon-turma"></i> 
7786                <p class="title-turma">`+ oferta.titulo +`</p> 
7787                <span class="text-default" data-info="info-turma">Alunos na turma: <strong>até `+ oferta.qtdeTotalVagas +`</strong></span> 
7788            </div> 
7789   
7790            <div class="content-previsao-inicio-termino"> 
7791   
7792                <div class="item-content"> 
7793                    <span class="text-default">Previsão de início:</span> 
7794                    <span class="text-default-lg">`+ formatarDataEmed(oferta.dataInicio,oferta.etapa,false) +`</span> 
7795                </div> 
7796   
7797                <div class="item-divisor"></div> 
7798   
7799                <div class="item-content"> 
7800                    <span class="text-default">Previsão de término:</span> 
7801                    <span class="text-default-lg">`+ formatarDataEmed(oferta.dataFim,oferta.etapa,true) +`</span> 
7802                </div> 
7803   
7804            </div> 
7805   
7806   
7807            <div class="item-divisor"></div> 
7808   
7809            <div class="item-content"> 
7810                <span class="text-default">Dias e horários das aulas:</span> 
7811                <span class="text-default-lg" style="text-transform: capitalize;">`+ diasHorarios(oferta) +`</span> 
7812                <span class="text-default-lg">`+ oferta.horaInicio.replace(':', 'h') + ' às ' + oferta.horaFimOferta.replace(':', 'h') +`</span> 
7813            </div> 
7814             
7815        </div> 
7816   
7817        <div class="ssp-ofertas-emed__card-info-investimento"> 
7818            <p class="title-investimento">Investimento anual:</p> 
7819   
7820            <div class="item-content-investimento"> 
7821                <span class="txt-parcelas">Até `+ oferta.numeroMaxParcelasOferta +`x</span> 
7822                <span class="txt-valor-parcela">R$ `+ formataValor(oferta.precoVendaMaxParcelaOferta) +`</span> 
7823            </div> 
7824   
7825            <div class="item-content-investimento"> 
7826                <p class="txt-boleto-cartao">(boleto bancário ou cartão de crédito)</p> 
7827            </div> 
7828   
7829            <div class="item-content-investimento"> 
7830                <i class="fas fa-credit-card icon-cartao-credito"></i> 
7831                <a id="`+ btnid +`" data-index="`+ oferta.indice +`" href="#" class="link-descontos-parcelamentos">Descontos e Parcelamentos</a> 
7832            </div> 
7833               
7834        </div> 
7835   
7836    </div> 
7837 
7838    `; 
7839
7840   
7841    
7842   function loadCursosVocePodeGostar(){ 
7843       
7844    if(isEmed){ 
7845      var url = urlSearchCursosPodeGostarEmed 
7846        .replace('\{groupId\}', groupId) 
7847        .replace('\{tiposDeCurso\}',$('[name="idTipoCurso"]').val()) 
7848        .replace('\{limit\}', 12) 
7849        .replace('\{articleId\}', $('[name="articleId"]').val()); 
7850    }else{ 
7851      var url = urlSearchCursosPodeGostar 
7852        .replace('\{companyId\}',themeDisplay.getCompanyId()) 
7853        .replace('\{groupId\}', groupId) 
7854        .replace('\{userId\}',themeDisplay.getUserId()) 
7855        .replace('\{articleId\}',$('[name="articleId"]').val()) 
7856        .replace('\{limit\}', 12); 
7857
7858 
7859   
7860       $.ajax({ 
7861           url :  url, 
7862           type : 'get', 
7863           beforeSend: function(){ 
7864             loading('#slider-curso'); 
7865
7866       }) 
7867       .done(function(cursos){ 
7868          
7869         if(cursos.length > 0){ 
7870   
7871           cursos = JSON.parse(cursos); 
7872            
7873           if(isEmed) cursos = cursos['cursos']; 
7874            
7875           if(cursos.length > 0) $('#section-cursos-voce-pode-gostar').removeClass('d-none'); 
7876           else { 
7877             $('#section-cursos-voce-pode-gostar').addClass('d-none'); 
7878             return; 
7879
7880            
7881           var articles = []; 
7882            
7883            $.each(cursos, function(k, c){ 
7884             articles.push(c.articleId); 
7885            }); 
7886             
7887           //Verifica a situação dos botoes de inscrições e bolsa 
7888          $.ajax({ 
7889                url :  '/o/senac-content-services/verificaBotoesInscricaoEBolsa/'+groupId+'/'+articles.join(','), 
7890                type : 'get' 
7891            })  
7892            .done(function(infoBotoes){ 
7893               
7894              if(infoBotoes.length > 0) { 
7895                 
7896                  infoBotoes = JSON.parse(infoBotoes); 
7897                   
7898                  $('#slider-curso').empty(); 
7899   
7900                      $.each(cursos, function(k, c){ 
7901                    	  $('#slider-curso').append(buildCardCurso(c, infoBotoes)); 
7902         
7903                      }); 
7904         
7905                      $('#slider-curso').addClass( 
7906                      'slick-area slick-area--md-bleed slider-container slick-area-cursos-pode-gostar'); 
7907         
7908                      sliderCurso('.slick-area-cursos-pode-gostar'); 
7909
7910            }); 
7911
7912   
7913        }) 
7914        .fail(function(jqXHR, textStatus, msg){ 
7915            // alert(msg); 
7916        }); 
7917   
7918
7919   
7920   /* 
7921    * Armazena a navegação em cookies, se habilitado 
7922    */ 
7923  $(document).on("click", ".ck-curso", function() { 
7924      
7925  //Verifica se o cookie está habilitado 
7926   if(getCookie('portalSenacCookie') != null){ 
7927      
7928    var articleId = $(this).data('ck'); 
7929    manageCookieArray('ck-cursos', articleId); 
7930        
7931
7932   
7933   }); 
7934   
7935   
7936 
7937   
7938   
7939  $(function(){ 
7940   
7941   if($('#unidades-ofertas').find('option').length ==0){ 
7942   
7943     $('.ssp-container-selecione-unidade').addClass('d-none') 
7944   
7945
7946   
7947  }); 
7948   
7949     function avisoNovasTurmas(){ 
7950        
7951       
7952       window.event.preventDefault() 
7953         
7954       //var unidadeSelecionada = $('#select-registro-interesse').val(); 
7955       //este select tem 2 valores separados por @ -> categoryId@codUnidade 
7956      //  var unidadeSelecionada = $('#unidades-ofertas').val(); 
7957        
7958       //Código fixo quando Senac Ao Vivo 
7959       var codUnidadeSelectRegInt = (isAoVivo) ? codUnidadeSenacAoVivo : $('#unidades-ofertas').val().split("@")[1]; 
7960         
7961      //  if(codUnidadeSelectRegInt && codUnidadeSelectRegInt.length){ 
7962          
7963         //Se ja tiver logado , redireciona para o registro 
7964         if(getCookie('ticket') == null){ 
7965            
7966           //Abre modal login 
7967               $('#modal-login').removeClass('d-none'); 
7968            
7969         }else{ 
7970            
7971          abrirModalRegistroInteresse(codUnidadeSelectRegInt); 
7972                  
7973            verificaBtnEnviarRegistroInteresseAtivo(); 
7974
7975          
7976         window.onclick = function(event) { 
7977            $('[id="modal-registro-interesse"]').each(function(index,_modal){ 
7978                if (event.target == _modal) { 
7979                   $('#modal-registro-interesse').addClass('d-none'); 
7980                   $("body").removeClass("overflow-hidden") 
7981
7982            }); 
7983
7984              
7985      //  } 
7986
7987     function login(){ 
7988      var unidadeSelecionada 
7989      var codUnidadeSelectRegInt 
7990      doLogin({ 
7991        user: $('#login-email-modal').val(), 
7992        pass: $('#login-password-modal').val(), 
7993        btnLoadingSelector: '#btnLogin', 
7994        before: () => { 
7995          $('#mensagem-erro-login').addClass('d-none') 
7996           
7997          unidadeSelecionada = $('#unidades-ofertas').val(); 
7998          codUnidadeSelectRegInt = (isAoVivo) ? codUnidadeSenacAoVivo : $('#unidades-ofertas').val().split("@")[1]; 
7999        }, 
8000        done: (data) => { 
8001          var loginData = JSON.parse(data); 
8002           
8003          if(loginData.status == 200 || loginData.status == 201){				 
8004            //Após logar-se, exibe o modal p/registro de interesse 
8005            abrirModalRegistroInteresse(codUnidadeSelectRegInt); 
8006            verificaBtnEnviarRegistroInteresseAtivo(); 
8007            //esconde o modal de login 
8008            $('#modal-login').addClass('d-none'); 
8009          }  
8010        }, 
8011        errorMessageSelector: '#mensagem-erro-login', 
8012        error: (err) => console.error(err) 
8013      }) 
8014
8015   
8016  function registroSelecionaTodosDias(){ 
8017     
8018    if($(this).hasClass('ssp-week-day-active')){ 
8019      $(this).removeClass('ssp-week-day-active') 
8020       $('.ssp-week-day').removeClass('ssp-week-day-active') 
8021    }else{ 
8022      $(this).addClass('ssp-week-day-active') 
8023      $('.ssp-week-day').addClass('ssp-week-day-active') 
8024
8025        
8026    verificaBtnEnviarRegistroInteresseAtivo(); 
8027
8028   
8029  function registroSelecionaTodosPeriodos(){ 
8030     
8031    if($(this).is(':checked')){ 
8032      $('.ssp-card-registro-interesse__check-itens-content.periodos-registro-interesse input[type=checkbox]').prop('checked', true); 
8033    }else{ 
8034      $('.ssp-card-registro-interesse__check-itens-content.periodos-registro-interesse input[type=checkbox]').prop('checked', false); 
8035
8036     
8037    verificaBtnEnviarRegistroInteresseAtivo(); 
8038
8039  $('.turmas-registro-interesse input[type=checkbox]').on('click', function() { 
8040    var $selecionado = $(this); 
8041    if ($selecionado.is(":checked")) { 
8042      $('.turmas-registro-interesse input[type=checkbox]').prop("checked", false); 
8043      $selecionado.prop("checked", true); 
8044    } else { 
8045      $selecionado.prop("checked", false); 
8046
8047}); 
8048     function enviarRegistroInteresse(){ 
8049       
8050	  const codigoUsr = getCookie('codigo'); 
8051	   
8052	  if(codigoUsr == null){ 
8053		  //Sem o cookie refaz o login 
8054		  $('#modal-registro-interesse').addClass('d-none'); 
8055	      $('body').removeClass('overflow-hidden'); 
8056	      $('#modal-login').removeClass('d-none'); 
8057	      return; 
8058
8059	   
8060      var codigoFT = $('[name="codigoFT"]').val(); 
8061       
8062      var unidades = new Set(); 
8063       
8064      var diasSemana = ''; 
8065       
8066      //Senac ao vivo nao tem opçao de dias da semana nem unidades 
8067      if(isAoVivo){ 
8068        unidades.add(codUnidadeSenacAoVivo); 
8069      }else{ 
8070          $.each($('.ssp-week-day').not('#todosDias'), function(k, v){ 
8071              if($(this).hasClass('ssp-week-day-active')){ 
8072                diasSemana += $(this).text()+','; 
8073
8074          }); 
8075             
8076          if(diasSemana.length > 0) diasSemana = diasSemana.slice(0, -1); 
8077           
8078          $.each($('.ssp-card-registro-interesse__select'), function(k,item){ 
8079               
8080            unidades.add(item.value); 
8081          }); 
8082
8083 
8084       
8085      var periodos = ''; 
8086       
8087      $.each($('.periodos-registro-interesse input[type=checkbox]').not('#check-todos-periodos'), function(k,v){ 
8088        if($(this).is(':checked')){ 
8089          periodos += $(this).val()+','; 
8090
8091      }); 
8092 
8093      var turmas = ''; 
8094 
8095      $.each($('.turmas-registro-interesse input[type=checkbox]').not('#check-todos-periodos'), function(k, v) { 
8096          if ($(this).is(':checked')) { 
8097              turmas += $(this).val() + ','; 
8098
8099      }); 
8100 
8101      if (periodos.length > 0) periodos = periodos.slice(0, -1); 
8102      if (turmas.length > 0) turmas = turmas.slice(0, -1); 
8103 
8104      var usuarioNotificado = false; 
8105       
8106      loadingSubmitButton('#enviar-registro-interesse-btn'); 
8107 
8108      unidades.forEach(function(codigoUnidade) { 
8109          var data = { 
8110              codigoFT: codigoFT, 
8111              codigo: codigoUsr, 
8112              diasSemana: diasSemana, 
8113              periodos: periodos, 
8114              turmas, turmas, 
8115              codigoUnidade: codigoUnidade, 
8116              interesseBolsa: 'N', 
8117              isEmed: isEmed ? 'S' : 'N' 
8118          }; 
8119 
8120          const url = urlRegistroInteresse; 
8121 
8122          $.ajax({ 
8123              url: url, 
8124              method: 'POST', 
8125              data: JSON.stringify(data), 
8126              headers: { 
8127                  'Accept': 'application/json', 
8128                  'Content-Type': 'application/json' 
8129              }, 
8130          }).done( 
8131              function(retornoData) { 
8132 
8133                  var retornoData = JSON.stringify(retornoData); 
8134 
8135                  if (retornoData.length > 0) { 
8136             
8137                    cleanLoadingSubmitButton('#enviar-registro-interesse-btn'); 
8138                     
8139                      var retorno = JSON.parse(retornoData); 
8140 
8141                      if (retorno.status == 200 || retorno.status == 201) { 
8142               
8143                        //Evita que o usuário recebe um email para cada unidade de interesse 
8144                        if(usuarioNotificado) return; 
8145                         
8146                          //Mensagem de sucesso registro interesse 
8147                          $('#modal-registro-interesse-sucesso').removeClass('d-none'); 
8148 
8149                          var prefixUrl = themeDisplay.getLayoutRelativeURL(); 
8150 
8151                          if (prefixUrl.indexOf('staging/') > 1) 
8152                              prefixUrl = prefixUrl.substring(0, prefixUrl.lastIndexOf('staging/') + 8); 
8153                          else 
8154                              prefixUrl = HOST; 
8155 
8156                          $('#btn-voltar-home').attr('href', prefixUrl); 
8157 
8158                          //Busca os dados do nome do usuário logado 
8159                          var username = getCookie('name').split(' ')[0]; 
8160 
8161                          //Prioridade para nomeSocial 
8162                          if (getCookie('nome_social') != null) { 
8163                              var nomeSocial = getCookie('nome_social').replace(/['"]+/g, ''); 
8164 
8165                              if (nomeSocial.length > 0) username = getCookie('nome_social'); 
8166 
8167
8168 
8169                          username = username.replace(/['"]+/g, ''); 
8170						   
8171                          var unidadesSel = getUnidadesSelecionadasRI(); 
8172                           
8173                          //Disara um email para o usuário interessado              
8174                          var data = { 
8175                              emailInteressado: getCookie('email'), 
8176                              nomeInteressado: username, 
8177                              tituloCurso: $('.ssp-card-detalhe-curso__title').text(), 
8178                              unidades: unidadesSel.unidades, 
8179                              unidadesPrefix: unidadesSel.unidadesPrefix 
8180                          }; 
8181 
8182                          $.ajax({ 
8183                              url: urlRegistroInteresseEmailInteressado, 
8184                              method: 'POST', 
8185                              data: JSON.stringify(data), 
8186                              headers: { 
8187                                  'Accept': 'application/json', 
8188                                  'Content-Type': 'application/json' 
8189                              }, 
8190                          }).done(function(retornoData) {}); 
8191 
8192              				usuarioNotificado = true; 
8193               
8194                          window.onclick = function(event) { 
8195                              $('[id="modal-registro-interesse-sucesso"]').each(function(index, _modal) { 
8196                                  if (event.target == _modal) { 
8197                                      $('#modal-registro-interesse-sucesso').addClass('d-none'); 
8198                                      $('#modal-registro-interesse').addClass('d-none'); 
8199                                      $("body").removeClass("overflow-hidden") 
8200
8201                              }); 
8202
8203 
8204                      } else { 
8205                          //Mensagem de erro registro interesse 
8206                          $('#modal-registro-interesse-erro').removeClass('d-none'); 
8207
8208                  } else { 
8209                      //Mensagem de erro registro interesse 
8210                      $('#modal-registro-interesse-erro').removeClass('d-none'); 
8211
8212              }).fail(function(){ 
8213				  cleanLoadingSubmitButton('#enviar-registro-interesse-btn'); 
8214				  $('#modal-registro-interesse-erro').removeClass('d-none'); 
8215			  }); 
8216      }); 
8217
8218   
8219  function verificaBtnEnviarRegistroInteresseAtivo(){ 
8220     
8221    var diasSemanaSelecionado = false; 
8222    var periodoSelecionado = false; 
8223    var turmaSelecionada = false; 
8224    var politicaPrivacidadeSelecionado = false; 
8225     
8226     
8227    $.each($('.periodos-registro-interesse input[type=checkbox]').not('#check-todos-periodos'), function(k,v){ 
8228      if($(this).is(':checked')) 
8229        periodoSelecionado = true; 
8230    }); 
8231 
8232    $.each($('.turmas-registro-interesse input[type=checkbox]').not('#check-todos-periodos'), function(k,v){ 
8233      if($(this).is(':checked')) 
8234        turmaSelecionada = true; 
8235    }); 
8236     
8237    if($('#check-politica-privacidade').is(':checked')) politicaPrivacidadeSelecionado = true; 
8238     
8239    var ativo = true 
8240     
8241    //Caso tenha algum dos selects de unidade sem uma opção válida selecionada 
8242    if(!isAoVivo) 
8243      ativo = ativo && !Array.from($('.ssp-card-registro-interesse__select.unidades')).filter(sel => !$(sel).val()).length 
8244     
8245    ativo = ativo && periodoSelecionado && politicaPrivacidadeSelecionado; 
8246     
8247    if(!isAoVivo && !isEmed){ 
8248       
8249        $.each($('.ssp-week-day').not('#todosDias'), function(k, v){ 
8250            if($(this).hasClass('ssp-week-day-active')) 
8251              diasSemanaSelecionado = true; 
8252          }); 
8253      ativo = ativo && diasSemanaSelecionado; 
8254       
8255
8256 
8257    if(isEmed) 
8258      ativo = ativo && turmaSelecionada; 
8259     
8260    if(ativo) 
8261        $('#enviar-registro-interesse-btn').attr("disabled", false); 
8262    else 
8263        $('#enviar-registro-interesse-btn').attr("disabled", true); 
8264
8265   
8266    function loadPlanoCurso(){ 
8267       
8268      const urlGetPlanoCurso = urlPlanoCurso 
8269											 
8270      .replace('\{codigoFT\}',  $('[name="codigoFT"]').val()) 
8271      .replace('\{dataEfetiva\}', $('[name="dataEfetivaSTR"]').val()); 
8272   
8273        $.ajax({ 
8274            url:urlGetPlanoCurso, 
8275            method:'get', 
8276            crossDomain: true, 
8277            dataType: 'html', 
8278            success: function( data ) { 
8279   
8280   
8281              //Atualiza o link com o plano de curso do servi¿o (ja retorna o texto) 
8282              $('#plano-curso').append('<br/>'+data);  
8283            }, 
8284            error: function(data){ 
8285               
8286              console.log('Não existe a URL do plano de curso'); 
8287								 
8288
8289         
8290          }); 
8291
8292     
8293  function checkCursoTrampolim(){ 
8294    return $('[name="codigoFT"]').val() == "24493";  
8295
8296   
8297  /*function verificaOfertaValida(oferta){ 
8298       
8299    if(oferta['precoCheioOferta'] == '' || oferta['precoVendaOferta'] == '' || oferta['numeroMaxParcelasOferta'] == '' || oferta['precoVendaMaxParcelaOferta']  == '') 
8300      return false; 
8301     
8302    var atual = new Date(); 
8303   
8304    var dataOfertaPartes = oferta['dataInicio'].split('/'); 
8305     
8306    var dataOferta = new Date(dataOfertaPartes[2], dataOfertaPartes[1] - 1, dataOfertaPartes[0]); 
8307     
8308    var dataLimiteMatriculaOfertaPartes = ""; 
8309    var dataLimiteMatriculaOferta = ""; 
8310     
8311    if(oferta['dtLimiteMatricula'] != ""){ 
8312    dataLimiteMatriculaOfertaPartes = oferta['dtLimiteMatricula'].split('-'); 
8313      dataLimiteMatriculaOferta = new Date(dataLimiteMatriculaOfertaPartes[0], dataLimiteMatriculaOfertaPartes[1] - 1, dataLimiteMatriculaOfertaPartes[2] ,atual.getHours(),atual.getMinutes(),atual.getSeconds(),atual.getMilliseconds());  
8314     
8315
8316     
8317     
8318    //Só deve aparecer ofertas D-1 . Se ela iniciou, aparece se o campo dtLimiteMatr estiver preenchido e com data até o dia de hoje  
8319    if(dataOferta <= atual) 
8320      if(dataLimiteMatriculaOferta == "" || (dataLimiteMatriculaOferta != "" &&  atual.getTime() > dataLimiteMatriculaOferta.getTime())) 
8321        return false; 
8322     
8323    return true; 
8324  }*/ 
8325   
8326   
8327  function loadServerDate(){ 
8328   
8329    $.ajax({ 
8330      url:urlGetServerT, 
8331      method:'get', 
8332      dataType: 'json', 
8333      cache: 'false', 
8334      headers: { 
8335      'Cache-Control': 'no-store, no-cache, max-age=0', 
8336      'Expires': '0', 
8337      'Pragma': 'no-cache' 
8338      }, 
8339      success: function( data ) { 
8340        todayG = new Date(data.year,(data.month - 1),data.day,(data.hour),data.minutes,data.seconds); 
8341        startTimer(); 
8342
8343    }); 
8344     
8345
8346   
8347   function handleVisibilityChange() { 
8348     
8349     if (!document[hidden] ){ 
8350      restartTimer(); 
8351
8352     
8353
8354   
8355  function restartTimer(){ 
8356     
8357    if(restartTimeout == null){ 
8358      loadServerDate(); 
8359      restartTimeout = setTimeout(function(){ 
8360        restartTimeout = null; 
8361      }, 5000); 
8362
8363     
8364
8365    
8366	 function startTimer(){ 
8367		 
8368		var mSeconds = todayG.getTime(); 
8369		if(interval01 != null){ 
8370			clearInterval(interval01); 
8371
8372		interval01 = setInterval(function(){ 
8373			todayG.setTime(todayG.getTime() + 1000); 
8374		}, 1000); 
8375		 
8376		if(interval15 != null){ 
8377			clearInterval(interval15); 
8378
8379		interval15 = setInterval(function(){ 
8380			mSeconds = mSeconds + 15000; 
8381			todayG.setTime(mSeconds); 
8382		}, 15000); 
8383		 
8384
8385   
8386  function checkIsAoVivo(){ 
8387    isAoVivo = $("input[name='formato']").attr("data-formato") == nomeFormatoAoVivoDxp; 
8388
8389   
8390   
8391  //Ao clicar na setinha next do slider, busca dinamicamente uma proxima oferta 
8392  function buscaProximaOferta(){ 
8393    //Zera variável que controla existência de ofertas com bolsa 
8394    //ofertasComBolsa = false; 
8395  	  
8396     //Verificamos se a ultima oferta já foi exibida, para evitar de fazer novas buscas 
8397     if(carregouUltimaOferta)  
8398        return; 
8399 
8400     //Fazemos o cálculo do que está sendo exibido, para verificar se existe apenas um card 'escondido'. Caso tenha apenas um, a busca deve ser executada, caso contrário não.	 
8401     var totalOfertasSlick = $('#turmas-container .slick-area__item').length; 
8402     //Pegamos o índice da oferta do meio (central) 
8403     var currentSliderIndex = parseInt($('.slick-current').attr('data-slick-index')); 
8404 
8405     var totalOfertasADireita = totalOfertasSlick - currentSliderIndex; 
8406 
8407     //Se o total de ofertas à direita for maior a 2 não precisa realizar a busca 
8408     if(totalOfertasADireita > 2)  
8409        return; 
8410 
8411	 startOfertaParam = endOfertaParam; 
8412	 endOfertaParam += 16; 
8413	  
8414     const codigoFT = $('[name="codigoFT"]').val(); 
8415  	 const dataEfetivaOferta = $('[name="dataEfetivaSTR"]').val(); 
8416	 
8417  	 var unidadeCategoryId = ''; 
8418     var unidadeCodigoSelect = ''; 
8419  	 
8420  	if(isAoVivo){ 
8421  	   
8422  		$.each(objsTela.unidades, function(k,unidade){ 
8423  			unidadeCategoryId += unidade['categoryId']+','; 
8424      	}); 
8425  		 
8426  		//tirando ultima virgula 
8427  	    unidadeCategoryId = unidadeCategoryId.substring(0,unidadeCategoryId.length - 1); 
8428  	   
8429  	}else{ 
8430  		 var splitted = $('#unidades-ofertas').val().split("@"); 
8431  		 unidadeCategoryId = splitted[0]; 
8432       unidadeCodigoSelect = splitted[1]; 
8433
8434     
8435    var params = new URLSearchParams(); 
8436    params.set('codigoFTOferta',codigoFT) 
8437    params.set('dataEfetivaOferta',dataEfetivaOferta) 
8438    params.set('categoryIds',unidadeCategoryId) 
8439    params.set('start',startOfertaParam) 
8440    params.set('end',endOfertaParam) 
8441    params.set('inscricaoAberta', $('#chkInscricao').prop('checked')) 
8442    params.set('bolsaAberta', $('#chkBolsa').prop('checked')) 
8443    params.set('cursoArticleId', $('[name="articleId"]').val() || ''); 
8444 
8445    if($('#chkBolsa').prop('checked')){ 
8446    	params.set('considerarDataBolsaFutura', true) 
8447
8448     
8449    const url = urlSearchOferta + '?' + params.toString() 
8450 
8451    $.ajax({ 
8452      url:url, 
8453      method:'get', 
8454      dataType:'json' 
8455    }).done( 
8456      function(data){ 
8457         
8458        if(data.length > 0){ 
8459          var indiceOferta = startOfertaParam; 
8460 
8461        	for (var index = 0; index < data.length; index++) { 
8462        		 
8463				var ofertaJSON = data[index]; 
8464	            var oferta = getOfertaObjectFromJson(ofertaJSON,index); 
8465				             
8466	            //Verificamos se a oferta buscada já existe na tela (que ocorre quando chega na última oferta) 
8467	            if($('.codigoOferta_'+oferta.codigoOferta).length > 0){ 
8468	              console.log('Ja tem a oferta '+oferta.codigoOferta); 
8469	              carregouUltimaOferta = true; 
8470	              break; 
8471
8472	 
8473	            //guardo em um map a oferta e qual unidade é, para utilizar depois no populaOferta para o aoVivo                
8474	            ofertaUnidadeMap.set(oferta['codigoOferta'],mapUnidadesIds.get(parseInt(ofertaJSON.unidadeCategoryIds))); 
8475	      
8476	            ofertasMap.set(oferta.codigoOferta, oferta); 
8477	 
8478	            if(isAoVivo) 
8479	            	objsTela.ofertasAoVivoTodasUnidades.push(oferta); 
8480	 
8481	             //O indice é igual ao ultimo elemento buscado - 1 
8482	             var i = indiceOferta; 
8483	             oferta['indice'] = i; 
8484	 
8485	             if(isAoVivo) 
8486	                codigoUnidade = ofertaUnidadeMap.get(oferta.codigoOferta); 
8487	             else codigoUnidade = unidadeCodigoSelect; 
8488	 
8489	              
8490	             montaHTMLOferta(oferta, i, codigoUnidade, true);  
8491	             montaHTMLModalFormaPgto(oferta, i, codigoUnidade);  
8492 
8493	             montaHTMLModalLocalRealizacao(oferta, i);  
8494	             montaHTMLModalAntesCompra(oferta, i, codigoUnidade); 
8495	             verificaBotaoBolsaSS(oferta); 
8496	             verificaCursoAprendizagem(i); 
8497	             verificaCursoTrampolim(i); 
8498	              
8499	             associaEventoBtnFormaPagamento(i); 
8500	             associaEventoBtnComprar(i);  
8501	             associaEventoBtnComprarDentroFormaPgto(i); 
8502	             associaEventoBtnLocalRealizacao(i); 
8503	             associaEventosFecharModal(i); 
8504 
8505                 if($('[name="tipoCurso"]').val() == 'extensao'){ 
8506                   associaEventoBtnConheca(i); 
8507                   associaEventoBtnComprarConhecaDescontoOk(i); 
8508                   associaEventoBtnComprarConhecaDescontoNot(i); 
8509                   associaEventoBtnAlunoNao(i); 
8510                   associaEventoBtnAlunoSim(i); 
8511                    
8512
8513                  
8514               indiceOferta++; 
8515
8516           
8517          controlaPaginaBolsa(); 
8518
8519
8520    ); 
8521     
8522
8523 
8524  function setUrlParam(key, value) { 
8525    const url = new URL(window.location.href) 
8526 
8527    if(value) 
8528      url.searchParams.set(key, value); 
8529    else 
8530      url.searchParams.delete(key); 
8531 
8532    window.history.pushState({}, '', url.toString()) 
8533
8534   
8535   function selectFilter(paramkey, el) { 
8536    setUrlParam(paramkey, el.prop("checked")) 
8537    const currentUnidadeFriendlyURLSelected = $('#unidades-ofertas').find('option').filter(':selected').attr('data-unidade-friendly-url') 
8538    loadUnidades(!isAoVivo, $('[data-unidade-friendly-url="' + currentUnidadeFriendlyURLSelected + '"]').val()) 
8539 
8540    if($('#chkInscricao').prop("checked") || $('#chkBolsa').prop("checked")) $('#msgFiltroAplicado').show() 
8541    else $('#msgFiltroAplicado').hide() 
8542
8543    
8544  function defineCurrentUrl(ev) { 
8545    const currentUnidadeFriendlyURLSelected = $(ev.target).find('option').filter(':selected').attr('data-unidade-friendly-url') 
8546 
8547    const hasPathWeb = window.location.pathname.includes('/web') 
8548    const hasPathGuest = window.location.pathname.includes('/guest') 
8549 
8550    let currentPath = window.location.pathname 
8551    currentPath = hasPathWeb ? currentPath.substring(4) : currentPath 
8552    currentPath = hasPathGuest ? currentPath.substring(6) : currentPath 
8553 
8554    objsTela.unidadesRegistroInteresse.forEach(unidade => currentPath = currentPath.replace('/' + unidade.friendlyURL, '')) 
8555 
8556    currentPath = (currentUnidadeFriendlyURLSelected ? '/' + currentUnidadeFriendlyURLSelected : '') + currentPath 
8557    currentPath = hasPathGuest ? '/guest' + currentPath : currentPath 
8558    currentPath = hasPathWeb ? '/web' + currentPath : currentPath 
8559 
8560    if(keepURL()) 
8561    window.history.replaceState(window.history.state, '', currentPath + window.location.search) 
8562
8563   
8564  let isKeepURL = true   
8565  /** Verifica se é para manter a URL atual. Isso deve acontecer somente ao iniciar a página #9674 */ 
8566  function keepURL() { 
8567    const aux = isKeepURL 
8568    isKeepURL = false 
8569    return !aux 
8570
8571   
8572  loadServerDate(); 
8573  $(document).ready(function(){ 
8574 
8575    if("${normalizedCategoryName}" == "graduacao" || "${normalizedCategoryName}" == "pos-graduacao"){ 
8576      document.location.href = '/erro-404' 
8577
8578     
8579    ehCursoTrampolim = checkCursoTrampolim(); 
8580    checkIsAoVivo(); 
8581    loadPlanoCurso(); 
8582    loadCursosVocePodeGostar(); 
8583 
8584    if(!isAoVivo) { 
8585      $('#unidades-ofertas').change(ev => { 
8586        mudarUnidade(ev) 
8587        defineCurrentUrl(ev) 
8588      }); 
8589
8590 
8591    const urlParams = new URLSearchParams(window.location.search) 
8592    $('#chkInscricao').prop("checked", urlParams.get('inscricao') == 'true') 
8593    $('#chkInscricao').change(ev => selectFilter('inscricao', $('#chkInscricao')) ) 
8594     
8595    if($('#chkBolsa').length) { 
8596      $('#chkBolsa').prop("checked", urlParams.get('bolsa') == 'true') 
8597      $('#chkBolsa').change(ev => selectFilter('bolsa', $('#chkBolsa')) ) 
8598      loadUnidades(!isAoVivo); 
8599    } else { 
8600      selectFilter('bolsa', $('#chkBolsa')) 
8601
8602           
8603      //Função para Montar breadcrumb Mobile 
8604   
8605      function breadcrumbMobile(){ 
8606   
8607		const linkEl = $('.ssp-card-detalhe-curso__secunday-info-back-link');   	  
8608    	   
8609        if ( $.trim(linkEl.html()) === 'Técnico'){ 
8610   
8611        	linkEl.attr("href", "/cursos-tecnicos"); 
8612   
8613        } else if ( $.trim(linkEl.html()) === 'Livre'){ 
8614       
8615           if(isAoVivo){ 
8616        	   	linkEl.html('Senac Online<i class="fas fa-signal-stream icon-ao-vivo" aria-hidden="true"></i>ao vivo') 
8617             	linkEl.attr("href", "/cursos-livres-senac-online-ao-vivo"); 
8618           }else{ 
8619        	   	linkEl.attr("href", "/cursos-livres"); 
8620
8621        } else if ( $.trim(linkEl.html()) === 'Aprendizagem'){ 
8622   
8623        	linkEl.attr("href", "/jovem-aprendiz"); 
8624   
8625        }else if ( $.trim(linkEl.html()) === 'Extensão Universitária'){ 
8626   
8627        	linkEl.attr("href", "/extensao-universitaria"); 
8628         
8629        }else if ( $.trim(linkEl.html()) === 'Ensino Médio Técnico'){ 
8630        		   
8631            	linkEl.attr("href", "/ensino-medio-tecnico");	 
8632
8633   
8634
8635   
8636      breadcrumbMobile() 
8637       
8638    //Esconde elementos quando o curso é aprendizagem 
8639      if($('[name="codigoFT"]').val() == codigoFTCursoAprendizagem){ 
8640        $('.ssp-section-novas-turmas').remove(); 
8641        $("div[class^='botoes-oferta-container_']").remove(); 
8642
8643   
8644     //retira os itens de dentro do container 
8645      $('.bg-').css('background-color','#e4e4e4') 
8646     $('.container.py-3').removeClass('container py-3') 
8647     //ajuste para versao 7.4 
8648     $('.lfr-layout-structure-item-container.container-fluid.container-fluid-max-xl').removeClass() 
8649 
8650   
8651     //Fecha modal registro de interesse 
8652   
8653     $('#btn-close-Modal-registro-interesse').click(function(){ 
8654   
8655       $('#modal-registro-interesse').addClass('d-none') 
8656       $("body").removeClass("overflow-hidden") 
8657   
8658     }) 
8659   
8660      $( "#modal-registro-interesse" ).click( function(event) { 
8661   
8662          
8663   
8664         if(event.target.id==$('#modal-registro-interesse')[0].id){ 
8665               $(this).addClass('d-none') 
8666
8667   
8668      }); 
8669   
8670       
8671      //Aviso sobre interesse em turmas 
8672      $('.ssp-card-registro-interesse').on('click', '#enviar-registro-interesse-btn', enviarRegistroInteresse); 
8673      if(!isEmed){ 
8674        $('.ssp-aviso-novas-turmas__content').on('click', '#btn-aviso-novas-turmas', avisoNovasTurmas); 
8675        $('.ssp-card-registro-interesse').on('click', '#todosDias', registroSelecionaTodosDias); 
8676      } else { 
8677        $('.ssp-emed__card-slider-body').on('click', '#btnOptin', avisoNovasTurmas) 
8678      }  
8679      $('#div-campo-todos').on('change', 'input[type=checkbox]', registroSelecionaTodosPeriodos); 
8680   
8681      $('#btnLogin').click(function(){ 
8682        
8683        login() 
8684         
8685       }); 
8686       
8687       $('#btn-close-loginModal').click(function(){ 
8688           $('#modal-login').addClass('d-none') 
8689       }); 
8690        
8691       $('.ssp-week-day').not('#todosDias').click(function(){ 
8692   
8693           $(this).toggleClass('ssp-week-day-active'); 
8694           verificaBtnEnviarRegistroInteresseAtivo(); 
8695            
8696       }); 
8697        
8698       $('#add-unidade-regsitro-interesse').click(function(e){ 
8699           var element = $('.ssp-card-registro-interesse__select.unidades').first().clone(); 
8700           element.empty(); 
8701            element.append('<option value="" disabled selected>Selecione uma unidade</option>') 
8702                $.each(objsTela.unidadesRegistroInteresse, function(k,unidade){ 
8703 
8704                    if(!unidade['selecionado']){      
8705                        element.append('<option value="'+unidade['codigoUnidade']+'">'+unidade['nome']+'</option>'); 
8706
8707 
8708                }); 
8709            element.change(changeSelectUnidades) 
8710 
8711   
8712           element.css('margin-top', '10px'); 
8713            
8714           if(element.find("option").length > 1 && $('.ssp-card-registro-interesse__select.unidades').length < objsTela.unidadesRegistroInteresse.length){ 
8715              element.attr("id", "select_" + cntSelectUnidades++) 
8716              $('#select-unidades-registro-interesse').append(element); 
8717          }    
8718 
8719          if($('.ssp-card-registro-interesse__select.unidades').length == objsTela.unidadesRegistroInteresse.length){ 
8720              $('#add-unidade-regsitro-interesse').addClass("d-none") 
8721
8722   
8723           verificaBtnEnviarRegistroInteresseAtivo(); 
8724       }); 
8725        
8726       $('#remove-unidade-regsitro-interesse').click(function(e){ 
8727          
8728         if($('.ssp-card-registro-interesse__select').length > 1){ 
8729          
8730              var element = $('.ssp-card-registro-interesse__select').last(); 
8731     
8732              var valueSelecionado = element.val(); 
8733 
8734              $.each(objsTela.unidadesRegistroInteresse, function(k,unidade){ 
8735 
8736                  if(unidade['selecionado'] && unidade['codigoUnidade'] == valueSelecionado){ 
8737                      unidade['selecionado'] = false; 
8738                      unidade['selectSelecionado'] = ""; 
8739
8740 
8741              }); 
8742              element.val(""); 
8743              cntSelectUnidades--; 
8744              element.change() 
8745 
8746              element.remove(); 
8747
8748   
8749         if($('.ssp-card-registro-interesse__select.unidades').length < objsTela.unidadesRegistroInteresse.length){ 
8750              $('#add-unidade-regsitro-interesse').removeClass("d-none") 
8751
8752 
8753          verificaBtnEnviarRegistroInteresseAtivo(); 
8754       }) 
8755        
8756       $('.ssp-card-registro-interesse__check-item').on('change', 'input[type=checkbox]', function(){ 
8757         verificaBtnEnviarRegistroInteresseAtivo(); 
8758       }); 
8759   
8760       //Contador em ofertas de bolsas proximas 
8761       var cancel = setInterval(atualizaTempoAberturasBolsas, 1000); 
8762        
8763        // Manipua o breadcrumb para as regras do Senac 
8764          
8765        if($('ol.breadcrumb').find('li:first').text().trim() == "Cursos Pai") 
8766          $('ol.breadcrumb').find('li:first').remove(); 
8767         
8768        var li = $('ol.breadcrumb').find('li:first'); 
8769   
8770        if(li.text().trim() == 'Cursos'){ 
8771       
8772          var primeiro = li.clone(); 
8773          primeiro.html(htmlBreadcrumb('/', 'Cursos', 'Home')); 
8774          li.parent().prepend(primeiro); 
8775       
8776          var tipoCurso = $('.ssp-header-curso__tag-formato').text().trim(); 
8777          var tipoBreadcrumb = ''; 
8778           
8779          const isPresencialEad = (tipoCurso.toLowerCase().includes("presencial + ead")) 
8780           
8781          if(tipoCurso.includes("Cursos Livres")){ 
8782            if(isPresencialEad) { 
8783              tipoBreadcrumb =  htmlBreadcrumb('/presencial-ead#cursos-livres', tipoCurso); 
8784            } else { 
8785              tipoBreadcrumb = htmlBreadcrumb( 
8786                    isAoVivo ? '/cursos-livres-senac-online-ao-vivo' : '/cursos-livres',  
8787                  isAoVivo ? nomeFormatoAoVivoDxp : tipoCurso); 
8788            }         
8789          }else if(tipoCurso.includes("Extensão")){ 
8790            if(isPresencialEad) { 
8791              tipoBreadcrumb =  htmlBreadcrumb('/presencial-ead#extensao-universitaria', tipoCurso); 
8792            } else { 
8793        	  	tipoBreadcrumb =  htmlBreadcrumb('/extensao-universitaria', tipoCurso); 
8794            }           
8795          }else if(tipoCurso.includes("Ensino Médio Técnico")){ 
8796            if(isPresencialEad) { 
8797              tipoBreadcrumb =  htmlBreadcrumb('/presencial-ead#ensino-medio-tecnico', tipoCurso); 
8798            } else { 
8799              tipoBreadcrumb =  htmlBreadcrumb('/ensino-medio-tecnico', tipoCurso); 
8800
8801          }else if(tipoCurso.includes("Jovem Aprendiz")){ 
8802            if(isPresencialEad) { 
8803              tipoBreadcrumb =  htmlBreadcrumb('/presencial-ead#jovem-aprendiz', tipoCurso); 
8804            } else { 
8805              tipoBreadcrumb =  htmlBreadcrumb('/jovem-aprendiz', tipoCurso); 
8806
8807          }else{ 
8808            if(isPresencialEad) { 
8809              tipoBreadcrumb =  htmlBreadcrumb('/presencial-ead#cursos-tecnicos', tipoCurso); 
8810            } else { 
8811              tipoBreadcrumb =  htmlBreadcrumb('/cursos-tecnicos', tipoCurso); 
8812
8813
8814           
8815          li.html(tipoBreadcrumb); 
8816         
8817          if($('ol.breadcrumb').find('li').length == 4) $('ol.breadcrumb').find('li:last').remove(); 
8818        	 
8819
8820         
8821        $('#turmas-container').on('click', 'a.slick-next', function(e){ 
8822				 
8823        	 	e.preventDefault(); 
8824			    buscaProximaOferta(); 
8825			 
8826        }); 
8827 
8828        $('#turmas-container').on('click', 'button.slick-dots', function(){ 
8829 
8830             
8831       
8832        }); 
8833		 
8834        $(".next-mobile").on("click",function(e){  
8835        	 e.preventDefault();  
8836       	 	 
8837        	 acoesMobileSliderOfertas("left"); 
8838       	}); 
8839         
8840        $(".prev-mobile").on("click",function(e){  
8841        	e.preventDefault();  
8842	        
8843        	acoesMobileSliderOfertas("right");	 
8844      	}); 
8845         
8846        //ação de drag do card de ofertas no mobile 
8847        $('.oferta-slick-area').on('swipe', function(event, slick, direction){ 
8848           	acoesMobileSliderOfertas(direction); 
8849        }); 
8850         
8851        loadAlternadores() 
8852        let modalFormAprendizagem = document.querySelector('[data-modal="modal"]') 
8853        if(modalFormAprendizagem){ 
8854          // Create dinamic close buttom form 
8855          let btnCloseModalForm = document.querySelector('[data-modal="close-form-modal"]') 
8856         
8857          btnCloseModalForm.addEventListener('click',closeModalFormAprendizagem) 
8858         
8859
8860    
8861        $(".oferta-slick-area").on("click", ".btnModalAprendizagem", function (){ 
8862           openModalFormAprendizagem(); 
8863         }) 
8864         
8865     }); 
8866   
8867  function htmlBreadcrumb(link, title, display){ 
8868	   
8869	  return '<a class="breadcrumb-link" href="'+link+'" title="'+title+'"><span class="breadcrumb-text-truncate">'+(display || title)+'</span></a>'; 
8870	   
8871
8872   
8873  function acoesMobileSliderOfertas(direcao){ 
8874	   
8875       	if(direcao == "right"){ 
8876       		$("a.slick-prev").click();  
8877	       	 
8878        	if($('.slick-current').attr('data-slick-index') == "0") 
8879	       		 $('.prev-mobile').addClass('nextPrevOpacity'); 
8880	       	 
8881        	if($(".next-mobile").hasClass('nextPrevOpacity')) 
8882        		 $('.next-mobile').removeClass('nextPrevOpacity'); 
8883
8884       	 
8885       	 
8886		if(direcao == "left"){ 
8887	      	 $("a.slick-next").click(); 
8888	   	  
8889	   	  	if($(".prev-mobile").hasClass('nextPrevOpacity')) 
8890	     		 $('.prev-mobile').removeClass('nextPrevOpacity'); 
8891	   	   
8892	   	 	if(carregouUltimaOferta){ 
8893	   	 		var totalCardOfertas = $('#turmas-container .slick-area__item').length; 
8894	   	 		var currentSliderIndex = parseInt($('.slick-current').attr('data-slick-index'));   
8895	 
8896	   	 		//o card do meio é o último	 
8897				if(totalCardOfertas == (currentSliderIndex + 1)) 
8898					$('.next-mobile').addClass('nextPrevOpacity'); 
8899
8900
8901
8902   
8903  //habilitar/desabilitar registro de interesse 
8904  function habilitarRegistroInteresse(habilitar){ 
8905    var sectionRI = $('#section-registro-interesse') 
8906 
8907    if(isEmed) { 
8908      sectionRI.hide() 
8909      return; 
8910
8911 
8912    //Redmine #9309 - sempre irá mostrar 
8913    habilitar = true 
8914       
8915    if(habilitar) sectionRI.show() 
8916    else sectionRI.hide() 
8917
8918   
8919  function abrirModalRegistroInteresse(codUnidadeSelect){ 
8920	    $('#modal-registro-interesse').removeClass('d-none'); 
8921      $("body").addClass("overflow-hidden") 
8922      if(!isEmed){ 
8923	    $('.ssp-card-registro-interesse__nome-curso').text($('.ssp-card-detalhe-curso__title').text()); 
8924      } else { 
8925        $(".transferencia-emed-link").find('a').attr("href", "/ensino-medio-tecnico#onde-estudar") 
8926        $('.ssp-card-registro-interesse__title-modal').text($('.ssp-card-detalhe-curso__title').text()); 
8927
8928       
8929      $('.ssp-card-registro-interesse__select:not(#select_0)').remove(); 
8930      $.each(objsTela.unidadesRegistroInteresse, function(k,unidade){ 
8931        if(unidade['codigoUnidade'] == codUnidadeSelect){ 
8932            unidade['selecionado'] = true; 
8933            unidade['selectSelecionado'] = 'select_0'; 
8934        } else { 
8935            unidade['selecionado'] = false; 
8936            unidade['selectSelecionado'] = ""; 
8937
8938 
8939    }); 
8940    objsTela.unidadesRegistroInteresse.sort(function (a, b) { 
8941        return ordenar(a, b, 'nome'); 
8942    }); 
8943 
8944    $('#select_0').empty(); 
8945    $('#select_0').append('<option value="" disabled>Selecione uma unidade</option>') 
8946        $.each(objsTela.unidadesRegistroInteresse, function(k,unidade){ 
8947 
8948          $('#select_0').append('<option value="'+unidade['codigoUnidade']+'" >'+unidade['nome']+'</option>'); 
8949             
8950        }); 
8951    $('#select_0').val(codUnidadeSelect); 
8952    console.dir(objsTela.unidadesRegistroInteresse) 
8953	 	if(isAoVivo){ 
8954	 		$('#unidades-registro-interesse, #dias-registro-interesse').addClass('d-none'); 
8955
8956     if(objsTela.unidadesRegistroInteresse.length > 1) { 
8957        $('#add-unidade-regsitro-interesse').removeClass("d-none") 
8958        $('#add-unidade-regsitro-interesse').show() 
8959        $('#remove-unidade-regsitro-interesse').show() 
8960      } else { 
8961        $('#add-unidade-regsitro-interesse').hide() 
8962        $('#remove-unidade-regsitro-interesse').hide() 
8963
8964
8965 
8966  $('.ssp-card-registro-interesse__select.unidades').on('change', changeSelectUnidades) 
8967  
8968 function changeSelectUnidades() { 
8969   var codUnidadeSelecionada = $(this).val(); 
8970   var idSelectSelecionado = $(this).attr('id') 
8971   $.each(objsTela.unidadesRegistroInteresse, function(k,unidade){ 
8972        if(unidade['codigoUnidade'] == codUnidadeSelecionada){ 
8973            unidade['selecionado'] = true; 
8974            unidade['selectSelecionado'] = idSelectSelecionado; 
8975        } else if(unidade['selectSelecionado'] == idSelectSelecionado && unidade['selecionado']){ 
8976            unidade['selecionado'] = false; 
8977            unidade['selectSelecionado'] = ""; 
8978
8979 
8980    }); 
8981     
8982    objsTela.unidadesRegistroInteresse.sort(function (a, b) { 
8983        return ordenar(a, b, 'nome'); 
8984    }); 
8985 
8986    $('.ssp-card-registro-interesse__select.unidades:not(#'+idSelectSelecionado+')').each(function() { 
8987        var valueSelecionado = $(this).val(); 
8988        var idActualSelect = $(this).attr('id'); 
8989        $(this).empty(); 
8990        $(this).append('<option value="" disabled>Selecione uma unidade</option>') 
8991        $.each(objsTela.unidadesRegistroInteresse, function(k,unidade){ 
8992 
8993            if(unidade['selecionado'] && unidade['codigoUnidade'] == valueSelecionado){ 
8994                $("#"+idActualSelect).append('<option value="'+unidade['codigoUnidade']+'" >'+unidade['nome']+'</option>'); 
8995            }else if(!unidade['selecionado']){      
8996                $("#"+idActualSelect).append('<option value="'+unidade['codigoUnidade']+'">'+unidade['nome']+'</option>'); 
8997
8998 
8999        }); 
9000        $(this).val(valueSelecionado) 
9001    }); 
9002     
9003   verificaBtnEnviarRegistroInteresseAtivo(); 
9004
9005 
9006   
9007 function ordenar(objA, objB, nomeAtributo){ 
9008	 	let a = (nomeAtributo) ? objA[nomeAtributo] : objA; 
9009	 	let b = (nomeAtributo) ? objB[nomeAtributo] : objB; 
9010	 
9011	 	return a.toString().localeCompare(b.toString()); 
9012
9013  
9014 function paramOrdem(xml){ 
9015	 	if(isEmed){ 
9016	 		var ordemPeriodo = ['MA', 'TA', 'NO']; 
9017	 		return $.inArray(xml.find('[name="periodoDiaOferta"]').text().trim(), ordemPeriodo); 
9018	 	}else{ 
9019	 		return xml.find('[name="dataInicioOferta"]').text(); 
9020
9021
9022  
9023 function getEtapaSelecionadaEmed(){ 
9024		var btnEtapa = $('.ssp-ofertas-emed__filtro-content .btn--filtro-ativo'); 
9025		 if(!btnEtapa) return ''; 
9026		 return btnEtapa.val(); 
9027
9028  
9029 function filtraOfertasEtapa(etapa, ofertas){ 
9030    if(!etapa) return []; 
9031    var ofertasEtapa = []; 
9032    var turmas = ['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J']; 
9033    var periodos = {['MA'] : 'Manhã', ['TA'] : 'Tarde', ['NO'] : 'Noite'}; 
9034    var ultimoPeriodo = null, indexPeriodo; 
9035    ofertas = ofertas.sort(function(a, b){ 
9036       return ordenar(a, b, 'periodoDiaOferta'); 
9037    }); 
9038 
9039    $.each(ofertas, async (index, oferta)=> { 
9040      if(oferta['etapa'] == etapa){ 
9041        if(oferta['periodoDiaOferta'] != ultimoPeriodo) indexPeriodo = 0; 
9042        ultimoPeriodo = oferta['periodoDiaOferta']; 
9043        oferta['titulo'] = 'Turma ' + turmas[indexPeriodo++] + ' - ' + (periodos[ultimoPeriodo] || ''); 
9044        ofertasEtapa.push(oferta); 
9045
9046    }); 
9047      
9048     return ofertasEtapa; 
9049
9050  
9051 function formatarDataEmed(data, etapa, isDataFim){ 
9052	  
9053 	try{ 
9054 
9055 		var splitdata = data.split('/'); 
9056 		var meses = ['Janeiro', 'Fevereiro', 'Março', 'Abril', 'Maio', 'Junho', 'Julho', 'Agosto', 'Setembro', 'Outubro', 'Novembro', 'Dezembro']; 
9057 	 	var mes = meses[parseInt(splitdata[1])-1]; 
9058 	 	 
9059 	 	var ano = splitdata[2]; 
9060 	 	 
9061 	 	if(isDataFim){ 
9062 	 		ano = parseInt(splitdata[2]); 
9063
9064 	 	 
9065 	 	return mes + '/' + ano; 
9066 	}catch(err){  
9067 		return data;  
9068
9069   
9070
9071  
9072 //EMED Mobile 
9073 function sliderOfertasEmed(){ 
9074	  
9075	 var tamScreen = $(window).width(); 
9076	 if(tamScreen < 1024){ 
9077	     $('.ssp-slick-ofertas-emed').slick({ 
9078	         slidesToShow: 1, 
9079	         slidesToScroll: 1, 
9080	         dots: false, 
9081	         infinite: false, 
9082	         adaptiveHeight: true, 
9083	         prevArrow:'<button class="btn slick-prev" type="button"><i class="fal fa-chevron-left"></i><span class="sr-only">Anterior</span></button>', 
9084	         nextArrow:'<button class="btn slick-next" type="button"><i class="fal fa-chevron-right"></i><span class="sr-only">Próximo</span></button>', 
9085	         responsive: [ 
9086	 
9087
9088	                 breakpoint: 1200, 
9089	                 settings: { 
9090	                     slidesToShow: 1, 
9091	                     slidesToScroll: 1, 
9092	                     prevArrow: '<button class="btn slick-prev ssp-slider-control-mobile__item-prev"><i class="fal fa-chevron-left mr-1"></i><span>Anterior</span></button>', 
9093	                     nextArrow: '<button class="btn slick-next ssp-slider-control-mobile__item-next"><span>Próximo</span><i class="fal fa-chevron-right ml-1"></i></button>', 
9094	 
9095
9096	             }, 
9097
9098	                 breakpoint: 768, 
9099	                 settings: { 
9100	                     slidesToShow: 1, 
9101	                     slidesToScroll: 1, 
9102	                     prevArrow: '<button class="btn slick-prev ssp-slider-control-mobile__item-prev"><i class="fal fa-chevron-left mr-1"></i><span>Anterior</span></button>', 
9103	                     nextArrow: '<button class="btn slick-next ssp-slider-control-mobile__item-next"><span>Próximo</span><i class="fal fa-chevron-right ml-1"></i></button>', 
9104
9105
9106	 
9107
9108	 
9109	     }); 
9110 
9111
9112 
9113
9114 
9115function addItemBackpack(codOferta, originElemSelector, codUnidade, dataEfetiva){ 
9116	 
9117	let backpackPostRequest = {}; 
9118	backpackPostRequest.codOferta = codOferta; 
9119	backpackPostRequest.codUnidade = codUnidade; 
9120	backpackPostRequest.dt_efetiva = dataEfetiva; 
9121 
9122	 
9123	mochila.requestAccess(function(backpackPostRequest){ 
9124		 
9125		let urlMochila = '/o/senac-backpack-services/backpack'; 
9126		 
9127		if(getCookie("codMochila") != null){ 
9128			backpackPostRequest.codMochila = getCookie("codMochila"); 
9129			urlMochila = '/o/senac-backpack-services/updateBackpack';	 
9130		}	 
9131		$.ajax({ 
9132		    type: 'POST', 
9133		    url: urlMochila, 
9134		    headers: { 
9135		        "Content-Type":"application/json" 
9136		    }, 
9137            beforeSend: function(xhr){ 
9138            	xhr.setRequestHeader("Authorization", "Bearer " + getCookie("tokenMochila")); 
9139            	loadingSubmitButton(originElemSelector); 
9140            	$(originElemSelector + ' .loading-icon-button').css('height', 'unset'); 
9141            	if($(window).width() < 1024){ 
9142            		$(originElemSelector + ' .loading-icon-button span').css('margin-left', '10%'); 
9143
9144            }, 
9145		    data : JSON.stringify(backpackPostRequest) 
9146		}).done(function(data) {  
9147			 
9148			let domain = ''; 
9149			if(getAmbiente() == 'hom' || getAmbiente() == 'prod') 
9150				domain = '.sp.senac.br'; 
9151			 
9152			writeCookie( 
9153					'codMochila',  
9154					(getCookie("codMochila") == null) ? data.backpackCode : JSON.parse(data).backpackCode,  
9155					24, 
9156					domain 
9157			); 
9158			addItemSuccessMochila(); 
9159			 
9160		}).fail(function(xhr, status, error) { 
9161			 
9162			$('#modal-backpack-error').removeClass('d-none'); 
9163			 
9164	 	}).always(function(){ 
9165	 		 
9166	 		cleanLoadingSubmitButton( 
9167	 				originElemSelector,  
9168	 				originElemSelector.indexOf('backpack') > 0 ? 'OK, desejo comprar' : 'COMPRAR' 
9169	 		); 
9170	 		$('[id^="modalAntesCompra_"]').each(function(index, modal) { 
9171	 			modal.style.display = "none"; 
9172	 		}); 
9173	 		 
9174	 	}); 
9175		 
9176	}, backpackPostRequest); 
9177	 
9178
9179 
9180function componentBuyConfirmation(codigoUnidade, oferta, dataEfetiva){ 
9181  
9182	var comp = null; 
9183		 
9184	if((oferta.destinoCompra !== null) && oferta.destinoCompra == "2"){ 
9185		 
9186		comp = $("<button>") 
9187		.addClass("btn btn-lg btn-success w-100 mt-3 btn-backpack") 
9188		.attr("offerCode",oferta.codigoOferta) 
9189		.attr("unitCode",codigoUnidade) 
9190		.attr("effectiveDate",dataEfetiva) 
9191		.text("OK, desejo comprar"); 
9192	 
9193	}else { 
9194	 
9195		comp = $("<a>") 
9196		.addClass("btn btn-lg btn-success w-100 mt-3") 
9197		.text("OK, desejo comprar") 
9198		.attr("href", linkBotaoCompra.replace('\{codigoUnidade\}', codigoUnidade).replace('\{codigoOferta\}', oferta.codigoOferta)) 
9199		.attr("target","_blank"); 
9200
9201	 
9202	comp.attr('id', 'btnCompraLocal_' + oferta.indice); 
9203	 
9204    return comp[0].outerHTML; 
9205     
9206
9207 
9208function getUnidadesSelecionadasRI(){ 
9209		var unidadesRI = []; 
9210		 
9211		try{ 
9212			 
9213			$('#select-unidades-registro-interesse').find('select').each((i,select) =>{ 
9214				var unidadeSel = select.selectedOptions[0].innerText; 
9215				if(!unidadesRI.includes(unidadeSel)) unidadesRI.push(unidadeSel); 
9216			}); 
9217			 
9218			var unidadesExt = unidadesRI.join(', '); 
9219			 
9220			const lastIndex = unidadesExt.lastIndexOf(','); 
9221			 
9222			if(lastIndex > 0) unidadesExt = unidadesExt.substring(0, lastIndex) + ' ou ' + unidadesExt.substring(lastIndex + 1); 
9223			 
9224			return { 
9225				'unidadesPrefix' : (unidadesRI.length > 1 ? ', nas unidades ' : (unidadesRI.length == 1 ? ', na unidade ' : '')), 
9226				'unidades' : unidadesExt 
9227			}; 
9228			 
9229		}catch(err){ 
9230			 
9231			return { 
9232				'unidadesPrefix' : '', 
9233				'unidades' : '' 
9234			}; 
9235			 
9236
9237		 
9238
9239 
9240 
9241 
9242 
9243function addItemSuccessMochila(){ 
9244	 
9245	mochila.check(); 
9246	$('#modal-backpack-success__nome-curso').html($('.ssp-card-detalhe-curso__title').text()); 
9247	$('#modal-backpack-success').removeClass('d-none'); 
9248	 
9249
9250 
9251$(document).on('click', '.btn-backpack', function(e){  
9252     
9253	addItemBackpack(event.target.getAttribute("offerCode"), '.btn-backpack',event.target.getAttribute("unitCode"),event.target.getAttribute("effectiveDate")); 
9254	 
9255}); 
9256 
9257$('#btn-voltar-modal-backpack-error').click(function () { 
9258    $('#modal-backpack-error').addClass('d-none'); 
9259}); 
9260 
9261$('#btn-voltar-modal-backpack-error').click(function () { 
9262    $('#modal-backpack-error').addClass('d-none'); 
9263}); 
9264 
9265$('.btn-mochila-continuar-site-success, .modal-btn-close').click(function () { 
9266    $('#modal-backpack-success').addClass('d-none'); 
9267}); 
9268 
9269$('.btn-mochila-finalizar-compra-success').click(function () { 
9270  // Montar object push - google tag manager - 6 
9271  sendEventEcommerce("begin_checkout", ofertaSelecionada); 
9272 
9273	mochila.verificaLogin(); 
9274	$('#modal-backpack-success').addClass('d-none'); 
9275	$('[id^="myModal_"]').each((i,modal)=>modal.style.display = "none"); 
9276}); 
9277 
9278   function closeModalFormAprendizagem(){ 
9279           let modal = document.querySelector('[data-modal="modal"]') 
9280            
9281       modal.classList.remove('open-modal-form') 
9282      
9283
9284      
9285      
9286   function openModalFormAprendizagem(){ 
9287           let modal = document.querySelector('[data-modal="modal"]') 
9288            
9289       modal.classList.add('open-modal-form') 
9290      
9291
9292 
9293  function addEventBolsa() { 
9294    // Mostra o preco 
9295    const btnShowPrices = document.querySelectorAll('.btn-show-price') 
9296 
9297    btnShowPrices.forEach(btnShowPrice => btnShowPrice.addEventListener('click',togglePriceCard)) 
9298     
9299    if(!$('#chkBolsa').prop('checked')) 
9300      togglePriceCard() 
9301
9302 
9303  function togglePriceCard(selector){ 
9304    if(selector instanceof PointerEvent) return 
9305 
9306    if(!selector) selector = '' 
9307    else selector = '.' + selector 
9308     
9309    const btnPrices = document.querySelectorAll('.show-price-content'+selector) 
9310    const contentPrices = document.querySelectorAll('.content-valores-descontos'+selector) 
9311    const contentBtnBolsas = document.querySelectorAll('.content-btn-bolsa'+selector) 
9312     
9313    btnPrices.forEach(btnPrice => btnPrice.classList.toggle('hide')) 
9314    contentBtnBolsas.forEach(contentBtnBolsa => contentBtnBolsa.classList.toggle('modifier-content-show')) 
9315    contentPrices.forEach(contentPrice => contentPrice.classList.toggle('hide-price'))       
9316
9317   
9318  function getRegiaoName(key) { 
9319	  switch (key) { 
9320	    case "C": 
9321	      return "Capital"; 
9322	    case "I":             
9323	      return "Interior"; 
9324	    case "GS": 
9325	      return "Grande São Paulo e Litoral"; 
9326	    default: 
9327	      return "Sem Região"; 
9328
9329
9330 
9331	function criarOptionUnidadesPorRegiao(unidades) { 
9332	  let regioes = {} 
9333	  let unidadeFounded 
9334 
9335	  unidades.forEach(unidade => { 
9336	    if(!regioes[unidade.codRegiaoUnidade || 'N']) 
9337	      regioes[unidade.codRegiaoUnidade || 'N'] = [] 
9338 
9339	    regioes[unidade.codRegiaoUnidade || 'N'].push(unidade) 
9340	  }) 
9341 
9342	  Array.from(['C', 'I', 'GS', 'N']) 
9343	  .filter(key => Object.keys(regioes).includes(key)) 
9344	  .forEach(key => { 
9345	    const unidadesDaRegiao = regioes[key] 
9346 
9347	    const optionDisabled = $('<option>') 
9348	    optionDisabled.attr('label', getRegiaoName(key)) 
9349	    optionDisabled.text(getRegiaoName(key)); 
9350	    optionDisabled.attr('disabled', true) 
9351	    optionDisabled.addClass('ssp-option-group') 
9352	    $('#unidades-ofertas').append(optionDisabled) 
9353 
9354	    $.each(unidadesDaRegiao, function(k,unidade){       
9355	      if($('#unidades-ofertas').find('[value="'+unidade['categoryId']+'"]').length == 0){         
9356	        var option = $('<option>'); 
9357	        option.val(unidade['categoryId']+"@"+unidade['codigoUnidade']); 
9358	        option.text(unidade['nome']); 
9359	        option.attr('data-unidade-friendly-url', unidade.friendlyURL) 
9360	        option.addClass('ssp-option') 
9361	   
9362	        $('#unidades-ofertas').append(option); 
9363	     
9364	        unidadeFounded = !unidadeFounded && getURLData().includes('/'+unidade.friendlyURL+'/') ? unidade : unidadeFounded	           
9365
9366	    }) 
9367	  }) 
9368 
9369	  return unidadeFounded 
9370
9371 
9372	function getURLData() { 
9373	  return URLGeral.replace(HOST, '') 
9374
9375 
9376	/** 
9377	* Copia um objeto JSON 
9378	*/ 
9379	function cloneObj(original) { 
9380	  return JSON.parse(JSON.stringify(original)); 
9381
9382 
9383  function getUrlConsultaBolsa(oferta){ 
9384   
9385    let url = ''; 
9386    if (isAmbienteTeste()) { 
9387      if(oferta.destinoBolsa=='1') { 
9388        url = 'https://hwse.sp.senac.br/rest/wss/cursos/bolsa/v1/?COD_EVENTO='+oferta.codigoOferta 
9389      } else { 
9390        url = 'https://hom-wse-bolsas.sp.senac.br/api/cursos/bolsa/v1/'+oferta.codigoOferta; 
9391
9392    }	else { 
9393      if(oferta.destinoBolsa=='1') { 
9394        url = 'https://wse.sp.senac.br/rest/wss/cursos/bolsa/v1/?COD_EVENTO='+oferta.codigoOferta 
9395      } else { 
9396        url = 'https://wse-bolsas.sp.senac.br/api/cursos/bolsa/v1/'+oferta.codigoOferta; 
9397
9398       
9399
9400     
9401    return url; 
9402
9403 
9404  function execCompraEmed(oferta){ 
9405 
9406    let linkInscricaoEmed, linkInscricaoEmedHml, acadProg; 
9407    if(oferta.etapa == '0010'){ 
9408      linkInscricaoEmed = 'https://www.sp.senac.br/login/Login?destino=https://inscricao-educacional-ms.sp.senac.br/?oferta={codOferta}'; 
9409      linkInscricaoEmedHml = 'https://gesportal.sp.senac.br/login/Login?destino=https://hinscricao-educacional-backend.sp.senac.br/?oferta={codOferta}'; 
9410      acadProg = null; 
9411    }else{ 
9412      linkInscricaoEmed = 'https://www.sp.senac.br/login/Login?destino=https://inscricao-emed.sp.senac.br?course={acad_prog}&unity={codUnidade}&shift={periodo}&step={etapa}&oferta={codOferta}'; 
9413      linkInscricaoEmedHml = 'https://gesportal.sp.senac.br/login/Login?destino=https://hinscricao-emed.sp.senac.br?course={acad_prog}&unity={codUnidade}&shift={periodo}&step={etapa}&oferta={codOferta}'; 
9414      acadProg = ()=>{ 
9415        //Codigo FT + Data Efetiva(ymd) : AcadProg 
9416        const acadProgMap = { 
9417          ['2478820220101'] : '08202', 
9418          ['2363020210101'] : '07325', 
9419          ['2362920210101'] : '07326', 
9420          ['2097420210101'] : '05918' 
9421        }	    
9422        var key = $('[name="codigoFT"]').val() + $('[name="dataEfetivaSTR"]').val().replace(/-/g, ''); 
9423        return acadProgMap[key] || ''; 
9424
9425
9426 
9427    var ambTeste = ['localhost', 'hom', 'dev']; 
9428      var link = linkInscricaoEmed; 
9429      $.each(ambTeste, function(i, a){ 
9430        if(location.hostname.indexOf(a) >= 0){ 
9431          link = linkInscricaoEmedHml; 
9432          return false; 
9433
9434      }); 
9435 
9436      // Montar object push - google tag manager - 3 
9437      ofertaSelecionada = itensEcommerce.get(oferta.codigoOferta) 
9438      sendEventEcommerce("select_item", ofertaSelecionada); 
9439      sendEventEcommerce("view_item", ofertaSelecionada); 
9440      sendEventEcommerce("add_to_cart", ofertaSelecionada); 
9441      sendEventEcommerce("begin_checkout", ofertaSelecionada); 
9442       
9443      var urlCompra  = link.replace('\{acad_prog\}', acadProg) 
9444        .replace('\{codUnidade\}', $('[name="codUnidadeSelecionada"]').val()) 
9445        .replace('\{periodo\}', (oferta.periodoDiaOferta == 'TA') ? 'V' :  oferta.periodoDiaOferta.slice(0, 1)) 
9446        .replace('\{etapa\}', oferta.etapa) 
9447        .replace('\{codOferta\}', oferta.codigoOferta); 
9448      window.open(urlCompra, '_blank'); 
9449 
9450
9451 
9452   function formataDataComBarra(dataInvertidaComTraco){ 
9453 		return dataInvertidaComTraco.split('-').reverse().join('/'); 
9454
9455 
9456 
9457   </script> 
9458 
9459</#if>