summaryrefslogtreecommitdiffstats
path: root/browser/fxr/content/common.js
blob: 292c0a916a69e914d605dd69cff11630531adc2f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
/* -*- indent-tabs-mode: nil; js-indent-level: 2 -*-
 * This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */

// Creates a modal container, if it doesn't exist, and adds the provided
// content element to it
function showModalContainer(content) {
  var container = document.getElementById("eModalContainer");
  if (container == null) {
    container = document.createElement("div");
    container.id = "eModalContainer";
    container.classList.add("modal_container");

    var mask = document.createElement("div");
    mask.id = "eModalMask";
    mask.classList.add("modal_mask");

    document.body.appendChild(mask);
    document.body.appendChild(container);
  } else {
    container.hidden = false;
    document.getElementById("eModalMask").hidden = false;
  }

  container.appendChild(content);
  if (content.classList.contains("modal_hide")) {
    content.classList.replace("modal_hide", "modal_content");
  } else {
    content.classList.add("modal_content");
  }
}

// Hides the modal container, and returns the contents back to the caller.
// The caller can choose to use the return value to move the contents to
// another part of the DOM, or ignore the return value so that the nodes
// can be garbage collected.
function clearModalContainer() {
  var container = document.getElementById("eModalContainer");
  container.hidden = true;
  document.getElementById("eModalMask").hidden = true;

  var content = container.firstElementChild;
  container.removeChild(content);
  content.classList.replace("modal_content", "modal_hide");

  return content;
}