<!DOCTYPE html>
<html>
<head>
    <meta content="width=device-width" name="viewport"/>
    <title>Fitlog Table</title>
    <!--<link rel="shortcut icon" href="#" />-->
    <link href="/table.ico" rel="shortcut icon">

    <link href="/static/css/bootstrap.css" rel="stylesheet"/>
    <link href="/static/css/bootstrap-table.css" rel="stylesheet"/>
    <link href="/static/css/bootstrap-table-filter-control.css" rel="stylesheet"/>
    <link href="/static/css/table.css" rel="stylesheet"/>

    <script src="/static/js/jquery.min.js"></script>
    <script src="/static/js/bootstrap.js"></script>
    <script src="/static/js/bootstrap-editable.js"></script>
    <script src="/static/js/bootstrap-table.js"></script>
    <script src="/static/js/bootbox.js"></script>
    <script src="/static/js/bootstrap-table-editable.js"></script>
    <script src="/static/js/jquery.tablednd.js"></script>
    <script src="/static/js/bootstrap-table-reorder-rows.js"></script>

    <script src="/static/js/tableExport.js"></script>
    <script src="/static/js/bootstrap-table-export.js"></script>
    <script src="/static/js/clone.js"></script>
    <script src="/static/js/table.js"></script>
    <script src="/static/js/table_page_utils.js"></script>
    <script src="/static/js/utils.js"></script>
    <script src="/static/js/bootstrap-table-filter-control.js"></script>
    <script src="/static/js/Sortable.js"></script>

    <style>
        .alert {
            display: none;
            position: fixed;
            top: 50%;
            left: 50%;
            min-width: 300px;
            max-width: 600px;
            transform: translate(-50%, -50%);
            z-index: 99999;
            text-align: center;
            padding: 15px;
            border-radius: 3px;
        }

        .alert-success {
            color: #31708f;
            background-color: #d9edf7;
            border-color: #bce8f1;
        }

        .alert-info {
            color: #3c763d;
            background-color: #dff0d8;
            border-color: #d6e9c6;
        }

        .alert-warning {
            color: #8a6d3b;
            background-color: #fcf8e3;
            border-color: #faebcc;
        }

        .alert-danger {
            color: #a94442;
            background-color: #f2dede;
            border-color: #ebccd1;
        }


    </style>
    <script src="../static/js/table_page_utils.js"></script>
    <script>
        $(function () {
            /*初始化setting选项
                window.settings: json包含所有的设置选项
                window.column_order: nested json, 包含的是column的顺序
                window.column_dict: 2级json，key为header的名称，value是一个json包含这个header的设置. 用于设置header的，不包含
                    不变的column。如果为底层header(与每一个row的值是对应，可以通过是否包含field判断)
                window.hidden_columns: json, 包含被隐藏的column的名称。
                window.table_data: 2级json，是一个json，key为id，value是一行的内容，为一个一层json对象
                window.server_uuid: str, 当前这个页面的uuid
                window.hidden_rows: json，当前隐藏的row
                window.max_compare_metrics, int表示最多可以对比多少
                window.column_order_updated: bool, 当前是否更新了column_order,用于判断是否需要向服务器发送更新
                window.hidden_columns_updated: bool, 是否更新了隐藏column，用于向服务器发送更新
                window.unchanged_columns: json, 值永远都恒定的column。
                window.save_config_name: str, 保存当前的setting到哪个文件。
            */
            window.settings = {};

            //0. 从后台获取必要的数据，然后用于创建Table
            $.ajax({
                url: '/table/table',
                type: 'GET',
                dataType: 'json',

                data: {},
                success: function (value) {
                    // 新加的column只能往后加，否则会出现hidden的时候顺序乱掉。
                    var column_dict = value['column_dict'];
                    var column_order = value['column_order'];
                    var settings = value['settings'];
                    var hidden_columns = value['hidden_columns'];
                    column_dict = processData(column_dict);

                    for (var setting in settings) {
                        window.settings[setting] = settings[setting];
                    }
                    // refine columns
                    window.column_order = column_order;
                    window.column_dict = column_dict;
                    window.hidden_columns = hidden_columns;
                    window.table_data = value['data']; // 是一个json，key为id，value是一行的内容，为一个一层json对象
                    window.server_uuid = value['uuid'];
                    window.hidden_rows = value['hidden_rows'];
                    window.max_compare_metrics = value['max_compare_metrics']; //最多可以对比的log数量
                    window.column_order_updated = false;
                    window.hidden_columns_updated = false;
                    window.unchanged_columns = value['unchanged_columns'];
                    window.save_config_name = value['log_config_name'];
                    initalizeTable();
                    // 如果unchanged_columns不为空，则使得button可见，否则不可见
                    if ($.isEmptyObject(window.unchanged_columns)) {
                        document.getElementById('consistent_cols').style.visibility = 'hidden';
                    } else {
                        document.getElementById('consistent_cols').style.visibility = 'visible';
                    }
                },
                error: function (error) {
                    bootbox.alert("Some error happens when initialize table.");
                    console.log(error);
                }
            });
        });

    </script>
