function buildUrl() {
    var url = $('input[name="BaseUrl"]').val();
    for (var item in arguments) {
        url += arguments[item] + "/";
    }
    return url;
}

$("#form-alterar-senha").on("submit", function (e) {
    e.preventDefault();


    $(this).ajaxSubmit({
        url: buildUrl("conta", "alterar_senha"),
        type: "POST",
        dataType: "json",
        beforeSubmit: function () {
            $("#form-alterar-senha").modal("hide");
        },
        success: function (response) {
            notify(response[0], response[1]);
            if (response[0] === "success") {
                setTimeout(function () {
                    location.reload();
                }, 1500);
            } else {
                $("#form-alterar-senha").modal("show");
            }
        },
    });
});

$(document).on("click", ".btn-show-password", function () {
    var botao = $(this);
    var input = $(this).siblings();

    $.each(input, function (item, value) {
        if (value.type === "password") {
            input.attr("type", "text");
            botao.html("Ocultar");
        } else if (value.type === "text") {
            input.attr("type", "password");
            botao.html("Mostrar");
        }
    });
});

function load(tipo) {
    if (tipo == "open") {
        $("#modal-load").modal("show");
        $(".btn").attr("disable", true);
    }

    if (tipo == "close") {
        setTimeout(function () {
            $("#modal-load").modal("hide");
            $(".btn").attr("disable", false);
        }, 300);
    }
}

function MascaraValor(value) {
    let valor = value;

    valor = valor.toString().replace(/\D/g, "");
    valor = valor.toString().replace(/(\d)(\d{8})$/, "$1.$2");
    valor = valor.toString().replace(/(\d)(\d{5})$/, "$1.$2");
    valor = valor.toString().replace(/(\d)(\d{2})$/, "$1,$2");

    return valor;
}

function notify(type, text, title) {
    if (type === 'success') {
        $.gritter.add({
            title: "Ok!",
            text: text,
            class_name: 'gritter-success',
            time: 2500
        });
    } else if (type === 'error') {
        $.gritter.add({
            title: "Ops!",
            text: text,
            class_name: 'gritter-error',
            time: 2500
        });
    } else {
        $.gritter.add({
            title: "Atenção!",
            text: text,
            class_name: 'gritter-warning',
            time: 2500
        });
    }
}

function MascaraMoeda(objTextBox, SeparadorMilesimo, SeparadorDecimal, e) {
    var sep = 0;
    var key = "";
    var i = (j = 0);
    var len = (len2 = 0);
    var strCheck = "0123456789";
    var aux = (aux2 = "");
    var whichCode = window.Event ? e.which : e.keyCode;

    if (whichCode == 13 || whichCode == 8 || whichCode == 0) return true;
    key = String.fromCharCode(whichCode); // Valor para o código da Chave
    if (strCheck.indexOf(key) == -1) return false; // Chave inválida
    len = objTextBox.value.length;
    for (i = 0; i < len; i++)
        if (
            objTextBox.value.charAt(i) != "0" &&
            objTextBox.value.charAt(i) != SeparadorDecimal
        )
            break;
    aux = "";
    for (; i < len; i++)
        if (strCheck.indexOf(objTextBox.value.charAt(i)) != -1)
            aux += objTextBox.value.charAt(i);
    aux += key;
    len = aux.length;
    if (len == 0) objTextBox.value = "";
    if (len == 1) objTextBox.value = "0" + SeparadorDecimal + "0" + aux;
    if (len == 2) objTextBox.value = "0" + SeparadorDecimal + aux;
    if (len > 2) {
        aux2 = "";
        for (j = 0, i = len - 3; i >= 0; i--) {
            if (j == 3) {
                aux2 += SeparadorMilesimo;
                j = 0;
            }
            aux2 += aux.charAt(i);
            j++;
        }
        objTextBox.value = "";
        len2 = aux2.length;
        for (i = len2 - 1; i >= 0; i--) objTextBox.value += aux2.charAt(i);
        objTextBox.value += SeparadorDecimal + aux.substr(len - 2, len);
    }
    return false;
}

