playbook_ui 14.15.0 → 14.16.0.pre.rc.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 988b1ee65101fb13b487e7fb3f8589b7b06a4510503b9a1d41dd84d1887ade9b
4
- data.tar.gz: 2ebbaf39afdeca0386f701dc867be16170b39f8f8cbcba101e92ca8df1d9bd35
3
+ metadata.gz: 29999d280f49fac0febbbb14cf22004a252aab3387af1d39edafca4cc2e0852c
4
+ data.tar.gz: 0e8f106c77c37528bef3310388435c63917090e93642dd5cf1b586eb2afea3b7
5
5
  SHA512:
6
- metadata.gz: e500e0257cd7da6adb7a707ea08e797d8322204341eaff40613dee843ee6c79d47db18c76192204a2b29576b3b3eb9ca13d8cb5ab5c2b401a7d4e775dec39450
7
- data.tar.gz: dbf426e01b04c62e96af16a1fc4769659c7111a0a276c6a5a2f05ae1fa2948be612447dfea2c39d5115e068ee71cc90f16c24de34a4f2791aa719d03cdb3cda2
6
+ metadata.gz: 95ec7db3153f2fea683909fc058a3f6ad1a0cd84dbb3954d5545234a98ac56e1614735a70e2ab3e47200010bde3055b005ced52e2ca996a7540d3cba854a3ee5
7
+ data.tar.gz: 909e9c77563d5a963b919c774bdc40ff892a1c462156229a10190305ec96e118110ab6a23e54fa54d4190f72f548290edc7ec60cd5a03ca3ff03bfa5d1512e1e
@@ -1,4 +1,8 @@
1
- <div class="pb_dialog_wrapper_rails <%= object.full_height_style %>" data-overlay-click= <%= object.overlay_close %> >
1
+ <div
2
+ class="pb_dialog_wrapper_rails <%= object.full_height_style %>"
3
+ data-pb-dialog-wrapper="true"
4
+ data-overlay-click= <%= object.overlay_close %>
5
+ >
2
6
  <%= pb_content_tag(:dialog) do %>
3
7
  <% if object.status === "" && object.title %>
4
8
  <%= pb_rails("dialog/dialog_header", props: { title: object.title, id: object.id }) %>
@@ -33,8 +37,3 @@
33
37
  <%= content %>
34
38
  <% end %>
35
39
  </div>
36
-
37
- <%= javascript_tag do %>
38
- window.addEventListener("DOMContentLoaded", () => dialogHelper())
39
- window.addEventListener("turbo:frame-load", () => dialogHelper())
40
- <% end %>
@@ -1,3 +1,5 @@
1
+ // Three places in Nitro depend on this function inside the window scope.
2
+ // We will keep this file until we remove this dependency from Nitro.
1
3
  const dialogHelper = () => {
2
4
  const openTrigger = document.querySelectorAll("[data-open-dialog]");
3
5
  const closeTrigger = document.querySelectorAll("[data-close-dialog]");
@@ -0,0 +1,75 @@
1
+ import PbEnhancedElement from "../pb_enhanced_element";
2
+
3
+ const DIALOG_WRAPPER_SELECTOR = "[data-pb-dialog-wrapper]";
4
+
5
+ export default class PbDialog extends PbEnhancedElement {
6
+ static get selector() {
7
+ return DIALOG_WRAPPER_SELECTOR;
8
+ }
9
+
10
+ connect() {
11
+ window.addEventListener("DOMContentLoaded", () => this.setupDialog())
12
+ window.addEventListener("turbo:frame-load", () => this.setupDialog())
13
+ }
14
+
15
+ setupDialog() {
16
+ const openTrigger = document.querySelectorAll("[data-open-dialog]");
17
+ const closeTrigger = document.querySelectorAll("[data-close-dialog]");
18
+ const dialogs = document.querySelectorAll(".pb_dialog_rails")
19
+
20
+ const loadingButton = document.querySelector('[data-disable-with="Loading"]');
21
+ if (loadingButton) {
22
+ loadingButton.addEventListener("click", function () {
23
+ const okayLoadingButton = document.querySelector('[data-disable-with="Loading"]');
24
+ const cancelButton = document.querySelector('[data-disable-cancel-with="Loading"]');
25
+ let currentClass = okayLoadingButton.className;
26
+ let cancelClass = cancelButton ? cancelButton.className : "";
27
+
28
+ let newClass = currentClass.replace("_enabled", "_disabled_loading");
29
+ let newCancelClass = cancelClass.replace("_enabled", "_disabled");
30
+
31
+ // Disable the buttons
32
+ okayLoadingButton.disabled = true;
33
+ if (cancelButton) cancelButton.disabled = true;
34
+
35
+ okayLoadingButton.className = newClass;
36
+ if (cancelButton) cancelButton.className = newCancelClass;
37
+ });
38
+ }
39
+
40
+ openTrigger.forEach((open) => {
41
+ open.addEventListener("click", () => {
42
+ var openTriggerData = open.dataset.openDialog;
43
+ var targetDialog = document.getElementById(openTriggerData)
44
+ if (targetDialog.open) return;
45
+ targetDialog.showModal();
46
+ });
47
+ });
48
+
49
+ closeTrigger.forEach((close) => {
50
+ close.addEventListener("click", () => {
51
+ var closeTriggerData = close.dataset.closeDialog;
52
+ document.getElementById(closeTriggerData).close();
53
+ });
54
+ });
55
+
56
+ // Close dialog box on outside click
57
+ dialogs.forEach((dialogElement) => {
58
+ dialogElement.addEventListener("mousedown", (event) => {
59
+ const dialogParentDataset = dialogElement.parentElement.dataset
60
+ if (dialogParentDataset.overlayClick === "overlay_close") return
61
+
62
+ const dialogModal = event.target.getBoundingClientRect()
63
+ const clickedOutsideDialogModal = event.clientX < dialogModal.left ||
64
+ event.clientX > dialogModal.right ||
65
+ event.clientY < dialogModal.top ||
66
+ event.clientY > dialogModal.bottom
67
+
68
+ if (clickedOutsideDialogModal) {
69
+ dialogElement.close()
70
+ event.stopPropagation()
71
+ }
72
+ })
73
+ })
74
+ }
75
+ }