/* * * (c) Copyright Ascensio System SIA 2010-2019 * * This program is a free software product. You can redistribute it and/or * modify it under the terms of the GNU Affero General Public License (AGPL) * version 3 as published by the Free Software Foundation. In accordance with * Section 7(a) of the GNU AGPL its Section 15 shall be amended to the effect * that Ascensio System SIA expressly excludes the warranty of non-infringement * of any third-party rights. * * This program is distributed WITHOUT ANY WARRANTY; without even the implied * warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. For * details, see the GNU AGPL at: http://www.gnu.org/licenses/agpl-3.0.html * * You can contact Ascensio System SIA at 20A-12 Ernesta Birznieka-Upisha * street, Riga, Latvia, EU, LV-1050. * * The interactive user interfaces in modified source and object code versions * of the Program must display Appropriate Legal Notices, as required under * Section 5 of the GNU AGPL version 3. * * Pursuant to Section 7(b) of the License you must retain the original Product * logo when distributing the program. Pursuant to Section 7(e) we decline to * grant you any rights under trademark law for use of our trademarks. * * All the Product's GUI elements, including illustrations and icon sets, as * well as technical writing content are licensed under the terms of the * Creative Commons Attribution-ShareAlike 4.0 International. See the License * terms at http://creativecommons.org/licenses/by-sa/4.0/legalcode * */ /** * Search.js * Document Editor * * Created by Alexander Yuzhin on 11/15/16 * Copyright (c) 2018 Ascensio System SIA. All rights reserved. * */ define([ 'text!documenteditor/mobile/app/template/Search.template', 'jquery', 'underscore', 'backbone' ], function (searchTemplate, $, _, Backbone) { 'use strict'; DE.Views.Search = Backbone.View.extend(_.extend((function() { // private var _isEdit = false, _layout; return { el: '.view-main', // Compile our stats template template: _.template(searchTemplate), // Delegated events for creating new items, and clearing completed ones. events: {}, // Set innerHTML and get the references to the DOM elements initialize: function () { this.on('searchbar:show', _.bind(this.initEvents, this)); }, initEvents: function() { $('#search-settings').single('click', _.bind(this.showSettings, this)); }, // Render layout render: function () { _layout = $('<div/>').append(this.template({ android : Common.SharedSettings.get('android'), phone : Common.SharedSettings.get('phone'), isEdit : _isEdit, scope : this })); return this; }, setMode: function (mode) { _isEdit = mode.isEdit; this.render(); }, showSettings: function (e) { var me = this; uiApp.closeModal(); if (Common.SharedSettings.get('phone')) { me.picker = $$(uiApp.popup([ '<div class="popup settings">', '<div class="view search-settings-view navbar-through">', _layout.find('#search-settings-view').html(), '</div>', '</div>'].join('') )) } else { me.picker = uiApp.popover([ '<div class="popover settings" style="width: 280px; height: 300px;">', '<div class="popover-angle"></div>', '<div class="popover-inner">', '<div class="content-block">', '<div class="view popover-view search-settings-view navbar-through" style="height: 300px;">', _layout.find('#search-settings-view').html(), '</div>', '</div>', '</div>', '</div>'].join(''), $$('#search-settings') ); // Prevent hide overlay. Conflict popover and modals. var $overlay = $('.modal-overlay'); $$(me.picker).on('opened', function () { $overlay.on('removeClass', function () { if (!$overlay.hasClass('modal-overlay-visible')) { $overlay.addClass('modal-overlay-visible') } }); }).on('close', function () { $overlay.off('removeClass'); $overlay.removeClass('modal-overlay-visible') }); } if (Common.SharedSettings.get('android')) { $$('.view.search-settings-view.navbar-through').removeClass('navbar-through').addClass('navbar-fixed'); $$('.view.search-settings-view .navbar').prependTo('.view.search-settings-view > .pages > .page'); } me.fireEvent('searchbar:showsettings', me); }, showSearch: function () { var me = this, searchBar = $$('.searchbar.document'); if (searchBar.length < 1) { $(me.el).find('.pages .page').first().prepend(_layout.find('#search-panel-view').html()); // Show replace mode if needed var isReplace = Common.SharedSettings.get('search-is-replace'); $('.searchbar.document').toggleClass('replace', !_.isUndefined(isReplace) && (isReplace === true)); me.fireEvent('searchbar:render', me); me.fireEvent('searchbar:show', me); searchBar = $$('.searchbar.document'); _.defer(function() { uiApp.showNavbar(searchBar); searchBar.transitionEnd(function () { if (!searchBar.hasClass('navbar-hidden')) { $('.searchbar.search input').focus(); } }); }, 10); } }, hideSearch: function () { var me = this, searchBar = $$('.searchbar.document'); if (searchBar.length > 0) { // Animating if (searchBar.hasClass('.navbar-hidding')) { return; } _.defer(function() { searchBar.transitionEnd(function () { me.fireEvent('searchbar:hide', me); searchBar.remove(); }); uiApp.hideNavbar(searchBar); }, 10); } }, textFind: 'Find', textFindAndReplace: 'Find and Replace', textDone: 'Done', textSearch: 'Search', textReplace: 'Replace', textCase: 'Case sensitive', textHighlight: 'Highlight results' } })(), DE.Views.Search || {})) });