Create vm and view

Signed-off-by: RMidhunSuresh <rmidhunsuresh@gmail.com>
This commit is contained in:
RMidhunSuresh 2021-07-19 21:03:42 +05:30
parent 7e481080b5
commit fdd4caa0b7
2 changed files with 50 additions and 0 deletions

View file

@ -0,0 +1,38 @@
import {ViewModel} from "../../ViewModel.js";
import {avatarInitials, getIdentifierColorNumber, getAvatarHttpUrl} from "../../avatar.js";
export class MemberDetailsViewModel extends ViewModel {
constructor(options) {
super(options);
this._observableMember = options.observableMember;
this._mediaRepository = options.mediaRepository;
this._member = this._observableMember.get();
this.track(this._observableMember.subscribe( () => this._onMemberChange()));
}
get name() { return this._member.name; }
get userId() { return this._member.userId; }
get type() { return "member-details"; }
_onMemberChange() {
this._member = this._observableMember.get();
this.emitChange();
}
get avatarLetter() {
return avatarInitials(this.name);
}
get avatarColorNumber() {
return getIdentifierColorNumber(this.userId)
}
avatarUrl(size) {
return getAvatarHttpUrl(this._member.avatarUrl, size, this.platform, this._mediaRepository);
}
get avatarTitle() {
return this.name;
}
}

View file

@ -0,0 +1,12 @@
import {AvatarView} from "../../AvatarView.js";
import {TemplateView} from "../../general/TemplateView.js";
export class MemberDetailsView extends TemplateView {
render(t, vm) {
return t.div({ className: "MemberDetailsView" },
[ t.view(new AvatarView(vm, 128)),
t.div({ className: "MemberDetailsView_name" }, vm.name),
t.div({ className: "MemberDetailsView_userId" }, vm.userId)
]);
}
}