function numberToReal(numero = 0.00) {
    if (numero == 0) {
        numero = 0.00;
    }

    var numero = numero.toFixed(2).split(".");

    numero[0] = numero[0].split(/(?=(?:...)*$)/).join(".");
    return numero.join(",");
}

function maskMoney(number) {
    numeral.locale('en');
    let value = numeral(number ? number : 0.0).value();
    return numeral(value).format('0,0.00');
}

function getObjectFromArray(data) {
    var index = [];
    var length = Object.keys(data).length;

    if (length > 0) {
        for (var i = 1; i <= length; i++) {
            index.push(data[i]);
        }
    }

    return index;
}

function soNumero(string) {
    return string.replace(/[^0-9]/g, "");
}

function busca_cep(cep) {
    $.get("https://viacep.com.br/ws/" + cep + "/json/", function (response) {

        if (response.erro) {
            notify("error", "Não foi possível encontrar os dados de endereço pelo CEP.");
            return false;
        }

        busca_estado(response.uf);
        busca_cidades(response.localidade, response.uf);

        $("#Logradouro").val(response.logradouro);
        $("#Bairro").val(response.bairro);
        $("#Numero").focus();

    }, "json");
}

function busca_cep_evento(cep) {
    $.get("https://viacep.com.br/ws/" + cep + "/json/", function (response) {

        if (response.erro) {
            notify("error", "Não foi possível encontrar os dados de endereço pelo CEP.");
            return false;
        }

        busca_estado_evento(response.uf);
        busca_cidades_evento(response.localidade);

        $("#LogradouroEvento").val(response.logradouro);
        $("#BairroEvento").val(response.bairro);
        $("#NumeroEvento").focus();

    }, "json");
}

function busca_estado_evento(uf) {
    $.get(buildUrl("estados", "find") + uf, function (response) {
        $("#EstadosIdEvento").val(response[1]["Id"]);
    }, "json");
}

function busca_cidades_evento(cidade) {
    $.get(buildUrl("cidades", "find") + cidade, function (response) {
        $("#CidadesIdEvento").val(response[1]["Id"]);
    }, "json");
}

function busca_estado(uf) {
    $.get(buildUrl("estados", "find") + uf, function (response) {
        $("#EstadosId").val(response[1]["Id"]).select2();
    }, "json");
}

function busca_cidades(cidade, estado) {
    $.get(buildUrl("cidades", "find", cidade, estado), function (response) {
        $("#CidadesId").val(response[1]["Id"]).select2();
    }, "json");
}

//Recebe os campos que para faze a busca e setor os valores
function busca_cepGenerico(cep, estado, cidade, logradouro, bairro, numero, complemento = null) {
    $.get("https://viacep.com.br/ws/" + cep + "/json/", function (dados) {
        const estadoEl = $("#" + estado);
        const cidadeEl = $("#" + cidade);
        const logradouroEl = $("#" + logradouro);
        const bairroEl = $("#" + bairro);
        const numeroEl = $("#" + numero);

        if (dados.erro) {
            // liberar e limpar campos
            estadoEl.val("").select2().attr('readonly', false);
            cidadeEl.html(`<option selected value="">- Selecione -</option>`).select2().attr('readonly', false);
            logradouroEl.val("").attr('readonly', false);
            bairroEl.val("").attr('readonly', false);
            numeroEl.val("").attr('readonly', false);

            if (complemento) {
                $('#' + complemento).val("").attr('readonly', false);
            }

            notify("error", "Não foi possível encontrar os dados de endereço pelo CEP.");
            return false;
        }

        $.get(buildUrl("Estados", "find") + dados.uf, function (response) {
            estadoEl.val(response[1]["Id"]).select2();
            if (estadoEl.data('select2')) {
                estadoEl.select2('destroy');
            }
            estadoEl.attr('readonly', true);

            $.get(buildUrl("Cidades", "getCidades") + response[1]["Id"], function (response) {
                let option = "";

                $.each(response, function (item, value) {
                    const selected = value.Nome.replace("'", "").toLowerCase() === dados.localidade.replace("'", "").toLowerCase() ? ' selected="" ' : '';
                    option += `<option ${selected} value="${value.Id}">${value.Nome}</option>`;
                });

                cidadeEl.html(option);

                if (cidadeEl.data('select2')) {
                    cidadeEl.select2('destroy');
                }

                cidadeEl.attr('readonly', true);
            }, "json");
        }, "json");

        logradouroEl.val(dados.logradouro);
        bairroEl.val(dados.bairro);
        numeroEl.focus();
    }, "json");
}

