telegram-crawler/data/web/fragment.com/js/auction.js
2022-11-23 16:27:46 +00:00

1302 lines
44 KiB
JavaScript

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-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);
$(cont).on('click.curPage', '.js-copy-code', Main.copyText);
$(cont).on('click.curPage', '.js-main-search-dd-item', Main.eMainSearchDDSelected);
state.$headerMenu = $('.js-header-menu');
state.$unavailPopup = $('.js-unavailable-popup');
state.$howitworksPopup = $('.js-howitworks-popup');
state.$mainSearchField = $('.js-main-search-field');
state.$mainSearchForm = $('.js-main-search-form');
state.$mainSearchForm.on('submit', Main.eMainSearchSubmit);
state.$mainSearchForm.field('query').on('input', Main.eMainSearchInput);
state.mainSearchCache = {};
$('.js-form-clear', state.$mainSearchForm).on('click', Main.eMainSearchClear);
Main.updateTime();
Main.initViewport();
Main.initLogo();
});
Aj.onUnload(function(state) {
clearTimeout(Aj.state.searchTimeout);
$(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);
state.$mainSearchForm.off('submit', Main.eMainSearchSubmit);
state.$mainSearchForm.field('query').off('input', Main.eMainSearchInput);
$('.js-form-clear', state.$mainSearchForm).off('click', Main.eMainSearchClear);
});
},
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);
}
},
fitUsername: function($el) {
$el.each(function(){
var init_size = $(this).data('init-size');
if (!init_size) {
init_size = parseInt($(this).css('font-size'));
$(this).data('init-size', init_size);
}
var size = parseInt($(this).css('font-size'));
size = parseInt(size);
while (this.scrollWidth > this.offsetWidth) {
size -= 0.5;
if (size >= init_size * 0.75) {
$(this).css('font-size', size + 'px');
} else {
break;
}
}
var text = $(this).attr('title') || $(this).text();
var prefix_len = text.length - 3;
while (this.scrollWidth > this.offsetWidth &&
prefix_len > 3) {
prefix_len--;
$(this).text(text.substr(0, prefix_len) + '…' + text.substr(-3));
}
});
},
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);
},
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;
}
},
copyText: function() {
var text = $(this).attr('data-copy');
var $text = $('<textarea readonly>').css('position', 'fixed').css('left', '-9999px');
$text.val(text).appendTo('body');
var selected = document.getSelection().rangeCount > 0 ? document.getSelection().getRangeAt(0) : false;
$text.focus().select();
document.execCommand('copy');
$text.remove();
if (selected) {
document.getSelection().removeAllRanges();
document.getSelection().addRange(selected);
}
},
eMainSearchInput: function(e) {
if (!Aj.state.quickSearch) {
return;
}
clearTimeout(Aj.state.searchTimeout);
var cached_results = Main.getSearchCachedResult();
if (cached_results) {
Main.updateResults(cached_results);
} else {
Aj.state.searchTimeout = setTimeout(Main.searchSubmit, 400);
}
},
eMainSearchDDSelected: function(e) {
e.preventDefault();
e.stopImmediatePropagation();
var field = $(this).attr('data-field');
var value = $(this).attr('data-value');
var $form = Aj.state.$mainSearchForm;
$form.field(field).value(value);
Main.searchSubmit();
},
eMainSearchClear: function(e) {
var $form = Aj.state.$mainSearchForm;
$form.field('query').value('');
Main.searchSubmit();
},
eMainSearchSubmit: function(e) {
e.preventDefault();
Main.searchSubmit();
},
updateResults: function(result) {
if (result.html) {
$('.js-search-results', Aj.ajContainer).html(result.html);
Main.updateTime();
Aj.setLocation(result.url, true);
}
$('.js-main-recent-bids').toggleClass('hide', !result.show_recent_bids);
},
getSearchCachedResult: function() {
var $form = Aj.state.$mainSearchForm;
var cache = Aj.state.mainSearchCache;
var query = $form.field('query').value();
var filter = $form.field('filter').value();
var sort = $form.field('sort').value();
var cache_key = 'q='+query+'&f='+filter+'&s='+sort;
if (cache[cache_key]) {
var expire_time = cache[cache_key].expire*1000;
var now_time = +(new Date);
if (expire_time > now_time) {
return cache[cache_key];
} else {
delete cache[cache_key];
}
}
return false;
},
searchSubmit: function() {
var $form = Aj.state.$mainSearchForm;
var cache = Aj.state.mainSearchCache;
var query = $form.field('query').value();
var filter = $form.field('filter').value();
var sort = $form.field('sort').value();
var cache_key = 'q='+query+'&f='+filter+'&s='+sort;
Aj.state.$mainSearchField.addClass('loading').removeClass('play').redraw().addClass('play');
Aj.apiRequest('searchAuctions', {
query: query,
filter: filter,
sort: sort
}, function(result) {
if (result.ok) {
cache[cache_key] = result;
Main.updateResults(result);
}
Aj.state.$mainSearchField.removeClass('loading');
});
}
};
var Login = {
init: function(options) {
Telegram.Login.init(options, function(user) {
if (user) {
Login.auth(user);
}
});
},
open: function(return_to) {
Login.returnTo = return_to;
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);
}
if (Login.returnTo) {
location.href = Login.returnTo;
} else {
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) {
var cont = Aj.ajContainer;
$(cont).on('click.curPage', '.js-place-bid-btn', Auction.ePlaceBid);
$(cont).on('submit.curPage', '.js-place-bid-form', Auction.ePlaceBidSubmit);
$(cont).on('click.curPage', '.js-buy-now-btn', Auction.eBuyNow);
$(cont).on('click.curPage', '.js-subscribe-btn', Auction.eSubscribe);
$(cont).on('click.curPage', '.js-unsubscribe-btn', Auction.eUnsubscribe);
$(cont).on('click.curPage', '.js-load-more-orders', Auction.eLoadMoreOrders);
$(cont).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();
Account.init();
});
Aj.onUnload(function(state) {
Main.destroyForm(state.$bidForm);
clearTimeout(state.updStateTo);
state.needUpdate = false;
});
},
updateState: function() {
Aj.apiRequest('updateAuction', {
username: Aj.state.username,
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);
$('.js-assign-account-item.external').addClass('hide');
if (assigned_to) {
$('.js-assign-account-item:has(input[name="assign_to"][value="' + assigned_to + '"])', Aj.state.$assignPopup).each(function() {
$(this).removeClass('hide');
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 Account = {
init: function() {
Aj.onLoad(function(state) {
var cont = Aj.ajContainer;
$(cont).on('click.curPage', '.js-convert-btn', Account.eConvertInit);
$(cont).on('click.curPage', '.js-revert-btn', Account.eConvertRevert);
$(cont).on('submit.curPage', '.js-convert-bid-form', Account.eConvertBidSubmit);
$(cont).on('submit.curPage', '.js-new-convert-bid-form', Account.eConvertBidSubmit);
state.$convertBidPopup = $('.js-convert-bid-popup');
state.$newConvertBidPopup = $('.js-new-convert-bid-popup');
state.$convertBidForm = $('.js-convert-bid-form');
state.$newConvertBidForm = $('.js-new-convert-bid-form');
Main.initForm(state.$convertBidForm);
Main.initForm(state.$newConvertBidForm);
state.$convertConfirmPopup = $('.js-convert-confirm-popup');
});
Aj.onUnload(function(state) {
Main.destroyForm(state.$convertBidForm);
Main.destroyForm(state.$newConvertBidForm);
clearTimeout(state.convertTimeout);
});
},
eConvertInit: function(e) {
e.stopImmediatePropagation();
e.preventDefault();
var $actions = $(this).closest('.js-actions');
var username = $actions.attr('data-username');
Aj.state.curPopup = null;
Aj.state.curPopupState = null;
Aj.apiRequest('initConverting', {
username: username
}, function(result) {
Account.processConverting(result);
});
},
eConvertRevert: function(e) {
e.stopImmediatePropagation();
e.preventDefault();
var $actions = $(this).closest('.js-actions');
var username = $actions.attr('data-username');
Aj.state.curPopup = null;
Aj.state.curPopupState = null;
Aj.apiRequest('revertConverting', {
username: username
}, function(result) {
Account.processConverting(result);
});
},
processConverting: function(result) {
var $popup = Aj.state.curPopup;
if (result.error) {
if (!result.keep && $popup) {
closePopup($popup);
}
return showAlert(result.error);
}
if (result.state == 'tg_confirm') {
Aj.state.curPopup = Aj.state.$convertConfirmPopup;
if (Aj.state.curPopupState != result.state) {
if ($popup) {
closePopup($popup);
}
Aj.state.curPopupState = result.state;
openPopup(Aj.state.curPopup, {
onOpen: function() {
Account.convertStateCheck(result.req_id);
},
onClose: function() {
Aj.state.curPopupState = null;
clearTimeout(Aj.state.convertTimeout);
}
});
} else {
Account.convertStateCheck(result.req_id);
}
}
else if (result.state == 'tg_declined') {
if ($popup) {
closePopup($popup);
}
Aj.state.curPopupState = result.state;
showAlert(result.message);
}
else if (result.state == 'bid_request') {
Aj.state.curPopup = Aj.state.$convertBidPopup;
if (Aj.state.curPopupState != result.state) {
if ($popup) {
closePopup($popup);
}
$('.js-username', Aj.state.curPopup).html('@' + result.username);
Aj.state.$convertBidForm.field('id').value(result.req_id);
Aj.state.curPopupState = result.state;
openPopup(Aj.state.curPopup, {
onClose: function() {
Aj.state.curPopupState = null;
}
});
}
}
else if (result.state == 'min_bid_request') {
Aj.state.curPopup = Aj.state.$newConvertBidPopup;
if (Aj.state.curPopupState != result.state) {
if ($popup) {
closePopup($popup);
}
$('.js-username', Aj.state.curPopup).html('@' + result.username);
$('.js-address', Aj.state.curPopup).html(result.address);
Aj.state.$newConvertBidForm.field('id').value(result.req_id);
Aj.state.curPopupState = result.state;
openPopup(Aj.state.curPopup, {
onClose: function() {
Aj.state.curPopupState = null;
}
});
}
}
else if (result.state == 'created') {
$(Aj.ajContainer).one('page:load', function() {
showAlert(result.message);
});
Aj.location('/username/' + result.username);
}
else if (result.state == 'revert_confirm') {
showConfirm(result.message, function() {
Aj.apiRequest('revertConverting', {
username: result.username,
confirmed: 1
}, function(result) {
Account.processConverting(result);
});
}, result.button);
}
else if (result.state == 'reverted') {
$(Aj.ajContainer).one('page:load', function() {
showAlert(result.message);
});
Aj.reload();
}
else if (result.state == 'qr') {
Aj.state.curPopupState = result.state;
if ($popup) {
closePopup($popup);
}
QR.showPopup({
data: result,
title: l('WEB_POPUP_QR_CONVERT_HEADER'),
description: l('WEB_POPUP_QR_CONVERT_TEXT', {
amount: '<span class="icon-before icon-ton-text">' + result.amount + '</span>'
}),
qr_label: '@' + result.username,
tk_label: l('WEB_POPUP_QR_CONVERT_TK_BUTTON'),
terms_label: l('WEB_POPUP_QR_PLACE_BID_TERMS'),
onConfirm: function(by_server) {
if (by_server) {
$(Aj.ajContainer).one('page:load', function() {
showAlert(l('WEB_CONVERT_SENT'));
});
}
Aj.location('/username/' + result.username);
}
});
}
},
convertStateCheck: function(req_id, force) {
var $popup = Aj.state.curPopup;
if (!force && (!$popup || $popup.hasClass('hide'))) {
return false;
}
clearTimeout(Aj.state.convertTimeout);
Aj.state.convertTimeout = setTimeout(function() {
Aj.apiRequest('checkConverting', {
id: req_id
}, function(result) {
Account.processConverting(result);
});
}, force ? 1 : 700);
},
eConvertBidSubmit: function(e) {
e.preventDefault();
var $form = $(this);
var req_id = $form.field('id').value();
var amount = Main.amountFieldValue($form, 'bid_value');
if (amount === false) {
$form.field('bid_value').focus();
return;
}
if ($form.data('loading')) {
return false;
}
$form.data('loading', true);
Aj.apiRequest('startConverting', {
id: req_id,
bid: amount
}, function(result) {
$form.data('loading', false);
Account.processConverting(result);
});
}
};
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,
onExpire: 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() {
options.onExpire && options.onExpire();
closePopup($popup);
};
var setData = function(data, req) {
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');
});
if (expTimeout = $popup.data('expTimeout')) {
clearTimeout(expTimeout);
}
if (data.expire_after) {
expTimeout = setTimeout(onExpire, data.expire_after * 1000);
$popup.data('expTimeout', expTimeout);
var retry_after = data.expire_after - 10;
if (retry_after > 0 && data.can_retry) {
var retryTimeout = setTimeout(loadData, retry_after * 1000, req);
$popup.data('retryTimeout', retryTimeout);
}
}
if (data.check_method) {
checkAction(data.check_method, data.check_params);
}
};
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, req);
});
};
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, options.request);
} else if (options.request) {
loadData(options.request);
}
$tonkeeperBtn.on('click', tkOpen);
$confirmedBtn.on('click', onConfirmedPress);
$(document).on('keydown', onEnterPress);
$popup.one('popup:open', function() {
Main.fitUsername($('.fit-text', $popup));
});
$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);
});
}
};