123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146 |
- /**
- * Licensed to the Apache Software Foundation (ASF) under one
- * or more contributor license agreements. See the NOTICE file
- * distributed with this work for additional information
- * regarding copyright ownership. The ASF licenses this file
- * to you under the Apache License, Version 2.0 (the
- * "License"); you may not use this file except in compliance
- * with the License. You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
- var App = require('app');
- App.ModalPopup = Ember.View.extend({
- viewName: 'modalPopup',
- template: Ember.Handlebars.compile([
- '<div class="modal-backdrop"></div><div class="modal" id="modal" tabindex="-1" role="dialog" aria-labelledby="modal-label" aria-hidden="true">',
- '<div class="modal-header">',
- '{{#if showCloseButton}}<a class="close" {{action onClose target="view"}}>x</a>{{/if}}',
- '<h3 id="modal-label">',
- '{{#if headerClass}}{{view headerClass}}',
- '{{else}}{{header}}{{/if}}',
- '</h3>',
- '</div>',
- '<div class="modal-body">',
- '{{#if bodyClass}}{{view bodyClass}}',
- '{{else}}{{#if encodeBody}}{{body}}{{else}}{{{body}}}{{/if}}{{/if}}',
- '</div>',
- '{{#if showFooter}}',
- '{{#if footerClass}}{{view footerClass}}',
- '{{else}}',
- '<div class="modal-footer">',
- '{{#if view.secondary}}<a class="btn" {{action onSecondary target="view"}}>{{view.secondary}}</a>{{/if}}',
- '{{#if view.primary}}<a class="btn btn-success" {{action onPrimary target="view"}}>{{view.primary}}</a>{{/if}}',
- '</div>',
- '{{/if}}',
- '{{/if}}',
- '</div>'
- ].join('\n')),
- header: ' ',
- body: ' ',
- encodeBody: true,
- // define bodyClass which extends Ember.View to use an arbitrary Handlebars template as the body
- primary: Em.I18n.t('ok'),
- secondary: Em.I18n.t('common.cancel'),
- autoHeight: true,
- onPrimary: function() {
- this.hide();
- },
- onSecondary: function() {
- this.hide();
- },
- onClose: function() {
- this.hide();
- },
- hide: function() {
- this.destroy();
- },
- showFooter: true,
- /**
- * Hide or show 'X' button for closing popup
- */
- showCloseButton: true,
- didInsertElement: function(){
- if(this.autoHeight){
- var block = this.$().find('#modal > .modal-body').first();
- block.css('max-height', $(window).height() - block.offset().top - 300 + $(window).scrollTop()); // fix popup height
- }
- },
- fitHeight: function(){
- var popup = this.$().find('#modal');
- var block = this.$().find('#modal > .modal-body');
- var wh = $(window).height();
- var top = wh * .05;
- popup.css({
- 'top' : top + 'px',
- 'marginTop' : 0
- });
- block.css('max-height', $(window).height()- top * 2 - 100);
- }
- });
- App.ModalPopup.reopenClass({
- show: function(options) {
- var popup = this.create(options);
- popup.appendTo('#wrapper');
- return popup;
- }
- })
- App.showReloadPopup = function(){
- return App.ModalPopup.show({
- primary: null,
- secondary: null,
- showFooter: false,
- header: this.t('app.reloadPopup.header'),
- body: "<div class='alert alert-info'><div class='spinner'>" + this.t('app.reloadPopup.text') + "</div></div><div><a href='#' onclick='location.reload();'>" + this.t('app.reloadPopup.link') + "</a></div>",
- encodeBody: false
- });
- }
- /**
- * Show confirmation popup
- *
- * @param {Function} primary - "OK" button click handler
- * @param {String} body - additional text constant. Will be placed in the popup-body
- * @return {*}
- */
- App.showConfirmationPopup = function(primary, body) {
- if (!primary) {
- return false;
- }
- return App.ModalPopup.show({
- primary: Em.I18n.t('yes'),
- secondary: Em.I18n.t('no'),
- header: Em.I18n.t('popup.confirmation.commonHeader'),
- body: Em.I18n.t('question.sure').format(body || ''),
- onPrimary: function() {
- primary();
- this.hide();
- }
- });
- }
|