manage_makeups.js 16.5 KB
Newer Older
1
var makeups_members_table = null,
2
    makeups_members = null,
3
    members_search_results = [],
Damien Moulard committed
4
    selected_rows = []; // Contain members id
5 6


7 8 9
/**
 * Load partners who have makeups to do
 */
10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33
function load_makeups_members() {
    $.ajax({
        type: 'GET',
        url: "/members/get_makeups_members",
        dataType:"json",
        traditional: true,
        contentType: "application/json; charset=utf-8",
        success: function(data) {
            makeups_members = data.res;
            display_makeups_members();
        },
        error: function(data) {
            err = {msg: "erreur serveur lors de la récupération des membres avec rattrapage", ctx: 'load_makeups_members'};
            if (typeof data.responseJSON != 'undefined' && typeof data.responseJSON.error != 'undefined') {
                err.msg += ' : ' + data.responseJSON.error;
            }
            report_JS_error(err, 'orders');

            closeModal();
            alert('Erreur serveur lors de la récupération des membres avec rattrapage. Ré-essayez plus tard.');
        }
    });
}

34 35 36
/**
 * (Re)Display table of makeup members
 */
37 38 39 40 41 42 43
function display_makeups_members() {
    if (makeups_members_table) {
        $('#makeups_members_table').off();
        makeups_members_table.clear().destroy();
        $('#makeups_members_table').empty();
    }

44
    // Remove members with 0 makeups to do and 0 makeups to come
Damien Moulard committed
45
    ids_to_remove = [];
46
    for (let member_item of makeups_members) {
47
        if (member_item.makeups_to_do === 0 && member_item.makeups_to_come === 0) {
Damien Moulard committed
48
            ids_to_remove.push(member_item.id);
49 50
        }
    }
Damien Moulard committed
51
    makeups_members = makeups_members.filter(m => !ids_to_remove.includes(m.id));
52 53 54 55 56 57 58

    // TODO : select multiple and grouped action
    makeups_members_table = $('#makeups_members_table').DataTable({
        data: makeups_members,
        columns: [
            {
                data: "id",
59
                title: "",
60 61
                className: "dt-body-center",
                orderable: false,
62 63 64 65 66 67
                render: function (data, type, full) {
                    var html = ``;
                    if(full.shift_type == 'standard') { //prevent checking of ftop members so that they can't be target of makeup removal
                        html = `<input type="checkbox" class="select_member_cb" id="select_member_${data}" value="${data}">`;
                    }
                    return html;
68 69 70 71 72
                },
                width: "3%"
            },
            {
                data: "name",
Damien Moulard committed
73
                title: "Nom"
74
            },
75 76 77 78 79 80 81 82 83 84 85 86 87
            {
                data: "shift_type",
                title: "<div class='title_center'>Type de créneau</div>",
                className: "dt-body-center",
                width: "5%",
                render: function (data) {
                    if (data == 'ftop') {
                        return (has_committe_shift === "True") ? "Comités" : "Volant";
                    } else {
                        return 'ABCD';
                    }
                }
            },
Félicie committed
88
            {
89
                data: "makeups_to_come",
90
                title: "<div class='title_center' title=\"Services de rattrapage déjà planifiés depuis l'espace membre.\">Déjà planifiés</div>",
Félicie committed
91
                className: "dt-body-center",
92 93 94
                width: "8%",
                render: function (data, type, full) {
                    return `<b>${data}</b>`;
Félicie committed
95 96
                }
            },
97 98
            {
                data: "makeups_to_do",
99
                title: "<div class='title_center' title=\"Rattrapages en attente de planification sur l'espace membre.\">A planifier</div>",
100 101 102
                className: "dt-body-center",
                width: "10%",
                render: function (data, type, full) {
103
                    var html = `<b>${data}</b>`
104
                    if(full.shift_type == 'standard') {
105 106 107 108 109 110
                        if(data > 0) {
                            html += `
                            <button class="decrement_makeup btn--primary" id="decrement_member_${full.id}">
                                <i class="fas fa-minus"></i>
                            </button>`;
                        }
111
                        html += `
112 113
                        <button class="increment_makeup btn--primary" id="increment_member_${full.id}">
                            <i class="fas fa-plus"></i>
114
                        </button>`;
115 116
                    }
                    return html;
Damien Moulard committed
117
                }
118 119
            },
            {
120
                data: "shift_type",
121
                title: "<div class='title_center' title=\"Le nombre de points est l'opposé du nombre total de rattrapages.\">Points</div>",
122 123 124 125 126 127 128 129 130 131 132
                className: "dt-body-center",
                width: "5%",
                render: function (data, type, row) {
                    if (data == 'ftop') {
                        return row.display_ftop_points;
                    } else if (data == 'standard') {
                        return row.display_std_points;
                    }

                    return null;
                }
133 134 135 136 137 138 139 140 141 142 143 144 145 146
            }
        ],
        aLengthMenu: [
            [
                25,
                50,
                -1
            ],
            [
                25,
                50,
                "Tout"
            ]
        ],
147
        iDisplayLength: 25,
148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169
        oLanguage: {
            "sProcessing":     "Traitement en cours...",
            "sSearch":         "Rechercher dans le tableau",
            "sLengthMenu":     "Afficher _MENU_ &eacute;l&eacute;ments",
            "sInfo":           "Affichage de l'&eacute;l&eacute;ment _START_ &agrave; _END_ sur _TOTAL_ &eacute;l&eacute;ments",
            "sInfoEmpty":      "Affichage de l'&eacute;l&eacute;ment 0 &agrave; 0 sur 0 &eacute;l&eacute;ment",
            "sInfoFiltered":   "(filtr&eacute; de _MAX_ &eacute;l&eacute;ments au total)",
            "sInfoPostFix":    "",
            "sLoadingRecords": "Chargement en cours...",
            "sZeroRecords":    "Aucun &eacute;l&eacute;ment &agrave; afficher",
            "sEmptyTable":     "Aucune donn&eacute;e disponible dans le tableau",
            "oPaginate": {
                "sFirst":      "Premier",
                "sPrevious":   "Pr&eacute;c&eacute;dent",
                "sNext":       "Suivant",
                "sLast":       "Dernier"
            },
            "oAria": {
                "sSortAscending":  ": activer pour trier la colonne par ordre croissant",
                "sSortDescending": ": activer pour trier la colonne par ordre d&eacute;croissant"
            },
            "select": {
Damien Moulard committed
170 171 172 173 174
                "rows": {
                    "_": "%d lignes séléctionnées",
                    "0": "Aucune ligne séléctionnée",
                    "1": "1 ligne séléctionnée"
                }
175 176
            }
        }
177 178 179
    });

    $('#makeups_members_table').on('click', 'tbody td .decrement_makeup', function () {
Damien Moulard committed
180 181
        const button_id = $(this).prop('id')
            .split('_');
182 183 184 185
        const member_id = button_id[button_id.length - 1];

        const member = makeups_members.find(m => m.id == member_id);

186 187 188 189
        let modal_template = $("#modal_decr_makeup_counter");

        modal_template.find(".member_name").text(member.name);

190
        openModal(
191
            modal_template.html(),
192
            () => {
193 194 195
                update_members_makeups(
                    [member_id],
                    "decrement",
196
                    ($("#decr-signature")[0].value || "auteur inconnu") + ' : ' + ($("#decr-explanation")[0].value || "pas d'explication")
197
                );
198 199 200
            },
            "Confirmer",
            false
Damien Moulard committed
201
        );
202
    });
203

204 205 206 207 208 209 210
    $('#makeups_members_table').on('click', 'tbody td .increment_makeup', function () {
        const button_id = $(this).prop('id')
            .split('_');
        const member_id = button_id[button_id.length - 1];

        const member = makeups_members.find(m => m.id == member_id);

211 212 213 214
        let modal_template = $("#modal_incr_makeup_counter");

        modal_template.find(".member_name").text(member.name);

215
        openModal(
216
            modal_template.html(),
217
            () => {
218 219 220
                update_members_makeups(
                    [member_id],
                    "increment",
221
                    ($("#incr-signature")[0].value || "auteur inconnu") + ' : ' + ($("#incr-explanation")[0].value || "pas d'explication")
222
                );
223 224 225 226 227 228
            },
            "Confirmer",
            false
        );
    });

229 230 231 232 233 234 235 236 237 238 239 240
    $('#makeups_members_table').on('click', 'tbody td .select_member_cb', function () {
        $(this).closest('tr')
            .toggleClass('selected');

        // Save / unsave selected row
        const m_id = makeups_members_table.row($(this).closest('tr')).data().id;
        const first_select = selected_rows.length === 0;

        if (this.checked) {
            selected_rows.push(m_id);
        } else {
            const i = selected_rows.findIndex(id => id == m_id);
Damien Moulard committed
241

242 243 244 245 246 247 248 249
            selected_rows.splice(i, 1);
        }

        if (selected_rows.length > 0) {
            $("#decrement_selected_members_makeups").show();
            if (first_select) {
                $("#decrement_selected_members_makeups").on("click", () => {
                    openModal(
250
                        $("#modal_decr_selected_makeup_counter").html(),
251
                        () => {
252 253 254
                            update_members_makeups(
                                selected_rows,
                                "decrement",
255
                                ($("#decr-signature-selected")[0].value || "auteur inconnu") + ' : ' + ($("#decr-explanation-selected")[0].value || "pas d'explication")
256
                            );
257 258 259
                        },
                        "Confirmer",
                        false
Damien Moulard committed
260
                    );
261 262 263
                });
            }
        } else {
Damien Moulard committed
264 265
            $("#decrement_selected_members_makeups").off()
                .hide();
266 267
        }
    });
268 269 270 271 272 273

    $('#makeups_members_table').on('click', 'tbody td .extend_delay_button', function () {
        const member_id = this.dataset.memberId;
        const member = makeups_members.find(m => m.id == member_id);

        let modal = $("#modal_extend_delay_template");
274

275 276 277 278 279 280 281 282 283 284 285
        modal.find(".member_name").text(member.name);

        openModal(
            modal.html(),
            () => {
                extend_member_delay(member);
            },
            "Confirmer",
            false
        );
    });
286 287
}

