Meteor.js, отображать элементы коллекции на основе значений полей формы - PullRequest
0 голосов
/ 03 июля 2019

Я новичок в метеорите, и недавно я начал разрабатывать приложение с ним.В настоящее время у меня есть форма, которая позволяет мне назначить получателя ваучера.Однако я хотел бы иметь возможность динамически добавлять несколько получателей в один и тот же ваучер.Для этого я использую 2 коллекции: коллекцию бенефициаров («Beneficiaires») и коллекцию ваучеров («bonsNuitees»).Принцип таков:

-fill the fields corresponding to a beneficiary,
depending on the fields elements, display existing and matching beneficiaries or “new beneficiary” if he doesn’t exist (like a search bar),
-select the corresponding option (an existing beneficiary or a new beneficiary)
-press a button to add the option, display it on the page, empty the fields to add a new beneficiary,
-possibility to remove a beneficiary,
-once the voucher fields are filled, pressing a button submits the form by adding beneficiaries and the voucher to their own collection

bon-creer.html:

<template name="bonCreer">
    <div class="container">
        <header>
            <h1>Ajouter un bon de nuitée(s)</h1>
        </header>
        <form class="new-bon">
            <label>Nom :</label><input type="text" name="nom" /><br />
            <label>Prenom :</label><input type="text" name="prenom" /><br />
            <label>Né(e) le :</label><input type="date" name="date_naissance" /><br />
            <label>Typologie :</label><input type="text" name="typologie" /><br />
            <label>Nationalite :</label><input type="text" name="nationalite" /><br />
            <label>Statut :</label><input type="text" name="statut" /><br />

            <br>
            <label>Hôtel :</label><input type="text" name="hotel" ><br />
            <label>Chambres :</label><input type="text" name="chambres" ><br />
            <label>Date de début :</label><input type="date" name="date_debut" ><br />
            <label>Date de fin :</label><input type="date" name="date_fin" ><br />

            <button type="submit" onclick="alert('Création du bon...')">Ajouter</button>
        </form>
    </div>
</template>

bon-creer.js:

Template.bonCreer.helpers({
    beneficiaires () {
        return Beneficiaires.find({});
    },
    hotels () {
        return Hotels.find({});
    },
    bons() {
        return BonsNuitees.find({});
    },
});

Template.bonCreer.events({
    'submit .new-bon'(event) {

        event.preventDefault();

        var beneficiaires = [];
        var nbBeneficiaires = 1;

        ////// Bénéficiaires //////
        var nom = $("input[name='nom']").val();
        var prenom = $("input[name='prenom']").val();
        var date_naissance = $("input[name='date_naissance']").val();
        var typologie = $("input[name='typologie']").val();
        var nationalite = $("input[name='nationalite']").val();
        var statut = $("input[name='statut']").val();

        var beneficiaire = {
            nomB : nom,
            prenomB : prenom,
            date_naissanceB : date_naissance,
            ageB : 0,
            typologieB : typologie,
            nationaliteB : nationalite,
            statutB : statut
        };

        ////// Bon de nuitee(s) //////
        beneficiaires.push(beneficiaire);
        var hotel = $("input[name='hotel']").val();
        var chambres = $("input[name='chambres']").val();
        var date_debut = $("input[name='date_debut']").val();
        var date_fin = $("input[name='date_fin']").val();
        //var prix = $("input[name='prix']").val();

        var bon = {
            beneficiaires : beneficiaires,
            nomH : hotel,
            chambresH : chambres,
            date_debut : date_debut,
            date_fin : date_fin,
            //prix : prix
        };

        Beneficiaires.insert(beneficiaire);
        BonsNuitees.insert(bon);

        window.location.href="./bons-nuitees";
    },
});

Для первого шага Iхотел бы иметь возможность отображать бенефициаров моей коллекции, соответствующих полям "бенефициары" и "новый бенефициар".Не могли бы вы мне помочь, пожалуйста ?Даже подсказки приветствуются.

...