Skip to content

Commit

Permalink
Precompile alchem/preview.js
Browse files Browse the repository at this point in the history
Precompile the preview mode code with Rollup
and serve this to the preview window.

(cherry picked from commit 4b2ebdf)
  • Loading branch information
tvdeyen committed Jan 3, 2025
1 parent 77f6251 commit bec7c31
Show file tree
Hide file tree
Showing 7 changed files with 127 additions and 100 deletions.
1 change: 1 addition & 0 deletions app/assets/builds/alchemy/preview.min.js

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 0 additions & 1 deletion app/assets/config/alchemy_manifest.js
Original file line number Diff line number Diff line change
@@ -1,5 +1,4 @@
//= link alchemy/admin/all.js
//= link alchemy/preview.js
//= link_tree ../builds/alchemy/
//= link_tree ../builds/tinymce/
//= link_tree ../images/alchemy/
Expand Down
97 changes: 0 additions & 97 deletions app/assets/javascripts/alchemy/alchemy.preview.js.coffee

This file was deleted.

1 change: 0 additions & 1 deletion app/assets/javascripts/alchemy/preview.js

This file was deleted.

117 changes: 117 additions & 0 deletions app/javascript/preview.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,117 @@
window.Alchemy = Alchemy || {}

Object.assign(Alchemy, {
ElementSelector: {
styles: {
reset: {
outline: "",
"outline-offset": "",
cursor: ""
},
hover: {
outline: "2px dashed #f0b437",
"outline-offset": "4px",
cursor: "pointer"
},
selected: {
outline: "2px dashed #90b9d0",
"outline-offset": "4px"
}
},

init() {
window.addEventListener("message", (event) => {
switch (event.data.message) {
case "Alchemy.blurElements":
this.blurElements()
break
case "Alchemy.focusElement":
this.focusElement(event.data)
break
default:
console.info("Received unknown message!", event.data)
}
})
this.elements = Array.from(
document.querySelectorAll("[data-alchemy-element]")
)
this.elements.forEach((element) => {
element.addEventListener("mouseover", () => {
if (!element.classList.contains("selected")) {
Object.assign(element.style, this.getStyle("hover"))
}
})
element.addEventListener("mouseout", () => {
if (!element.classList.contains("selected")) {
Object.assign(element.style, this.getStyle("reset"))
}
})
element.addEventListener("click", (e) => {
e.stopPropagation()
e.preventDefault()
this.selectElement(element)
this.focusElementEditor(element)
})
})
},

// Mark element in preview frame as selected and scrolls to it.
selectElement(element) {
this.blurElements(element)
element.classList.add("selected")
Object.assign(element.style, this.getStyle("selected"))
element.scrollIntoView({
behavior: "smooth",
block: "start"
})
},

// Blur all elements in preview frame.
blurElements(selectedElement) {
this.elements.forEach((element) => {
if (element !== selectedElement) {
element.classList.remove("selected")
Object.assign(element.style, this.getStyle("reset"))
}
})
},

// Focus the element in the Alchemy preview window.
focusElement(data) {
const element = this.getElement(data.element_id)
if (element) {
return this.selectElement(element)
} else {
return console.warn("Could not focus element with id", data.element_id)
}
},

getElement(element_id) {
return this.elements.find(
(element) => element.dataset.alchemyElement === element_id.toString()
)
},

// Focus the element editor in the Alchemy element window.
focusElementEditor(element) {
const element_id = element.dataset.alchemyElement
window.parent.postMessage(
{
message: "Alchemy.focusElementEditor",
element_id
},
window.location.origin
)
},

getStyle(state) {
if (state === "reset") {
return this.styles["reset"]
} else {
return this.styles[state]
}
}
}
})

Alchemy.ElementSelector.init()
2 changes: 1 addition & 1 deletion app/views/alchemy/_preview_mode_code.html.erb
Original file line number Diff line number Diff line change
Expand Up @@ -2,5 +2,5 @@
<script type="text/javascript">
Alchemy = { locale: "<%= session[:alchemy_locale] %>" };
</script>
<%= javascript_include_tag("alchemy/preview") %>
<%= javascript_include_tag("alchemy/preview.min") %>
<% end %>
8 changes: 8 additions & 0 deletions rollup.config.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -67,5 +67,13 @@ export default [
commonjs(),
terser()
]
},
{
input: "app/javascript/preview.js",
output: {
file: "app/assets/builds/alchemy/preview.min.js"
},
context: "window",
plugins: [terser()]
}
]

0 comments on commit bec7c31

Please sign in to comment.