2022-06-03 15:49:36 +02:00
var DemoApp = {
initData : Telegram . WebApp . initData || '' ,
initDataUnsafe : Telegram . WebApp . initDataUnsafe || { } ,
MainButton : Telegram . WebApp . MainButton ,
2023-09-14 15:30:39 +02:00
BackButton : Telegram . WebApp . BackButton ,
2023-10-02 17:03:05 +02:00
SettingsButton : Telegram . WebApp . SettingsButton ,
2022-06-03 15:49:36 +02:00
init : function ( options ) {
$ ( 'body' ) . css ( 'visibility' , '' ) ;
Telegram . WebApp . ready ( ) ;
Telegram . WebApp . MainButton . setParams ( {
text : 'CLOSE WEBVIEW' ,
is _visible : true
} ) . onClick ( DemoApp . close ) ;
2023-09-14 15:30:39 +02:00
Telegram . WebApp . BackButton . onClick ( function ( ) {
DemoApp . showAlert ( 'Back button pressed' ) ;
} ) ;
2023-10-02 17:03:05 +02:00
Telegram . WebApp . SettingsButton . onClick ( function ( ) {
2023-09-07 14:08:48 +02:00
DemoApp . showAlert ( 'Settings opened!' ) ;
} ) ;
2022-06-03 15:49:36 +02:00
} ,
expand : function ( ) {
Telegram . WebApp . expand ( ) ;
} ,
close : function ( ) {
Telegram . WebApp . close ( ) ;
} ,
sendMessage : function ( msg _id , with _webview ) {
if ( ! DemoApp . initDataUnsafe . query _id ) {
alert ( 'WebViewQueryId not defined' ) ;
return ;
}
$ ( 'button' ) . prop ( 'disabled' , true ) ;
$ ( '#btn_status' ) . text ( 'Sending...' ) . removeClass ( 'ok err' ) . show ( ) ;
DemoApp . apiRequest ( 'sendMessage' , {
msg _id : msg _id || '' ,
with _webview : ! DemoApp . initDataUnsafe . receiver && with _webview ? 1 : 0
} , function ( result ) {
$ ( 'button' ) . prop ( 'disabled' , false ) ;
if ( result . response ) {
if ( result . response . ok ) {
$ ( '#btn_status' ) . html ( 'Message sent successfully!' ) . addClass ( 'ok' ) . show ( ) ;
} else {
$ ( '#btn_status' ) . text ( result . response . description ) . addClass ( 'err' ) . show ( ) ;
alert ( result . response . description ) ;
}
} else if ( result . error ) {
$ ( '#btn_status' ) . text ( result . error ) . addClass ( 'err' ) . show ( ) ;
alert ( result . error ) ;
} else {
$ ( '#btn_status' ) . text ( 'Unknown error' ) . addClass ( 'err' ) . show ( ) ;
alert ( 'Unknown error' ) ;
}
} ) ;
} ,
changeMenuButton : function ( close ) {
$ ( 'button' ) . prop ( 'disabled' , true ) ;
$ ( '#btn_status' ) . text ( 'Changing button...' ) . removeClass ( 'ok err' ) . show ( ) ;
DemoApp . apiRequest ( 'changeMenuButton' , { } , function ( result ) {
$ ( 'button' ) . prop ( 'disabled' , false ) ;
if ( result . response ) {
if ( result . response . ok ) {
$ ( '#btn_status' ) . html ( 'Button changed!' ) . addClass ( 'ok' ) . show ( ) ;
Telegram . WebApp . close ( ) ;
} else {
$ ( '#btn_status' ) . text ( result . response . description ) . addClass ( 'err' ) . show ( ) ;
alert ( result . response . description ) ;
}
} else if ( result . error ) {
$ ( '#btn_status' ) . text ( result . error ) . addClass ( 'err' ) . show ( ) ;
alert ( result . error ) ;
} else {
$ ( '#btn_status' ) . text ( 'Unknown error' ) . addClass ( 'err' ) . show ( ) ;
alert ( 'Unknown error' ) ;
}
} ) ;
if ( close ) {
setTimeout ( function ( ) {
Telegram . WebApp . close ( ) ;
} , 50 ) ;
}
} ,
checkInitData : function ( ) {
if ( DemoApp . initDataUnsafe . query _id &&
DemoApp . initData &&
$ ( '#webview_data_status' ) . hasClass ( 'status_need' ) ) {
$ ( '#webview_data_status' ) . removeClass ( 'status_need' ) ;
DemoApp . apiRequest ( 'checkInitData' , { } , function ( result ) {
if ( result . ok ) {
$ ( '#webview_data_status' ) . html ( 'Hash is correct (async)' ) . addClass ( 'ok' ) ;
} else {
$ ( '#webview_data_status' ) . html ( result . error + ' (async)' ) . addClass ( 'err' ) ;
}
} ) ;
}
} ,
sendText : function ( spam ) {
var text = $ ( '#text_field' ) . val ( ) ;
if ( ! text . length ) {
return $ ( '#text_field' ) . focus ( ) ;
}
if ( byteLength ( text ) > 4096 ) {
return alert ( 'Text is too long' ) ;
}
var repeat = spam ? 10 : 1 ;
for ( var i = 0 ; i < repeat ; i ++ ) {
Telegram . WebApp . sendData ( text ) ;
}
} ,
sendTime : function ( spam ) {
var repeat = spam ? 10 : 1 ;
for ( var i = 0 ; i < repeat ; i ++ ) {
Telegram . WebApp . sendData ( new Date ( ) . toString ( ) ) ;
}
} ,
2023-03-02 19:33:48 +01:00
switchInlineQuery : function ( query , choose _chat ) {
var choose _chat _types = false ;
if ( choose _chat ) {
var choose _chat _types = [ ] ;
var types = [ 'users' , 'bots' , 'groups' , 'channels' ] ;
for ( var i = 0 ; i < types . length ; i ++ ) {
if ( $ ( '#select-' + types [ i ] ) . prop ( 'checked' ) ) {
choose _chat _types . push ( types [ i ] ) ;
}
}
if ( ! choose _chat _types . length ) {
return DemoApp . showAlert ( 'Select chat types!' ) ;
}
}
Telegram . WebApp . switchInlineQuery ( query , choose _chat _types ) ;
} ,
2022-06-03 15:49:36 +02:00
requestLocation : function ( el ) {
if ( navigator . geolocation ) {
navigator . geolocation . getCurrentPosition ( function ( position ) {
$ ( el ) . next ( 'span' ) . html ( '(' + position . coords . latitude + ', ' + position . coords . longitude + ')' ) . attr ( 'class' , 'ok' ) ;
} ) ;
} else {
$ ( el ) . next ( 'span' ) . html ( 'Geolocation is not supported in this browser.' ) . attr ( 'class' , 'err' ) ;
}
return false ;
} ,
requestVideo : function ( el ) {
if ( navigator . mediaDevices ) {
navigator . mediaDevices . getUserMedia ( { audio : false , video : true } ) . then ( function ( stream ) {
$ ( el ) . next ( 'span' ) . html ( '(Access granted)' ) . attr ( 'class' , 'ok' ) ;
} ) ;
} else {
$ ( el ) . next ( 'span' ) . html ( 'Media devices is not supported in this browser.' ) . attr ( 'class' , 'err' ) ;
}
return false ;
} ,
requestAudio : function ( el ) {
if ( navigator . mediaDevices ) {
navigator . mediaDevices . getUserMedia ( { audio : true , video : false } ) . then ( function ( stream ) {
$ ( el ) . next ( 'span' ) . html ( '(Access granted)' ) . attr ( 'class' , 'ok' ) ;
} ) ;
} else {
$ ( el ) . next ( 'span' ) . html ( 'Media devices is not supported in this browser.' ) . attr ( 'class' , 'err' ) ;
}
return false ;
} ,
2022-11-23 17:27:46 +01:00
requestAudioVideo : function ( el ) {
if ( navigator . mediaDevices ) {
navigator . mediaDevices . getUserMedia ( { audio : true , video : true } ) . then ( function ( stream ) {
$ ( el ) . next ( 'span' ) . html ( '(Access granted)' ) . attr ( 'class' , 'ok' ) ;
} ) ;
} else {
$ ( el ) . next ( 'span' ) . html ( 'Media devices is not supported in this browser.' ) . attr ( 'class' , 'err' ) ;
}
return false ;
} ,
testClipboard : function ( el ) {
2022-12-13 15:46:38 +01:00
Telegram . WebApp . readTextFromClipboard ( function ( clipText ) {
if ( clipText === null ) {
$ ( el ) . next ( 'span' ) . html ( 'Clipboard text unavailable.' ) . attr ( 'class' , 'err' ) ;
} else {
2022-11-23 17:27:46 +01:00
$ ( el ) . next ( 'span' ) . text ( '(Read from clipboard: «' + clipText + '»)' ) . attr ( 'class' , 'ok' ) ;
2022-12-13 15:46:38 +01:00
}
} ) ;
2022-11-23 17:27:46 +01:00
return false ;
} ,
2023-08-25 14:44:38 +02:00
requestWriteAccess : function ( el ) {
Telegram . WebApp . requestWriteAccess ( function ( allowed ) {
if ( allowed ) {
$ ( el ) . next ( 'span' ) . text ( '(Access granted)' ) . attr ( 'class' , 'ok' ) ;
} else {
$ ( el ) . next ( 'span' ) . html ( '(User declined this request)' ) . attr ( 'class' , 'err' ) ;
}
} ) ;
} ,
requestPhoneNumber : function ( el ) {
2023-10-05 16:50:03 +02:00
Telegram . WebApp . requestContact ( function ( sent , event ) {
2023-08-25 14:44:38 +02:00
if ( sent ) {
2023-10-05 16:50:03 +02:00
$ ( el ) . next ( 'span' ) . text ( '(Phone number sent to the bot' + ( event && event . responseUnsafe && event . responseUnsafe . contact && event . responseUnsafe . contact . phone _number ? ': +' + event . responseUnsafe . contact . phone _number : '' ) + ')' ) . attr ( 'class' , 'ok' ) ;
2023-08-25 14:44:38 +02:00
} else {
$ ( el ) . next ( 'span' ) . html ( '(User declined this request)' ) . attr ( 'class' , 'err' ) ;
}
} ) ;
} ,
requestServerTime : function ( el ) {
Telegram . WebApp . invokeCustomMethod ( 'getCurrentTime' , { } , function ( err , time ) {
if ( err ) {
$ ( el ) . next ( 'span' ) . html ( '(' + cleanHTML ( err ) + ')' ) . attr ( 'class' , 'err' ) ;
} else {
$ ( el ) . next ( 'span' ) . text ( '(' + ( new Date ( time * 1000 ) ) . toString ( ) + ')' ) . attr ( 'class' , 'ok' ) ;
}
} ) ;
} ,
2023-08-26 14:03:09 +02:00
cloudStorageKeys : { } ,
cloudStorageItems : { } ,
editCloudRow : function ( el , event ) {
event . preventDefault ( ) ;
var values = DemoApp . cloudStorageItems ;
var key = $ ( el ) . parents ( 'tr' ) . attr ( 'data-key' ) ;
el . form . reset ( ) ;
el . form . key . value = key ;
el . form . value . value = values [ key ] ;
} ,
deleteCloudRow : function ( el , event ) {
event . preventDefault ( ) ;
var key = $ ( el ) . parents ( 'tr' ) . attr ( 'data-key' ) ;
Telegram . WebApp . CloudStorage . removeItem ( key , function ( err , deleted ) {
if ( err ) {
DemoApp . showAlert ( 'Error: ' + err ) ;
} else {
if ( deleted ) {
var index = DemoApp . cloudStorageKeys . indexOf ( key ) ;
if ( index >= 0 ) {
DemoApp . cloudStorageKeys . splice ( index , 1 ) ;
}
delete DemoApp . cloudStorageItems [ key ] ;
}
el . form . reset ( ) ;
DemoApp . updateCloudRows ( ) ;
}
} ) ;
} ,
saveCloudForm : function ( form , event ) {
event . preventDefault ( ) ;
var key = form . key . value ;
var value = form . value . value ;
Telegram . WebApp . CloudStorage . setItem ( key , value , function ( err , saved ) {
if ( err ) {
DemoApp . showAlert ( 'Error: ' + err ) ;
} else {
if ( saved ) {
if ( typeof DemoApp . cloudStorageItems [ key ] === 'undefined' ) {
DemoApp . cloudStorageKeys . push ( key ) ;
}
DemoApp . cloudStorageItems [ key ] = value ;
}
form . reset ( ) ;
DemoApp . updateCloudRows ( ) ;
}
} ) ;
} ,
updateCloudRows : function ( ) {
var html = '' ;
var keys = DemoApp . cloudStorageKeys ;
var values = DemoApp . cloudStorageItems ;
for ( var i = 0 ; i < keys . length ; i ++ ) {
var key = keys [ i ] ;
html += '<tr data-key="' + cleanHTML ( key ) + '"><td>' + cleanHTML ( key ) + '</td><td>' + cleanHTML ( values [ key ] ) + '</td><td><button onclick="DemoApp.editCloudRow(this, event);">Edit</button><button onclick="DemoApp.deleteCloudRow(this, event);">Delete</button></td></tr>' ;
}
$ ( '#cloud_rows' ) . html ( html ) ;
} ,
loadCloudKeys : function ( el ) {
Telegram . WebApp . CloudStorage . getKeys ( function ( err , keys ) {
if ( err ) {
DemoApp . showAlert ( 'Error: ' + err ) ;
} else {
if ( keys . length > 0 ) {
Telegram . WebApp . CloudStorage . getItems ( keys , function ( err , values ) {
if ( err ) {
DemoApp . showAlert ( 'Error: ' + err ) ;
} else {
DemoApp . cloudStorageKeys = keys ;
DemoApp . cloudStorageItems = { } ;
for ( var i = 0 ; i < keys . length ; i ++ ) {
var key = keys [ i ] ;
DemoApp . cloudStorageItems [ key ] = values [ key ] ;
}
DemoApp . updateCloudRows ( ) ;
}
} ) ;
}
}
} ) ;
} ,
2022-06-03 15:49:36 +02:00
toggleMainButton : function ( el ) {
if ( DemoApp . MainButton . isVisible ) {
DemoApp . MainButton . hide ( ) ;
el . innerHTML = 'Show Main Button' ;
} else {
DemoApp . MainButton . show ( ) ;
el . innerHTML = 'Hide Main Button' ;
}
} ,
2023-09-14 15:30:39 +02:00
toggleBackButton : function ( el ) {
if ( DemoApp . BackButton . isVisible ) {
DemoApp . BackButton . hide ( ) ;
el . innerHTML = 'Show Back Button' ;
} else {
DemoApp . BackButton . show ( ) ;
el . innerHTML = 'Hide Back Button' ;
}
} ,
2023-10-02 17:03:05 +02:00
toggleSettingsButton : function ( el ) {
if ( DemoApp . SettingsButton . isVisible ) {
DemoApp . SettingsButton . hide ( ) ;
el . innerHTML = 'Show Settings Button' ;
} else {
DemoApp . SettingsButton . show ( ) ;
el . innerHTML = 'Hide Settings Button' ;
}
} ,
2022-07-01 18:14:00 +02:00
showAlert : function ( message ) {
Telegram . WebApp . showAlert ( message ) ;
} ,
showConfirm : function ( message ) {
Telegram . WebApp . showConfirm ( message ) ;
} ,
showPopup : function ( ) {
Telegram . WebApp . showPopup ( {
title : 'Popup title' ,
message : 'Popup message' ,
buttons : [
{ id : 'delete' , type : 'destructive' , text : 'Delete all' } ,
{ id : 'faq' , type : 'default' , text : 'Open FAQ' } ,
{ type : 'cancel' } ,
]
} , function ( button _id ) {
if ( button _id == 'delete' ) {
DemoApp . showAlert ( "'Delete all' selected" ) ;
} else if ( button _id == 'faq' ) {
Telegram . WebApp . openLink ( 'https://telegram.org/faq' ) ;
}
} ) ;
} ,
2022-12-14 14:55:38 +01:00
showScanQrPopup : function ( links _only ) {
2022-12-13 15:46:38 +01:00
Telegram . WebApp . showScanQrPopup ( {
2022-12-14 14:55:38 +01:00
text : links _only ? 'with any link' : 'for test purposes'
2022-12-13 15:46:38 +01:00
} , function ( text ) {
2022-12-14 14:55:38 +01:00
if ( links _only ) {
2022-12-15 20:37:50 +01:00
var lower _text = text . toString ( ) . toLowerCase ( ) ;
2022-12-14 14:55:38 +01:00
if ( lower _text . substr ( 0 , 7 ) == 'http://' ||
lower _text . substr ( 0 , 8 ) == 'https://' ) {
setTimeout ( function ( ) {
Telegram . WebApp . openLink ( text ) ;
} , 50 ) ;
return true ;
}
} else {
2022-12-13 15:46:38 +01:00
DemoApp . showAlert ( text ) ;
2022-12-14 14:55:38 +01:00
return true ;
2022-12-13 15:46:38 +01:00
}
} ) ;
} ,
2022-06-03 15:49:36 +02:00
apiRequest : function ( method , data , onCallback ) {
var authData = DemoApp . initData || '' ;
2023-09-01 21:39:40 +02:00
$ . ajax ( DemoApp . apiUrl , {
2022-06-03 15:49:36 +02:00
type : 'POST' ,
data : $ . extend ( data , { _auth : authData , method : method } ) ,
dataType : 'json' ,
xhrFields : {
withCredentials : true
} ,
success : function ( result ) {
onCallback && onCallback ( result ) ;
} ,
error : function ( xhr ) {
onCallback && onCallback ( { error : 'Server error' } ) ;
}
} ) ;
}
} ;
var DemoAppMenu = {
init : function ( ) {
DemoApp . init ( ) ;
$ ( 'body' ) . addClass ( 'gray' ) ;
Telegram . WebApp . setHeaderColor ( 'secondary_bg_color' ) ;
}
} ;
var DemoAppInitData = {
init : function ( ) {
DemoApp . init ( ) ;
// $('body').addClass('gray');
// Telegram.WebApp.setHeaderColor('secondary_bg_color');
Telegram . WebApp . onEvent ( 'themeChanged' , function ( ) {
$ ( '#theme_data' ) . html ( JSON . stringify ( Telegram . WebApp . themeParams , null , 2 ) ) ;
} ) ;
$ ( '#webview_data' ) . html ( JSON . stringify ( DemoApp . initDataUnsafe , null , 2 ) ) ;
$ ( '#theme_data' ) . html ( JSON . stringify ( Telegram . WebApp . themeParams , null , 2 ) ) ;
DemoApp . checkInitData ( ) ;
}
} ;
var DemoAppViewport = {
init : function ( ) {
DemoApp . init ( ) ;
// $('body').addClass('gray');
// Telegram.WebApp.setHeaderColor('secondary_bg_color');
Telegram . WebApp . onEvent ( 'viewportChanged' , DemoAppViewport . setData ) ;
DemoAppViewport . setData ( ) ;
} ,
setData : function ( ) {
$ ( '.viewport-border' ) . attr ( 'text' , window . innerWidth + ' x ' + round ( Telegram . WebApp . viewportHeight , 2 ) ) ;
$ ( '.viewport-stable_border' ) . attr ( 'text' , window . innerWidth + ' x ' + round ( Telegram . WebApp . viewportStableHeight , 2 ) + ' | is_expanded: ' + ( Telegram . WebApp . isExpanded ? 'true' : 'false' ) ) ;
}
} ;
2023-08-26 14:03:09 +02:00
function cleanHTML ( value ) {
return value . replace ( /&/g , '&' ) . replace ( /</g , '<' ) . replace ( />/g , '>' ) . replace ( /"/g , '"' ) . replace ( /\n/g , '<br/>' ) ;
}
2022-06-03 15:49:36 +02:00
function byteLength ( str ) {
if ( window . Blob ) {
try { return new Blob ( [ str ] ) . size ; } catch ( e ) { }
}
var s = str . length ;
for ( var i = str . length - 1 ; i >= 0 ; i -- ) {
var code = str . charCodeAt ( i ) ;
if ( code > 0x7f && code <= 0x7ff ) s ++ ;
else if ( code > 0x7ff && code <= 0xffff ) s += 2 ;
if ( code >= 0xDC00 && code <= 0xDFFF ) i -- ;
}
return s ;
}
function round ( val , d ) {
var k = Math . pow ( 10 , d || 0 ) ;
return Math . round ( val * k ) / k ;
}
2023-09-14 15:30:39 +02:00
( function ( $ ) {
$ . fn . cssProp = function ( prop , val ) {
if ( typeof val !== 'undefined' ) {
return this . each ( function ( ) {
if ( this . style && this . style . setProperty ) {
this . style . setProperty ( prop , val ) ;
}
} ) ;
}
return this . first ( ) . map ( function ( ) {
if ( this . style && this . style . getPropertyValue ) {
return this . style . getPropertyValue ( prop ) ;
} else {
return '' ;
}
} ) . get ( 0 ) || '' ;
} ;
} ) ( jQuery ) ;