</head>
<body>

<div class="btn-group" id="toolbar" style="margin-left: 20px">
    <button class="btn btn-danger" disabled id="delete" style="margin-right: 5px">
        <i class="glyphicon glyphicon-remove"></i> Delete
    </button>
    <button class="btn btn-warning" disabled id="hide" style="margin-left: 5px;margin-right: 5px" type="button">
        <i class="glyphicon glyphicon-eye-close"></i> Hide
    </button>
    <button class="btn btn-success" disabled id="display" style="margin-left: 5px;margin-right: 5px" type="button">
        <i class="glyphicon glyphicon-eye-open"></i> Display
    </button>
    <button class="btn btn-default" id="checkInvert" style="margin-left: 5px;margin-right: 5px;
                background: #dca7a7;" type="button">
        <i class="glyphicon glyphicon-retweet"></i> InvertCheck
    </button>
    <button class="btn btn-default" id="clearCheck" style="margin-left: 5px;margin-right: 5px;
                background: #dca7a7;" type="button">
        <i class="glyphicon glyphicon-remove-circle"></i> ClearCheck
    </button>
    <!--model button, choose columns-->
    <button class="btn btn-primary" data-target="#columns_box" data-toggle="modal" id="choose_columns"
            style="margin-left: 5px;margin-right: 5px" type="button">
        <i class="glyphicon glyphicon-th icon-th"></i> Columns
    </button>

    <!--setting-->
    <button class="btn btn-info" data-target="#setting_box" data-toggle="modal" id="setting"
            style="margin-left: 5px;margin-right: 5px" type="button">
        <i class="glyphicon glyphicon-option-horizontal"></i> Setting
    </button>

    <!--consisten columns-->
    <button class="btn btn-default" data-target="#unchanged_columns_box" data-toggle="modal" id="consistent_cols"
            style="margin-left: 5px;margin-right: 5px" type="button">
        <i class="glyphicon glyphicon-th-list"></i> Con. cols.
    </button>

</div>

<!--setting Modal -->
<div aria-hidden="true" aria-labelledby="myModalLabel" class="modal fade" id="setting_box" role="dialog" style="font-size: 18px"
     tabindex="-1">
    <div class="modal-dialog">
        <div class="modal-content">
            <div class="modal-header">
                <button aria-label="Close" class="close" data-dismiss="modal" type="button"><span aria-hidden="true">&times;</span></button>
                <h4 class="modal-title" id="myModalLabel">Settings</h4>
            </div>
            <div class="modal-body " id="setting_div">

            </div>
            <div class="modal-footer">
                <button class="btn btn-default" data-dismiss="modal" id="setting_cancel" type="button">Cancel</button>
                <button class="btn btn-primary" id="setting_confirm" type="button">Confirm</button>
            </div>
        </div>
    </div>
</div>