function busca_cidades_estado(estadoId, campoCidade) {
    $("#" + campoCidade).html('<option values="">Carregando...</option>');
    load("open");
    $.get(buildUrl("ConsultoresPublic", "getCidades") + estadoId, function (response) {
        var option = `<option value="">- Selecione um estado -</option>`;

        if (response.erro) {
            $(`#${campoCidade}`).html(option);
            load("close");
            return
        }

        $.each(response, function (item, value) {
            option += '<option value="' + value.Id + '">' + value.Nome + "</option>";
        });

        $("#" + campoCidade).html(option);
        load("close");
    }, "json");
}

function retiraApostrofo() {

    $('.retiraApostrofo').on('keyup', function (e) {
        var digitado = $(this).val();
        var replaced = '';

        if (e.keyCode == 192) {
            notify("error", "Apóstrofo não é permitido!");
            replaced = digitado.replace(/´|`/g, '');
            replaced = digitado.replace("'", '');
            $(this).val(replaced);
        }
    });

}

function moneyBr(value) {
    return Intl.NumberFormat("pt-BR", {
        style: "currency",
        currency: "BRL",
    }).format(value);
}

function createCookie(name, value, days) {
    var expires;

    if (days) {
        var date = new Date();
        date.setTime(date.getTime() + days * 24 * 60 * 60 * 1000);
        expires = "; expires=" + date.toGMTString();
    } else {
        expires = "";
    }

    document.cookie = name + "=" + value + expires + "; path=/";
}

function getCookie(c_name) {
    if (document.cookie.length > 0) {
        c_start = document.cookie.indexOf(c_name + "=");
        if (c_start != -1) {
            c_start = c_start + c_name.length + 1;
            c_end = document.cookie.indexOf(";", c_start);
            if (c_end == -1) {
                c_end = document.cookie.length;
            }
            return unescape(document.cookie.substring(c_start, c_end));
        }
    }
    return "";
}

function clearCookie(name) {
    createCookie(name, "", -1);
}

/**
 * @method Verificar se a variavel esta Nula ou Vazia
 * @param {*} variable
 */
function isEmpty(variable) {
    if (!variable || 0 === variable.length) return "";
    return variable;
}

$(document).on("click", ".btn-password", function () {
    let btn = $(this);
    let input = btn.siblings();
    $.each(input, function (item, value) {
        if (value.type === "password") {
            input.attr("type", "text");
            btn.html(
                '  <div class="input-group-text"><i class="fa fa-eye-slash" title="Mostrar senha" aria-hidden="true"></i></div>'
            );
        } else if (value.type === "text") {
            input.attr("type", "password");
            btn.html(
                '  <div class="input-group-text"><i class="fa fa-eye" title="Ocultar senha" aria-hidden="true"></i></div>'
            );
        }
    });
});

/**
 * Função para criar um Datatables com server-side
 * @string url | Onde será feita a consulta
 * @string typeUrl | POST, GET
 * @array buttonsWanted | PDF, EXCEL, CSV, COPY, COLVIS
 * @string formId | Id do formulário para filtros e transformar seus inputs e campos de busca externo
 * @string tableId | Id da tabela para aplicar o datatables
 * @array columnsWanted | Colunas da tabela HTML
 */
var makeDatatables = function (
    url,
    typeUrl,
    buttonsWanted,
    formId,
    tableId,
    columnsWanted
) {
    var buttonsStandard = [
        //Paginação
        {
            extend: "pageLength",
            collectionLayout: "two-column",
        },
    ];
    var buttonsOptionals = {
        //EXCEL
        EXCEL: {
            extend: "excel",
            text: '<i class="fas fa-file-excel"></i>',
            titleAttr: "Gerar Excel",
            header: true,
            title: "Plamev - Gerenciador",
            autoFilter: true,
            sheetName: "Relatório Colaboradores",
            exportOptions: {
                columns: ":visible",
                search: "applied",
                order: "applied",
                format: {
                    body: function (data, row, column, node) {
                        //data = data.replace( /[$,.]/g, '' )
                        //data = data.replace(/(&nbsp;|<([^>]+)>)/ig, "")
                        data = data.replace(/<.*?>/gi, "");
                        return data.replace(/<br\s*\/?>/gi, "\n");
                    },
                },
            },
        },
        //PDF
        PDF: {
            extend: "pdfHtml5",
            text: '<i class="far fa-file-pdf"></i>',
            titleAttr: "Gerar PDF",
            orientation: "landscape",
            pageSize: "A4",
            header: true,
            footer: true,
            title: "Relatório Colaboradores",
            messageTop: "Plamev - Gerenciador",
            download: "open",
            exportOptions: {
                columns: ":visible",
                search: "applied",
                order: "applied",
                stripNewlines: false,
            },
            customize: function (doc) {
                doc.pageMargins = [20, 60, 20, 30];
                doc.defaultStyle.fontSize = 12;
                doc.styles.tableHeader.fontSize = 14;
                doc["styles"] = {
                    userTable: {
                        margin: [0, 15, 0, 15],
                    },
                    title: {
                        color: "black",
                        fontSize: "20",
                        alignment: "center",
                    },
                    tableHeader: {
                        bold: !0,
                        fontSize: 15,
                        color: "white",
                        padding: "5px",
                        fillColor: "#3366CC",
                        alignment: "center",
                    },
                };
                /*doc.content.splice( 1, 0, {
                            margin: [ 0, 0, 0, 0 ],
                            alignment: 'center',
                            image: ''
                        } );*/
            },
        },
        //PRINT
        PRINT: {
            extend: "print",
            text: '<i class="fas fa-print corrige-fas"></i>',
            titleAttr: "Imprimir",
            header: true,
            title: "Relatório MEEP",
            messageTop: "Dados exportados do relatório Relatório MEEP",
            orientation: "landscape",
            customize: function (doc) {
                $(doc.document.body)
                    .css("font-size", "15pt")
                    .prepend
                    //'<img src="#" style="position:absolute; top:0; left:0;" />'
                    ();
                $(doc.document.body)
                    .find("table")
                    .addClass("compact")
                    .css("font-size", "inherit");
            },
            exportOptions: {
                columns: ":visible",
                search: "applied",
                order: "applied",
            },
        },
        //CSV
        CSV: {
            extend: "csv",
            text: '<i class="fas fa-file-excel"></i>',
            titleAttr: "Gerar CSV",
            header: true,
            title: "Relatório MEEP",
            exportOptions: {
                columns: ":visible",
                search: "applied",
                order: "applied",
            },
        },
        //COPIAR
        COPY: {
            extend: "copy",
            text: '<i class="far fa-copy"></i>',
            titleAttr: "Copiar",
            header: true,
            title: "Relatório MEEP",
        },
        //Ocultar colunas
        COLVIS: {
            extend: "colvis",
            text: '<i class="fas fa-eye-slash"></i>',
            titleAttr: "Ocultar colunas",
            collectionLayout: "two-column",
        },
    };
    var columnsStandard = [
        {
            data: "action",
            name: "action",
            orderable: false,
            searchable: false,
            class: "text-center",
        },
    ];

    for (let i = 0; i < buttonsWanted.length; i++) {
        if (typeof buttonsOptionals[buttonsWanted[i]] !== "undefined") {
            buttonsStandard.push(buttonsOptionals[buttonsWanted[i]]);
        }
    }

    for (let j = 0; j < columnsWanted.length; j++) {
        columnsStandard.push(columnsWanted[j]);
    }
    reorderArray(columnsStandard, 0, columnsStandard.length);

    var table = $("#" + tableId).DataTable({
        processing: true,
        serverSide: true,
        ordering: false,
        colReorder: false,
        rowReorder: false,
        stateSave: false,
        select: false,
        dom: "Brftip",
        lengthMenu: [
            [10, 25, 50, -1],
            [10, 25, 50, "Todos"],
        ],
        language: {
            url: "public/plugins/DataTables-1.10.24/pt-br.json",
        },
        buttons: buttonsStandard,
        ajax: {
            url: url,
            type: typeUrl,
            data: function (d) {
                if (formId !== "") {
                    $.each($("input, select, textarea", "#" + formId), function (k, v) {
                        if (v.type !== "radio" && v.type !== "checkbox") {
                            if (v.value != "") {
                                d[v.name] = v.value;
                            }
                        } else {
                            d[v.name] = $("input[name=" + v.name + "]:checked").val();
                        }
                    });
                }
            },
        },
        columns: columnsStandard,
        initComplete: function () {
            $(".dt-buttons > button").addClass("shadow2");
            /*$(".dataTables_filter > label > input").click(function() {
                      $('#' + formId).trigger("reset")
                  })*/
        },
    });

    if (formId !== "") {
        $("#" + formId).on("submit", function (e) {
            e.preventDefault();
            table.draw();
        });

        $("#" + formId).click(function () {
            $(".dataTables_filter > label > input").val("");
        });
    }
};

/**
 * Função para reordenar array
 * @param arr
 * @param from
 * @param to
 */
var reorderArray = function (arr, from, to) {
    if (Object.prototype.toString.call(arr) !== "[object Array]") {
        throw new Error("Por favor, insira um array válido");
    }

    // Remover o item de sua posição original, salvando em uma variável temporária
    var item = arr.splice(from, 1);

    // Verificar se tem mesmo um item
    if (!item.length) {
        throw new Error(
            "Item na posição " + from + " não encontrado no array fornecido."
        );
    }

    // Adiciona o item na nova posição
    arr.splice(to, 0, item[0]);
};

/**
 * Setar menu lateral como ativo
 * @param url
 */
function setActive() {
    let url = window.location.href
    let hasBackslash = url.substr(-1, 1)
    let positionBackslash = 0

    //Verificar se a url termina com uma /. Se sim, remove a mesma
    if (hasBackslash === "/") {
        positionBackslash = url.lastIndexOf(hasBackslash) //Posição da barra final
        url = url.substr(0, positionBackslash) //Remontar a url, sem a barra final
    }

    let urlSemInterrogacao = url.split("?");
    let aUrl = urlSemInterrogacao[0].split("/")
    if ((aUrl[2] === "localhost") || (aUrl[2] === "projetos")) {
        url = `${aUrl[0]}\/\/${aUrl[2]}/${aUrl[3]}/${aUrl[4]}`;
    } else {
        url = `${aUrl[0]}\/\/${aUrl[2]}/${aUrl[3]}`;
    }

    let filho = $(`a[href='${url}']`).attr("id") //Pegar o id do elemento <a> que possui a url acessada

    if (!filho) {
        $(`#dashboard_menu`).parents().eq(0).addClass("active");
    } else {
        const id = filho.split('_');
        if (id[1] === 'menu') {
            $(`#${filho}`).parents().eq(0).addClass("active");
        } else if (id[1] === 'submenu') {
            $(`#${filho}`).parents().eq(0).addClass("active");
            $(`#${filho}`).parents().eq(2).addClass("active");
        } else if (id[1] === 'subsubmenu') {
            $(`#${filho}`).parents().eq(0).addClass("active");
            $(`#${filho}`).parents().eq(2).addClass("active");
            $(`#${filho}`).parents().eq(4).addClass("active");
        }
    }
}

/**
 * Remover a classe de erro no campo no click do botao
 * @param field
 */
function removeErrorClick(campo) {
    $(`#${campo}`).parents().eq(0).removeClass("has-error");
}

function isInt(n) {
    return Number(n) === n && n % 1 === 0;
}

function isFloat(n) {
    return Number(n) === n && n % 1 !== 0;
}

//VERIFICA SE HA CARACTERES ESPECIAIS NO EVENT PASSADO
function checkChar(e) {
    var char = String.fromCharCode(e.keyCode);

    var pattern = '[a-zA-Z0-9]';
    if (char.match(pattern)) {
        return true;
    }
}

$(document).ready(function () {
    //Remover as classes de erro de campos obrigatórios não preenchidos
    $("input").keyup(function () {
        var id = $(this).attr("id");

        removeErrorClick(id);
    });

    //Remover caractetes especiais de inputs selecionados com a classe noEspecialChar
    $('.noEspecialChar').on('keypress', function (e) {
        if (!checkChar(e)) {
            e.preventDefault();
        }
    });

    $("select").change(function () {
        var id = $(this).attr("id");

        removeErrorClick(id);
    });

    $("radio").click(function () {
        var id = $(this).attr("id");

        removeErrorClick(id);
    });

    $("checkbox").click(function () {
        var id = $(this).attr("id");

        removeErrorClick(id);
    });
    //Analisar radio com style

    $("textarea").keyup(function () {
        var id = $(this).attr("id");

        removeErrorClick(id);
    });
    //Analisar o textarea com ckeditor
});

if ($('.select-checkbox').length > 0) {
    $('.select-checkbox').multipleSelect({filter: true});
}

// PARSLEY VALIDATOR
function validaFormParsley(validator) {
    if (!validator.isValid()) {
        load("close");
        // - INICIO - Ajusta mensagem de erro para select2
        let divSelect2El = $(document).find('.select2.select2-container.select2-container--default:visible').parent();
        $.each(divSelect2El, function (i, v) {
            let ul = $(v).find('> ul');
            if (ul.length > 0) {
                let select2 = $(v).find('> span');
                ul.insertAfter(select2)
                select2.find('.select2-selection--single').attr('style', 'border-color: #DC3545FF !important');
            }
        });
        // - FIM - Ajusta mensagem de erro para select2
        return false;
    }
}

window.Parsley.on('field:error', function (fieldInstance) {
    let arrErrorMsg = fieldInstance.getErrorsMessages();
    let errorMsg = arrErrorMsg.join(';');
    let nome = fieldInstance.$element.attr('name');
    nome = nome.replace('[]', '');
    notify('error', `${nome} - ${errorMsg} `);
});

function geraAutoComplete(classe, rota = '', min = 3, seletor = '') {
    let elemento = seletor || `.${classe}`;

    $(document).find(`${elemento}-autocomplete`).select2({
        placeholder: '- Selecione -',
        minimumInputLength: min,
        language: 'pt-BR',
        width: "100%",
        allowClear: true,
        ajax: {
            url: buildUrl(`${rota}`),
            data: function (params) {
                return {
                    termoPesquisa: params.term
                };
            }
        }
    });
}

$(document).on('click', '.btn-search-with-loading', function (e) {
    e.preventDefault();
    const $button = $(this);

    $button.prop('disabled', true).html('<i class="fa fa-spinner fa-spin"></i> Pesquisando...');
    $button.closest('form')[0].submit();

    $(window).on('load', function () {
        $button.prop('disabled', false).html('<i class="fas fa-search"></i> Pesquisar');

    });
});