mirror of
				https://github.com/zulip/zulip.git
				synced 2025-10-31 20:13:46 +00:00 
			
		
		
		
	This commit prepares the frontend code to be consumed by webpack. It is a hack: In theory, modules should be declaring and importing the modules they depend on and the globals they expose directly. However, that requires significant per-module work, which we don't really want to block moving our toolchain to webpack on. So we expose the modules by setting window.varName = varName; as needed in the js files.
		
			
				
	
	
		
			99 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			99 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| var panels = (function () {
 | |
| 
 | |
| var exports = {};
 | |
| 
 | |
| var resize_app = function () {
 | |
|     var panels_height = $("#panels").height();
 | |
|     $("body > .app").height("calc(100% - " + panels_height + "px)");
 | |
|     // the floating recipient bar is usually positioned 10px below the
 | |
|     // header, so add that to the panels height to get the new `top` value.
 | |
|     $("#floating_recipient_bar").css("top", panels_height + $(".header").height() + 10 + "px");
 | |
| };
 | |
| 
 | |
| exports.resize_app = resize_app;
 | |
| 
 | |
| var show_step = function ($process, step) {
 | |
|     $process.find("[data-step]").hide().filter("[data-step=" + step + "]").show();
 | |
| };
 | |
| 
 | |
| var get_step = function ($process) {
 | |
|     return $process.find("[data-step]").filter(":visible").data("step");
 | |
| };
 | |
| 
 | |
| exports.initialize = function () {
 | |
|     // if email has not been set up and the user is the admin, display a warning
 | |
|     // to tell them to set up an email server.
 | |
|     if (page_params.warn_no_email === true && page_params.is_admin) {
 | |
|         panels.open($("[data-process='email-server']"));
 | |
|     } else {
 | |
|         panels.open($("[data-process='notifications']"));
 | |
|     }
 | |
| };
 | |
| 
 | |
| exports.open = function ($process) {
 | |
|     var ls = localstorage();
 | |
| 
 | |
|     $("[data-process]").hide();
 | |
| 
 | |
|     var should_show_notifications =
 | |
|         // notifications *basically* don't work on any mobile platforms, so don't
 | |
|         // event show the banners. This prevents trying to access things that
 | |
|         // don't exist like `Notification.permission`.
 | |
|         !util.is_mobile() &&
 | |
|         // if permission has not been granted yet.
 | |
|         !notifications.granted_desktop_notifications_permission() &&
 | |
|         // if permission is allowed to be requested (e.g. not in "denied" state).
 | |
|         notifications.permission_state() !== "denied"
 | |
|     ;
 | |
| 
 | |
|     if (localstorage.supported()) {
 | |
|         // if the user said to never show banner on this computer again, it will
 | |
|         // be stored as `true` so we want to negate that.
 | |
|         should_show_notifications = should_show_notifications && !ls.get("dontAskForNotifications");
 | |
|     }
 | |
| 
 | |
|     if (should_show_notifications) {
 | |
|         $process.show();
 | |
|         resize_app();
 | |
|     }
 | |
| 
 | |
|     // if it is not the notifications prompt, show the error if it has been
 | |
|     // initialized here.
 | |
|     if ($process.is(":not([data-process='notifications'])")) {
 | |
|         $process.show();
 | |
|         resize_app();
 | |
|     }
 | |
| 
 | |
|     $(".request-desktop-notifications").on("click", function (e) {
 | |
|         e.preventDefault();
 | |
|         $(this).closest(".alert").hide();
 | |
|         notifications.request_desktop_notifications_permission();
 | |
|         resize_app();
 | |
|     });
 | |
| 
 | |
|     $(".reject-notifications").on("click", function () {
 | |
|         $(this).closest(".alert").hide();
 | |
|         ls.set("dontAskForNotifications", true);
 | |
|         resize_app();
 | |
|     });
 | |
| 
 | |
|     $("#panels").on("click", ".alert .close, .alert .exit", function (e) {
 | |
|         e.stopPropagation();
 | |
|         if (get_step($process) === 1 && $process.data("process") === "notifications") {
 | |
|             show_step($process, 2);
 | |
|         } else {
 | |
|             $(this).closest(".alert").hide();
 | |
|         }
 | |
|         resize_app();
 | |
|     });
 | |
| };
 | |
| 
 | |
| return exports;
 | |
| 
 | |
| }());
 | |
| 
 | |
| if (typeof module !== 'undefined') {
 | |
|     module.exports = panels;
 | |
| }
 | |
| window.panels = panels;
 |