<!--columns modal-->
<div aria-hidden="true" aria-labelledby="myModalLabel" class="modal fade" id="columns_box" role="dialog" style="font-size: 16px"
     tabindex="-1">
    <div class="modal-dialog modal-lg">
        <div class="modal-content">
            <div class="modal-header">
                <button aria-label="Close" class="close" data-dismiss="modal" type="button"><span aria-hidden="true">&times;</span></button>
                <h4 class="modal-title">Columns(uncheck to hide, drag to reorder)</h4>
            </div>
            <div class="modal-body" id="columns_dialogue">

            </div>
            <div class="modal-footer">
                <button class="btn btn-default" data-dismiss="modal" id="cancel_columns" type="button">Cancel</button>
                <button class="btn btn-primary" id="confirm_columns" type="button">Confirm</button>
            </div>
        </div>
    </div>
</div>

<!--Add a row-->
<div aria-hidden="true" aria-labelledby="myModalLabel" class="modal fade" id="row_box" role="dialog" style="font-size: 16px"
     tabindex="-1">
    <div class="modal-dialog modal-lg">
        <div class="modal-content">
            <div class="modal-header">
                <button aria-label="Close" class="close" data-dismiss="modal" type="button"><span aria-hidden="true">&times;</span></button>
                <h4 class="modal-title">Add a row</h4>
            </div>
            <div class="modal-body" id="add_row_dialogue">

            </div>
            <div class="modal-footer">
                <button class="btn btn-default" id="cancel_add_row" type="button">Cancel</button>
                <button class="btn btn-primary" id="confirm_add_row" type="button">Confirm</button>
            </div>
        </div>
    </div>
</div>

<!--statistics-->
<div aria-hidden="true" aria-labelledby="myModalLabel" class="modal fade" id="stats_box" role="dialog" style="font-size: 16px"
     tabindex="-1">
    <div class="modal-dialog modal-lg">
        <div class="modal-content">
            <div class="modal-header">
                <button aria-label="Close" class="close" data-dismiss="modal" type="button"><span aria-hidden="true">&times;</span></button>
                <h4 class="modal-title">Statistics of metrics</h4>
            </div>
            <div class="modal-body" id="stats_dialogue">

            </div>
            <div class="modal-footer">
                <button class="btn btn-default" id="cancel_stats" type="button">Cancel</button>
                <button class="btn btn-primary" id="confirm_stats" type="button">Add avg row</button>
                <button class="btn btn-primary" id="confirm_max_stats" type="button">Add max row</button>
                <button class="btn btn-primary" id="confirm_min_stats" type="button">Add min row</button>
            </div>
        </div>
    </div>
</div>

<!--View multiple metric-->
<div aria-hidden="true" aria-labelledby="myModalLabel" class="modal fade" id="compare_metric_box" role="dialog" style="font-size: 16px"
     tabindex="-1">
    <div class="modal-dialog">
        <div class="modal-content">
            <div class="modal-header">
                <button aria-label="Close" class="close" data-dismiss="modal" type="button"><span aria-hidden="true">&times;</span></button>
                <h4 class="modal-title">Choose metric to compare</h4>
            </div>
            <div class="modal-body" id="compare_metric_modal">

            </div>
            <div class="modal-footer">
                <button class="btn btn-default" id="cancel_compare_metric" type="button">Cancel</button>
                <button class="btn btn-primary" id="confirm_compare_metric" type="button">Confirm</button>
            </div>
        </div>
    </div>
</div>

<!--consistent_columns-->
<div aria-hidden="true" aria-labelledby="myModalLabel" class="modal fade" id="unchanged_columns_box" role="dialog" style="font-size: 18px"
     tabindex="-1">
    <div class="modal-dialog">
        <div class="modal-content">
            <div class="modal-header">
                <button aria-label="Close" class="close" data-dismiss="modal" type="button"><span aria-hidden="true">&times;</span></button>
                <h4 class="modal-title">The following columns have consistent value.</h4>
            </div>
            <div class="modal-body" id="unchanged_column_modal">

            </div>
            <div class="modal-footer">
            </div>
        </div>
    </div>
