mirror of
https://github.com/MarshalX/telegram-crawler.git
synced 2024-12-29 15:59:13 +01:00
Update content of files
This commit is contained in:
parent
9fa9615c2c
commit
ca6c5e5a4e
4 changed files with 1124 additions and 0 deletions
50
data/web/fragment.com/about.html
Normal file
50
data/web/fragment.com/about.html
Normal file
|
@ -0,0 +1,50 @@
|
|||
<!DOCTYPE html>
|
||||
<html>
|
||||
<head>
|
||||
<meta charset="utf-8">
|
||||
<title>Fragment</title>
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=no" />
|
||||
<meta name="format-detection" content="telephone=no" />
|
||||
<meta http-equiv="X-UA-Compatible" content="IE=edge" />
|
||||
<meta name="MobileOptimized" content="176" />
|
||||
<meta name="HandheldFriendly" content="True" />
|
||||
<link rel="shortcut icon" href="/img/fragment.ico" type="image/x-icon" />
|
||||
<link rel="mask-icon" href="/img/fragment_icon.svg" color="#121519">
|
||||
<script>document.cookie="stel_dt="+encodeURIComponent((new Date).getTimezoneOffset())+";path=/;max-age=31536000;samesite=None;secure"</script>
|
||||
|
||||
<link href="/css/font-roboto.css?1" rel="stylesheet" type="text/css">
|
||||
<link href="/css/bootstrap.min.css?3" rel="stylesheet">
|
||||
<link href="/css/bootstrap-extra.css?2" rel="stylesheet">
|
||||
<link href="/css/auction.css?24" rel="stylesheet">
|
||||
|
||||
</head>
|
||||
<body class="emoji_image no-transition">
|
||||
|
||||
<div id="aj_progress" class="progress-bar"></div>
|
||||
|
||||
<div id="aj_content"> <main class="tm-unavailable">
|
||||
<div class="tm-logo js-logo js-logo-clickable">
|
||||
<i class="tm-logo-icon js-logo-icon"></i>
|
||||
</div>
|
||||
<h1 class="tm-unavailable-header">
|
||||
Oops
|
||||
</h1>
|
||||
<p class="tm-unavailable-text">
|
||||
This service is not available in the United States.
|
||||
</p>
|
||||
</main></div>
|
||||
<script src="/js/jquery.min.js?1"></script>
|
||||
<script src="/js/bootstrap.min.js"></script>
|
||||
<script src="/js/main-aj.js?64"></script>
|
||||
<script src="/js/jquery-ex.js?13"></script>
|
||||
<script src="/js/qr-code-styling.js?1"></script>
|
||||
<script src="/js/auction.js?23"></script>
|
||||
|
||||
<script>ajInit({"version":363,"apiUrl":"\/api?hash=telegram-crawler","unauth":true});</script>
|
||||
<script id="aj_script">Main.init();
|
||||
</script>
|
||||
<script>Aj.pageLoaded();</script>
|
||||
|
||||
</body>
|
||||
</html>
|
||||
|
974
data/web/fragment.com/js/auction.js
Normal file
974
data/web/fragment.com/js/auction.js
Normal file
|
@ -0,0 +1,974 @@
|
|||
|
||||
var Main = {
|
||||
init: function() {
|
||||
Aj.onLoad(function(state) {
|
||||
var cont = Aj.ajContainer;
|
||||
$(window).on('resize', Main.onResize);
|
||||
$('.js-logo-hoverable').on('mouseover', Main.playLogo);
|
||||
$('.js-logo-clickable').on('click', Main.playLogo);
|
||||
$('.js-logo-icon').on('animationend', Main.eLogoAnimEnd);
|
||||
$(cont).on('click.curPage', '.js-header-menu-button', Main.eHeaderMenu);
|
||||
$(cont).on('click.curPage', '.js-header-menu-close-button', Main.eHeaderMenuClose);
|
||||
$(cont).on('click.curPage', '.js-btn-tonkeeper', Main.eTonkeeperOpen);
|
||||
$(cont).on('click.curPage', '.js-form-clear', Main.eFormClear);
|
||||
$(cont).on('click.curPage', '.js-auction-unavail', Main.eAuctionUnavailable);
|
||||
$(cont).on('click.curPage', '.js-howitworks', Main.eHowitworks);
|
||||
$(cont).on('click.curPage', '.logout-link', Login.logOut);
|
||||
$(cont).on('click.curPage', '.ton-logout-link', Login.tonLogOut);
|
||||
state.$headerMenu = $('.js-header-menu');
|
||||
state.$unavailPopup = $('.js-unavailable-popup');
|
||||
state.$howitworksPopup = $('.js-howitworks-popup');
|
||||
Main.updateTime();
|
||||
Main.initViewport();
|
||||
Main.initLogo();
|
||||
});
|
||||
Aj.onUnload(function(state) {
|
||||
$(window).off('resize', Main.onResize);
|
||||
$('.js-logo-hoverable').off('mouseover', Main.playLogo);
|
||||
$('.js-logo-clickable').off('click', Main.playLogo);
|
||||
$('.js-logo-icon').off('animationend', Main.eLogoAnimEnd);
|
||||
});
|
||||
},
|
||||
initForm: function(form) {
|
||||
var $form = $(form);
|
||||
$('.js-amount-input', $form).on('keyup change input', Main.eUpdateAmountField);
|
||||
$('.js-amount-input', $form).trigger('input');
|
||||
},
|
||||
destroyForm: function(form) {
|
||||
var $form = $(form);
|
||||
$('.js-amount-input', $form).off('keyup change input', Main.eUpdateAmountField);
|
||||
},
|
||||
updateTime: function() {
|
||||
var now = Math.round(+(new Date) / 1000);
|
||||
if (Main._lastUpdateTime != now) {
|
||||
Main._lastUpdateTime = now;
|
||||
$('time[datetime]', Aj.ajContainer).each(function () {
|
||||
var $time = $(this), datetime = $time.attr('datetime');
|
||||
var mode = $time.attr('data-relative');
|
||||
if (mode) {
|
||||
var date = new Date(datetime);
|
||||
var cur_date = new Date();
|
||||
var time_left = Math.floor((date - cur_date) / 1000);
|
||||
var ended = time_left < 0;
|
||||
if (time_left < 0) time_left = 0;
|
||||
var days = Math.floor(time_left / 86400);
|
||||
var hours = Math.floor((time_left % 86400) / 3600);
|
||||
var minutes = Math.floor((time_left % 3600) / 60);
|
||||
var seconds = (time_left % 60);
|
||||
var days_html = l('{n:# days|# day|# days}', {n: days});
|
||||
if (mode == 'counter') {
|
||||
var hours0 = Math.floor(hours / 10);
|
||||
var hours1 = hours % 10;
|
||||
var minutes0 = Math.floor(minutes / 10);
|
||||
var minutes1 = minutes % 10;
|
||||
var seconds0 = Math.floor(seconds / 10);
|
||||
var seconds1 = seconds % 10;
|
||||
Main.updateDigit($('.timer-d', this), days_html);
|
||||
Main.updateDigit($('.timer-h0', this), hours0);
|
||||
Main.updateDigit($('.timer-h1', this), hours1);
|
||||
Main.updateDigit($('.timer-m0', this), minutes0);
|
||||
Main.updateDigit($('.timer-m1', this), minutes1);
|
||||
Main.updateDigit($('.timer-s0', this), seconds0);
|
||||
Main.updateDigit($('.timer-s1', this), seconds1);
|
||||
} else {
|
||||
var arr = [];
|
||||
if (days > 0) {
|
||||
arr.push(days_html);
|
||||
}
|
||||
if (arr.length || hours > 0) {
|
||||
arr.push(l('{n:# hours|# hour|# hours}', {n: hours}));
|
||||
}
|
||||
if (arr.length || minutes > 0) {
|
||||
arr.push(l('{n:# minutes|# minute|# minutes}', {n: minutes}));
|
||||
}
|
||||
if (!days && !hours && (mode == 'text' || !minutes)) {
|
||||
arr.push(l('{n:# seconds|# second|# seconds}', {n: seconds}));
|
||||
}
|
||||
arr = arr.slice(0, mode == 'text' ? 3 : 2);
|
||||
$time.html(arr.join(' '));
|
||||
}
|
||||
$(this).closest('.js-timer-wrap').toggleClass('ended', ended);
|
||||
} else {
|
||||
var title = $time.attr('title'),
|
||||
html = $time.html(),
|
||||
new_html = formatDateTime(datetime, false, !$time.hasClass('short'));
|
||||
if (html != new_html) {
|
||||
$time.html(new_html);
|
||||
}
|
||||
$time.removeAttr('datetime');
|
||||
}
|
||||
});
|
||||
}
|
||||
requestAnimationFrame(Main.updateTime);
|
||||
},
|
||||
updateDigit: function($el, value) {
|
||||
var cur_value = $el.attr('data-val');
|
||||
if (cur_value != value) {
|
||||
$el.removeAttr('data-prev-val');
|
||||
$el.map(function(){ this.offsetTop; });
|
||||
$el.attr('data-val', value);
|
||||
$el.attr('data-prev-val', cur_value);
|
||||
}
|
||||
},
|
||||
initViewport: function() {
|
||||
if (!window.$viewportHelper) {
|
||||
window.$viewportHelper = $('<div>').css({position: 'absolute', left: '-100px', top: '0', height: '100vh'}).appendTo('body');
|
||||
}
|
||||
Main.onResize();
|
||||
},
|
||||
onResize: function() {
|
||||
var vh = window.innerHeight;
|
||||
if (window.$viewportHelper && window.$viewportHelper.height() != vh) {
|
||||
document.documentElement.style.setProperty('--viewport-height', vh + 'px');
|
||||
} else {
|
||||
document.documentElement.style.removeProperty('--viewport-height');
|
||||
}
|
||||
},
|
||||
initLogo: function() {
|
||||
if (!Aj.globalState.logoInited) {
|
||||
Aj.globalState.logoInited = true;
|
||||
var main_url = '/img/TelemintLogoSprite1.svg';
|
||||
var mainLogo = new Image();
|
||||
mainLogo.onload = function() {
|
||||
Aj.globalState.logoImageMain = main_url;
|
||||
Main.playLogo(true);
|
||||
};
|
||||
mainLogo.src = main_url;
|
||||
var url2 = '/img/TelemintLogoSprite2.svg';
|
||||
var logo2 = new Image();
|
||||
logo2.onload = function() {
|
||||
Aj.globalState.logoImage2 = url2;
|
||||
};
|
||||
logo2.src = url2;
|
||||
var url3 = '/img/TelemintLogoSprite3.svg';
|
||||
var logo3 = new Image();
|
||||
logo3.onload = function() {
|
||||
Aj.globalState.logoImage3 = url3;
|
||||
};
|
||||
logo3.src = url3;
|
||||
}
|
||||
},
|
||||
playLogo: function(main) {
|
||||
if (!$('.js-logo').hasClass('play')) {
|
||||
var url = Aj.globalState.logoImageMain;
|
||||
if (!main) {
|
||||
var rnd = Math.random();
|
||||
if (rnd > 0.9 && Aj.globalState.logoImage3) {
|
||||
url = Aj.globalState.logoImage3;
|
||||
} else if (rnd > 0.8 && Aj.globalState.logoImage2) {
|
||||
url = Aj.globalState.logoImage2;
|
||||
}
|
||||
}
|
||||
$('.js-logo').each(function() {
|
||||
this.style.setProperty('--image-url-logo-icon-animated', 'url(\'' + url + '\')');
|
||||
});
|
||||
$('.js-logo').addClass('play');
|
||||
}
|
||||
},
|
||||
eLogoAnimEnd: function(e) {
|
||||
$('.js-logo').removeClass('play');
|
||||
},
|
||||
eHeaderMenu: function(e) {
|
||||
e.preventDefault();
|
||||
openPopup(Aj.state.$headerMenu, {
|
||||
noAppend: true
|
||||
});
|
||||
},
|
||||
eHeaderMenuClose: function(e) {
|
||||
e.preventDefault();
|
||||
closePopup(Aj.state.$headerMenu);
|
||||
},
|
||||
eFormClear: function(e) {
|
||||
var form = $(this).closest('form').get(0);
|
||||
if (form) {
|
||||
form.query.value = '';
|
||||
form.submit();
|
||||
}
|
||||
},
|
||||
eAuctionUnavailable: function(e) {
|
||||
e.preventDefault();
|
||||
var username = $(this).attr('data-username');
|
||||
var later = +$(this).attr('data-later');
|
||||
var onEnterPress = function(e) {
|
||||
if (e.keyCode == Keys.RETURN) {
|
||||
e.stopImmediatePropagation();
|
||||
closePopup(Aj.state.$unavailPopup);
|
||||
}
|
||||
};
|
||||
openPopup(Aj.state.$unavailPopup, {
|
||||
onOpen: function() {
|
||||
$('.js-username', this).html(username);
|
||||
$('.js-unavailable-text', this).toggleClass('hide', !!later);
|
||||
$('.js-available-later-text', this).toggleClass('hide', !later);
|
||||
$(document).on('keydown', onEnterPress);
|
||||
},
|
||||
onClose: function() {
|
||||
$(document).off('keydown', onEnterPress);
|
||||
}
|
||||
});
|
||||
},
|
||||
eHowitworks: function(e) {
|
||||
e.preventDefault();
|
||||
e.stopImmediatePropagation();
|
||||
var onEnterPress = function(e) {
|
||||
if (e.keyCode == Keys.RETURN) {
|
||||
e.stopImmediatePropagation();
|
||||
closePopup(Aj.state.$howitworksPopup);
|
||||
}
|
||||
};
|
||||
openPopup(Aj.state.$howitworksPopup, {
|
||||
onOpen: function() {
|
||||
$(document).on('keydown', onEnterPress);
|
||||
},
|
||||
onClose: function() {
|
||||
$(document).off('keydown', onEnterPress);
|
||||
}
|
||||
});
|
||||
},
|
||||
amountFieldValue: function($form, field) {
|
||||
var $fieldEl = field ? $form.field(field) : $form;
|
||||
var minValue = $fieldEl.attr('data-min') || null;
|
||||
var maxValue = $fieldEl.attr('data-max') || null;
|
||||
var decPoint = $fieldEl.attr('data-dec-point') || '.';
|
||||
var value = $fieldEl.value();
|
||||
|
||||
var float_value = value.length ? value : '0';
|
||||
if (decPoint != '.') {
|
||||
float_value.split(decPoint).join('.');
|
||||
}
|
||||
float_value = parseFloat(float_value);
|
||||
if (isNaN(float_value) || float_value >= 1e12) {
|
||||
return false;
|
||||
}
|
||||
if (minValue !== null && float_value < minValue ||
|
||||
maxValue !== null && float_value > maxValue) {
|
||||
return false;
|
||||
} else {
|
||||
return float_value;
|
||||
}
|
||||
},
|
||||
eUpdateAmountField: function(e) {
|
||||
var $fieldEl = $(this);
|
||||
var minValue = $fieldEl.attr('data-min') || null;
|
||||
var maxValue = $fieldEl.attr('data-max') || null;
|
||||
var decPoint = $fieldEl.attr('data-dec-point') || '.';
|
||||
var decimals = $fieldEl.attr('data-decimals') || 0;
|
||||
var sel_dir = this.selectionDirection;
|
||||
var sel_start = this.selectionStart;
|
||||
var sel_end = this.selectionEnd;
|
||||
var value = this.value;
|
||||
var new_sel_start = sel_start;
|
||||
var new_sel_end = sel_end;
|
||||
var new_value = '';
|
||||
var has_decimal = false;
|
||||
var chars_len = 0;
|
||||
var decimal_len = 0;
|
||||
for (var i = 0; i < value.length; i++) {
|
||||
var char = value[i];
|
||||
if ((char == '.' || char == ',') && !has_decimal && decimals > 0) {
|
||||
if (!chars_len) {
|
||||
new_value += '0';
|
||||
if (i < sel_start) new_sel_start++;
|
||||
if (i < sel_end) new_sel_end++;
|
||||
}
|
||||
has_decimal = true;
|
||||
new_value += decPoint;
|
||||
} else if (char >= '0' && char <= '9' && (!has_decimal || decimal_len < decimals)) {
|
||||
new_value += char;
|
||||
if (has_decimal) decimal_len++;
|
||||
else chars_len++;
|
||||
} else {
|
||||
if (i < sel_start) new_sel_start--;
|
||||
if (i < sel_end) new_sel_end--;
|
||||
}
|
||||
}
|
||||
this.value = new_value;
|
||||
this.setSelectionRange(new_sel_start, new_sel_end, sel_dir);
|
||||
var float_value = new_value.length ? new_value : '0';
|
||||
if (decPoint != '.') {
|
||||
float_value.split(decPoint).join('.');
|
||||
}
|
||||
float_value = parseFloat(float_value);
|
||||
var is_invalid = (isNaN(float_value) || float_value >= 1e12);
|
||||
var field_value = float_value;
|
||||
if (minValue !== null && float_value < minValue ||
|
||||
maxValue !== null && float_value > maxValue ||
|
||||
is_invalid) {
|
||||
field_value = false;
|
||||
// Main.showFieldError($fieldEl);
|
||||
} else {
|
||||
// Main.hideFieldError($fieldEl);
|
||||
}
|
||||
if (e.type == 'change') {
|
||||
if (new_value.length && !is_invalid) {
|
||||
this.value = Main.wrapTonAmount(float_value, true);
|
||||
}
|
||||
}
|
||||
if (e.type == 'input') {
|
||||
var forClass, usdForClass;
|
||||
if (forClass = $fieldEl.attr('data-for')) {
|
||||
$('.' + forClass).html(Main.wrapTonAmount(field_value));
|
||||
}
|
||||
if (usdForClass = $fieldEl.attr('data-usd-for')) {
|
||||
$('.' + usdForClass).html(Main.wrapUsdAmount(field_value));
|
||||
}
|
||||
}
|
||||
},
|
||||
wrapTonAmount: function(value, field_format) {
|
||||
if (!value) {
|
||||
return '';
|
||||
}
|
||||
var dec = (Math.floor(value * 1000000) % 1000000) + '';
|
||||
while (dec.substr(-1) == '0') {
|
||||
dec = dec.slice(0, -1);
|
||||
}
|
||||
return formatNumber(value, dec.length, '.', field_format ? '' : ',');
|
||||
},
|
||||
wrapUsdAmount: function(value, field_format) {
|
||||
if (!value) {
|
||||
return '';
|
||||
}
|
||||
value = Math.round(value * Aj.state.tonRate * 100) / 100;
|
||||
return formatNumber(value, (value % 1) && value < 1000 ? 2 : 0, '.', field_format ? '' : ',');
|
||||
},
|
||||
eTonkeeperOpen: function(e) {
|
||||
e.stopImmediatePropagation();
|
||||
e.preventDefault();
|
||||
var href = $(this).attr('data-href');
|
||||
if (href) {
|
||||
location.href = href;
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
var Login = {
|
||||
init: function(options) {
|
||||
Telegram.Login.init(options, function(user) {
|
||||
if (user) {
|
||||
Login.auth(user);
|
||||
}
|
||||
});
|
||||
},
|
||||
open: function() {
|
||||
Telegram.Login.open();
|
||||
},
|
||||
checkAuth: function (e) {
|
||||
if (Aj.state.unAuth) {
|
||||
e && e.preventDefault();
|
||||
Login.open();
|
||||
return false;
|
||||
}
|
||||
return true;
|
||||
},
|
||||
auth: function(user) {
|
||||
var auth_data = window.btoa(encodeURIComponent(JSON.stringify(user)));
|
||||
Aj.apiRequest('logIn', {
|
||||
auth: auth_data
|
||||
}, function(result) {
|
||||
if (result.error) {
|
||||
return showAlert(result.error);
|
||||
}
|
||||
location.reload();
|
||||
});
|
||||
},
|
||||
logOut: function (e) {
|
||||
e.preventDefault();
|
||||
e.stopImmediatePropagation();
|
||||
Aj.apiRequest('logOut', {}, function(result) {
|
||||
location.reload();
|
||||
});
|
||||
return false;
|
||||
},
|
||||
tonLogOut: function(e) {
|
||||
e.preventDefault();
|
||||
e.stopImmediatePropagation();
|
||||
Aj.apiRequest('tonLogOut', {}, function(result) {
|
||||
location.reload();
|
||||
});
|
||||
return false;
|
||||
}
|
||||
};
|
||||
|
||||
var Auction = {
|
||||
UPDATE_PERIOD: 1200,
|
||||
init: function() {
|
||||
Aj.onLoad(function(state) {
|
||||
$(document).on('click.curPage', '.js-place-bid-btn', Auction.ePlaceBid);
|
||||
$(document).on('submit.curPage', '.js-place-bid-form', Auction.ePlaceBidSubmit);
|
||||
$(document).on('click.curPage', '.js-buy-now-btn', Auction.eBuyNow);
|
||||
$(document).on('click.curPage', '.js-subscribe-btn', Auction.eSubscribe);
|
||||
$(document).on('click.curPage', '.js-unsubscribe-btn', Auction.eUnsubscribe);
|
||||
$(document).on('click.curPage', '.js-load-more-orders', Auction.eLoadMoreOrders);
|
||||
$(document).on('click.curPage', '.js-load-more-owners', Auction.eLoadMoreOwners);
|
||||
state.$bidPopup = $('.js-place-bid-popup');
|
||||
state.$bidForm = $('.js-place-bid-form');
|
||||
Main.initForm(state.$bidForm);
|
||||
state.needUpdate = true;
|
||||
state.updStateTo = setTimeout(Auction.updateState, Auction.UPDATE_PERIOD);
|
||||
Assets.init();
|
||||
});
|
||||
Aj.onUnload(function(state) {
|
||||
Main.destroyForm(state.$bidForm);
|
||||
clearTimeout(state.updStateTo);
|
||||
state.needUpdate = false;
|
||||
});
|
||||
},
|
||||
updateState: function() {
|
||||
Aj.apiRequest('updateAuction', {
|
||||
address: Aj.state.auctionAddress,
|
||||
lt: Aj.state.auctionLastLt
|
||||
}, function(result) {
|
||||
if (result.html) {
|
||||
$('.js-main-content').html(result.html);
|
||||
}
|
||||
if (result.lt) {
|
||||
Aj.state.auctionLastLt = result.lt;
|
||||
}
|
||||
if (Aj.state.needUpdate) {
|
||||
Aj.state.updStateTo = setTimeout(Auction.updateState, Auction.UPDATE_PERIOD);
|
||||
}
|
||||
});
|
||||
},
|
||||
ePlaceBid: function(e) {
|
||||
e.stopImmediatePropagation();
|
||||
e.preventDefault();
|
||||
var amount = $(this).attr('data-bid-amount');
|
||||
openPopup(Aj.state.$bidPopup, {
|
||||
onOpen: function() {
|
||||
Aj.state.$bidForm.reset();
|
||||
Aj.state.$bidForm.field('bid_value').value(amount).trigger('input').focusAndSelect();
|
||||
}
|
||||
});
|
||||
},
|
||||
ePlaceBidSubmit: function(e) {
|
||||
e.preventDefault();
|
||||
var $form = $(this);
|
||||
var username = Aj.state.username;
|
||||
var amount = Main.amountFieldValue($form, 'bid_value');
|
||||
if (amount === false) {
|
||||
$form.field('bid_value').focus();
|
||||
return;
|
||||
}
|
||||
closePopup(Aj.state.$bidPopup);
|
||||
QR.showPopup({
|
||||
request: {
|
||||
method: 'getBidLink',
|
||||
params: {
|
||||
username: username,
|
||||
bid: amount
|
||||
}
|
||||
},
|
||||
title: l('WEB_POPUP_QR_PLACE_BID_HEADER'),
|
||||
description: l('WEB_POPUP_QR_PLACE_BID_TEXT', {
|
||||
amount: '<span class="icon-before icon-ton-text">' + amount + '</span>'
|
||||
}),
|
||||
qr_label: '@' + username,
|
||||
tk_label: l('WEB_POPUP_QR_PLACE_BID_TK_BUTTON'),
|
||||
terms_label: l('WEB_POPUP_QR_PLACE_BID_TERMS'),
|
||||
onConfirm: function(by_server) {
|
||||
if (by_server) {
|
||||
showAlert(l('WEB_PLACE_BID_SENT'));
|
||||
}
|
||||
}
|
||||
});
|
||||
},
|
||||
eBuyNow: function(e) {
|
||||
e.preventDefault();
|
||||
var username = Aj.state.username;
|
||||
var amount = $(this).attr('data-bid-amount');
|
||||
QR.showPopup({
|
||||
request: {
|
||||
method: 'getBidLink',
|
||||
params: {
|
||||
username: username,
|
||||
bid: amount
|
||||
}
|
||||
},
|
||||
title: l('WEB_POPUP_QR_BUY_NOW_HEADER', {
|
||||
username: '<span class="accent-color">@' + username + '</span>'
|
||||
}),
|
||||
description: l('WEB_POPUP_QR_BUY_NOW_TEXT', {
|
||||
amount: '<span class="icon-before icon-ton-text">' + amount + '</span>'
|
||||
}),
|
||||
qr_label: '@' + username,
|
||||
tk_label: l('WEB_POPUP_QR_BUY_NOW_TK_BUTTON'),
|
||||
terms_label: l('WEB_POPUP_QR_PLACE_BID_TERMS'),
|
||||
onConfirm: function(by_server) {
|
||||
if (by_server) {
|
||||
showAlert(l('WEB_BUY_NOW_SENT'));
|
||||
}
|
||||
}
|
||||
});
|
||||
},
|
||||
eSubscribe: function(e) {
|
||||
if (!Login.checkAuth(e)) {
|
||||
return false;
|
||||
}
|
||||
e.preventDefault();
|
||||
var username = Aj.state.username;
|
||||
Aj.apiRequest('subscribe', {
|
||||
username: username
|
||||
}, function(result) {
|
||||
if (result.error) {
|
||||
return showAlert(result.error);
|
||||
}
|
||||
$('.js-subscribe').addClass('subscribed');
|
||||
});
|
||||
},
|
||||
eUnsubscribe: function(e) {
|
||||
if (!Login.checkAuth(e)) {
|
||||
return false;
|
||||
}
|
||||
e.preventDefault();
|
||||
var username = Aj.state.username;
|
||||
Aj.apiRequest('unsubscribe', {
|
||||
username: username
|
||||
}, function(result) {
|
||||
if (result.error) {
|
||||
return showAlert(result.error);
|
||||
}
|
||||
$('.js-subscribe').removeClass('subscribed');
|
||||
});
|
||||
},
|
||||
eLoadMoreOrders: function(e) {
|
||||
e.preventDefault();
|
||||
var username = Aj.state.username;
|
||||
var $table = $(this).closest('table');
|
||||
var offset_id = $(this).attr('data-next-offset');
|
||||
Aj.apiRequest('getOrdersHistory', {
|
||||
username: username,
|
||||
offset_id: offset_id
|
||||
}, function(result) {
|
||||
if (result.error) {
|
||||
return showAlert(result.error);
|
||||
}
|
||||
$('tbody', $table).append(result.body);
|
||||
$('tfoot', $table).html(result.foot);
|
||||
});
|
||||
},
|
||||
eLoadMoreOwners: function(e) {
|
||||
e.preventDefault();
|
||||
var username = Aj.state.username;
|
||||
var $table = $(this).closest('table');
|
||||
var offset_id = $(this).attr('data-next-offset');
|
||||
Aj.apiRequest('getOwnersHistory', {
|
||||
username: username,
|
||||
offset_id: offset_id
|
||||
}, function(result) {
|
||||
if (result.error) {
|
||||
return showAlert(result.error);
|
||||
}
|
||||
$('tbody', $table).append(result.body);
|
||||
$('tfoot', $table).html(result.foot);
|
||||
});
|
||||
}
|
||||
};
|
||||
|
||||
var Assets = {
|
||||
init: function() {
|
||||
Aj.onLoad(function(state) {
|
||||
$(document).on('click.curPage', '.js-assign-btn', Assets.eAssignToTelegram);
|
||||
$(document).on('submit.curPage', '.js-assign-form', Assets.eAssignSubmit);
|
||||
$(document).on('click.curPage', '.js-put-to-auction-btn', Assets.ePutToAuction);
|
||||
$(document).on('submit.curPage', '.js-put-to-auction-form', Assets.ePutToAuctionSubmit);
|
||||
$(document).on('click.curPage', '.js-cancel-auction-btn', Assets.eCancelAuction);
|
||||
$(document).on('click.curPage', '.js-sell-username-btn', Assets.eSellUsername);
|
||||
$(document).on('submit.curPage', '.js-sell-username-form', Assets.eSellUsernameSubmit);
|
||||
$('.table-selectable-in-row').on('mouseover mouseout', Assets.eTableRowSelHovered);
|
||||
state.$assignPopup = $('.js-assign-popup');
|
||||
state.$assignForm = $('.js-assign-form');
|
||||
|
||||
state.$putToAuctionPopup = $('.js-put-to-auction-popup');
|
||||
state.$putToAuctionForm = $('.js-put-to-auction-form');
|
||||
Main.initForm(state.$putToAuctionForm);
|
||||
state.$sellUsernamePopup = $('.js-sell-username-popup');
|
||||
state.$sellUsernameForm = $('.js-sell-username-form');
|
||||
Main.initForm(state.$sellUsernameForm);
|
||||
});
|
||||
Aj.onUnload(function(state) {
|
||||
$('.table-selectable-in-row').off('mouseover mouseout', Assets.eTableRowSelHovered);
|
||||
Main.destroyForm(state.$putToAuctionForm);
|
||||
Main.destroyForm(state.$sellUsernameForm);
|
||||
});
|
||||
},
|
||||
eTableRowSelHovered: function(e) {
|
||||
$(this).closest('.tm-row-selectable').toggleClass('noselect', e.type == 'mouseover');
|
||||
},
|
||||
eAssignToTelegram: function(e) {
|
||||
e.stopImmediatePropagation();
|
||||
e.preventDefault();
|
||||
var $actions = $(this).closest('.js-actions');
|
||||
var username = $actions.attr('data-username');
|
||||
var assigned_to = $actions.attr('data-assigned-to');
|
||||
openPopup(Aj.state.$assignPopup, {
|
||||
onOpen: function() {
|
||||
Aj.state.$assignForm.reset();
|
||||
Aj.state.$assignForm.field('username').value(username);
|
||||
Aj.state.$assignForm.field('assign_to').value(assigned_to);
|
||||
if (assigned_to) {
|
||||
$('.js-assign-account-item:has(input[name="assign_to"][value="' + assigned_to + '"])', Aj.state.$assignPopup).each(function() {
|
||||
if (this.scrollIntoViewIfNeeded) {
|
||||
this.scrollIntoViewIfNeeded();
|
||||
} else if (this.scrollIntoView) {
|
||||
this.scrollIntoView();
|
||||
}
|
||||
});
|
||||
}
|
||||
},
|
||||
onClose: function() {
|
||||
Aj.state.$assignForm.field('username').value('');
|
||||
Aj.state.$assignForm.field('assign_to').value(false);
|
||||
}
|
||||
});
|
||||
},
|
||||
eAssignSubmit: function(e) {
|
||||
e.preventDefault();
|
||||
var $form = $(this);
|
||||
var username = $form.field('username').value();
|
||||
var assign_to = $form.field('assign_to').value();
|
||||
Aj.apiRequest('assignToTgAccount', {
|
||||
username: username,
|
||||
assign_to: assign_to
|
||||
}, function(result) {
|
||||
if (result.error) {
|
||||
return showAlert(result.error);
|
||||
}
|
||||
closePopup();
|
||||
$('.js-actions', Aj.ajContainer).each(function() {
|
||||
if ($(this).attr('data-username') == username) {
|
||||
$(this).attr('data-assigned-to', assign_to);
|
||||
}
|
||||
});
|
||||
if (result.msg) {
|
||||
showAlert(result.msg);
|
||||
}
|
||||
});
|
||||
},
|
||||
ePutToAuction: function(e) {
|
||||
e.stopImmediatePropagation();
|
||||
e.preventDefault();
|
||||
$(this).closeDropdown();
|
||||
var $actions = $(this).closest('.js-actions');
|
||||
var username = $actions.attr('data-username');
|
||||
var def_bid = $actions.attr('data-def-bid');
|
||||
$('.js-username', Aj.state.$putToAuctionPopup).html('@' + username);
|
||||
openPopup(Aj.state.$putToAuctionPopup, {
|
||||
onOpen: function() {
|
||||
Aj.state.$putToAuctionForm.reset();
|
||||
Aj.state.$putToAuctionForm.field('username').value(username);
|
||||
Aj.state.$putToAuctionForm.field('min_bid_value').value(def_bid).trigger('input').focusAndSelect();
|
||||
}
|
||||
});
|
||||
},
|
||||
ePutToAuctionSubmit: function(e) {
|
||||
e.preventDefault();
|
||||
var $form = $(this);
|
||||
var username = $form.field('username').value();
|
||||
var min_amount = Main.amountFieldValue($form, 'min_bid_value');
|
||||
var max_amount = Main.amountFieldValue($form, 'max_price_value');
|
||||
closePopup(Aj.state.$putToAuctionPopup);
|
||||
QR.showPopup({
|
||||
request: {
|
||||
method: 'getStartAuctionLink',
|
||||
params: {
|
||||
username: username,
|
||||
min_amount: min_amount,
|
||||
max_amount: max_amount
|
||||
}
|
||||
},
|
||||
title: l('WEB_POPUP_QR_START_AUCTION_HEADER'),
|
||||
description: l('WEB_POPUP_QR_START_AUCTION_TEXT'),
|
||||
qr_label: '@' + username,
|
||||
tk_label: l('WEB_POPUP_QR_START_AUCTION_TK_BUTTON'),
|
||||
terms_label: l('WEB_POPUP_QR_PROCEED_TERMS'),
|
||||
onConfirm: function(by_server) {
|
||||
if (by_server) {
|
||||
$(Aj.ajContainer).one('page:load', function() {
|
||||
showAlert(l('WEB_START_AUCTION_SENT'));
|
||||
});
|
||||
}
|
||||
Aj.location('/username/' + username);
|
||||
}
|
||||
});
|
||||
},
|
||||
eCancelAuction: function(e) {
|
||||
e.stopImmediatePropagation();
|
||||
e.preventDefault();
|
||||
$(this).closeDropdown();
|
||||
var $actions = $(this).closest('.js-actions');
|
||||
var username = $actions.attr('data-username');
|
||||
QR.showPopup({
|
||||
request: {
|
||||
method: 'getCancelAuctionLink',
|
||||
params: {
|
||||
username: username
|
||||
}
|
||||
},
|
||||
title: l('WEB_POPUP_QR_STOP_AUCTION_HEADER'),
|
||||
description: l('WEB_POPUP_QR_STOP_AUCTION_TEXT'),
|
||||
qr_label: '@' + username,
|
||||
tk_label: l('WEB_POPUP_QR_STOP_AUCTION_TK_BUTTON'),
|
||||
terms_label: l('WEB_POPUP_QR_PROCEED_TERMS'),
|
||||
onConfirm: function(by_server) {
|
||||
if (by_server) {
|
||||
$(Aj.ajContainer).one('page:load', function() {
|
||||
showAlert(l('WEB_STOP_AUCTION_SENT'));
|
||||
});
|
||||
}
|
||||
Aj.location('/username/' + username);
|
||||
}
|
||||
});
|
||||
},
|
||||
eSellUsername: function(e) {
|
||||
e.stopImmediatePropagation();
|
||||
e.preventDefault();
|
||||
$(this).closeDropdown();
|
||||
var $actions = $(this).closest('.js-actions');
|
||||
var username = $actions.attr('data-username');
|
||||
var def_bid = $actions.attr('data-def-bid');
|
||||
$('.js-username', Aj.state.$sellUsernamePopup).html('@'+username);
|
||||
openPopup(Aj.state.$sellUsernamePopup, {
|
||||
onOpen: function() {
|
||||
Aj.state.$sellUsernameForm.reset();
|
||||
Aj.state.$sellUsernameForm.field('username').value(username);
|
||||
Aj.state.$sellUsernameForm.field('sell_value').value(def_bid).trigger('input').focusAndSelect();
|
||||
}
|
||||
});
|
||||
},
|
||||
eSellUsernameSubmit: function(e) {
|
||||
e.preventDefault();
|
||||
var $form = $(this);
|
||||
var username = $form.field('username').value();
|
||||
var sell_amount = Main.amountFieldValue($form, 'sell_value');
|
||||
closePopup(Aj.state.$sellUsernamePopup);
|
||||
QR.showPopup({
|
||||
request: {
|
||||
method: 'getStartAuctionLink',
|
||||
params: {
|
||||
username: username,
|
||||
min_amount: sell_amount,
|
||||
max_amount: sell_amount
|
||||
}
|
||||
},
|
||||
title: l('WEB_POPUP_QR_SELL_USERNAME_HEADER'),
|
||||
description: l('WEB_POPUP_QR_SELL_USERNAME_TEXT'),
|
||||
qr_label: '@' + username,
|
||||
tk_label: l('WEB_POPUP_QR_SELL_USERNAME_TK_BUTTON'),
|
||||
terms_label: l('WEB_POPUP_QR_PROCEED_TERMS'),
|
||||
onConfirm: function(by_server) {
|
||||
if (by_server) {
|
||||
$(Aj.ajContainer).one('page:load', function() {
|
||||
showAlert(l('WEB_SELL_USERNAME_SENT'));
|
||||
});
|
||||
}
|
||||
Aj.location('/username/' + username);
|
||||
}
|
||||
});
|
||||
}
|
||||
};
|
||||
|
||||
var MyBids = {
|
||||
init: function() {
|
||||
Aj.onLoad(function(state) {
|
||||
$(document).on('click.curPage', '.js-load-more-bids', MyBids.eLoadMoreBids);
|
||||
});
|
||||
},
|
||||
eLoadMoreBids: function(e) {
|
||||
e.preventDefault();
|
||||
var $table = $(this).closest('table');
|
||||
var offset_id = $(this).attr('data-next-offset');
|
||||
Aj.apiRequest('getBidsHistory', {
|
||||
offset_id: offset_id
|
||||
}, function(result) {
|
||||
if (result.error) {
|
||||
return showAlert(result.error);
|
||||
}
|
||||
$('tbody', $table).append(result.body);
|
||||
$('tfoot', $table).html(result.foot);
|
||||
});
|
||||
}
|
||||
};
|
||||
|
||||
var QR = {
|
||||
showPopup: function(options) {
|
||||
options = $.extend({
|
||||
title: 'Scan QR Code',
|
||||
description: null,
|
||||
hint: null,
|
||||
qr_label: null,
|
||||
tk_label: null,
|
||||
terms_label: null,
|
||||
data: null,
|
||||
request: null,
|
||||
onConfirm: null
|
||||
}, options);
|
||||
var ua = (navigator.userAgent || '').toLowerCase(),
|
||||
is_ios = ua.indexOf('iphone') >= 0 ||
|
||||
ua.indexOf('ipad') >= 0,
|
||||
is_android = ua.indexOf('android') >= 0;
|
||||
var qr_label = options.qr_label ? '<div class="tm-qr-code-label fit-text">' + options.qr_label + '</div>' : '';
|
||||
var hint = options.hint ? '<p class="popup-text popup-hint-text">' + options.hint + '</p>' : '';
|
||||
var tk_button = options.tk_label && (is_android || is_ios) ? '<p class="tm-qr-code-or">' + l('WEB_POPUP_QR_OR_BUTTON') + '</p><button class="btn btn-primary btn-block btn-tonkeeper js-tonkeeper-btn" data-inactive-label="' + l('WEB_WAITING', 'Waiting...') + '"><span class="tm-button-label">' + options.tk_label + '</span></button>' : '';
|
||||
var terms_text = options.terms_label ? '<p class="popup-footer-text">' + options.terms_label + '</p>' : '';
|
||||
var $popup = $('<div class="popup-container hide qr-code-popup-container qr-inactive" data-close-outside="popup-body"><div class="popup"><div class="popup-body"><section><h2>' + options.title + '</h2><p class="popup-text">' + options.description + '</p><div class="tm-qr-code"><div class="tm-qr-code-image"></div>' + qr_label + '</div>' + tk_button + hint + terms_text + '</section></div></div></div>');
|
||||
var $qrCode = $('.tm-qr-code-image', $popup);
|
||||
var $tonkeeperBtn = $('.js-tonkeeper-btn', $popup);
|
||||
var $confirmedBtn = $('.js-confirmed-btn', $popup);
|
||||
var tkOpen = function() {
|
||||
if ($popup.hasClass('qr-inactive')) {
|
||||
return false;
|
||||
}
|
||||
var href = $tonkeeperBtn.attr('data-href');
|
||||
if (href) {
|
||||
location.href = href;
|
||||
}
|
||||
}
|
||||
var onConfirmedPress = function() {
|
||||
confirmed();
|
||||
}
|
||||
var confirmed = function(by_server) {
|
||||
options.onConfirm && options.onConfirm(by_server);
|
||||
closePopup($popup);
|
||||
}
|
||||
var onEnterPress = function(e) {
|
||||
if (e.keyCode == Keys.RETURN) {
|
||||
e.stopImmediatePropagation();
|
||||
tkOpen();
|
||||
}
|
||||
};
|
||||
var onExpire = function() {
|
||||
closePopup($popup);
|
||||
showAlert('QR code expired');
|
||||
};
|
||||
var setData = function(data) {
|
||||
QR.getUrl(data.qr_link, function(url) {
|
||||
var urlObj = $popup.data('qrCodeUrlObj');
|
||||
if (urlObj) {
|
||||
URL.revokeObjectURL(urlObj);
|
||||
}
|
||||
$popup.data('qrCodeUrlObj', url);
|
||||
$qrCode.css('backgroundImage', "url('" + url + "')");
|
||||
$tonkeeperBtn.attr('data-href', data.link);
|
||||
$popup.removeClass('qr-inactive');
|
||||
});
|
||||
};
|
||||
var loadData = function(req) {
|
||||
var retryTimeout, expTimeout;
|
||||
if (retryTimeout = $popup.data('retryTimeout')) {
|
||||
clearTimeout(retryTimeout);
|
||||
}
|
||||
Aj.apiRequest(req.method, req.params || {}, function(result) {
|
||||
if (result.error) {
|
||||
if ($popup.hasClass('qr-inactive')) {
|
||||
closePopup($popup);
|
||||
}
|
||||
return showAlert(result.error);
|
||||
}
|
||||
setData(result);
|
||||
if (expTimeout = $popup.data('expTimeout')) {
|
||||
clearTimeout(expTimeout);
|
||||
}
|
||||
if (result.expire_after) {
|
||||
expTimeout = setTimeout(onExpire, result.expire_after * 1000);
|
||||
$popup.data('expTimeout', expTimeout);
|
||||
var retry_after = result.expire_after - 10;
|
||||
if (retry_after > 0) {
|
||||
var retryTimeout = setTimeout(loadData, retry_after * 1000, req);
|
||||
$popup.data('retryTimeout', retryTimeout);
|
||||
}
|
||||
}
|
||||
if (result.check_method) {
|
||||
checkAction(result.check_method, result.check_params);
|
||||
|
||||
}
|
||||
});
|
||||
};
|
||||
var checkAction = function(method, params) {
|
||||
var checkTimeout;
|
||||
if (checkTimeout = $popup.data('checkTimeout')) {
|
||||
clearTimeout(checkTimeout);
|
||||
}
|
||||
checkTimeout = setTimeout(function() {
|
||||
Aj.apiRequest(method, params || {}, function(result) {
|
||||
if (result.error) {
|
||||
return showAlert(result.error);
|
||||
}
|
||||
if (result.confirmed) {
|
||||
confirmed(true);
|
||||
} else {
|
||||
var checkTimeout = $popup.data('checkTimeout');
|
||||
if (checkTimeout) {
|
||||
checkAction(method, params);
|
||||
}
|
||||
}
|
||||
});
|
||||
}, 700);
|
||||
$popup.data('checkTimeout', checkTimeout);
|
||||
};
|
||||
if (options.data) {
|
||||
setData(options.data);
|
||||
} else if (options.request) {
|
||||
loadData(options.request);
|
||||
}
|
||||
$tonkeeperBtn.on('click', tkOpen);
|
||||
$confirmedBtn.on('click', onConfirmedPress);
|
||||
$(document).on('keydown', onEnterPress);
|
||||
$popup.one('popup:open', function() {
|
||||
$('.fit-text', $popup).fitText();
|
||||
});
|
||||
$popup.one('popup:close', function() {
|
||||
$tonkeeperBtn.off('click', tkOpen);
|
||||
$confirmedBtn.off('click', onConfirmedPress);
|
||||
$(document).off('keydown', onEnterPress);
|
||||
var retryTimeout, expTimeout, checkTimeout;
|
||||
if (retryTimeout = $popup.data('retryTimeout')) {
|
||||
clearTimeout(retryTimeout);
|
||||
$popup.data('retryTimeout', false);
|
||||
}
|
||||
if (expTimeout = $popup.data('expTimeout')) {
|
||||
clearTimeout(expTimeout);
|
||||
$popup.data('expTimeout', false);
|
||||
}
|
||||
if (checkTimeout = $popup.data('checkTimeout')) {
|
||||
clearTimeout(expTimeout);
|
||||
$popup.data('checkTimeout', false);
|
||||
}
|
||||
setTimeout(function() {
|
||||
$popup.remove();
|
||||
}, 500);
|
||||
});
|
||||
openPopup($popup);
|
||||
return $popup;
|
||||
},
|
||||
getUrl: function(link, callback) {
|
||||
var qrCode = new QRCodeStyling({
|
||||
width: 656,
|
||||
height: 656,
|
||||
type: 'canvas',
|
||||
data: link,
|
||||
image: 'data:image/svg+xml,%3Csvg%20height%3D%2255%22%20viewBox%3D%220%200%2055%2055%22%20width%3D%2255%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20d%3D%22m6.94%2013.98%2018.58%208.96c.22.11.37.34.37.6l-.07%2020.79c0%20.22-.12.43-.31.55-.31.2-.71.1-.91-.21l-18.51-29.75c-.12-.19-.13-.43-.03-.63.16-.33.55-.47.88-.31zm42%20.31c.1.2.09.44-.03.63l-18.51%2029.75c-.2.31-.6.41-.91.21-.19-.12-.31-.33-.31-.55l-.07-20.79c0-.26.15-.49.37-.6l18.58-8.96c.33-.16.72-.02.88.31zm-2.39-4.29c.26%200%20.5.15.6.39.15.34%200%20.73-.33.87l-19.12%208.48c-.17.07-.37.07-.54-.01l-19-8.47c-.23-.1-.39-.34-.39-.6%200-.36.3-.66.66-.66z%22%20fill%3D%22%231a2026%22%20fill-rule%3D%22evenodd%22%2F%3E%3C%2Fsvg%3E',
|
||||
backgroundOptions: {
|
||||
color: 'transparent'
|
||||
},
|
||||
dotsOptions: {
|
||||
color: '#1a2026',
|
||||
type: 'rounded'
|
||||
},
|
||||
cornersSquareOptions: {
|
||||
type: 'extra-rounded'
|
||||
},
|
||||
imageOptions: {
|
||||
// imageSize: 0.8,
|
||||
imageSize: 0.3,
|
||||
margin: 0
|
||||
},
|
||||
qrOptions: {
|
||||
// errorCorrectionLevel: 'L'
|
||||
}
|
||||
});
|
||||
qrCode.getRawData('png').then(function(blob) {
|
||||
var qr_url = URL.createObjectURL(blob);
|
||||
callback(qr_url);
|
||||
});
|
||||
}
|
||||
};
|
50
data/web/fragment.com/privacy.html
Normal file
50
data/web/fragment.com/privacy.html
Normal file
|
@ -0,0 +1,50 @@
|
|||
<!DOCTYPE html>
|
||||
<html>
|
||||
<head>
|
||||
<meta charset="utf-8">
|
||||
<title>Fragment</title>
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=no" />
|
||||
<meta name="format-detection" content="telephone=no" />
|
||||
<meta http-equiv="X-UA-Compatible" content="IE=edge" />
|
||||
<meta name="MobileOptimized" content="176" />
|
||||
<meta name="HandheldFriendly" content="True" />
|
||||
<link rel="shortcut icon" href="/img/fragment.ico" type="image/x-icon" />
|
||||
<link rel="mask-icon" href="/img/fragment_icon.svg" color="#121519">
|
||||
<script>document.cookie="stel_dt="+encodeURIComponent((new Date).getTimezoneOffset())+";path=/;max-age=31536000;samesite=None;secure"</script>
|
||||
|
||||
<link href="/css/font-roboto.css?1" rel="stylesheet" type="text/css">
|
||||
<link href="/css/bootstrap.min.css?3" rel="stylesheet">
|
||||
<link href="/css/bootstrap-extra.css?2" rel="stylesheet">
|
||||
<link href="/css/auction.css?24" rel="stylesheet">
|
||||
|
||||
</head>
|
||||
<body class="emoji_image no-transition">
|
||||
|
||||
<div id="aj_progress" class="progress-bar"></div>
|
||||
|
||||
<div id="aj_content"> <main class="tm-unavailable">
|
||||
<div class="tm-logo js-logo js-logo-clickable">
|
||||
<i class="tm-logo-icon js-logo-icon"></i>
|
||||
</div>
|
||||
<h1 class="tm-unavailable-header">
|
||||
Oops
|
||||
</h1>
|
||||
<p class="tm-unavailable-text">
|
||||
This service is not available in the United States.
|
||||
</p>
|
||||
</main></div>
|
||||
<script src="/js/jquery.min.js?1"></script>
|
||||
<script src="/js/bootstrap.min.js"></script>
|
||||
<script src="/js/main-aj.js?64"></script>
|
||||
<script src="/js/jquery-ex.js?13"></script>
|
||||
<script src="/js/qr-code-styling.js?1"></script>
|
||||
<script src="/js/auction.js?23"></script>
|
||||
|
||||
<script>ajInit({"version":363,"apiUrl":"\/api?hash=telegram-crawler","unauth":true});</script>
|
||||
<script id="aj_script">Main.init();
|
||||
</script>
|
||||
<script>Aj.pageLoaded();</script>
|
||||
|
||||
</body>
|
||||
</html>
|
||||
|
50
data/web/fragment.com/terms.html
Normal file
50
data/web/fragment.com/terms.html
Normal file
|
@ -0,0 +1,50 @@
|
|||
<!DOCTYPE html>
|
||||
<html>
|
||||
<head>
|
||||
<meta charset="utf-8">
|
||||
<title>Fragment</title>
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=no" />
|
||||
<meta name="format-detection" content="telephone=no" />
|
||||
<meta http-equiv="X-UA-Compatible" content="IE=edge" />
|
||||
<meta name="MobileOptimized" content="176" />
|
||||
<meta name="HandheldFriendly" content="True" />
|
||||
<link rel="shortcut icon" href="/img/fragment.ico" type="image/x-icon" />
|
||||
<link rel="mask-icon" href="/img/fragment_icon.svg" color="#121519">
|
||||
<script>document.cookie="stel_dt="+encodeURIComponent((new Date).getTimezoneOffset())+";path=/;max-age=31536000;samesite=None;secure"</script>
|
||||
|
||||
<link href="/css/font-roboto.css?1" rel="stylesheet" type="text/css">
|
||||
<link href="/css/bootstrap.min.css?3" rel="stylesheet">
|
||||
<link href="/css/bootstrap-extra.css?2" rel="stylesheet">
|
||||
<link href="/css/auction.css?24" rel="stylesheet">
|
||||
|
||||
</head>
|
||||
<body class="emoji_image no-transition">
|
||||
|
||||
<div id="aj_progress" class="progress-bar"></div>
|
||||
|
||||
<div id="aj_content"> <main class="tm-unavailable">
|
||||
<div class="tm-logo js-logo js-logo-clickable">
|
||||
<i class="tm-logo-icon js-logo-icon"></i>
|
||||
</div>
|
||||
<h1 class="tm-unavailable-header">
|
||||
Oops
|
||||
</h1>
|
||||
<p class="tm-unavailable-text">
|
||||
This service is not available in the United States.
|
||||
</p>
|
||||
</main></div>
|
||||
<script src="/js/jquery.min.js?1"></script>
|
||||
<script src="/js/bootstrap.min.js"></script>
|
||||
<script src="/js/main-aj.js?64"></script>
|
||||
<script src="/js/jquery-ex.js?13"></script>
|
||||
<script src="/js/qr-code-styling.js?1"></script>
|
||||
<script src="/js/auction.js?23"></script>
|
||||
|
||||
<script>ajInit({"version":363,"apiUrl":"\/api?hash=telegram-crawler","unauth":true});</script>
|
||||
<script id="aj_script">Main.init();
|
||||
</script>
|
||||
<script>Aj.pageLoaded();</script>
|
||||
|
||||
</body>
|
||||
</html>
|
||||
|
Loading…
Reference in a new issue