Bladeren bron

Import trello: map comment author

Xavier Priour 10 jaren geleden
bovenliggende
commit
2057764801
1 gewijzigde bestanden met toevoegingen van 32 en 18 verwijderingen
  1. 32 18
      models/import.js

+ 32 - 18
models/import.js

@@ -7,7 +7,7 @@ class TrelloCreator {
   constructor(data) {
     // we log current date, to use the same timestamp for all our actions.
     // this helps to retrieve all elements performed by the same import.
-    this._now = new Date();
+    this._nowDate = new Date();
     // The object creation dates, indexed by Trello id (so we only parse actions
     // once!)
     this.createdAt = {
@@ -37,14 +37,28 @@ class TrelloCreator {
    *
    * @param {String} dateString a properly formatted Date
    */
-  now(dateString) {
+  _now(dateString) {
     if(dateString) {
       return new Date(dateString);
     }
-    if(!this._now) {
-      this._now = new Date();
+    if(!this._nowDate) {
+      this._nowDate = new Date();
     }
-    return this._now;
+    return this._nowDate;
+  }
+
+  /**
+   * if trelloUserId is provided and we have a mapping,
+   * return it.
+   * Otherwise return current logged user.
+   * @param trelloUserId
+   * @private
+     */
+  _user(trelloUserId) {
+    if(trelloUserId && this.members[trelloUserId]) {
+      return this.members[trelloUserId];
+    }
+    return Meteor.userId();
   }
 
   checkActions(trelloActions) {
@@ -105,7 +119,7 @@ class TrelloCreator {
       archived: trelloBoard.closed,
       color: this.getColor(trelloBoard.prefs.background),
       // very old boards won't have a creation activity so no creation date
-      createdAt: this.now(this.createdAt.board),
+      createdAt: this._now(this.createdAt.board),
       labels: [],
       members: [{
         userId: Meteor.userId(),
@@ -147,12 +161,12 @@ class TrelloCreator {
       boardToCreate.labels.push(labelToCreate);
     });
     const boardId = Boards.direct.insert(boardToCreate);
-    Boards.direct.update(boardId, {$set: {modifiedAt: this.now()}});
+    Boards.direct.update(boardId, {$set: {modifiedAt: this._now()}});
     // log activity
     Activities.direct.insert({
       activityType: 'importBoard',
       boardId,
-      createdAt: this.now(),
+      createdAt: this._now(),
       source: {
         id: trelloBoard.id,
         system: 'Trello',
@@ -179,8 +193,8 @@ class TrelloCreator {
         archived: card.closed,
         boardId,
         // very old boards won't have a creation activity so no creation date
-        createdAt: this.now(this.createdAt.cards[card.id]),
-        dateLastActivity: this.now(),
+        createdAt: this._now(this.createdAt.cards[card.id]),
+        dateLastActivity: this._now(),
         description: card.desc,
         listId: this.lists[card.idList],
         sort: card.pos,
@@ -220,7 +234,7 @@ class TrelloCreator {
         activityType: 'importCard',
         boardId,
         cardId,
-        createdAt: this.now(),
+        createdAt: this._now(),
         listId: cardToCreate.listId,
         source: {
           id: card.id,
@@ -238,10 +252,10 @@ class TrelloCreator {
           const commentToCreate = {
             boardId,
             cardId,
-            createdAt: this.now(comment.date),
+            createdAt: this._now(comment.date),
             text: comment.data.text,
-            // XXX use the original comment user instead
-            userId: Meteor.userId(),
+            // map comment author, default to current user
+            userId: this._user(comment.memberCreator.id),
           };
           // dateLastActivity will be set from activity insert, no need to
           // update it ourselves
@@ -251,7 +265,7 @@ class TrelloCreator {
             boardId: commentToCreate.boardId,
             cardId: commentToCreate.cardId,
             commentId,
-            createdAt: this.now(commentToCreate.createdAt),
+            createdAt: this._now(commentToCreate.createdAt),
             userId: commentToCreate.userId,
           });
         });
@@ -314,18 +328,18 @@ class TrelloCreator {
         // creation date wasn't found on the action log. This happen on old
         // Trello boards (eg from 2013) that didn't log the 'createList' action
         // we require.
-        createdAt: this.now(this.createdAt.lists[list.id]),
+        createdAt: this._now(this.createdAt.lists[list.id]),
         title: list.name,
         userId: Meteor.userId(),
       };
       const listId = Lists.direct.insert(listToCreate);
-      Lists.direct.update(listId, {$set: {'updatedAt': this.now()}});
+      Lists.direct.update(listId, {$set: {'updatedAt': this._now()}});
       this.lists[list.id] = listId;
       // log activity
       Activities.direct.insert({
         activityType: 'importList',
         boardId,
-        createdAt: this.now(),
+        createdAt: this._now(),
         listId,
         source: {
           id: list.id,