</div>

<!--config selection-->
<div aria-hidden="true" aria-labelledby="myModalLabel" class="modal fade" id="config_box" role="dialog" style="font-size: 16px"
     tabindex="-1">
    <div class="modal-dialog">
        <div class="modal-content">
            <div class="modal-header">
                <button aria-label="Close" class="close" data-dismiss="modal" type="button"><span aria-hidden="true">&times;</span></button>
                <h4 class="modal-title">Select a config</h4>
            </div>
            <div class="modal-body" id="change_config_dialogue">

            </div>
            <div class="modal-footer">
                <button class="btn btn-default" id="cancel_change_config" type="button">Cancel</button>
                <button class="btn btn-default" id="delete_config" type="button">Delete</button>
                <button class="btn btn-primary" id="confirm_change_config" type="button">Change</button>
            </div>
        </div>
    </div>
</div>

{# style="overflow-x: auto; max-width: 90%; margin-left: 5%; margin-right: 5%"#}
<div style="padding-left:15px; padding-right:15px">
    <table id="tb_departments"></table>
</div>

</body>

<script>
    const $delete = $('#delete');
    const $hide = $('#hide');
    const $table = $('#tb_departments');
    const $display = $('#display');
    const $checkInvert = $('#checkInvert');
    const $setting = $('#setting');
    const $setting_confirm = $('#setting_confirm');
    const $choose_columns = $('#choose_columns');
    const $confirm_columns = $('#confirm_columns');
    const $confirm_add_row = $('#confirm_add_row');
    const $cancel_add_row = $('#cancel_add_row');
    const $config_change_config = $('#confirm_change_config');
    const $cancel_change_config = $('#cancel_change_config');
    const $delete_config = $('#delete_config');
    const $cancel_stats = $('#cancel_stats');
    const $confirm_stats = $('#confirm_stats');
    const $cancel_compare_metric = $('#cancel_compare_metric');
    const $confirm_compare_metric = $('#confirm_compare_metric');

    var col_sortables = [];

    // 点击setting
    $setting.click(function () {
        const settings = window.settings;
        const $div = $("#setting_div");
        for (const setting in settings) {
            let checked;
            checked = settings[setting];
            if (setting === 'Offline' && checked) {
                continue; // 不允许再次修改Offline为Online
            }
            if (checked) {
                checked = 'checked'
            } else {
                checked = ""
            }
            $div.append("<div class=\"page__toggle\" style=\"padding: 0 0;margin: 0 0\">\n" +
                "                                      <label class=\"toggle\" style=\"margin-bottom: 0\">\n" +
                "                                        <input class=\"toggle__input\"" +
                checked + " name='setting-check-box'  type=\"checkbox\" id='" + setting + "'>\n" +
                "                                        <span class=\"toggle__label\">\n" +
                "                                          <span class=\"toggle__text\">" + setting + "</span>\n" +
                "                                        </span>\n" +
                "                                      </label>\n" +
                "                                    </div>");
        }
        $div.append('<div class="page__toggle" style="padding: 0 0;margin: 0 0">' +
            '<label class="toggle" style="margin-bottom: 0">' +
            '<span class="toggle__text">Save config name: </span>' +
            '<input type="text" name="config_name" id="config_name_input" value="' + window.save_config_name + '">' +
            '</label>' +
            '</div>')

    });
    //点击reorder columns
    $choose_columns.click(function () {
        generate_sortable_columns(window.column_order, window.column_dict, window.hidden_columns, $("#columns_dialogue"));
        const nestedSortables = [].slice.call(document.querySelectorAll('.nested-sortable'));

        col_sortables = [];
        for (let i = 0; i < nestedSortables.length; i++) {
            col_sortables.push(new Sortable(nestedSortables[i], {
                group: {
                    'name': nestedSortables[i].getAttribute('id'),
                    'pull': false,
                    'put': false
                },
                animation: 150,
                fallbackOnBody: true,
                swapThreshold: 0.65,
                dataIdAttr: 'title'
            }));
        }
        //检查是否所有的checkbox都已经正确运行了
        check_checkbox_valid($("#choose_column_nested"));

        // 触发column的点击
        $('input').change(function () {
            const $cb = $(this);
            if ($cb[0].getAttribute('id') === 'choose_column_checkbox') {
                const $group_item = $cb.closest('.list-group-item');
                const state = $cb.prop('checked');
                change_children_state($group_item, state);
                change_parent_state($group_item, state);
            }
        });
    });

    //点击con. cols.
    $("#consistent_cols").click(function () {
        const unchanged_columns = window.unchanged_columns;
        for (const key in unchanged_columns) {
            const value = unchanged_columns[key];
            $("#unchanged_column_modal").append("<div class=\"pretty p-default\" " +
                "style='min-width:20px;margin-left: 5px;margin-right: 5px;'>" +
                "<div class='state p-primary'><label>" + key + ": " + value + "</label></div></div>");
        }
    });

    //setting确认
    $setting_confirm.click(function () {
        const config_name = document.getElementById('config_name_input');
        if (!config_name.value.endsWith('.cfg')) {
            bootbox.alert("config name has to end with .cfg");
            return
        }
        if (config_name.value !== window.save_config_name) {
            update_config_name(config_name.value);
        }

        const checkboxes = document.getElementsByName('setting-check-box');
        const checkbox_json = {};
        checkboxes.forEach(function (element, index, array) {
            checkbox_json[element.getAttribute('id')] = element.checked;
        });
        let update = false;
        let update_to_server = false;
        for (const setting in checkbox_json) {
            if ((setting === 'Pagination' && (window.settings[setting] !== checkbox_json[setting]))) {
                update = true;
                window.settings['Pagination'] = checkbox_json[setting];
            } else if ((setting === 'Wrap display' && (window.settings[setting] !== checkbox_json[setting]))) {
                update = true;
                window.settings['Wrap display'] = checkbox_json[setting];
            } else if ((setting === 'Reorderable rows' && (window.settings[setting] !== checkbox_json[setting]))) {
                update = true;
                window.settings['Reorderable rows'] = checkbox_json[setting];
            } else if (window.settings[setting] !== checkbox_json[setting]) {
                window.settings[setting] = checkbox_json[setting];
                update_to_server = true;
            }
        }
        $("#setting_box").modal('hide');
        if (update) {
            initalizeTable();
        }

        if (update_to_server || update)
            update_settings(window.settings);
    });

    // add a row确认
    $confirm_add_row.click(function () {
        // 获取所有的input
        var inputs = document.getElementsByName('input_row');
        var row = {};
        var index;
        for (index = 0; index < inputs.length; index++) {
            var input = inputs[index];
            if (input.value !== undefined && input.value !== '') {
                if (input.id === 'id') {
                    row[input.id] = input.value.replace('/\s/g', '_') + '_' + generate_uuid();
                } else {
                    row[input.id] = input.value;
                }
            }
        }
        // check id是否为空
        if (!('id' in row)) {
            bootbox.alert("`id` cannot be empty.");
        } else {
            // 不能是已经有的id
            if (row['id'] in window.table_data) {
                bootbox.alert("Duplicated `id`.")
            } else {
                if (Object.keys(row).length === 1) {
                    bootbox.alert("Only has `id` is not allowed.")
                } else {
                    add_a_row(row);
                    $("#row_box").modal('hide');
                }
            }
        }
    });

    $cancel_add_row.click(function () {
        $("#row_box").modal('hide');
    });

    $cancel_compare_metric.click(function () {
        $("#compare_metric_box").modal('hide');
    });
    $confirm_compare_metric.click(function () {
        var checkboxes = document.getElementsByName('compare-metric-check-box');
        var chosen_metric = [];
        checkboxes.forEach(function (element, index, array) {
            if (element.checked) {
                chosen_metric.push(element.getAttribute('id'));
            }
        });
        if (chosen_metric.length > 0) {
            jump_to_multi_chart(chosen_metric);
            $("#compare_metric_box").modal('hide');
        } else {
            bootbox.alert("You have to choose at least one metric.")
        }
    });

    // 确认切换config
    $config_change_config.click(function () {
        var value = $("input:radio:checked").val();
        if (!(value === window.save_config_name)) {
            bootbox.confirm("This will reload this page, make sure you have saved your settings.", function (result) {
                if (result) {
                    $.ajax({
                        url: '/table/change_config',
                        type: 'POST',
                        dataType: 'json',
                        contentType: 'application/json;charset=UTF-8',
                        data: JSON.stringify({
                            uuid: window.server_uuid,
                            config_name: value
                        }),
                        success: function (value) {
                            var status = value['status'];
                            if (status === 'success') {
                                $('#config_box').modal('hide');
                                window.location.reload();
                            } else {
                                bootbox.alert(value['msg']);
                            }
                        },
                        error: function (error) {
                            bootbox.alert("Some error happens. Fail to change config file.");
                        }
                    })
                }
            })
        }
        $('#config_box').modal('hide');
    });

    $cancel_change_config.click(function () {
        $('#config_box').modal('hide');
    });

    $delete_config.click(function () {
        var config_name = $("input:radio:checked").val();
        if (config_name === window.save_config_name) {
            bootbox.alert("Cannot delete the config being used.")
        } else {
            bootbox.confirm("This will delete this config, go on?", function (result) {
                if (result) {
                    $.ajax({
                        url: '/table/delete_config',
                        type: 'POST',
                        dataType: 'json',
                        contentType: 'application/json;charset=UTF-8',
                        data: JSON.stringify({
                            uuid: window.server_uuid,
                            config_name: config_name
                        }),
                        success: function (value) {
                            var status = value['status'];
                            if (status === 'success') {
                                $("input:radio:checked").parent().parent().remove();
                                $("input:radio[name='config'][value='" + window.save_config_name + "']").click();
                                success_prompt(config_name + ' has been deleted.');
                            } else {
                                bootbox.alert(value['msg']);
                            }
                        },
                        error: function (error) {
                            bootbox.alert("Some error happens. Fail to change config file.");
                        }
                    })
                }
            })
        }
    });

    // 确认选择columns
    $confirm_columns.click(function () {
        var $nested = $("#choose_column_nested");
        var new_column_order = get_new_column_order($nested, window.column_order);
        var new_hidden_columns = window.hidden_columns;
        get_new_hidden_columns($nested, new_hidden_columns, '');

        $("#columns_box").modal('hide');
        // 更新columns
        if (window.column_order_updated) {
            window.column_order = new_column_order;
            update_column_order(new_column_order);
        }
        if (window.hidden_columns_updated) {
            window.hidden_columns = new_hidden_columns;
            update_hidden_columns(new_hidden_columns);
        }

        if (window.column_order_updated || window.hidden_columns_updated) {
            initalizeTable();
        }
        window.column_order_updated = false;
        window.hidden_columns_updated = false;

        for (let i = 0; i < col_sortables.length; i++) {
            const sortable = col_sortables.pop();
            sortable.destroy();
        }
    });

    function add_calculate_stats_to_table(method) {
        let value;
        const row = {};
        row['id'] = 'stats_avg_' + generate_uuid();
        const metric_names = getJsonKeys(window.row_stats['stats']); // metric_names就是metric的名称; 每个metric对应着自己的值
        for (let index = 0; index < metric_names.length; index++) {
            value = window.row_stats['stats'][metric_names[index]];
            if (!(method in value)) {
                bootbox.alert(method + " value is not found for " + metric_names[index] + '.');
                $('#stats_box').modal('hide');
                return;
            } else
                row[metric_names[index]] = value[method];
        }
        for (const key in window.row_stats['invariant_values']) {
            value = window.row_stats['invariant_values'][key];
            row[key] = value;
        }

        // add a memo to specify components
        row['memo'] = method + ' from ' + window.row_stats['ids'].join(', ');
        window.row_stats = null;
        add_a_row(row);

        $('#stats_box').modal('hide');
    }

    $confirm_stats.click(function () {
        add_calculate_stats_to_table('avg')
    });
    $('#confirm_max_stats').click(function () {
        add_calculate_stats_to_table('max')
    });
    $('#confirm_min_stats').click(function () {
        add_calculate_stats_to_table('min')
    });

    $cancel_stats.click(function () {
        $('#stats_box').modal('hide');
    });

    // 清除内容
    $("#columns_box").on('hide.bs.modal', function (e) {
        $("#columns_dialogue").empty();
    });
    $("#setting_box").on('hide.bs.modal', function (e) {
        $("#setting_div").empty();
    });
    $("#unchanged_columns_box").on('hide.bs.modal', function (e) {
        $("#unchanged_column_modal").empty();
    });
    $("#row_box").on('hide.bs.modal', function (e) {
        $("#add_row_dialogue").empty();
    });
    $("#config_box").on('hide.bs.modal', function (e) {
        $("#change_config_dialogue").empty();
    });
    $('#stats_box').on('hide.bs.modal', function (e) {
        $("#stats_dialogue").empty();
    });
    $('#compare_metric_box').on('hide.bs.modal', function (e) {
        $('#compare_metric_modal').empty();
    });

    // 当前选中的row的id
    function getIdSelections() {
        return $.map($table.bootstrapTable('getSelections'), function (row) {
            return row.id
        })
    }

    // 是否运行点击相应的按钮
    $table.on('check.bs.table uncheck.bs.table ' +
        'check-all.bs.table uncheck-all.bs.table',
        function () {
            $delete.prop('disabled', !$table.bootstrapTable('getSelections').length);
            $hide.prop('disabled', !$table.bootstrapTable('getSelections').length);
        });

    //点击delete
    $delete.click(function () {
        var ids = getIdSelections();
        var msg = 'Delete ' + '<span style="color: red;font-weight: bold;">' +
            ids.length + '</span> rows with id=' + JSON.stringify(ids) + '`delete` only make' +
            ' them invisible in current setting; `erase` will delete them from disk.';
        bootbox.deleteConfirm(msg, function (result) {
            if (!window.settings['Offline']) {
                if (result === 1) {
                    $.ajax({
                        url: '/table/delete_records',
                        type: 'POST',
                        dataType: 'json',
                        contentType: 'application/json;charset=UTF-8',
                        data: JSON.stringify({
                            ids: ids,
                            uuid: window.server_uuid
                        }),
                        success: function (value) {
                            //delete success.
                            $table.bootstrapTable('remove', {
                                field: 'id',
                                values: ids
                            });
                            for (var index = 0; index < ids.length; index++)
                                delete window.table_data[ids[index]];
                            $delete.prop('disabled', true);
                            $hide.prop('disabled', true);
                            if (value['status'] === 'fail') {
                                warning_prompt("Delete in front-page, but not update to the server.", 2000);
                            } else {
                                success_prompt("Deletion succeed.", 1500);
                            }

                        },
                        error: function (error) {
                            bootbox.alert("Fail to execute deletion, please delete in server.")
                        }
                    })
                }
                if (result === 2) {// erase
                    $.ajax({
                        url: '/table/erase_records',
                        type: 'POST',
                        dataType: 'json',
                        contentType: 'application/json;charset=UTF-8',
                        data: JSON.stringify({
                            ids: ids,
                            uuid: window.server_uuid
                        }),
                        success: function (value) {
                            //delete success.
                            $table.bootstrapTable('remove', {
                                field: 'id',
                                values: ids
                            });
                            for (var index = 0; index < ids.length; index++)
                                delete window.table_data[ids[index]];
                            $delete.prop('disabled', true);
                            $hide.prop('disabled', true);
                            if (value['status'] === 'fail') {
                                var fail_ids = value['msg'];
                                bootbox.alert("Fail to erase: " + JSON.stringify(fail_ids) + " from disk.");
                            } else {
                                success_prompt("Erase succeed.", 1500);
                            }

                        },
                        error: function (error) {
                            bootbox.alert("Fail to execute erase, please erase in server.")
                        }
                    })
                }
            } else {
                $table.bootstrapTable('remove', {
                    field: 'id',
                    values: ids
                });
                $delete.prop('disabled', true);
                $hide.prop('disabled', true);
                success_prompt("Deletion succeed.", 1500);
            }
        });
    });

    // 点击hide
    $hide.click(function () {
        var ids = getIdSelections();
        $table.bootstrapTable('uncheckBy', {'field': 'id', 'values': ids});
        hide_row_by_ids(ids, $table);

        $delete.prop('disabled', true);
        $hide.prop('disabled', true);
        $display.prop('disabled', false);

        window.hidden_rows = window.hidden_rows.concat(ids);
        update_hide_row_ids(window.hidden_rows);
    });

    //点击checkInvert
    $checkInvert.click(function () {
        $table.bootstrapTable('checkInvert');
    });

    //点击clear check
    $('#clearCheck').click(function () {
        const checkedRows = $table.bootstrapTable('getSelections');
        if (checkedRows.length > 0) {
            const checkedRowIds = [];
            for (let index = 0; index < checkedRows.length; index++) {
                checkedRowIds.push(checkedRows[index]['id']);
            }
            $table.bootstrapTable('uncheckBy', {'field': 'id', 'values': checkedRowIds});
        }
        success_prompt("Clear all checks.", 1500);
    });

    //点击diplay
    $display.click(function () {
        $table.bootstrapTable('getHiddenRows', true);
        $display.prop('disabled', true);
        window.hidden_rows = [];
        update_hide_row_ids([]);
    });

    //获取对应的index
    function getRowOrderByProperty(table, key, value) {
        var data = $(table).bootstrapTable("getData");
        var result = [];
        data.filter(function (o, i) {
            if (o[key] === value) {
                result.push(i);
            }
        });
        return result;
    }

    function hide_row_by_ids(ids, $table) {
        // 传入table对象和ids的array，将这些隐藏
        var results = [];
        ids.forEach(function (id, i) {
            var result = getRowOrderByProperty($table, 'id', id);
            results = results.concat(result);
        });

        results.forEach(function (index, i) {
            $table.bootstrapTable('hideRow', {'index': index})
        });
    }

    $table.on('refresh.bs.table', function () {
        $.ajax({
            url: '/table/refresh',
            type: 'POST',
            dataType: 'json',
            contentType: 'application/json;charset=UTF-8',
            data: JSON.stringify({
                uuid: window.server_uuid
            }),
            success: function (value) {
                let index;
                const status = value['status'];
                const msg = value['msg'];
                if (status === 'success') {
                    if (value['new_logs'].length === 0 && value['updated_logs'].length === 0) {
                        success_prompt(msg, 2000);
                    } else {
                        new_logs = value['new_logs'];
                        updated_logs = value['updated_logs'];
                        if (new_logs.length > 0) {
                            $('#tb_departments').bootstrapTable('prepend', new_logs);
                            for (index = 0; index < new_logs.length; index++) {
                                window.table_data[new_logs[index]['id']] = new_logs[index];
                            }
                        }
                        if (updated_logs.length > 0) {
                            for (index = 0; index < updated_logs.length; index++) {
                                $('#tb_departments').bootstrapTable('updateByUniqueId', {
                                    id: updated_logs[index]['id'],
                                    row: updated_logs[index]
                                });
                                window.table_data[updated_logs[index]['id']] = updated_logs[index];
                            }
                        }
                        success_prompt(msg, 2000);
                    }
                } else {
                    bootbox.alert("Update failed! " + msg);
                }
            },
            error: function (error) {
                bootbox.alert('Error encountered. Check your connection to server.');
            }
        })
    });

</script>

</html>