Um erro ocorreu enquanto processava o modelo.
The following has evaluated to null or missing:
==> isEMED [in template "20102#20129#438394" at line 4102, 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 4102, 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?cb=${_rnd}"></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 será realizada presencialmente nos hotéis-escola Senac. Se você não participar, sua inscrição é cancelada automaticamente. Lembre-se: antes da entrevista, envie por e-mail os documentos necessários.
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 será realizada presencialmente nos hotéis-escola Senac. Se você não participar, sua inscrição é cancelada automaticamente. Lembre-se: antes da entrevista, envie por e-mail os documentos necessários.
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. </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 <!--Modal de Login -->
4036
4037 <section id="modal-login" class="ssp-modal-registro-interesse d-none">
4038
4039 <div class="dropdown-menu-modal dropdown-menu-right" id="js-login-dropdown-menu-2" style="width: 340px; max-width: 340px; display: block;">
4040
4041 <div class="px-5">
4042 <i id="btn-close-loginModal" class="fas fa-times btn-close__modal-login"></i>
4043 <div class="text-darker-gray py-3">Faça login na sua conta</div>
4044 </div>
4045
4046 <div class="dropdown-divider"></div>
4047
4048 <div class="dropdown-menu-arrow"></div>
4049
4050 <form id="login_form" class="px-5 py-4" method="post">
4051
4052 <div class="alert alert-danger py-3 d-none" id="mensagem-erro-login" style="background:#f8d7da;border-color:#f5c6cb; color:#a94442"></div>
4053
4054 <div class="form-group">
4055
4056 <label for="login-email">E-mail</label>
4057 <div class="input-group mb-2">
4058 <div class="input-group-prepend">
4059 <span class="input-group-text"><i class="icon-envelope"></i></span>
4060 </div>
4061 <input type="text" class="form-control" id="login-email-modal" name="_com_liferay_login_web_portlet_LoginPortlet_login" placeholder="Digite seu e-mail" aria-label="Email" aria-describedby="login-email">
4062 </div>
4063
4064 </div>
4065
4066 <div class="form-group">
4067
4068 <label for="login-password">Senha</label>
4069 <div class="input-group mb-2">
4070 <div class="input-group-prepend">
4071 <span class="input-group-text"><i class="icon-key"></i></span>
4072 </div>
4073 <input type="password" class="form-control" id="login-password-modal" name="_com_liferay_login_web_portlet_LoginPortlet_password" placeholder="Digite sua senha" aria-label="Password" aria-describedby="login-password">
4074 </div>
4075
4076 </div>
4077
4078 <div class="pt-1 pb-3">
4079 <small><a href="http://www.sp.senac.br/login-unico/SendPassword" target="_blank">Esqueceu sua senha?</a></small>
4080 </div>
4081
4082 <button type="button" class="btn btn-primary w-100" id="btnLogin" data-login="btnLogin">Entrar</button>
4083 </form>
4084
4085 <div class="dropdown-divider"></div>
4086
4087 <div class="px-5 pb-4">
4088 <div class="text-darker-gray py-3">Não tem cadastro?</div>
4089 <a href="https://www.sp.senac.br/usuario-unico/InsertUser?destino=${themeDisplay.getPortalURL()+themeDisplay.getURLCurrent()}" target="_blank" class="btn bg-btn-cadastre btn-nivel-livre text-white w-100 ">Cadastre-se</a>
4090 </div>
4091
4092
4093 </div>
4094
4095 </section>
4096
4097 <!-- modal registro interesse -->
4098
4099
4100 <section id="modal-registro-interesse" class="ssp-modal-registro-interesse d-none">
4101
4102 <#if !isEMED>
4103 <div class="ssp-card-registro-interesse">
4104
4105 <i id="btn-close-Modal-registro-interesse" class="fas fa-times btn-close__modal-login"></i>
4106
4107 <p class="ssp-card-registro-interesse__label-curso-selecionado">Curso selecionado:</p>
4108 <h3 class="ssp-card-registro-interesse__nome-curso"></h3>
4109
4110 <div id="unidades-registro-interesse">
4111
4112 <h4 class="ssp-card-registro-interesse__title-section-itens">Unidade:</h4>
4113
4114 <div id="select-unidades-registro-interesse">
4115 <select class="ssp-card-registro-interesse__select unidades" id="select_0"><option value="" disabled="" selected="">Selecione uma unidade</option></select>
4116 </div>
4117
4118 <div class="ssp-card-registro-interesse__add-mais">
4119 <a class="" id="add-unidade-regsitro-interesse" href="#a"><i class="fas fa-plus mr-1"></i>Adicionar unidade</a>
4120
4121
4122
4123 <a class="" id="remove-unidade-regsitro-interesse" href="#a"><i class="fas fa-times mr-1"></i>Remover unidade</a>
4124 </div>
4125
4126 </div>
4127
4128 <div id="dias-registro-interesse">
4129 <h4 class="ssp-card-registro-interesse__title-section-itens text-center">Dias da Semana</h4>
4130
4131 <div class="ssp-card-registro-interesse__week-content">
4132 <span id="todosDias" class="ssp-week-day">Todos</span>
4133 <span class="ssp-week-day">Seg</span>
4134 <span class="ssp-week-day">Ter</span>
4135 <span class="ssp-week-day">Qua</span>
4136 <span class="ssp-week-day">Qui</span>
4137 <span class="ssp-week-day">Sex</span>
4138 <span class="ssp-week-day">Sab</span>
4139 </div>
4140
4141 </div>
4142
4143 <div id="periodo-registro-interesse">
4144
4145 <h4 class="ssp-card-registro-interesse__title-section-itens text-center">Período:</h4>
4146
4147 <div class="ssp-card-registro-interesse__check-itens-content periodos-registro-interesse">
4148
4149 <div class="ssp-card-registro-interesse__check-item" id="div-campo-todos">
4150 <input type="checkbox" name="" value="" id="check-todos-periodos">
4151 <label for="check-todos-periodos">Todos</label>
4152 </div>
4153
4154 <div class="ssp-card-registro-interesse__check-item">
4155 <input type="checkbox" name="" value="M" id="periodo-m">
4156 <label for="periodo-m">Manhã</label>
4157 </div>
4158
4159 <div class="ssp-card-registro-interesse__check-item">
4160 <input type="checkbox" name="" value="T" id="periodo-t">
4161 <label for="periodo-t">Tarde</label>
4162 </div>
4163
4164 <div class="ssp-card-registro-interesse__check-item">
4165 <input type="checkbox" name="" value="N" id="periodo-n">
4166 <label for="periodo-n" "="">Noite</label>
4167 </div>
4168
4169
4170 </div>
4171
4172 </div>
4173
4174 <div class="ssp-card-registro-interesse__card-politica">
4175
4176
4177 </div>
4178
4179 <div class="ssp-card-registro-interesse__check-item">
4180 <input type="checkbox" name="" value="" id="check-politica-privacidade">
4181 <label for="check-politica-privacidade">Aceito a Política de Privacidade</label>
4182 </div>
4183
4184 <div class="text-center mt-5">
4185
4186 <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>
4187
4188 <p class="ssp-card-registro-interesse__aviso"><strong>Importante:</strong> O registro de interesse não garante a vaga.</p>
4189
4190 </div>
4191
4192 </div>
4193
4194 <#else>
4195
4196 <div class="ssp-card-registro-interesse emed">
4197
4198 <i id="btn-close-Modal-registro-interesse" class="fas fa-times btn-close__modal-login"></i>
4199
4200 <p class="ssp-card-registro-interesse__label-curso-selecionado">Curso selecionado:</p>
4201
4202 <div class="emed-select-group">
4203
4204 <h3 class="ssp-card-registro-interesse__title-modal"></h3>
4205
4206 <div id="unidades-registro-interesse">
4207
4208 <h4 class="ssp-card-registro-interesse__title-section-itens">Escolha uma unidade</h4>
4209
4210 <div id="select-unidades-registro-interesse">
4211 <select class="ssp-card-registro-interesse__select unidades" id="select_0"><option value="" disabled="" selected="">Selecione uma unidade</option></select>
4212 </div>
4213
4214 <div class="ssp-card-registro-interesse__add-mais">
4215 <a class="" id="add-unidade-regsitro-interesse" href="#a"><i class="fas fa-plus mr-1"></i>Adicionar unidade</a>
4216
4217
4218
4219 <a class="" id="remove-unidade-regsitro-interesse" href="#a"><i class="fas fa-times mr-1"></i>Remover unidade</a>
4220 </div>
4221
4222 </div>
4223
4224 </div>
4225
4226
4227 <div id="periodo-registro-interesse">
4228
4229 <p class="ssp-card-registro-interesse__title-section-itens">Período:</p>
4230
4231 <div class="ssp-card-registro-interesse__check-itens-content periodos-registro-interesse">
4232 <div class="ssp-card-registro-interesse__check-item">
4233 <input type="checkbox" name="" value="M" id="periodo-m">
4234 <label for="periodo-m">Manhã</label>
4235 </div>
4236
4237 <div class="ssp-card-registro-interesse__check-item">
4238 <input type="checkbox" name="" value="T" id="periodo-t">
4239 <label for="periodo-t">Tarde</label>
4240 </div>
4241
4242 <div class="ssp-card-registro-interesse__check-item" id="div-campo-todos">
4243 <input type="checkbox" name="" value="" id="check-todos-periodos">
4244 <label for="check-todos-periodos">Todos</label>
4245 </div>
4246
4247 </div>
4248
4249 </div>
4250
4251 <div id="turmas-registro-interesse">
4252
4253 <p class="ssp-card-registro-interesse__title-section-itens">Turma:</p>
4254
4255 <div class="ssp-card-registro-interesse__check-itens-content turmas-registro-interesse">
4256
4257 <div class="ssp-card-registro-interesse__check-item">
4258 <input type="checkbox" name="" value="1" id="primeiro">
4259 <label for="primeiro">1º ano</label>
4260 </div>
4261
4262 <div class="ssp-card-registro-interesse__check-item">
4263 <input type="checkbox" name="" value="2" id="segundo">
4264 <label for="segundo">2º ano</label>
4265 </div>
4266
4267 <div class="ssp-card-registro-interesse__check-item">
4268 <input type="checkbox" name="" value="3" id="terceiro">
4269 <label for="terceiro">3º ano</label>
4270 </div>
4271
4272 </div>
4273
4274 </div>
4275
4276 <div id="msg-transferencia-emed">
4277
4278 <div class="transferencia-emed-title">
4279 <i class="fas fa-comment-exclamation"></i>
4280 <p>Quer se transferir de escola?</p>
4281 </div>
4282
4283 <div class="transferencia-emed-link">
4284 <a href="#">Fale direto com a unidade de interesse.</a>
4285 </div>
4286
4287 </div>
4288
4289 <div class="ssp-card-registro-interesse__card-politica">
4290
4291 </div>
4292
4293 <div class="ssp-card-registro-interesse__check-item">
4294 <input type="checkbox" name="" value="" id="check-politica-privacidade">
4295 <label for="check-politica-privacidade">Aceito a Política de Privacidade</label>
4296 </div>
4297
4298 <div class="text-center mt-5">
4299
4300 <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>
4301
4302 <p class="ssp-card-registro-interesse__aviso"><strong>Importante:</strong> O registro de interesse não garante a vaga.</p>
4303
4304 </div>
4305
4306 </div>
4307
4308 </#if>
4309 </section>
4310
4311 <section id="modal-registro-interesse-sucesso" class="ssp-modal-registro-interesse d-none">
4312
4313 <div class="ssp-card-msg-sucesso">
4314
4315 <div class="ssp-card-msg-sucesso__content">
4316 <i class="fas fa-exclamation-circle"></i>
4317 <p>Obrigado por registrar seu interesse!</p>
4318 <p>Acompanhe seu e-mail para ficar por dentro das novidades!</p>
4319 </div>
4320
4321 <div>
4322 <a class="btn btn-nivel ssp-card-msg-sucesso__btn" href="#" id="btn-voltar-home">Voltar para a home</a>
4323 </div>
4324
4325 </div>
4326
4327 </section>
4328
4329 <section id="modal-registro-interesse-erro" class="ssp-modal-registro-interesse d-none">
4330
4331 <div class="ssp-card-msg-erro">
4332
4333 <div class="ssp-card-msg-sucesso__content">
4334 <i class="fas fa-exclamation-circle" style="color: #ec3a3a;"></i>
4335 <p>Houve um erro ao registrar seu interesse!</p>
4336 <p>Por favor, tente novamente!</p>
4337 </div>
4338
4339 <div>
4340 <a class="btn btn-nivel ssp-card-msg-sucesso__btn" href="#">Voltar para a home</a>
4341 </div>
4342
4343 </div>
4344
4345 </section>
4346
4347 <!-- Aviso para curso de aprendizagem -->
4348
4349 <div id="aviso-curso-aprendizagem" class="ssp-bolsa-formulario__card-aviso-atencao d-none" style="width: 100%;">
4350
4351 <i class="fas fa-exclamation-circle ssp-bolsa-formulario__card-aviso-atencao-icon" aria-hidden="true"></i>
4352
4353 <div class="ssp-bolsa-formulario__card-aviso-texto">
4354 <p>Para contratar aprendiz, preencha o formulário e entraremos em contato.</p>
4355 </div>
4356
4357 </div>
4358
4359 <!-- modal form de aprendizagem -->
4360
4361 <#if isAprendizagem>
4362
4363 <#assign resources = themeDisplay.getPortalURL() />
4364 <link href="${resources}/documents/d/global/css-formulario-aprendizagem" rel="stylesheet" type="text/css">
4365
4366 <dialog id="modal-form" class="ssp-modal-ds">
4367
4368 <button type="button" data-modal="close-form-modal">
4369 Fechar
4370 <i class="fas fa-times"></i>
4371 </button>
4372
4373 </dialog>
4374
4375 </#if>
4376
4377 <div id="avisoTrampolim" class="ssp-bolsa-formulario__card-aviso-atencao container text-left d-none" style="width: 100%;">
4378 <i class="fas fa-exclamation-circle ssp-bolsa-formulario__card-aviso-atencao-icon" aria-hidden="true"></i>
4379 <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>
4380 </div>
4381
4382 </div>
4383
4384
4385 <!--modal forma pagto extensao-->
4386 <section id="modalFormaPagtoExt" class="modal-extensao ssp-modal">
4387 <div class="modal-extensao_content">
4388 <i class="fas fa-undo modal-extensao-voltar-icon"><span class="modal-extensao-voltar-txticon">Voltar</span></i>
4389 <h1 class="modal-extensao-condicoes__title">Descontos e Parcelamento</h1>
4390 <div class="row">
4391
4392 <!-- <button class="btn-preco-padrao d-xs-flex d-sm-flex d-lg-none d-xl-none">
4393 Preço Padrão
4394 <i class="fas fa-chevron-right custom-icon-right"></i>
4395 </button> -->
4396
4397 <div class="col-lg-6 col-sm-12 col-xs-12">
4398
4399 <h2 class="modal-extensao_subtitle">Investimento</h2>
4400
4401 <span class="modal-extensao_preco">R$ <span class="precoVendaOferta"></span></span>
4402 <span class="modal-extensao_txteconomiza">.<b class="modal-extensao_txtverde"></b></span>
4403 <div class="modal-extensao_ctboleto pt-2 pb-2 mb-3">
4404 <i class="fas fa-barcode" aria-hidden="true"></i>
4405 <span class="modal-extensao_txtPag">Boleto Bancário</span>
4406 <span class="modal-extensao_txtParcela"><b><span class="numParcelaBoleto"></span>x de R$ <span class="precoParcelaBoleto"></span></b></span>
4407 <span class="modal-extensao_txtParcela">sem juros</span>
4408 </div>
4409 <div class="modal-extensao_ctcard pt-2 pb-2 mb-3">
4410 <i class="far fa-credit-card" aria-hidden="true"></i>
4411 <span class="modal-extensao_txtPag">Cartão de Crédito</span>
4412 <span class="modal-extensao_txtParcela"><b><span class="numParcelaCartoes"></span>x de R$ <span class="precoParcelaCartoes"></span></b></span>
4413 <span class="modal-extensao_txtParcela">sem juros</span>
4414 </div>
4415 <p class="modal-extensao_txtParcela pt-5"><b>À vista:</b> R$ <span class="precoAVistaPadraoExt"></span> <span class="modal-extensao_txtporcent">(-8%)</span></p>
4416 </div>
4417
4418 <!-- <hr class="ssp-divisor d-xs-block d-sm-block d-lg-none d-xl-none"> -->
4419
4420 <!-- <button class="btn-preco-ex-aluno d-xs-flex d-sm-flex d-lg-none d-xl-none">
4421 Preço para Contribuintes,<br>alunos e ex-alunos*
4422 <i class="fas fa-chevron-right custom-icon-right"></i>
4423 </button> -->
4424
4425 <div class="col-lg-6 col-sm-12 col-xs-12">
4426 <h2 class="modal-extensao_subtitle mt-4">Valor com 20% de desconto para alunos, ex-alunos e contribuintes Senac</h2>
4427 <span class="modal-extensao_preco">R$ <span class="precoContrExt"></span></span>
4428 <span class="modal-extensao_txteconomiza">Você economiza <b class="modal-extensao_txtverde">R$ <span class="economiaExt"></span> (-20%)</b></span>
4429 <div class="modal-extensao_ctboleto pt-2 pb-2 mb-3">
4430 <i class="fas fa-barcode" aria-hidden="true"></i>
4431 <span class="modal-extensao_txtPag">Boleto Bancário</span>
4432 <span class="modal-extensao_txtParcela"><b><span class="numParcelaBoleto"></span>x de R$ <span class="precoParcelaBoletoExt"></span></b></span>
4433 <span class="modal-extensao_txtParcela">sem juros</span>
4434 </div>
4435 <div class="modal-extensao_ctcard pt-2 pb-2 mb-3">
4436 <i class="far fa-credit-card" aria-hidden="true"></i>
4437 <span class="modal-extensao_txtPag">Cartão de Crédito</span>
4438 <span class="modal-extensao_txtParcela"><b><span class="numParcelaCartoes"></span>x de R$ <span class="precoParcelaCartoesExt"></span></b></span>
4439 <span class="modal-extensao_txtParcela">sem juros</span>
4440 </div>
4441 <p class="modal-extensao_txtParcela pt-5"><b>À vista:</b> R$ <span class="precoAVistaContrExt"></span> <span class="modal-extensao_txtporcent">(-8%)</span></p>
4442 </div>
4443 <div class="col-lg-6 col-sm-12 col-xs-12">
4444 <a target="_blank" href="#">
4445 <button class="btn modal-extensao__btn mt-3 text-uppercase">Comprar</button>
4446 </a>
4447 </div>
4448 <div class="col-lg-6 col-sm-12 col-xs-12">
4449 <button class="btn btn-primary modal-extensao-btn-conheca mt-3" >Conheça os descontos</button>
4450 </div>
4451 </div>
4452 </div>
4453
4454 <div class="modal-extensao_content modal-pergunta-aluno-ext d-none">
4455
4456 <i class="fal fa-times modal-extensao-voltar-icon" style="font-size:25px;"></i>
4457 <h1 class="modal-extensao-condicoes__title">Você é nosso aluno?</h1>
4458 <div class="row">
4459 <div class="col-6 text-right">
4460
4461 <button class="btn btn-primary modal-extensao-btn-aluno-sim-nao sim mt-3">Sim</button>
4462
4463 </div>
4464 <div class="col-6 text-left">
4465
4466 <button class="btn btn-primary modal-extensao-btn-aluno-sim-nao nao mt-3">Não</button>
4467
4468 </div>
4469 </div>
4470 <div class="row d-none msg-alunoSim">
4471 <div class="col-12 text-center mt-10">
4472 <i class="fas fa-check-circle modal-extensao-ico-check"></i>
4473 <h2 class="modal-extensao-condicoes__subtitle">Boa notícia!</h2>
4474 <p class="modal-extensao-aluno_txtcontent">Você tem 20% de desconto neste curso.<br> Faça seu login e preencha os dados solicitados.</p>
4475 <p class="mb-0">
4476 <a target="_blank" href="#">
4477 <button class="btn modal-extensao-aluno__btn ok mt-3">Fazer Inscrição</button>
4478 </a>
4479 </p>
4480 <p class="mt-0">
4481 <a href="https://www.sp.senac.br/descontos-e-parcelamentos/pos-e-extensao-universitaria">
4482 <button class="btn btn-primary modal-extensao-btn-conferir mt-3" id="btn-conferir-regras">Conferir Regras</button>
4483 </a>
4484 </p>
4485 </div>
4486 </div>
4487 <div class="row d-none msg-alunoNao">
4488 <div class="col-12 text-center mt-10">
4489 <i class="fas fa-percentage modal-extensao-ico-percent"></i>
4490 <h2 class="modal-extensao-condicoes__subtitle">Poxa! Não fique triste...</h2>
4491 <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>
4492 <p class="mb-0">
4493 <a target="_blank" href="#">
4494 <button class="btn modal-extensao-aluno__btn not mt-3">Fazer Inscrição</button>
4495 </a>
4496 </p>
4497 <p class="mt-0">
4498 <a href="https://www.sp.senac.br/descontos-e-parcelamentos/pos-e-extensao-universitaria">
4499 <button class="btn btn-primary modal-extensao-btn-conferir mt-3" id="btn-conferir-regras">Conferir Regras</button>
4500 </a>
4501 </p>
4502 </div>
4503 </div>
4504 </div>
4505 </section>
4506
4507
4508 <!-- Modal Descontos e Parcelamento EMED -->
4509 <div id="modalPagtoEmed" class="ssp-modal">
4510
4511 <div class="ssp-card-modal-forma-pagamento">
4512
4513 <div class="ssp-card-modal-forma-pagamento__header">
4514 <h6 class="ssp-card-modal-forma-pagamento__header-title font-weight-bold text-center" style="color:#454F63">Descontos e parcelamentos</h6>
4515 <div class="ssp-modal-emed-btfechar">
4516 <i class="ssp-card-modal-forma-pagamento__btn-close ssp-card-modal-forma-pagamento__btn-close_0"></i>
4517 <span>Fechar</span>
4518 </div>
4519 </div>
4520
4521 <div class="ssp-card-modal-forma-pagamento__body">
4522
4523 <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>
4524
4525 <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>
4526 <span class="ssp-card-modal-emed-ano">/ano</span></p>
4527
4528 <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>
4529 <div class="ssp-card-modal-emed-lineou"><span>ou</span></div>
4530
4531 <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>
4532
4533 <div class="ssp-card-modal-forma-pagamento__tipos">
4534
4535 <div class="ssp-card-modal-forma-pagamento__tipos-content align-items-start ssp-card-modal-emed-centralizaPagtos" style="margin:0 auto" >
4536 <i class="ssp-card-modal-forma-pagamento__icon-boleto-cartao"></i>
4537 <div class="ssp-card-modal-forma-pagamento__info-cartao">
4538 <p><strong>Cartão de Crédito +</strong></p>
4539 <p><strong>Boleto Bancário</strong></p>
4540 <!-- <p>1ª parcela em <span>até 4x de R$ <span class="valorParcelaEntradaCartoesBoleto">265,50</span></span> sem juros no cartão</p> -->
4541 <p>1ª parcela no cartão</p>
4542 <p>Valor restante em <span>até <span class="numParcelaCartoesBoleto"></span>x de <br>R$ <span class="precoParcelaCartoesBoleto"></span></span> sem juros no boleto</p>
4543 </div>
4544 </div>
4545
4546
4547 <div class="ssp-card-modal-forma-pagamento__tipos-content align-items-start ssp-card-modal-emed-centralizaPagtos" style="margin:0 auto" >
4548 <i class="ssp-card-modal-forma-pagamento__icon-credit-card"></i>
4549 <div class="ssp-card-modal-forma-pagamento__info-cartao">
4550 <p><strong>Cartão de Crédito</strong></p>
4551 <p>(<span class="textoCartoesAceitos">Mastercard, Visa, Elo, American Express, Hipercard</span>)</p>
4552 <p>Em até <span><span class="numParcelaCartoes">12</span>x de R$ <span class="precoParcelaCartoes">34,53</span></span> sem juros</p>
4553 </div>
4554 </div>
4555
4556 <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">
4557 <i class="ssp-card-modal-forma-pagamento__icon-boleto"></i>
4558 <div class="ssp-card-modal-forma-pagamento__info-cartao">
4559 <p><strong>Boleto Bancário</strong></p>
4560 <p>Em até <span><span class="numParcelaBoleto">12</span>x de R$ <span class="precoParcelaBoleto">34,53</span></span> sem juros</p>
4561 </div>
4562 </div>
4563
4564 <p class="txt-desconto-oito ssp-modal-emed-txt-desconto-oito ssp-modal-emed-boxoito" data-info="data-para-matricula"><span class="ssp-card-modal-emed-valorObs obsspan"><i class="fas fa-exclamation-circle"></i>As vagas são limitadas e por ordem de chegada!</span>Garanta seu lugar! Matricule-se agora.</p>
4565
4566 <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>
4567 - Estuda ou estudou no Senac<br>
4568 - É dependente de quem trabalha em empresa contribuinte do Senac<br>
4569 - Estuda ou estudou na rede pública de ensino
4570 </p>
4571
4572 </div>
4573
4574 </div>
4575
4576
4577 <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>
4578
4579
4580
4581 </div>
4582 </div>
4583
4584 <#if isEMED>
4585 <div id="modalAntesCompraEmed" class="ssp-modal">
4586 <div class="ssp-modal-local-realizacao">
4587 <div class="ssp-modal-local-realizacao__title-content">
4588 <h6 class="ssp-modal-local-realizacao__title" style="padding-left:10%;">IMPORTANTE!</h6>
4589 <i class="ssp-card-modal-antes-compra__btn-close ssp-card-modal-forma-pagamento__btn-close"></i>
4590 </div>
4591 <div class="ssp-modal-local-realizacao__texto">
4592 <p class="texto-modal-emed textoEmedModalAntesCompra0010 d-none">
4593
4594 Esta matrícula é válida apenas para a compra do curso de acordo com a escola e o horário já selecionados.<br/>
4595
4596 </p>
4597 <p class="texto-modal-emed textoEmedModalAntesCompra0010Espera d-none">
4598
4599 Saiba como funciona a inscrição para a lista de espera:<br/><br/>
4600 - É válida somente para a <b>compra do curso</b><br/>
4601 - Não garante vaga para o estudante<br/>
4602 - É válida apenas para o curso, horário e escola selecionados<br/>
4603 - Caso surjam vagas, você receberá um e-mail para fazer a matrícula<br/>
4604
4605 </p>
4606 <p class="texto-modal-emed textoEmedModalAntesCompra0020e0030 d-none">
4607
4608 - 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/>
4609 - A inscrição só pode ser solicitada para quem deseja estudar no Senac realizando a compra do curso<br/><br/>
4610 - 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
4611
4612 </p>
4613 <div class="btn ssp-modal-local-realizacao__btn-content">
4614 <button class="btn btn-lg btn-success w-100 mt-3" offercode="" id="btnCompraLocalEmed">Continuar para compra</button>
4615 <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>
4616 </div>
4617 </div>
4618 </div>
4619 </div>
4620
4621 </#if>
4622
4623
4624
4625
4626 <script>
4627 let showedFilters = false
4628 var groupId = themeDisplay.getScopeGroupId();
4629
4630 var urlSearchCursosPorCategory = '/o/senac-curso-services/cursosPorCategoryIds/{groupId}?categoryIds={categoryId}&start=0&end={limit}';
4631
4632 var urlSearchOferta = '/o/senac-oferta-services/ofertasPorCategoryIds/' + groupId
4633
4634 var urlSearchUnidade = '/o/senacsearch/Unidade/{companyId}/{groupId}/{userId}?q=codigoUnidade_pt_BR:{codigoUnidade}';
4635 var urlUnidadeInfoDetalhe = '/o/senac-content-services/unidadeInfoDetalhe/{companyId}/{codigoUnidade}';
4636 var urlSearchCursosPodeGostar = '/o/senac-content-services/cursosVocePodeGostar/{companyId}/{groupId}/{userId}/{articleId}/{limit}';
4637 var urlSearchCursoInfo = '/o/senac-content-services/cursosInfoDetalhe/{groupId}/{cursosInfo}?inscricaoAberta={inscricaoAberta}&bolsaAberta={bolsaAberta}&buscarUnidadesComOferta={buscarUnidadesComOferta}';
4638 var urlRegistroInteresse = '/o/senac-content-services/registroInteresse/';
4639 var urlRegistroInteresseEmailInteressado = '/o/senac-content-services/envioEmailRegistroInteresse/';
4640 var cntSelectUnidades = 1;
4641 var urlPlanoCurso = 'https://www.sp.senac.br/jsp/includeMatdid.jsp?file=/ha1shared/projects/matdid/{codigoFT}-{dataEfetiva}.html';
4642 var urlGetServerT = '/o/senac-content-services/getServerTime';
4643 var urlSearchCursosPodeGostarEmed = '/o/senac-curso-services/cursosPorCategoryIdsFilterAndOr/{groupId}/?categoryIdsOr={tiposDeCurso}&start=0&end={limit}&articleId={articleId}';
4644 var todayG = '';
4645 var codigoFTCursoAprendizagem = 18984;
4646 var globalGroupId = Liferay.ThemeDisplay.getCompanyGroupId();
4647 var isAoVivo = 0;
4648 var nomeFormatoAoVivoDxp = 'Senac Online - ao vivo';
4649 var ofertaUnidadeMap = new Map();
4650 var ultimaUnidade = 0;
4651 var regIndex = new RegExp('\{index\}', 'g');
4652 var linkBotaoCompra = 'http://www.sp.senac.br/login/Login?destino=/ecommerceFrontEnd/?vcw_unidade={codigoUnidade}&vcw_evento={codigoOferta}';
4653 var carregouUltimaOferta = false;
4654 var ofertasMap = new Map();
4655 var codUnidadeSenacAoVivo = '108';
4656 var ofertasComBolsa = false;
4657
4658 //funcao para pegar host do ambiente, se eh teste ou prod (utilizado no servico da bolsa)- 9546
4659 function getServiceEnvironmentHost(){
4660 if(!isAmbienteTeste())
4661 return window.location.origin
4662 else
4663 return 'https://gesportal.sp.senac.br'
4664 }
4665
4666 var hostBolsa = getServiceEnvironmentHost()
4667
4668 // Montar object push - google tag manager - 1
4669 let itensEcommerce = null;
4670 let ofertaSelecionada = null;
4671
4672 const today = new Date;
4673
4674 //categoryId -> cod unidade
4675 var mapUnidadesIds = new Map();
4676 var objsTela = {
4677 unidades: [],
4678 unidadesRegistroInteresse: [],
4679 categoriesIds:[],
4680 ofertasAoVivoTodasUnidades: [],
4681 primeiroChange: true
4682 };
4683 var startOfertaParam = 0;
4684 var endOfertaParam = 25;
4685
4686 var ehCursoTrampolim = false;
4687
4688 const isHibrido = $('input[name="formato"]').data('formato') === 'Presencial + EAD';
4689
4690 var textoFormatoHibrido = "";
4691 var temTextoParaFormatoHibrido = false;
4692
4693 //Validar se o campo textoFormatoHibrido existe e se não está vazio
4694 if(isHibrido){
4695 textoFormatoHibrido = $('input[name="textoFormatoHibrido"]').val();
4696 if(typeof textoFormatoHibrido !== 'undefined'){
4697 if (textoFormatoHibrido.trim() !== '' ) {
4698 temTextoParaFormatoHibrido = true;
4699 textoFormatoHibrido += '<br>';
4700 }
4701 }
4702 }
4703
4704 const HOST = window.location.origin;
4705 const URLGeral = window.location.href;
4706
4707 //EMED
4708 const anoTurmaEmed = '2026';
4709
4710 const tipoCursoNome = function(){ return $('.ssp-header-curso__tag-formato').text().trim(); }
4711
4712 const isEmed = (tipoCursoNome().indexOf('Ensino Médio Técnico') > -1);
4713
4714 const statusEmed = Object.freeze({
4715 NAO_ENCONTRADA: 0,
4716 INSCRICAO: 1,
4717 ESPERA: 2,
4718 ESGOTADO: 3
4719 });
4720
4721 let unidadesToURL = []
4722
4723 const loadPoliticaPrivacidade = async function() {
4724
4725 if(PortalService !== 'undefined') {
4726 const politicaContent = await PortalService.getPoliticaPrivacidade();
4727 document.querySelectorAll('.ssp-card-registro-interesse__card-politica').forEach(el => {
4728 el.innerHTML = politicaContent;
4729 });
4730 }
4731
4732 }
4733
4734 const localLivreOnline = function(textoLocal){
4735 textoLocal = textoLocal || ''
4736 textoLocal = textoLocal.replaceAll('online', 'on-line')
4737
4738 const textoOnline = 'Nesta turma, todas as aulas serão on-line e ao vivo pela plataforma digital Microsoft Teams';
4739
4740 return textoLocal.toUpperCase().includes(textoOnline.toUpperCase());
4741 }
4742
4743 const linkBolsa = function(oferta){
4744
4745 let tiposCurso = new Map();
4746 tiposCurso.set('livre', 'L');
4747 tiposCurso.set('tecnico', 'T');
4748 tiposCurso.set('aprendizagem', 'A');
4749 let letraTipoCurso = tiposCurso.get($('[name="tipoCurso"]').val()) || '';
4750
4751 // verifica o campo destinoBolsa da oferta - 9546
4752 var destinoBolsa = ""
4753 if(oferta.destinoBolsa){
4754 destinoBolsa = parseInt(oferta.destinoBolsa,10)
4755 }
4756
4757 return hostBolsa+'/login/Login?origem=bolsas&destino=/jsp/default.jsp?template=2464.dwt&testeira=1540&idcourse='+
4758 $('[name="codigoFT"]').val()+
4759 '&cod_evento='+
4760 oferta.codigoOferta+
4761 '&cod_u='+
4762 codigoUnidade+
4763 '&nvg='+
4764 oferta.qtdeTotalVagasPSG+
4765 '&type='+
4766 letraTipoCurso+
4767 '&sel_unit=&ft=y'+
4768 (destinoBolsa ? '&destino='+destinoBolsa : '');
4769 }
4770
4771
4772 $('.ssp-ofertas-emed__filtro-content .btn').on('click', function(){
4773
4774 var classAtivo = 'btn--filtro-ativo';
4775
4776 if(!$(this).hasClass(classAtivo)){
4777
4778 $(this).siblings().removeClass(classAtivo);
4779
4780 $(this).addClass(classAtivo);
4781
4782 const $cardTransferencias = $('.card-transferencias-emed');
4783
4784 if($(this).val() == '0'){
4785 hideCardSemTurmas(true);
4786 $('.ssp-slick-ofertas-emed').empty();
4787 if(!$('.ssp-slick-ofertas-emed').hasClass('d-none')) $('.ssp-slick-ofertas-emed').addClass('d-none');
4788 $('.prev-mobile, .next-mobile').addClass('d-none');
4789 $cardTransferencias.removeClass('d-none');
4790 } else{
4791 if(!$cardTransferencias.hasClass('d-none')) $cardTransferencias.addClass('d-none');
4792 $('.ssp-slick-ofertas-emed').removeClass('d-none');
4793 populaOfertas(objsTela.ofertas);
4794 }
4795
4796 }
4797
4798 });
4799
4800 //Cronometro
4801 var hidden, visibilityChange;
4802 var restartTimeout = null;
4803 var interval01, interval15;
4804
4805 if (typeof document.hidden !== "undefined") { // Opera 12.10 and Firefox 18 and later support
4806 hidden = "hidden";
4807 visibilityChange = "visibilitychange";
4808 } else if (typeof document.msHidden !== "undefined") {
4809 hidden = "msHidden";
4810 visibilityChange = "msvisibilitychange";
4811 } else if (typeof document.webkitHidden !== "undefined") {
4812 hidden = "webkitHidden";
4813 visibilityChange = "webkitvisibilitychange";
4814 }
4815
4816 // Verifica suporte a Visibility API
4817 if (typeof document.addEventListener === "undefined" || hidden === undefined) {
4818 console.log("Navegador incompativel com page visibility api");
4819 } else {
4820 // Evento para quando a visibilidade da pagina mudar
4821 document.addEventListener(visibilityChange, handleVisibilityChange, false);
4822 }
4823
4824 $(".ssp-saiba-mais-curso-accordion").on("click", ".ssp-saiba-mais-curso-accordion__heading", function() {
4825
4826 $(this).toggleClass("active").next().slideToggle();
4827
4828 $(".sp-saiba-mais-curso-accordion__contents").not($(this).next()).slideUp(300);
4829
4830 $(this).siblings().removeClass("active");
4831 });
4832
4833 function loadUnidadesRegistroInteresse(urlCursoInfo) {
4834 if(objsTela.unidadesRegistroInteresse && objsTela.unidadesRegistroInteresse.length)
4835 return
4836
4837 let urlUnidades = new URL(window.location.origin + urlCursoInfo)
4838 let paramsUnidades = new URLSearchParams(urlUnidades.search)
4839 paramsUnidades.delete('inscricaoAberta')
4840 paramsUnidades.delete('bolsaAberta')
4841 paramsUnidades.delete('buscarUnidadesComOferta')
4842 urlUnidades.search = '?' + paramsUnidades.toString()
4843 urlUnidades = urlUnidades.href
4844
4845 $.ajax({
4846 url: urlUnidades,
4847 method:'get',
4848 async: false
4849 }).done(function(data){
4850 if(data.length > 0){
4851 const cursoInfo = JSON.parse(data);
4852 const unidadesOfertantes = cursoInfo.unidadesOfertantes;
4853
4854 $.each(unidadesOfertantes, function(k,item){
4855 var unidade = {};
4856 unidade['categoryId'] = item['categoryId'];
4857 unidade['codigoUnidade'] = item['codigoUnidade'];
4858 unidade['nome'] = item['nomeUnidade'];
4859 unidade['enderecoUnidade'] =item['enderecoUnidade'];
4860 unidade['numero'] =item['numEnderecoUnidade'];
4861 unidade['complemento'] = item['complementoEnderecoUnidade'];
4862 unidade['bairro'] = item['bairroUnidade'];
4863 unidade['googlemapsUnidade'] = item['googlemapsUnidade'];
4864 unidade['friendlyURL'] = item['friendlyURL'];
4865 unidade['selecionado'] = false;
4866 unidade['selectSelecionado'] = "";
4867 unidade['ofertas'] = [];
4868
4869 if(!objsTela.unidadesRegistroInteresse.filter(uni => uni['categoryId'] == unidade['categoryId']).length)
4870 objsTela.unidadesRegistroInteresse.push(unidade)
4871 });
4872 }
4873 });
4874 }
4875
4876 function loadUnidades(showOptions, unidadeValue){
4877 //Busca as unidades do curso
4878 let buscarUnidadesComOferta = false;
4879
4880 if( !isEmed && ( !$('#chkInscricao').prop('checked') && !$('#chkBolsa').prop('checked')))
4881 buscarUnidadesComOferta = true;
4882
4883 const urlCursoInfo = urlSearchCursoInfo
4884 .replace('\{groupId\}', groupId)
4885 .replace('\{cursosInfo\}', $('[name="articleId"]').val())
4886 .replace('\{inscricaoAberta\}', $('#chkInscricao').prop('checked'))
4887 .replace('\{bolsaAberta\}', $('#chkBolsa').prop('checked'))
4888 .replace('\{buscarUnidadesComOferta\}', buscarUnidadesComOferta);
4889
4890 loadUnidadesRegistroInteresse(urlCursoInfo)
4891
4892 $.ajax({
4893 url:urlCursoInfo,
4894 method:'get',
4895 async: false,
4896 beforeSend: function () {
4897 loading('.oferta-slick-area');
4898 }
4899 }).done(
4900 function(data){
4901
4902 if(data.length > 0){
4903
4904 const cursoInfo = JSON.parse(data);
4905
4906 const unidades = buscarUnidadesComOferta ? cursoInfo.unidadesComOferta : cursoInfo.unidadesOfertantes;
4907
4908 if(!isAoVivo && (!buscarUnidadesComOferta || unidades.length > 0))
4909 $('.ssp-container-selecione-unidade').removeClass('d-none')
4910
4911 objsTela.unidades = []
4912 mapUnidadesIds = new Map();
4913
4914 $.each(unidades, function(k,item){
4915
4916 var unidade = cloneObj(item)
4917 unidade['nome'] = item['nomeUnidade'];
4918 unidade['numero'] =item['numEnderecoUnidade'];
4919 unidade['complemento'] = item['complementoEnderecoUnidade'];
4920 unidade['bairro'] = item['bairroUnidade'];
4921 unidade['ofertas'] = [];
4922
4923 objsTela.unidades.push(unidade);
4924
4925 mapUnidadesIds.set(unidade['categoryId'], unidade['codigoUnidade']);
4926
4927 objsTela.unidades.forEach(unidade => unidadesToURL.filter(u => u.friendlyURL == unidade.friendlyURL).length ? '' : unidadesToURL.push(unidade))
4928 });
4929
4930
4931 populaSelectUnidades(undefined, showOptions, unidadeValue);
4932
4933 }
4934 });
4935
4936 }
4937
4938function getOfertaObjectFromJson(ofertaJSON,index){
4939
4940
4941 var oferta = {};
4942 var xml = $($.parseXML(ofertaJSON.content));
4943 oferta['ordenar'] = paramOrdem(xml);
4944 oferta['vagasTotal'] = xml.find('[name="vagasTotal"]').text().trim();
4945 var dataInicio = xml.find('[name="dataInicioOferta"]').text().split('-');
4946 var dataFim =xml.find('[name="dataFimOferta"]').text().split('-');
4947 oferta['dataInicio'] = dataInicio[2].trim()+'/'+dataInicio[1].trim()+'/'+dataInicio[0].trim();
4948 oferta['dataFim'] = dataFim[2].trim()+'/'+dataFim[1].trim()+'/'+dataFim[0].trim();
4949 oferta['horaInicio'] = xml.find('[name="horaInicioOferta"]').text();
4950 oferta['codigoOferta'] = xml.find('[name="codigoOferta"]').text().trim();
4951 var dias = [];
4952 oferta['horaFimOferta'] = xml.find('[name="horaFimOferta"]').text().trim();
4953 xml.find('[name="diasDaSemanaOferta"]').find('option').each(function(index,dia){
4954 dias.push($(dia).text());
4955 });
4956 oferta['diasDaSemanaOferta'] = dias;
4957 oferta['periodoDiaOferta'] = xml.find('[name="periodoDiaOferta"]').text().trim();
4958 oferta['precoCheioOferta'] = xml.find('[name="precoCheioOferta"]').text().trim();
4959 oferta['precoVendaOferta'] = xml.find('[name="precoVendaOferta"]').text().trim();
4960 oferta['numeroMaxParcelasOferta'] = xml.find('[name="numeroMaxParcelasOferta"]').text().trim();
4961
4962 oferta['textoCartoesAceitos'] = pegarTextoCartoesAceitos(xml.find('[name="formaDePagamentoCartaoOferta"]').text().trim());
4963 oferta['numParcelaCartoes'] = pegaNumParcela(xml.find('[name="formaDePagamentoCartaoOferta"]').text().trim());
4964 oferta['precoParcelaCartoes'] = pegaValorParcela(xml.find('[name="formaDePagamentoCartaoOferta"]').text().trim());
4965 oferta['numParcelaBoleto'] = pegaNumParcela(xml.find('[name="formaDePagamentoBoletoOferta"]').text().trim());
4966 oferta['precoParcelaBoleto'] = pegaValorParcela(xml.find('[name="formaDePagamentoBoletoOferta"]').text().trim());
4967
4968 oferta['precoVendaMaxParcelaOferta'] = xml.find('[name="precoVendaMaxParcelaOferta"]').text().trim();
4969 oferta['formaDePagamentoOferta'] = xml.find('[name="formaDePagamentoOferta"]').text().trim();
4970 oferta['botaoCompraOferta'] = xml.find('[name="botaoCompraOferta"]').text().trim();
4971 oferta['vagasParaCompraOferta'] = xml.find('[name="vagasParaCompraOferta"]').text().trim();
4972 oferta['botaoBolsaOferta'] = xml.find('[name="botaoBolsaOferta"]').text().trim();
4973 oferta['vagasBolsaOferta'] = xml.find('[name="vagasBolsaOferta"]').text().trim();
4974 oferta['dataAberturaBolsaOferta'] = xml.find('[name="dataAberturaBolsaOferta"]').text().trim();
4975 oferta['horaAberturaBolsaOferta'] = xml.find('[name="horaAberturaBolsaOferta"]').text().trim();
4976 oferta['espacoExterno'] = xml.find('[name="espacoExterno"]').text().trim();
4977 oferta['localEspacoExterno'] = xml.find('[name="localEspacoExterno"]').text().trim();
4978 oferta['ruaEspacoExterno'] = xml.find('[name="ruaEspacoExterno"]').text().trim();
4979 oferta['numeroEspacoExterno'] = xml.find('[name="numeroEspacoExterno"]').text().trim();
4980 oferta['complementoEspacoExterno'] = xml.find('[name="complementoEspacoExterno"]').text().trim();
4981 oferta['bairroEspacoExterno'] = xml.find('[name="bairroEspacoExterno"]').text().trim();
4982 oferta['cidadeEspacoExterno'] = xml.find('[name="cidadeEspacoExterno"]').text().trim();
4983 oferta['ufEspacoExterno'] = xml.find('[name="ufEspacoExterno"]').text().trim();
4984 oferta['cepEspacoExterno'] = xml.find('[name="cepEspacoExterno"]').text().trim();
4985 oferta['qtdeTotalVagas'] = xml.find('[name="qtdeTotalVagas"]').text().trim();
4986 oferta['qtdeTotalVagasPSG'] = xml.find('[name="qtdeTotalVagasPSG"]').text().trim();
4987 oferta['horariosAllOferta'] = xml.find('[name="horariosAllOferta"]').text().trim();
4988 oferta['formaDePagamentoCartaoOferta'] = xml.find('[name="formaDePagamentoCartaoOferta"]').text().trim();
4989 oferta['formaDePagamentoBoletoOferta'] = xml.find('[name="formaDePagamentoBoletoOferta"]').text().trim();
4990 oferta['dtLimiteMatricula'] = xml.find('[name="dtLimiteMatricula"]').text().trim();
4991 oferta['dataAberturaMatricula'] = xml.find('[name="dataAberturaMatricula"]').text().trim();
4992 oferta['etapa'] = xml.find('[name="etapa"]').text().trim();
4993 oferta['destinoCompra'] = xml.find('[name="destinoCompra"]').text().trim();
4994 //adicao do destinoBolsa na oferta - 9546 - 11/07/2022
4995 oferta['destinoBolsa'] = xml.find('[name="destinoBolsa"]').text().trim();
4996
4997 // 18/07/2025 - Removido o dataAberturaBolsaOferta recebendo o dataAberturaMatricula
4998 // devido a mudança de regra que recebemos da área
4999
5000 return oferta;
5001 }
5002
5003 const getStatusEmed = (oferta) => {
5004
5005 const urlStatusEsperaEmed = () => {
5006 let url = (isAmbienteTeste()) ?
5007 'https://hinscricao-educacional-backend.sp.senac.br/api/lista-espera/'
5008 : 'https://inscricao-educacional-ms.sp.senac.br/api/lista-espera/';
5009
5010 return url + oferta.codigoOferta;
5011 }
5012
5013 const callTl = async () => {
5014 if(getCookie('tl') == null){
5015 return await $.ajax({
5016 url: '/o/senac-content-services/geraTokenServicosSenac',
5017 method: 'GET'
5018 });
5019 }
5020 return getCookie('tl');
5021 }
5022
5023 const callListaEspera = async () => {
5024 var tl = '';
5025 try{
5026 tl = await callTl();
5027 if(getCookie('tl') == null){
5028 tl = JSON.parse(tl).token;
5029 writeCookie('tl', tl, 6, '');
5030 }
5031 }catch(err){
5032 console.error(err);
5033 return {};
5034 }
5035
5036 return $.ajax({
5037 url: urlStatusEsperaEmed(),
5038 method: 'GET',
5039 beforeSend: function (xhr) {
5040 xhr.setRequestHeader("Authorization", tl);
5041 }
5042 })
5043 }
5044
5045 return new Promise(async function (resolve, reject) {
5046 const resp = await callListaEspera();
5047 if(typeof resp !== 'object') resp = JSON.parse(resp);
5048 let status = resp.STATUS;
5049 resolve(status);
5050 });
5051
5052 }
5053
5054 function getOfertasAoVivo(codigoFT, dataEfetivaOferta, categoryIds){
5055
5056 if(categoryIds && categoryIds.length) {
5057 var params = new URLSearchParams();
5058 params.set('codigoFTOferta',codigoFT)
5059 params.set('dataEfetivaOferta',dataEfetivaOferta)
5060 params.set('categoryIds',categoryIds)
5061 params.set('start',startOfertaParam)
5062 params.set('end',endOfertaParam)
5063 params.set('inscricaoAberta', $('#chkInscricao').prop('checked'))
5064 params.set('bolsaAberta', $('#chkBolsa').prop('checked'))
5065 params.set('cursoArticleId', $('[name="articleId"]').val() || '');
5066
5067 if($('#chkBolsa').prop('checked')){
5068 params.set('considerarDataBolsaFutura', true)
5069 }
5070 const url = urlSearchOferta + '?' + params.toString()
5071
5072 $.ajax({
5073 url:url,
5074 method:'get',
5075 dataType:'json',
5076 async: false
5077 }).done(
5078 function(data){
5079
5080 if(data.length > 0){
5081 $('#ssp-alternadores').show()
5082 showedFilters = true
5083
5084 objsTela.ofertasAoVivoTodasUnidades = []
5085
5086 data.forEach(function(ofertaJSON,index){
5087
5088 var oferta = getOfertaObjectFromJson(ofertaJSON,index);
5089
5090 //guardo em um map a oferta e qual unidade é, para utilizar depois no populaOferta para o aoVivo
5091 ofertaUnidadeMap.set(oferta['codigoOferta'],mapUnidadesIds.get(parseInt(ofertaJSON.unidadeCategoryIds)));
5092 objsTela.ofertasAoVivoTodasUnidades.push(oferta);
5093
5094 });
5095 } else {
5096 loadAlternadores(data)
5097 }
5098
5099 populaOfertas(objsTela.ofertasAoVivoTodasUnidades);
5100 addEventBolsa()
5101 }
5102 ).fail(function(e) {
5103 console.error(e)
5104 populaOfertas(objsTela.ofertasAoVivoTodasUnidades = []);
5105 })
5106 } else {
5107 loadAlternadores([])
5108 populaOfertas(objsTela.ofertasAoVivoTodasUnidades = [])
5109 }
5110
5111 if(isAoVivo) {
5112 if(objsTela.ofertasAoVivoTodasUnidades && objsTela.ofertasAoVivoTodasUnidades.length)
5113 hideCardSemTurmas(true)
5114 else
5115 hideCardSemTurmas(false)
5116 }
5117 }
5118
5119 function mudouToggleOferta(ofertas) {
5120 const oferta = ofertas && ofertas[0]
5121 if(!oferta)
5122 return true
5123
5124 const selecaoInscricao = $('#chkInscricao').prop('checked')
5125 const selecaoBolsa = $('#chkBolsa').prop('checked')
5126
5127 return oferta.selecaoInscricao != selecaoInscricao || oferta.selecaoBolsa != selecaoBolsa
5128 }
5129
5130 function loadAlternadores(ofertas) {
5131 if(showedFilters) {
5132 $('#ssp-alternadores').show()
5133 return
5134 }
5135
5136 if($('#unidades-ofertas').is(":hidden") || $('#unidades-ofertas option').length <= 1) {
5137 if(isAoVivo) {
5138 if(ofertas && ofertas.length)
5139 $('#ssp-alternadores').show()
5140 else {
5141 if(!$('#chkInscricao').prop('checked') && !$('#chkBolsa').prop('checked'))
5142 $('#ssp-alternadores').hide()
5143 else
5144 $('#ssp-alternadores').show()
5145 }
5146 } else {
5147 if(!$('#chkInscricao').prop('checked') && !$('#chkBolsa').prop('checked'))
5148 $('#ssp-alternadores').hide()
5149 else
5150 $('#ssp-alternadores').show()
5151 }
5152 } else
5153 $('#ssp-alternadores').show()
5154
5155 showedFilters = showedFilters || $('#ssp-alternadores').is(":visible")
5156 }
5157
5158 function getOfertas(codigoFT, dataEfetivaOferta, categoryId){
5159
5160 var indiceUnidade = -1;
5161 const selecaoInscricao = $('#chkInscricao').prop('checked')
5162 const selecaoBolsa = $('#chkBolsa').prop('checked')
5163
5164 for(var i = 0; i < objsTela.unidades.length; i++)
5165 if(objsTela.unidades[i].categoryId == categoryId)
5166 indiceUnidade = i;
5167
5168 ultimaUnidade = indiceUnidade;
5169
5170 if( !objsTela.categoriesIds.includes(categoryId) || mudouToggleOferta(objsTela.unidades[indiceUnidade]['ofertas'])){
5171 objsTela.unidades[indiceUnidade]['ofertas'] = []
5172
5173 var params = new URLSearchParams();
5174 params.set('codigoFTOferta',codigoFT)
5175 params.set('dataEfetivaOferta',dataEfetivaOferta)
5176 params.set('categoryIds',categoryId)
5177 params.set('start',startOfertaParam)
5178 params.set('end',endOfertaParam)
5179 params.set('inscricaoAberta', $('#chkInscricao').prop('checked'))
5180 params.set('bolsaAberta', $('#chkBolsa').prop('checked'))
5181 params.set('cursoArticleId', $('[name="articleId"]').val() || '');
5182
5183 if($('#chkBolsa').prop('checked')){
5184 params.set('considerarDataBolsaFutura', true)
5185 }
5186
5187 const url = urlSearchOferta + '?' + params.toString()
5188
5189 $.ajax({
5190 url:url,
5191 method:'get',
5192 dataType:'json',
5193 async: false
5194 }).done(
5195 function(data){
5196
5197 if(data.length > 0){
5198 $('#ssp-alternadores').show()
5199 showedFilters = true
5200
5201 $('.ssp-container-selecione-unidade').show();
5202
5203 data.forEach(function(ofertaJSON,index){
5204
5205 var oferta = getOfertaObjectFromJson(ofertaJSON,index);
5206
5207 //Preenche as ofertas da unidade
5208 objsTela.unidades[indiceUnidade]['ofertas'].push(oferta);
5209 objsTela.unidades[indiceUnidade]['ofertas'].forEach(o => {
5210 o.selecaoInscricao = selecaoInscricao
5211 o.selecaoBolsa = selecaoBolsa
5212 })
5213
5214 });
5215 } else {
5216 loadAlternadores()
5217 }
5218 objsTela.categoriesIds.push(categoryId);
5219 populaOfertas(objsTela.unidades[indiceUnidade]['ofertas']);
5220 addEventBolsa()
5221 }
5222 )
5223
5224 //Se estiver na cache, valida as ofertas
5225 }else{
5226
5227 populaOfertas(objsTela.unidades[indiceUnidade]['ofertas']);
5228
5229 }
5230 }
5231
5232 function populaSelectUnidades(unidades, showOptions, unidadeValue){
5233 var unidadePreSelecionada = false;
5234 var categoryIdUnidadePreSelecionada = '';
5235
5236 //Oredenacao
5237 objsTela.unidades.sort(function (a, b) {
5238 return ordenar(a, b, 'nome');
5239 });
5240
5241 objsTela.unidadesRegistroInteresse.sort(function (a, b) {
5242 return ordenar(a, b, 'nome');
5243 });
5244
5245 //console.log(objsTela.unidades);
5246
5247 $.each(objsTela.unidades, function(k,item){
5248
5249 if(getURLData().includes('/'+item.friendlyURL+'/')){
5250 unidadePreSelecionada= true;
5251 categoryIdUnidadePreSelecionada = item['categoryId'];
5252 }
5253 });
5254
5255 //console.log('Unidade Pre '+unidadePreSelecionada);
5256
5257 if(objsTela.unidades.length == 0){
5258 if(!showOptions)
5259 $('.ssp-container-selecione-unidade').addClass('d-none');
5260 $('.oferta-slick-area').empty();
5261 $('.prev-mobile').addClass('d-none');
5262 $('.next-mobile').addClass('d-none');
5263 //EMED remove msg registro interesse
5264 //if(isEmed) $('.ssp-card-oferta-curso__sem-vaga-description').addClass('d-none');
5265 }
5266
5267 if(isAoVivo){
5268
5269 const codigoFT = $('[name="codigoFT"]').val();
5270 const dataEfetivaOferta = $('[name="dataEfetivaSTR"]').val();
5271
5272 var unidadesCategoryAll = '';
5273
5274 $.each(objsTela.unidades, function(k,unidade){
5275 unidadesCategoryAll += unidade['categoryId']+',';
5276 });
5277
5278 //tirando ultima virgula
5279 unidadesCategoryAll = unidadesCategoryAll.substring(0,unidadesCategoryAll.length - 1);
5280
5281 getOfertasAoVivo(codigoFT, dataEfetivaOferta, unidadesCategoryAll);
5282
5283 }else{
5284 $('#unidades-ofertas').empty()
5285
5286 if(objsTela.unidades && objsTela.unidades.length){
5287 if(isEmed)
5288 $('#unidades-ofertas').append($('<option value="">Selecione uma unidade</option>'))
5289 else
5290 $('#unidades-ofertas').append($('<option value="">Clique na unidade de interesse</option>'))
5291
5292 } else
5293 $('#unidades-ofertas').append($('<option value="">Nenhum resultado encontrado</option>'))
5294
5295 let unidadeFounded = criarOptionUnidadesPorRegiao(objsTela.unidades)
5296
5297 //Dispara o evento para primeira unidade ou pela friendlyURl da unidade
5298 if(unidadeValue) {
5299 $('#unidades-ofertas').val(unidadeValue);
5300 $('#unidades-ofertas').change();
5301 } else if(unidadeFounded){
5302 $('#unidades-ofertas').val(unidadeFounded['categoryId']+"@"+unidadeFounded['codigoUnidade']);
5303 $('#unidades-ofertas').change();
5304 } else if(!unidadePreSelecionada) {
5305 $('#unidades-ofertas').change();
5306 }
5307
5308 $('.ssp-card-registro-interesse__select.unidades').empty()
5309 $('.ssp-card-registro-interesse__select.unidades').append('<option value="" disabled selected>Selecione uma unidade</option>')
5310 $.each(objsTela.unidadesRegistroInteresse, function(k,unidade){
5311
5312 $('.ssp-card-registro-interesse__select.unidades').append('<option value="'+unidade['codigoUnidade']+'">'+unidade['nome']+'</option>');
5313 });
5314 }
5315
5316 }
5317
5318 function excecaoCursoGratuito(oferta){
5319 return $('[name="modalidadeName"]').val() == 'acoes-educ.-curta-duracao' && $('[name="tipoCurso"]').val() == 'livre' && (strToFloat(oferta.precoVendaOferta) == 0);
5320 }
5321
5322
5323 function mudarUnidade(ev){
5324 startOfertaParam = 0;
5325 endOfertaParam = 25;
5326 carregouUltimaOferta = false;
5327
5328 var elem = $(ev.target);
5329 var unidades = objsTela.unidades;
5330
5331 //verifica se selecionou alguma unidade
5332 if(!elem.val()){
5333 $('#informe-novas-turmas, .ssp-ofertas-emed__section, .ssp-ofertas__box-endereco-unidade').addClass('d-none');
5334
5335 if(isEmed)
5336 $('#ssp-section-response').addClass('d-none')
5337
5338 hideCardSemTurmas($('#unidades-ofertas option').length > 1)
5339
5340 elem.val('')
5341 habilitarRegistroInteresse(false)
5342 //Zera variável que controla existência de ofertas com bolsa
5343 ofertasComBolsa = false;
5344 controlaPaginaBolsa();
5345
5346 return;
5347 }
5348
5349 $('#informe-novas-turmas, .ssp-ofertas__box-endereco-unidade').removeClass('d-none');
5350 hideCardSemTurmas(true)
5351 if(isEmed){
5352 $('.ssp-ofertas-emed__section').removeClass('d-none');
5353 $('#ssp-section-response').removeClass('d-none')
5354 $('.ssp-card-oferta-curso__section-title').addClass('d-none');
5355 $('.prev-mobile, .next-mobile').addClass('d-none');
5356 var nomeUnidade = $('#unidades-ofertas option:selected').text();
5357 let tamScreen = $(window).width();
5358
5359 if(tamScreen < 1024)
5360 $('#titulo-emed').text('Turmas ' + anoTurmaEmed );
5361 else
5362 $('#titulo-emed').text('Turmas ' + anoTurmaEmed + ' - ' + nomeUnidade);
5363
5364 }
5365
5366 const codigoFT = $('[name="codigoFT"]').val();
5367 const dataEfetivaOferta = $('[name="dataEfetivaSTR"]').val();
5368
5369 //colocamos dentro do option categoryId@codUnidade
5370 splitted = elem.val().split("@");
5371 var categoryIdUnidade = splitted[0];
5372 var codUnidade = splitted[1];
5373
5374 for(var i = 0; unidades.length > i ; i++){
5375
5376 if(unidades[i].categoryId == categoryIdUnidade){
5377
5378 var unidade = unidades[i];
5379
5380 //Exibe o endereco da unidade
5381 const urlBuscaUnidade = urlUnidadeInfoDetalhe
5382 .replace('\{companyId\}',themeDisplay.getCompanyId())
5383 .replace('\{codigoUnidade\}', unidade.codigoUnidade);
5384
5385 $.ajax({
5386 url : urlBuscaUnidade,
5387 type : 'get',
5388 dataType: 'json',
5389 success: function( unidadeInfo ) {
5390 if(unidadeInfo != null && typeof unidadeInfo !== 'undefined'){
5391
5392 var endereco = concatSTR(unidadeInfo.enderecoUnidade,unidadeInfo.numEnderecoUnidade,', ');
5393 endereco = concatSTR(endereco,unidadeInfo.complementoEnderecoUnidade, ' - ');
5394 endereco = concatSTR(endereco,unidadeInfo.bairroUnidade, ' - ');
5395
5396 $('.ssp-ofertas__endereco-unidade').text(endereco);
5397 $('.ssp-ofertas__endereco-unidade').attr('href',unidadeInfo.googlemapsUnidade);
5398 }
5399 },
5400 error: function(data){
5401 $('.ssp-ofertas__endereco-unidade').text('');
5402 $('.ssp-ofertas__endereco-unidade').attr('href','#a');
5403 console.log('Unidade não encontrada');
5404 }
5405 })
5406
5407 getOfertas(codigoFT, dataEfetivaOferta, unidades[i].categoryId);
5408
5409 habilitarRegistroInteresse(!!(unidades && unidades.length));
5410
5411 }
5412 }
5413 }
5414
5415 function pegarTextoCartoesAceitos(campo){
5416 indice = campo.indexOf(' em até ');
5417 inicio = 0;
5418 fim = indice;
5419
5420 return campo.substring(inicio, fim);
5421 }
5422
5423 function pegaNumParcela(campo){
5424
5425 indice = campo.indexOf('até ');
5426 inicio = indice + 4;
5427 fim = indice + 6;
5428
5429 return campo.substring(inicio, fim);
5430
5431 }
5432
5433 function pegaValorParcela(campo){
5434
5435 indice = campo.indexOf('R$');
5436 inicio = indice+2;
5437 valorAmericano = campo.substring(inicio)
5438
5439 return formataValor(valorAmericano);
5440
5441 }
5442
5443 function montaHTMLOferta(oferta, index, codigoUnidade, posLoad){
5444
5445 var retornoDiasHorarios = processaDiasHorariosOferta(oferta.horariosAllOferta);
5446 diasSemanaHTML = "";
5447
5448 for(var diaDaOferta of retornoDiasHorarios){
5449 diasSemanaHTML += htmlSlickAreaDiasSemana.replace('\{diasSemana\}',diaDaOferta.dias);
5450 diasSemanaHTML = diasSemanaHTML.replace('\{horasSemana\}',diaDaOferta.horario)
5451 }
5452
5453 var ofertaHTML = "";
5454
5455 if(isEmed){
5456
5457 ofertaHTML = htmlSlickAreaEmed(oferta);
5458 $('[name="codUnidadeSelecionada"]').val(codigoUnidade);
5459
5460 if(!posLoad) $('.ssp-slick-ofertas-emed').append(ofertaHTML)
5461 else $('.ssp-slick-ofertas-emed').slick('slickAdd', ofertaHTML);
5462 }else{
5463
5464
5465 ofertaHTML = htmlSlickArea(index, oferta, diasSemanaHTML, codigoUnidade)
5466
5467 if(!posLoad)
5468 $('.oferta-slick-area').append(ofertaHTML);
5469 else
5470 $('.oferta-slick-area').slick('slickAdd', ofertaHTML);
5471
5472 ajustaTextoDiasHorarioOferta(oferta.codigoOferta);
5473
5474 }
5475
5476 if(turmasIniciadas(oferta.dataInicio))
5477 $("#aviso-turma-iniciada-"+index).show();
5478
5479 //remove os botões/itens de compra/bolsa caso seja preciso
5480 $('.oferta-slick-area').find('.d-none-btn').remove();
5481 }
5482
5483
5484 //RECEBE A STRING DE HORARIOS E RETORNA UMA LISTA DE OBJETOS COM OS DIAS E HORARIOS FORMATADOS
5485 //@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"
5486 function processaDiasHorariosOferta(horariosAllOferta){
5487
5488 var dias = horariosAllOferta.trim().split(',');
5489 let arrayDiasSemana = [{"Seg":"Segunda"},{"Ter":"Terça"},{"Qua":"Quarta"},{"Qui":"Quinta"},{"Sex":"Sexta"},{"Sab":"Sábado"},{"Dom":"Domingo"}]
5490
5491 var arrayDia = [];
5492 if(dias.length >= 1){
5493 for(var k=0; dias.length > k; k++){
5494 var diasSplit = dias[k].trim().split(' ');
5495 var diasSemana = diasSplit.shift()
5496 var ultimaPos = diasSplit.length-1;
5497 var horasStr = diasSplit[0] + ' às ' + diasSplit[ultimaPos]
5498 arrayDia.push({horasStr,diasSemana});
5499 }
5500 }
5501
5502 arrayDia = groupByArray(arrayDia, 'horasStr','diasSemana');
5503 arrayDia = orderByArray(arrayDia,arrayDiasSemana);
5504
5505 var ret = diaHorarioOfertaFormatado(arrayDia,arrayDiasSemana);
5506 return ret;
5507 }
5508
5509 //cria um array de objetos Agrupando de acordo ao campo informado como chave.
5510 //@arr = Array multidimensional que tenha os campos key e valueAdd
5511 //@key = campo que será chave nesse array
5512 //@valueAdd = campo que será agrupado caso tenha a mesma informação passada no campo key
5513 const groupByArray = (arr, key,valueAdd) => {
5514 const initialValue = [];
5515 const retornoValue = [];
5516 arr.forEach((acc, cval) => {
5517 const myAttribute = cval[key];
5518 acc[key] in retornoValue ? retornoValue[acc[key]].push(acc[valueAdd]):retornoValue[acc[key]]=[acc[valueAdd]];
5519 return acc;
5520 }, initialValue);
5521 return retornoValue;
5522 };
5523
5524
5525 //Cria um array de objetos a partir do primeiro array inserido e ordenados de acordo a ordem do segundo array informado.
5526 //@arrayOrdena = Array de objetos que tenha os campos que precisa ser ordenados
5527 //@ordem = array com a sequencia que queira ordenar - ex: seg, ter, qua, qua
5528 const orderByArray = (arrayOrdena, ordem) => {
5529
5530 let diasSem = [];
5531 const arrayOrdenado = [];
5532 let controle;
5533
5534 //percorre cada campo existente no ordem e busca o mesmo no arrayOrdena, encontrando insere no arrayOrdenado
5535 for(let campo of ordem){
5536 Object.entries(arrayOrdena).forEach(([key, value]) => {
5537 for(let diaOferta of value){
5538 if(diaOferta===Object.keys(campo)[0]){
5539 arrayOrdenado[key]=arrayOrdena[key];
5540 }
5541 }
5542 })
5543 }
5544 return arrayOrdenado;
5545 };
5546
5547 //retorna o valor de um objeto dentro de um array
5548 //@objetoBusca = array de objetos que sera buscado o valor
5549 //@keyBusca = nome do campo a ser buscada no objeto para pegar o seu valor
5550 function findValueInObject(objetoBusca, keyBusca){
5551 var retorno = "";
5552 Object.entries(objetoBusca).forEach(([horario, dias]) => {
5553 Object.entries(dias).forEach(([key,val]) => {
5554 if(key.trim()==keyBusca.trim()){
5555 retorno = val;
5556 }
5557 });
5558 });
5559 return retorno;
5560 }
5561
5562 //Recebe um objeto com valores dos dias da semana e define se sao dias seguidos ou alternados.
5563 //@arrayComDiasDaSemana = array com os dias da semana a serem validados - exemplo ['Qua','Qui','Sex']
5564 //@keyBusca = nome do campo a ser buscada no objeto para pegar o seu valor
5565 function diasSequenciaisOuAlternados(arrayComDiasDaSemana, arrayDiasDaSemana){
5566
5567 let arrayValidador = [];
5568
5569 //cria um array com o index dos dias das semanas encontrados [0 = seg, 1 = ter ... 6 = dom]
5570 for(let diaOferta of arrayComDiasDaSemana){
5571 for(let i = 0; i < arrayDiasDaSemana.length; i++){
5572 if(diaOferta === Object.keys(arrayDiasDaSemana[i])[0]){
5573 arrayValidador[i] = true;
5574 }
5575 }
5576 }
5577
5578 let keyCompair = 99;
5579 var sequencial = true;
5580
5581 //verifica quais posições foram criadas no array, e se os valores delas estão em sequencia.
5582 for(let keyValidator of Object.keys(arrayValidador)){
5583 keyValidator = parseInt(keyValidator);
5584 if(keyCompair!==99){
5585 if(keyValidator===keyCompair){
5586 sequencial = true;
5587 }else{
5588 sequencial = false;
5589 break;
5590 }
5591 }
5592 keyCompair = keyValidator+1;
5593 }
5594 return sequencial;
5595 }
5596
5597
5598 //Exibe as informações de dia e horario de oferta de acordo a sua estrutura
5599 //Caso os dias sejam sequenciais exibe a primeiro e ultimo dia da semana ligados com a letra 'a' Ex: Segunda a Quinta
5600 //Caso os dias Nao sejam sequenciais exibem todos os dias separados por virgula Ex: Segunda, terça, sexta e domingo
5601 //@arrayAgrupadoEOrdenado = array de objetos que sera exibido
5602 //@arrayDiasDaSemana = array com os dias da semana, sendo chave a sigla da semana (ex: Qua) e o valor o nome esperado (ex: Quarta)
5603 function diaHorarioOfertaFormatado(arrayAgrupadoEOrdenado, arrayDiasDaSemana){
5604
5605 var stringAux = "";
5606 var listRetorno = [];
5607
5608 Object.entries(arrayAgrupadoEOrdenado).forEach(([key, value]) => {
5609
5610 var sequencial = diasSequenciaisOuAlternados(value, arrayDiasDaSemana);
5611 var stringAux = "";
5612 var diaOferta = {};
5613
5614 if(sequencial){
5615 switch (value.length) {
5616 case 1:
5617 stringAux = stringAux+findValueInObject(arrayDiasDaSemana,value[0])+": ";
5618 diaOferta.dias = stringAux.charAt(0).toUpperCase() + stringAux.slice(1).toLowerCase(); // somente a primeira maiúscula
5619 diaOferta.horario = key;
5620 break;
5621 case 2:
5622 stringAux = stringAux+findValueInObject(arrayDiasDaSemana,value[0])+" e "+findValueInObject(arrayDiasDaSemana,value[value.length-1])+": ";
5623 diaOferta.dias = stringAux.charAt(0).toUpperCase() + stringAux.slice(1).toLowerCase(); // somente a primeira maiúscula
5624 diaOferta.horario = key;
5625 break;
5626 default:
5627 stringAux = stringAux+findValueInObject(arrayDiasDaSemana,value[0])+" a "+findValueInObject(arrayDiasDaSemana,value[value.length-1])+": ";
5628
5629 diaOferta.dias = stringAux.charAt(0).toUpperCase() + stringAux.slice(1).toLowerCase(); // somente a primeira maiúscula
5630 diaOferta.horario = key;
5631 break;
5632 }
5633 }else{
5634 switch (value.length) {
5635 case 2:
5636 stringAux = stringAux+findValueInObject(arrayDiasDaSemana,value[0])+" e "+findValueInObject(arrayDiasDaSemana,value[value.length-1])+": ";
5637 diaOferta.dias = stringAux.charAt(0).toUpperCase() + stringAux.slice(1).toLowerCase(); // somente a primeira maiúscula
5638 diaOferta.horario = key;
5639 break;
5640 default:
5641 var ct = 0;
5642 var stringDias="";
5643 for(let v of value){
5644 ct++;
5645 ct==value.length ? stringDias=stringDias.substring(0,stringDias.length - 2)+" e "+findValueInObject(arrayDiasDaSemana,v) : stringDias+=findValueInObject(arrayDiasDaSemana,v)+", ";
5646 }
5647 stringAux = stringAux+stringDias+": ";
5648 diaOferta.dias = stringAux.charAt(0).toUpperCase() + stringAux.slice(1).toLowerCase(); // somente a primeira maiúscula
5649 diaOferta.horario = key;
5650 break;
5651 }
5652 }
5653
5654 listRetorno.push(diaOferta);
5655 })
5656 return listRetorno;
5657 };
5658
5659
5660 //Distribui dia e horario com quebra de linha entre eles ou nao dependendo da resolução de tela e tamanho da string
5661 function ajustaTextoDiasHorarioOferta(codOferta){
5662
5663 var classOferta = ".codigoOferta_"+codOferta;
5664 let oferta = $(classOferta);
5665
5666 let ofertaDiasSemana = $(oferta).find('*[data-dia-hora="dias-semana"]');
5667
5668 let widthDevice = window.screen.width;
5669 let tamLimDesktop = 185;
5670
5671 if(widthDevice <= 1024){
5672 tamLimDesktop = 180;
5673 }
5674
5675 ofertaDiasSemana.each(function(index){
5676
5677
5678 let widthDiaSemana = $(this).width();
5679
5680 let contentDiaHora = $(this).parent().parent().parent();
5681
5682 if(!(widthDiaSemana <= tamLimDesktop)){
5683 $(this).css("display","block");
5684 }
5685
5686 if(ofertaDiasSemana.length == parseInt(index+1)){
5687 contentDiaHora.css("opacity","1");
5688 }
5689
5690 })
5691 }
5692
5693 function getObjBtnComprar(oferta){
5694 let obj = {};
5695 obj['dataEspacoEx'] = (oferta.espacoExterno == 'true' || (isHibrido && temTextoParaFormatoHibrido)) ? 'true' : 'false';
5696 if($('#manutencao-compra').val()){
5697 obj['classeBotao'] = 'disabled manutencao';
5698 obj['textoBotao'] = $('#manutencao-compra').val();
5699 }
5700 else{
5701 obj['classeBotao'] = oferta.botaoCompraOferta == 'true' ? (oferta.vagasParaCompraOferta == 'true' ? '' : 'disabled') : 'd-none-btn';
5702 obj['textoBotao'] = oferta.vagasParaCompraOferta == 'true' ? 'COMPRAR' : 'Vagas esgotadas para compra';
5703 }
5704 return obj;
5705 }
5706
5707 function getObjFormaPagto(oferta,index,tipoCurso,codigoUnidade){
5708
5709 var formaPagtoObj = {};
5710
5711 var regNumMaxParce = new RegExp('\{numeroMaxParcelasOferta\}', 'g');
5712 var regPrecMaxParce = new RegExp('\{precoVendaMaxParcelaOferta\}', 'g')
5713
5714 formaPagtoObj['regIndex'] = index;
5715 formaPagtoObj['precoCheioOferta'] = formataValor(oferta.precoCheioOferta);
5716 formaPagtoObj['textoCartoesAceitos'] = oferta.textoCartoesAceitos;
5717
5718 formaPagtoObj['numParcelaCartoes'] = oferta.numParcelaCartoes;
5719 formaPagtoObj['precoParcelaCartoes'] = oferta.precoParcelaCartoes;
5720 formaPagtoObj['numParcelaBoleto'] = oferta.numParcelaBoleto;
5721 formaPagtoObj['precoParcelaBoleto'] = oferta.precoParcelaBoleto;
5722 formaPagtoObj['precoVendaOferta'] = formataValor(oferta.precoVendaOferta);
5723
5724 formaPagtoObj['economia'] = formataValor(parseFloat(oferta.precoCheioOferta).toFixed(2) - parseFloat(oferta.precoVendaOferta).toFixed(2));
5725 formaPagtoObj['espacoExterno'] = oferta.espacoExterno == 'true' ? 'true' : 'false';
5726 formaPagtoObj['dataUnidade'] = codigoUnidade;
5727 formaPagtoObj['dataEvento'] = oferta.codigoOferta;
5728 formaPagtoObj['destinoCompra '] = oferta.destinoCompra;
5729
5730 //EMED nao restringe o botao
5731 if(isEmed){
5732 let manutencao = $('#manutencao-compra').val();
5733 formaPagtoObj['textoBotaoComprar'] = manutencao || 'COMPRAR';
5734 formaPagtoObj['classeBotaoComprar'] = manutencao ? 'disabled manutencao' : '';
5735 }else{
5736 let btnComprar = getObjBtnComprar(oferta);
5737 formaPagtoObj['textoBotaoComprar'] = btnComprar.textoBotao;
5738 formaPagtoObj['classeBotaoComprar'] = btnComprar.classeBotao;
5739 }
5740
5741 formaPagtoObj['regNumMaxParce'] = oferta.numeroMaxParcelasOferta;
5742 formaPagtoObj['regPrecMaxParce'] = formataValor(oferta.precoVendaMaxParcelaOferta);
5743
5744 //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
5745 formaPagtoObj['precoAVistaPadraoExt'] = formataValor(oferta.precoVendaOferta);
5746 var precoContribuinteExtensao = (parseFloat(oferta.precoVendaOferta).toFixed(2) * 0.80).toFixed(2);
5747 formaPagtoObj['precoContrExt'] = formataValor(precoContribuinteExtensao);
5748 formaPagtoObj['economiaExt'] = formataValor(parseFloat(oferta.precoVendaOferta).toFixed(2) - precoContribuinteExtensao);
5749 formaPagtoObj['precoParcelaBoletoExt'] = formataValor( (precoContribuinteExtensao / oferta.numParcelaBoleto).toFixed(2));
5750 formaPagtoObj['precoParcelaCartoesExt'] = formataValor( (precoContribuinteExtensao / oferta.numParcelaCartoes).toFixed(2));
5751 formaPagtoObj['precoAVistaContrExt'] = formataValor( (precoContribuinteExtensao * 0.92).toFixed(2));
5752
5753 return formaPagtoObj;
5754 }
5755
5756 function calculaPrecoAvista(precoVendaOferta){
5757 return (parseFloat(precoVendaOferta).toFixed(2) * 0.92).toFixed(2);
5758 }
5759
5760 function getParcelasEntradaCartao(dataInicioCurso){
5761
5762 const dCurso = new Date(dataInicioCurso.split("/").reverse().join("-"));
5763 const dHoje = new Date();
5764
5765 let diffAnos = dCurso.getUTCFullYear() - dHoje.getUTCFullYear();
5766 let diffMeses = dCurso.getUTCMonth() - dHoje.getUTCMonth();
5767 diffMeses = diffAnos * 12 + diffMeses;
5768
5769 return (diffMeses > 4) ? 4 : ((diffMeses<=0) ? 1 : diffMeses);
5770
5771 }
5772
5773 function createModalFormaPagto(formaPagtoObj, oferta, index) {
5774 let temDesconto = possuiCriteriosDesconto2022(oferta.dataInicio)
5775 temDesconto = temDesconto && !possuiMensalidadeCampanha(oferta)
5776
5777 result = `
5778 <div id="modalFormaPagto" class="ssp-modal">
5779 <div class="ssp-card-modal-forma-pagamento ` + (temDesconto ? 'ssp-desconto-2022' : '') + `">
5780 <div class="ssp-card-modal-forma-pagamento__header" style="border: 0; margin-bottom: 0 !important;">
5781 <h6 class="ssp-card-modal-forma-pagamento__header-title font-weight-bold" style="color:#454F63">Descontos e ` + (temDesconto ? 'pagamento' : 'parcelamento') + `</h6>
5782 <i class="ssp-card-modal-forma-pagamento__btn-close ssp-card-modal-forma-pagamento__btn-close_` + index + `"></i>
5783 </div>
5784 `
5785 + (temDesconto ? '' : '<div class="ssp-card-oferta-curso__line-divider mt-0 mb-5 mb-md-8"></div>') +
5786 `
5787 <div class="ssp-card-modal-forma-pagamento__body">
5788 `
5789 if(temDesconto) {
5790 result = result + `
5791 <div>
5792 <p class="my-0"><strong>Valor com </strong>
5793 <span class="ssp-card-oferta-curso__valor-desconto mt-0 mb-0">50% de desconto*</span>
5794 </p>
5795 </div>
5796 <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>`
5797
5798 if($('[name="tipoCurso"]').val() == 'extensao') {
5799 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>`
5800 } else {
5801 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>`
5802 }
5803
5804
5805 result = result + `
5806 <div class="ssp-card-oferta-curso__line-divider mb-5 mb-md-2 mt-2"></div>
5807 <p class="my-0"><strong>Valor:</strong></p>
5808 <h6 class="ssp-card-oferta-curso__item-valor-investimento ` + (temDesconto ? 'ssp-desconto-2022' : '') + `"><span>` + oferta.numeroMaxParcelasOferta + `x</span>R$ ` + formataValor(oferta.precoVendaMaxParcelaOferta) + `</h6>
5809 <p class="mt-0 mb-0"><strong>Valor Total: </strong> ` + formataValor(ajustarCasasDecimaisSemArredondar(strToFloat(oferta.precoVendaOferta), 2)) + `</p>
5810 <div class="ssp-card-oferta-curso__line-divider mt-4 mb-md-3 mb-4"></div>
5811 <p class="my-0"><strong>Parcele e garanta mais tempo para pagar:</strong></p>
5812 `
5813 } else {
5814 if(formaPagtoObj.precoCheioOferta == formaPagtoObj.precoVendaOferta) {
5815 result = result + `
5816 <p class="ssp-card-modal-forma-pagamento__valor-desconto mt-n3">R$ <span class="precoVendaOferta">` + formaPagtoObj.precoVendaOferta + `</span></p>
5817 <p class="txt-desconto-oito">Pague à vista e <span style="color:#FC7834;font-weight:bold"> ganhe mais 8% de desconto.</span></p>
5818 <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>
5819 </div>
5820 `
5821 } else {
5822 const textoDesc = temDesconto ? 'Valor com 30% de desconto:' : 'Valor com desconto:'
5823
5824 result = result + `
5825 <small class="ssp-card-oferta-curso__title-item font-weight-bold" style="margin:0;font-size:16px;">` + textoDesc + `</small>
5826 <p class="ssp-card-modal-forma-pagamento__valor-cheio">R$ <span class="precoCheioOferta">` + formaPagtoObj.precoCheioOferta + `</span></p>
5827 <p class="ssp-card-modal-forma-pagamento__valor-desconto">R$ <span class="precoVendaOferta">` + formaPagtoObj.precoVendaOferta + `</span></p>
5828 <p class="ssp-card-modal-forma-pagamento__total-economia">Você economiza <span>R$ <span class="economia">` + formaPagtoObj.economia + `</span></span></p>
5829 <p class="txt-desconto-oito">Pague à vista e <span style="color:#FC7834;font-weight:bold"> ganhe mais 8% de desconto.</span></p>
5830 <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>
5831 </div>
5832 `
5833 }
5834 }
5835
5836 let textoParcelaCartoes, textoParcelaBoleto, textoParcelaCartaoComBoleto
5837 if(temDesconto) {
5838 const precoParcelaCartoes = formataValor(ajustarCasasDecimaisSemArredondar(strToFloat(formaPagtoObj.precoParcelaCartoes)/2, 2))
5839 const precoParcelaBoleto = formataValor(ajustarCasasDecimaisSemArredondar(strToFloat(formaPagtoObj.precoParcelaBoleto)/2, 2))
5840
5841 if(formaPagtoObj.numParcelaCartoes)
5842 textoParcelaCartoes = `<p>Em até <span><span class="numParcelaCartoes">` + formaPagtoObj.numParcelaCartoes + `</span>x</span> sem juros</p>`
5843
5844 if(formaPagtoObj.numParcelaBoleto)
5845 textoParcelaBoleto = `<p>Em até <span><span class="numParcelaBoleto">` + formaPagtoObj.numParcelaBoleto + `</span>x</span> sem juros</p>`
5846
5847 } else {
5848 if(formaPagtoObj.numParcelaCartoes)
5849 textoParcelaCartoes = `<p>Em até <span><span class="numParcelaCartoes">` + formaPagtoObj.numParcelaCartoes + `</span>x de R$ <span class="precoParcelaCartoes">` + formaPagtoObj.precoParcelaCartoes + `</span></span> sem juros</p>`
5850
5851 if(formaPagtoObj.numParcelaBoleto)
5852 textoParcelaBoleto = `<p>Em até <span><span class="numParcelaBoleto">` + formaPagtoObj.numParcelaBoleto + `</span>x de R$ <span class="precoParcelaBoleto">` + formaPagtoObj.precoParcelaBoleto + `</span></span> sem juros</p>`
5853
5854 }
5855
5856 if(formaPagtoObj.numParcelaBoleto){
5857 textoParcelaCartaoComBoleto = `<p>1ª parcela em até <span><span class="numParcelaCartoes">` + getParcelasEntradaCartao(oferta.dataInicio) + `</span>x</span> sem juros no cartão + valor </p>`;
5858 textoParcelaCartaoComBoleto += `<p>restante em até <span><span class="numParcelaBoleto">` + (parseInt(formaPagtoObj.numParcelaBoleto) - 1) + `</span>x</span> sem juros no boleto bancário </p>`;
5859 }
5860
5861 if(temDesconto) {
5862 result = result + `
5863 <div class="ssp-card-modal-forma-pagamento__tipos">`
5864
5865 if(textoParcelaBoleto)
5866 result = result + `
5867 <div class="ssp-card-modal-forma-pagamento__tipos-content align-items-start">
5868 <i class="ssp-card-modal-forma-pagamento__icon-boleto"></i>
5869 <div class="ssp-card-modal-forma-pagamento__info-cartao">
5870 <p><strong>Boleto Bancário</strong></p>`
5871 + textoParcelaBoleto +
5872 `</div>
5873 </div>`
5874
5875 if(textoParcelaCartoes)
5876 result = result + `
5877 <div class="ssp-card-modal-forma-pagamento__tipos-content align-items-start mt-4">
5878 <i class="ssp-card-modal-forma-pagamento__icon-credit-card"></i>
5879 <div class="ssp-card-modal-forma-pagamento__info-cartao">
5880 <p><strong>Cartões</strong></p>
5881 <p>(<span class="textoCartoesAceitos">` + formaPagtoObj.textoCartoesAceitos + `</span>)</p>`
5882 + textoParcelaCartoes +
5883 `</div>
5884 </div>
5885 </div>
5886 `
5887 if(textoParcelaCartaoComBoleto)
5888 result = result + `
5889 <div class="ssp-card-modal-forma-pagamento__tipos-content align-items-start">
5890 <i class="ssp-card-modal-forma-pagamento__icon-boleto-e-cartao fa-solid fa-money-check-dollar"></i>
5891 <div class="ssp-card-modal-forma-pagamento__info-cartao">
5892 <p><strong>Cartão + boleto bancário</strong></p>`
5893 + textoParcelaCartaoComBoleto +
5894 `</div>
5895 </div>`
5896 } else {
5897 result = result + `
5898 <div class="ssp-card-modal-forma-pagamento__tipos">`
5899
5900 if(textoParcelaCartoes)
5901 result = result + `
5902 <div class="ssp-card-modal-forma-pagamento__tipos-content align-items-start">
5903 <i class="ssp-card-modal-forma-pagamento__icon-credit-card"></i>
5904 <div class="ssp-card-modal-forma-pagamento__info-cartao">
5905 <p><strong>Cartões</strong></p>
5906 <p>(<span class="textoCartoesAceitos">` + formaPagtoObj.textoCartoesAceitos + `</span>)</p>`
5907 + textoParcelaCartoes +
5908 `</div>
5909 </div>`
5910
5911 if(textoParcelaBoleto)
5912 result = result + `
5913 <div class="ssp-card-modal-forma-pagamento__tipos-content align-items-start mt-4">
5914 <i class="ssp-card-modal-forma-pagamento__icon-boleto"></i>
5915 <div class="ssp-card-modal-forma-pagamento__info-cartao">
5916 <p><strong>Boleto Bancário</strong></p>`
5917 + textoParcelaBoleto +
5918 `</div>
5919 </div>
5920 </div>
5921 `
5922
5923 if(textoParcelaCartaoComBoleto)
5924 result = result + `
5925 <div class="ssp-card-modal-forma-pagamento__tipos-content align-items-start">
5926 <i class="ssp-card-modal-forma-pagamento__icon-boleto-e-cartao fa-solid fa-money-check-dollar"></i>
5927 <div class="ssp-card-modal-forma-pagamento__info-cartao">
5928 <p><strong>Cartão + boleto bancário</strong></p>`
5929 + textoParcelaCartaoComBoleto +
5930 `</div>
5931 </div>`
5932 }
5933
5934
5935
5936 if(temDesconto) {
5937 result = result + `
5938 <p class="txt-desconto-oito my-0">Pague à vista e ganhe <span style="color:#5ACC75;font-weight:bold">8% de desconto.</span></p>
5939 `
5940 }
5941
5942 result = result + `
5943 <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>`
5944
5945 if(temDesconto) {
5946 result = result + `
5947 <a class="btn btn-primary modal-extensao-btn-conheca mt-3" href="/descontos-e-parcelamentos" target="_blank">Conheça os descontos</a>
5948 `
5949 }
5950
5951 result = result + `
5952 </div>
5953 </div>
5954 `
5955
5956 return result;
5957 }
5958
5959 function montaHTMLModalFormaPgto(oferta, index, codigoUnidade){
5960
5961 var tipoCurso = $('[name="tipoCurso"]').val();
5962
5963 var formaPagtoObj = getObjFormaPagto(oferta,index,tipoCurso,codigoUnidade);
5964
5965 var modalFormaPagto
5966 if(tipoCurso == 'extensao' && !possuiCriteriosDesconto2022(oferta.dataInicio)) {
5967 modalFormaPagto = $('#modalFormaPagtoExt').clone();
5968
5969 $.each(formaPagtoObj, function(k,v){
5970 if(modalFormaPagto.find('.'+k).length > 0)
5971 modalFormaPagto.find('.'+k).text(v);
5972 })
5973 } else if(isEmed) {
5974 modalFormaPagto = $('#modalPagtoEmed').clone();
5975
5976 $.each(formaPagtoObj, function(k,v){
5977 if(modalFormaPagto.find('.'+k).length > 0)
5978 modalFormaPagto.find('.'+k).text(v);
5979 })
5980 } else
5981 modalFormaPagto = $(createModalFormaPagto(formaPagtoObj, oferta, index));
5982
5983 modalFormaPagto.removeAttr('id');
5984 modalFormaPagto.removeClass('d-none');
5985 modalFormaPagto.attr('id','myModal_'+index);
5986
5987 if(tipoCurso == 'extensao' && !possuiCriteriosDesconto2022(oferta.dataInicio)){
5988
5989 var botoaoCompraOk = modalFormaPagto.find('.modal-extensao-aluno__btn.ok');
5990 botoaoCompraOk.attr('id','btnComprarConhecaDescontoOk_'+index);
5991
5992 botoaoCompraOk.attr('data-espaco-ex', formaPagtoObj.espacoExterno);
5993 botoaoCompraOk.attr('data-unidade', formaPagtoObj.dataUnidade);
5994 botoaoCompraOk.attr('data-evento', formaPagtoObj.dataEvento);
5995 botoaoCompraOk.attr('data-destino-compra', formaPagtoObj.destinoCompra);
5996 botoaoCompraOk.attr('data-index', index);
5997 botoaoCompraOk.addClass(formaPagtoObj.classeBotaoComprar);
5998
5999 var botoaoCompraNot =modalFormaPagto.find('.modal-extensao-aluno__btn.not');
6000 botoaoCompraNot.attr('id','btnComprarConhecaDescontoNot_'+index);
6001
6002 botoaoCompraNot.attr('data-espaco-ex', formaPagtoObj.espacoExterno);
6003 botoaoCompraNot.attr('data-unidade', formaPagtoObj.dataUnidade);
6004 botoaoCompraNot.attr('data-evento', formaPagtoObj.dataEvento);
6005 botoaoCompraNot.attr('data-destino-compra', formaPagtoObj.destinoCompra);
6006 botoaoCompraNot.attr('data-index', index);
6007 botoaoCompraNot.addClass(formaPagtoObj.classeBotaoComprar);
6008
6009 modalFormaPagto.find('.modal-extensao-btn-aluno-sim-nao.sim').attr('id','btn-aluno-sim_'+index);
6010 modalFormaPagto.find('.modal-extensao-btn-aluno-sim-nao.nao').attr('id','btn-aluno-nao_'+index);
6011
6012 modalFormaPagto.find('.modal-extensao-voltar-icon').addClass('ssp-card-modal-forma-pagamento__btn-close_'+index);
6013
6014 modalFormaPagto.find('.modal-extensao-btn-conheca').attr('id','btnModalExtConheca_'+index);
6015
6016 modalFormaPagto.find('.modal-pergunta-aluno-ext').attr('id','modalExtAluno_'+index);
6017
6018 modalFormaPagto.find('.msg-alunoSim').attr('id','msg-alunoSim_'+index);
6019 modalFormaPagto.find('.msg-alunoNao').attr('id','msg-alunoNao_'+index);
6020
6021 var botaoCompra = modalFormaPagto.find('.modal-extensao__btn.mt-3');
6022
6023 }else{
6024
6025 modalFormaPagto.find('.mt-4').attr('id','content_boleto_'+index);
6026 modalFormaPagto.find('.ssp-card-modal-forma-pagamento__btn-close').addClass('ssp-card-modal-forma-pagamento__btn-close_'+index);
6027
6028 var botaoCompra = modalFormaPagto.find('.btn.w-100');
6029
6030 }
6031
6032 if(isEmed){
6033
6034 var elementoPai = modalFormaPagto.find('.ssp-card-modal-forma-pagamento');
6035
6036 //Cria botao inscreva-se ajustado ao modal
6037 var dadosAbertura = calculaTempoAberturaBolsa(oferta.dataAberturaMatricula, oferta.horaAberturaBolsaOferta);
6038 if($('#manutencao-compra').val()){
6039 textoBotao = $('#manutencao-compra').val();
6040 classeBotao = 'disabled manutencao';
6041 }else{
6042 if(oferta.permiteListaEspera == statusEmed.ESPERA && dadosAbertura.bolsaJaAberta){
6043 textoBotao = 'Lista de espera';
6044 classeBotao = 'btn-emed-lista-espera';
6045 }else{
6046 if (dadosAbertura.bolsaJaAberta || !oferta.dataAberturaMatricula || oferta.dataAberturaMatricula == ''){
6047 if(oferta.etapa == '0020' || oferta.etapa == '0030'){
6048 textoBotao = 'Lista de espera';
6049 classeBotao = 'btn-emed-lista-espera';
6050 }else{
6051 textoBotao = 'Fazer matrícula';
6052 classeBotao = '';
6053 }
6054 }else{
6055 textoBotao = 'Matrícula em '+formataDataAberturaBolsa(oferta.dataAberturaMatricula, oferta.horaAberturaBolsaOferta);
6056 classeBotao = 'disabled';
6057 }
6058 }
6059 }
6060 criaBotaoInscreverEmedModal(oferta, textoBotao, classeBotao, 'btnComprarEmedModal_' + index, elementoPai, index);
6061 preencheDadosEmedModal(oferta, modalFormaPagto);
6062
6063 }else{
6064 botaoCompra.attr('id', "btnComprarFormaPgto_"+index);
6065 botaoCompra.attr('data-espaco-ex', formaPagtoObj.espacoExterno);
6066 botaoCompra.attr('data-unidade', formaPagtoObj.dataUnidade);
6067 botaoCompra.attr('data-evento', formaPagtoObj.dataEvento);
6068 botaoCompra.attr('data-destino-compra', formaPagtoObj.destinoCompra);
6069 botaoCompra.attr('data-index', index);
6070 botaoCompra.addClass(formaPagtoObj.classeBotaoComprar);
6071 }
6072
6073 $('.oferta-slick-area_modal').append(modalFormaPagto);
6074 $('.oferta-slick-area_modal').find('.d-none-btn').remove();
6075
6076 //Evita o erro de exibição de Nan
6077 if(oferta.numParcelaBoleto.length == 0){
6078 $('#content_boleto_'+index).remove();
6079 }
6080 }
6081
6082 function verificaTerminoDia(dataInicio, dataFim){
6083 if (dataInicio === dataFim) {
6084 return true;
6085 }
6086 return false;
6087 }
6088
6089
6090 function montaHTMLModalLocalRealizacao(oferta, index){
6091
6092 // Lógica para decidir o texto (Singular ou Plural)
6093 // Assume que oferta.dataInicio e oferta.dataFim existem
6094 var textoTitulo = verificaTerminoDia(oferta.dataInicio, oferta.dataFim) ?
6095 "ONDE A AULA IRÁ ACONTECER?" : // True: Mesmo dia (Singular)
6096 "ONDE AS AULAS VÃO ACONTECER?"; // False: Dias diferentes (Plural)
6097
6098 var tituloLocalRealizacao = (localLivreOnline(oferta.localEspacoExterno) && !isHibrido) ?
6099 '<i class="fas fa-wifi icon-wifi-title__modal"></i> <h6 class="title-idioma-online__modal"> Aulas Online - ao vivo</h6>'
6100 : '<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>';
6101
6102 if(textoFormatoHibrido.length>0 && oferta.espacoExterno=="true")
6103 textoFormatoHibrido += '</br>';
6104
6105 var localRealizacaoHTMLModal = htmlModalLocalRealizacao
6106 .replace('\{nomeUnidade\}',$('#unidades-ofertas option:selected').text())
6107 .replace('\{textoFormatoHibrido\}', textoFormatoHibrido )
6108 .replace('\{localEspacoExterno\}', oferta.espacoExterno=="true"? oferta.localEspacoExterno: "" )
6109 .replace('\{classeTextoInfoLocalRealizacao\}', (oferta.ruaEspacoExterno != "" && !isHibrido) ? "" : "d-none")
6110 .replace('\{classeEnderecoRealizacao\}',oferta.ruaEspacoExterno != "" ? "" : "d-none")
6111 .replace('\{ruaEspacoExterno\}',oferta.ruaEspacoExterno)
6112 .replace('\{numeroEspacoExterno\}',oferta.numeroEspacoExterno)
6113 .replace('\{complementoEspacoExterno\}',oferta.complementoEspacoExterno)
6114 .replace('\{classeBairroRealizacao\}', oferta.bairroEspacoExterno != "" && oferta.ruaEspacoExterno != "" ? "" : "d-none")
6115 .replace('\{bairroEspacoExterno\}',oferta.bairroEspacoExterno)
6116 .replace('\{classeCidadeRealizacao\}', oferta.cidadeEspacoExterno != "" && oferta.ruaEspacoExterno != "" ? "" : "d-none")
6117 .replace('\{cidadeEspacoExterno\}',oferta.cidadeEspacoExterno)
6118 .replace('\{classeCepRealizacao\}', oferta.cepEspacoExterno != "" && oferta.ruaEspacoExterno != "" ? "" : "d-none")
6119 .replace('\{cepEspacoExterno\}',oferta.cepEspacoExterno)
6120 .replace(regIndex, index)
6121 .replace('\{tituloLocalRealizacao\}', tituloLocalRealizacao)
6122 .replace('\{classeEntendi\}', (localLivreOnline(oferta.localEspacoExterno)) ? "btn-modal-entendi__idioma-online" : "");
6123
6124 $('.oferta-slick-area_modal').append(localRealizacaoHTMLModal);
6125 $('.oferta-slick-area_modal').find('.d-none-btn').remove();
6126
6127 if(oferta.ruaEspacoExterno == "")
6128 $('.localEspacoExternoTexto_'+index).removeClass('ssp-modal-local-realizacao__subtitle');
6129 }
6130
6131 function montaHTMLModalAntesCompra(oferta, index, codigoUnidade){
6132
6133 if(isEmed){
6134
6135 $('#modalAntesCompraEmed_' + oferta.indice).remove();
6136 const antesCompraHTMLModal = $('#modalAntesCompraEmed').clone();
6137 antesCompraHTMLModal.attr('id', 'modalAntesCompraEmed_' + oferta.indice);
6138 antesCompraHTMLModal.find('.ssp-card-modal-antes-compra__btn-close').addClass('ssp-card-modal-antes-compra__btn-close_'+oferta.indice);
6139 antesCompraHTMLModal.find('.ssp-card-modal-selecionar-outro__btn-close').addClass('ssp-card-modal-selecionar-outro__btn-close_'+oferta.indice);
6140 antesCompraHTMLModal.insertAfter('#modalAntesCompraEmed');
6141
6142 if(oferta.etapa == '0010'){
6143 if(oferta.permiteListaEspera == statusEmed.ESPERA){
6144 antesCompraHTMLModal.find('.textoEmedModalAntesCompra0010Espera').removeClass('d-none');
6145 antesCompraHTMLModal.find('#btnCompraLocalEmed').text('Ir para lista de espera');
6146 }else{
6147 antesCompraHTMLModal.find('.textoEmedModalAntesCompra0010').removeClass('d-none');
6148 }
6149 }else{
6150 antesCompraHTMLModal.find('.textoEmedModalAntesCompra0020e0030').removeClass('d-none');
6151 }
6152
6153 const btnCompra = antesCompraHTMLModal.find('#btnCompraLocalEmed');
6154 btnCompra.attr('id', 'btnCompraLocalEmed_' + oferta.indice);
6155 btnCompra.attr('offercode', oferta.codigoOferta);
6156
6157 btnCompra.on('click', function(ev){
6158 ev.preventDefault();
6159 execCompraEmed(oferta);
6160 });
6161
6162 }else{
6163
6164 var dataEfetivaFormat = formataDataComBarra($('[name="dataEfetivaSTR"]').val());
6165
6166
6167 var antesCompraHTMLModal = htmlModalAntesCompra
6168 .replace('\{nomeUnidade\}',$('#unidades-ofertas option:selected').text())
6169 .replace('\{textoFormatoHibrido\}', textoFormatoHibrido )
6170 .replace('\{localEspacoExterno\}', oferta.espacoExterno=="true"? oferta.localEspacoExterno:"" )
6171 .replace('\{classeTextoInfoLocalRealizacao\}', (oferta.ruaEspacoExterno != "" && !isHibrido) ? "" : "d-none")
6172 .replace('\{classeEnderecoRealizacao\}', oferta.ruaEspacoExterno != "" ? "" : "d-none")
6173 .replace('\{ruaEspacoExterno\}',oferta.ruaEspacoExterno)
6174 .replace('\{numeroEspacoExterno\}',oferta.numeroEspacoExterno)
6175 .replace('\{complementoEspacoExterno\}',oferta.complementoEspacoExterno)
6176 .replace('\{classeBairroRealizacao\}', oferta.bairroEspacoExterno != "" && oferta.ruaEspacoExterno != "" ? "" : "d-none")
6177 .replace('\{bairroEspacoExterno\}',oferta.bairroEspacoExterno)
6178 .replace('\{classeCidadeRealizacao\}', oferta.cidadeEspacoExterno != "" && oferta.ruaEspacoExterno != "" ? "" : "d-none")
6179 .replace('\{cidadeEspacoExterno\}',oferta.cidadeEspacoExterno)
6180 .replace('\{classeCepRealizacao\}', oferta.cepEspacoExterno != "" && oferta.ruaEspacoExterno != "" ? "" : "d-none")
6181 .replace('\{cepEspacoExterno\}',oferta.cepEspacoExterno)
6182 .replace('\{componentBuyConfirmation\}', componentBuyConfirmation(codigoUnidade, oferta, dataEfetivaFormat))
6183 .replace('\{linkBtnBolsa\}', linkBolsa(oferta))
6184 .replace(regIndex, index);
6185
6186 $('.oferta-slick-area_modal').append(antesCompraHTMLModal);
6187 $('.oferta-slick-area_modal').find('.d-none-btn').remove();
6188 }
6189 }
6190
6191 async function populaOfertas(ofertas){
6192
6193 //Zera variável que controla existência de ofertas com bolsa
6194 ofertasComBolsa = false;
6195
6196 objsTela.ofertas = ofertas;
6197
6198 if(ofertas && ofertas.length)
6199 $('#ssp-h3-turmas').show()
6200 else
6201 $('#ssp-h3-turmas').hide()
6202
6203 if(ofertas && ofertas.length > 1){
6204 //remove dupl
6205 const ofertasDistintas = [];
6206 ofertas.forEach(oferta => {
6207 if(ofertasDistintas.filter(dist => dist.codigoOferta == oferta.codigoOferta).length == 0){
6208 ofertasDistintas.push(oferta);
6209 }
6210 });
6211 ofertas = ofertasDistintas;
6212 }
6213
6214 if(isEmed){
6215
6216 $('.btn-filtro[value="0"]').attr('disabled','');
6217 $('.ssp-slick-ofertas-emed').empty();
6218 // executa a class do slick slider
6219 $('.ssp-slick-ofertas-emed').removeClass('slick-initialized slick-slider slick-dotted');
6220 ofertas = filtraOfertasEtapa(getEtapaSelecionadaEmed(), ofertas);
6221
6222 }
6223
6224 if(ofertas.length == 0){
6225
6226 if($('#unidades-ofertas').val() || $('#chkInscricao').prop('checked') || $('#chkBolsa').prop('checked'))
6227 hideCardSemTurmas(false)
6228
6229 $('.oferta-slick-area').empty();
6230 $('.prev-mobile, .next-mobile').addClass('d-none');
6231
6232 //Mostrar section registro interesse quando nao tiver oferta
6233 habilitarRegistroInteresse(true);
6234
6235 controlaPaginaBolsa()
6236 if(isEmed) $('.btn-filtro[value="0"]').removeAttr('disabled');
6237 return;
6238 }
6239 hideCardSemTurmas(true)
6240 if(!isEmed) $('.prev-mobile, .next-mobile').removeClass('d-none');
6241 habilitarRegistroInteresse(false);
6242
6243 $('.oferta-slick-area').empty();
6244 $('.oferta-slick-area_modal').empty();
6245 ofertas = ofertas.sort(function(a, b){
6246 return ordenar(a, b, 'ordenar');
6247 });
6248 // executa a class do slick slider
6249 $('.oferta-slick-area').removeClass('slick-initialized slick-slider slick-dotted');
6250
6251 //busca o codigoUnidade para o link do ecommerce
6252 if(!isAoVivo){
6253 var selectedUnidade = $('#unidades-ofertas').val().split('@')[0];
6254 for(var i=0;objsTela.unidades.length > i ;i++){
6255 if(selectedUnidade == objsTela.unidades[i].categoryId)
6256 codigoUnidade = objsTela.unidades[i].codigoUnidade;
6257 }
6258 }
6259
6260 // Montar object push - google tag manager - 2
6261 itensEcommerce = criaItensEcommerce(ofertas);
6262 sendEventEcommerce("view_item_list", Array.from(itensEcommerce.values()));
6263
6264 for(var i=0;ofertas.length > i ;i++){
6265
6266 var oferta = ofertas[i];
6267 var ofertaGratuita = excecaoCursoGratuito(oferta);
6268
6269 //guardando a oferta no map para chamar ajax com infos de bolsa em tempo real
6270 oferta['indice'] = i;
6271 ofertasMap.set(oferta.codigoOferta, oferta);
6272
6273 if(isAoVivo)
6274 codigoUnidade = ofertaUnidadeMap.get(oferta.codigoOferta);
6275
6276 if(isEmed && oferta.etapa == '0010'){
6277 try{
6278 let status = await getStatusEmed(oferta);
6279 oferta['permiteListaEspera'] = status;
6280 }catch(err){
6281 console.log(err);
6282 }
6283 }
6284 montaHTMLOferta(oferta, i, codigoUnidade, false);
6285
6286 if(!ofertaGratuita)
6287 montaHTMLModalFormaPgto(oferta, i, codigoUnidade);
6288
6289 montaHTMLModalLocalRealizacao(oferta, i);
6290 montaHTMLModalAntesCompra(oferta, i, codigoUnidade);
6291
6292 if(!ofertaGratuita)
6293 verificaBotaoBolsaSS(oferta);
6294
6295 verificaCursoAprendizagem(i, oferta.codigoOferta);
6296 verificaCursoTrampolim(i, oferta.codigoOferta);
6297
6298 if(!ofertaGratuita)
6299 associaEventoBtnFormaPagamento(i);
6300
6301 associaEventoBtnComprar(i);
6302
6303 if(!ofertaGratuita)
6304 associaEventoBtnComprarDentroFormaPgto(i);
6305
6306 associaEventoBtnLocalRealizacao(i);
6307 associaEventosFecharModal(i);
6308
6309 if($('[name="tipoCurso"]').val() == 'extensao'){
6310 associaEventoBtnConheca(i);
6311 associaEventoBtnComprarConhecaDescontoOk(i);
6312 associaEventoBtnComprarConhecaDescontoNot(i);
6313 associaEventoBtnAlunoNao(i);
6314 associaEventoBtnAlunoSim(i);
6315 }
6316
6317 }
6318
6319 if(isEmed){
6320 sliderOfertasEmed();
6321 $('.btn-filtro[value="0"]').removeAttr('disabled');
6322 }
6323 else sliderOfertas();
6324
6325 controlaPaginaBolsa()
6326
6327 }
6328
6329 function hideCardSemTurmas(hide){
6330 if(!isEmed){
6331 if(hide)
6332 $('.ssp-card-oferta-curso__sem-vaga').addClass('d-none');
6333 else
6334 $('.ssp-card-oferta-curso__sem-vaga').removeClass('d-none');
6335 } else {
6336
6337
6338 if(hide || getEtapaSelecionadaEmed() == "0"){
6339 $('.sem-vaga-emed').addClass('d-none');
6340 }else{
6341 $('.sem-vaga-emed').removeClass('d-none');
6342 if($('.sem-vaga-emed.emed-transferencias-space:not(.d-none)').length ) return;
6343 var tamScreen = $(window).width();
6344 if(tamScreen < 768){
6345 $('.slick-area-emed').slick({
6346 slidesToShow: 2,
6347 slidesToScroll: 2,
6348 autoplay: false,
6349 infinite: false,
6350 dots: false,
6351 arrows: false,
6352 centerPadding: 0,
6353 centerMode: false,
6354 responsive: [
6355 {
6356 breakpoint: 768,
6357 settings: {
6358 slidesToShow: 1,
6359 slidesToScroll: 1,
6360 variableWidth: false,
6361 infinite: false,
6362 centerPadding: 0,
6363 centerMode: false,
6364 dots: true,
6365 }
6366 }
6367 ]
6368 });
6369 }
6370 }
6371 }
6372 }
6373
6374 function verificaCursoAprendizagem(i, codigoOferta){
6375
6376 //Esconde elementsos quando o curso é aprendizagem
6377 if($('[name="codigoFT"]').val() == codigoFTCursoAprendizagem){
6378 $('#btnComprar_'+i).remove();
6379 $('#container_investimento_'+i).remove();
6380 $('#container_forma_pgto_'+i).remove();
6381
6382 var avisoAprendizagem = $('#aviso-curso-aprendizagem').clone();
6383 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>'
6384 avisoAprendizagem.removeAttr('id');
6385 avisoAprendizagem.removeClass('d-none');
6386 $('.card_oferta_'+i+ ' .ssp-card-oferta-curso').append(avisoAprendizagem);
6387 $('.card_oferta_'+i+ ' .ssp-card-oferta-curso').append(btnFormAprendizagem);
6388 }
6389 }
6390
6391 function verificaCursoTrampolim(i, codOferta){
6392 if(ehCursoTrampolim){
6393 $('#btnComprar_'+i).remove();
6394 $('#container_investimento_'+i).remove();
6395 $('#container_forma_pgto_'+i).remove();
6396 $('.ssp-card-oferta-curso .codigoOferta_'+codOferta).hide();
6397
6398 var avisoTrampolim = $('#avisoTrampolim').clone();
6399 avisoTrampolim.removeAttr('id');
6400 avisoTrampolim.removeClass('d-none');
6401 $('.card_oferta_'+i+ ' .ssp-card-oferta-curso').append(avisoTrampolim);
6402 }
6403 }
6404
6405 function verificaBotoesEmed(dadosOferta, verificaBolsa) {
6406
6407 var elementoPai = $('.codigoOferta_' + dadosOferta.codigoOferta + ' .ssp-ofertas-emed__card-info-investimento');
6408
6409 //INICIO - Logica para Matricula
6410
6411 //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
6412 var dadosAberturaMatricula = calculaTempoAberturaBolsa(dadosOferta.dataAberturaMatricula, dadosOferta.horaAberturaBolsaOferta);
6413
6414 var textoBotaoMatricula = '';
6415 var exibirBotaoMatricula = true;
6416 var classeBotaoMatricula = '';
6417 var htmlBotaoMatricula = '';
6418
6419 if (dadosAberturaMatricula.exibirContador) {
6420 textoBotaoMatricula = dadosAberturaMatricula.textoContador;
6421 exibirBotaoMatricula = false;
6422 }
6423
6424 //exibe o botão sem cronômetro
6425 if (exibirBotaoMatricula) {
6426 if ($('#manutencao-compra').val()) {
6427 textoBotaoMatricula = $('#manutencao-compra').val();
6428 classeBotaoMatricula = 'disabled manutencao';
6429 } else {
6430
6431 if (dadosOferta.permiteListaEspera == statusEmed.ESPERA && dadosAberturaMatricula.bolsaJaAberta) {
6432 textoBotaoMatricula = 'Lista de espera';
6433 classeBotaoMatricula = 'btn-emed-lista-espera';
6434 } else {
6435 classeBotaoMatricula = '';
6436 if (dadosAberturaMatricula.bolsaJaAberta || !dadosOferta.dataAberturaMatricula || dadosOferta.dataAberturaMatricula == '') {
6437 textoBotaoMatricula = 'Fazer matrícula';
6438
6439 if (dadosOferta.etapa == '0020' || dadosOferta.etapa == '0030') {
6440 textoBotaoMatricula = 'Lista de espera';
6441 classeBotaoMatricula = 'btn-emed-lista-espera';
6442 }
6443 } else {
6444 textoBotaoMatricula = 'Matrícula em ' + formataDataAberturaBolsa(dadosOferta.dataAberturaMatricula, dadosOferta.horaAberturaBolsaOferta);
6445 }
6446 if (!dadosAberturaMatricula.bolsaJaAberta)
6447 classeBotaoMatricula = 'disabled';
6448 }
6449 }
6450
6451 criaBotaoInscreverEmed(dadosOferta, textoBotaoMatricula, classeBotaoMatricula, 'btnComprarEmed_' + dadosOferta.indice, elementoPai);
6452
6453 } else { //exibe o cronometro para matricula
6454
6455 //codigoOferta como index para usar o ofertasMap
6456 htmlBotaoMatricula = '<button id="btnContadorComprar_' + dadosOferta.indice + '" data-index="' + dadosOferta.codigoOferta + '" class="btn btn-card-investimento --inscreva-se">Matrícula em <span>' + textoBotaoMatricula + '</span></button>';
6457 elementoPai.append(htmlBotaoMatricula);
6458 }
6459
6460 //INICIO - Logica para Botão Bolsa
6461
6462 if (!verificaBolsa || !dadosOferta.dataAberturaBolsaOferta || dadosOferta.dataAberturaBolsaOferta == '') {
6463 dadosOferta.vagasBolsaOferta = false;
6464 dadosOferta.botaoBolsaOferta = false;
6465 }
6466
6467 //calcula o tempo até abertura da bolsa, se houver (apenas depois das 08hrs)
6468 var dadosAberturaBolsa = calculaTempoAberturaBolsa(dadosOferta.dataAberturaBolsaOferta, dadosOferta.horaAberturaBolsaOferta);
6469
6470 var textoBotaoBolsa = '';
6471 var classeBotaoBolsa = '';
6472 var exibirBotaoBolsa = false;
6473 var exibirContadorBolsa = false;
6474 var htmlBotaoBolsa = '';
6475
6476 //verifica se o botão de concorrer a bolsa deve aparecer
6477 //Oferta EMED possui bolsa apenas no 1o ano
6478 if (dadosOferta.etapa == '0010' && dadosOferta.botaoBolsaOferta && !dadosAberturaBolsa.exibirContador) {
6479 exibirBotaoBolsa = true;
6480 if ($('#manutencao-bolsa').val()) {
6481 classeBotaoBolsa = 'disabled manutencao';
6482 textoBotaoBolsa = $('#manutencao-bolsa').val();
6483 } else {
6484 if (dadosOferta.vagasBolsaOferta) {
6485 classeBotaoBolsa = dadosAberturaBolsa.bolsaJaAberta ? '' : 'disabled';
6486 textoBotaoBolsa = dadosAberturaBolsa.bolsaJaAberta ? 'Bolsa de estudo' : 'Bolsa em ' + formataDataAberturaBolsa(dadosOferta.dataAberturaBolsaOferta, dadosOferta.horaAberturaBolsaOferta);
6487 } else {
6488 classeBotaoBolsa = 'disabled';
6489 textoBotaoBolsa = 'Bolsas de Estudo Esgotadas';
6490 }
6491 }
6492 }
6493
6494 //Verifica se o botão do cronômetro deve aparecer
6495 if (dadosAberturaBolsa.exibirContador) {
6496 textoBotao = dadosAberturaBolsa.textoContador;
6497 textoBotaoBolsa = dadosAberturaBolsa.textoContador;
6498 exibirContadorBolsa = true;
6499 exibirBotaoBolsa = false;
6500 }
6501
6502 if (exibirBotaoBolsa) {
6503
6504 if (!ofertasComBolsa) ofertasComBolsa = true;
6505
6506 criaBotaoBolsaEmed(dadosOferta, textoBotaoBolsa, classeBotaoBolsa);
6507
6508 } else if (exibirContadorBolsa) {
6509
6510 if (!ofertasComBolsa && dadosOferta.etapa == '0010') ofertasComBolsa = true;
6511
6512 if (dadosOferta.etapa == '0010' && dadosOferta.botaoBolsaOferta) {
6513 htmlBotaoBolsa = '<button id="btnContadorBolsa_' + dadosOferta.indice + '" data-index="' + dadosOferta.codigoOferta + '" class="btn btn-card-investimento --bolsas">Bolsa em <span>' + textoBotaoBolsa + '</span></button>';
6514 elementoPai.append(htmlBotaoBolsa);
6515 }
6516 }
6517 }
6518
6519 function criaBotaoInscreverEmedModal(oferta, textoBotao, classeBotao, idBotao, elementoPai, index){
6520 criaBotaoInscreverEmed(oferta, textoBotao, classeBotao, idBotao, elementoPai);
6521 var btnInscr = elementoPai.find('#btnComprarEmedModal_' + index);
6522 btnInscr.removeClass(btnInscr.classList);
6523 btnInscr.addClass('btn btn-lg btn-success w-100');
6524 btnInscr.attr('style', 'margin-top: 20px;font-weight:600');
6525
6526 //Reposiciona o botao voltar
6527 var btnVoltar = elementoPai.find('.ssp-btn-emed__voltar-curso');
6528 elementoPai.find('.ssp-btn-emed__voltar-curso').remove();
6529 elementoPai.append(btnVoltar);
6530 btnVoltar.addClass('ssp-btn-emed__voltar-curso_'+index);
6531 btnVoltar.click(() => {
6532 $('[id^="myModal_"]').each(function(index,modal){
6533 modal.style.display = "none";
6534 })
6535 });
6536 }
6537
6538 function preencheDadosEmedModal(oferta,$modal){
6539 const parcelaEntrada = 1;
6540 $modal.find('.numParcelaCartoesBoleto').text(oferta.numeroMaxParcelasOferta - parcelaEntrada);
6541 $modal.find('.precoParcelaCartoesBoleto').text(formataValor(oferta.precoVendaMaxParcelaOferta));
6542 $modal.find('.numParcelaEmedModal').text(oferta.numeroMaxParcelasOferta - parcelaEntrada);
6543 $modal.find('.precoParcelaEmedModal').text(formataValor(oferta.precoVendaMaxParcelaOferta));
6544 }
6545
6546
6547 function criaBotaoInscreverEmed(oferta, textoBotao, classeBotao, idBotao, elementoPai){
6548 if(oferta.permiteListaEspera && oferta.permiteListaEspera == statusEmed.NAO_ENCONTRADA) return;
6549 var htmlBotao = '<button id="'+ idBotao +'" data-index="'+ oferta.indice +'" class="btn btn-card-investimento --inscreva-se '+ classeBotao +'"><span>'+textoBotao+'</span></button>';
6550 elementoPai.append(htmlBotao);
6551
6552 if(!classeBotao.includes('disabled')){
6553
6554 elementoPai.on("click", '#'+ idBotao, function(ev){
6555 ev.preventDefault();
6556 const _modal = $('#modalAntesCompraEmed_'+$(this).data('index'));
6557 _modal.css('display','flex');
6558
6559
6560 });
6561
6562 }
6563
6564 }
6565
6566 function criaBotaoBolsaEmed(oferta, textoBotaoBolsa, classeBotaoBolsa=""){
6567
6568 var htmlBotao = '<a id="btnBolsa_'+ oferta.indice +'" data-index="'+ oferta.indice +'" class="btn btn-card-investimento --bolsas '+ classeBotaoBolsa +'">'+ textoBotaoBolsa +'</a>';
6569 $('.codigoOferta_'+oferta.codigoOferta+' .ssp-ofertas-emed__card-info-investimento').append(htmlBotao);
6570
6571 if(!classeBotaoBolsa.includes('disabled')){
6572 // Associa o evento de clique no botão de bolsa
6573 $('#btnBolsa_'+oferta.indice).attr('href', linkBolsa(oferta));
6574 $('#btnBolsa_'+oferta.indice).attr('target', '_blank');
6575 //$('#btnBolsa_'+oferta.indice).attr('style', 'text-transform:uppercase;');
6576
6577 }
6578 }
6579
6580 function criaBotaoBolsa(oferta, textoBotaoBolsa, classeBotaoBolsa=""){
6581
6582 const botao = $('<a>'+ textoBotaoBolsa +'</a>');
6583 botao.attr('id', 'btnBolsa_' + oferta.indice);
6584 botao.attr('data-index', oferta.indice);
6585 botao.attr('class', 'btn btn-lg btn-info w-100 mt-3 ' + (classeBotaoBolsa || ''));
6586 botao.css('font-size', '14px');
6587 botao.css('font-weight', '600');
6588 botao.css('background-color', '#004EFF');
6589 if(!classeBotaoBolsa.includes('disabled')){
6590 if(oferta.espacoExterno == 'true' || (isHibrido && temTextoParaFormatoHibrido)){
6591 botao.attr('data-espaco-ex', 'true');
6592 botao.click((ev)=>{
6593 ev.preventDefault();
6594 $('#btnCompraLocal_'+oferta.indice).hide();
6595 $('#btnBolsaLocal_'+oferta.indice).show();
6596 const _modal = $('#modalAntesCompra_'+oferta.indice);
6597 _modal.css('display','flex');
6598 });
6599 }else{
6600 botao.attr('href', linkBolsa(oferta));
6601 botao.attr('target', '_blank');
6602 }
6603 }
6604
6605 return botao;
6606
6607 }
6608
6609 function verificaBotaoBolsaSS(oferta, codigoUnidade){
6610
6611
6612 if(!isEmed && (!oferta.dataAberturaBolsaOferta || oferta.dataAberturaBolsaOferta == '') ) return;
6613
6614 if(!ehCursoTrampolim){
6615 $.ajax({
6616 url : getUrlConsultaBolsa(oferta),
6617 type : 'get',
6618 dataType: 'json',
6619 beforeSend: function (xhr) {
6620 xhr.setRequestHeader ("Authorization", "KGG4KMW5s0CVowr7d6y6Ww==");
6621 },
6622 })
6623 .done(function(infosBolsa){
6624
6625
6626 if(infosBolsa != null && typeof infosBolsa !== 'undefined'){
6627
6628 var codigoOfertaRetornoBolsa = infosBolsa.DATA[0].COD_EVENTO;
6629 var retornoOfertaBolsaSenac = infosBolsa.DATA[0];
6630
6631 //Sobrescreve as flags de bolsa com o retorno do serviço SS
6632 ofertasMap.get(codigoOfertaRetornoBolsa).vagasBolsaOferta = retornoOfertaBolsaSenac.TEM_VAGA_BOLSA;
6633 ofertasMap.get(codigoOfertaRetornoBolsa).botaoBolsaOferta = retornoOfertaBolsaSenac.BOTAO_BOLSA;
6634
6635 var dadosOferta = ofertasMap.get(codigoOfertaRetornoBolsa);
6636
6637 //calcula o tempo até abertura da bolsa, se houver (apenas depois das 08hrs)
6638 var dadosAberturaBolsa = calculaTempoAberturaBolsa(dadosOferta.dataAberturaBolsaOferta, dadosOferta.horaAberturaBolsaOferta, dadosOferta.botaoBolsaOferta);
6639 var textoBotaoBolsa = '';
6640 var classeBotaoBolsa = '';
6641 var textoBotaoContadorBolsa = '';
6642 var exibirBotaoBolsa = false;
6643 var exibirContadorBolsa = false;
6644
6645 //EMED
6646 if(isEmed){
6647 verificaBotoesEmed(ofertasMap.get(codigoOfertaRetornoBolsa), true);
6648 return;
6649 }
6650
6651 //Verifica o texto do botão de bolsa
6652 if($('#manutencao-bolsa').val()) textoBotaoBolsa = $('#manutencao-bolsa').val();
6653 else{
6654
6655 if(retornoOfertaBolsaSenac.TEM_VAGA_BOLSA){
6656
6657 if(dadosAberturaBolsa.bolsaJaAberta)
6658 textoBotaoBolsa = "Inscrever para bolsa de estudo";
6659
6660 else
6661 textoBotaoBolsa = "Inscrições para bolsas a partir de "+formataDataAberturaBolsa(dadosOferta.dataAberturaBolsaOferta, dadosOferta.horaAberturaBolsaOferta);
6662
6663 if(!ofertasComBolsa){ ofertasComBolsa = true;
6664 }
6665 }else
6666 textoBotaoBolsa = "Vagas esgotadas para bolsas de estudo";
6667 }
6668
6669 //verifica se o botão de concorrer a bolsa deve aparecer
6670 if(retornoOfertaBolsaSenac.BOTAO_BOLSA && !dadosAberturaBolsa.exibirContador){
6671
6672 exibirBotaoBolsa = true;
6673
6674 if(!ofertasComBolsa) ofertasComBolsa = true;
6675
6676 if(retornoOfertaBolsaSenac.TEM_VAGA_BOLSA && dadosAberturaBolsa.bolsaJaAberta && !$('#manutencao-bolsa').val()){
6677 classeBotaoBolsa = '';
6678 }else{
6679 classeBotaoBolsa = 'disabled';
6680 }
6681 }
6682
6683 //Verifica se o botão do cronômetro deve aparecer
6684 if(dadosAberturaBolsa.exibirContador && !$('#manutencao-bolsa').val()){
6685 textoBotaoContadorBolsa = dadosAberturaBolsa.textoContador;
6686 exibirContadorBolsa = true;
6687 }
6688
6689 if(exibirBotaoBolsa)
6690 $('.codigoOferta_'+codigoOfertaRetornoBolsa+' .ssp-card-oferta-curso .ssp-container-botao-bolsa').append( criaBotaoBolsa(dadosOferta, textoBotaoBolsa, classeBotaoBolsa) )
6691 else if(exibirContadorBolsa)
6692 $('.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>')
6693 else {
6694 $('.codigoOferta_'+codigoOfertaRetornoBolsa+'.content-btn-bolsa').hide()
6695 $('.show-price-content.codigoOferta_'+oferta.codigoOferta + ' .ou-separator-desconto').hide()
6696 }
6697
6698 }else{
6699 //EMED
6700 if(isEmed){
6701 verificaBotoesEmed(oferta, false);
6702 }
6703 }
6704
6705 controlaPaginaBolsa()
6706 })
6707 .fail(function(){
6708 $('.content-btn-bolsa.codigoOferta_'+oferta.codigoOferta).hide()
6709 $('.show-price-content.codigoOferta_'+oferta.codigoOferta + ' .ou-separator-desconto').hide()
6710
6711 //EMED
6712 if(isEmed){
6713 verificaBotoesEmed(oferta, false);
6714 }
6715 });
6716
6717
6718 }
6719
6720 }
6721
6722 function controlaPaginaBolsa(){
6723 if(ofertasComBolsa)
6724 $("#ssp-abrir-pagina-bolsa").removeClass("d-none")
6725 else
6726 $("#ssp-abrir-pagina-bolsa").addClass("d-none")
6727 }
6728
6729 function associaEventoBtnFormaPagamento(i){
6730 var modal = document.getElementById("myModal_"+i);
6731
6732 var btn = document.getElementById("myBtn_"+i);
6733
6734 if(btn!=null){
6735 btn.onclick = function(ev) {
6736 event.preventDefault()
6737
6738 $('#modalExtAluno_'+i).addClass('d-none');
6739
6740 var elem = $(ev.target);
6741 var _modal = document.getElementById(
6742 'myModal_'+elem.data('index'));
6743 _modal.style.display = "block";
6744 $('#myModal_'+i).find('.modal-extensao_content:first-child').removeClass('d-none');
6745
6746 }
6747 }
6748
6749
6750
6751
6752 }
6753
6754
6755 function actionBtnComprar(elem){
6756
6757 // Montar object push - google tag manager - 3
6758 ofertaSelecionada = itensEcommerce.get(elem.attr('data-evento'))
6759 sendEventEcommerce("select_item", ofertaSelecionada);
6760 sendEventEcommerce("view_item", ofertaSelecionada);
6761
6762 //Verifica se deve exibir o modal com a localização
6763 if(elem.attr('data-espaco-ex') == 'true'){
6764 $('#btnCompraLocal_'+elem.data('index')).show();
6765
6766 //Limpa onclicks para nao repetir execucao
6767 $('#modalAntesCompra_'+elem.data('index')).off('click', '#btnCompraLocal_'+elem.data('index'))
6768 $('#modalAntesCompra_'+elem.data('index')).on('click', '#btnCompraLocal_'+elem.data('index'), function () {
6769 // Montar object push - google tag manager - 4
6770 sendEventEcommerce("add_to_cart", ofertaSelecionada);
6771 if( elem.attr('data-destino-compra') != '2' )
6772 sendEventEcommerce("begin_checkout", ofertaSelecionada);
6773 })
6774 $('#btnBolsaLocal_'+elem.data('index')).hide();
6775 const _modal = $('#modalAntesCompra_'+elem.data('index'));
6776 _modal.css('display','flex');
6777 }else{
6778 var urlCompra = linkBotaoCompra.replace('\{codigoUnidade\}', elem.attr('data-unidade')).replace('\{codigoOferta\}', elem.attr('data-evento'));
6779
6780 if( elem.attr('data-destino-compra') == '2' ){
6781 var dataEfetivaFormat = formataDataComBarra($('[name="dataEfetivaSTR"]').val());
6782
6783 addItemBackpack(elem.attr('data-evento'), '#' + elem.attr('id'),elem.attr('data-unidade'), dataEfetivaFormat);
6784
6785 }else{
6786 window.open(urlCompra, '_blank');
6787 }
6788 }
6789
6790
6791
6792 }
6793
6794 function associaEventoBtnComprar(i){
6795 var btnComprar = document.getElementById("btnComprar_"+i);
6796
6797 if(btnComprar != null && !btnComprar.classList.contains('disabled')){
6798 btnComprar.onclick = function(ev) {
6799
6800 ev.preventDefault()
6801 var elem = $(ev.target);
6802 actionBtnComprar(elem);
6803
6804 }
6805 }
6806 }
6807
6808 function associaEventoBtnComprarDentroFormaPgto(i){
6809 var btnComprarFormaPgto = document.getElementById("btnComprarFormaPgto_"+i);
6810
6811 if(btnComprarFormaPgto != null && !btnComprarFormaPgto.classList.contains('disabled')){
6812 btnComprarFormaPgto.onclick = function(ev) {
6813 event.preventDefault()
6814 var elem = $('#btnComprarFormaPgto_'+i);
6815 actionBtnComprar(elem);
6816 }
6817 }
6818 }
6819
6820 function associaEventoBtnComprarConhecaDescontoOk(i){
6821 var btnComprarConhecaDescontoOk = document.getElementById("btnComprarConhecaDescontoOk_"+i);
6822
6823 if(btnComprarConhecaDescontoOk != null){
6824 btnComprarConhecaDescontoOk.onclick = function(ev) {
6825 event.preventDefault()
6826 var elem = $(ev.target);
6827 actionBtnComprar(elem);
6828 }
6829 }
6830 }
6831
6832 function associaEventoBtnComprarConhecaDescontoNot(i){
6833 var btnComprarConhecaDescontoNot = document.getElementById("btnComprarConhecaDescontoNot_"+i);
6834
6835 if(btnComprarConhecaDescontoNot != null){
6836 btnComprarConhecaDescontoNot.onclick = function(ev) {
6837 event.preventDefault()
6838 var elem = $(ev.target);
6839 actionBtnComprar(elem);
6840 }
6841 }
6842 }
6843
6844 function associaEventoBtnAlunoNao(i){
6845 var btnAlunoNao = document.getElementById("btn-aluno-nao_"+i);
6846
6847 if(btnAlunoNao != null){
6848 btnAlunoNao.onclick = function(ev) {
6849 event.preventDefault()
6850 var elem = $(ev.target);
6851 elem.addClass('modal-extensao-btn-aluno-sim-ativo'),
6852 elem.closest('.sim').removeClass('modal-extensao-btn-aluno-sim-ativo');
6853 elem.parent().siblings().find('button').removeClass('modal-extensao-btn-aluno-sim-ativo')
6854 $('#msg-alunoNao_'+i).removeClass('d-none');
6855 $('#msg-alunoSim_'+i).addClass('d-none');
6856 }
6857 }
6858 }
6859
6860 function associaEventoBtnAlunoSim(i){
6861 var btnAlunoSim = document.getElementById("btn-aluno-sim_"+i);
6862
6863 if(btnAlunoSim != null){
6864 btnAlunoSim.onclick = function(ev) {
6865 event.preventDefault()
6866 var elem = $(ev.target);
6867 elem.addClass('modal-extensao-btn-aluno-sim-ativo'),
6868 elem.closest('.nao').removeClass('modal-extensao-btn-aluno-sim-ativo');
6869 elem.parent().siblings().find('button').removeClass('modal-extensao-btn-aluno-sim-ativo')
6870 $('#msg-alunoSim_'+i).removeClass('d-none');
6871 $('#msg-alunoNao_'+i).addClass('d-none');
6872
6873 }
6874 }
6875 }
6876
6877 function associaEventoBtnConheca(i){
6878 var btnModalExtConheca = document.getElementById("btnModalExtConheca_"+i);
6879
6880 if(btnModalExtConheca != null){
6881 btnModalExtConheca.onclick = function(ev) {
6882 event.preventDefault();
6883 var elem = $(ev.target);
6884 elem.closest('.modal-extensao_content').addClass('d-none');
6885 $('#modalExtAluno_'+i).removeClass('d-none');
6886 $('#msg-alunoSim_'+i).addClass('d-none');
6887 $('#msg-alunoNao_'+i).addClass('d-none');
6888 $('#btn-aluno-sim_'+i).removeClass('modal-extensao-btn-aluno-sim-ativo');
6889 $('#btn-aluno-nao_'+i).removeClass('modal-extensao-btn-aluno-sim-ativo');
6890
6891 }
6892 }
6893 }
6894
6895 function associaEventoBtnLocalRealizacao(i){
6896 var btnLocalRealizacao = document.getElementById("btnLocalRealizacao_"+i);
6897
6898 if(btnLocalRealizacao!=null){
6899 btnLocalRealizacao.onclick = function(ev) {
6900 event.preventDefault();
6901 var elem = $(ev.target);
6902 var _modal = document.getElementById(
6903 'modalLocalRealizacao_'+elem.data('index'));
6904 _modal.style.display = "flex";
6905 }
6906 }
6907 }
6908
6909 function associaEventosFecharModal(i){
6910
6911 var span = document.getElementsByClassName("ssp-card-modal-forma-pagamento__btn-close_"+i);
6912 var closeModalLocalRealizacao = document.getElementsByClassName("ssp-card-modal-local-realizacao__btn-close_"+i)[0];
6913 var closeModalAntesCompra = document.getElementsByClassName("ssp-card-modal-antes-compra__btn-close_"+i)[0];
6914 var closeModalSelecionarOutro = document.getElementsByClassName("ssp-card-modal-selecionar-outro__btn-close_"+i)[0];
6915 var btnEntendiLocalRealizacao = document.getElementsByClassName("ssp-modal-local-realizacao__btn_"+i)[0];
6916 var closeModalBotaoBolsa = document.getElementById("btnBolsaLocal_"+i)
6917
6918 if(isEmed){
6919 var closeModalFormaPagamento = document.getElementsByClassName("ssp-btn-emed__voltar-curso_"+i);
6920 for (const val of closeModalFormaPagamento) {
6921
6922 val.onclick = function() {
6923 $('[id^="myModal_"]').each(function(index,modal){
6924 modal.style.display = "none";
6925 });
6926 }
6927 };
6928 }
6929
6930 //event close modal
6931 for (const val of span) {
6932
6933 val.onclick = function() {
6934 $('[id^="myModal_"]').each(function(index,modal){
6935 modal.style.display = "none";
6936 });
6937 }
6938 };
6939
6940 closeModalLocalRealizacao.onclick = function() {
6941
6942 $('[id^="modalLocalRealizacao_"]').each(function(index,modal){
6943 modal.style.display = "none";
6944
6945 });
6946 }
6947
6948 closeModalAntesCompra.onclick = function() {
6949
6950 $('[id^="modalAntesCompra_"], [id^="modalAntesCompraEmed_"]').each(function(index,modal){
6951 modal.style.display = "none";
6952 });
6953 }
6954
6955 closeModalSelecionarOutro.onclick = function() {
6956
6957 $('[id^="modalAntesCompra_"], [id^="modalAntesCompraEmed_"]').each(function(index,modal){
6958 modal.style.display = "none";
6959 });
6960 }
6961
6962 btnEntendiLocalRealizacao.onclick = function() {
6963
6964 $('[id^="modalLocalRealizacao_"]').each(function(index,modal){
6965 modal.style.display = "none";
6966 });
6967 }
6968
6969 if(closeModalBotaoBolsa != null){
6970 closeModalBotaoBolsa.onclick = function() {
6971
6972 $('[id^="modalAntesCompra_"], [id^="modalAntesCompraEmed_"]').each(function(index,modal){
6973 modal.style.display = "none";
6974 });
6975 }
6976 }
6977
6978 // When the user clicks anywhere outside of the modal, close it
6979 window.onclick = function(event) {
6980
6981 $('[id^="myModal_"]').each(function(index,_modal){
6982 if (event.target == _modal)
6983 _modal.style.display = "none";
6984 });
6985 $('[id^="modalLocalRealizacao_"]').each(function(index,_modal){
6986 if (event.target == _modal)
6987 _modal.style.display = "none";
6988 });
6989
6990 $('[id^="modalAntesCompra_"], [id^="modalAntesCompraEmed_"]').each(function(index,_modal){
6991 if (event.target == _modal)
6992 _modal.style.display = "none";
6993 });
6994 }
6995 }
6996
6997 function turmasIniciadas(dataInicioCurso){
6998
6999 var hoje = new Date();
7000 var dataInicioPartes = dataInicioCurso.split('/');
7001 var dataInicioCursoOferta = new Date(dataInicioPartes[2], dataInicioPartes[1] - 1, dataInicioPartes[0] , hoje.getHours(),hoje.getMinutes(),hoje.getSeconds(),hoje.getMilliseconds());
7002
7003 return dataInicioCursoOferta.getTime() <= hoje.getTime();
7004 }
7005
7006
7007 function concatSTR(str1, str2, separador){
7008
7009 if(str2){
7010
7011 return str1+separador+str2;
7012 }
7013 return str1;
7014 }
7015
7016 //Formata exibicao de datas conforme especificacao GCR
7017 function formataPeriodo(dataInicio, dataFim){
7018
7019 // Se as datas são iguais, retornar apenas a data final
7020 if (dataInicio === dataFim) {
7021 return dataFim;
7022 }
7023
7024 var dtInicioPartes = dataInicio.split('/');
7025 var dtFimPartes = dataFim.split('/');
7026
7027 //Não exibir o número zero antes dos números e o dia 1 como 1º
7028 var dInicioFormatada = (parseInt(dtInicioPartes[0].trim()) == 1 ? '1º' : parseInt(dtInicioPartes[0].trim())) +'/'+parseInt(dtInicioPartes[1].trim())+'/'+dtInicioPartes[2].trim();
7029 var dFimFormatada = (parseInt(dtFimPartes[0].trim()) == 1 ? '1º' : parseInt(dtFimPartes[0].trim())) +'/'+parseInt(dtFimPartes[1].trim())+'/'+dtFimPartes[2].trim();
7030
7031 //Quando um curso inicia e finaliza dentro do mesmo ano: 17/2 a 25/4/2020
7032 if(dtInicioPartes[2].trim() == dtFimPartes[2].trim()){
7033
7034 dInicioFormatada = (parseInt(dtInicioPartes[0].trim()) == 1 ? '1º' : parseInt(dtInicioPartes[0].trim()))+'/'+parseInt(dtInicioPartes[1].trim());
7035
7036 //Quando um curso inicia e finaliza dentro do mesmo mês: 5 a 30/4/2020
7037 if(dtInicioPartes[1].trim() == dtFimPartes[1].trim())
7038 dInicioFormatada = (parseInt(dtInicioPartes[0].trim()) == 1 ? '1º' : parseInt(dtInicioPartes[0].trim()));
7039 }
7040
7041 return dInicioFormatada + ' a ' + dFimFormatada;
7042 }
7043
7044 //Decrementa os contadores de abertudas de bolsa
7045 function atualizaTempoAberturasBolsas() {
7046
7047 var btnsContador = (isEmed) ? $('[id^="btnContadorBolsa_"], [id^="btnContadorComprar_"]') : $('[id^="btnContadorBolsa_"]');
7048
7049 btnsContador.each(function() {
7050
7051 var index = $(this).data('index');
7052 var elId = $(this).attr('id');
7053 var btnContent = $(this).parent('.ssp-btn-group__content');
7054
7055 if(isEmed){
7056 //EMED filtra ofertas e usa outra lista para referenciar as ofertas carregadas
7057 var dadosAberturaBolsa = calculaTempoAberturaBolsa((elId.indexOf('btnContadorBolsa') >= 0) ? ofertasMap.get('' +index).dataAberturaBolsaOferta : ofertasMap.get('' +index).dataAberturaMatricula, ofertasMap.get('' + index).horaAberturaBolsaOferta);
7058 }else{
7059 //calcula o tempo até abertura da bolsa, se houver (apenas depois das 08hrs)
7060 var dadosAberturaBolsa = calculaTempoAberturaBolsa(objsTela.ofertas[index].dataAberturaBolsaOferta, objsTela.ofertas[index].horaAberturaBolsaOferta, objsTela.ofertas[index].botaoBolsaOferta);
7061 }
7062
7063 $(this).find('span').text(dadosAberturaBolsa.hours+':'+dadosAberturaBolsa.minutes+':'+dadosAberturaBolsa.seconds);
7064
7065 //Se esgotou o contador
7066 if(dadosAberturaBolsa.hours == 0 && dadosAberturaBolsa.minutes == 0 && dadosAberturaBolsa.seconds == 0){
7067
7068 //remove o contador
7069 $(this).remove();
7070
7071 //Habilitar inscrição EMED
7072 if(isEmed){
7073 var ofertaEmed = ofertasMap.get('' +index);
7074 var btnIndex = elId.slice(elId.indexOf('_')+1);
7075 var elementoPai = $('.codigoOferta_'+ofertaEmed.codigoOferta+' .ssp-ofertas-emed__card-info-investimento');
7076
7077 if(elId.indexOf('btnContadorBolsa') >= 0){
7078 if($('#manutencao-bolsa').val())
7079 criaBotaoBolsaEmed(ofertaEmed, $('#manutencao-bolsa').val(), 'disabled manutencao');
7080 else if(ofertaEmed.vagasBolsaOferta == true || ofertaEmed.vagasBolsaOferta == "true")
7081 criaBotaoBolsaEmed(ofertaEmed, 'Bolsa de estudo', '');
7082 else
7083 criaBotaoBolsaEmed(ofertaEmed, 'Bolsas de Estudo Esgotadas', 'disabled');
7084 }else if(elId.indexOf('btnContadorComprar') >= 0){
7085
7086 var textoBotao, classeBotao;
7087
7088 textoBotao = $('#manutencao-compra').val() || 'Fazer matrícula';
7089 classeBotao = $('#manutencao-compra').val() ? 'disabled manutencao' : '';
7090
7091 //Garante a ordenação dos botoes (matricula depois bolsa)
7092 const botaoBolsa = document.getElementById('btnBolsa_' + btnIndex) || document.getElementById('btnContadorBolsa_' + btnIndex);
7093
7094 botaoBolsa?.remove(); // Remove se existir
7095
7096 criaBotaoInscreverEmed(ofertaEmed, textoBotao, classeBotao, 'btnComprarEmed_' + ofertaEmed.indice, elementoPai);
7097
7098 if (botaoBolsa) {
7099 elementoPai.append(botaoBolsa);
7100 }
7101
7102 //Altera o botao do modal de pagamento
7103 var modal = $('#myModal_' + btnIndex).find('.ssp-card-modal-forma-pagamento');
7104 var btnModal = modal.find('#btnComprarEmedModal_' + btnIndex);
7105 if(btnModal){
7106 btnModal.remove();
7107 criaBotaoInscreverEmedModal(ofertaEmed, textoBotao, classeBotao, 'btnComprarEmedModal_' + btnIndex, modal, btnIndex);
7108 preencheDadosEmedModal(ofertaEmed,modal);
7109 }
7110
7111
7112 }
7113
7114 }else{
7115
7116 //Checa as condições das vagas do botão de bolsa
7117 var btnBolsaHTML = null;
7118 if($('#manutencao-bolsa').val())
7119 btnBolsaHTML = criaBotaoBolsa(objsTela.ofertas[index], $('#manutencao-bolsa').val(), 'disabled manutencao');
7120 else if(objsTela.ofertas[index].vagasBolsaOferta == true || objsTela.ofertas[index].vagasBolsaOferta == "true")
7121 btnBolsaHTML = criaBotaoBolsa(objsTela.ofertas[index], 'Inscrever para bolsa de estudo');
7122 else
7123 btnBolsaHTML = criaBotaoBolsa(objsTela.ofertas[index], 'Vagas esgotadas para bolsas de estudo', 'disabled');
7124
7125 $('.codigoOferta_'+ objsTela.ofertas[index].codigoOferta +'.ssp-container-botao-bolsa').append(btnBolsaHTML);
7126
7127
7128 }
7129 }
7130
7131 });
7132
7133 }
7134
7135 // Retorna um objeto com o tempo de abertura da bolsa, em horas, minutos e segundos
7136 function calculaTempoAberturaBolsa(dataAberturaBolsa, horaAberturaBolsa, botaoBolsa){
7137
7138 var dadosAberturaBolsa = {
7139 days : '',
7140 hours : '',
7141 minutes : '',
7142 seconds : '',
7143 bolsaJaAberta: false,
7144 exibirContador: false,
7145 textoContador: ''
7146 };
7147
7148 if(dataAberturaBolsa.length == 0 || horaAberturaBolsa.length == 0)
7149 return dadosAberturaBolsa;
7150
7151 var now = todayG;
7152 var dia = now.getDate();
7153 var horarioDia = now.getHours();
7154
7155 var tempoRestante= tempoRestanteAberturaBolsa(dataAberturaBolsa, horaAberturaBolsa);
7156
7157 //console.log('tempo restante '+tempoRestante);
7158
7159 var diaAberturaBolsa = dataAberturaBolsa.split('-')[2];
7160
7161 var delta = tempoRestante / 1000;
7162
7163 var days = Math.floor(delta / 86400);
7164
7165 delta -= days * 86400;
7166
7167 var hours = Math.floor(delta / 3600) % 24;
7168 delta -= hours * 3600;
7169
7170 var minutes = Math.floor(delta / 60) % 60;
7171 delta -= minutes * 60;
7172
7173 var seconds = Math.floor(delta % 60);
7174
7175 //Zerar contador para data que ja passou
7176 if(days < 0){
7177 dadosAberturaBolsa.days = 0;
7178 dadosAberturaBolsa.hours = '00';
7179 dadosAberturaBolsa.minutes = '00';
7180 dadosAberturaBolsa.seconds = '00';
7181 }else{
7182 dadosAberturaBolsa.days = days;
7183 dadosAberturaBolsa.hours = hours < 10 ? '0'+hours : hours;
7184 dadosAberturaBolsa.minutes = minutes < 10 ? '0'+minutes : minutes;
7185 dadosAberturaBolsa.seconds = seconds < 10 ? '0'+seconds : seconds;
7186 }
7187
7188 dadosAberturaBolsa.bolsaAberta = days <= 0 && hours <= 0 && minutes <= 0 && seconds <= 0;
7189 var horaExibeContador = 8;
7190 if(!isEmed && botaoBolsa == false){
7191 dadosAberturaBolsa.exibirContador = false;
7192 }else{
7193 dadosAberturaBolsa.exibirContador = days == 0 && horarioDia >= horaExibeContador && !dadosAberturaBolsa.bolsaAberta && (diaAberturaBolsa == dia);
7194 dadosAberturaBolsa.textoContador = dadosAberturaBolsa.hours + ':' + dadosAberturaBolsa.minutes + ":"+ dadosAberturaBolsa.seconds;
7195 }
7196 dadosAberturaBolsa.bolsaJaAberta = tempoRestante < 0;
7197
7198 return dadosAberturaBolsa;
7199
7200 }
7201
7202 // Verifica se uma oferrta já chegou sua data de abertura
7203 function tempoRestanteAberturaBolsa(dataAberturaBolsa, horaAberturaBolsa){
7204 // console.log(dataAberturaBolsa);
7205 // console.log(horaAberturaBolsa);
7206
7207 //var today = new Date();
7208
7209
7210 //console.log( "TodayG "+ todayG);
7211
7212 //Precisa fazer formatação nos horários pois pode estar como 9h ou 9h30
7213 var partesHora = horaAberturaBolsa.split('h');
7214
7215 var partesHora = partesHora.filter(function (el) {
7216 return el != "";
7217 });
7218
7219 //formato 9h
7220 if(partesHora.length == 1)
7221 var aberturaBolsa = new Date(dataAberturaBolsa+'T'+horaAberturaBolsa.replace('h', '').trim()+":00");
7222
7223 else{
7224
7225 //format 9h3
7226 if(partesHora[1].length == 1)
7227 var aberturaBolsa = new Date(dataAberturaBolsa+'T'+partesHora[0].replace('h', '').trim()+':'+partesHora[1] +'0');
7228
7229 //formato 9h30
7230 else
7231 var aberturaBolsa = new Date(dataAberturaBolsa+'T'+partesHora[0].replace('h', '').trim()+':'+partesHora[1]);
7232 }
7233
7234 // console.log(aberturaBolsa);
7235 return aberturaBolsa - todayG;
7236 }
7237
7238 function formataDataAberturaBolsa(dataAberturaBolsa, horaAberturaBolsa){
7239 var dataPartes = dataAberturaBolsa.split('-');
7240
7241 return dataPartes[2]+'/'+dataPartes[1]+ ' às '+horaAberturaBolsa.replace('h', '').trim()+' horas';
7242
7243 }
7244
7245 function formataValor(valor){
7246
7247 if(!valor.toString().includes(".")){
7248 valor = parseFloat(valor).toLocaleString('pt-BR')+",00";
7249 }else{
7250 valor = parseFloat(valor).toLocaleString('pt-BR');
7251
7252 if(valor.split(",").length == 2){
7253
7254 if(valor.split(",")[1].length == 1)
7255 valor += "0";
7256
7257 }else
7258 valor += ",00";
7259 }
7260
7261 return valor;
7262 }
7263
7264 function ajustarCasasDecimaisSemArredondar(numero, casas) {
7265 const str = numero + ''
7266 const arr = str.split('.')
7267 return parseFloat(arr[0].concat('.').concat(arr[1] ? arr[1].substring(0, casas) : '0'))
7268 }
7269
7270 function possuiCriteriosDesconto2022(dt) {
7271 return dt.substring(dt.lastIndexOf('/') + 1) >= 2022
7272 && (
7273 $('[name="tipoCurso"]').val() == 'livre'
7274 || ($('[name="tipoCurso"]').val() == 'tecnico' && $('[name="modalidades"]').val() == 'espec.-tecnica-de-nivel-medio')
7275 || $('[name="tipoCurso"]').val() == 'extensao'
7276 )
7277 }
7278
7279 function strToFloat(str) {
7280 const separator = str.includes(',') ? ',' : '.'
7281
7282 const numArr = str.split(separator)
7283 const inteiro = numArr[0].replaceAll('.', '').replaceAll(',', '.')
7284 const decimal = numArr[1] ? numArr[1].replaceAll('.', '').replaceAll(',', '.') : ''
7285 return parseFloat(inteiro.concat('.').concat(decimal ? decimal : '0'))
7286 }
7287
7288 /**
7289 * Compare date formatted as "YYYY-MM-DD" with the current date
7290 * Return:
7291 * -1 if dateStr < today
7292 * 0 if dateStr == today
7293 * 1 if dateStr > today
7294 */
7295 function compareDates(dateStr1, dateStr2) {
7296
7297 const convertDate = (dateStr) => {
7298 if (typeof dateStr !== 'string') throw new TypeError('dateStr must be a string with format YYYY-MM-DD');
7299 const match = dateStr.match(/^(\d{4})-(\d{2})-(\d{2})$/);
7300 if (!match) throw new Error('invalid format. Use YYYY-MM-DD');
7301 const [, yy, mm, dd] = match;
7302 return Date.UTC(Number(yy), Number(mm) - 1, Number(dd));
7303 }
7304
7305 const date1 = convertDate(dateStr1);
7306 const date2 = convertDate(dateStr2);
7307 if (date1 < date2) return -1;
7308 if (date1 > date2) return 1;
7309 return 0;
7310 }
7311
7312
7313 function possuiMensalidadeCampanha(oferta) {
7314
7315 const dataInicio = oferta.dataInicio.split('/').reverse().join('-');
7316 const precoParcelaCartoes = parseFloat(oferta.precoParcelaCartoes.replace(',','.'));
7317 const precoParcelaBoleto = parseFloat(oferta.precoParcelaBoleto.replace(',','.'));
7318
7319 if(!oferta.precoVendaMaxParcelaOferta
7320 || (oferta.precoVendaMaxParcelaOferta != 99 && precoParcelaCartoes != 99 && precoParcelaBoleto != 99 && compareDates(dataInicio, '2025-12-31') <= 0)
7321 || (oferta.precoVendaMaxParcelaOferta != 109 && precoParcelaCartoes != 109 && precoParcelaBoleto != 109 && compareDates(dataInicio, '2026-01-01') >= 0)
7322 )
7323 return false
7324
7325 if($('[name="modalidades"]').val() == 'hab.-tecnica-de-nivel-medio')
7326 return true
7327
7328 if($('[name="modalidades"]').val() == 'espec.-tecnica-de-nivel-medio')
7329 return true
7330
7331 if($('[name="modalidades"]').val() == 'qualificacao-profissional')
7332 return true
7333
7334 return false
7335 }
7336
7337 function htmlSlickArea(index, oferta, diasSemanaHTML, codigoUnidade) {
7338 let temDesconto = possuiCriteriosDesconto2022(oferta.dataInicio)
7339 temDesconto = temDesconto && !possuiMensalidadeCampanha(oferta)
7340
7341 // Define o texto singular ou plural
7342 var textoHorario = verificaTerminoDia(oferta.dataInicio, oferta.dataFim) ?
7343 "Horário e dia da aula:" :
7344 "Horário e dias das aulas:";
7345
7346 const btnLocalReal = function(oferta){
7347
7348 // NOVA LÓGICA: Define o texto (Singular/Plural)
7349 var textoOndeAcontece = verificaTerminoDia(oferta.dataInicio, oferta.dataFim) ?
7350 "Onde a aula irá acontecer?" :
7351 "Onde as aulas vão acontecer?";
7352
7353 var btn = `<div class="container-local-realizacao ` + ((oferta.espacoExterno == 'true'|| (isHibrido && temTextoParaFormatoHibrido)) ? '' : 'd-none-btn') + (localLivreOnline(oferta.localEspacoExterno) ? ' idioma-online' : '') + `">`;
7354
7355 btn += (localLivreOnline(oferta.localEspacoExterno)) ?
7356 `<a id="btnLocalRealizacao_` + index + `" data-index="` + index + `" class="btn-idiomas__aula-online" href="#">
7357 <i class="fas fa-wifi"></i>Aulas Online - ao vivo</a>`
7358 : `<a id="btnLocalRealizacao_` + index + `" data-index="` + index + `" class="ssp-card-oferta-curso__local-realizacao-content__title" href="#">
7359 <i class="fas fa-user"></i>` + textoOndeAcontece + `</a>`;
7360
7361 btn += `</div>`;
7362
7363 return btn;
7364
7365 }
7366
7367 // Card Oferta
7368
7369 let result = `
7370 <div class="slick-area__item card_oferta_` + index + ` codigoOferta_` + oferta.codigoOferta + ` ` + (temDesconto ? 'ssp-desconto-2022' : '') + `">
7371
7372 <div class="ssp-card-oferta-curso">
7373
7374 <div class="content-data-dias">
7375
7376 <div class="ssp-card-oferta__info-turma-iniciada" id="aviso-turma-iniciada-` + index + `" style="display:none">
7377 <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>
7378 </div>
7379
7380
7381 <div>
7382 <small class="ssp-card-oferta-curso__title-item">Período:</small>
7383 <h6 class="ssp-card-oferta-curso__item-data-periodo item-data-periodo_` + index + `">` + formataPeriodo(oferta.dataInicio, oferta.dataFim) + `</h6>
7384 </div>
7385
7386 <div class="content-horario-dias-semana">
7387
7388 <div class="horario">
7389 <small class="ssp-card-oferta-curso__title-item">` + textoHorario + `</small>
7390 </div> ` +
7391
7392 `<div class="ssp-card-oferta-curso__dia-hora_content">
7393 ` + diasSemanaHTML + `
7394 </div>
7395
7396 </div>
7397
7398 ` + btnLocalReal(oferta);
7399
7400 result = result + `
7401 </div>
7402 `
7403
7404 if(excecaoCursoGratuito(oferta)){
7405 result += montaRestanteHTMLexcecaoCursoGratuito(index,oferta);
7406 return result;
7407 }
7408
7409 //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
7410 //Adicionada a validação dos preços da oferta em 07/06/2022 - Tarefa 9498
7411 const estaSemValorOferta = oferta.botaoCompraOferta == ''
7412 || oferta.botaoCompraOferta == 'false'
7413 || !oferta.precoVendaOferta
7414 || !oferta.precoCheioOferta
7415 || !oferta.precoVendaMaxParcelaOferta
7416 || strToFloat(oferta.precoVendaOferta) == 0
7417 || strToFloat(oferta.precoCheioOferta) == 0
7418 || strToFloat(oferta.precoVendaMaxParcelaOferta) == 0
7419
7420 //Trecho inicial do Bolsa de estudo
7421 result += `<div class="content-btn-bolsa codigoOferta_` + oferta.codigoOferta + (estaSemValorOferta ? ' pb-0' : '') + `">
7422 <div class="ssp-card-oferta__info-turma-content">
7423 <h6 class="ssp-card-oferta__info-turma mb-0">Bolsas de estudo</h6>
7424 </div>
7425 <div class="codigoOferta_` + oferta.codigoOferta + ` ssp-container-botao-bolsa"></div>
7426 </div>
7427 `
7428
7429 if(estaSemValorOferta) {
7430 result = result + `
7431 <div class="content-buttons hide">
7432 </div>
7433 `
7434 return result;
7435 }
7436
7437
7438 //Trecho final do Bolsa de estudo e inclusao de botao de expansao do "Valores para compra"
7439 result += ` <div class="show-price-content codigoOferta_` + oferta.codigoOferta + `">
7440 <div class="ou-separator-desconto">Ou</div>
7441 <button type="button" class="btn-show-price">
7442 <p>Saiba mais sobre:</p>
7443 <div onclick="togglePriceCard('codigoOferta_` + oferta.codigoOferta + `')">
7444 <i class="fas fa-money-bill"></i>
7445 <span>Valores para compra</span>
7446 </div>
7447 </button>
7448 </div>
7449 `
7450
7451 result = result + `
7452 <div class="content-valores-descontos hide-price codigoOferta_` + oferta.codigoOferta + `">
7453 `
7454
7455 if( temDesconto && !ehCursoTrampolim ) {
7456 result = result + `
7457 <div class="ssp-card-oferta__info-turma-content">
7458 <h6 class="ssp-card-oferta__info-turma">Valores para compra</h6>
7459 </div>
7460
7461 <div class="block-valor-desconto">
7462
7463 <div class="tag-label-desconto">
7464 <small class="ssp-card-oferta-curso__title-item">Valor com </small>
7465 <span class="ssp-card-oferta-curso__valor-desconto">50% de desconto*</span>
7466 </div>
7467
7468 <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>
7469
7470 <div class="ssp-card-oferta-curso__desconto-content">
7471 <p>De: <span class="ssp-card-oferta-curso__valor-antigo">R$ ` + formataValor(ajustarCasasDecimaisSemArredondar(strToFloat(oferta.precoVendaOferta), 2)) + `</span></p>
7472 <p>Por: <span class="ssp-card-oferta-curso__valor-desconto">R$ ` + formataValor(ajustarCasasDecimaisSemArredondar(strToFloat(oferta.precoVendaOferta)/2, 2)) + `</span></p>
7473 </div>
7474 `
7475
7476 if($('[name="tipoCurso"]').val() == 'extensao') {
7477 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>`
7478 } else {
7479 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>`
7480 }
7481
7482 result = result + `
7483 <div class="ou-separator-desconto">Ou</div>
7484
7485 <div class="block-valor-total">
7486
7487 <small class="ssp-card-oferta-curso__title-item">Valor sem desconto:</small>
7488
7489 <h6 class="ssp-card-oferta-curso__item-valor-investimento"><span>` + oferta.numeroMaxParcelasOferta + `x</span>R$ ` + formataValor(oferta.precoVendaMaxParcelaOferta) + `</h6>
7490
7491 <div class="ssp-card-oferta-curso__desconto-content">
7492 <p>Valor total: <strong>R$ ` + formataValor(strToFloat(oferta.precoVendaOferta)) + `</strong></p>
7493 </div>
7494
7495 </div>
7496 `
7497 }else{
7498
7499 // itens que são diferentes entre técnico e livres comprado a extensão
7500 if($('[name="tipoCurso"]').val() == 'extensao'){
7501 result = result + `
7502
7503 <div class="block-valor-total">
7504
7505 <div class="investimento" id="container_investimento_` + index + `">
7506
7507 <small class="ssp-card-oferta-curso__title-item">Investimento:</small>
7508
7509 <h6 class="ssp-card-oferta-curso__item-valor-investimento"><span>` + oferta.numeroMaxParcelasOferta + `x</span>R$ ` + formataValor(ajustarCasasDecimaisSemArredondar(strToFloat(oferta.precoVendaMaxParcelaOferta))) + `</h6>
7510
7511 <div class="ssp-card-oferta-curso__desconto-content">
7512 <p>Ou: <span class="ssp-card-oferta-curso__valor-antigo text-decoration-none">R$ ` + formataValor(oferta.precoVendaOferta) + `</span> à vista</p>
7513 </div>
7514
7515 </div>
7516
7517 </div>
7518 `
7519 } else {
7520 result = result + `
7521 <div class="block-valor-total">
7522 <div class="investimento" id="container_investimento_` + index + `">
7523 `
7524
7525 // Não mostrar mensagem de 30% de desconto em casos especificos
7526 if(temDesconto){
7527 result = result + `
7528 <small class="ssp-card-oferta-curso__title-item font-weight-bold">Valor com 30% de desconto:</small>
7529 `
7530 }
7531
7532 if(oferta.precoCheioOferta == oferta.precoVendaOferta) {
7533 result = result + `
7534 <small class="ssp-card-oferta-curso__title-item">Valor do curso:</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>Ou <span class="ssp-card-oferta-curso__valor-antigo text-decoration-none">R$ ` + formataValor(oferta.precoVendaOferta) + `</span></p>
7539 </div>
7540 </div>
7541 </div>
7542 `
7543 } else {
7544 result = result + `
7545 <small class="ssp-card-oferta-curso__title-item">Investimento:</small>
7546 <h6 class="ssp-card-oferta-curso__item-valor-investimento"><span>` + oferta.numeroMaxParcelasOferta + `x</span>R$ ` + formataValor(oferta.precoVendaMaxParcelaOferta) + `</h6>
7547
7548 <div class="ssp-card-oferta-curso__desconto-content">
7549 <p>De: <span class="ssp-card-oferta-curso__valor-antigo">R$ ` + formataValor(oferta.precoCheioOferta) + `</span></p>
7550 <p>Por: <span class="ssp-card-oferta-curso__valor-desconto">R$ ` + formataValor(oferta.precoVendaOferta) + `</span></p>
7551 </div>
7552 </div>
7553 </div>
7554 `
7555 }
7556 }
7557 }
7558
7559 let dataBtnComprar = getObjBtnComprar(oferta);
7560
7561 // itens que são diferentes entre técnico e livres comprado a extensão
7562 result = result + `
7563
7564 <div class="ssp-card-oferta-curso__formas-pagamento-content" id="container_forma_pgto_` + index + `">
7565
7566 <span>Saiba mais sobre:</span>
7567
7568 <div>
7569 <i class="ssp-card-oferta-curso__formas-pagamento-content__icon-credit-card"></i>
7570 <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>
7571 </div>
7572
7573 </div>
7574
7575 <div class="content-buttons">
7576
7577 <div class="ssp-btn-group__content botoes-oferta-container_` + index + `">
7578
7579 <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>
7580
7581 </div>
7582
7583 </div>
7584
7585 </div>
7586
7587 </div>
7588 `
7589
7590 return result
7591 }
7592
7593 function montaRestanteHTMLexcecaoCursoGratuito(index, oferta){
7594
7595 let dataBtnComprarExcecao = getObjBtnComprar(oferta);
7596 let resultModalidade =
7597 `
7598 <div class="content-valores-descontos hide-price codigoOferta_` + oferta.codigoOferta + `">
7599 <div class="ssp-card-oferta__info-turma-content">
7600 <h6 class="ssp-card-oferta__info-turma">Curso gratuito</h6>
7601 </div>
7602 <div class="block-valor-total">
7603 <div class="investimento" id="container_investimento_` + index + `">
7604 <h6 class="ssp-card-oferta-curso__item-valor-investimento"><span>R$ 0,00</h6>
7605 </div>
7606 </div>
7607 <div class="content-buttons">
7608
7609 <div class="ssp-btn-group__content botoes-oferta-container_` + index + `">
7610
7611 <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>
7612
7613 </div>
7614
7615 </div>
7616 </div>
7617 </div>
7618 `
7619 ;
7620 return resultModalidade;
7621
7622 }
7623
7624
7625 var htmlModalLocalRealizacao = '<div id="modalLocalRealizacao_{index}" class="ssp-modal">'
7626 htmlModalLocalRealizacao += '<div class="ssp-modal-local-realizacao">'
7627 htmlModalLocalRealizacao += '<div class="ssp-modal-local-realizacao__title-content">'
7628
7629 htmlModalLocalRealizacao += '{tituloLocalRealizacao}'
7630
7631 htmlModalLocalRealizacao += '<i class="ssp-card-modal-local-realizacao__btn-close_{index} ssp-card-modal-forma-pagamento__btn-close"></i>'
7632 htmlModalLocalRealizacao += '</div>'
7633 htmlModalLocalRealizacao += '<div class="ssp-modal-local-realizacao__texto">'
7634 htmlModalLocalRealizacao += '<p class="{classeTextoInfoLocalRealizacao}">A unidade {nomeUnidade} realizará as aulas em outro endereço, conforme informações abaixo:</p>'
7635 htmlModalLocalRealizacao += '<p><span class="ssp-modal-local-realizacao__subtitle localEspacoExternoTexto_{index}">{textoFormatoHibrido}{localEspacoExterno}</span></p>'
7636 htmlModalLocalRealizacao += '<address>'
7637 htmlModalLocalRealizacao += '<span id="endereco_realizacao_{index}" class="{classeEnderecoRealizacao}">{ruaEspacoExterno}, {numeroEspacoExterno} {complementoEspacoExterno}<br></span>'
7638 htmlModalLocalRealizacao += '<span id="bairro_realizacao_{index}" class="{classeBairroRealizacao}">Bairro: {bairroEspacoExterno}<br></span>'
7639 htmlModalLocalRealizacao += '<span id="cidade_realizacao_{index}" class="{classeCidadeRealizacao}">Cidade: {cidadeEspacoExterno} - SP<br></span>'
7640 htmlModalLocalRealizacao += '<span id="cep_realizacao_{index}" class="{classeCepRealizacao}">CEP: {cepEspacoExterno}</span>'
7641 htmlModalLocalRealizacao += '</address>'
7642 htmlModalLocalRealizacao += '<div class="btn ssp-modal-local-realizacao__btn-content">'
7643 htmlModalLocalRealizacao += '<a class="btn ssp-modal-local-realizacao__btn {classeEntendi} ssp-modal-local-realizacao__btn_{index}" href="#a">Entendi</a>'
7644 htmlModalLocalRealizacao +='</div>'
7645 htmlModalLocalRealizacao +='</div>'
7646 htmlModalLocalRealizacao +='</div>'
7647 htmlModalLocalRealizacao +='</div>';
7648
7649 var htmlModalAntesCompra = '<div id="modalAntesCompra_{index}" class="ssp-modal">'
7650 htmlModalAntesCompra += '<div class="ssp-modal-local-realizacao">'
7651 htmlModalAntesCompra += '<div class="ssp-modal-local-realizacao__title-content">'
7652 htmlModalAntesCompra += '<h6 class="ssp-modal-local-realizacao__title"> LEMBRETE IMPORTANTE!</h6>'
7653 htmlModalAntesCompra += '<i class="ssp-card-modal-antes-compra__btn-close_{index} ssp-card-modal-forma-pagamento__btn-close"></i>'
7654 htmlModalAntesCompra += '</div>'
7655 htmlModalAntesCompra += '<div class="ssp-modal-local-realizacao__texto">'
7656 htmlModalAntesCompra += '<p class="{classeTextoInfoLocalRealizacao}">A unidade {nomeUnidade} realizará as aulas em outro endereço, conforme informações abaixo:</p>'
7657 htmlModalAntesCompra += '<p><span class="ssp-modal-local-realizacao__subtitle localEspacoExternoTexto_{index}">{textoFormatoHibrido}{localEspacoExterno}</span></p>'
7658 htmlModalAntesCompra += '<address>'
7659 htmlModalAntesCompra += '<span id="endereco_realizacao_{index}" class="{classeEnderecoRealizacao}">{ruaEspacoExterno}, {numeroEspacoExterno} {complementoEspacoExterno}<br></span>'
7660 htmlModalAntesCompra += '<span id="bairro_realizacao_{index}" class="{classeBairroRealizacao}">Bairro: {bairroEspacoExterno}<br></span>'
7661 htmlModalAntesCompra += '<span id="cidade_realizacao_{index}" class="{classeCidadeRealizacao}">Cidade: {cidadeEspacoExterno} - SP<br></span>'
7662 htmlModalAntesCompra += '<span id="cep_realizacao_{index}" class="{classeCepRealizacao}">CEP: {cepEspacoExterno}</span>'
7663 htmlModalAntesCompra += '</address>'
7664 htmlModalAntesCompra += '<div class="btn ssp-modal-local-realizacao__btn-content">'
7665 htmlModalAntesCompra += '{componentBuyConfirmation}'
7666 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>'
7667 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>'
7668 htmlModalAntesCompra +='</div>'
7669 htmlModalAntesCompra +='</div>'
7670 htmlModalAntesCompra +='</div>'
7671 htmlModalAntesCompra +='</div>';
7672
7673 var htmlSlickAreaDiasSemana = '<div class="ssp-card-oferta-curso__dia-hora-item">'
7674 htmlSlickAreaDiasSemana +='<p class="ssp-card-oferta-curso__dia-hora-item__dia">'
7675 htmlSlickAreaDiasSemana += '<span data-dia-hora="dias-semana">{diasSemana}</span>'
7676 htmlSlickAreaDiasSemana += '<span data-dia-hora="horário">{horasSemana}</span>'
7677 htmlSlickAreaDiasSemana += '</p>'
7678 htmlSlickAreaDiasSemana += '</div>';
7679
7680
7681 //Montar object push - google tag manager - 5
7682 function criaItensEcommerce(ofertas){
7683
7684 let nomeUnidadeSelecionada = objsTela.unidades[ultimaUnidade].nome
7685
7686 let dadosCurso = {
7687 //Pegar do freemarker
7688 tituloComercial : $('[name="tituloComercial"]').val(),
7689 tipoCurso : $('[name="nomeCategoriaTipoCurso"]').val(),
7690 formato : $('[name="formato"]').data("formato")
7691 }
7692
7693 let ecommerceObject = {
7694
7695 item_id: "", //codOferta - oferta,
7696 item_name: "", //Nome do curso - curso,
7697 affiliation: "", //nome da unidade - oferta,
7698 currency: "BRL", //Moeda - "BRL",
7699 discount: "", //desconto - oferta,
7700 index: "", //indice da lista - i,
7701 item_brand: "Senac SP", //"Senac SP",
7702 item_category: "", //categoria do curso - curso,
7703 item_list_id: "", //"60",
7704 item_list_name: "", //"São Carlos" - Oferta,
7705 item_variant: "", //modalidade - curso,
7706 price: "", //preco cheio - oferta,
7707 quantity: 1
7708
7709 }
7710
7711 let itensEcommerce = new Map();
7712
7713 for(var i = 0; i < ofertas.length; i++){
7714
7715 itensEcommerce.set(ofertas[i].codigoOferta, {
7716
7717 item_id: ofertas[i].codigoOferta, //codOferta - oferta,
7718 item_name: dadosCurso.tituloComercial, //Nome do curso - curso,
7719 affiliation: nomeUnidadeSelecionada, //nome da unidade - oferta,
7720 currency: "BRL", //Moeda - "BRL",
7721 discount: parseFloat(ofertas[i].precoCheioOferta - ofertas[i].precoVendaOferta).toFixed(2), //desconto - oferta,
7722 index: i, //indice da lista - i,
7723 item_brand: "Senac SP", //"Senac SP",
7724 item_category: dadosCurso.tipoCurso, //categoria do curso - curso,
7725 item_list_id: objsTela.unidades[ultimaUnidade].codigoUnidade, //"60",
7726 item_list_name: nomeUnidadeSelecionada, //"São Carlos" - Oferta,
7727 item_variant: dadosCurso.formato, //modalidade - curso,
7728 price: parseFloat(ofertas[i].precoCheioOferta).toFixed(2), //preco cheio - oferta,
7729 quantity: 1
7730
7731 }
7732 )
7733 }
7734
7735 return itensEcommerce;
7736 }
7737
7738 //EMED - ELEMENTOS DINAMICOS
7739 const htmlSlickAreaEmed = function(oferta){
7740 var btnid = 'myBtn_' + oferta.indice;
7741 const diasHorarios = function(oferta){
7742 return oferta.diasDaSemanaOferta.join(', ').toLowerCase();
7743
7744 }
7745
7746
7747 return `
7748 <div class="ssp-ofertas-emed__card codigoOferta_`+ oferta.codigoOferta + `">
7749
7750 <div class="ssp-ofertas-emed__card-info-turma">
7751
7752 <div class="item-content">
7753 <i class="fas fa-calendar-alt calendar-icon-turma"></i>
7754 <p class="title-turma">`+ oferta.titulo +`</p>
7755 <span class="text-default" data-info="info-turma">Alunos na turma: <strong>até `+ oferta.qtdeTotalVagas +`</strong></span>
7756 </div>
7757
7758 <div class="content-previsao-inicio-termino">
7759
7760 <div class="item-content">
7761 <span class="text-default">Previsão de início:</span>
7762 <span class="text-default-lg">`+ formatarDataEmed(oferta.dataInicio,oferta.etapa,false) +`</span>
7763 </div>
7764
7765 <div class="item-divisor"></div>
7766
7767 <div class="item-content">
7768 <span class="text-default">Previsão de término:</span>
7769 <span class="text-default-lg">`+ formatarDataEmed(oferta.dataFim,oferta.etapa,true) +`</span>
7770 </div>
7771
7772 </div>
7773
7774
7775 <div class="item-divisor"></div>
7776
7777 <div class="item-content">
7778 <span class="text-default">Dias e horários das aulas:</span>
7779 <span class="text-default-lg" style="text-transform: capitalize;">`+ diasHorarios(oferta) +`</span>
7780 <span class="text-default-lg">`+ oferta.horaInicio.replace(':', 'h') + ' às ' + oferta.horaFimOferta.replace(':', 'h') +`</span>
7781 </div>
7782
7783 </div>
7784
7785 <div class="ssp-ofertas-emed__card-info-investimento">
7786 <p class="title-investimento">Investimento anual:</p>
7787
7788 <div class="item-content-investimento">
7789 <span class="txt-parcelas">Até `+ oferta.numeroMaxParcelasOferta +`x</span>
7790 <span class="txt-valor-parcela">R$ `+ formataValor(oferta.precoVendaMaxParcelaOferta) +`</span>
7791 </div>
7792
7793 <div class="item-content-investimento">
7794 <p class="txt-boleto-cartao">(boleto bancário ou cartão de crédito)</p>
7795 </div>
7796
7797 <div class="item-content-investimento">
7798 <i class="fas fa-credit-card icon-cartao-credito"></i>
7799 <a id="`+ btnid +`" data-index="`+ oferta.indice +`" href="#" class="link-descontos-parcelamentos">Descontos e Parcelamentos</a>
7800 </div>
7801
7802 </div>
7803
7804 </div>
7805
7806 `;
7807 }
7808
7809
7810 function loadCursosVocePodeGostar(){
7811
7812 if(isEmed){
7813 var url = urlSearchCursosPodeGostarEmed
7814 .replace('\{groupId\}', groupId)
7815 .replace('\{tiposDeCurso\}',$('[name="idTipoCurso"]').val())
7816 .replace('\{limit\}', 12)
7817 .replace('\{articleId\}', $('[name="articleId"]').val());
7818 }else{
7819 var url = urlSearchCursosPodeGostar
7820 .replace('\{companyId\}',themeDisplay.getCompanyId())
7821 .replace('\{groupId\}', groupId)
7822 .replace('\{userId\}',themeDisplay.getUserId())
7823 .replace('\{articleId\}',$('[name="articleId"]').val())
7824 .replace('\{limit\}', 12);
7825 }
7826
7827
7828 $.ajax({
7829 url : url,
7830 type : 'get',
7831 beforeSend: function(){
7832 loading('#slider-curso');
7833 }
7834 })
7835 .done(function(cursos){
7836
7837 if(cursos.length > 0){
7838
7839 cursos = JSON.parse(cursos);
7840
7841 if(isEmed) cursos = cursos['cursos'];
7842
7843 if(cursos.length > 0) $('#section-cursos-voce-pode-gostar').removeClass('d-none');
7844 else {
7845 $('#section-cursos-voce-pode-gostar').addClass('d-none');
7846 return;
7847 }
7848
7849 var articles = [];
7850
7851 $.each(cursos, function(k, c){
7852 articles.push(c.articleId);
7853 });
7854
7855 //Verifica a situação dos botoes de inscrições e bolsa
7856 $.ajax({
7857 url : '/o/senac-content-services/verificaBotoesInscricaoEBolsa/'+groupId+'/'+articles.join(','),
7858 type : 'get'
7859 })
7860 .done(function(infoBotoes){
7861
7862 if(infoBotoes.length > 0) {
7863
7864 infoBotoes = JSON.parse(infoBotoes);
7865
7866 $('#slider-curso').empty();
7867
7868 $.each(cursos, function(k, c){
7869 $('#slider-curso').append(buildCardCurso(c, infoBotoes));
7870
7871 });
7872
7873 $('#slider-curso').addClass(
7874 'slick-area slick-area--md-bleed slider-container slick-area-cursos-pode-gostar');
7875
7876 sliderCurso('.slick-area-cursos-pode-gostar');
7877 }
7878 });
7879 }
7880
7881 })
7882 .fail(function(jqXHR, textStatus, msg){
7883 // alert(msg);
7884 });
7885
7886 }
7887
7888 /*
7889 * Armazena a navegação em cookies, se habilitado
7890 */
7891 $(document).on("click", ".ck-curso", function() {
7892
7893 //Verifica se o cookie está habilitado
7894 if(getCookie('portalSenacCookie') != null){
7895
7896 var articleId = $(this).data('ck');
7897 manageCookieArray('ck-cursos', articleId);
7898
7899 }
7900
7901 });
7902
7903
7904
7905
7906
7907 $(function(){
7908
7909 if($('#unidades-ofertas').find('option').length ==0){
7910
7911 $('.ssp-container-selecione-unidade').addClass('d-none')
7912
7913 }
7914
7915 });
7916
7917 function avisoNovasTurmas(){
7918
7919
7920 window.event.preventDefault()
7921
7922 //var unidadeSelecionada = $('#select-registro-interesse').val();
7923 //este select tem 2 valores separados por @ -> categoryId@codUnidade
7924 // var unidadeSelecionada = $('#unidades-ofertas').val();
7925
7926 //Código fixo quando Senac Ao Vivo
7927 var codUnidadeSelectRegInt = (isAoVivo) ? codUnidadeSenacAoVivo : $('#unidades-ofertas').val().split("@")[1];
7928
7929 // if(codUnidadeSelectRegInt && codUnidadeSelectRegInt.length){
7930
7931 //Se ja tiver logado , redireciona para o registro
7932 if(getCookie('ticket') == null){
7933
7934 //Abre modal login
7935 $('#modal-login').removeClass('d-none');
7936
7937 }else{
7938
7939 abrirModalRegistroInteresse(codUnidadeSelectRegInt);
7940
7941 verificaBtnEnviarRegistroInteresseAtivo();
7942 }
7943
7944 window.onclick = function(event) {
7945 $('[id="modal-registro-interesse"]').each(function(index,_modal){
7946 if (event.target == _modal) {
7947 $('#modal-registro-interesse').addClass('d-none');
7948 $("body").removeClass("overflow-hidden")
7949 }
7950 });
7951 }
7952
7953 // }
7954 }
7955 function login(){
7956 var unidadeSelecionada
7957 var codUnidadeSelectRegInt
7958 doLogin({
7959 user: $('#login-email-modal').val(),
7960 pass: $('#login-password-modal').val(),
7961 btnLoadingSelector: '#btnLogin',
7962 before: () => {
7963 $('#mensagem-erro-login').addClass('d-none')
7964
7965 unidadeSelecionada = $('#unidades-ofertas').val();
7966 codUnidadeSelectRegInt = (isAoVivo) ? codUnidadeSenacAoVivo : $('#unidades-ofertas').val().split("@")[1];
7967 },
7968 done: (data) => {
7969 var loginData = JSON.parse(data);
7970
7971 if(loginData.status == 200 || loginData.status == 201){
7972 //Após logar-se, exibe o modal p/registro de interesse
7973 abrirModalRegistroInteresse(codUnidadeSelectRegInt);
7974 verificaBtnEnviarRegistroInteresseAtivo();
7975 //esconde o modal de login
7976 $('#modal-login').addClass('d-none');
7977 }
7978 },
7979 errorMessageSelector: '#mensagem-erro-login',
7980 error: (err) => console.error(err)
7981 })
7982 }
7983
7984 function registroSelecionaTodosDias(){
7985
7986 if($(this).hasClass('ssp-week-day-active')){
7987 $(this).removeClass('ssp-week-day-active')
7988 $('.ssp-week-day').removeClass('ssp-week-day-active')
7989 }else{
7990 $(this).addClass('ssp-week-day-active')
7991 $('.ssp-week-day').addClass('ssp-week-day-active')
7992 }
7993
7994 verificaBtnEnviarRegistroInteresseAtivo();
7995 }
7996
7997 function registroSelecionaTodosPeriodos(){
7998
7999 if($(this).is(':checked')){
8000 $('.ssp-card-registro-interesse__check-itens-content.periodos-registro-interesse input[type=checkbox]').prop('checked', true);
8001 }else{
8002 $('.ssp-card-registro-interesse__check-itens-content.periodos-registro-interesse input[type=checkbox]').prop('checked', false);
8003 }
8004
8005 verificaBtnEnviarRegistroInteresseAtivo();
8006 }
8007 $('.turmas-registro-interesse input[type=checkbox]').on('click', function() {
8008 var $selecionado = $(this);
8009 if ($selecionado.is(":checked")) {
8010 $('.turmas-registro-interesse input[type=checkbox]').prop("checked", false);
8011 $selecionado.prop("checked", true);
8012 } else {
8013 $selecionado.prop("checked", false);
8014 }
8015});
8016 function enviarRegistroInteresse(){
8017
8018 const codigoUsr = getCookie('codigo');
8019
8020 if(codigoUsr == null){
8021 //Sem o cookie refaz o login
8022 $('#modal-registro-interesse').addClass('d-none');
8023 $('body').removeClass('overflow-hidden');
8024 $('#modal-login').removeClass('d-none');
8025 return;
8026 }
8027
8028 var codigoFT = $('[name="codigoFT"]').val();
8029
8030 var unidades = new Set();
8031
8032 var diasSemana = '';
8033
8034 //Senac ao vivo nao tem opçao de dias da semana nem unidades
8035 if(isAoVivo){
8036 unidades.add(codUnidadeSenacAoVivo);
8037 }else{
8038 $.each($('.ssp-week-day').not('#todosDias'), function(k, v){
8039 if($(this).hasClass('ssp-week-day-active')){
8040 diasSemana += $(this).text()+',';
8041 }
8042 });
8043
8044 if(diasSemana.length > 0) diasSemana = diasSemana.slice(0, -1);
8045
8046 $.each($('.ssp-card-registro-interesse__select'), function(k,item){
8047
8048 unidades.add(item.value);
8049 });
8050 }
8051
8052
8053 var periodos = '';
8054
8055 $.each($('.periodos-registro-interesse input[type=checkbox]').not('#check-todos-periodos'), function(k,v){
8056 if($(this).is(':checked')){
8057 periodos += $(this).val()+',';
8058 }
8059 });
8060
8061 var turmas = '';
8062
8063 $.each($('.turmas-registro-interesse input[type=checkbox]').not('#check-todos-periodos'), function(k, v) {
8064 if ($(this).is(':checked')) {
8065 turmas += $(this).val() + ',';
8066 }
8067 });
8068
8069 if (periodos.length > 0) periodos = periodos.slice(0, -1);
8070 if (turmas.length > 0) turmas = turmas.slice(0, -1);
8071
8072 var usuarioNotificado = false;
8073
8074 loadingSubmitButton('#enviar-registro-interesse-btn');
8075
8076 unidades.forEach(function(codigoUnidade) {
8077 var data = {
8078 codigoFT: codigoFT,
8079 codigo: codigoUsr,
8080 diasSemana: diasSemana,
8081 periodos: periodos,
8082 turmas, turmas,
8083 codigoUnidade: codigoUnidade,
8084 interesseBolsa: 'N',
8085 isEmed: isEmed ? 'S' : 'N'
8086 };
8087
8088 const url = urlRegistroInteresse;
8089
8090 $.ajax({
8091 url: url,
8092 method: 'POST',
8093 data: JSON.stringify(data),
8094 headers: {
8095 'Accept': 'application/json',
8096 'Content-Type': 'application/json'
8097 },
8098 }).done(
8099 function(retornoData) {
8100
8101 var retornoData = JSON.stringify(retornoData);
8102
8103 if (retornoData.length > 0) {
8104
8105 cleanLoadingSubmitButton('#enviar-registro-interesse-btn');
8106
8107 var retorno = JSON.parse(retornoData);
8108
8109 if (retorno.status == 200 || retorno.status == 201) {
8110
8111 //Evita que o usuário recebe um email para cada unidade de interesse
8112 if(usuarioNotificado) return;
8113
8114 //Mensagem de sucesso registro interesse
8115 $('#modal-registro-interesse-sucesso').removeClass('d-none');
8116
8117 var prefixUrl = themeDisplay.getLayoutRelativeURL();
8118
8119 if (prefixUrl.indexOf('staging/') > 1)
8120 prefixUrl = prefixUrl.substring(0, prefixUrl.lastIndexOf('staging/') + 8);
8121 else
8122 prefixUrl = HOST;
8123
8124 $('#btn-voltar-home').attr('href', prefixUrl);
8125
8126 //Busca os dados do nome do usuário logado
8127 var username = getCookie('name').split(' ')[0];
8128
8129 //Prioridade para nomeSocial
8130 if (getCookie('nome_social') != null) {
8131 var nomeSocial = getCookie('nome_social').replace(/['"]+/g, '');
8132
8133 if (nomeSocial.length > 0) username = getCookie('nome_social');
8134
8135 }
8136
8137 username = username.replace(/['"]+/g, '');
8138
8139 var unidadesSel = getUnidadesSelecionadasRI();
8140
8141 //Disara um email para o usuário interessado
8142 var data = {
8143 emailInteressado: getCookie('email'),
8144 nomeInteressado: username,
8145 tituloCurso: $('.ssp-card-detalhe-curso__title').text(),
8146 unidades: unidadesSel.unidades,
8147 unidadesPrefix: unidadesSel.unidadesPrefix
8148 };
8149
8150 $.ajax({
8151 url: urlRegistroInteresseEmailInteressado,
8152 method: 'POST',
8153 data: JSON.stringify(data),
8154 headers: {
8155 'Accept': 'application/json',
8156 'Content-Type': 'application/json'
8157 },
8158 }).done(function(retornoData) {});
8159
8160 usuarioNotificado = true;
8161
8162 window.onclick = function(event) {
8163 $('[id="modal-registro-interesse-sucesso"]').each(function(index, _modal) {
8164 if (event.target == _modal){
8165 $('#modal-registro-interesse-sucesso').addClass('d-none');
8166 $('#modal-registro-interesse').addClass('d-none');
8167 $("body").removeClass("overflow-hidden");
8168 }
8169 });
8170 }
8171
8172 } else {
8173 //Mensagem de erro registro interesse
8174 $('#modal-registro-interesse-erro').removeClass('d-none');
8175 }
8176 } else {
8177 //Mensagem de erro registro interesse
8178 $('#modal-registro-interesse-erro').removeClass('d-none');
8179 }
8180 }).fail(function(){
8181 cleanLoadingSubmitButton('#enviar-registro-interesse-btn');
8182 $('#modal-registro-interesse-erro').removeClass('d-none');
8183 });
8184 });
8185 }
8186
8187 function verificaBtnEnviarRegistroInteresseAtivo(){
8188
8189 var diasSemanaSelecionado = false;
8190 var periodoSelecionado = false;
8191 var turmaSelecionada = false;
8192 var politicaPrivacidadeSelecionado = false;
8193
8194
8195 $.each($('.periodos-registro-interesse input[type=checkbox]').not('#check-todos-periodos'), function(k,v){
8196 if($(this).is(':checked'))
8197 periodoSelecionado = true;
8198 });
8199
8200 $.each($('.turmas-registro-interesse input[type=checkbox]').not('#check-todos-periodos'), function(k,v){
8201 if($(this).is(':checked'))
8202 turmaSelecionada = true;
8203 });
8204
8205 if($('#check-politica-privacidade').is(':checked')) politicaPrivacidadeSelecionado = true;
8206
8207 var ativo = true
8208
8209 //Caso tenha algum dos selects de unidade sem uma opção válida selecionada
8210 if(!isAoVivo)
8211 ativo = ativo && !Array.from($('.ssp-card-registro-interesse__select.unidades')).filter(sel => !$(sel).val()).length
8212
8213 ativo = ativo && periodoSelecionado && politicaPrivacidadeSelecionado;
8214
8215 if(!isAoVivo && !isEmed){
8216
8217 $.each($('.ssp-week-day').not('#todosDias'), function(k, v){
8218 if($(this).hasClass('ssp-week-day-active'))
8219 diasSemanaSelecionado = true;
8220 });
8221 ativo = ativo && diasSemanaSelecionado;
8222
8223 }
8224
8225 if(isEmed)
8226 ativo = ativo && turmaSelecionada;
8227
8228 if(ativo)
8229 $('#enviar-registro-interesse-btn').attr("disabled", false);
8230 else
8231 $('#enviar-registro-interesse-btn').attr("disabled", true);
8232 }
8233
8234 function loadPlanoCurso(){
8235
8236 const urlGetPlanoCurso = urlPlanoCurso
8237
8238 .replace('\{codigoFT\}', $('[name="codigoFT"]').val())
8239 .replace('\{dataEfetiva\}', $('[name="dataEfetivaSTR"]').val());
8240
8241 $.ajax({
8242 url:urlGetPlanoCurso,
8243 method:'get',
8244 crossDomain: true,
8245 dataType: 'html',
8246 success: function( data ) {
8247
8248
8249 //Atualiza o link com o plano de curso do servi¿o (ja retorna o texto)
8250 $('#plano-curso').append('<br/>'+data);
8251 },
8252 error: function(data){
8253
8254 console.log('Não existe a URL do plano de curso');
8255
8256 }
8257
8258 });
8259 }
8260
8261 function checkCursoTrampolim(){
8262 return $('[name="codigoFT"]').val() == "24493";
8263 }
8264
8265 /*function verificaOfertaValida(oferta){
8266
8267 if(oferta['precoCheioOferta'] == '' || oferta['precoVendaOferta'] == '' || oferta['numeroMaxParcelasOferta'] == '' || oferta['precoVendaMaxParcelaOferta'] == '')
8268 return false;
8269
8270 var atual = new Date();
8271
8272 var dataOfertaPartes = oferta['dataInicio'].split('/');
8273
8274 var dataOferta = new Date(dataOfertaPartes[2], dataOfertaPartes[1] - 1, dataOfertaPartes[0]);
8275
8276 var dataLimiteMatriculaOfertaPartes = "";
8277 var dataLimiteMatriculaOferta = "";
8278
8279 if(oferta['dtLimiteMatricula'] != ""){
8280 dataLimiteMatriculaOfertaPartes = oferta['dtLimiteMatricula'].split('-');
8281 dataLimiteMatriculaOferta = new Date(dataLimiteMatriculaOfertaPartes[0], dataLimiteMatriculaOfertaPartes[1] - 1, dataLimiteMatriculaOfertaPartes[2] ,atual.getHours(),atual.getMinutes(),atual.getSeconds(),atual.getMilliseconds());
8282
8283 }
8284
8285
8286 //Só deve aparecer ofertas D-1 . Se ela iniciou, aparece se o campo dtLimiteMatr estiver preenchido e com data até o dia de hoje
8287 if(dataOferta <= atual)
8288 if(dataLimiteMatriculaOferta == "" || (dataLimiteMatriculaOferta != "" && atual.getTime() > dataLimiteMatriculaOferta.getTime()))
8289 return false;
8290
8291 return true;
8292 }*/
8293
8294
8295 function loadServerDate(){
8296
8297 $.ajax({
8298 url:urlGetServerT,
8299 method:'get',
8300 dataType: 'json',
8301 cache: 'false',
8302 headers: {
8303 'Cache-Control': 'no-store, no-cache, max-age=0',
8304 'Expires': '0',
8305 'Pragma': 'no-cache'
8306 },
8307 success: function( data ) {
8308 todayG = new Date(data.year,(data.month - 1),data.day,(data.hour),data.minutes,data.seconds);
8309 startTimer();
8310 }
8311 });
8312
8313 }
8314
8315 function handleVisibilityChange() {
8316
8317 if (!document[hidden] ){
8318 restartTimer();
8319 }
8320
8321 }
8322
8323 function restartTimer(){
8324
8325 if(restartTimeout == null){
8326 loadServerDate();
8327 restartTimeout = setTimeout(function(){
8328 restartTimeout = null;
8329 }, 5000);
8330 }
8331
8332 }
8333
8334 function startTimer(){
8335
8336 var mSeconds = todayG.getTime();
8337 if(interval01 != null){
8338 clearInterval(interval01);
8339 }
8340 interval01 = setInterval(function(){
8341 todayG.setTime(todayG.getTime() + 1000);
8342 }, 1000);
8343
8344 if(interval15 != null){
8345 clearInterval(interval15);
8346 }
8347 interval15 = setInterval(function(){
8348 mSeconds = mSeconds + 15000;
8349 todayG.setTime(mSeconds);
8350 }, 15000);
8351
8352 }
8353
8354 function checkIsAoVivo(){
8355 isAoVivo = $("input[name='formato']").attr("data-formato") == nomeFormatoAoVivoDxp;
8356 }
8357
8358
8359 //Ao clicar na setinha next do slider, busca dinamicamente uma proxima oferta
8360 function buscaProximaOferta(){
8361 //Zera variável que controla existência de ofertas com bolsa
8362 //ofertasComBolsa = false;
8363
8364 //Verificamos se a ultima oferta já foi exibida, para evitar de fazer novas buscas
8365 if(carregouUltimaOferta)
8366 return;
8367
8368 //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.
8369 var totalOfertasSlick = $('#turmas-container .slick-area__item').length;
8370 //Pegamos o índice da oferta do meio (central)
8371 var currentSliderIndex = parseInt($('.slick-current').attr('data-slick-index'));
8372
8373 var totalOfertasADireita = totalOfertasSlick - currentSliderIndex;
8374
8375 //Se o total de ofertas à direita for maior a 2 não precisa realizar a busca
8376 if(totalOfertasADireita > 2)
8377 return;
8378
8379 startOfertaParam = endOfertaParam;
8380 endOfertaParam += 16;
8381
8382 const codigoFT = $('[name="codigoFT"]').val();
8383 const dataEfetivaOferta = $('[name="dataEfetivaSTR"]').val();
8384
8385 var unidadeCategoryId = '';
8386 var unidadeCodigoSelect = '';
8387
8388 if(isAoVivo){
8389
8390 $.each(objsTela.unidades, function(k,unidade){
8391 unidadeCategoryId += unidade['categoryId']+',';
8392 });
8393
8394 //tirando ultima virgula
8395 unidadeCategoryId = unidadeCategoryId.substring(0,unidadeCategoryId.length - 1);
8396
8397 }else{
8398 var splitted = $('#unidades-ofertas').val().split("@");
8399 unidadeCategoryId = splitted[0];
8400 unidadeCodigoSelect = splitted[1];
8401 }
8402
8403 var params = new URLSearchParams();
8404 params.set('codigoFTOferta',codigoFT)
8405 params.set('dataEfetivaOferta',dataEfetivaOferta)
8406 params.set('categoryIds',unidadeCategoryId)
8407 params.set('start',startOfertaParam)
8408 params.set('end',endOfertaParam)
8409 params.set('inscricaoAberta', $('#chkInscricao').prop('checked'))
8410 params.set('bolsaAberta', $('#chkBolsa').prop('checked'))
8411 params.set('cursoArticleId', $('[name="articleId"]').val() || '');
8412
8413 if($('#chkBolsa').prop('checked')){
8414 params.set('considerarDataBolsaFutura', true)
8415 }
8416
8417 const url = urlSearchOferta + '?' + params.toString()
8418
8419 $.ajax({
8420 url:url,
8421 method:'get',
8422 dataType:'json'
8423 }).done(
8424 function(data){
8425
8426 if(data.length > 0){
8427 var indiceOferta = startOfertaParam;
8428
8429 for (var index = 0; index < data.length; index++) {
8430
8431 var ofertaJSON = data[index];
8432 var oferta = getOfertaObjectFromJson(ofertaJSON,index);
8433
8434 //Verificamos se a oferta buscada já existe na tela (que ocorre quando chega na última oferta)
8435 if($('.codigoOferta_'+oferta.codigoOferta).length > 0){
8436 console.log('Ja tem a oferta '+oferta.codigoOferta);
8437 carregouUltimaOferta = true;
8438 break;
8439 }
8440
8441 //guardo em um map a oferta e qual unidade é, para utilizar depois no populaOferta para o aoVivo
8442 ofertaUnidadeMap.set(oferta['codigoOferta'],mapUnidadesIds.get(parseInt(ofertaJSON.unidadeCategoryIds)));
8443
8444 ofertasMap.set(oferta.codigoOferta, oferta);
8445
8446 if(isAoVivo)
8447 objsTela.ofertasAoVivoTodasUnidades.push(oferta);
8448
8449 //O indice é igual ao ultimo elemento buscado - 1
8450 var i = indiceOferta;
8451 oferta['indice'] = i;
8452
8453 if(isAoVivo)
8454 codigoUnidade = ofertaUnidadeMap.get(oferta.codigoOferta);
8455 else codigoUnidade = unidadeCodigoSelect;
8456
8457
8458 montaHTMLOferta(oferta, i, codigoUnidade, true);
8459 montaHTMLModalFormaPgto(oferta, i, codigoUnidade);
8460
8461 montaHTMLModalLocalRealizacao(oferta, i);
8462 montaHTMLModalAntesCompra(oferta, i, codigoUnidade);
8463 verificaBotaoBolsaSS(oferta);
8464 verificaCursoAprendizagem(i, oferta.codigoOferta);
8465 verificaCursoTrampolim(i);
8466
8467 associaEventoBtnFormaPagamento(i);
8468 associaEventoBtnComprar(i);
8469 associaEventoBtnComprarDentroFormaPgto(i);
8470 associaEventoBtnLocalRealizacao(i);
8471 associaEventosFecharModal(i);
8472
8473 if($('[name="tipoCurso"]').val() == 'extensao'){
8474 associaEventoBtnConheca(i);
8475 associaEventoBtnComprarConhecaDescontoOk(i);
8476 associaEventoBtnComprarConhecaDescontoNot(i);
8477 associaEventoBtnAlunoNao(i);
8478 associaEventoBtnAlunoSim(i);
8479
8480 }
8481
8482 indiceOferta++;
8483 }
8484
8485 controlaPaginaBolsa();
8486 }
8487 }
8488 );
8489
8490 }
8491
8492 function setUrlParam(key, value) {
8493 const url = new URL(window.location.href)
8494
8495 if(value)
8496 url.searchParams.set(key, value);
8497 else
8498 url.searchParams.delete(key);
8499
8500 window.history.pushState({}, '', url.toString())
8501 }
8502
8503 function selectFilter(paramkey, el) {
8504 setUrlParam(paramkey, el.prop("checked"))
8505 const currentUnidadeFriendlyURLSelected = $('#unidades-ofertas').find('option').filter(':selected').attr('data-unidade-friendly-url')
8506 loadUnidades(!isAoVivo, $('[data-unidade-friendly-url="' + currentUnidadeFriendlyURLSelected + '"]').val())
8507
8508 if($('#chkInscricao').prop("checked") || $('#chkBolsa').prop("checked")) $('#msgFiltroAplicado').show()
8509 else $('#msgFiltroAplicado').hide()
8510 }
8511
8512 function defineCurrentUrl(ev) {
8513 const currentUnidadeFriendlyURLSelected = $(ev.target).find('option').filter(':selected').attr('data-unidade-friendly-url')
8514
8515 const hasPathWeb = window.location.pathname.includes('/web')
8516 const hasPathGuest = window.location.pathname.includes('/guest')
8517
8518 let currentPath = window.location.pathname
8519 currentPath = hasPathWeb ? currentPath.substring(4) : currentPath
8520 currentPath = hasPathGuest ? currentPath.substring(6) : currentPath
8521
8522 objsTela.unidadesRegistroInteresse.forEach(unidade => currentPath = currentPath.replace('/' + unidade.friendlyURL, ''))
8523
8524 currentPath = (currentUnidadeFriendlyURLSelected ? '/' + currentUnidadeFriendlyURLSelected : '') + currentPath
8525 currentPath = hasPathGuest ? '/guest' + currentPath : currentPath
8526 currentPath = hasPathWeb ? '/web' + currentPath : currentPath
8527
8528 if(keepURL())
8529 window.history.replaceState(window.history.state, '', currentPath + window.location.search)
8530 }
8531
8532 let isKeepURL = true
8533 /** Verifica se é para manter a URL atual. Isso deve acontecer somente ao iniciar a página #9674 */
8534 function keepURL() {
8535 const aux = isKeepURL
8536 isKeepURL = false
8537 return !aux
8538 }
8539
8540 loadServerDate();
8541 $(document).ready(function(){
8542
8543 if("${normalizedCategoryName}" == "graduacao" || "${normalizedCategoryName}" == "pos-graduacao"){
8544 document.location.href = '/erro-404'
8545 }
8546
8547 ehCursoTrampolim = checkCursoTrampolim();
8548 checkIsAoVivo();
8549 loadPlanoCurso();
8550 loadCursosVocePodeGostar();
8551 loadPoliticaPrivacidade();
8552
8553 if(!isAoVivo) {
8554 $('#unidades-ofertas').change(ev => {
8555 mudarUnidade(ev)
8556 defineCurrentUrl(ev)
8557 });
8558 }
8559
8560 const urlParams = new URLSearchParams(window.location.search)
8561 $('#chkInscricao').prop("checked", urlParams.get('inscricao') == 'true')
8562 $('#chkInscricao').change(ev => selectFilter('inscricao', $('#chkInscricao')) )
8563
8564 if($('#chkBolsa').length) {
8565 $('#chkBolsa').prop("checked", urlParams.get('bolsa') == 'true')
8566 $('#chkBolsa').change(ev => selectFilter('bolsa', $('#chkBolsa')) )
8567 loadUnidades(!isAoVivo);
8568 } else {
8569 selectFilter('bolsa', $('#chkBolsa'))
8570 }
8571
8572 //Função para Montar breadcrumb Mobile
8573
8574 function breadcrumbMobile(){
8575
8576 const linkEl = $('.ssp-card-detalhe-curso__secunday-info-back-link');
8577
8578 if ( $.trim(linkEl.html()) === 'Técnico'){
8579
8580 linkEl.attr("href", "/cursos-tecnicos");
8581
8582 } else if ( $.trim(linkEl.html()) === 'Livre'){
8583
8584 if(isAoVivo){
8585 linkEl.html('Senac Online<i class="fas fa-signal-stream icon-ao-vivo" aria-hidden="true"></i>ao vivo')
8586 linkEl.attr("href", "/cursos-livres-senac-online-ao-vivo");
8587 }else{
8588 linkEl.attr("href", "/cursos-livres");
8589 }
8590 } else if ( $.trim(linkEl.html()) === 'Aprendizagem'){
8591
8592 linkEl.attr("href", "/jovem-aprendiz");
8593
8594 }else if ( $.trim(linkEl.html()) === 'Extensão Universitária'){
8595
8596 linkEl.attr("href", "/extensao-universitaria");
8597
8598 }else if ( $.trim(linkEl.html()) === 'Ensino Médio Técnico'){
8599
8600 linkEl.attr("href", "/ensino-medio-tecnico");
8601 }
8602
8603 }
8604
8605 breadcrumbMobile()
8606
8607 //Esconde elementos quando o curso é aprendizagem
8608 if($('[name="codigoFT"]').val() == codigoFTCursoAprendizagem){
8609 $('.ssp-section-novas-turmas').remove();
8610 $("div[class^='botoes-oferta-container_']").remove();
8611 }
8612
8613 //retira os itens de dentro do container
8614 $('.bg-').css('background-color','#e4e4e4')
8615 $('.container.py-3').removeClass('container py-3')
8616 //ajuste para versao 7.4
8617 $('.lfr-layout-structure-item-container.container-fluid.container-fluid-max-xl').removeClass()
8618
8619
8620 //Fecha modal registro de interesse
8621
8622 $('#btn-close-Modal-registro-interesse').click(function(){
8623
8624 $('#modal-registro-interesse').addClass('d-none')
8625 $("body").removeClass("overflow-hidden")
8626
8627 })
8628
8629 $( "#modal-registro-interesse" ).click( function(event) {
8630
8631 if(event.target.id==$('#modal-registro-interesse')[0].id){
8632 $(this).addClass('d-none')
8633 }
8634
8635 });
8636
8637
8638 //Aviso sobre interesse em turmas
8639 $('.ssp-card-registro-interesse').on('click', '#enviar-registro-interesse-btn', enviarRegistroInteresse);
8640 if(!isEmed){
8641 $('.ssp-aviso-novas-turmas__content').on('click', '#btn-aviso-novas-turmas', avisoNovasTurmas);
8642 $('.ssp-card-registro-interesse').on('click', '#todosDias', registroSelecionaTodosDias);
8643 } else {
8644 $('.ssp-emed__card-slider-body').on('click', '#btnOptin', avisoNovasTurmas)
8645 }
8646 $('#div-campo-todos').on('change', 'input[type=checkbox]', registroSelecionaTodosPeriodos);
8647
8648 $('#btnLogin').click(function(){
8649
8650 login()
8651
8652 });
8653
8654 $('#btn-close-loginModal').click(function(){
8655 $('#modal-login').addClass('d-none')
8656 });
8657
8658 $('.ssp-week-day').not('#todosDias').click(function(){
8659
8660 $(this).toggleClass('ssp-week-day-active');
8661 verificaBtnEnviarRegistroInteresseAtivo();
8662
8663 });
8664
8665 $('#add-unidade-regsitro-interesse').click(function(e){
8666 var element = $('.ssp-card-registro-interesse__select.unidades').first().clone();
8667 element.empty();
8668 element.append('<option value="" disabled selected>Selecione uma unidade</option>')
8669 $.each(objsTela.unidadesRegistroInteresse, function(k,unidade){
8670
8671 if(!unidade['selecionado']){
8672 element.append('<option value="'+unidade['codigoUnidade']+'">'+unidade['nome']+'</option>');
8673 }
8674
8675 });
8676 element.change(changeSelectUnidades)
8677
8678
8679 element.css('margin-top', '10px');
8680
8681 if(element.find("option").length > 1 && $('.ssp-card-registro-interesse__select.unidades').length < objsTela.unidadesRegistroInteresse.length){
8682 element.attr("id", "select_" + cntSelectUnidades++)
8683 $('#select-unidades-registro-interesse').append(element);
8684 }
8685
8686 if($('.ssp-card-registro-interesse__select.unidades').length == objsTela.unidadesRegistroInteresse.length){
8687 $('#add-unidade-regsitro-interesse').addClass("d-none")
8688 }
8689
8690 verificaBtnEnviarRegistroInteresseAtivo();
8691 });
8692
8693 $('#remove-unidade-regsitro-interesse').click(function(e){
8694
8695 if($('.ssp-card-registro-interesse__select').length > 1){
8696
8697 var element = $('.ssp-card-registro-interesse__select').last();
8698
8699 var valueSelecionado = element.val();
8700
8701 $.each(objsTela.unidadesRegistroInteresse, function(k,unidade){
8702
8703 if(unidade['selecionado'] && unidade['codigoUnidade'] == valueSelecionado){
8704 unidade['selecionado'] = false;
8705 unidade['selectSelecionado'] = "";
8706 }
8707
8708 });
8709 element.val("");
8710 cntSelectUnidades--;
8711 element.change()
8712
8713 element.remove();
8714 }
8715
8716 if($('.ssp-card-registro-interesse__select.unidades').length < objsTela.unidadesRegistroInteresse.length){
8717 $('#add-unidade-regsitro-interesse').removeClass("d-none")
8718 }
8719
8720 verificaBtnEnviarRegistroInteresseAtivo();
8721 })
8722
8723 $('.ssp-card-registro-interesse__check-item').on('change', 'input[type=checkbox]', function(){
8724 verificaBtnEnviarRegistroInteresseAtivo();
8725 });
8726
8727 //Contador em ofertas de bolsas proximas
8728 var cancel = setInterval(atualizaTempoAberturasBolsas, 1000);
8729
8730 // Manipua o breadcrumb para as regras do Senac
8731
8732 if($('ol.breadcrumb').find('li:first').text().trim() == "Cursos Pai")
8733 $('ol.breadcrumb').find('li:first').remove();
8734
8735 var li = $('ol.breadcrumb').find('li:first');
8736
8737 if(li.text().trim() == 'Cursos'){
8738
8739 var primeiro = li.clone();
8740 primeiro.html(htmlBreadcrumb('/', 'Cursos', 'Home'));
8741 li.parent().prepend(primeiro);
8742
8743 var tipoCurso = $('.ssp-header-curso__tag-formato').text().trim();
8744 var tipoBreadcrumb = '';
8745
8746 const isPresencialEad = (tipoCurso.toLowerCase().includes("presencial + ead"))
8747
8748 if(tipoCurso.includes("Cursos Livres")){
8749 if(isPresencialEad) {
8750 tipoBreadcrumb = htmlBreadcrumb('/presencial-ead#cursos-livres', tipoCurso);
8751 } else {
8752 tipoBreadcrumb = htmlBreadcrumb(
8753 isAoVivo ? '/cursos-livres-senac-online-ao-vivo' : '/cursos-livres',
8754 isAoVivo ? nomeFormatoAoVivoDxp : tipoCurso);
8755 }
8756 }else if(tipoCurso.includes("Extensão")){
8757 if(isPresencialEad) {
8758 tipoBreadcrumb = htmlBreadcrumb('/presencial-ead#extensao-universitaria', tipoCurso);
8759 } else {
8760 tipoBreadcrumb = htmlBreadcrumb('/extensao-universitaria', tipoCurso);
8761 }
8762 }else if(tipoCurso.includes("Ensino Médio Técnico")){
8763 if(isPresencialEad) {
8764 tipoBreadcrumb = htmlBreadcrumb('/presencial-ead#ensino-medio-tecnico', tipoCurso);
8765 } else {
8766 tipoBreadcrumb = htmlBreadcrumb('/ensino-medio-tecnico', tipoCurso);
8767 }
8768 }else if(tipoCurso.includes("Jovem Aprendiz")){
8769 if(isPresencialEad) {
8770 tipoBreadcrumb = htmlBreadcrumb('/presencial-ead#jovem-aprendiz', tipoCurso);
8771 } else {
8772 tipoBreadcrumb = htmlBreadcrumb('/jovem-aprendiz', tipoCurso);
8773 }
8774 }else{
8775 if(isPresencialEad) {
8776 tipoBreadcrumb = htmlBreadcrumb('/presencial-ead#cursos-tecnicos', tipoCurso);
8777 } else {
8778 tipoBreadcrumb = htmlBreadcrumb('/cursos-tecnicos', tipoCurso);
8779 }
8780 }
8781
8782 li.html(tipoBreadcrumb);
8783
8784 if($('ol.breadcrumb').find('li').length == 4) $('ol.breadcrumb').find('li:last').remove();
8785
8786 }
8787
8788 $('#turmas-container').on('click', 'a.slick-next', function(e){
8789
8790 e.preventDefault();
8791 buscaProximaOferta();
8792
8793 });
8794
8795 $('#turmas-container').on('click', 'button.slick-dots', function(){
8796
8797
8798
8799 });
8800
8801 $(".next-mobile").on("click",function(e){
8802 e.preventDefault();
8803
8804 acoesMobileSliderOfertas("left");
8805 });
8806
8807 $(".prev-mobile").on("click",function(e){
8808 e.preventDefault();
8809
8810 acoesMobileSliderOfertas("right");
8811 });
8812
8813 //ação de drag do card de ofertas no mobile
8814 $('.oferta-slick-area').on('swipe', function(event, slick, direction){
8815 acoesMobileSliderOfertas(direction);
8816 });
8817
8818 loadAlternadores()
8819 let modalFormAprendizagem = document.querySelector('#modal-form');
8820 if(modalFormAprendizagem){
8821 // Create dinamic close buttom form
8822 let btnCloseModalForm = document.querySelector('[data-modal="close-form-modal"]');
8823 btnCloseModalForm.addEventListener('click',closeModalFormAprendizagem);
8824
8825 }
8826
8827 $(".oferta-slick-area").on("click", ".btnModalAprendizagem",openModalFormAprendizagem);
8828
8829 });
8830
8831 function htmlBreadcrumb(link, title, display){
8832
8833 return '<a class="breadcrumb-link" href="'+link+'" title="'+title+'"><span class="breadcrumb-text-truncate">'+(display || title)+'</span></a>';
8834
8835 }
8836
8837 function acoesMobileSliderOfertas(direcao){
8838
8839 if(direcao == "right"){
8840 $("a.slick-prev").click();
8841
8842 if($('.slick-current').attr('data-slick-index') == "0")
8843 $('.prev-mobile').addClass('nextPrevOpacity');
8844
8845 if($(".next-mobile").hasClass('nextPrevOpacity'))
8846 $('.next-mobile').removeClass('nextPrevOpacity');
8847 }
8848
8849
8850 if(direcao == "left"){
8851 $("a.slick-next").click();
8852
8853 if($(".prev-mobile").hasClass('nextPrevOpacity'))
8854 $('.prev-mobile').removeClass('nextPrevOpacity');
8855
8856 if(carregouUltimaOferta){
8857 var totalCardOfertas = $('#turmas-container .slick-area__item').length;
8858 var currentSliderIndex = parseInt($('.slick-current').attr('data-slick-index'));
8859
8860 //o card do meio é o último
8861 if(totalCardOfertas == (currentSliderIndex + 1))
8862 $('.next-mobile').addClass('nextPrevOpacity');
8863 }
8864 }
8865 }
8866
8867 //habilitar/desabilitar registro de interesse
8868 function habilitarRegistroInteresse(habilitar){
8869 var sectionRI = $('#section-registro-interesse')
8870
8871 if(isEmed) {
8872 sectionRI.hide()
8873 return;
8874 }
8875
8876 //Redmine #9309 - sempre irá mostrar
8877 habilitar = true
8878
8879 if(habilitar) sectionRI.show()
8880 else sectionRI.hide()
8881 }
8882
8883 function abrirModalRegistroInteresse(codUnidadeSelect){
8884 $('#modal-registro-interesse').removeClass('d-none');
8885 $("body").addClass("overflow-hidden")
8886 if(!isEmed){
8887 $('.ssp-card-registro-interesse__nome-curso').text($('.ssp-card-detalhe-curso__title').text());
8888 } else {
8889 $(".transferencia-emed-link").find('a').attr("href", "/ensino-medio-tecnico#onde-estudar")
8890 $('.ssp-card-registro-interesse__title-modal').text($('.ssp-card-detalhe-curso__title').text());
8891 }
8892
8893 $('.ssp-card-registro-interesse__select:not(#select_0)').remove();
8894 $.each(objsTela.unidadesRegistroInteresse, function(k,unidade){
8895 if(unidade['codigoUnidade'] == codUnidadeSelect){
8896 unidade['selecionado'] = true;
8897 unidade['selectSelecionado'] = 'select_0';
8898 } else {
8899 unidade['selecionado'] = false;
8900 unidade['selectSelecionado'] = "";
8901 }
8902
8903 });
8904 objsTela.unidadesRegistroInteresse.sort(function (a, b) {
8905 return ordenar(a, b, 'nome');
8906 });
8907
8908 $('#select_0').empty();
8909 $('#select_0').append('<option value="" disabled>Selecione uma unidade</option>')
8910 $.each(objsTela.unidadesRegistroInteresse, function(k,unidade){
8911
8912 $('#select_0').append('<option value="'+unidade['codigoUnidade']+'" >'+unidade['nome']+'</option>');
8913
8914 });
8915 $('#select_0').val(codUnidadeSelect);
8916
8917 if(isAoVivo){
8918 $('#unidades-registro-interesse, #dias-registro-interesse').addClass('d-none');
8919 }
8920 if(objsTela.unidadesRegistroInteresse.length > 1) {
8921 $('#add-unidade-regsitro-interesse').removeClass("d-none")
8922 $('#add-unidade-regsitro-interesse').show()
8923 $('#remove-unidade-regsitro-interesse').show()
8924 } else {
8925 $('#add-unidade-regsitro-interesse').hide()
8926 $('#remove-unidade-regsitro-interesse').hide()
8927 }
8928 }
8929
8930 $('.ssp-card-registro-interesse__select.unidades').on('change', changeSelectUnidades)
8931
8932 function changeSelectUnidades() {
8933 var codUnidadeSelecionada = $(this).val();
8934 var idSelectSelecionado = $(this).attr('id')
8935 $.each(objsTela.unidadesRegistroInteresse, function(k,unidade){
8936 if(unidade['codigoUnidade'] == codUnidadeSelecionada){
8937 unidade['selecionado'] = true;
8938 unidade['selectSelecionado'] = idSelectSelecionado;
8939 } else if(unidade['selectSelecionado'] == idSelectSelecionado && unidade['selecionado']){
8940 unidade['selecionado'] = false;
8941 unidade['selectSelecionado'] = "";
8942 }
8943
8944 });
8945
8946 objsTela.unidadesRegistroInteresse.sort(function (a, b) {
8947 return ordenar(a, b, 'nome');
8948 });
8949
8950 $('.ssp-card-registro-interesse__select.unidades:not(#'+idSelectSelecionado+')').each(function() {
8951 var valueSelecionado = $(this).val();
8952 var idActualSelect = $(this).attr('id');
8953 $(this).empty();
8954 $(this).append('<option value="" disabled>Selecione uma unidade</option>')
8955 $.each(objsTela.unidadesRegistroInteresse, function(k,unidade){
8956
8957 if(unidade['selecionado'] && unidade['codigoUnidade'] == valueSelecionado){
8958 $("#"+idActualSelect).append('<option value="'+unidade['codigoUnidade']+'" >'+unidade['nome']+'</option>');
8959 }else if(!unidade['selecionado']){
8960 $("#"+idActualSelect).append('<option value="'+unidade['codigoUnidade']+'">'+unidade['nome']+'</option>');
8961 }
8962
8963 });
8964 $(this).val(valueSelecionado)
8965 });
8966
8967 verificaBtnEnviarRegistroInteresseAtivo();
8968 }
8969
8970
8971 function ordenar(objA, objB, nomeAtributo){
8972 let a = (nomeAtributo) ? objA[nomeAtributo] : objA;
8973 let b = (nomeAtributo) ? objB[nomeAtributo] : objB;
8974
8975 return a.toString().localeCompare(b.toString());
8976 }
8977
8978 function paramOrdem(xml){
8979 if(isEmed){
8980 var ordemPeriodo = ['MA', 'TA', 'NO'];
8981 return $.inArray(xml.find('[name="periodoDiaOferta"]').text().trim(), ordemPeriodo);
8982 }else{
8983 return xml.find('[name="dataInicioOferta"]').text();
8984 }
8985 }
8986
8987 function getEtapaSelecionadaEmed(){
8988 var btnEtapa = $('.ssp-ofertas-emed__filtro-content .btn--filtro-ativo');
8989 if(!btnEtapa) return '';
8990 return btnEtapa.val();
8991 }
8992
8993 function filtraOfertasEtapa(etapa, ofertas){
8994 if(!etapa) return [];
8995 var ofertasEtapa = [];
8996 var turmas = ['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J'];
8997 var periodos = {['MA'] : 'Manhã', ['TA'] : 'Tarde', ['NO'] : 'Noite'};
8998 var ultimoPeriodo = null, indexPeriodo;
8999 ofertas = ofertas.sort(function(a, b){
9000 return ordenar(a, b, 'periodoDiaOferta');
9001 });
9002
9003 $.each(ofertas, async (index, oferta)=> {
9004 if(oferta['etapa'] == etapa){
9005 if(oferta['periodoDiaOferta'] != ultimoPeriodo) indexPeriodo = 0;
9006 ultimoPeriodo = oferta['periodoDiaOferta'];
9007 oferta['titulo'] = 'Turma ' + turmas[indexPeriodo++] + ' - ' + (periodos[ultimoPeriodo] || '');
9008 ofertasEtapa.push(oferta);
9009 }
9010 });
9011
9012 return ofertasEtapa;
9013 }
9014
9015 function formatarDataEmed(data, etapa, isDataFim){
9016
9017 try{
9018
9019 var splitdata = data.split('/');
9020 var meses = ['Janeiro', 'Fevereiro', 'Março', 'Abril', 'Maio', 'Junho', 'Julho', 'Agosto', 'Setembro', 'Outubro', 'Novembro', 'Dezembro'];
9021 var mes = meses[parseInt(splitdata[1])-1];
9022
9023 var ano = splitdata[2];
9024
9025 if(isDataFim){
9026 ano = parseInt(splitdata[2]);
9027 }
9028
9029 return mes + '/' + ano;
9030 }catch(err){
9031 return data;
9032 }
9033
9034 }
9035
9036 //EMED Mobile
9037 function sliderOfertasEmed(){
9038
9039 var tamScreen = $(window).width();
9040 if(tamScreen < 1024){
9041 $('.ssp-slick-ofertas-emed').slick({
9042 slidesToShow: 1,
9043 slidesToScroll: 1,
9044 dots: false,
9045 infinite: false,
9046 adaptiveHeight: true,
9047 prevArrow:'<button class="btn slick-prev" type="button"><i class="fal fa-chevron-left"></i><span class="sr-only">Anterior</span></button>',
9048 nextArrow:'<button class="btn slick-next" type="button"><i class="fal fa-chevron-right"></i><span class="sr-only">Próximo</span></button>',
9049 responsive: [
9050
9051 {
9052 breakpoint: 1200,
9053 settings: {
9054 slidesToShow: 1,
9055 slidesToScroll: 1,
9056 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>',
9057 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>',
9058
9059 }
9060 },
9061 {
9062 breakpoint: 768,
9063 settings: {
9064 slidesToShow: 1,
9065 slidesToScroll: 1,
9066 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>',
9067 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>',
9068 }
9069 }
9070
9071 ]
9072
9073 });
9074
9075 }
9076
9077 }
9078
9079function addItemBackpack(codOferta, originElemSelector, codUnidade, dataEfetiva){
9080
9081 let backpackPostRequest = {};
9082 backpackPostRequest.codOferta = codOferta;
9083 backpackPostRequest.codUnidade = codUnidade;
9084 backpackPostRequest.dt_efetiva = dataEfetiva;
9085
9086
9087 mochila.requestAccess(function(backpackPostRequest){
9088
9089 let urlMochila = '/o/senac-backpack-services/backpack';
9090
9091 if(getCookie("codMochila") != null){
9092 backpackPostRequest.codMochila = getCookie("codMochila");
9093 urlMochila = '/o/senac-backpack-services/updateBackpack';
9094 }
9095 $.ajax({
9096 type: 'POST',
9097 url: urlMochila,
9098 headers: {
9099 "Content-Type":"application/json"
9100 },
9101 beforeSend: function(xhr){
9102 xhr.setRequestHeader("Authorization", "Bearer " + getCookie("tokenMochila"));
9103 loadingSubmitButton(originElemSelector);
9104 $(originElemSelector + ' .loading-icon-button').css('height', 'unset');
9105 if($(window).width() < 1024){
9106 $(originElemSelector + ' .loading-icon-button span').css('margin-left', '10%');
9107 }
9108 },
9109 data : JSON.stringify(backpackPostRequest)
9110 }).done(function(data) {
9111
9112 let domain = '';
9113 if(getAmbiente() == 'hom' || getAmbiente() == 'prod')
9114 domain = '.sp.senac.br';
9115
9116 writeCookie(
9117 'codMochila',
9118 (getCookie("codMochila") == null) ? data.backpackCode : JSON.parse(data).backpackCode,
9119 24,
9120 domain
9121 );
9122 addItemSuccessMochila();
9123
9124 }).fail(function(xhr, status, error) {
9125
9126 $('#modal-backpack-error').removeClass('d-none');
9127
9128 }).always(function(){
9129
9130 cleanLoadingSubmitButton(
9131 originElemSelector,
9132 originElemSelector.indexOf('backpack') > 0 ? 'OK, desejo comprar' : 'COMPRAR'
9133 );
9134 $('[id^="modalAntesCompra_"]').each(function(index, modal) {
9135 modal.style.display = "none";
9136 });
9137
9138 });
9139
9140 }, backpackPostRequest);
9141
9142}
9143
9144function componentBuyConfirmation(codigoUnidade, oferta, dataEfetiva){
9145
9146 var comp = null;
9147
9148 if((oferta.destinoCompra !== null) && oferta.destinoCompra == "2" && !excecaoCursoGratuito(oferta)){
9149
9150 comp = $("<button>")
9151 .addClass("btn btn-lg btn-success w-100 mt-3 btn-backpack")
9152 .attr("offerCode",oferta.codigoOferta)
9153 .attr("unitCode",codigoUnidade)
9154 .attr("effectiveDate",dataEfetiva)
9155 .text("OK, desejo comprar");
9156
9157 }else {
9158 var textoBotaoConfirmacao = "OK, desejo comprar";
9159
9160 if(excecaoCursoGratuito(oferta))
9161 textoBotaoConfirmacao = "Ok, desejo fazer a matrícula";
9162
9163 comp = $("<a>")
9164 .addClass("btn btn-lg btn-success w-100 mt-3")
9165 .text(textoBotaoConfirmacao)
9166 .attr("href", linkBotaoCompra.replace('\{codigoUnidade\}', codigoUnidade).replace('\{codigoOferta\}', oferta.codigoOferta))
9167 .attr("target","_blank");
9168 }
9169
9170 comp.attr('id', 'btnCompraLocal_' + oferta.indice);
9171
9172 return comp[0].outerHTML;
9173
9174}
9175
9176function getUnidadesSelecionadasRI(){
9177 var unidadesRI = [];
9178
9179 try{
9180
9181 $('#select-unidades-registro-interesse').find('select').each((i,select) =>{
9182 var unidadeSel = select.selectedOptions[0].innerText;
9183 if(!unidadesRI.includes(unidadeSel)) unidadesRI.push(unidadeSel);
9184 });
9185
9186 var unidadesExt = unidadesRI.join(', ');
9187
9188 const lastIndex = unidadesExt.lastIndexOf(',');
9189
9190 if(lastIndex > 0) unidadesExt = unidadesExt.substring(0, lastIndex) + ' ou ' + unidadesExt.substring(lastIndex + 1);
9191
9192 return {
9193 'unidadesPrefix' : (unidadesRI.length > 1 ? ', nas unidades ' : (unidadesRI.length == 1 ? ', na unidade ' : '')),
9194 'unidades' : unidadesExt
9195 };
9196
9197 }catch(err){
9198
9199 return {
9200 'unidadesPrefix' : '',
9201 'unidades' : ''
9202 };
9203
9204 }
9205
9206 }
9207
9208
9209
9210
9211function addItemSuccessMochila(){
9212
9213 mochila.check();
9214 $('#modal-backpack-success__nome-curso').html($('.ssp-card-detalhe-curso__title').text());
9215 $('#modal-backpack-success').removeClass('d-none');
9216
9217}
9218
9219$(document).on('click', '.btn-backpack', function(e){
9220
9221 addItemBackpack(event.target.getAttribute("offerCode"), '.btn-backpack',event.target.getAttribute("unitCode"),event.target.getAttribute("effectiveDate"));
9222
9223});
9224
9225$('#btn-voltar-modal-backpack-error').click(function () {
9226 $('#modal-backpack-error').addClass('d-none');
9227});
9228
9229$('#btn-voltar-modal-backpack-error').click(function () {
9230 $('#modal-backpack-error').addClass('d-none');
9231});
9232
9233$('.btn-mochila-continuar-site-success, .modal-btn-close').click(function () {
9234 $('#modal-backpack-success').addClass('d-none');
9235});
9236
9237$('.btn-mochila-finalizar-compra-success').click(function () {
9238 // Montar object push - google tag manager - 6
9239 sendEventEcommerce("begin_checkout", ofertaSelecionada);
9240
9241 mochila.verificaLogin();
9242 $('#modal-backpack-success').addClass('d-none');
9243 $('[id^="myModal_"]').each((i,modal)=>modal.style.display = "none");
9244});
9245
9246 function closeModalFormAprendizagem(){
9247 let modal = document.querySelector('#modal-form');
9248 modal.close();
9249 }
9250
9251
9252 function openModalFormAprendizagem(ev){
9253
9254 const $container = document.getElementById('modal-form');
9255 if(!$container || !$container.nodeName == 'DIALOG') return;
9256
9257 const ofertaSel = ofertasMap.get(ev.target.getAttribute('data-codigo-oferta'));
9258
9259 function getUnidadeSelecionada() {
9260 const categoryUnidade = $('#unidades-ofertas').val().split('@')[0];
9261 return objsTela.unidades.find(u => u.categoryId == categoryUnidade) || {};
9262 }
9263
9264 async function request(url, { method = 'GET', headers = {}, body, beforeSend } = {}) {
9265 const init = { method, headers, body, credentials: 'same-origin' };
9266 const resp = await fetch(url, init);
9267 if (!resp.ok) throw new Error('Erro status ' + resp.status);
9268 return resp.text();
9269 }
9270
9271 async function loadHTMLForm () {
9272
9273 if($container.querySelectorAll('form').length) {
9274 FormControl.changeCursoInfo(ofertaSel, getUnidadeSelecionada());
9275 return;
9276 }
9277
9278 const url = Liferay.ThemeDisplay.getPortalURL().concat('/documents/d/global/html-formulario-aprendizagem?cb=' + Date.now());
9279
9280 const formHTML = await request(url);
9281
9282 $container.innerHTML += formHTML;
9283
9284 let script = document.createElement('script');
9285 script.src = '/documents/d/global/js-aprendizagem-formulario';
9286 script.async = true;
9287
9288 script.onload = () => {
9289 console.log(`script loaded successfully.`);
9290 init(ofertaSel, getUnidadeSelecionada());
9291 };
9292
9293 script.onerror = () => {
9294 console.error(`Error loading script`);
9295 };
9296
9297 document.head.appendChild(script);
9298
9299 }
9300
9301 loadHTMLForm();
9302
9303 $container.showModal();
9304
9305 }
9306
9307 function addEventBolsa() {
9308 // Mostra o preco
9309 const btnShowPrices = document.querySelectorAll('.btn-show-price')
9310
9311 btnShowPrices.forEach(btnShowPrice => btnShowPrice.addEventListener('click',togglePriceCard))
9312
9313 if(!$('#chkBolsa').prop('checked'))
9314 togglePriceCard()
9315 }
9316
9317 function togglePriceCard(selector){
9318 if(selector instanceof PointerEvent) return
9319
9320 if(!selector) selector = ''
9321 else selector = '.' + selector
9322
9323 const btnPrices = document.querySelectorAll('.show-price-content'+selector)
9324 const contentPrices = document.querySelectorAll('.content-valores-descontos'+selector)
9325 const contentBtnBolsas = document.querySelectorAll('.content-btn-bolsa'+selector)
9326
9327 btnPrices.forEach(btnPrice => btnPrice.classList.toggle('hide'))
9328 contentBtnBolsas.forEach(contentBtnBolsa => contentBtnBolsa.classList.toggle('modifier-content-show'))
9329 contentPrices.forEach(contentPrice => contentPrice.classList.toggle('hide-price'))
9330 }
9331
9332 function getRegiaoName(key) {
9333 switch (key) {
9334 case "C":
9335 return "Capital";
9336 case "I":
9337 return "Interior";
9338 case "GS":
9339 return "Grande São Paulo e Litoral";
9340 default:
9341 return "Sem Região";
9342 }
9343 }
9344
9345 function criarOptionUnidadesPorRegiao(unidades) {
9346 let regioes = {}
9347 let unidadeFounded
9348
9349 unidades.forEach(unidade => {
9350 if(!regioes[unidade.codRegiaoUnidade || 'N'])
9351 regioes[unidade.codRegiaoUnidade || 'N'] = []
9352
9353 regioes[unidade.codRegiaoUnidade || 'N'].push(unidade)
9354 })
9355
9356 Array.from(['C', 'I', 'GS', 'N'])
9357 .filter(key => Object.keys(regioes).includes(key))
9358 .forEach(key => {
9359 const unidadesDaRegiao = regioes[key]
9360
9361 const optionDisabled = $('<option>')
9362 optionDisabled.attr('label', getRegiaoName(key))
9363 optionDisabled.text(getRegiaoName(key));
9364 optionDisabled.attr('disabled', true)
9365 optionDisabled.addClass('ssp-option-group')
9366 $('#unidades-ofertas').append(optionDisabled)
9367
9368 $.each(unidadesDaRegiao, function(k,unidade){
9369 if($('#unidades-ofertas').find('[value="'+unidade['categoryId']+'"]').length == 0){
9370 var option = $('<option>');
9371 option.val(unidade['categoryId']+"@"+unidade['codigoUnidade']);
9372 option.text(unidade['nome']);
9373 option.attr('data-unidade-friendly-url', unidade.friendlyURL)
9374 option.addClass('ssp-option')
9375
9376 $('#unidades-ofertas').append(option);
9377
9378 unidadeFounded = !unidadeFounded && getURLData().includes('/'+unidade.friendlyURL+'/') ? unidade : unidadeFounded
9379 }
9380 })
9381 })
9382
9383 return unidadeFounded
9384 }
9385
9386 function getURLData() {
9387 return URLGeral.replace(HOST, '')
9388 }
9389
9390 /**
9391 * Copia um objeto JSON
9392 */
9393 function cloneObj(original) {
9394 return JSON.parse(JSON.stringify(original));
9395 }
9396
9397 function getUrlConsultaBolsa(oferta){
9398
9399 let url = '';
9400 if (isAmbienteTeste()) {
9401 if(oferta.destinoBolsa=='1') {
9402 url = 'https://hwse.sp.senac.br/rest/wss/cursos/bolsa/v1/?COD_EVENTO='+oferta.codigoOferta
9403 } else {
9404 url = 'https://hom-wse-bolsas.sp.senac.br/api/cursos/bolsa/v1/'+oferta.codigoOferta;
9405 }
9406 } else {
9407 if(oferta.destinoBolsa=='1') {
9408 url = 'https://wse.sp.senac.br/rest/wss/cursos/bolsa/v1/?COD_EVENTO='+oferta.codigoOferta
9409 } else {
9410 url = 'https://wse-bolsas.sp.senac.br/api/cursos/bolsa/v1/'+oferta.codigoOferta;
9411 }
9412
9413 }
9414
9415 return url;
9416 }
9417
9418 function execCompraEmed(oferta){
9419 let linkInscricaoEmed = '', linkInscricaoEmedHml = '';
9420 if(oferta.etapa == '0010'){
9421 linkInscricaoEmed = 'https://www.sp.senac.br/login/Login?destino=https://inscricao-educacional-ms.sp.senac.br/?oferta={codOferta}';
9422 linkInscricaoEmedHml = 'https://gesportal.sp.senac.br/login/Login?destino=https://hinscricao-educacional-backend.sp.senac.br/?oferta={codOferta}';
9423 }
9424
9425 var ambTeste = ['localhost', 'hom', 'dev'];
9426 var link = linkInscricaoEmed;
9427 $.each(ambTeste, function(i, a){
9428 if(location.hostname.indexOf(a) >= 0){
9429 link = linkInscricaoEmedHml;
9430 return false;
9431 }
9432 });
9433
9434 // Montar object push - google tag manager - 3
9435 ofertaSelecionada = itensEcommerce.get(oferta.codigoOferta)
9436 sendEventEcommerce("select_item", ofertaSelecionada);
9437 sendEventEcommerce("view_item", ofertaSelecionada);
9438 sendEventEcommerce("add_to_cart", ofertaSelecionada);
9439 sendEventEcommerce("begin_checkout", ofertaSelecionada);
9440
9441 var urlCompra = link.replace('\{codOferta\}', oferta.codigoOferta);
9442 window.open(urlCompra, '_blank');
9443 }
9444
9445 function formataDataComBarra(dataInvertidaComTraco){
9446 return dataInvertidaComTraco.split('-').reverse().join('/');
9447 }
9448
9449
9450 let ctrlPressed = false;
9451 $(window).keydown(function (ev) {
9452 if(ev.which == 17){
9453 ctrlPressed = true;
9454 return false;
9455 }
9456 if(ev.which == 82 && ctrlPressed){
9457 return false;
9458 }
9459 return (ev.which != 116); // F5
9460 }).keyup(function(ev) {
9461 if (ev.which == 17){
9462 ctrlPressed = false;
9463 }
9464 return true;
9465 });
9466
9467
9468 </script>
9469
9470</#if>