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