TeaWeb/shared/js/proto.ts

302 lines
9.5 KiB
TypeScript
Raw Normal View History

//Used by CertAccept popup
2020-03-30 11:44:18 +00:00
declare global {
interface Array<T> {
remove(elem?: T): boolean;
last?(): T;
2018-02-27 16:20:49 +00:00
2020-03-30 11:44:18 +00:00
pop_front(): T | undefined;
}
2018-02-27 16:20:49 +00:00
2020-03-30 11:44:18 +00:00
interface JSON {
map_to<T>(object: T, json: any, variables?: string | string[], validator?: (map_field: string, map_value: string) => boolean, variable_direction?: number) : number;
map_field_to<T>(object: T, value: any, field: string) : boolean;
}
2018-08-10 19:30:58 +00:00
2020-03-30 11:44:18 +00:00
type JQueryScrollType = "height" | "width";
interface JQuery<TElement = HTMLElement> {
render(values?: any) : string;
renderTag(values?: any) : JQuery<TElement>;
hasScrollBar(direction?: JQueryScrollType) : boolean;
Implemented the Material Design and fixed some bugs (#33) * cleaned up some files * Fundamental style update * Redesigned some style * fixed hostbanner popup * Removed old identity stuff * fixed close listener * Fixed changelog date * fixed release chat icons * fixed url * Fixed hostbanner * Uploaded missing images * Improved update handling * Improved script files * Fixed loading error and icon error * fixed Yes/No modal * Fixed loader issues with MS Edge * fixed modal style bug * Fixed control bar overflow for small devices * Improved error handling on identity creation * Logging generate error to terminal * fixed possible php error * fixed some possible loading errors when other files have'nt been already loaded. * removed debug message * Changed emsrcypten flags * Improved codec error handling * removed webassembly as required dependency * Improved and fixed channel tree issues * Improved the sliders * Removed unneeded files * fixed loader versions cache * second slight performance improved (dont animate elements anymore if they are not shown) * Fixed query visibility setting * not showing useless client infos for query clients * Added an auto reconnect system * Added a canceled message and increased reconnect interval * removed implemented todo * fixed repetitive channel names * Reworked the channel tree selected lines * Fixed channel tree names * Fixed name alignment * fixed the native client * added min width to the server select groups to avoid a disappearing effect on shrink * fixed bugged downloaded icons
2019-02-17 15:08:10 +00:00
2020-03-30 11:44:18 +00:00
visible_height() : number;
visible_width() : number;
Implemented the Material Design and fixed some bugs (#33) * cleaned up some files * Fundamental style update * Redesigned some style * fixed hostbanner popup * Removed old identity stuff * fixed close listener * Fixed changelog date * fixed release chat icons * fixed url * Fixed hostbanner * Uploaded missing images * Improved update handling * Improved script files * Fixed loading error and icon error * fixed Yes/No modal * Fixed loader issues with MS Edge * fixed modal style bug * Fixed control bar overflow for small devices * Improved error handling on identity creation * Logging generate error to terminal * fixed possible php error * fixed some possible loading errors when other files have'nt been already loaded. * removed debug message * Changed emsrcypten flags * Improved codec error handling * removed webassembly as required dependency * Improved and fixed channel tree issues * Improved the sliders * Removed unneeded files * fixed loader versions cache * second slight performance improved (dont animate elements anymore if they are not shown) * Fixed query visibility setting * not showing useless client infos for query clients * Added an auto reconnect system * Added a canceled message and increased reconnect interval * removed implemented todo * fixed repetitive channel names * Reworked the channel tree selected lines * Fixed channel tree names * Fixed name alignment * fixed the native client * added min width to the server select groups to avoid a disappearing effect on shrink * fixed bugged downloaded icons
2019-02-17 15:08:10 +00:00
2020-03-30 11:44:18 +00:00
/* bootstrap */
alert() : JQuery<TElement>;
modal(properties: any) : this;
bootstrapMaterialDesign() : this;
2019-08-21 08:00:01 +00:00
2020-03-30 11:44:18 +00:00
/* first element which matches the selector, could be the element itself or a parent */
firstParent(selector: string) : JQuery;
}
2018-02-27 16:20:49 +00:00
2020-03-30 11:44:18 +00:00
interface JQueryStatic<TElement extends Node = HTMLElement> {
spawn<K extends keyof HTMLElementTagNameMap>(tagName: K): JQuery<HTMLElementTagNameMap[K]>;
views: any;
}
interface String {
format(...fmt): string;
format(arguments: string[]): string;
}
interface Twemoji {
parse(message: string) : string;
}
let twemoji: Twemoji;
interface HighlightJS {
listLanguages() : string[];
getLanguage(name: string) : any | undefined;
highlight(language: string, text: string, ignore_illegals?: boolean) : HighlightJSResult;
highlightAuto(text: string) : HighlightJSResult;
}
2018-02-27 16:20:49 +00:00
2020-03-30 11:44:18 +00:00
interface HighlightJSResult {
language: string;
relevance: number;
value: string;
second_best?: any;
}
let remarkable: typeof window.remarkable;
interface Window {
2020-04-01 13:40:45 +00:00
readonly webkitAudioContext: typeof AudioContext;
readonly AudioContext: typeof OfflineAudioContext;
2020-03-30 11:44:18 +00:00
readonly OfflineAudioContext: typeof OfflineAudioContext;
readonly webkitOfflineAudioContext: typeof OfflineAudioContext;
2020-03-30 11:44:18 +00:00
readonly RTCPeerConnection: typeof RTCPeerConnection;
readonly Pointer_stringify: any;
readonly jsrender: any;
twemoji: Twemoji;
hljs: HighlightJS;
remarkable: any;
2020-04-11 09:43:41 +00:00
readonly require: typeof require;
2020-03-30 11:44:18 +00:00
}
2020-04-11 09:43:41 +00:00
const __non_webpack_require__: typeof require;
2020-03-30 11:44:18 +00:00
interface Navigator {
browserSpecs: {
name: string,
version: string
};
mozGetUserMedia(constraints: MediaStreamConstraints, successCallback: NavigatorUserMediaSuccessCallback, errorCallback: NavigatorUserMediaErrorCallback): void;
webkitGetUserMedia(constraints: MediaStreamConstraints, successCallback: NavigatorUserMediaSuccessCallback, errorCallback: NavigatorUserMediaErrorCallback): void;
}
2018-02-27 16:20:49 +00:00
}
2020-03-30 11:44:18 +00:00
export function initialize() { }
2018-08-10 19:30:58 +00:00
if(!JSON.map_to) {
2019-09-12 21:59:35 +00:00
JSON.map_to = function <T>(object: T, json: any, variables?: string | string[], validator?: (map_field: string, map_value: string) => boolean, variable_direction?: number): number {
2018-09-30 19:50:59 +00:00
if (!validator) validator = (a, b) => true;
2018-08-10 19:30:58 +00:00
2018-09-30 19:50:59 +00:00
if (!variables) {
2018-08-10 19:30:58 +00:00
variables = [];
2018-09-30 19:50:59 +00:00
if (!variable_direction || variable_direction == 0) {
for (let field in json)
2018-08-10 19:30:58 +00:00
variables.push(field);
2018-09-30 19:50:59 +00:00
} else if (variable_direction == 1) {
for (let field in object)
2018-08-10 19:30:58 +00:00
variables.push(field);
}
2018-09-30 19:50:59 +00:00
} else if (!Array.isArray(variables)) {
2018-08-10 19:30:58 +00:00
variables = [variables];
}
2019-09-12 21:59:35 +00:00
let updates = 0;
2018-09-30 19:50:59 +00:00
for (let field of variables) {
2020-02-02 14:05:36 +00:00
if (typeof json[field] === "undefined") {
console.trace(tr("Json does not contains %s"), field);
2018-08-10 19:30:58 +00:00
continue;
}
2018-09-30 19:50:59 +00:00
if (!validator(field, json[field])) {
console.trace(tr("Validator results in false for %s"), field);
2018-08-10 19:30:58 +00:00
continue;
}
2019-09-12 21:59:35 +00:00
if(JSON.map_field_to(object, json[field], field))
updates++;
2018-08-10 19:30:58 +00:00
}
2019-09-12 21:59:35 +00:00
return updates;
2018-08-10 19:30:58 +00:00
}
}
if(!JSON.map_field_to) {
2019-09-12 21:59:35 +00:00
JSON.map_field_to = function<T>(object: T, value: any, field: string) : boolean {
2018-08-10 19:30:58 +00:00
let field_type = typeof(object[field]);
2019-09-12 21:59:35 +00:00
let new_object;
2018-08-10 19:30:58 +00:00
if(field_type == "string" || field_type == "object" || field_type == "undefined")
2019-09-12 21:59:35 +00:00
new_object = value;
2018-08-10 19:30:58 +00:00
else if(field_type == "number")
2019-09-12 21:59:35 +00:00
new_object = parseFloat(value);
2018-08-10 19:30:58 +00:00
else if(field_type == "boolean")
2019-09-12 21:59:35 +00:00
new_object = value == "1" || value == "true";
else {
console.warn(tr("Invalid object type %s for entry %s"), field_type, field);
return false;
}
if(new_object === object[field as string]) return false;
2018-08-10 19:30:58 +00:00
2019-09-12 21:59:35 +00:00
object[field as string] = new_object;
return true;
2018-08-10 19:30:58 +00:00
}
}
2018-02-27 16:20:49 +00:00
if (!Array.prototype.remove) {
Array.prototype.remove = function<T>(elem?: T): boolean {
2018-03-24 22:38:01 +00:00
const index = this.indexOf(elem, 0);
2018-02-27 16:20:49 +00:00
if (index > -1) {
this.splice(index, 1);
return true;
}
return false;
}
}
if (!Array.prototype.pop_front) {
Array.prototype.pop_front = function<T>(): T {
if(this.length == 0) return undefined;
return this.splice(0, 1)[0];
}
}
2018-04-16 18:38:35 +00:00
2018-02-27 16:20:49 +00:00
if (!Array.prototype.last){
Array.prototype.last = function(){
if(this.length == 0) return undefined;
return this[this.length - 1];
};
}
2018-04-11 15:56:09 +00:00
if(typeof ($) !== "undefined") {
if(!$.spawn) {
$.spawn = function<K extends keyof HTMLElementTagNameMap>(tagName: K): JQuery<HTMLElementTagNameMap[K]> {
return $(document.createElement(tagName) as any);
2018-04-11 15:56:09 +00:00
}
2018-02-27 16:20:49 +00:00
}
2020-03-30 11:44:18 +00:00
2018-12-23 16:41:14 +00:00
if(!$.fn.renderTag) {
$.fn.renderTag = function (this: JQuery, values?: any) : JQuery {
let result;
if(this.render) {
result = $(this.render(values));
} else {
const template = window.jsrender.render[this.attr("id")];
if(!template) {
console.error("Tried to render template %o, but template is not available!", this.attr("id"));
throw "missing template " + this.attr("id");
}
/*
result = window.jsrender.templates("tmpl_permission_entry", $("#tmpl_permission_entry").html());
result = window.jsrender.templates("xxx", this.html());
*/
result = template(values);
result = $(result);
}
2018-09-30 20:36:17 +00:00
result.find("node").each((index, element) => {
2018-11-03 23:39:29 +00:00
$(element).replaceWith(values[$(element).attr("key")] || (values[0] || [])[$(element).attr("key")]);
2018-09-30 20:36:17 +00:00
});
2018-09-30 19:50:59 +00:00
return result;
}
}
2018-12-23 16:41:14 +00:00
if(!$.fn.hasScrollBar)
2019-04-04 19:47:52 +00:00
$.fn.hasScrollBar = function(direction?: "height" | "width") {
if(this.length <= 0)
return false;
const scroll_height = this.get(0).scrollHeight > this.height();
const scroll_width = this.get(0).scrollWidth > this.width();
if(typeof(direction) === "string") {
if(direction === "height")
return scroll_height;
if(direction === "width")
return scroll_width;
}
return scroll_width || scroll_height;
};
2018-12-23 16:41:14 +00:00
Implemented the Material Design and fixed some bugs (#33) * cleaned up some files * Fundamental style update * Redesigned some style * fixed hostbanner popup * Removed old identity stuff * fixed close listener * Fixed changelog date * fixed release chat icons * fixed url * Fixed hostbanner * Uploaded missing images * Improved update handling * Improved script files * Fixed loading error and icon error * fixed Yes/No modal * Fixed loader issues with MS Edge * fixed modal style bug * Fixed control bar overflow for small devices * Improved error handling on identity creation * Logging generate error to terminal * fixed possible php error * fixed some possible loading errors when other files have'nt been already loaded. * removed debug message * Changed emsrcypten flags * Improved codec error handling * removed webassembly as required dependency * Improved and fixed channel tree issues * Improved the sliders * Removed unneeded files * fixed loader versions cache * second slight performance improved (dont animate elements anymore if they are not shown) * Fixed query visibility setting * not showing useless client infos for query clients * Added an auto reconnect system * Added a canceled message and increased reconnect interval * removed implemented todo * fixed repetitive channel names * Reworked the channel tree selected lines * Fixed channel tree names * Fixed name alignment * fixed the native client * added min width to the server select groups to avoid a disappearing effect on shrink * fixed bugged downloaded icons
2019-02-17 15:08:10 +00:00
if(!$.fn.visible_height)
$.fn.visible_height = function (this: JQuery<HTMLElement>) {
const original_style = this.attr("style");
this.css({
position: 'absolute!important',
visibility: 'hidden!important',
display: 'block!important'
});
const result = this.height();
this.attr("style", original_style || "");
return result;
2020-03-30 11:44:18 +00:00
};
Implemented the Material Design and fixed some bugs (#33) * cleaned up some files * Fundamental style update * Redesigned some style * fixed hostbanner popup * Removed old identity stuff * fixed close listener * Fixed changelog date * fixed release chat icons * fixed url * Fixed hostbanner * Uploaded missing images * Improved update handling * Improved script files * Fixed loading error and icon error * fixed Yes/No modal * Fixed loader issues with MS Edge * fixed modal style bug * Fixed control bar overflow for small devices * Improved error handling on identity creation * Logging generate error to terminal * fixed possible php error * fixed some possible loading errors when other files have'nt been already loaded. * removed debug message * Changed emsrcypten flags * Improved codec error handling * removed webassembly as required dependency * Improved and fixed channel tree issues * Improved the sliders * Removed unneeded files * fixed loader versions cache * second slight performance improved (dont animate elements anymore if they are not shown) * Fixed query visibility setting * not showing useless client infos for query clients * Added an auto reconnect system * Added a canceled message and increased reconnect interval * removed implemented todo * fixed repetitive channel names * Reworked the channel tree selected lines * Fixed channel tree names * Fixed name alignment * fixed the native client * added min width to the server select groups to avoid a disappearing effect on shrink * fixed bugged downloaded icons
2019-02-17 15:08:10 +00:00
if(!$.fn.visible_width)
$.fn.visible_width = function (this: JQuery<HTMLElement>) {
const original_style = this.attr("style");
this.css({
position: 'absolute!important',
visibility: 'hidden!important',
display: 'block!important'
});
const result = this.width();
this.attr("style", original_style || "");
return result;
2020-03-30 11:44:18 +00:00
};
2019-08-21 08:00:01 +00:00
if(!$.fn.firstParent)
$.fn.firstParent = function (this: JQuery<HTMLElement>, selector: string) {
if(this.is(selector))
return this;
return this.parent(selector);
}
2018-02-27 16:20:49 +00:00
}
if (!String.prototype.format) {
String.prototype.format = function() {
2018-03-24 22:38:01 +00:00
const args = arguments;
2018-04-11 15:56:09 +00:00
let array = args.length == 1 && $.isArray(args[0]);
2018-02-27 16:20:49 +00:00
return this.replace(/\{\{|\}\}|\{(\d+)\}/g, function (m, n) {
if (m == "{{") { return "{"; }
if (m == "}}") { return "}"; }
2018-04-11 15:56:09 +00:00
return array ? args[0][n] : args[n];
2018-02-27 16:20:49 +00:00
});
};
}
function concatenate(resultConstructor, ...arrays) {
let totalLength = 0;
for (const arr of arrays) {
totalLength += arr.length;
}
const result = new resultConstructor(totalLength);
let offset = 0;
for (const arr of arrays) {
result.set(arr, offset);
offset += arr.length;
}
return result;
}
2018-08-10 19:30:58 +00:00
function calculate_width(text: string) : number {
let element = $.spawn("div");
element.text(text)
.css("display", "none")
.css("margin", 0);
$("body").append(element);
let size = element.width();
element.detach();
return size;
2018-02-27 16:20:49 +00:00
}