浏览代码

feat: relative creation times for reports

Signed-off-by: Jonathan <theflametrooper@gmail.com>
Jonathan 6 年之前
父节点
当前提交
ba7f9242f4
共有 2 个文件被更改,包括 36 次插入8 次删除
  1. 15 3
      frontend/components/Admin/Reports.vue
  2. 21 5
      frontend/components/Modals/IssuesModal.vue

+ 15 - 3
frontend/components/Admin/Reports.vue

@@ -6,8 +6,8 @@
 				<thead>
 				<thead>
 					<tr>
 					<tr>
 						<td>Song ID</td>
 						<td>Song ID</td>
-						<td>Created By</td>
-						<td>Created At</td>
+						<td>Author</td>
+						<td>Time of report</td>
 						<td>Description</td>
 						<td>Description</td>
 						<td>Options</td>
 						<td>Options</td>
 					</tr>
 					</tr>
@@ -28,7 +28,13 @@
 							/>
 							/>
 						</td>
 						</td>
 						<td>
 						<td>
-							<span>{{ report.createdAt }}</span>
+							<span :title="report.createdAt">{{
+								formatDistance(
+									new Date(report.createdAt),
+									new Date(),
+									{ addSuffix: true }
+								)
+							}}</span>
 						</td>
 						</td>
 						<td>
 						<td>
 							<span>{{ report.description }}</span>
 							<span>{{ report.description }}</span>
@@ -58,6 +64,7 @@
 
 
 <script>
 <script>
 import { mapState, mapActions } from "vuex";
 import { mapState, mapActions } from "vuex";
+import { formatDistance } from "date-fns";
 
 
 import Toast from "toasters";
 import Toast from "toasters";
 import io from "../../io";
 import io from "../../io";
@@ -76,17 +83,21 @@ export default {
 		io.getSocket(socket => {
 		io.getSocket(socket => {
 			this.socket = socket;
 			this.socket = socket;
 			if (this.socket.connected) this.init();
 			if (this.socket.connected) this.init();
+
 			this.socket.emit("reports.index", res => {
 			this.socket.emit("reports.index", res => {
 				this.reports = res.data;
 				this.reports = res.data;
 			});
 			});
+
 			this.socket.on("event:admin.report.resolved", reportId => {
 			this.socket.on("event:admin.report.resolved", reportId => {
 				this.reports = this.reports.filter(report => {
 				this.reports = this.reports.filter(report => {
 					return report._id !== reportId;
 					return report._id !== reportId;
 				});
 				});
 			});
 			});
+
 			this.socket.on("event:admin.report.created", report => {
 			this.socket.on("event:admin.report.created", report => {
 				this.reports.push(report);
 				this.reports.push(report);
 			});
 			});
+
 			io.onConnect(() => {
 			io.onConnect(() => {
 				this.init();
 				this.init();
 			});
 			});
@@ -109,6 +120,7 @@ export default {
 		})
 		})
 	},
 	},
 	methods: {
 	methods: {
+		formatDistance,
 		init() {
 		init() {
 			this.socket.emit("apis.joinAdminRoom", "reports", () => {});
 			this.socket.emit("apis.joinAdminRoom", "reports", () => {});
 		},
 		},

+ 21 - 5
frontend/components/Modals/IssuesModal.vue

@@ -17,11 +17,24 @@
 					<strong>Song ID:</strong>
 					<strong>Song ID:</strong>
 					{{ report.song.songId }} / {{ report.song._id }}
 					{{ report.song.songId }} / {{ report.song._id }}
 					<br />
 					<br />
-					<strong>Created By:</strong>
-					{{ report.createdBy }}
+					<strong>Author:</strong>
+					<user-id-to-username
+						:userId="report.createdBy"
+						:alt="report.createdBy"
+					/>
 					<br />
 					<br />
-					<strong>Created At:</strong>
-					{{ report.createdAt }}
+					<strong>Time of report:</strong>
+					<span :title="report.createdAt">
+						{{
+							formatDistance(
+								new Date(report.createdAt),
+								new Date(),
+								{
+									addSuffix: true
+								}
+							)
+						}}
+					</span>
 					<br />
 					<br />
 					<span v-if="report.description">
 					<span v-if="report.description">
 						<strong>Description:</strong>
 						<strong>Description:</strong>
@@ -81,7 +94,9 @@
 
 
 <script>
 <script>
 import { mapActions, mapState } from "vuex";
 import { mapActions, mapState } from "vuex";
+import { formatDistance } from "date-fns";
 
 
+import UserIdToUsername from "../UserIdToUsername.vue";
 import Modal from "./Modal.vue";
 import Modal from "./Modal.vue";
 
 
 export default {
 export default {
@@ -96,9 +111,10 @@ export default {
 		}
 		}
 	},
 	},
 	methods: {
 	methods: {
+		formatDistance,
 		...mapActions("modals", ["closeModal"])
 		...mapActions("modals", ["closeModal"])
 	},
 	},
-	components: { Modal }
+	components: { Modal, UserIdToUsername }
 };
 };
 </script>
 </script>