288 289
/**
 * Send request to update members nb of makeups to do
François committed
290
 *
Damien Moulard committed
291
 * @param {Array} member_ids
292
 * @param {String} action increment | decrement
293
 * @param description
294
 */
295
function update_members_makeups(member_ids, action, description) {
296 297
    openModal();

Damien Moulard committed
298
    data = [];
299 300
    for (mid of member_ids) {
        member_index = makeups_members.findIndex(m => m.id == mid);
301 302
        data.push({
            member_id: mid,
303
            target_makeups_nb: makeups_members[member_index].makeups_to_do + (action === 'increment' ? 1 : -1),
304 305
            member_shift_type: makeups_members[member_index].shift_type,
            display_ftop_points: makeups_members[member_index].display_ftop_points,
306 307
            display_std_points: makeups_members[member_index].display_std_points,
            description: description,
308 309 310 311 312 313 314 315 316 317
        });
    }

    $.ajax({
        type: 'POST',
        url: "/members/update_members_makeups",
        data: JSON.stringify(data),
        dataType:"json",
        traditional: true,
        contentType: "application/json; charset=utf-8",
318
        success: function(res) {
319
            selected_rows = [];
320 321
            for (element of res['res']) {
                member_index = makeups_members.findIndex(m => m.id == element['mid']);
Yvon Kerdoncuff committed
322
                makeups_members[member_index].makeups_to_do += action === 'increment' ? 1 : -1
323
                makeups_members[member_index].display_std_points = element['standard_points']
324
            }
325 326 327 328
            display_makeups_members();
            closeModal();
        },
        error: function(data) {
329
            err = {msg: data.responseJSON.error, ctx: 'update_members_makeups'};
330 331
            report_JS_error(err, 'members_admin-manage_makeups');
            closeModal();
332
            alert(data.responseJSON.error);
333 334 335 336
        }
    });
}

