]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blobdiff - client/src/app/shared/users/user.model.ts
Add account settings new design
[github/Chocobozzz/PeerTube.git] / client / src / app / shared / users / user.model.ts
index 1c2b481e34d41bb695ca81d72b919a1b9ecc0b39..b075ab717b60a61ad1e80b81eb72d3cd74995a6b 100644 (file)
@@ -1,33 +1,64 @@
-import { User as UserServerModel, UserRole } from '../../../../../shared'
+import {
+  User as UserServerModel,
+  UserRole,
+  VideoChannel,
+  UserRight,
+  hasUserRight
+} from '../../../../../shared'
 
+export type UserConstructorHash = {
+  id: number,
+  username: string,
+  email: string,
+  role: UserRole,
+  videoQuota?: number,
+  displayNSFW?: boolean,
+  createdAt?: Date,
+  account?: {
+    id: number
+    uuid: string
+  },
+  videoChannels?: VideoChannel[]
+}
 export class User implements UserServerModel {
   id: number
   username: string
   email: string
   role: UserRole
   displayNSFW: boolean
+  videoQuota: number
+  account: {
+    id: number
+    uuid: string
+  }
+  videoChannels: VideoChannel[]
   createdAt: Date
 
-  constructor (hash: {
-    id: number,
-    username: string,
-    email: string,
-    role: UserRole,
-    displayNSFW?: boolean,
-    createdAt?: Date
-  }) {
+  constructor (hash: UserConstructorHash) {
     this.id = hash.id
     this.username = hash.username
     this.email = hash.email
     this.role = hash.role
-    this.displayNSFW = hash.displayNSFW
+    this.account = hash.account
+
+    if (hash.videoChannels !== undefined) {
+      this.videoChannels = hash.videoChannels
+    }
+
+    if (hash.videoQuota !== undefined) {
+      this.videoQuota = hash.videoQuota
+    }
+
+    if (hash.displayNSFW !== undefined) {
+      this.displayNSFW = hash.displayNSFW
+    }
 
-    if (hash.createdAt) {
+    if (hash.createdAt !== undefined) {
       this.createdAt = hash.createdAt
     }
   }
 
-  isAdmin () {
-    return this.role === 'admin'
+  hasRight (right: UserRight) {
+    return hasUserRight(this.role, right)
   }
 }