var Ads = { init: function() { Aj.onLoad(function(state) { Ads.updateTime(Aj.ajContainer); Ads.updateAdMessagePreviews(Aj.ajContainer); $('.logout-link').on('click', Ads.eLogOut); }); Aj.onUnload(function(state) { $('.logout-link').off('click', Ads.eLogOut); }); }, checkAuth: function (e) { if (Aj.needAuth()) { e.preventDefault(); return false; } }, eUpdateField: function(e) { var $fieldEl = $(this); if (e.type == 'focus' || e.type == 'focusin') { Ads.updateField($fieldEl, true); } else if (e.type == 'blur' || e.type == 'focusout') { Ads.updateField($fieldEl, false); } else { Ads.updateField($fieldEl); } }, wrapAmount: function(value, no_currency, field_format) { var amount_str = formatNumber(value, 2, '.', field_format ? '' : ','); if (no_currency) { return amount_str; } var currency = l('WEB_ADS_DEF_CURRENCY_SIGN', '€'); var parts = amount_str.split('.'); amount_str = parts[0] + (parts[1].length ? '.' + parts[1] + '' : ''); return '' + currency + '' + amount_str; }, amountFieldValue: function($form, field) { var $fieldEl = $form.field(field); 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') || 2; 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) { 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' && 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); if (minValue !== null && float_value < minValue || maxValue !== null && float_value > maxValue || is_invalid) { Ads.showFieldError($fieldEl); } else { Ads.hideFieldError($fieldEl); } if (e.type == 'change') { if (new_value.length && !is_invalid) { this.value = Ads.wrapAmount(float_value, true, true); } } }, updateField: function($fieldEl, focused) { var $formGroup = $fieldEl.fieldEl().parents('.form-group'); if (typeof focused !== 'undefined') { $formGroup.toggleClass('field-focused', focused); } var $select = $fieldEl.parents('.select'); var selectedCnt = $select.find('.selected-item').size(); $formGroup.toggleClass('noinput', $select.hasClass('no-search') && !selectedCnt); var hasValue = $fieldEl.value().length > 0 || selectedCnt > 0; $formGroup.toggleClass('field-has-value', hasValue); }, showFieldHint: function($fieldEl, hint_text, field_invalid) { var $formGroup = $fieldEl.fieldEl().parents('.form-group'); var $hint = $formGroup.find('>.pr-form-control-hint'); var $msg = $formGroup.find('>.pr-form-control-msg'); if (!$msg.size() && hint_text) { $msg = $('
'); $formGroup.find('>.pr-form-control-wrap').after($msg); } $msg.toggleClass('no-hint', !$hint.text().length); if (hint_text) { $msg.html('
' + hint_text + '
').redraw().slideShow(); } else { $msg.slideHide(); } $formGroup.toggleClass('field-invalid', !!field_invalid); }, showFieldError: function($fieldEl, error_text, focus) { Ads.showFieldHint($fieldEl, error_text, true); if (focus) { if ($fieldEl.hasClass('select')) { $fieldEl.trigger('click'); $fieldEl.find('.items-list').addClass('collapsed'); $fieldEl.removeClass('open'); } else if (!$fieldEl.is('[type="file"]')) { $fieldEl.focusAndSelect(); } } }, hideFieldError: function($fieldEl) { Ads.showFieldHint($fieldEl, '', false); }, onSelectChange: function(field, value, valueFull) { var $fieldEl = Aj.state.$form.field(field); Ads.hideFieldError($fieldEl); }, updateTime: function(context) { $('time[datetime]', context).each(function () { var $time = $(this), datetime = $time.attr('datetime'), title = $time.attr('title'), html = $time.html(), new_html = formatDateTime(datetime, $time.hasClass('short')); if (html != new_html) { $time.html(new_html); } if ($time.hasClass('short') && title) { var new_title = formatDateTime(datetime); if (title != new_title) { $time.attr('title', new_title); } } $time.removeAttr('datetime'); }); }, formatTableDate: function(timestamp) { var date = new Date(timestamp * 1000); var j = date.getDate(); var M = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'][date.getMonth()]; var y = date.getFullYear() % 100; return j + ' ' + M + ' ' + y + ' ' + formatTime(timestamp * 1000); }, fieldInit: function(field) { $(field).on('focus blur keyup change input', Ads.eUpdateField); $(field).parents('.pr-search-input-wrap').find('.pr-search-reset').on('click', Ads.eClearField); Ads.updateField($(field)); }, fieldDestroy: function(field) { $(field).off('focus blur keyup change input', Ads.eUpdateField); $(field).parents('.pr-search-input-wrap').find('.pr-search-reset').off('click', Ads.eClearField); }, formInit: function(form) { var $form = $(form); $('.pr-form-control', $form).each(function(){ Ads.fieldInit(this); }); $('.js-amount-input', $form).on('keyup change input', Ads.eUpdateAmountField); $('input.checkbox,input.radio', $form).on('focus blur', Ads.eUpdateField); $('.js-hint-tooltip', $form).on('mouseover mouseout click', Ads.eHintEvent); $('textarea.pr-form-control', $form).initAutosize(); $('.upload-input input', $form).on('change', Ads.eFileChange); $('.upload-input .js-file-reset', $form).on('click', Ads.eFileReset); $(document).on('touchstart click', Ads.eHideAllHints); setTimeout(function(){ $form.removeClass('no-transition'); }, 100); }, formDestroy: function(form) { var $form = $(form); $('.pr-form-control', $form).each(function(){ Ads.fieldDestroy(this); }); $('.js-amount-input', $form).off('keyup change input', Ads.eUpdateAmountField); $('input.checkbox,input.radio', $form).off('focus blur', Ads.eUpdateField); $('.js-hint-tooltip', $form).off('mouseover mouseout click', Ads.eHintEvent); $('textarea.pr-form-control', $form).destroyAutosize(); $('.upload-input input', $form).off('change', Ads.eFileChange); $('.upload-input .js-file-reset', $form).off('click', Ads.eFileReset); $(document).off('touchstart click', Ads.eHideAllHints); }, eClearField: function(e) { var $fieldEl = $(this).parents('.pr-search-input-wrap').find('.pr-search-input'); $fieldEl.value('').trigger('input').focus(); }, eFileChange: function(e) { var files = this.files || []; var $field = $(this); var $input = $field.parents('.upload-input'); var $fileName = $('.js-selected-value', $input); if (files.length > 0) { var file = files[0]; $field.data('file', file) $fileName.attr('data-filename', file.name); $input.addClass('selected'); } else { $field.data('file', null); $fileName.attr('data-filename', ''); $input.removeClass('selected'); } Ads.hideFieldError($field); }, eFileReset: function(e) { var $input = $(this).parents('.upload-input'); var $field = $input.find('input'); var $fileName = $('.js-selected-value', $input); $field.data('file', null).val(''); $fileName.attr('data-filename', ''); $input.removeClass('selected'); Ads.hideFieldError($field); }, showHint: function($hint, delay, hide_delay) { hide_delay = hide_delay || 0; var show_to = $hint.data('show_to'); var hide_to = $hint.data('hide_to'); clearTimeout(show_to); clearTimeout(hide_to); show_to = setTimeout(function() { $hint.addClass('show-hint'); if (hide_delay > 0) { Ads.hideHint($hint, hide_delay); } }, delay); $hint.data('show_to', show_to); }, hideHint: function($hint, delay) { var show_to = $hint.data('show_to'); var hide_to = $hint.data('hide_to'); clearTimeout(show_to); clearTimeout(hide_to); hide_to = setTimeout(function() { $hint.removeClass('show-hint'); }, delay); $hint.data('hide_to', hide_to); }, eHintEvent: function(e) { var $hint = $(this); if (e.type == 'click') { Ads.showHint($hint, 50, 2000); } else if (e.type == 'mouseover') { Ads.showHint($hint, 400); } else if (e.type == 'mouseout') { Ads.hideHint($hint, 100); } }, eHideAllHints: function(e) { var $closestHint = $(e.target).closest('.js-hint-tooltip'); $('.js-hint-tooltip.show-hint').each(function() { if (!$closestHint.filter(this).size()) { Ads.hideHint($(this), 1); } }); }, updateTextShadow: function(footerEl, textSel, shadowedSel, add_margin) { var textEl = footerEl.previousElementSibling; if (textEl && $(textEl).is(textSel)) { var text_rect = textEl.getBoundingClientRect(); var tnode = textEl.firstChild; while (tnode && tnode.nodeType == tnode.ELEMENT_NODE) { tnode = tnode.firstChild; } $(textEl).removeClass('before_footer'); if (tnode) { var r = document.createRange(); r.setStart(tnode, 0); r.setEnd(tnode, 1); var char_rect = r.getBoundingClientRect(); if (Math.abs(char_rect.right - text_rect.right) > 3) { var $infoEl = $(footerEl).find(shadowedSel); if ($infoEl.size()) { $(textEl).find('span.js-shadow').remove(); var $shadowEl = $('').css('display', 'inline-block').width($infoEl.width() + (add_margin || 0)); $(textEl).append($shadowEl).addClass('before_footer'); } } } } }, updateAdMessagePreviews: function(cont) { $('.pr-review-ad-preview .tgme_widget_message_text tg-emoji', cont).each(function() { TEmoji.init(this); }); $('.pr-review-ad-preview .tgme_widget_message_footer', cont).each(function() { Ads.updateTextShadow(this, '.js-message_text', '.js-message_info'); }); }, initSelect: function($form, field, options) { var $selectEl = $form.field(field); var $selectInput = $('.input', $selectEl); options = options || {}; $selectEl.data('selOpts', options); var onload = function(state) { var cachedData; $selectEl.initSelect({ multiSelect: !options.noMultiSelect, noCloseOnSelect: false, noCloseOnEnter: !!options.onEnter, enterEnabled: function() { return !!options.onEnter; }, prepareQuery: function(str) { return $.trim(str).toLowerCase(); }, renderItem: options.renderItem, renderSelectedItem: options.renderSelectedItem, renderNoItems: function(q) { return q && options.l_no_items_found ? '
' + options.l_no_items_found + '
' : ''; }, getData: function(value) { if (cachedData !== false && !cachedData) { cachedData = false; if (options.items) { var data = options.items; for (var i = 0; i < data.length; i++) { var item = data[i]; item._values = [item.name.toLowerCase()]; } cachedData = data; } } if (options.getData) { return options.getData(value, cachedData, options.getDataOpts); } else { return cachedData; } }, onBlur: function(value) { options.onEnter && options.onEnter(field, value); }, onEnter: function(value) { options.onEnter && options.onEnter(field, value); }, onChange: function(value, valueFull) { options.onChange && options.onChange(field, value, valueFull); }, onUpdate: function(value, valueFull) { Ads.updateField($selectInput); options.onUpdate && options.onUpdate(field, value, valueFull); } }); Ads.updateField($selectInput); }; var onunload = function(state) { $selectEl.destroySelect(); }; if (options.insideLayer) { Aj.onLayerLoad(onload); Aj.onLayerUnload(onunload); } else { Aj.onLoad(onload); Aj.onUnload(onunload); } }, getSelectItems: function(method, need_fields) { var _data = Aj.globalState.adsList; if (_data === false) { return false; } else if (_data) { return _data; } Aj.state.adsList = false; Aj.state.adsListIsLoading = true; if (Aj.state.initialAdsList) { setTimeout(function() { OwnerAds.processAdsList(Aj.state.initialAdsList); }, 10); } else { OwnerAds.loadAdsList({offset: 0}); } return false; }, eLogOut: function(e) { e.preventDefault(); e.stopImmediatePropagation(); Aj.apiRequest('logOut', {}, function(result) { location.reload(); }); return false; } }; var NewAd = { init: function() { var cont = Aj.ajContainer; Aj.onLoad(function(state) { state.$form = $('.pr-new-form', cont); Ads.formInit(state.$form); state.$form.on('submit', preventDefault); cont.on('click.curPage', '.js-preview-link', NewAd.ePreviewAd); cont.on('click.curPage', '.clear-draft-btn', NewAd.eClearDraft); cont.on('click.curPage', '.create-new-ad-btn', NewAd.eSubmitForm); for (var i = 0; i < state.selectList.length; i++) { var selectData = state.selectList[i]; if (selectData.channel_search) { Ads.initSelect(state.$form, selectData.field, { items: Aj.state[selectData.items_key] || [], pairedField: selectData.paired_field || false, renderSelectedItem: function(val, item) { return '
' + (item.photo ? '
' + item.photo + '
' : '') + '
' + item.name + '
'; }, onEnter: NewAd.onChannelSearch, onUpdate: NewAd.onSelectUpdate, onChange: Ads.onSelectChange }); } else if (selectData.location_search) { var $cFieldEl = state.$form.field(selectData.c_field).fieldEl(); $cFieldEl.data('l_field', selectData.field); $cFieldEl.on('valueupdate', NewAd.updateLocationFields); Ads.initSelect(state.$form, selectData.field, { items: Aj.state[selectData.items_key] || [], renderItem: function(item) { return '
' + (item.name + (item.region ? ', ' + item.region : '')) + '
'; }, getData: function(query, items, opts) { return NewAd.getLocationData(items, opts.field, opts.c_field, query); }, getDataOpts: { field: selectData.field, c_field: selectData.c_field, }, onUpdate: NewAd.onSelectUpdate, onChange: NewAd.onLocationSelectChange }); } else { Ads.initSelect(state.$form, selectData.field, { items: Aj.state[selectData.items_key] || [], pairedField: selectData.paired_field || false, l_no_items_found: selectData.no_items_lang_key ? l(selectData.no_items_lang_key) : '', onUpdate: NewAd.onSelectUpdate, onChange: Ads.onSelectChange }); } } state.titleField = state.$form.field('title'); state.titleField.on('change.curPage', NewAd.onTitleChange); state.textField = state.$form.field('text'); state.textField.on('change.curPage', NewAd.onTextChange); state.textField.on('input.curPage', NewAd.onTextInput); state.promoteUrlField = state.$form.field('promote_url'); state.promoteUrlField.on('change.curPage', NewAd.onPromoteUrlChange); state.adInfoField = state.$form.field('ad_info'); state.adInfoField.on('change.curPage', NewAd.onAdInfoChange); state.targetTypeField = state.$form.field('target_type'); state.targetTypeField.fieldEl().on('change.curPage', NewAd.onTargetTypeChange); state.pictureCheckbox = state.$form.field('picture'); state.pictureCheckbox.on('change.curPage', NewAd.onPictureChange); state.confirmedCheckbox = state.$form.field('confirmed'); state.confirmedCheckbox.on('change.curPage', NewAd.onConfirmedChange); NewAd.updateAdPreview(state.$form, state.previewData); NewAd.updateAdTargetOverview(); setTimeout(function() { state.titleField.focusAndSelect(); }, 50); Aj.onLoad(function(state) { state.initFormData = NewAd.getFormData(state.$form); state.initPreviewFormData = NewAd.getPreviewFormData(); Aj.onBeforeUnload(function() { var curPreviewFormData = NewAd.getPreviewFormData(); if (Aj.state.initPreviewFormData != curPreviewFormData) { return l('WEB_LEAVE_PAGE_CONFIRM_TEXT'); } var curFormData = NewAd.getFormData(state.$form); if (Aj.state.initFormData != curFormData) { return l('WEB_LEAVE_PAGE_CONFIRM_TEXT'); } return false; }); NewAd.saveDraftAuto(true); }); }); Aj.onUnload(function(state) { Ads.formDestroy(state.$form); state.$form.off('submit', preventDefault); state.titleField.off('.curPage'); state.textField.off('.curPage'); state.promoteUrlField.off('.curPage'); state.adInfoField.off('.curPage'); state.targetTypeField.fieldEl().off('.curPage'); state.confirmedCheckbox.off('.curPage'); state.pictureCheckbox.off('.curPage'); for (var i = 0; i < state.selectList.length; i++) { var selectData = state.selectList[i]; if (selectData.location_search) { var $cFieldEl = state.$form.field(selectData.c_field).fieldEl(); $cFieldEl.off('valueupdate', NewAd.updateLocationFields); } } clearTimeout(state.saveDraftTo); }); }, onTitleChange: function() { Ads.hideFieldError($(this)); }, onAdInfoChange: function() { Ads.hideFieldError($(this)); }, onTargetTypeChange: function() { var cur_type = this.value; $('.pr-target-options', Aj.ajContainer).each(function() { $(this).toggleClass('visible', $(this).attr('data-value') == cur_type); }); NewAd.updateAdTargetOverview(); NewAd.saveDraftAuto(true); }, onPictureChange: function() { var $form = $(this.form); NewAd.adPostCheck($form); }, onConfirmedChange: function() { $('.create-new-ad-btn', Aj.ajContainer).prop('disabled', !$(this).prop('checked')); }, onTextChange: function() { var $form = $(this.form); var textField = $form.field('text'); Ads.hideFieldError(textField); NewAd.adPostCheck($form); }, getAdTextLength: function(text) { text = text.replace(/!\[(.*?)\]\(tg:\/\/emoji\?id=(\d+)\)/g, '$1'); return text.length; }, onTextInput: function() { var textField = $(this); var text = textField.value(); var max_len = Aj.state.textMaxLength; var symbols_left = max_len - NewAd.getAdTextLength(text); Ads.showFieldError(textField); if (text.indexOf('\n') >= 0) { Ads.showFieldHint(textField, l('ADS_ERROR_POST_NEW_LINES_NOT_ALLOWED'), true); } else if (symbols_left < 0) { Ads.showFieldHint(textField, l('ADS_ERROR_POST_MESSAGE_TOO_LONG', {max_len: Aj.state.textMaxLength}), true); } else { if (symbols_left <= 20) { Ads.showFieldHint(textField, l('WEB_AD_TEXT_SYMBOLS_LEFT', {n: symbols_left})); } else { Ads.showFieldHint(textField, ''); } } }, onPromoteUrlChange: function() { var $form = $(this.form); var promoteUrlField = $form.field('promote_url'); Ads.hideFieldError(promoteUrlField); NewAd.adPostCheck($form); }, adPostCheck: function($form) { var textField = $form.field('text'); var promoteUrlField = $form.field('promote_url'); var cpmField = $form.field('cpm'); var text = textField.value(); var promote_url = promoteUrlField.value(); var $formGroup = promoteUrlField.fieldEl().parents('.form-group'); var $cpmFormGroup = cpmField.fieldEl().parents('.form-group'); if (!text && !promote_url) { return false; } var params = { owner_id: Aj.state.ownerId, text: text, promote_url: promote_url }; if (Aj.state.adId) { params.ad_id = Aj.state.adId; } if ($form.field('picture').prop('checked')) { params.picture = 1; } $formGroup.addClass('field-loading'); $cpmFormGroup.addClass('field-loading'); Aj.apiRequest('checkAdPost', params, function(result) { Ads.hideFieldError(textField); Ads.hideFieldError(promoteUrlField); $cpmFormGroup.removeClass('field-loading'); $formGroup.removeClass('field-loading'); if (result.promote_url) { var new_promote_url = promoteUrlField.value(); if (!new_promote_url || promote_url == new_promote_url) { if (new_promote_url != result.promote_url) { promoteUrlField.value(result.promote_url); } } } if (result.exclude_channel) { var $excludeField = Aj.state.$form.field('exclude_channels'); var excludeValueFull = $excludeField.data('valueFull'); var already_excluded = false; excludeValueFull && $.each(excludeValueFull, function(val, item) { if (item.val == result.exclude_channel.id) { already_excluded = true; } else if (item._auto) { $excludeField.trigger('deselectval', [val]); $excludeField.data('prevval', ''); if (Aj.state.autoExcluded) { delete Aj.state.autoExcluded[item.val]; } } }); if (!already_excluded) { if (!Aj.state.autoExcluded) { Aj.state.autoExcluded = {}; } if (!Aj.state.autoExcluded[result.exclude_channel.id]) { var item = { val: result.exclude_channel.id, name: result.exclude_channel.title, photo: result.exclude_channel.photo, _auto: true }; $excludeField.trigger('selectval', [item, true]); $excludeField.data('prevval', ''); Aj.state.autoExcluded[result.exclude_channel.id] = true; } } } NewAd.updateAdPreview($form, result.preview_data); if (result.error) { if (result.field) { var $field = $form.field(result.field); if ($field.size()) { Ads.showFieldError($field, result.error, true); return false; } } return showAlert(result.error); } }); }, onChannelSearch: function(field, value) { var $fieldEl = Aj.state.$form.field(field); var $formGroup = $fieldEl.fieldEl().parents('.form-group'); var prev_value = $fieldEl.data('prevval'); if (prev_value && prev_value == value) { return false; } $fieldEl.data('prevval', value); Ads.hideFieldError($fieldEl); if (!value) { return false; } var channels_limit = Aj.state.channelItemsLimit; if ($fieldEl.data('value').length >= channels_limit) { var selOpts = $fieldEl.data('selOpts'); if (selOpts.l_channels_limit) { Ads.showFieldError($fieldEl, selOpts.l_channels_limit); return false; } } $formGroup.addClass('field-loading'); Aj.apiRequest('searchChannel', { query: value, field: field }, function(result) { $formGroup.removeClass('field-loading'); if (result.error) { Ads.showFieldError($fieldEl, result.error); return false; } if (result.channel) { var item = { val: result.channel.id, name: result.channel.title, photo: result.channel.photo, username: result.channel.username }; if (result.channel.ask_outside) { item.ask_outside = result.channel.ask_outside; } $fieldEl.trigger('selectval', [item, true]); $fieldEl.data('prevval', ''); } }); }, loadLocationData: function(params, opts, onUpdate, onReady) { Aj.apiRequest('searchLocation', params, function(result) { if (result.error) { if (result.field) { onReady && onReady(); var $field = Aj.state.$form.field(result.field); if ($field.size()) { Ads.showFieldError($field, result.error, true); return false; } } else { if (!opts.retry) opts.retry = 1; else opts.retry++; setTimeout(function(){ NewAd.loadLocationData(params, opts, onUpdate, onReady); }, opts.retry * 1000); } } else { if (opts.retry) { opts.retry = 0; } if (result.items) { var locCache = Aj.globalState._locationCache; var data_key = opts.key; if (!locCache[data_key]) { locCache[data_key] = []; } var items = result.items; for (var i = 0; i < items.length; i++) { var item = items[i]; item._values = [item.name.toLowerCase()]; locCache[data_key].push(item); } onUpdate && onUpdate(); } if (result.next_offset) { params.offset = result.next_offset; NewAd.loadLocationData(params, opts, onUpdate, onReady); } else { onReady && onReady(); } } }); }, updateLocationFields: function(e, value, valueFull) { var field = $(this).data('l_field'); var $fieldEl = Aj.state.$form.field(field); if (!value.length) { $fieldEl.trigger('reset'); } }, getLocationData: function(items, field, c_field, query) { var $form = Aj.state.$form; var $fieldEl = $form.field(field); var $formGroup = $fieldEl.fieldEl().parents('.form-group'); var $cFieldEl = $form.field(c_field); var c_value = $cFieldEl.data('value'); if (c_value.join) { if (c_value.length > 1) { Ads.showFieldError($cFieldEl, l('ADS_ERROR_LOCATION_COUNTRIES_TOO_MANY')); return false; } c_value = c_value.join(';'); } query = query.replace(/^\s+/, ''); if (!query.length || !c_value) { return items; } if (!Aj.globalState._locationCache) { Aj.globalState._locationCache = {}; } var locCache = Aj.globalState._locationCache; var data_key = c_value + '.' + query.substr(0, 1); if (locCache[data_key] === false || locCache[data_key]) { return locCache[data_key] ? locCache[data_key].concat(items) : items; } locCache[data_key] = false; $formGroup.addClass('field-loading'); NewAd.loadLocationData({ countries: c_value, query: query, offset: 0 }, {key: data_key}, function() { $fieldEl.trigger('contentchange'); }, function() { $formGroup.removeClass('field-loading'); $fieldEl.trigger('dataready').trigger('datachange'); }); return false; }, onLocationSelectChange: function(field, value, valueFull) { var $fieldEl = Aj.state.$form.field(field); Ads.hideFieldError($fieldEl); }, onSelectUpdate: function(field, value, valueFull) { var $fieldEl = Aj.state.$form.field(field); var selOpts = $fieldEl.data('selOpts'); var paired_field = selOpts.pairedField; if (!paired_field) { NewAd.updateAdTargetOverview(); return; } var $pairedField = Aj.state.$form.field(paired_field); if ($pairedField.data('inited')) { var paired_value = $pairedField.data('value'); var paired_valueFull = $pairedField.data('valueFull'); valueFull && $.each(valueFull, function(val, item) { if (paired_valueFull[val]) { $pairedField.trigger('deselectval', [val]); $pairedField.data('prevval', ''); } }); } NewAd.updateAdTargetOverview(); }, ePreviewAd: function(e) { e.preventDefault(); NewAd.previewPopup(); }, updateAdPreview: function($form, previewData) { var $previewPopup = Aj.state.$previewPopup; var inPopup = $form.parents('.pr-layer-preview-ad').size() > 0; if (inPopup) { Aj.state.popupPreviewData = previewData; if ($previewPopup) { if (previewData) { $('.js-preview-from', $previewPopup).html(previewData.from); $('.js-preview-from', $previewPopup).attr('href', previewData.from_url); $('.js-promote-photo', $previewPopup).html(previewData.photo); $('.js-promote-photo-tooltip', $previewPopup).html(previewData.from); $('.js-preview-text', $previewPopup).html(previewData.text); $('.js-preview-text tg-emoji', $previewPopup).each(function(){ TEmoji.init(this); }); $('.js-preview-button', $previewPopup).html(previewData.button); $('.js-preview-button', $previewPopup).attr('href', previewData.button_url); $('.js-preview-footer', $previewPopup).each(function() { Ads.updateTextShadow(this, '.ad-msg-text', '.label', 10); }); $('.js-picture-label', $previewPopup).html(previewData.picture_label); $('.js-picture-hint', $previewPopup).html(previewData.picture_hint); } $('.js-promote-photo', $previewPopup).parents('.pr-form-control-wrap').toggleClass('has-photo', !!previewData); $('.js-preview', $previewPopup).toggleClass('active', !!previewData); } } else { Aj.state.previewData = previewData; if (previewData) { $('.js-promote-photo', Aj.state.$form).html(previewData.photo); $('.js-promote-photo-tooltip', Aj.state.$form).html(previewData.from); $('.js-picture-label', Aj.state.$form).html(previewData.picture_label); $('.js-picture-hint', Aj.state.$form).html(previewData.picture_hint); $('.js-cpm-extra', Aj.state.$form).html(previewData.cpm_extra); $('.js-cpm-extra-tooltip', Aj.state.$form).html(previewData.cpm_extra_tooltip); } $('.js-promote-photo', Aj.state.$form).parents('.pr-form-control-wrap').toggleClass('has-photo', !!previewData); $('.js-cpm-extra', Aj.state.$form).parents('.pr-form-control-wrap').toggleClass('has-extra-cpm', !!(previewData && previewData.cpm_extra)); $('.js-preview-link', Aj.state.$form).toggleClass('inactive', !previewData); } }, checkBeforePreviewPopupUnload: function(load_fn) { var message = null; var curPreviewFormData = NewAd.getPreviewFormData(); if (Aj.state.initPreviewFormData != curPreviewFormData) { message = l('WEB_LEAVE_FORM_CONFIRM_TEXT'); } if (message) { var message_html = $('
').text(message).html(); showConfirm(message_html, load_fn, l('WEB_LEAVE_PAGE', 'Leave')); return false; } else { load_fn(); return true; } }, previewPopup: function() { var state = Aj.state; if (!state.previewData) { return false; } var $previewPopup = $(''); state.$previewPopup = $previewPopup; var $form = state.$form; var text = $form.field('text').value(); var promote_url = $form.field('promote_url').value(); var picture_checked = $form.field('picture').prop('checked'); var previewPictureChange = function() { $('.js-preview', $previewPopup).toggleClass('picture', !!$(this).prop('checked')); }; var $previewForm = $('.pr-new-form', $previewPopup); Ads.formInit($previewForm); $previewForm.on('submit', preventDefault); state.previewTextField = $previewForm.field('text'); state.previewTextField.on('change.curPage', NewAd.onTextChange); state.previewTextField.value(text); state.previewTextField.on('input.curPage', NewAd.onTextInput); state.previewPromoteUrlField = $previewForm.field('promote_url'); state.previewPromoteUrlField.on('change.curPage', NewAd.onPromoteUrlChange); state.previewPromoteUrlField.value(promote_url); state.previewPictureCheckbox = $previewForm.field('picture'); state.previewPictureCheckbox.on('change.curPage', previewPictureChange); state.previewPictureCheckbox.prop('checked', picture_checked); $('.js-preview', $previewPopup).toggleClass('picture', !!picture_checked); NewAd.updateAdPreview($previewForm, state.previewData); NewAd.adPostCheck($previewForm); var previewSave = function() { var text = state.previewTextField.value(); var promote_url = state.previewPromoteUrlField.value(); var picture_checked = state.previewPictureCheckbox.prop('checked'); $form.field('text').value(text).updateAutosize(); $form.field('promote_url').value(promote_url); $form.field('picture').prop('checked', picture_checked); NewAd.updateAdPreview($form, state.popupPreviewData); NewAd.adPostCheck($form); delete state.popupPreviewData; delete state.$previewPopup; state.initPreviewFormData = NewAd.getPreviewFormData(); closePopup($previewPopup); } var $submitBtn = $('.submit-form-btn', $previewPopup); $submitBtn.on('click', previewSave); var previewCancel = function() { closePopup($previewPopup); } var $cancelBtn = $('.cancel-form-btn', $previewPopup); $cancelBtn.on('click', previewCancel); $previewPopup.one('popup:open', function() { $('.pr-preview-ad-message .ad-msg-date', $previewPopup).each(function() { Ads.updateTextShadow(this, '.ad-msg-text', '.label', 10); }); state.previewTextField.updateAutosize(); state.initPreviewFormData = NewAd.getPreviewFormData(); }); $previewPopup.one('popup:close', function() { Ads.formDestroy($previewForm); $previewForm.off('submit', preventDefault); delete state.$previewPopup; $submitBtn.off('click', previewSave); $cancelBtn.off('click', previewCancel); $previewPopup.remove(); state.initPreviewFormData = NewAd.getPreviewFormData(); }); openPopup($previewPopup, { closeByClickOutside: '.popup-no-close', onBeforeClose: function($popup) { var unloaded = NewAd.checkBeforePreviewPopupUnload(function() { var options = $popup.data('options'); options.onBeforeClose = null; closePopup($popup); }); return unloaded; } }); return $previewPopup; }, updateAdTargetOverview: function() { var len = {}, lang_params = {}, need_outside_cb = false; var target_type = Aj.state.$form.field('target_type').value(); for (var i = 0; i < Aj.state.selectList.length; i++) { var selectData = Aj.state.selectList[i]; var field = selectData.field; var $field = Aj.state.$form.field(field); var value = $field.data('value') || []; var valueFull = $field.data('valueFull') || {}; len[field] = value.length; if (value.length) { var list = []; for (var j = 0; j < value.length; j++) { var val = value[j], valFull = valueFull[val] || {}; list.push(valFull.username ? '' + valFull.name + '' : '' + valFull.name + ''); if (valFull.ask_outside) { need_outside_cb = true; } } if (list.length > 1) { var last_item = list.pop(); list[list.length - 1] = l('WEB_AD_TARGET_AND', {item1: list[list.length - 1], item2: last_item}); } lang_params[field] = list.join(', '); } else { lang_params[field] = ''; } Ads.hideFieldError($field); } var overview = ''; if (target_type == 'channels') { if ((len.langs || len.topics) && len.channels) { if (len.langs) { Ads.showFieldError(Aj.state.$form.field('langs'), l('ADS_ERROR_LANG_AND_CHANNEL_NOT_ALLOWED')); } else if (len.topics) { Ads.showFieldError(Aj.state.$form.field('topics'), l('ADS_ERROR_TOPIC_AND_CHANNEL_NOT_ALLOWED')); } } else if (!len.langs && len.topics) { Ads.showFieldError(Aj.state.$form.field('langs'), l('ADS_ERROR_LANGUAGE_REQUIRED')); } if (!len.langs && !len.topics && !len.channels || (len.langs || len.topics) && len.channels || !len.langs && len.topics) { overview += '
' + l('WEB_AD_TARGET_NOTHING') + '
'; } else { if (len.langs > 0) { if (len.topics > 0) { overview += '
' + l('WEB_AD_TARGET_TOPICS', lang_params) + '
'; } else { overview += '
' + l('WEB_AD_TARGET_LANGS', lang_params) + '
'; } } if (len.channels > 0) { overview += '
' + l('WEB_AD_TARGET_CHANNELS', lang_params) + '
'; } if (len.exclude_topics > 0) { overview += '
' + l('WEB_AD_TARGET_EXCLUDE_TOPICS', lang_params) + '
'; } if (len.exclude_channels > 0) { overview += '
' + l('WEB_AD_TARGET_EXCLUDE_CHANNELS', lang_params) + '
'; } } $('.js-exclude-outside').toggleClass('hide', !need_outside_cb); } else if (target_type == 'users') { if (!len.locations && !len.countries) { overview += '
' + l('WEB_AD_TARGET_NOTHING') + '
'; } else { var user_targets = []; if (len.locations > 0) { user_targets.push(l('WEB_AD_TARGET_USER_LOCATIONS', lang_params)); } else if (len.countries > 0) { lang_params.locations = lang_params.countries; user_targets.push(l('WEB_AD_TARGET_USER_LOCATIONS', lang_params)); } if (len.user_langs > 0) { user_targets.push(l('WEB_AD_TARGET_USER_LANGS', lang_params)); } if (len.user_topics > 0) { user_targets.push(l('WEB_AD_TARGET_USER_TOPICS', lang_params)); } if (len.audiences > 0) { user_targets.push(l('WEB_AD_TARGET_AUDIENCES', lang_params)); } if (user_targets.length > 1) { var last_user_target = user_targets.pop(); user_targets[user_targets.length - 1] = l('WEB_AD_TARGET_AND', {item1: user_targets[user_targets.length - 1], item2: last_user_target}); } overview += '
' + l('WEB_AD_TARGET_USERS', {target: user_targets.join(', ')}) + '
'; if (len.exclude_user_topics > 0) { overview += '
' + l('WEB_AD_TARGET_USER_EXCLUDE_TOPICS', lang_params) + '
'; } if (len.exclude_audiences > 0) { overview += '
' + l('WEB_AD_TARGET_EXCLUDE_AUDIENCES', lang_params) + '
'; } } $('.js-exclude-outside').addClass('hide'); } else { overview += '
' + l('WEB_AD_TARGET_NOTHING') + '
'; } $('.pr-target-overview', Aj.ajContainer).html(overview); }, getFormData: function($form) { var form = $form.get(0); if (!form) return false; var values = [ $form.field('title').value(), $form.field('text').value(), $form.field('promote_url').value(), $form.field('ad_info').value(), $form.field('cpm').value(), $form.field('budget').value(), $form.field('target_type').value() ]; if ($form.field('picture').prop('checked')) { values.push('picture'); } for (var i = 0; i < Aj.state.selectList.length; i++) { var selectData = Aj.state.selectList[i]; var vals = $form.field(selectData.field).data('value'); values.push(vals.join(';')); } if ($form.field('exclude_outside').prop('checked')) { values.push('exclude_outside'); } return values.join('|'); }, getPreviewFormData: function($form) { if (Aj.state.$previewPopup) { var $previewPopup = Aj.state.$previewPopup; var $previewForm = $('.pr-new-form', $previewPopup); if (!$previewForm.get(0)) return false; var values = [ $previewForm.field('text').value(), $previewForm.field('promote_url').value() ]; if ($previewForm.field('picture').prop('checked')) { values.push('picture'); } return values.join('|'); } return false; }, eSubmitForm: function(e) { e.preventDefault(); var $form = Aj.state.$form; var $button = $(this); var title = $form.field('title').value(); var text = $form.field('text').value(); var promote_url = $form.field('promote_url').value(); var ad_info = $form.field('ad_info').value(); var cpm = Ads.amountFieldValue($form, 'cpm'); var budget = Ads.amountFieldValue($form, 'budget'); var target_type = $form.field('target_type').value(); if (!title.length) { $form.field('title').focus(); return false; } if (!text.length) { $form.field('text').focus(); return false; } if (!promote_url.length) { $form.field('promote_url').focus(); return false; } if (cpm === false) { $form.field('cpm').focus(); return false; } if (budget === false) { $form.field('budget').focus(); return false; } var params = { owner_id: Aj.state.ownerId, title: title, text: text, promote_url: promote_url, ad_info: ad_info, cpm: cpm, budget: budget, target_type: target_type }; if ($form.field('picture').prop('checked')) { params.picture = 1; } for (var i = 0; i < Aj.state.selectList.length; i++) { var selectData = Aj.state.selectList[i]; var values = $form.field(selectData.field).data('value'); params[selectData.field] = values.join(';'); } if ($form.field('exclude_outside').prop('checked')) { params.exclude_outside = 1; } NewAd.saveDraftAuto(true); $button.prop('disabled', true); Aj.apiRequest('createAd', params, function(result) { if (result.error) { $button.prop('disabled', false); if (result.field) { var $field = $form.field(result.field); if ($field.size()) { Ads.showFieldError($field, result.error, true); return false; } } return showAlert(result.error); } Aj.state.initFormData = NewAd.getFormData($form); NewAd.saveDraftAuto(true); if (result.redirect_to) { Aj.location(result.redirect_to); } }); return false; }, eClearDraft: function(e) { e.preventDefault(); NewAd.clearDraft(); }, saveDraftAuto: function(with_delay) { if (!with_delay) { NewAd.saveDraft(); } clearTimeout(Aj.state.saveDraftTo); Aj.state.saveDraftTo = setTimeout(NewAd.saveDraftAuto, 3000, false); }, saveDraft: function() { var $form = Aj.state.$form; var title = $form.field('title').value(); var text = $form.field('text').value(); var promote_url = $form.field('promote_url').value(); var ad_info = $form.field('ad_info').value(); var cpm = Ads.amountFieldValue($form, 'cpm'); var budget = Ads.amountFieldValue($form, 'budget'); var target_type = $form.field('target_type').value(); var curFormData = NewAd.getFormData($form); if (Aj.state.initFormData == curFormData) { return false; } var params = { owner_id: Aj.state.ownerId, title: title, text: text, promote_url: promote_url, ad_info: ad_info, cpm: cpm, budget: budget, target_type: target_type }; if ($form.field('picture').prop('checked')) { params.picture = 1; } for (var i = 0; i < Aj.state.selectList.length; i++) { var selectData = Aj.state.selectList[i]; var values = $form.field(selectData.field).data('value'); params[selectData.field] = values.join(';'); } if ($form.field('exclude_outside').prop('checked')) { params.exclude_outside = 1; } Aj.apiRequest('saveAdDraft', params, function(result) { if (result.error) { return showAlert(result.error); } Aj.state.initFormData = curFormData; NewAd.saveDraftAuto(true); $('.pr-draft-btn-wrap').toggleClass('active', !!result.has_draft); // $('.pr-draft-btn-wrap').addClass('saved'); // setTimeout(function() { // $('.pr-draft-btn-wrap').removeClass('saved'); // }, 1500); }); return false; }, clearDraft: function(callback) { var $form = Aj.state.$form; $form.field('title').value(''); $form.field('text').value(''); $form.field('promote_url').value(''); $form.field('ad_info').value(''); $form.field('cpm').value(''); $form.field('budget').value(''); $form.field('picture').prop('checked', false); for (var i = 0; i < Aj.state.selectList.length; i++) { var selectData = Aj.state.selectList[i]; var values = $form.field(selectData.field).trigger('reset'); } $form.field('exclude_outside').prop('checked', false); Aj.state.titleField.focusAndSelect(); NewAd.updateAdPreview(Aj.state.$form, false); var curFormData = NewAd.getFormData($form); var params = { owner_id: Aj.state.ownerId }; $('.pr-draft-btn-wrap').removeClass('active'); NewAd.saveDraftAuto(true); Aj.apiRequest('clearAdDraft', params, function(result) { if (result.error) { return showAlert(result.error); } Aj.state.initFormData = curFormData; NewAd.saveDraftAuto(true); callback && callback(); }); return false; } }; var Account = { formFields: [ 'full_name', 'email', 'phone_number', 'country', 'city', 'ad_info' ], addFundsFormFields: [ 'adv_type', 'products_desc', 'ads_language', 'annual_budget', 'additional_comment', ], optFields: { ad_info: 1 }, init: function() { var cont = Aj.ajContainer; Aj.onLoad(function(state) { state.$form = $('.account-edit-form', cont); Ads.formInit(state.$form); state.$form.on('submit', preventDefault); cont.on('click.curPage', '.save-info-btn', Account.eSubmitForm); cont.on('change.curPage', '.pr-form-control', Account.onFieldChange); Ads.initSelect(state.$form, 'channel', { items: Aj.state.channelItems || [], noMultiSelect: true, renderSelectedItem: function(val, item) { return '
' + (item.photo ? '
' + item.photo + '
' : '') + '
' + item.name + '
'; }, onChange: Account.onChannelChange }); Aj.onLoad(function(state) { state.initFormData = Account.getFormData(state.$form); Aj.onBeforeUnload(function() { var curFormData = Account.getFormData(state.$form); if (Aj.state.initFormData != curFormData) { return l('WEB_LEAVE_PAGE_CONFIRM_TEXT'); } return false; }); }); }); Aj.onUnload(function(state) { Ads.formDestroy(state.$form); state.$form.off('submit', preventDefault); }); }, onFieldChange: function() { if (!$(this).hasClass('js-amount-input')) { Ads.hideFieldError($(this)); } }, onChannelChange: function(field, value, valueFull) { $accPhoto = $('.pr-account-button-wrap.current .pr-account-button-photo'); $accTitle = $('.pr-account-button-wrap.current .pr-account-button-title'); if (!$accPhoto.data('def-val')) { $accPhoto.data('def-val', $accPhoto.html()); } if (!$accTitle.data('def-val')) { $accTitle.data('def-val', $accTitle.html()); } $accPhoto.html(valueFull ? valueFull.photo : $accPhoto.data('def-val')); $accTitle.html(valueFull ? valueFull.name : $accTitle.data('def-val')); var $form = Aj.state.$form; for (var i = 0; i < Account.formFields.length; i++) { var field = Account.formFields[i]; var value = $form.field(field).prop('disabled', !valueFull); } }, getFormData: function($form) { var form = $form.get(0); if (!form) return false; var values = []; if (!Aj.state.ownerId) { var value = $form.field('channel').data('value'); values.push(value); } for (var i = 0; i < Account.formFields.length; i++) { var field = Account.formFields[i]; var value = $form.field(field).value(); values.push(value); } return values.join('|'); }, eSubmitForm: function(e) { e.preventDefault(); var $form = Aj.state.$form; var $button = $(this); var params = {}; if (Aj.state.ownerId) { params.owner_id = Aj.state.ownerId; } else { params.owner_id = $form.field('channel').data('value'); if (!params.owner_id) { $form.field('channel').trigger('click'); return false; } } for (var i = 0; i < Account.formFields.length; i++) { var field = Account.formFields[i]; var value = $form.field(field).value(); if (!value.length && !Account.optFields[field]) { $form.field(field).focus(); return false; } params[field] = value; } $button.prop('disabled', true); Aj.apiRequest('saveAccountInfo', params, function(result) { if (result.error) { $button.prop('disabled', false); if (result.field) { var $field = $form.field(result.field); if ($field.size()) { Ads.showFieldError($field, result.error, true); return false; } } return showAlert(result.error); } Aj.state.initFormData = Account.getFormData($form); if (result.redirect_to) { Aj.location(result.redirect_to); } }); return false; }, initAddFunds: function() { var cont = Aj.ajContainer; Aj.onLoad(function(state) { state.$form = $('.add-funds-req-form', cont); Ads.formInit(state.$form); state.$form.on('submit', preventDefault); cont.on('click.curPage', '.send-request-btn', Account.eSendAddFundsRequest); cont.on('change.curPage', '.pr-form-control', Account.onFieldChange); Ads.initSelect(state.$form, 'ads_language', { items: Aj.state.langItems || [], noMultiSelect: true, l_no_items_found: l('WEB_AD_NO_LANGS_FOUND'), onChange: Account.onFieldChange }); state.confirmedCheckbox = state.$form.field('confirmed'); state.confirmedCheckbox.on('change.curPage', Account.onConfirmedChange); Aj.onLoad(function(state) { state.initFormData = Account.getAddFundsFormData(state.$form); Aj.onBeforeUnload(function() { var curFormData = Account.getAddFundsFormData(state.$form); if (Aj.state.initFormData != curFormData) { return l('WEB_LEAVE_PAGE_CONFIRM_TEXT'); } return false; }); }); }); Aj.onUnload(function(state) { Ads.formDestroy(state.$form); state.$form.off('submit', preventDefault); }); }, onConfirmedChange: function() { $('.send-request-btn', Aj.ajContainer).prop('disabled', !$(this).prop('checked')); }, getAddFundsFormData: function($form) { var form = $form.get(0); if (!form) return false; var values = []; for (var i = 0; i < Account.formFields.length; i++) { var field = Account.formFields[i]; var value = $form.field(field).value(); values.push(value); } for (var i = 0; i < Account.addFundsFormFields.length; i++) { var field = Account.addFundsFormFields[i]; var value = $form.field(field).value(); values.push(value); } return values.join('|'); }, eSendAddFundsRequest: function(e) { e.preventDefault(); var $form = Aj.state.$form; var $button = $(this); var params = { owner_id: Aj.state.ownerId }; for (var i = 0; i < Account.formFields.length; i++) { var field = Account.formFields[i]; var value = $form.field(field).value(); if (!value.length && !Account.optFields[field]) { $form.field(field).focus(); return false; } params[field] = value; } params.adv_type = $form.field('adv_type').value(); params.products_desc = $form.field('products_desc').value(); if (!params.products_desc.length) { $form.field('products_desc').focus(); return false; } params.ads_language = $form.field('ads_language').data('value'); if (!params.ads_language.length) { $form.field('ads_language').trigger('click'); return false; } params.annual_budget = Ads.amountFieldValue($form, 'annual_budget'); if (params.annual_budget === false) { $form.field('annual_budget').focus(); return false; } params.additional_comment = $form.field('additional_comment').value(); $button.prop('disabled', true); Aj.apiRequest('sendAddFundsRequest', params, function(result) { if (result.error) { $button.prop('disabled', false); if (result.field) { var $field = $form.field(result.field); if ($field.size()) { Ads.showFieldError($field, result.error, true); return false; } } return showAlert(result.error); } Aj.state.initFormData = Account.getAddFundsFormData($form); if (result.redirect_to) { Aj.location(result.redirect_to); } if (result.ok_msg) { showAlert(result.ok_msg); } }); return false; }, initToken: function() { var cont = Aj.ajContainer; Aj.onLoad(function(state) { cont.on('click.curPage', '.js-copy-token-btn', Account.eCopyToken); cont.on('click.curPage', '.js-revoke-token-btn', Account.eRevokeToken); }); }, eCopyToken: function(e) { e.preventDefault(); copyToClipboard(Aj.state.token); showToast(l('WEB_TOKEN_COPIED', 'Copied.')); }, revokeTokenPopup: function (onConfirm) { var $confirm = $(''); var confirm = function() { onConfirm && onConfirm($confirm); closePopup($confirm); } var $primaryBtn = $('.popup-primary-btn', $confirm); $primaryBtn.on('click', confirm); $confirm.one('popup:close', function() { $primaryBtn.off('click', confirm); $confirm.remove(); }); openPopup($confirm, { closeByClickOutside: '.popup-no-close', }); return $confirm; }, eRevokeToken: function(e) { e.preventDefault(); var $btn = $(this); if ($btn.data('disabled')) { return false; } Account.revokeTokenPopup(function() { $btn.data('disabled', true); Aj.apiRequest('revokeToken', { owner_id: Aj.state.ownerId }, function(result) { $btn.data('disabled', false); if (result.error) { return showAlert(result.error); } if (result.new_token) { Aj.state.token = result.new_token; } if (result.new_token_value) { $('.js-token-value', Aj.ajContainer).value(result.new_token_value); } if (result.toast) { showToast(result.toast); } }); }); return false; } }; var OwnerAds = { init: function() { var cont = Aj.ajContainer; Aj.onLoad(function(state) { state.$searchField = $('.pr-search-input'); state.$adsListTable = $('.pr-table'); state.$searchResults = $('.pr-table tbody'); Ads.fieldInit(state.$searchField); cont.on('click.curPage', '.pr-cell-sort', OwnerAds.eSortList); cont.on('click.curPage', '.pr-table-settings', OwnerAds.eSettingsOpen); cont.on('click.curPage', '.js-clone-ad-btn', EditAd.eCloneAd); cont.on('click.curPage', '.delete-ad-btn', EditAd.deleteAd); state.$tableColumnsPopup = $('.table-columns-popup'); state.$tableColumnsForm = $('.table-columns-form'); state.$tableColumnsForm.on('change.curPage', 'input.checkbox', OwnerAds.eColumnChange); state.$tableColumnsForm.on('submit.curPage', preventDefault); state.$searchField.initSearch({ $results: state.$searchResults, emptyQueryEnabled: true, updateOnInit: true, resultsNotScrollable: true, itemTagName: 'tr', enterEnabled: function() { return false; }, renderItem: function(item, query) { var status_attrs = ' href="' + item.base_url + item.status_url + '" ' + (item.status_attrs || 'data-layer'); var title_class = 'pr-trg-type-' + item.trg_type; var tme_link = item.tme_path ? 't.me/' + item.tme_path + '' : '' + l('WEB_ADS_NO_TME_LINK') + ''; return '
' + item.title + '
' + tme_link + '
' + item.status + '
' + Aj.state.adsDropdownTpl.replace(/\{ad_id\}/g, item.ad_id).replace(/\{tme_path\}/g, item.tme_path).replace(/\{ad_text\}/g, item.text) + '
'; }, renderLoading: function() { return '
' + l('WEB_OWNER_ADS_LOADING') + '
'; }, renderNoItems: function(query) { if (Aj.state.adsListIsLoading) { return '
' + l('WEB_OWNER_ADS_LOADING') + '
'; } return '
' + l('WEB_OWNER_NO_ADS') + '
'; }, appendToItems: function(query, result_count) { if (Aj.state.adsListIsLoading && result_count > 0) { return '
' + l('WEB_OWNER_ADS_LOADING') + '
'; } return ''; }, getData: function() { return OwnerAds.getAdsList(); } }); }); Aj.onUnload(function(state) { Ads.fieldDestroy(state.$searchField); state.$searchField.destroySearch(); state.$tableColumnsForm.off('.curPage'); }); }, eSortList: function(e) { var $sortEl = $(this); var sortBy = $sortEl.attr('data-sort-by'); var sortAsc = $sortEl.hasClass('sort-asc'); if (sortBy == Aj.state.adsListSortBy) { Aj.state.adsListSortAsc = !sortAsc; } else { Aj.state.adsListSortBy = sortBy; Aj.state.adsListSortAsc = false; } OwnerAds.updateAdsList(); Aj.state.$searchField.trigger('datachange'); }, eSettingsOpen: function() { openPopup(Aj.state.$tableColumnsPopup, { closeByClickOutside: '.popup-no-close', }); }, eColumnChange: function() { var column = $(this).prop('name'); var checked = $(this).prop('checked'); Aj.state.$adsListTable.cssProp('--coldp-' + column, checked ? '' : 'none'); OwnerAds.submitColumns(); }, submitColumns: function() { var $form = Aj.state.$tableColumnsForm; var active_columns = []; for (var i = 0; i < Aj.state.adsListAllColumns.length; i++) { var column = Aj.state.adsListAllColumns[i]; if ($form.field(column).prop('checked')) { active_columns.push(column); } } Aj.apiRequest('saveAdsColumns', { columns: active_columns.join(';') }); return false; }, updateAdsList: function() { if (Aj.state.adsList) { var sortBy = Aj.state.adsListSortBy; var sortAsc = Aj.state.adsListSortAsc; $('.pr-cell-sort').each(function() { var $sortEl = $(this); var curSortBy = $sortEl.attr('data-sort-by'); $sortEl.toggleClass('sort-active', sortBy == curSortBy); $sortEl.toggleClass('sort-asc', sortAsc && sortBy == curSortBy); }); Aj.state.adsList.sort(function(ad1, ad2) { var v1 = sortAsc ? ad1 : ad2; var v2 = sortAsc ? ad2 : ad1; return (v1[sortBy] - v2[sortBy]) || (v1.date - v2.date); }); } }, processAdsList: function(result, opts) { opts = opts || {}; if (result.items) { if (!Aj.state.adsList) { Aj.state.adsList = []; } for (var i = 0; i < result.items.length; i++) { var item = result.items[i]; item.base_url = '/account/ad/' + item.ad_id; item._values = [ item.title.toLowerCase(), item.tme_path.toLowerCase(), ]; Aj.state.adsList.push(item); } OwnerAds.updateAdsList(); Aj.state.$searchField.trigger('contentchange'); } if (result.next_offset_id) { opts.offset = result.next_offset_id; OwnerAds.loadAdsList(opts); } else { Aj.state.adsListIsLoading = false; Aj.state.$searchField.trigger('dataready'); } }, loadAdsList: function(opts) { opts = opts || {}; Aj.apiRequest('getAdsList', { owner_id: Aj.state.ownerId, offset_id: opts.offset }, function(result) { if (result.error) { if (!opts.retry) opts.retry = 1; else opts.retry++; setTimeout(function(){ OwnerAds.loadAdsList(opts); }, opts.retry * 1000); } else { if (opts.retry) { opts.retry = 0; } OwnerAds.processAdsList(result, opts); } }); }, getAdsList: function() { var _data = Aj.state.adsList; if (_data === false) { return false; } else if (_data) { return _data; } Aj.state.adsList = false; Aj.state.adsListIsLoading = true; if (Aj.state.initialAdsList) { setTimeout(function() { OwnerAds.processAdsList(Aj.state.initialAdsList); }, 10); } else { OwnerAds.loadAdsList({offset: 0}); } return false; }, updateAd: function(ad) { if (!Aj.state || !Aj.state.adsList) { return; } var adsList = Aj.state.adsList; for (var i = 0; i < adsList.length; i++) { if (ad.owner_id == adsList[i].owner_id && ad.ad_id == adsList[i].ad_id) { ad.base_url = '/account/ad/' + ad.ad_id; ad._values = [ ad.title.toLowerCase(), ad.tme_path.toLowerCase(), ]; adsList[i] = ad; OwnerAds.updateAdsList(); Aj.state.$searchField.trigger('contentchange'); return; } } } }; var ReviewAds = { init: function() { var cont = Aj.ajContainer; Aj.onLoad(function(state) { state.$form = $('.pr-search-form', cont); state.$form.on('submit', ReviewAds.onSubmit); state.$searchField = $('.pr-search-input', cont); Ads.fieldInit(state.$searchField); cont.on('click.curPage', '.pr-search-reset', ReviewAds.eClearSearch); cont.on('click.curPage', '.ad-approve-btn', ReviewAds.eApproveAd); cont.on('click.curPage', '.ad-decline-btn', ReviewAds.eDeclineAd); $(window).on('scroll resize', ReviewAds.onScroll); ReviewAds.onScroll(); }); Aj.onUnload(function(state) { state.$form.off('submit', ReviewAds.onSubmit); Ads.fieldDestroy(state.$searchField); $(window).off('scroll resize', ReviewAds.onScroll); }); }, onScroll: function() { $('.js-load-more').each(function() { var $loadMore = $(this); var top = $loadMore.offset().top - $(window).scrollTop(); if (top < $(window).height() * 2) { ReviewAds.load($loadMore); } }); }, load: function($loadMore) { var offset = $loadMore.attr('data-offset'); if (!offset) { $loadMore.remove(); } if ($loadMore.data('loading')) { return; } var params = Aj.state.filterParams; params.offset_id = offset; var $loadMoreBtn = $('.pr-load-more', $loadMore); $loadMoreBtn.data('old-text', $loadMoreBtn.text()).text($loadMoreBtn.data('loading')).addClass('dots-animated'); $loadMore.data('loading', true); Aj.apiRequest('loadReviewedAds', params, function(result) { $loadMore.data('loading', false); if (result.ads_html) { var $loadMoreCont = $loadMore.closest('.pr-review-list'); if ($loadMoreCont.size()) { $loadMore.remove(); $loadMoreCont.append(result.ads_html); Ads.updateAdMessagePreviews($loadMoreCont); } else { var $loadMoreBtn = $('.pr-load-more', $loadMore); $loadMoreBtn.text($loadMoreBtn.data('old-text')).removeClass('dots-animated'); } ReviewAds.onScroll(); } }); }, onSubmit: function(e) { e.preventDefault(); var href = this.action; if (this.query.value) { href += href.indexOf('?') >= 0 ? '&' : '?'; href += 'query=' + encodeURIComponent(this.query.value); } Aj.location(href); }, eClearSearch: function(e) { Aj.state.$form.submit(); }, eApproveAd: function(e) { e.preventDefault(); var $ad = $(this).parents('.js-review-item'); var owner_id = $ad.attr('data-owner-id'); var ad_id = $ad.attr('data-ad-id'); var $buttons = $ad.find('.pr-btn'); if ($buttons.prop('disabled')) { return false; } $buttons.prop('disabled', true); Aj.apiRequest('approveAd', { owner_id: owner_id, ad_id: ad_id }, function(result) { $buttons.prop('disabled', false); if (result.error) { return showAlert(result.error); } if (result.status_html) { $ad.find('.js-review-ad-status').html(result.status_html); } if (result.buttons_html) { $ad.find('.js-review-buttons').html(result.buttons_html); } }); return false; }, eDeclineAd: function(e) { e.preventDefault(); var $ad = $(this).parents('.js-review-item'); var owner_id = $ad.attr('data-owner-id'); var ad_id = $ad.attr('data-ad-id'); var $buttons = $ad.find('.pr-btn'); var reason_id = $(this).attr('data-reason-id'); if ($buttons.prop('disabled')) { return false; } $buttons.prop('disabled', true); Aj.apiRequest('declineAd', { owner_id: owner_id, ad_id: ad_id, reason_id: reason_id }, function(result) { $buttons.prop('disabled', false); if (result.error) { return showAlert(result.error); } if (result.status_html) { $ad.find('.js-review-ad-status').html(result.status_html); } if (result.buttons_html) { $ad.find('.js-review-buttons').html(result.buttons_html); } }); return false; } }; var EditAd = { init: function() { var cont = Aj.ajContainer; Aj.onLoad(function(state) { state.$form = $('.pr-new-form', cont); Ads.formInit(state.$form); state.$form.on('submit', preventDefault); cont.on('click.curPage', '.js-preview-link', NewAd.ePreviewAd); cont.on('click.curPage', '.edit-ad-btn', EditAd.eSubmitForm); cont.on('click.curPage', '.js-clone-ad-btn', EditAd.eCloneAd); cont.on('click.curPage', '.delete-ad-btn', EditAd.deleteAd); cont.on('click.curPage', '.pr-form-select', EditAd.eSelectPlaceholder); state.titleField = state.$form.field('title'); state.titleField.on('change.curPage', NewAd.onTitleChange); state.textField = state.$form.field('text'); state.textField.on('change.curPage', NewAd.onTextChange); state.textField.on('input.curPage', NewAd.onTextInput); state.promoteUrlField = state.$form.field('promote_url'); state.promoteUrlField.on('change.curPage', NewAd.onPromoteUrlChange); state.adInfoField = state.$form.field('ad_info'); state.adInfoField.on('change.curPage', NewAd.onAdInfoChange); state.pictureCheckbox = state.$form.field('picture'); state.pictureCheckbox.on('change.curPage', NewAd.onPictureChange); NewAd.updateAdPreview(state.$form, state.previewData); Aj.onLoad(function(state) { state.initFormData = EditAd.getFormData(state.$form); state.initPreviewFormData = NewAd.getPreviewFormData(); Aj.onBeforeUnload(function() { var curPreviewFormData = NewAd.getPreviewFormData(); if (Aj.state.initPreviewFormData != curPreviewFormData) { return l('WEB_LEAVE_PAGE_CONFIRM_TEXT'); } var curFormData = EditAd.getFormData(state.$form); if (Aj.state.initFormData != curFormData) { return l('WEB_LEAVE_PAGE_CONFIRM_TEXT'); } return false; }); }); }); Aj.onUnload(function(state) { Ads.formDestroy(state.$form); state.$form.off('submit', preventDefault); state.titleField.off('.curPage'); state.textField.off('.curPage'); state.promoteUrlField.off('.curPage'); }); }, getFormData: function($form) { var form = $form.get(0); if (!form) return false; var values = [ $form.field('title').value(), $form.field('text').value(), $form.field('promote_url').value(), $form.field('cpm').value(), ]; return values.join('|'); }, eSelectPlaceholder: function() { Ads.showHint($('.pr-form-control-hint', this), 50, 2000); }, initEditTitlePopup: function() { var cont = Aj.layer; Aj.onLayerLoad(function(layerState) { layerState.$form = $('.pr-popup-edit-form', cont); Ads.formInit(layerState.$form); layerState.titleField = layerState.$form.field('title'); layerState.titleField.on('change.curPage', NewAd.onTitleChange); Aj.layer.one('popup:open', function() { layerState.titleField.focusAndSelect(true); }); layerState.$form.on('submit', EditAd.eSubmitEditTitlePopupForm); cont.on('click.curLayer', '.submit-form-btn', EditAd.eSubmitEditTitlePopupForm); }); Aj.onLayerUnload(function(layerState) { Ads.formDestroy(layerState.$form); layerState.$form.off('submit', EditAd.eSubmitEditTitlePopupForm); layerState.titleField.off('.curPage'); }); }, eSubmitEditTitlePopupForm: function(e) { e.preventDefault(); var $form = Aj.layerState.$form; var owner_id = $form.field('owner_id').value(); var ad_id = $form.field('ad_id').value(); var title = $form.field('title').value(); if ($form.data('disabled')) { return false; } if (!title.length) { $form.field('title').focus(); return false; } var params = { owner_id: owner_id, ad_id: ad_id, title: title }; $form.data('disabled', true); Aj.apiRequest('editAdTitle', params, function(result) { $form.data('disabled', false); if (result.error) { if (result.field) { var $field = $form.field(result.field); if ($field.size()) { Ads.showFieldError($field, result.error, true); return false; } } return showAlert(result.error); } closePopup(Aj.layer); if (result.ad) { OwnerAds.updateAd(result.ad); } }); return false; }, initEditCPMPopup: function() { var cont = Aj.layer; Aj.onLayerLoad(function(layerState) { layerState.$form = $('.pr-popup-edit-form', cont); Ads.formInit(layerState.$form); layerState.cpmField = layerState.$form.field('cpm'); Aj.layer.one('popup:open', function() { layerState.cpmField.focusAndSelect(true); }); layerState.$form.on('submit', EditAd.eSubmitEditCPMPopupForm); cont.on('click.curLayer', '.submit-form-btn', EditAd.eSubmitEditCPMPopupForm); }); Aj.onLayerUnload(function(layerState) { Ads.formDestroy(layerState.$form); layerState.$form.off('submit', EditAd.eSubmitEditCPMPopupForm); }); }, eSubmitEditCPMPopupForm: function(e) { e.preventDefault(); var $form = Aj.layerState.$form; var owner_id = $form.field('owner_id').value(); var ad_id = $form.field('ad_id').value(); var cpm = Ads.amountFieldValue($form, 'cpm'); if ($form.data('disabled')) { return false; } if (cpm === false) { $form.field('cpm').focus(); return false; } var params = { owner_id: owner_id, ad_id: ad_id, cpm: cpm }; $form.data('disabled', true); Aj.apiRequest('editAdCPM', params, function(result) { $form.data('disabled', false); if (result.error) { if (result.field) { var $field = $form.field(result.field); if ($field.size()) { Ads.showFieldError($field, result.error, true); return false; } } return showAlert(result.error); } closePopup(Aj.layer); if (result.ad) { OwnerAds.updateAd(result.ad); } }); return false; }, initEditBudgetPopup: function() { var cont = Aj.layer; Aj.onLayerLoad(function(layerState) { layerState.$form = $('.pr-popup-edit-form', cont); Ads.formInit(layerState.$form); layerState.budgetField = layerState.$form.field('budget'); Aj.layer.one('popup:open', function() { layerState.budgetField.focusAndSelect(true); }); layerState.$form.on('submit', EditAd.eSubmitEditBudgetPopupForm); cont.on('click.curLayer', '.submit-form-btn', EditAd.eSubmitEditBudgetPopupForm); }); Aj.onLayerUnload(function(layerState) { Ads.formDestroy(layerState.$form); layerState.$form.off('submit', EditAd.eSubmitEditBudgetPopupForm); }); }, eSubmitEditBudgetPopupForm: function(e) { e.preventDefault(); var $form = Aj.layerState.$form; var owner_id = $form.field('owner_id').value(); var ad_id = $form.field('ad_id').value(); var budget = Ads.amountFieldValue($form, 'budget'); if ($form.data('disabled')) { return false; } if (budget === false) { $form.field('budget').focus(); return false; } var params = { owner_id: owner_id, ad_id: ad_id, budget: budget, popup: 1 }; $form.data('disabled', true); Aj.apiRequest('incrAdBudget', params, function(result) { $form.data('disabled', false); if (result.error) { if (result.field) { var $field = $form.field(result.field); if ($field.size()) { Ads.showFieldError($field, result.error, true); return false; } } return showAlert(result.error); } closePopup(Aj.layer); if (result.ad) { OwnerAds.updateAd(result.ad); } if (result.owner_budget) { $('.js-owner_budget').html(result.owner_budget); } if (result.ad_budget_val) { $('.js-ad_budget_val').value(result.ad_budget_val); } }); return false; }, initEditStatusPopup: function() { var cont = Aj.layer; Aj.onLayerLoad(function(layerState) { layerState.$form = $('.pr-popup-edit-form', cont); Ads.formInit(layerState.$form); layerState.$form.on('submit', EditAd.eSubmitEditStatusForm); cont.on('click.curLayer', '.submit-form-btn', EditAd.eSubmitEditStatusForm); }); Aj.onLayerUnload(function(layerState) { Ads.formDestroy(layerState.$form); layerState.$form.off('submit', EditAd.eSubmitEditStatusForm); }); }, eSubmitEditStatusForm: function(e) { e.preventDefault(); var $form = Aj.layerState.$form; var owner_id = $form.field('owner_id').value(); var ad_id = $form.field('ad_id').value(); var active = $form.field('active').value(); if ($form.data('disabled')) { return false; } var params = { owner_id: owner_id, ad_id: ad_id, active: active }; $form.data('disabled', true); Aj.apiRequest('editAdStatus', params, function(result) { $form.data('disabled', false); if (result.error) { if (result.field) { var $field = $form.field(result.field); if ($field.size()) { Ads.showFieldError($field, result.error, true); return false; } } return showAlert(result.error); } closePopup(Aj.layer); if (result.ad) { OwnerAds.updateAd(result.ad); } }); return false; }, initShareStatsPopup: function() { var cont = Aj.layer; Aj.onLayerLoad(function(layerState) { layerState.$urlField = $('.js-share-url', cont); layerState.$copyBtn = $('.js-copy-link', cont); layerState.$revokeBtn = $('.js-revoke-link', cont); layerState.$urlField.on('click', EditAd.eSelectUrl); layerState.$copyBtn.on('click', EditAd.eCopyUrl); layerState.$revokeBtn.on('click', EditAd.eRevokeUrl); }); Aj.onLayerUnload(function(layerState) { layerState.$urlField.off('click', EditAd.eSelectUrl); layerState.$copyBtn.off('click', EditAd.eCopyUrl); layerState.$revokeBtn.off('click', EditAd.eRevokeUrl); }); }, eSelectUrl: function() { Aj.layerState.$urlField.focusAndSelectAll(); }, eCopyUrl: function(copy) { Aj.layerState.$urlField.focusAndSelectAll(); document.execCommand('copy'); showToast(l('WEB_AD_STATS_LINK_COPIED', 'Copied.')); }, eRevokeUrl: function(e) { e.preventDefault(); var $btn = $(this); if ($btn.data('disabled')) { return false; } var params = { owner_id: Aj.layerState.ownerId, ad_id: Aj.layerState.adId }; $btn.data('disabled', true); Aj.apiRequest('revokeStatsUrl', params, function(result) { $btn.data('disabled', false); if (result.error) { return showAlert(result.error); } if (result.new_url) { Aj.layerState.$urlField.value(result.new_url); } if (result.toast) { showToast(result.toast); } }); return false; }, initIncrBudget: function() { var cont = Aj.ajContainer; Aj.onLoad(function(state) { state.$form = $('.pr-incr-budget-form', cont); Ads.formInit(state.$form); state.budgetField = state.$form.field('budget'); state.$form.on('submit', EditAd.eSubmitIncrBudgetForm); cont.on('click.curPage', '.submit-form-btn', EditAd.eSubmitIncrBudgetForm); }); Aj.onUnload(function(state) { Ads.formDestroy(state.$form); state.$form.off('submit', EditAd.eSubmitIncrBudgetForm); }); }, eSubmitIncrBudgetForm: function(e) { e.preventDefault(); var $form = Aj.state.$form; var owner_id = $form.field('owner_id').value(); var ad_id = $form.field('ad_id').value(); var budget = Ads.amountFieldValue($form, 'budget'); if ($form.data('disabled')) { return false; } if (budget === false) { $form.field('budget').focus(); return false; } var params = { owner_id: owner_id, ad_id: ad_id, budget: budget }; $form.data('disabled', true); Aj.apiRequest('incrAdBudget', params, function(result) { $form.data('disabled', false); if (result.error) { if (result.field) { var $field = $form.field(result.field); if ($field.size()) { Ads.showFieldError($field, result.error, true); return false; } } return showAlert(result.error); } Aj.state.$form.reset(); if (result.owner_budget) { $('.js-owner_budget').html(result.owner_budget); } if (result.ad_budget) { $('.js-ad_budget').html(result.ad_budget); } if (result.history) { $('.js-history').html(result.history); } }); return false; }, eSubmitForm: function(e) { e.preventDefault(); var $form = Aj.state.$form; var $button = $(this); var title = $form.field('title').value(); var text = $form.field('text').value(); var promote_url = $form.field('promote_url').value(); var ad_info = $form.field('ad_info').value(); var cpm = Ads.amountFieldValue($form, 'cpm'); if (!title.length) { $form.field('title').focus(); return false; } if (!text.length) { $form.field('text').focus(); return false; } if (!promote_url.length) { $form.field('promote_url').focus(); return false; } if (cpm === false) { $form.field('cpm').focus(); return false; } var params = { owner_id: Aj.state.ownerId, ad_id: Aj.state.adId, title: title, text: text, promote_url: promote_url, ad_info: ad_info, cpm: cpm }; if ($form.field('picture').prop('checked')) { params.picture = 1; } $button.prop('disabled', true); Aj.apiRequest('editAd', params, function(result) { if (result.error) { $button.prop('disabled', false); if (result.field) { var $field = $form.field(result.field); if ($field.size()) { Ads.showFieldError($field, result.error, true); return false; } } return showAlert(result.error); } Aj.state.initFormData = EditAd.getFormData($form); if (result.redirect_to) { Aj.location(result.redirect_to); } }); return false; }, eCloneAd: function(e) { e.preventDefault(); var $button = $(this); if ($button.prop('disabled')) { return false; } var $item = $button.parents('li'); var ad_id = Aj.state.adId; if ($item.size()) { $item.parents('.open').find('.dropdown-toggle').dropdown('toggle'); ad_id = $(this).parents('[data-ad-id]').attr('data-ad-id'); } var params = { owner_id: Aj.state.ownerId, ad_id: ad_id }; var onSuccess = function(result) { $button.prop('disabled', false); if (result.error) { return showAlert(result.error); } if (result.confirm_text && result.confirm_hash) { showConfirm(result.confirm_text, function() { params.confirm_hash = result.confirm_hash; $button.prop('disabled', true); Aj.apiRequest('createDraftFromAd', params, onSuccess); }, result.confirm_btn); } else if (result.redirect_to) { Aj.location(result.redirect_to); } }; $button.prop('disabled', true); Aj.apiRequest('createDraftFromAd', params, onSuccess); return false; }, deletePopup: function (confirm_text, onConfirm) { var $confirm = $(''); var confirm = function() { onConfirm && onConfirm($confirm); closePopup($confirm); } $('.pr-layer-text', $confirm).html(confirm_text); var $primaryBtn = $('.popup-primary-btn', $confirm); $primaryBtn.on('click', confirm); $confirm.one('popup:close', function() { $primaryBtn.off('click', confirm); $confirm.remove(); }); openPopup($confirm, { closeByClickOutside: '.popup-no-close', }); return $confirm; }, deleteAd: function(e) { e.preventDefault(); var $button = $(this); if ($button.prop('disabled')) { return false; } var $item = $button.parents('li'); var ad_id = Aj.state.adId; if ($item.size()) { $item.parents('.open').find('.dropdown-toggle').dropdown('toggle'); ad_id = $(this).parents('[data-ad-id]').attr('data-ad-id'); } var params = { owner_id: Aj.state.ownerId, ad_id: ad_id }; var onSuccess = function(result) { $button.prop('disabled', false); if (result.error) { return showAlert(result.error); } if (result.confirm_text && result.confirm_hash) { EditAd.deletePopup(result.confirm_text, function() { params.confirm_hash = result.confirm_hash; $button.prop('disabled', true); Aj.apiRequest('deleteAd', params, onSuccess); }); } else if (result.redirect_to) { Aj.location(result.redirect_to); } }; $button.prop('disabled', true); Aj.apiRequest('deleteAd', params, onSuccess); return false; } }; var TransferFunds = { init: function() { var cont = Aj.ajContainer; Aj.onLoad(function(state) { state.$form = $('form.add-funds-form', cont); Ads.formInit(state.$form); state.$form.on('submit', preventDefault); cont.on('click.curPage', '.js-toggle-sign', TransferFunds.onToggleAmountSign); cont.on('click.curPage', '.transfer-funds-btn', TransferFunds.eSubmitForm); state.submitBtn = $('.transfer-funds-btn', cont); state.amountField = state.$form.field('amount'); state.amountField.on('keyup.curPage change.curPage input.curPage', TransferFunds.onAmountChange); state.decrAmountField = state.$form.field('decr_amount'); state.decrAmountField.on('keyup.curPage change.curPage input.curPage', TransferFunds.onAmountChange); state.curAmountField = state.$form.hasClass('decr') ? 'decr_amount' : 'amount'; Ads.initSelect(state.$form, 'account', { items: Aj.state.accountItems || [], noMultiSelect: true, renderSelectedItem: function(val, item) { return '
' + (item.photo ? '
' + item.photo + '
' : '') + '
' + item.name + '
'; }, onChange: TransferFunds.onAccountChange }); }); Aj.onUnload(function(state) { Ads.formDestroy(state.$form); state.$form.off('submit', preventDefault); state.amountField.off('.curPage'); clearTimeout(Aj.state.transferTo); }); }, onToggleAmountSign: function(e) { e.preventDefault(); Aj.state.$form.toggleClass('decr'); Aj.state.curAmountField = Aj.state.$form.hasClass('decr') ? 'decr_amount' : 'amount'; TransferFunds.onAmountChange(); Aj.state.$form.field(Aj.state.curAmountField).focusAndSelectAll(); }, onAccountChange: function(field, value, valueFull) { if (valueFull.budget) { $('.js-sel_account_budget', Aj.state.$form).removeClass('disabled').html(valueFull.budget); } else { $('.js-sel_account_budget', Aj.state.$form).addClass('disabled').html(Ads.wrapAmount(0)); } }, onAmountChange: function() { var decr = Aj.state.curAmountField == 'decr_amount'; var amount = Ads.amountFieldValue(Aj.state.$form, Aj.state.curAmountField) || 0; if (amount) { var button_label = l(decr ? 'WEB_WITHDRAW_AMOUNT_BUTTON' : 'WEB_TRANSFER_AMOUNT_BUTTON', {amount: Ads.wrapAmount(amount)}); } else { var button_label = l(decr ? 'WEB_WITHDRAW_FUNDS_BUTTON' : 'WEB_TRANSFER_FUNDS_BUTTON'); } Aj.state.submitBtn.prop('disabled', !amount).html(button_label); }, eSubmitForm: function(e) { e.preventDefault(); var $form = Aj.state.$form; var $button = $(this); var decr = $form.hasClass('decr'); var account_id = $form.field('account').data('value'); var amount_field = decr ? 'decr_amount' : 'amount'; var amount = Ads.amountFieldValue($form, amount_field); if ($button.prop('disabled')) { return false; } if (!account_id) { $form.field('account').trigger('click'); return false; } if (amount === false) { $form.field(amount_field).focus(); return false; } var method = decr ? 'transferWithdrawFunds' : 'transferFunds'; var params = { owner_id: Aj.state.ownerId, account_id: account_id, amount: amount }; var onSuccess = function(result) { $button.prop('disabled', false); if (result.error) { if (result.field) { var $field = $form.field(result.field); if ($field.size()) { Ads.showFieldError($field, result.error, true); return false; } } if (result.budget) { $('.js-owner_budget').html(result.budget); } return showAlert(result.error); } if (result.confirm_text && result.confirm_hash) { showConfirm(result.confirm_text, function() { params.confirm_hash = result.confirm_hash; $button.prop('disabled', true); Aj.apiRequest(method, params, onSuccess); }, result.confirm_btn); } else if (result.request_id) { $button.prop('disabled', true); Aj.state.transferTo = setTimeout(function() { params.request_id = result.request_id; Aj.apiRequest(method, params, onSuccess); }, 400); } else if (result.redirect_to) { Aj.location(result.redirect_to); } }; $button.prop('disabled', true); Aj.apiRequest(method, params, onSuccess); return false; } }; var Audiences = { init: function() { var cont = Aj.ajContainer; Aj.onLoad(function(state) { state.$searchField = $('.pr-search-input'); state.$searchResults = $('.pr-table tbody'); Ads.fieldInit(state.$searchField); cont.on('click.curPage', '.pr-cell-sort', Audiences.eSortList); cont.on('click.curPage', '.js-create-audience-ad-btn', Audiences.createAudienceAd); cont.on('click.curPage', '.delete-audience-btn', Audiences.deleteAudience); state.$searchResults.on('mouseover mouseout click', '.js-hint-tooltip', Ads.eHintEvent); $(document).on('touchstart click', Ads.eHideAllHints); state.listInited = false; state.needUpdateState = false; state.$searchField.initSearch({ $results: state.$searchResults, emptyQueryEnabled: true, updateOnInit: true, resultsNotScrollable: true, itemTagName: 'tr', enterEnabled: function() { return false; }, renderItem: function(item, query) { return '
' + item.title + '
' + Ads.formatTableDate(item.date) + '
' + item.used + '
' + item.users + (item.processing_hint ? '
' + item.processing_hint + '
' : '') + '
' + (item.need_update ? '' : Aj.state.audienceDropdownTpl.replace(/{audience_id}/g, item.audience_id)) + '
'; }, getData: function() { if (!state.listInited) { state.listInited = true; var items = Aj.state.audiencesList; for (var i = 0; i < items.length; i++) { var item = items[i]; item.base_url = '/account/audience/' + item.audience_id; item._values = [item.title.toLowerCase()]; if (item.need_update) { state.needUpdateState = true; } } Audiences.updateAudiencesState(); } return Aj.state.audiencesList; } }); }); Aj.onUnload(function(state) { state.$searchResults.off('mouseover mouseout click', '.js-hint-tooltip', Ads.eHintEvent); $(document).off('touchstart click', Ads.eHideAllHints); clearTimeout(Aj.state.updateStateTo); Ads.fieldDestroy(state.$searchField); state.$searchField.destroySearch(); }); }, eSortList: function(e) { var $sortEl = $(this); var sortBy = $sortEl.attr('data-sort-by'); var sortAsc = $sortEl.hasClass('sort-asc'); if (sortBy == Aj.state.audiencesListSortBy) { Aj.state.audiencesListSortAsc = !sortAsc; } else { Aj.state.audiencesListSortBy = sortBy; Aj.state.audiencesListSortAsc = false; } Audiences.updateAudiencesList(); Aj.state.$searchField.trigger('datachange'); }, updateAudiencesList: function() { if (Aj.state.audiencesList) { var sortBy = Aj.state.audiencesListSortBy; var sortAsc = Aj.state.audiencesListSortAsc; $('.pr-cell-sort').each(function() { var $sortEl = $(this); var curSortBy = $sortEl.attr('data-sort-by'); $sortEl.toggleClass('sort-active', sortBy == curSortBy); $sortEl.toggleClass('sort-asc', sortAsc && sortBy == curSortBy); }); Aj.state.audiencesList.sort(function(ad1, ad2) { var v1 = sortAsc ? ad1 : ad2; var v2 = sortAsc ? ad2 : ad1; return (v1[sortBy] - v2[sortBy]) || (v1.date - v2.date); }); } }, updateAudiencesState: function() { if (!Aj.state || !Aj.state.audiencesList || !Aj.state.needUpdateState) { return; } Aj.state.needUpdateState = false; Aj.state.updateStateTo = setTimeout(function() { Aj.apiRequest('updateAudiencesState', { owner_id: Aj.state.ownerId }, function(result) { if (result.error) { return showAlert(result.error); } if (result.audiences) { for (var i = 0; i < result.audiences.length; i++) { Audiences.updateAudience(result.audiences[i], true); } Audiences.updateAudiencesList(); Aj.state.$searchField.trigger('contentchange'); Audiences.updateAudiencesState(); } }); }, 400); }, updateAudience: function(audience, no_update) { if (!Aj.state || !Aj.state.audiencesList) { return; } var audiencesList = Aj.state.audiencesList; for (var i = 0; i < audiencesList.length; i++) { if (audience.owner_id == audiencesList[i].owner_id && audience.audience_id == audiencesList[i].audience_id) { audience.base_url = '/account/audience/' + audience.audience_id; audience._values = [audience.title.toLowerCase()]; audiencesList[i] = audience; if (audience.need_update) { Aj.state.needUpdateState = true; } if (!no_update) { Audiences.updateAudiencesList(); Aj.state.$searchField.trigger('contentchange'); Audiences.updateAudiencesState(); } return; } } }, initCreatePopup: function() { var cont = Aj.layer; Aj.onLayerLoad(function(layerState) { layerState.$form = $('.pr-popup-edit-form', cont); Ads.formInit(layerState.$form); layerState.titleField = layerState.$form.field('title'); layerState.titleField.on('change.curPage', NewAd.onTitleChange); Aj.layer.one('popup:open', function() { layerState.titleField.focusAndSelect(true); }); layerState.$form.on('submit', Audiences.eSubmitCreatePopupForm); cont.on('click.curLayer', '.submit-form-btn', Audiences.eSubmitCreatePopupForm); }); Aj.onLayerUnload(function(layerState) { if (Aj.layerState.uploadRequestXhr) { Aj.layerState.uploadRequestXhr.abort(); } Ads.formDestroy(layerState.$form); layerState.$form.off('submit', Audiences.eSubmitCreatePopupForm); layerState.titleField.off('.curPage'); }); }, eSubmitCreatePopupForm: function(e) { e.preventDefault(); var $form = Aj.layerState.$form; var owner_id = $form.field('owner_id').value(); var title = $form.field('title').value(); var $fileEl = $form.field('file'); var file = $fileEl.data('file'); if ($form.data('disabled')) { return false; } if (!title.length) { $form.field('title').focus(); return false; } if (!file) { $form.field('file').focus(); return false; } var params = { owner_id: owner_id, title: title }; var $formGroup = $fileEl.parents('.form-group'); $formGroup.addClass('field-loading'); $form.addClass('disabled').data('disabled', true); Aj.layerState.uploadRequestXhr = Aj.uploadRequest('createAudience', file, params, function(result) { Aj.layerState.uploadRequestXhr = null; $form.removeClass('disabled').data('disabled', false); $formGroup.removeClass('field-loading'); if (result.error) { if (result.field) { var $field = $form.field(result.field); if ($field.size()) { Ads.showFieldError($field, result.error, true); return false; } } return showAlert(result.error); } closePopup(Aj.layer); if (result.audience && Aj.state.audiencesList) { Aj.state.audiencesList.push(result.audience); Audiences.updateAudience(result.audience); } if (result.audience_opt && Aj.state.audienceItems) { Aj.state.audienceItems.push(result.audience_opt); for (var i = 0; i < Aj.state.selectList.length; i++) { var selectData = Aj.state.selectList[i]; if (selectData.items_key == 'audienceItems') { var $fieldEl = Aj.state.$form.field(selectData.field); $fieldEl.trigger('datachange'); if (selectData.add_new_audience) { $fieldEl.trigger('selectval', [result.audience_opt, true]); } } } } }, function(loaded, total) { var progress = total ? loaded / total : 0; $('.js-progress-value', $formGroup).html(Math.round(progress * 100) + '%'); $formGroup.each(function() { this.style.setProperty('--upload-progress', progress); }); }); return false; }, initEditTitlePopup: function() { var cont = Aj.layer; Aj.onLayerLoad(function(layerState) { layerState.$form = $('.pr-popup-edit-form', cont); Ads.formInit(layerState.$form); layerState.titleField = layerState.$form.field('title'); layerState.titleField.on('change.curPage', NewAd.onTitleChange); Aj.layer.one('popup:open', function() { layerState.titleField.focusAndSelect(true); }); layerState.$form.on('submit', Audiences.eSubmitEditTitlePopupForm); cont.on('click.curLayer', '.submit-form-btn', Audiences.eSubmitEditTitlePopupForm); }); Aj.onLayerUnload(function(layerState) { Ads.formDestroy(layerState.$form); layerState.$form.off('submit', Audiences.eSubmitEditTitlePopupForm); layerState.titleField.off('.curPage'); }); }, eSubmitEditTitlePopupForm: function(e) { e.preventDefault(); var $form = Aj.layerState.$form; var owner_id = $form.field('owner_id').value(); var audience_id = $form.field('audience_id').value(); var title = $form.field('title').value(); if ($form.data('disabled')) { return false; } if (!title.length) { $form.field('title').focus(); return false; } var params = { owner_id: owner_id, audience_id: audience_id, title: title }; $form.data('disabled', true); Aj.apiRequest('editAudienceTitle', params, function(result) { $form.data('disabled', false); if (result.error) { if (result.field) { var $field = $form.field(result.field); if ($field.size()) { Ads.showFieldError($field, result.error, true); return false; } } return showAlert(result.error); } closePopup(Aj.layer); if (result.audience) { Audiences.updateAudience(result.audience); } }); return false; }, initUpdateUsersPopup: function() { var cont = Aj.layer; Aj.onLayerLoad(function(layerState) { layerState.$form = $('.pr-popup-edit-form', cont); Ads.formInit(layerState.$form); layerState.$form.on('submit', Audiences.eSubmitUpdateUsersPopupForm); cont.on('click.curLayer', '.submit-form-btn', Audiences.eSubmitUpdateUsersPopupForm); }); Aj.onLayerUnload(function(layerState) { if (Aj.layerState.uploadRequestXhr) { Aj.layerState.uploadRequestXhr.abort(); } Ads.formDestroy(layerState.$form); layerState.$form.off('submit', Audiences.eSubmitUpdateUsersPopupForm); }); }, eSubmitUpdateUsersPopupForm: function(e) { e.preventDefault(); var $form = Aj.layerState.$form; var owner_id = $form.field('owner_id').value(); var audience_id = $form.field('audience_id').value(); var $fileEl = $form.field('file'); var file = $fileEl.data('file'); if ($form.data('disabled')) { return false; } if (!file) { $form.field('file').focus(); return false; } var params = { owner_id: owner_id, audience_id: audience_id }; var $formGroup = $fileEl.parents('.form-group'); $formGroup.addClass('field-loading'); $form.addClass('disabled').data('disabled', true); var method = Aj.layerState.updateMethod; Aj.layerState.uploadRequestXhr = Aj.uploadRequest(method, file, params, function(result) { Aj.layerState.uploadRequestXhr = null; $form.removeClass('disabled').data('disabled', false); $formGroup.removeClass('field-loading'); if (result.error) { if (result.field) { var $field = $form.field(result.field); if ($field.size()) { Ads.showFieldError($field, result.error, true); return false; } } return showAlert(result.error); } closePopup(Aj.layer); if (result.audience) { Audiences.updateAudience(result.audience); } }, function(loaded, total) { var progress = total ? loaded / total : 0; $('.js-progress-value', $formGroup).html(Math.round(progress * 100) + '%'); $formGroup.each(function() { this.style.setProperty('--upload-progress', progress); }); }); return false; }, createAudienceAd: function(e) { e.preventDefault(); var $button = $(this); if ($button.prop('disabled')) { return false; } var $item = $button.parents('li'); var audience_id = Aj.state.audienceId; if ($item.size()) { $item.parents('.open').find('.dropdown-toggle').dropdown('toggle'); audience_id = $(this).parents('[data-audience-id]').attr('data-audience-id'); } var params = { owner_id: Aj.state.ownerId, audience_id: audience_id }; var onSuccess = function(result) { $button.prop('disabled', false); if (result.error) { return showAlert(result.error); } if (result.confirm_text && result.confirm_hash) { showConfirm(result.confirm_text, function() { params.confirm_hash = result.confirm_hash; $button.prop('disabled', true); Aj.apiRequest('createDraftFromAudience', params, onSuccess); }, result.confirm_btn); } else if (result.redirect_to) { Aj.location(result.redirect_to); } }; $button.prop('disabled', true); Aj.apiRequest('createDraftFromAudience', params, onSuccess); return false; }, deletePopup: function (confirm_text, onConfirm) { var $confirm = $(''); var confirm = function() { onConfirm && onConfirm($confirm); closePopup($confirm); } $('.pr-layer-text', $confirm).html(confirm_text); var $primaryBtn = $('.popup-primary-btn', $confirm); $primaryBtn.on('click', confirm); $confirm.one('popup:close', function() { $primaryBtn.off('click', confirm); $confirm.remove(); }); openPopup($confirm, { closeByClickOutside: '.popup-no-close', }); return $confirm; }, deleteAudience: function(e) { e.preventDefault(); var $button = $(this); if ($button.prop('disabled')) { return false; } var $item = $button.parents('li'); var audience_id = Aj.state.audienceId; if ($item.size()) { $item.parents('.open').find('.dropdown-toggle').dropdown('toggle'); audience_id = $(this).parents('[data-audience-id]').attr('data-audience-id'); } var params = { owner_id: Aj.state.ownerId, audience_id: audience_id }; var onSuccess = function(result) { $button.prop('disabled', false); if (result.error) { return showAlert(result.error); } if (result.confirm_text && result.confirm_hash) { Audiences.deletePopup(result.confirm_text, function() { params.confirm_hash = result.confirm_hash; $button.prop('disabled', true); Aj.apiRequest('deleteAudience', params, onSuccess); }); } else if (result.redirect_to) { Aj.location(result.redirect_to); } }; $button.prop('disabled', true); Aj.apiRequest('deleteAudience', params, onSuccess); return false; } }; (function(d){var c=function(a){this._options={checkOnLoad:!1,resetOnEnd:!1,loopCheckTime:50,loopMaxNumber:5,baitClass:"pub_300x250 pub_300x250m pub_728x90 text-ad textAd text_ad text_ads text-ads text-ad-links ads-header ads-content",baitStyle:"width: 1px !important; height: 1px !important; position: absolute !important; left: -10000px !important; top: -1000px !important;"};this._var={version:"3.2.1",bait:null,checking:!1,loop:null,loopNumber:0,event:{detected:[],notDetected:[]}};void 0!==a&&this.setOption(a);var b=this;a=function(){setTimeout(function(){!0===b._options.checkOnLoad&&(null===b._var.bait&&b._creatBait(),setTimeout(function(){b.check()},1))},1)};void 0!==d.addEventListener?d.addEventListener("load",a,!1):d.attachEvent("onload",a)};c.prototype._options=null;c.prototype._var=null;c.prototype._bait=null;c.prototype.setOption=function(a,b){if(void 0!==b){var e=a;a={};a[e]=b}for(var f in a)this._options[f]=a[f];return this};c.prototype._creatBait=function(){var a=document.createElement("div");a.setAttribute("class",this._options.baitClass);a.setAttribute("style",this._options.baitStyle);this._var.bait=d.document.body.appendChild(a);this._var.bait.offsetParent;this._var.bait.offsetHeight;this._var.bait.offsetLeft;this._var.bait.offsetTop;this._var.bait.offsetWidth;this._var.bait.clientHeight;this._var.bait.clientWidth};c.prototype._destroyBait=function(){d.document.body.removeChild(this._var.bait);this._var.bait=null};c.prototype.check=function(a){void 0===a&&(a=!0);this._var.checking=!0;null===this._var.bait&&this._creatBait();var b=this;this._var.loopNumber=0;!0===a&&(this._var.loop=setInterval(function(){b._checkBait(a)},this._options.loopCheckTime));setTimeout(function(){b._checkBait(a)},1);return!0};c.prototype._checkBait=function(a){var b=!1;null===this._var.bait&&this._creatBait();if(null!==d.document.body.getAttribute("abp")||null===this._var.bait.offsetParent||0==this._var.bait.offsetHeight||0==this._var.bait.offsetLeft||0==this._var.bait.offsetTop||0==this._var.bait.offsetWidth||0==this._var.bait.clientHeight||0==this._var.bait.clientWidth)b=!0;if(void 0!==d.getComputedStyle){var e=d.getComputedStyle(this._var.bait,null);!e||"none"!=e.getPropertyValue("display")&&"hidden"!=e.getPropertyValue("visibility")||(b=!0)}!0===a&&(this._var.loopNumber++,this._var.loopNumber>=this._options.loopMaxNumber&&this._stopLoop());if(!0===b)this._stopLoop(),this._destroyBait(),this.emitEvent(!0),!0===a&&(this._var.checking=!1);else if(null===this._var.loop||!1===a)this._destroyBait(),this.emitEvent(!1),!0===a&&(this._var.checking=!1)};c.prototype._stopLoop=function(a){clearInterval(this._var.loop);this._var.loop=null;this._var.loopNumber=0};c.prototype.emitEvent=function(a){a=this._var.event[!0===a?"detected":"notDetected"];for(var b in a)if(a.hasOwnProperty(b))a[b]();!0===this._options.resetOnEnd&&this.clearEvent();return this};c.prototype.clearEvent=function(){this._var.event.detected=[];this._var.event.notDetected=[]};c.prototype.on=function(a){this._var.event.detected.push(a);return this};d.ABC=c;void 0===d.AB&&(d.AB=new c({checkOnLoad:!0,resetOnEnd:!0}))})(window); AB.on(function() { openPopup(''); });