Skip to content

Commit

Permalink
Convert Dirty from Coffeescript to Javascript
Browse files Browse the repository at this point in the history
Also move the file to app/javascript folder.
  • Loading branch information
sascha-karnatz committed Jul 6, 2023
1 parent 830e5dc commit 9bd0277
Show file tree
Hide file tree
Showing 5 changed files with 83 additions and 65 deletions.
1 change: 0 additions & 1 deletion app/assets/javascripts/alchemy/admin.js
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,6 @@
//= require alchemy/alchemy.dialog
//= require alchemy/alchemy.char_counter
//= require alchemy/alchemy.confirm_dialog
//= require alchemy/alchemy.dirty
//= require alchemy/alchemy.dragndrop
//= require alchemy/alchemy.element_editors
//= require alchemy/alchemy.elements_window
Expand Down
59 changes: 0 additions & 59 deletions app/assets/javascripts/alchemy/alchemy.dirty.js.coffee

This file was deleted.

5 changes: 3 additions & 2 deletions app/javascript/alchemy_admin.js
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
import "@hotwired/turbo-rails"

import translate from "alchemy_admin/i18n"
import Dirty from "alchemy_admin/dirty"
import translationData from "alchemy_admin/translations"
import fileEditors from "alchemy_admin/file_editors"
import IngredientAnchorLink from "alchemy_admin/ingredient_anchor_link"
Expand All @@ -19,8 +20,8 @@ if (typeof window.Alchemy === "undefined") {

// Enhance the global Alchemy object with imported features
Object.assign(Alchemy, {
// Global utility method for translating a given string
t: translate,
...Dirty,
t: translate, // Global utility method for translating a given string
translations: Object.assign(Alchemy.translations || {}, translationData),
fileEditors,
pictureEditors,
Expand Down
4 changes: 1 addition & 3 deletions app/javascript/alchemy_admin/datepicker.js
Original file line number Diff line number Diff line change
Expand Up @@ -23,9 +23,7 @@ export default function Datepicker(scope = document) {
noCalendar: type === "time",
time_24hr: Alchemy.t("formats.time_24hr"),
onValueUpdate(_selectedDates, _dateStr, instance) {
return Alchemy.setElementDirty(
instance.element.closest(".element-editor")
)
Alchemy.setElementDirty(instance.element.closest(".element-editor"))
}
}
flatpickr(input, options)
Expand Down
79 changes: 79 additions & 0 deletions app/javascript/alchemy_admin/dirty.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,79 @@
function ElementDirtyObserver(selector) {
$(selector)
.find('input[type="text"], select')
.change(function (event) {
const $content = $(event.target)
$content.addClass("dirty")
setElementDirty($content.closest(".element-editor"))
})
}

function setElementDirty(element) {
$(element).addClass("dirty")
window.onbeforeunload = Alchemy.t("page_dirty_notice")
}

function setElementClean(element) {
const $element = $(element)
$element.removeClass("dirty")
$element.find("> .element-body .dirty").removeClass("dirty")
window.onbeforeunload = () => {}
}

function isPageDirty() {
return $("#element_area").find(".element-editor.dirty").length > 0
}

function isElementDirty(element) {
return $(element).hasClass("dirty")
}

function checkPageDirtyness(element) {
let callback = () => {}

if ($(element).is("form")) {
callback = function () {
const $form = $(
`<form action="${element.action}" method="POST" style="display: none" />`
)
$form.append($(element).find("input"))
$form.appendTo("body")

Alchemy.pleaseWaitOverlay()
$form.submit()
}
} else if ($(element).is("a")) {
callback = () => Turbo.visit(element.pathname)
}

if (isPageDirty()) {
Alchemy.openConfirmDialog(Alchemy.t("page_dirty_notice"), {
title: Alchemy.t("warning"),
ok_label: Alchemy.t("ok"),
cancel_label: Alchemy.t("cancel"),
on_ok: function () {
window.onbeforeunload = void 0
callback()
}
})
return false
}
return true
}

function PageLeaveObserver() {
$("#main_navi a").click(function (event) {
if (!checkPageDirtyness(event.currentTarget)) {
event.preventDefault()
}
})
}

export default {
ElementDirtyObserver,
setElementDirty,
setElementClean,
isElementDirty,
checkPageDirtyness,
PageLeaveObserver
}

0 comments on commit 9bd0277

Please sign in to comment.