Fix multidownloading the same file
Focus media viewer caption on touchstart
This commit is contained in:
parent
4c6b9d115f
commit
ae18152cdf
@ -1316,7 +1316,26 @@ export default class AppMediaViewer extends AppMediaViewerBase<'caption', 'delet
|
|||||||
this.content.main.prepend(stub); */
|
this.content.main.prepend(stub); */
|
||||||
|
|
||||||
this.content.caption = document.createElement('div');
|
this.content.caption = document.createElement('div');
|
||||||
this.content.caption.classList.add(MEDIA_VIEWER_CLASSNAME + '-caption'/* , 'media-viewer-stub' */);
|
this.content.caption.classList.add(MEDIA_VIEWER_CLASSNAME + '-caption', MEDIA_VIEWER_CLASSNAME + '-appear'/* , 'media-viewer-stub' */);
|
||||||
|
|
||||||
|
let captionTimeout: number;
|
||||||
|
this.content.caption.addEventListener('touchstart', () => {
|
||||||
|
if(!mediaSizes.isMobile) return;
|
||||||
|
|
||||||
|
this.content.caption.classList.add('is-focused');
|
||||||
|
|
||||||
|
if(captionTimeout) {
|
||||||
|
clearTimeout(captionTimeout);
|
||||||
|
captionTimeout = undefined;
|
||||||
|
}
|
||||||
|
|
||||||
|
document.addEventListener('touchend', () => {
|
||||||
|
captionTimeout = window.setTimeout(() => {
|
||||||
|
captionTimeout = undefined;
|
||||||
|
this.content.caption.classList.remove('is-focused');
|
||||||
|
}, 1000);
|
||||||
|
}, {once: true});
|
||||||
|
});
|
||||||
|
|
||||||
new Scrollable(this.content.caption);
|
new Scrollable(this.content.caption);
|
||||||
|
|
||||||
|
@ -31,7 +31,7 @@ export default class ProgressivePreloader {
|
|||||||
private tryAgainOnFail = true;
|
private tryAgainOnFail = true;
|
||||||
private attachMethod: 'append' | 'prepend' = 'append';
|
private attachMethod: 'append' | 'prepend' = 'append';
|
||||||
|
|
||||||
public loadFunc: () => {download: CancellablePromise<any>};
|
public loadFunc: (e?: Event) => {download: CancellablePromise<any>};
|
||||||
|
|
||||||
private totalLength: number;
|
private totalLength: number;
|
||||||
|
|
||||||
@ -120,7 +120,7 @@ export default class ProgressivePreloader {
|
|||||||
|
|
||||||
if(this.preloader.classList.contains('manual')) {
|
if(this.preloader.classList.contains('manual')) {
|
||||||
if(this.loadFunc) {
|
if(this.loadFunc) {
|
||||||
this.loadFunc();
|
this.loadFunc(e);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if(this.promise && this.promise.cancel) {
|
if(this.promise && this.promise.cancel) {
|
||||||
|
@ -575,11 +575,14 @@ export function wrapDocument({message, withTime, fontWeight, voiceAsMusic, showS
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
const load = () => {
|
const load = (e: Event) => {
|
||||||
|
const save = !e || e.isTrusted;
|
||||||
const doc = appDocsManager.getDoc(docDiv.dataset.docId);
|
const doc = appDocsManager.getDoc(docDiv.dataset.docId);
|
||||||
let download: DownloadBlob;
|
let download: DownloadBlob;
|
||||||
const queueId = appImManager.chat.bubbles ? appImManager.chat.bubbles.lazyLoadQueue.queueId : undefined;
|
const queueId = appImManager.chat.bubbles ? appImManager.chat.bubbles.lazyLoadQueue.queueId : undefined;
|
||||||
if(doc.type === 'pdf') {
|
if(!save) {
|
||||||
|
download = appDocsManager.downloadDoc(doc, queueId);
|
||||||
|
} else if(doc.type === 'pdf') {
|
||||||
download = appDocsManager.downloadDoc(doc, queueId);
|
download = appDocsManager.downloadDoc(doc, queueId);
|
||||||
download.then(() => {
|
download.then(() => {
|
||||||
const cacheContext = appDownloadManager.getCacheContext(doc);
|
const cacheContext = appDownloadManager.getCacheContext(doc);
|
||||||
@ -624,7 +627,7 @@ export function wrapDocument({message, withTime, fontWeight, voiceAsMusic, showS
|
|||||||
if(preloader) {
|
if(preloader) {
|
||||||
preloader.onClick(e);
|
preloader.onClick(e);
|
||||||
} else {
|
} else {
|
||||||
load();
|
load(e);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -123,15 +123,16 @@
|
|||||||
bottom: .75rem;
|
bottom: .75rem;
|
||||||
left: 0;
|
left: 0;
|
||||||
right: 0;
|
right: 0;
|
||||||
padding: 0 .5rem;
|
padding: .5rem .5rem 0;
|
||||||
// background-color: rgba(0, 0, 0, .6);
|
// background-color: rgba(0, 0, 0, .6);
|
||||||
// border-radius: 8px;
|
// border-radius: 8px;
|
||||||
opacity: 0;
|
opacity: 0;
|
||||||
line-height: var(--line-height);
|
line-height: var(--line-height);
|
||||||
white-space: pre-wrap;
|
white-space: pre-wrap;
|
||||||
|
background-color: transparent;
|
||||||
|
|
||||||
@include animation-level(2) {
|
@include animation-level(2) {
|
||||||
transition: opacity var(--open-duration);
|
transition: opacity var(--open-duration), background-color var(--open-duration);
|
||||||
}
|
}
|
||||||
|
|
||||||
a {
|
a {
|
||||||
@ -175,12 +176,22 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
@include animation-level(2) {
|
@include animation-level(2) {
|
||||||
transition: transform var(--layer-transition), opacity var(--open-duration) ease-in-out;
|
transition: transform var(--layer-transition), opacity var(--open-duration) ease-in-out, background-color var(--open-duration);
|
||||||
}
|
}
|
||||||
|
|
||||||
.media-viewer-whole.has-video-controls & {
|
.media-viewer-whole.has-video-controls & {
|
||||||
transform: translate3d(0, -69px, 0);
|
transform: translate3d(0, -69px, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@include hover() {
|
||||||
|
background-color: #000;
|
||||||
|
opacity: 1 !important;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
&.is-focused {
|
||||||
|
background-color: #000;
|
||||||
|
opacity: 1 !important;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user