Приложение Meteor не вставляет элементы в коллекцию

Я изучаю Meteor JS и следовал учебному пособию, чтобы составить список покупок для строителя меню. Я пытаюсь добавить некоторые функции к нему. Я успешно добавил одну функцию, но сейчас я пытаюсь создать функцию организации, в которой пользователи могут присоединиться к организации и просмотреть все списки покупок, связанные с этой организацией. Первым шагом является добавление организации пользователями.

Форма появляется, и я смог вставить в базу данных из консоли, но когда я использую автоформу, объекты не вставляются в базу данных.

Я недавно обновился с Meteor 1.3 до 1.4. Я не верю, что это проблема, так как все другие формы в приложении вставляются правильно.

У меня такое чувство, что это как-то связано с подпиской / публикацией, но я не уверен, что делаю неправильно.

HTML- neworganization.html

        <template name='NewOrganization'>
    <div class='new-organization-container'>

        <i class='fa fa-close'></i>

          {{#autoForm collection='Organizations' id='insertOrganizationForm'  type='insert'}}
<div class='form-group'>
      {{> afQuickField name='organization'}}
      </div>
      <div class='form-group'>
      {{> afQuickField name='members'}}
      </div>



    <button type="submit" class="btn btn-primary">Add</button>
  {{/autoForm}}

    </div>


</template>

organizations.html

<template name='Organizations'>
<h3>Your Organizations</h3>
{{#if $.Session.get 'newOrganization'}}
        {{> NewOrganization }}
{{else}}
<button class='btn btn-organization btn-primary'>Add an Organization</button>
<button class='btn btn-join'>Join an Organization</button>
<button class='btn btn-deny'>Leave an Organization</button>
{{/if}}
<section class='organization-list'>
        {{#if Template.subscriptionsReady}}
        {{#each organizationList}}
            {{> OrganizationItem}}
        {{/each}}
    {{else}}
        <p>Loading...</p>
    {{/if}}

JS- organization.js

Template.Organizations.onCreated(function() {
  this.autorun(() => {
    this.subscribe('organizations');
  });
});

Template.Organizations.helpers({
    organizations()  {
        return Organizations.find({});
    }
});


Template.Organizations.events({
      'click .btn-organization': () => {
        Session.set('newOrganization', true);
      }
});

Template.NewOrganization.helpers({
    organizationList: () => {

      var organizationItems = Organizations.find({});

        return organizationItems;
    }
});

newOrganization.js

    if (Meteor.isClient) {
    Meteor.subscribe('organizations');
} 
Template.NewOrganization.events ({
    'click .fa-close': function () {
        Session.set('newOrganization', false);
    }
});

Коллекции /organizations.js

    import SimpleSchema from 'simpl-schema';
SimpleSchema.extendOptions(['autoform']);


Organizations = new Mongo.Collection('organizations');

Organizations.allow({
    insert: function(userId){
        return !!userId;
    },
    update: function(userId, doc){
        return !!userId;
    }
});


OrganizationSchema = new SimpleSchema ({
    organization: {
        label: "Organization Name",
        type: String
    },
    id: {
        label: "ID",
        type: String,
        autoform: {
            type: "hidden"
        }

    },
    members: {
        type: Array
    },
        "members.$": Object,
        "members.$.name": String,
        "members.$.role": String,
          inOrganization: {
            type: Boolean,
            defaultValue: true,

            autoform: {
                type: 'hidden'
            }
      },

    createdAt: {
        type: Date,
        label: "CreatedAt",
        autoform: {
            type: "hidden"
        },
        autoValue: function() {
            return new Date();
        }
    }
});

Meteor.methods({
    deleteOrganizations: function(id) {
        Organizations.remove(id);
    }
});

Organizations.attachSchema(OrganizationSchema);

1 ответ

Решение

Проблема в том, как была разработана схема. Я вставил идентификатор в схему. Мое рассуждение состояло в том, что я хотел иметь способ добавлять и удалять участников из организации. Чего я не учел, так это того, что Mongo автоматически генерирует идентификатор для объекта базы данных, и, проектируя мою схему таким образом, я создавал конфликт. Я удалил идентификатор из моей схемы и удалил проблему.

Вот новый файл collection /organization.js:

import SimpleSchema from 'simpl-schema';
SimpleSchema.extendOptions(['autoform']);

Organizations = new Mongo.Collection('organizations');

Organizations.allow({
    insert: function(userId){
        return !!userId;
    },
    update: function(userId, doc){
        return !!userId;
    }
});


OrganizationSchema = new SimpleSchema ({
    organization: {
        label: "Organization Name",
        type: String
    },
    members: {
        type: Array
    },
        "members.$": Object,
        "members.$.name": String,
        "members.$.role": String,

          inOrganization: {
            type: Boolean,
            defaultValue: true,

            autoform: {
                type: 'hidden'
            }
      },

    createdAt: {
        type: Date,
        label: "CreatedAt",
        autoform: {
            type: "hidden"
        },
        autoValue: function() {
            return new Date();
        }
    }
});

Meteor.methods({
    deleteOrganizations: function(id) {
        Organizations.remove(id);
    }
});

SimpleSchema.debug = true;

Organizations.attachSchema(OrganizationSchema);
Другие вопросы по тегам