337 338 339 340 341 342
/**
 * Display the members from the search result
 */
function display_possible_members() {
    $('.search_member_results_area').show();
    $('.search_member_results').empty();
343
    $('.btn_possible_member').off();
344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364

    let no_result = true;

    if (members_search_results.length > 0) {
        for (member of members_search_results) {
            // Don't display members already in the table
            if (makeups_members.find(m => m.id == member.id) != null) {
                continue;
            }

            $(".search_results_text").show();
            no_result = false;

            // Display results (possible members) as buttons
            var member_button = '<button class="btn--success btn_possible_member" member_id="'
                + member.id + '">'
                + member.barcode_base + ' - ' + member.name
                + '</button>';

            $('.search_member_results').append(member_button);

365 366 367 368 369 370 371 372
        }

        // Set action on member button click
        $('.btn_possible_member').on('click', function() {
            for (member of members_search_results) {
                if (member.id == $(this).attr('member_id')) {
                    if (makeups_members === null) {
                        makeups_members = [];
373
                    }
374 375 376 377 378

                    makeups_members.unshift({
                        id: member.id,
                        name: member.name,
                        makeups_to_do: 0,
379 380
                        shift_type: member.shift_type,
                        display_std_points: member.display_std_points,
381 382
                        display_ftop_points: member.display_ftop_points,
                        makeups_to_come: member.makeups_to_come
383 384
                    });

385 386 387 388
                    let modal_template = $("#modal_incr_makeup_counter");

                    modal_template.find(".member_name").text(member.name);

389
                    openModal(
390
                        modal_template.html(),
391
                        () => {
392 393 394
                            update_members_makeups(
                                [member.id],
                                "increment",
395
                                ($("#incr-signature")[0].value || "auteur inconnu") + ' : ' + ($("#incr-explanation")[0].value || "pas d'explication")
396
                            );
397 398 399 400 401 402 403 404 405 406
                            members_search_results = [];
                            $('#search_member_input').val('');
                            $('.search_member_results_area').hide();
                            $('.search_member_results').empty();
                        },
                        "Confirmer",
                        false
                    );

                    break;
407
                }
408 409
            }
        });
410
    }
Damien Moulard committed
411

412 413 414
    if (no_result === true) {
        $(".search_results_text").hide();
        $('.search_member_results').html(`<p>
Damien Moulard committed
415
            <i>Aucun résultat ! Vérifiez votre recherche, ou si le.la membre n'est pas déjà dans le tableau...</i>
416 417 418 419
        </p>`);
    }
}

