Update button

This commit is contained in:
Eduard Kuzmenko 2022-01-25 10:35:43 +04:00
parent bd06984e5e
commit 43ad3b9050
7 changed files with 92 additions and 7 deletions

View File

@ -25,7 +25,7 @@ import AppNewChannelTab from "./tabs/newChannel";
import AppContactsTab from "./tabs/contacts";
import AppArchivedTab from "./tabs/archivedTab";
import AppAddMembersTab from "./tabs/addMembers";
import { FormatterArguments, i18n_, LangPackKey } from "../../lib/langPack";
import { FormatterArguments, i18n, i18n_, LangPackKey } from "../../lib/langPack";
import AppPeopleNearbyTab from "./tabs/peopleNearby";
import { ButtonMenuItemOptions } from "../buttonMenu";
import CheckboxField from "../checkboxField";
@ -38,7 +38,7 @@ import App from "../../config/app";
import ButtonMenuToggle from "../buttonMenuToggle";
import replaceContent from "../../helpers/dom/replaceContent";
import sessionStorage from "../../lib/sessionStorage";
import { CLICK_EVENT_NAME } from "../../helpers/dom/clickEvent";
import { attachClickEvent, CLICK_EVENT_NAME } from "../../helpers/dom/clickEvent";
import { closeBtnMenu } from "../misc";
import { indexOfAndSplice } from "../../helpers/array";
import ButtonIcon from "../buttonIcon";
@ -46,6 +46,8 @@ import confirmationPopup from "../confirmationPopup";
import IS_GEOLOCATION_SUPPORTED from "../../environment/geolocationSupport";
import type SortedUserList from "../sortedUserList";
import Button, { ButtonOptions } from "../button";
import noop from "../../helpers/noop";
import { ripple } from "../ripple";
export const LEFT_COLUMN_ACTIVE_CLASSNAME = 'is-left-column-shown';
@ -64,6 +66,9 @@ export class AppSidebarLeft extends SidebarSlider {
private searchGroups: {[k in 'contacts' | 'globalContacts' | 'messages' | 'people' | 'recent']: SearchGroup} = {} as any;
private searchSuper: AppSearchSuper;
private updateBtn: HTMLElement;
private hasUpdate: boolean;
constructor() {
super({
sidebarEl: document.getElementById('column-left') as HTMLDivElement,
@ -264,6 +269,28 @@ export class AppSidebarLeft extends SidebarSlider {
this.newBtnMenu.id = 'new-menu';
sidebarHeader.nextElementSibling.append(this.newBtnMenu);
this.updateBtn = document.createElement('div');
// this.updateBtn.classList.add('btn-update');
this.updateBtn.className = 'btn-circle rp btn-corner z-depth-1 btn-update is-hidden';
ripple(this.updateBtn);
this.updateBtn.append(i18n('Update'));
// const weave = new TopbarWeave();
// const weaveContainer = weave.render('btn-update-weave');
// this.updateBtn.prepend(weaveContainer);
attachClickEvent(this.updateBtn, () => {
location.reload();
});
sidebarHeader.nextElementSibling.append(this.updateBtn);
// setTimeout(() => {
// weave.componentDidMount();
// weave.setCurrentState(GROUP_CALL_STATE.MUTED, true);
// weave.setAmplitude(0);
// weave.handleBlur();
// }, 1e3);
this.inputSearch.input.addEventListener('focus', () => this.initSearch(), {once: true});
//parseMenuButtonsTo(this.newButtons, this.newBtnMenu.firstElementChild.children);
@ -289,6 +316,23 @@ export class AppSidebarLeft extends SidebarSlider {
for(let i = 0, length = recentSearch.length; i < length; ++i) {
appStateManager.requestPeer(recentSearch[i], 'recentSearch');
}
const CHECK_UPDATE_INTERVAL = 1800e3;
const checkUpdateInterval = setInterval(() => {
fetch('version')
.then(res => (res.status === 200 && res.ok && res.text()) || Promise.reject())
.then(text => {
if(text !== App.versionFull) {
this.hasUpdate = true;
clearInterval(checkUpdateInterval);
if(!this.newBtnMenu.classList.contains('is-hidden')) {
this.updateBtn.classList.remove('is-hidden');
}
}
})
.catch(noop);
}, CHECK_UPDATE_INTERVAL);
});
}
@ -553,6 +597,7 @@ export class AppSidebarLeft extends SidebarSlider {
hideNewBtnMenuTimeout = window.setTimeout(() => {
hideNewBtnMenuTimeout = 0;
this.newBtnMenu.classList.remove('is-hidden');
this.hasUpdate && this.updateBtn.classList.remove('is-hidden');
}, 150);
}
@ -566,6 +611,7 @@ export class AppSidebarLeft extends SidebarSlider {
this.toolsBtn.classList.remove(activeClassName);
this.backBtn.classList.add(activeClassName);
this.newBtnMenu.classList.add('is-hidden');
this.updateBtn.classList.add('is-hidden');
this.toolsBtn.parentElement.firstElementChild.classList.toggle('state-back', true);
if(!IS_MOBILE_SAFARI && !appNavigationController.findItemByType('global-search')) {

View File

@ -267,7 +267,7 @@ export default class TopbarCall {
container.append(left, center, right);
const weave = this.weave = new TopbarWeave();
const weaveContainer = weave.render();
const weaveContainer = weave.render(CLASS_NAME + '-weave');
container.prepend(weaveContainer);
document.getElementById('column-center').prepend(container);

View File

@ -180,12 +180,12 @@ export default class TopbarWeave {
this.invokeDraw();
}
private handleFocus = () => {
public handleFocus = () => {
this.focused = true;
this.invokeDraw();
}
private handleBlur = () => {
public handleBlur = () => {
this.focused = false;
}
@ -327,8 +327,7 @@ export default class TopbarWeave {
this.setCanvasSize();
}
public render() {
const className = 'topbar-call-weave';
public render(className: string) {
const container = this.container = document.createElement('div');
container.classList.add(className);

View File

@ -639,6 +639,7 @@ const lang = {
"RequestToJoinSent": "Join request sent",
"RequestToJoinGroupApproved": "Your request to join the group was approved",
"RequestToJoinChannelApproved": "Your request to join the channel was approved",
"Update": "UPDATE",
// * macos
"AccountSettings.Filters": "Chat Folders",

View File

@ -31,6 +31,7 @@ for(const key in env) {
lines.push(`${key}=${env[key]}`);
}
fs.writeFileSync('./.env', lines.join('\n') + '\n', 'utf-8');
fs.writeFileSync('./public/version', env.VERSION_FULL, 'utf-8');
if(changelog) {
const data = fs.readFileSync('./CHANGELOG.md');

View File

@ -489,3 +489,40 @@
margin-left: var(--call-button-margin);
}
}
// .btn-update {
// position: absolute;
// right: 0;
// bottom: 0;
// left: 0;
// height: 2.5rem;
// line-height: 2.5rem;
// text-align: center;
// color: #fff;
// &-weave {
// position: absolute;
// top: 0;
// right: 0;
// bottom: -2.5rem;
// left: 0;
// z-index: -1;
// transform: scale(1, -1);
// &-canvas {
// width: 100%;
// height: 100%;
// }
// }
// }
.btn-update {
width: auto;
padding: 0 2rem !important;
border-radius: var(--size);
font-size: 1rem;
font-weight: 500;
/* margin-right: calc(var(--size) + 0.5rem); */
/* left: var(--offset); */
right: auto;
}

View File

@ -381,6 +381,7 @@
.item-main .sidebar-content {
overflow: visible;
justify-content: center;
.btn-menu {
bottom: calc(100% + 10px);