Добавить свойство в сгруппированные объекты и разгруппировать - PullRequest
0 голосов
/ 05 марта 2019

Я использую underscore.js для группировки своих объектов, теперь я хочу добавить свойство для работы в качестве идентификатора для этой группы, а затем уменьшить эти объекты до первоначальной структуры.Но не уверен, как это сделать.

Правило состоит в том, чтобы найти, у кого есть более одной встречи в тот день, и добавить к нему свойство.

Что-то, чего мы достигли здесь:

https://jsfiddle.net/bjxgszmw/

с этой строкой кода:

var resultt = _.chain(allAppointments)
    .groupBy('appointment_date')
    .mapObject( date => _.groupBy(date, 'email' ) )

Итак, из того, что мы получили, это:

{
  "23July": {
    "john@domain.com": [
      {
        "ap_id": 23,
        "name": "John",
        "email": "john@domain.com",
        "appointment_date": "23July",
        "appointment_category": 3,
        "time": "morning"
      },
      {
        "ap_id": 44,
        "name": "John",
        "email": "john@domain.com",
        "appointment_date": "23July",
        "appointment_category": 4,
        "time": "afternon"
      }
    ],
    "rose@domain.com": [
      {
        "ap_id": 55,

к чему-то простомукак это;

allAppointments_Filtered: 
      [{
            "ap_id": 23,
            "name": "John",
            "email": "John@domain.com",
            "appointment_date": "23July",
            "appointment_category": 3,
            "time": "morning",
            hasMultipleAppointmentOnDate: "yes"

            },{

           "ap_id": 55,
           "name": "Rose",
           "email": "rose@domain.com",
           "appointment_date": "23July",
           "appointment_category": 4,
           "time": "afternoon"
            hasMultipleAppointmentOnDate: "nope"

            },{

           "ap_id": 44,
           "name": "John",
           "email": "john@domain.com",
           "appointment_date": "23July",
           "appointment_category": 4,
           "time": "afternoon"
            hasMultipleAppointmentOnDate: "yes"

            },{
              ...

      }];

Ответы [ 2 ]

0 голосов
/ 05 марта 2019

Вам нужно сгруппировать по составному ключу:

// data
const allAppointments = [
 {
        "ap_id": 23,
        "name": "John",
        "email": "john@domain.com",
        "appointment_date": "23July",
        "appointment_category": 3,
        "time": "morning"    
   },
      {
        "ap_id": 55,
        "name": "Rose",
        "email": "rose@domain.com",
        "appointment_date": "23July",
        "appointment_category": 4,
        "time": "afternon"        
      },
      {
        "ap_id": 44,
        "name": "John",
        "email": "john@domain.com",
        "appointment_date": "23July",
        "appointment_category": 4,
        "time": "afternon"        
      },
      {
        "ap_id": 70,
        "name": "Kate",
        "email": "kate@domain.com",
        "appointment_date": "29July",
        "appointment_category": 4,
        "time": "afternon"        
      }
];

// gets grouping key, which is email + date
const groupKey = i => i.email +'_'+ i.appointment_date;

// store counts for appointments for unique (email + date)
const counts = _.countBy(allAppointments,groupKey);

// checks if appointment has more than one instances on date
const isMulti = i => counts[groupKey(i)] > 1;

// updated appointment with multiple indicator property
const multiProp = i => ({hasMultipleAppointmentOnDate: isMulti(i) ? "yes": "nope"});

// update initial array items with multiple 
const updated = _.map(allAppointments,i => _.extend(i,multiProp(i)));

// see results
console.log(updated);
<script src="https://cdnjs.cloudflare.com/ajax/libs/underscore.js/1.9.1/underscore-min.js"></script>
0 голосов
/ 05 марта 2019

Ну, вам не нужно делать все эти группировки и сопоставления.Все, что вам нужно сделать, - это одна карта и подсчет, основанный на текущей проверке, которую вы проверяете:

var allAppointments = [
 {
        "ap_id": 23,
        "name": "John",
        "email": "john@domain.com",
        "appointment_date": "23July",
        "appointment_category": 3,
        "time": "morning"    
   },
      {
        "ap_id": 55,
        "name": "Rose",
        "email": "rose@domain.com",
        "appointment_date": "23July",
        "appointment_category": 4,
        "time": "afternon"        
      },
      {
        "ap_id": 44,
        "name": "John",
        "email": "john@domain.com",
        "appointment_date": "23July",
        "appointment_category": 4,
        "time": "afternon"        
      },
      {
        "ap_id": 70,
        "name": "Kate",
        "email": "kate@domain.com",
        "appointment_date": "29July",
        "appointment_category": 4,
        "time": "afternon"        
      }
]

var counts = {};
var result = _.mapObject(allAppointments, (appointment) => {
    var key = appointment.email + appointment.appointment_date;
    
    if (!_.has(counts, key)) {
        counts[key] = _.countBy(allAppointments, (app) => 
            appointment.email === app.email && 
            appointment.appointment_date === app.appointment_date
        ).true > 1
    }
    
    appointment.hasMultipleAppointmentOnDate = counts[key];

    return appointment;
});

console.log(result);
<script src="https://cdnjs.cloudflare.com/ajax/libs/underscore.js/1.9.1/underscore-min.js"></script>
...