Added avatar arrows

This commit is contained in:
Eduard Kuzmenko 2021-07-09 21:47:20 +03:00
parent 5da93bc962
commit bfe2dd7eac
2 changed files with 88 additions and 4 deletions

View File

@ -178,6 +178,8 @@ class PeerProfileAvatars {
public avatars: HTMLElement; public avatars: HTMLElement;
public gradient: HTMLElement; public gradient: HTMLElement;
public info: HTMLElement; public info: HTMLElement;
public arrowPrevious: HTMLElement;
public arrowNext: HTMLElement;
private tabs: HTMLDivElement; private tabs: HTMLDivElement;
private listLoader: ListLoader<string | Message.messageService>; private listLoader: ListLoader<string | Message.messageService>;
private peerId: number; private peerId: number;
@ -198,7 +200,21 @@ class PeerProfileAvatars {
this.tabs = document.createElement('div'); this.tabs = document.createElement('div');
this.tabs.classList.add(PeerProfileAvatars.BASE_CLASS + '-tabs'); this.tabs.classList.add(PeerProfileAvatars.BASE_CLASS + '-tabs');
this.container.append(this.avatars, this.gradient, this.info, this.tabs); this.arrowPrevious = document.createElement('div');
this.arrowPrevious.classList.add(PeerProfileAvatars.BASE_CLASS + '-arrow');
/* const previousIcon = document.createElement('i');
previousIcon.classList.add(PeerProfileAvatars.BASE_CLASS + '-arrow-icon', 'tgico-previous');
this.arrowBack.append(previousIcon); */
this.arrowNext = document.createElement('div');
this.arrowNext.classList.add(PeerProfileAvatars.BASE_CLASS + '-arrow', PeerProfileAvatars.BASE_CLASS + '-arrow-next');
/* const nextIcon = document.createElement('i');
nextIcon.classList.add(PeerProfileAvatars.BASE_CLASS + '-arrow-icon', 'tgico-next');
this.arrowNext.append(nextIcon); */
this.container.append(this.avatars, this.gradient, this.info, this.tabs, this.arrowPrevious, this.arrowNext);
const checkScrollTop = () => { const checkScrollTop = () => {
if(this.scrollable.scrollTop !== 0) { if(this.scrollable.scrollTop !== 0) {
@ -258,7 +274,18 @@ class PeerProfileAvatars {
// this.avatars.classList.remove('no-transition'); // this.avatars.classList.remove('no-transition');
// fastRaf(() => { // fastRaf(() => {
this.listLoader.go(toRight ? 1 : -1); this.avatars.classList.add('no-transition');
void this.avatars.offsetLeft; // reflow
let distance: number;
if(this.listLoader.index === 0 && !toRight) distance = this.listLoader.count - 1;
else if(this.listLoader.index === (this.listLoader.count - 1) && toRight) distance = -(this.listLoader.count - 1);
else distance = toRight ? 1 : -1;
this.listLoader.go(distance);
fastRaf(() => {
this.avatars.classList.remove('no-transition');
});
// }); // });
} }
}); });
@ -288,7 +315,7 @@ class PeerProfileAvatars {
cancelNextClick(); cancelNextClick();
cancelEvent(e); cancelEvent(e);
return false; return false;
} else if(this.tabs.classList.contains('hide') || freeze) { } else if(this.container.classList.contains('is-single') || freeze) {
return false; return false;
} }
@ -305,6 +332,7 @@ class PeerProfileAvatars {
this.avatars.style.transform = PeerProfileAvatars.TRANSLATE_TEMPLATE.replace('{x}', x + 'px'); this.avatars.style.transform = PeerProfileAvatars.TRANSLATE_TEMPLATE.replace('{x}', x + 'px');
this.container.classList.add('is-swiping');
this.avatars.classList.add('no-transition'); this.avatars.classList.add('no-transition');
void this.avatars.offsetLeft; // reflow void this.avatars.offsetLeft; // reflow
}, },
@ -317,6 +345,7 @@ class PeerProfileAvatars {
this.avatars.classList.remove('no-transition'); this.avatars.classList.remove('no-transition');
fastRaf(() => { fastRaf(() => {
this.listLoader.go(addIndex); this.listLoader.go(addIndex);
this.container.classList.remove('is-swiping');
}); });
} }
}); });
@ -410,7 +439,7 @@ class PeerProfileAvatars {
tab.classList.add('active'); tab.classList.add('active');
} }
this.tabs.classList.toggle('hide', this.tabs.childElementCount <= 1); this.container.classList.toggle('is-single', this.tabs.childElementCount <= 1);
} }
public processItem = (photoId: string | Message.messageService) => { public processItem = (photoId: string | Message.messageService) => {

View File

@ -21,6 +21,24 @@
height: 100%; height: 100%;
width: width:
} */ } */
@include hover() {
.profile-avatars-arrow {
opacity: .2;
}
}
&.is-single {
.profile-avatars-arrow,
.profile-avatars-tabs {
display: none;
}
}
&.is-swiping {
.profile-avatars-arrow {
opacity: 0 !important;
}
}
} }
&-avatars { &-avatars {
@ -127,6 +145,43 @@
opacity: .6; opacity: .6;
} }
} }
&-arrow {
position: absolute;
top: 0;
left: 0;
bottom: 0;
width: calc(100% / 3);
opacity: 0;
background-image: url(assets/img/avatarprevious.svg);
background-position: 1.125rem 50%;
background-repeat: no-repeat;
background-size: 1.25rem;
@include animation-level(2) {
transition: opacity .2s ease-in-out;
}
.profile-avatars-container:not(.is-swiping) & {
@include hover() {
opacity: 1 !important;
}
}
/* &-icon {
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
} */
&-next {
left: auto;
right: 0;
background-image: url(assets/img/avatarnext.svg);
background-position: calc(100% - 1.125rem) 50%;
}
}
} }
&-content { &-content {