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