420
$(document).ready(function() {
421
    if (coop_is_connected()) {
Damien Moulard committed
422 423
        $.ajaxSetup({ headers: { "X-CSRFToken": getCookie('csrftoken') } });

424 425 426 427 428
        $(".page_content").show();
        load_makeups_members();
    } else {
        $(".page_content").hide();
    }
429

430 431
    $('#back_to_admin_index').on('click', function() {
        let base_location = window.location.href.split("manage_makeups")[0].slice(0, -1);
Damien Moulard committed
432

433 434 435
        window.location.assign(base_location);
    });

436 437 438 439 440
    // Set action to search for the member
    $('#search_member_form').submit(function() {
        let search_str = $('#search_member_input').val();

        $.ajax({
441
            url: '/members/search/' + search_str +'?search_type=makeups_data',
442 443 444
            dataType : 'json',
            success: function(data) {
                members_search_results = [];
445
                members_search_results = data.res;
446 447 448

                display_possible_members();
            },
Damien Moulard committed
449
            error: function() {
450 451
                err = {
                    msg: "erreur serveur lors de la recherche de membres",
452
                    ctx: 'members.admin.manage_makeups.search_members'
453 454 455 456 457 458 459 460 461 462
                };
                report_JS_error(err, 'stock');

                $.notify("Erreur lors de la recherche de membre, il faut ré-essayer plus tard...", {
                    globalPosition:"top right",
                    className: "error"
                });
            }
        });
    });
463
});