overlastic 0.3.0 → 0.4.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: bda80a4a2551cff283adee236709eec0c463cbe2bc3ca7b218742b84877584ef
4
- data.tar.gz: 938eb098db92191e485e6bb4dade9496dd68b5f934af7291d5961fe274c8e814
3
+ metadata.gz: 12febd358472a27cc298f0fccbc926ca3371541318e1a44b3c820d68d343ef82
4
+ data.tar.gz: be8ad7a622c7fea1f4ef02c11d725ec3de01775a3cba8b7815dfc18de9686316
5
5
  SHA512:
6
- metadata.gz: d53a5c31f75bb3c00652d91974f43061de0a5a6f38dfe7802ff9a59d248136f5b05fe22d23ddd5c186e2c218b71ae4802f607152a88c27cd089e679bde7d7c56
7
- data.tar.gz: 53fb86bb7138bedd8a4c8cf05abb2e4787cfec0215fb7dff9c01924ed5b340cd1e078d2bdf927b3304059200a08bfe18b1625d72bff50b879cd16b502f61d6ff
6
+ metadata.gz: ea378a5f3ecd88da89eb84ee9830ffd253f8b548e23e0c031a34f39bf644e905ef1ac42b964245857f5cddaf69b1805a0c295eaef0b378528b982e304e358cab
7
+ data.tar.gz: cb6106f4f28b54b4232666c7cc1930622c53ca04851f0379650dc2c8382d41aac7bf80064a4df89877eb14885372cacda0706f920bacb8f4ccd1aed763cc3f0e
data/README.md CHANGED
@@ -45,6 +45,16 @@ By default, links and forms inside an overlay will drive the entire page (target
45
45
  <%= link_to_dialog "Open dialog", edit_article_path, overlay_target: :_self %>
46
46
  ```
47
47
 
48
+ A common use case is to render a form inside an overlay. When the form is submitted, you'll validate the data and redirect to a different page if it's successful or render the form again with errors. Overlastic will handle both cases gracefully without any modifications:
49
+
50
+ ```rb
51
+ if @article.save
52
+ redirect_to article_url(@article)
53
+ else
54
+ render :new, status: :unprocessable_entity
55
+ end
56
+ ```
57
+
48
58
  Sometimes, you may want to alter the content depending on whether it's inside an overlay or not. Overlastic defines a new `:overlay` request variant that you can use to create custom partials like `_form.html+overlay.erb` or inside a controller like so:
49
59
 
50
60
  ```rb
@@ -101,7 +111,9 @@ Overlastic comes with default views for both the dialog and pane overlays. It al
101
111
  <details>
102
112
  <summary>Roadmap</summary><br>
103
113
 
104
- - Handle 4xx responses (p.e. validation errors) when submitting forms inside an overlay
114
+ - Ability to configure the default target
115
+ - Allow the server to request closing an overlay / all the overlays
116
+ - Toasts?
105
117
  </details>
106
118
 
107
119
  <details>
@@ -203,34 +203,59 @@ var enableBodyScroll$1 = function enableBodyScroll(targetElement) {
203
203
  };
204
204
 
205
205
  addEventListener("click", (event => {
206
- window._overlasticClickedElement = event.target.closest("[data-turbo-frame^=overlay]");
207
- }));
208
-
209
- addEventListener("click", (_event => {
210
- if (!window._overlasticClickedElement) return;
211
- const target = window._overlasticClickedElement.dataset.overlayTarget;
212
- const frame = document.querySelector(`turbo-frame#${window._overlasticClickedElement.dataset.turboFrame}`);
213
- if (target === "_self") {
214
- frame.removeAttribute("target");
215
- } else {
216
- frame.setAttribute("target", "_top");
217
- }
218
- }));
206
+ window._overlasticAnchor = event.target.closest("a[data-turbo-frame^=overlay]");
207
+ }), true);
219
208
 
220
209
  addEventListener("turbo:before-fetch-request", (event => {
221
- if (!window._overlasticClickedElement) return;
222
- const target = window._overlasticClickedElement;
223
- const type = target?.dataset?.overlayType;
224
- const args = target?.dataset?.overlayArgs;
210
+ if (!window._overlasticAnchor) return;
211
+ const anchor = window._overlasticAnchor;
212
+ const type = anchor?.dataset?.overlayType;
213
+ const target = anchor?.dataset?.overlayTarget;
214
+ const args = anchor?.dataset?.overlayArgs;
215
+ event.detail.fetchOptions.headers["Overlay-Initiator"] = "1";
225
216
  if (type) {
226
217
  event.detail.fetchOptions.headers["Overlay-Type"] = type;
227
218
  }
219
+ if (target) {
220
+ event.detail.fetchOptions.headers["Overlay-Target"] = target;
221
+ }
228
222
  if (args) {
229
223
  event.detail.fetchOptions.headers["Overlay-Args"] = args;
230
224
  }
231
225
  delete window._overlasticTarget;
232
226
  }));
233
227
 
228
+ addEventListener("turbo:before-fetch-request", (event => {
229
+ if (window._overlasticAnchor) return;
230
+ const frame = event.target.closest("turbo-frame[id^=overlay]");
231
+ if (frame) {
232
+ const target = frame.dataset.overlayTarget;
233
+ const type = frame.dataset?.overlayType;
234
+ const args = frame.dataset?.overlayArgs;
235
+ event.detail.fetchOptions.headers["Overlay-Target"] = target;
236
+ if (type) {
237
+ event.detail.fetchOptions.headers["Overlay-Type"] = type;
238
+ }
239
+ if (args) {
240
+ event.detail.fetchOptions.headers["Overlay-Args"] = args;
241
+ }
242
+ }
243
+ }));
244
+
245
+ addEventListener("turbo:before-fetch-response", (async event => {
246
+ const fetchResponse = event.detail.fetchResponse;
247
+ if (!fetchResponse.response.headers.has("Overlay-Visit")) return;
248
+ const responseHTML = await fetchResponse.responseHTML;
249
+ const {location: location, redirected: redirected, statusCode: statusCode} = fetchResponse;
250
+ return Turbo.session.visit(location, {
251
+ response: {
252
+ redirected: redirected,
253
+ statusCode: statusCode,
254
+ responseHTML: responseHTML
255
+ }
256
+ });
257
+ }));
258
+
234
259
  class DialogElement extends HTMLElement {
235
260
  connectedCallback() {
236
261
  disableBodyScroll(this);
@@ -1,2 +1,2 @@
1
- var e=!1;if("undefined"!=typeof window){var t={get passive(){e=!0}};window.addEventListener("testPassive",null,t),window.removeEventListener("testPassive",null,t)}var o="undefined"!=typeof window&&window.navigator&&window.navigator.platform&&(/iP(ad|hone|od)/.test(window.navigator.platform)||"MacIntel"===window.navigator.platform&&window.navigator.maxTouchPoints>1),n=[],i=!1,r=-1,l=void 0,d=void 0,s=void 0,a=function(e){return n.some((function(t){return!(!t.options.allowTouchMove||!t.options.allowTouchMove(e))}))},c=function(e){var t=e||window.event;return!!a(t.target)||(t.touches.length>1||(t.preventDefault&&t.preventDefault(),!1))};addEventListener("click",(e=>{window._overlasticClickedElement=e.target.closest("[data-turbo-frame^=overlay]")})),addEventListener("click",(e=>{if(!window._overlasticClickedElement)return;const t=window._overlasticClickedElement.dataset.overlayTarget,o=document.querySelector(`turbo-frame#${window._overlasticClickedElement.dataset.turboFrame}`);"_self"===t?o.removeAttribute("target"):o.setAttribute("target","_top")})),addEventListener("turbo:before-fetch-request",(e=>{if(!window._overlasticClickedElement)return;const t=window._overlasticClickedElement,o=t?.dataset?.overlayType,n=t?.dataset?.overlayArgs;o&&(e.detail.fetchOptions.headers["Overlay-Type"]=o),n&&(e.detail.fetchOptions.headers["Overlay-Args"]=n),delete window._overlasticTarget}));class u extends HTMLElement{connectedCallback(){disableBodyScroll(this),this.addEventListener("click",(e=>this.close(e,!0))),this.querySelector(".overlastic-close").addEventListener("click",(e=>this.close(e)))}close(e,t=!1){t&&e.target!==this||(enableBodyScroll(this),setTimeout((()=>{this.remove()}),5))}}customElements.define("overlastic-dialog",u);customElements.define("overlastic-pane",class extends u{connectedCallback(){super.connectedCallback();const e=Turbo.navigator.history.location;window.modalVisitStack||(window.modalVisitStack=[]),window.modalVisitStack.push(e),Turbo.navigator.history.push(new URL(this.parentElement.src))}close(e,t=!1){t&&e.target!==this||(super.close(e,t),window.modalVisitStack.length>0&&Turbo.navigator.history.replace(window.modalVisitStack.pop()))}}),window.disableBodyScroll=function(t,u){if(t){if(!n.some((function(e){return e.targetElement===t}))){var v={targetElement:t,options:u||{}};n=[].concat(function(e){if(Array.isArray(e)){for(var t=0,o=Array(e.length);t<e.length;t++)o[t]=e[t];return o}return Array.from(e)}(n),[v]),o?window.requestAnimationFrame((function(){if(void 0===d){d={position:document.body.style.position,top:document.body.style.top,left:document.body.style.left};var e=window,t=e.scrollY,o=e.scrollX,n=e.innerHeight;document.body.style.position="fixed",document.body.style.top=-t,document.body.style.left=-o,setTimeout((function(){return window.requestAnimationFrame((function(){var e=n-window.innerHeight;e&&t>=n&&(document.body.style.top=-(t+e))}))}),300)}})):function(e){if(void 0===s){var t=!!e&&!0===e.reserveScrollBarGap,o=window.innerWidth-document.documentElement.clientWidth;if(t&&o>0){var n=parseInt(window.getComputedStyle(document.body).getPropertyValue("padding-right"),10);s=document.body.style.paddingRight,document.body.style.paddingRight=n+o+"px"}}void 0===l&&(l=document.body.style.overflow,document.body.style.overflow="hidden")}(u),o&&(t.ontouchstart=function(e){1===e.targetTouches.length&&(r=e.targetTouches[0].clientY)},t.ontouchmove=function(e){1===e.targetTouches.length&&function(e,t){var o=e.targetTouches[0].clientY-r;!a(e.target)&&(t&&0===t.scrollTop&&o>0||function(e){return!!e&&e.scrollHeight-e.scrollTop<=e.clientHeight}(t)&&o<0?c(e):e.stopPropagation())}(e,t)},i||(document.addEventListener("touchmove",c,e?{passive:!1}:void 0),i=!0))}}else console.error("disableBodyScroll unsuccessful - targetElement must be provided when calling disableBodyScroll on IOS devices.")},window.enableBodyScroll=function(t){t?(n=n.filter((function(e){return e.targetElement!==t})),o&&(t.ontouchstart=null,t.ontouchmove=null,i&&0===n.length&&(document.removeEventListener("touchmove",c,e?{passive:!1}:void 0),i=!1)),o?function(){if(void 0!==d){var e=-parseInt(document.body.style.top,10),t=-parseInt(document.body.style.left,10);document.body.style.position=d.position,document.body.style.top=d.top,document.body.style.left=d.left,window.scrollTo(t,e),d=void 0}}():(void 0!==s&&(document.body.style.paddingRight=s,s=void 0),void 0!==l&&(document.body.style.overflow=l,l=void 0))):console.error("enableBodyScroll unsuccessful - targetElement must be provided when calling enableBodyScroll on IOS devices.")};
1
+ var e=!1;if("undefined"!=typeof window){var t={get passive(){e=!0}};window.addEventListener("testPassive",null,t),window.removeEventListener("testPassive",null,t)}var o="undefined"!=typeof window&&window.navigator&&window.navigator.platform&&(/iP(ad|hone|od)/.test(window.navigator.platform)||"MacIntel"===window.navigator.platform&&window.navigator.maxTouchPoints>1),n=[],i=!1,r=-1,s=void 0,a=void 0,d=void 0,l=function(e){return n.some((function(t){return!(!t.options.allowTouchMove||!t.options.allowTouchMove(e))}))},c=function(e){var t=e||window.event;return!!l(t.target)||(t.touches.length>1||(t.preventDefault&&t.preventDefault(),!1))};addEventListener("click",(e=>{window._overlasticAnchor=e.target.closest("a[data-turbo-frame^=overlay]")}),!0),addEventListener("turbo:before-fetch-request",(e=>{if(!window._overlasticAnchor)return;const t=window._overlasticAnchor,o=t?.dataset?.overlayType,n=t?.dataset?.overlayTarget,i=t?.dataset?.overlayArgs;e.detail.fetchOptions.headers["Overlay-Initiator"]="1",o&&(e.detail.fetchOptions.headers["Overlay-Type"]=o),n&&(e.detail.fetchOptions.headers["Overlay-Target"]=n),i&&(e.detail.fetchOptions.headers["Overlay-Args"]=i),delete window._overlasticTarget})),addEventListener("turbo:before-fetch-request",(e=>{if(window._overlasticAnchor)return;const t=e.target.closest("turbo-frame[id^=overlay]");if(t){const o=t.dataset.overlayTarget,n=t.dataset?.overlayType,i=t.dataset?.overlayArgs;e.detail.fetchOptions.headers["Overlay-Target"]=o,n&&(e.detail.fetchOptions.headers["Overlay-Type"]=n),i&&(e.detail.fetchOptions.headers["Overlay-Args"]=i)}})),addEventListener("turbo:before-fetch-response",(async e=>{const t=e.detail.fetchResponse;if(!t.response.headers.has("Overlay-Visit"))return;const o=await t.responseHTML,{location:n,redirected:i,statusCode:r}=t;return Turbo.session.visit(n,{response:{redirected:i,statusCode:r,responseHTML:o}})}));class u extends HTMLElement{connectedCallback(){disableBodyScroll(this),this.addEventListener("click",(e=>this.close(e,!0))),this.querySelector(".overlastic-close").addEventListener("click",(e=>this.close(e)))}close(e,t=!1){t&&e.target!==this||(enableBodyScroll(this),setTimeout((()=>{this.remove()}),5))}}customElements.define("overlastic-dialog",u);customElements.define("overlastic-pane",class extends u{connectedCallback(){super.connectedCallback();const e=Turbo.navigator.history.location;window.modalVisitStack||(window.modalVisitStack=[]),window.modalVisitStack.push(e),Turbo.navigator.history.push(new URL(this.parentElement.src))}close(e,t=!1){t&&e.target!==this||(super.close(e,t),window.modalVisitStack.length>0&&Turbo.navigator.history.replace(window.modalVisitStack.pop()))}}),window.disableBodyScroll=function(t,u){if(t){if(!n.some((function(e){return e.targetElement===t}))){var v={targetElement:t,options:u||{}};n=[].concat(function(e){if(Array.isArray(e)){for(var t=0,o=Array(e.length);t<e.length;t++)o[t]=e[t];return o}return Array.from(e)}(n),[v]),o?window.requestAnimationFrame((function(){if(void 0===a){a={position:document.body.style.position,top:document.body.style.top,left:document.body.style.left};var e=window,t=e.scrollY,o=e.scrollX,n=e.innerHeight;document.body.style.position="fixed",document.body.style.top=-t,document.body.style.left=-o,setTimeout((function(){return window.requestAnimationFrame((function(){var e=n-window.innerHeight;e&&t>=n&&(document.body.style.top=-(t+e))}))}),300)}})):function(e){if(void 0===d){var t=!!e&&!0===e.reserveScrollBarGap,o=window.innerWidth-document.documentElement.clientWidth;if(t&&o>0){var n=parseInt(window.getComputedStyle(document.body).getPropertyValue("padding-right"),10);d=document.body.style.paddingRight,document.body.style.paddingRight=n+o+"px"}}void 0===s&&(s=document.body.style.overflow,document.body.style.overflow="hidden")}(u),o&&(t.ontouchstart=function(e){1===e.targetTouches.length&&(r=e.targetTouches[0].clientY)},t.ontouchmove=function(e){1===e.targetTouches.length&&function(e,t){var o=e.targetTouches[0].clientY-r;!l(e.target)&&(t&&0===t.scrollTop&&o>0||function(e){return!!e&&e.scrollHeight-e.scrollTop<=e.clientHeight}(t)&&o<0?c(e):e.stopPropagation())}(e,t)},i||(document.addEventListener("touchmove",c,e?{passive:!1}:void 0),i=!0))}}else console.error("disableBodyScroll unsuccessful - targetElement must be provided when calling disableBodyScroll on IOS devices.")},window.enableBodyScroll=function(t){t?(n=n.filter((function(e){return e.targetElement!==t})),o&&(t.ontouchstart=null,t.ontouchmove=null,i&&0===n.length&&(document.removeEventListener("touchmove",c,e?{passive:!1}:void 0),i=!1)),o?function(){if(void 0!==a){var e=-parseInt(document.body.style.top,10),t=-parseInt(document.body.style.left,10);document.body.style.position=a.position,document.body.style.top=a.top,document.body.style.left=a.left,window.scrollTo(t,e),a=void 0}}():(void 0!==d&&(document.body.style.paddingRight=d,d=void 0),void 0!==s&&(document.body.style.overflow=s,s=void 0))):console.error("enableBodyScroll unsuccessful - targetElement must be provided when calling enableBodyScroll on IOS devices.")};
2
2
  //# sourceMappingURL=overlastic.min.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"overlastic.min.js","sources":["../../../node_modules/body-scroll-lock/lib/bodyScrollLock.esm.js","../../javascript/overlastic/clickInterceptor.js","../../javascript/overlastic/dialogElement.js","../../javascript/overlastic/paneElement.js","../../javascript/overlastic/index.js"],"sourcesContent":["function _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }\n\n// Older browsers don't support event options, feature detect it.\n\n// Adopted and modified solution from Bohdan Didukh (2017)\n// https://stackoverflow.com/questions/41594997/ios-10-safari-prevent-scrolling-behind-a-fixed-overlay-and-maintain-scroll-posi\n\nvar hasPassiveEvents = false;\nif (typeof window !== 'undefined') {\n var passiveTestOptions = {\n get passive() {\n hasPassiveEvents = true;\n return undefined;\n }\n };\n window.addEventListener('testPassive', null, passiveTestOptions);\n window.removeEventListener('testPassive', null, passiveTestOptions);\n}\n\nvar isIosDevice = typeof window !== 'undefined' && window.navigator && window.navigator.platform && (/iP(ad|hone|od)/.test(window.navigator.platform) || window.navigator.platform === 'MacIntel' && window.navigator.maxTouchPoints > 1);\n\n\nvar locks = [];\nvar documentListenerAdded = false;\nvar initialClientY = -1;\nvar previousBodyOverflowSetting = void 0;\nvar previousBodyPosition = void 0;\nvar previousBodyPaddingRight = void 0;\n\n// returns true if `el` should be allowed to receive touchmove events.\nvar allowTouchMove = function allowTouchMove(el) {\n return locks.some(function (lock) {\n if (lock.options.allowTouchMove && lock.options.allowTouchMove(el)) {\n return true;\n }\n\n return false;\n });\n};\n\nvar preventDefault = function preventDefault(rawEvent) {\n var e = rawEvent || window.event;\n\n // For the case whereby consumers adds a touchmove event listener to document.\n // Recall that we do document.addEventListener('touchmove', preventDefault, { passive: false })\n // in disableBodyScroll - so if we provide this opportunity to allowTouchMove, then\n // the touchmove event on document will break.\n if (allowTouchMove(e.target)) {\n return true;\n }\n\n // Do not prevent if the event has more than one touch (usually meaning this is a multi touch gesture like pinch to zoom).\n if (e.touches.length > 1) return true;\n\n if (e.preventDefault) e.preventDefault();\n\n return false;\n};\n\nvar setOverflowHidden = function setOverflowHidden(options) {\n // If previousBodyPaddingRight is already set, don't set it again.\n if (previousBodyPaddingRight === undefined) {\n var _reserveScrollBarGap = !!options && options.reserveScrollBarGap === true;\n var scrollBarGap = window.innerWidth - document.documentElement.clientWidth;\n\n if (_reserveScrollBarGap && scrollBarGap > 0) {\n var computedBodyPaddingRight = parseInt(window.getComputedStyle(document.body).getPropertyValue('padding-right'), 10);\n previousBodyPaddingRight = document.body.style.paddingRight;\n document.body.style.paddingRight = computedBodyPaddingRight + scrollBarGap + 'px';\n }\n }\n\n // If previousBodyOverflowSetting is already set, don't set it again.\n if (previousBodyOverflowSetting === undefined) {\n previousBodyOverflowSetting = document.body.style.overflow;\n document.body.style.overflow = 'hidden';\n }\n};\n\nvar restoreOverflowSetting = function restoreOverflowSetting() {\n if (previousBodyPaddingRight !== undefined) {\n document.body.style.paddingRight = previousBodyPaddingRight;\n\n // Restore previousBodyPaddingRight to undefined so setOverflowHidden knows it\n // can be set again.\n previousBodyPaddingRight = undefined;\n }\n\n if (previousBodyOverflowSetting !== undefined) {\n document.body.style.overflow = previousBodyOverflowSetting;\n\n // Restore previousBodyOverflowSetting to undefined\n // so setOverflowHidden knows it can be set again.\n previousBodyOverflowSetting = undefined;\n }\n};\n\nvar setPositionFixed = function setPositionFixed() {\n return window.requestAnimationFrame(function () {\n // If previousBodyPosition is already set, don't set it again.\n if (previousBodyPosition === undefined) {\n previousBodyPosition = {\n position: document.body.style.position,\n top: document.body.style.top,\n left: document.body.style.left\n };\n\n // Update the dom inside an animation frame \n var _window = window,\n scrollY = _window.scrollY,\n scrollX = _window.scrollX,\n innerHeight = _window.innerHeight;\n\n document.body.style.position = 'fixed';\n document.body.style.top = -scrollY;\n document.body.style.left = -scrollX;\n\n setTimeout(function () {\n return window.requestAnimationFrame(function () {\n // Attempt to check if the bottom bar appeared due to the position change\n var bottomBarHeight = innerHeight - window.innerHeight;\n if (bottomBarHeight && scrollY >= innerHeight) {\n // Move the content further up so that the bottom bar doesn't hide it\n document.body.style.top = -(scrollY + bottomBarHeight);\n }\n });\n }, 300);\n }\n });\n};\n\nvar restorePositionSetting = function restorePositionSetting() {\n if (previousBodyPosition !== undefined) {\n // Convert the position from \"px\" to Int\n var y = -parseInt(document.body.style.top, 10);\n var x = -parseInt(document.body.style.left, 10);\n\n // Restore styles\n document.body.style.position = previousBodyPosition.position;\n document.body.style.top = previousBodyPosition.top;\n document.body.style.left = previousBodyPosition.left;\n\n // Restore scroll\n window.scrollTo(x, y);\n\n previousBodyPosition = undefined;\n }\n};\n\n// https://developer.mozilla.org/en-US/docs/Web/API/Element/scrollHeight#Problems_and_solutions\nvar isTargetElementTotallyScrolled = function isTargetElementTotallyScrolled(targetElement) {\n return targetElement ? targetElement.scrollHeight - targetElement.scrollTop <= targetElement.clientHeight : false;\n};\n\nvar handleScroll = function handleScroll(event, targetElement) {\n var clientY = event.targetTouches[0].clientY - initialClientY;\n\n if (allowTouchMove(event.target)) {\n return false;\n }\n\n if (targetElement && targetElement.scrollTop === 0 && clientY > 0) {\n // element is at the top of its scroll.\n return preventDefault(event);\n }\n\n if (isTargetElementTotallyScrolled(targetElement) && clientY < 0) {\n // element is at the bottom of its scroll.\n return preventDefault(event);\n }\n\n event.stopPropagation();\n return true;\n};\n\nexport var disableBodyScroll = function disableBodyScroll(targetElement, options) {\n // targetElement must be provided\n if (!targetElement) {\n // eslint-disable-next-line no-console\n console.error('disableBodyScroll unsuccessful - targetElement must be provided when calling disableBodyScroll on IOS devices.');\n return;\n }\n\n // disableBodyScroll must not have been called on this targetElement before\n if (locks.some(function (lock) {\n return lock.targetElement === targetElement;\n })) {\n return;\n }\n\n var lock = {\n targetElement: targetElement,\n options: options || {}\n };\n\n locks = [].concat(_toConsumableArray(locks), [lock]);\n\n if (isIosDevice) {\n setPositionFixed();\n } else {\n setOverflowHidden(options);\n }\n\n if (isIosDevice) {\n targetElement.ontouchstart = function (event) {\n if (event.targetTouches.length === 1) {\n // detect single touch.\n initialClientY = event.targetTouches[0].clientY;\n }\n };\n targetElement.ontouchmove = function (event) {\n if (event.targetTouches.length === 1) {\n // detect single touch.\n handleScroll(event, targetElement);\n }\n };\n\n if (!documentListenerAdded) {\n document.addEventListener('touchmove', preventDefault, hasPassiveEvents ? { passive: false } : undefined);\n documentListenerAdded = true;\n }\n }\n};\n\nexport var clearAllBodyScrollLocks = function clearAllBodyScrollLocks() {\n if (isIosDevice) {\n // Clear all locks ontouchstart/ontouchmove handlers, and the references.\n locks.forEach(function (lock) {\n lock.targetElement.ontouchstart = null;\n lock.targetElement.ontouchmove = null;\n });\n\n if (documentListenerAdded) {\n document.removeEventListener('touchmove', preventDefault, hasPassiveEvents ? { passive: false } : undefined);\n documentListenerAdded = false;\n }\n\n // Reset initial clientY.\n initialClientY = -1;\n }\n\n if (isIosDevice) {\n restorePositionSetting();\n } else {\n restoreOverflowSetting();\n }\n\n locks = [];\n};\n\nexport var enableBodyScroll = function enableBodyScroll(targetElement) {\n if (!targetElement) {\n // eslint-disable-next-line no-console\n console.error('enableBodyScroll unsuccessful - targetElement must be provided when calling enableBodyScroll on IOS devices.');\n return;\n }\n\n locks = locks.filter(function (lock) {\n return lock.targetElement !== targetElement;\n });\n\n if (isIosDevice) {\n targetElement.ontouchstart = null;\n targetElement.ontouchmove = null;\n\n if (documentListenerAdded && locks.length === 0) {\n document.removeEventListener('touchmove', preventDefault, hasPassiveEvents ? { passive: false } : undefined);\n documentListenerAdded = false;\n }\n }\n\n if (isIosDevice) {\n restorePositionSetting();\n } else {\n restoreOverflowSetting();\n }\n};\n\n","// Save the clicked overlay link element for use down the line\naddEventListener(\"click\", event => {\n window._overlasticClickedElement = event.target.closest(\"[data-turbo-frame^=overlay]\")\n})\n\n// Set the correct target for the frame according to the desired behavior\naddEventListener(\"click\", _event => {\n if (!window._overlasticClickedElement) return\n\n const target = window._overlasticClickedElement.dataset.overlayTarget\n const frame = document.querySelector(`turbo-frame#${window._overlasticClickedElement.dataset.turboFrame}`)\n\n if (target === \"_self\") {\n frame.removeAttribute(\"target\")\n } else {\n frame.setAttribute(\"target\", \"_top\")\n }\n})\n\n// Send overlay type and args along with the frame request\naddEventListener(\"turbo:before-fetch-request\", event => {\n if (!window._overlasticClickedElement) return\n\n const target = window._overlasticClickedElement\n const type = target?.dataset?.overlayType\n const args = target?.dataset?.overlayArgs\n\n if (type) {\n event.detail.fetchOptions.headers[\"Overlay-Type\"] = type\n }\n\n if (args) {\n event.detail.fetchOptions.headers[\"Overlay-Args\"] = args\n }\n\n delete window._overlasticTarget\n})\n","export default class DialogElement extends HTMLElement {\n connectedCallback() {\n disableBodyScroll(this)\n\n this.addEventListener(\"click\", event => this.close(event, true))\n this.querySelector(\".overlastic-close\").addEventListener(\"click\", event => this.close(event))\n }\n\n close(event, self = false) {\n if (self && event.target !== this) return\n\n enableBodyScroll(this)\n\n // Avoid removing before sending dispatching other events (like form submissions)\n setTimeout(() => {\n this.remove()\n }, 5)\n }\n}\n\ncustomElements.define(\"overlastic-dialog\", DialogElement)\n","import DialogElement from \"./dialogElement\"\n\nclass PaneElement extends DialogElement {\n connectedCallback() {\n super.connectedCallback()\n\n const lastVisit = Turbo.navigator.history.location\n\n if (!window.modalVisitStack) {\n window.modalVisitStack = []\n }\n\n window.modalVisitStack.push(lastVisit)\n Turbo.navigator.history.push(new URL(this.parentElement.src))\n }\n\n close(event, self = false) {\n if (self && event.target !== this) return\n\n super.close(event, self)\n\n if (window.modalVisitStack.length > 0) {\n Turbo.navigator.history.replace(window.modalVisitStack.pop())\n }\n }\n}\n\ncustomElements.define(\"overlastic-pane\", PaneElement)\n","import { disableBodyScroll, enableBodyScroll } from \"body-scroll-lock\"\n\nimport \"./clickInterceptor\"\nimport \"./dialogElement\"\nimport \"./paneElement\"\n\nwindow.disableBodyScroll = disableBodyScroll\nwindow.enableBodyScroll = enableBodyScroll\n"],"names":["hasPassiveEvents","window","passiveTestOptions","passive","addEventListener","removeEventListener","isIosDevice","navigator","platform","test","maxTouchPoints","locks","documentListenerAdded","initialClientY","previousBodyOverflowSetting","previousBodyPosition","previousBodyPaddingRight","allowTouchMove","el","some","lock","options","preventDefault","rawEvent","e","event","target","touches","length","_overlasticClickedElement","closest","_event","dataset","overlayTarget","frame","document","querySelector","turboFrame","removeAttribute","setAttribute","type","overlayType","args","overlayArgs","detail","fetchOptions","headers","_overlasticTarget","DialogElement","HTMLElement","[object Object]","disableBodyScroll","this","close","self","enableBodyScroll","setTimeout","remove","customElements","define","super","connectedCallback","lastVisit","Turbo","history","location","modalVisitStack","push","URL","parentElement","src","replace","pop","targetElement","concat","arr","Array","isArray","i","arr2","from","_toConsumableArray","requestAnimationFrame","undefined","position","body","style","top","left","_window","scrollY","scrollX","innerHeight","bottomBarHeight","_reserveScrollBarGap","reserveScrollBarGap","scrollBarGap","innerWidth","documentElement","clientWidth","computedBodyPaddingRight","parseInt","getComputedStyle","getPropertyValue","paddingRight","overflow","setOverflowHidden","ontouchstart","targetTouches","clientY","ontouchmove","scrollTop","scrollHeight","clientHeight","isTargetElementTotallyScrolled","stopPropagation","handleScroll","console","error","filter","y","x","scrollTo","restorePositionSetting"],"mappings":"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"}
1
+ {"version":3,"file":"overlastic.min.js","sources":["../../../node_modules/body-scroll-lock/lib/bodyScrollLock.esm.js","../../javascript/overlastic/clickInterceptor.js","../../javascript/overlastic/dialogElement.js","../../javascript/overlastic/paneElement.js","../../javascript/overlastic/index.js"],"sourcesContent":["function _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }\n\n// Older browsers don't support event options, feature detect it.\n\n// Adopted and modified solution from Bohdan Didukh (2017)\n// https://stackoverflow.com/questions/41594997/ios-10-safari-prevent-scrolling-behind-a-fixed-overlay-and-maintain-scroll-posi\n\nvar hasPassiveEvents = false;\nif (typeof window !== 'undefined') {\n var passiveTestOptions = {\n get passive() {\n hasPassiveEvents = true;\n return undefined;\n }\n };\n window.addEventListener('testPassive', null, passiveTestOptions);\n window.removeEventListener('testPassive', null, passiveTestOptions);\n}\n\nvar isIosDevice = typeof window !== 'undefined' && window.navigator && window.navigator.platform && (/iP(ad|hone|od)/.test(window.navigator.platform) || window.navigator.platform === 'MacIntel' && window.navigator.maxTouchPoints > 1);\n\n\nvar locks = [];\nvar documentListenerAdded = false;\nvar initialClientY = -1;\nvar previousBodyOverflowSetting = void 0;\nvar previousBodyPosition = void 0;\nvar previousBodyPaddingRight = void 0;\n\n// returns true if `el` should be allowed to receive touchmove events.\nvar allowTouchMove = function allowTouchMove(el) {\n return locks.some(function (lock) {\n if (lock.options.allowTouchMove && lock.options.allowTouchMove(el)) {\n return true;\n }\n\n return false;\n });\n};\n\nvar preventDefault = function preventDefault(rawEvent) {\n var e = rawEvent || window.event;\n\n // For the case whereby consumers adds a touchmove event listener to document.\n // Recall that we do document.addEventListener('touchmove', preventDefault, { passive: false })\n // in disableBodyScroll - so if we provide this opportunity to allowTouchMove, then\n // the touchmove event on document will break.\n if (allowTouchMove(e.target)) {\n return true;\n }\n\n // Do not prevent if the event has more than one touch (usually meaning this is a multi touch gesture like pinch to zoom).\n if (e.touches.length > 1) return true;\n\n if (e.preventDefault) e.preventDefault();\n\n return false;\n};\n\nvar setOverflowHidden = function setOverflowHidden(options) {\n // If previousBodyPaddingRight is already set, don't set it again.\n if (previousBodyPaddingRight === undefined) {\n var _reserveScrollBarGap = !!options && options.reserveScrollBarGap === true;\n var scrollBarGap = window.innerWidth - document.documentElement.clientWidth;\n\n if (_reserveScrollBarGap && scrollBarGap > 0) {\n var computedBodyPaddingRight = parseInt(window.getComputedStyle(document.body).getPropertyValue('padding-right'), 10);\n previousBodyPaddingRight = document.body.style.paddingRight;\n document.body.style.paddingRight = computedBodyPaddingRight + scrollBarGap + 'px';\n }\n }\n\n // If previousBodyOverflowSetting is already set, don't set it again.\n if (previousBodyOverflowSetting === undefined) {\n previousBodyOverflowSetting = document.body.style.overflow;\n document.body.style.overflow = 'hidden';\n }\n};\n\nvar restoreOverflowSetting = function restoreOverflowSetting() {\n if (previousBodyPaddingRight !== undefined) {\n document.body.style.paddingRight = previousBodyPaddingRight;\n\n // Restore previousBodyPaddingRight to undefined so setOverflowHidden knows it\n // can be set again.\n previousBodyPaddingRight = undefined;\n }\n\n if (previousBodyOverflowSetting !== undefined) {\n document.body.style.overflow = previousBodyOverflowSetting;\n\n // Restore previousBodyOverflowSetting to undefined\n // so setOverflowHidden knows it can be set again.\n previousBodyOverflowSetting = undefined;\n }\n};\n\nvar setPositionFixed = function setPositionFixed() {\n return window.requestAnimationFrame(function () {\n // If previousBodyPosition is already set, don't set it again.\n if (previousBodyPosition === undefined) {\n previousBodyPosition = {\n position: document.body.style.position,\n top: document.body.style.top,\n left: document.body.style.left\n };\n\n // Update the dom inside an animation frame \n var _window = window,\n scrollY = _window.scrollY,\n scrollX = _window.scrollX,\n innerHeight = _window.innerHeight;\n\n document.body.style.position = 'fixed';\n document.body.style.top = -scrollY;\n document.body.style.left = -scrollX;\n\n setTimeout(function () {\n return window.requestAnimationFrame(function () {\n // Attempt to check if the bottom bar appeared due to the position change\n var bottomBarHeight = innerHeight - window.innerHeight;\n if (bottomBarHeight && scrollY >= innerHeight) {\n // Move the content further up so that the bottom bar doesn't hide it\n document.body.style.top = -(scrollY + bottomBarHeight);\n }\n });\n }, 300);\n }\n });\n};\n\nvar restorePositionSetting = function restorePositionSetting() {\n if (previousBodyPosition !== undefined) {\n // Convert the position from \"px\" to Int\n var y = -parseInt(document.body.style.top, 10);\n var x = -parseInt(document.body.style.left, 10);\n\n // Restore styles\n document.body.style.position = previousBodyPosition.position;\n document.body.style.top = previousBodyPosition.top;\n document.body.style.left = previousBodyPosition.left;\n\n // Restore scroll\n window.scrollTo(x, y);\n\n previousBodyPosition = undefined;\n }\n};\n\n// https://developer.mozilla.org/en-US/docs/Web/API/Element/scrollHeight#Problems_and_solutions\nvar isTargetElementTotallyScrolled = function isTargetElementTotallyScrolled(targetElement) {\n return targetElement ? targetElement.scrollHeight - targetElement.scrollTop <= targetElement.clientHeight : false;\n};\n\nvar handleScroll = function handleScroll(event, targetElement) {\n var clientY = event.targetTouches[0].clientY - initialClientY;\n\n if (allowTouchMove(event.target)) {\n return false;\n }\n\n if (targetElement && targetElement.scrollTop === 0 && clientY > 0) {\n // element is at the top of its scroll.\n return preventDefault(event);\n }\n\n if (isTargetElementTotallyScrolled(targetElement) && clientY < 0) {\n // element is at the bottom of its scroll.\n return preventDefault(event);\n }\n\n event.stopPropagation();\n return true;\n};\n\nexport var disableBodyScroll = function disableBodyScroll(targetElement, options) {\n // targetElement must be provided\n if (!targetElement) {\n // eslint-disable-next-line no-console\n console.error('disableBodyScroll unsuccessful - targetElement must be provided when calling disableBodyScroll on IOS devices.');\n return;\n }\n\n // disableBodyScroll must not have been called on this targetElement before\n if (locks.some(function (lock) {\n return lock.targetElement === targetElement;\n })) {\n return;\n }\n\n var lock = {\n targetElement: targetElement,\n options: options || {}\n };\n\n locks = [].concat(_toConsumableArray(locks), [lock]);\n\n if (isIosDevice) {\n setPositionFixed();\n } else {\n setOverflowHidden(options);\n }\n\n if (isIosDevice) {\n targetElement.ontouchstart = function (event) {\n if (event.targetTouches.length === 1) {\n // detect single touch.\n initialClientY = event.targetTouches[0].clientY;\n }\n };\n targetElement.ontouchmove = function (event) {\n if (event.targetTouches.length === 1) {\n // detect single touch.\n handleScroll(event, targetElement);\n }\n };\n\n if (!documentListenerAdded) {\n document.addEventListener('touchmove', preventDefault, hasPassiveEvents ? { passive: false } : undefined);\n documentListenerAdded = true;\n }\n }\n};\n\nexport var clearAllBodyScrollLocks = function clearAllBodyScrollLocks() {\n if (isIosDevice) {\n // Clear all locks ontouchstart/ontouchmove handlers, and the references.\n locks.forEach(function (lock) {\n lock.targetElement.ontouchstart = null;\n lock.targetElement.ontouchmove = null;\n });\n\n if (documentListenerAdded) {\n document.removeEventListener('touchmove', preventDefault, hasPassiveEvents ? { passive: false } : undefined);\n documentListenerAdded = false;\n }\n\n // Reset initial clientY.\n initialClientY = -1;\n }\n\n if (isIosDevice) {\n restorePositionSetting();\n } else {\n restoreOverflowSetting();\n }\n\n locks = [];\n};\n\nexport var enableBodyScroll = function enableBodyScroll(targetElement) {\n if (!targetElement) {\n // eslint-disable-next-line no-console\n console.error('enableBodyScroll unsuccessful - targetElement must be provided when calling enableBodyScroll on IOS devices.');\n return;\n }\n\n locks = locks.filter(function (lock) {\n return lock.targetElement !== targetElement;\n });\n\n if (isIosDevice) {\n targetElement.ontouchstart = null;\n targetElement.ontouchmove = null;\n\n if (documentListenerAdded && locks.length === 0) {\n document.removeEventListener('touchmove', preventDefault, hasPassiveEvents ? { passive: false } : undefined);\n documentListenerAdded = false;\n }\n }\n\n if (isIosDevice) {\n restorePositionSetting();\n } else {\n restoreOverflowSetting();\n }\n};\n\n","// Save the clicked overlay link element for use down the line\naddEventListener(\"click\", event => {\n window._overlasticAnchor = event.target.closest(\"a[data-turbo-frame^=overlay]\")\n}, true)\n\n// When an overlay anchor is clicked,\n// send its type, target and args along with the frame request\naddEventListener(\"turbo:before-fetch-request\", event => {\n if (!window._overlasticAnchor) return\n\n const anchor = window._overlasticAnchor\n const type = anchor?.dataset?.overlayType\n const target = anchor?.dataset?.overlayTarget\n const args = anchor?.dataset?.overlayArgs\n\n event.detail.fetchOptions.headers[\"Overlay-Initiator\"] = \"1\"\n\n if (type) {\n event.detail.fetchOptions.headers[\"Overlay-Type\"] = type\n }\n\n if (target) {\n event.detail.fetchOptions.headers[\"Overlay-Target\"] = target\n }\n\n if (args) {\n event.detail.fetchOptions.headers[\"Overlay-Args\"] = args\n }\n\n delete window._overlasticTarget\n})\n\n// When any other element triggers a fetch,\n// send the current overlay's target along with the frame request\naddEventListener(\"turbo:before-fetch-request\", event => {\n if (window._overlasticAnchor) return\n\n const frame = event.target.closest(\"turbo-frame[id^=overlay]\")\n\n if (frame) {\n const target = frame.dataset.overlayTarget\n const type = frame.dataset?.overlayType\n const args = frame.dataset?.overlayArgs\n\n event.detail.fetchOptions.headers[\"Overlay-Target\"] = target\n\n if (type) {\n event.detail.fetchOptions.headers[\"Overlay-Type\"] = type\n }\n\n if (args) {\n event.detail.fetchOptions.headers[\"Overlay-Args\"] = args\n }\n }\n})\n\n// Handle frame-to-visit promotions when the server asks for it\naddEventListener(\"turbo:before-fetch-response\", async event => {\n const fetchResponse = event.detail.fetchResponse\n\n if (!fetchResponse.response.headers.has(\"Overlay-Visit\")) return\n\n const responseHTML = await fetchResponse.responseHTML\n const { location, redirected, statusCode } = fetchResponse\n\n return Turbo.session.visit(location, { response: { redirected, statusCode, responseHTML } })\n})\n","export default class DialogElement extends HTMLElement {\n connectedCallback() {\n disableBodyScroll(this)\n\n this.addEventListener(\"click\", event => this.close(event, true))\n this.querySelector(\".overlastic-close\").addEventListener(\"click\", event => this.close(event))\n }\n\n close(event, self = false) {\n if (self && event.target !== this) return\n\n enableBodyScroll(this)\n\n // Avoid removing before sending dispatching other events (like form submissions)\n setTimeout(() => {\n this.remove()\n }, 5)\n }\n}\n\ncustomElements.define(\"overlastic-dialog\", DialogElement)\n","import DialogElement from \"./dialogElement\"\n\nclass PaneElement extends DialogElement {\n connectedCallback() {\n super.connectedCallback()\n\n const lastVisit = Turbo.navigator.history.location\n\n if (!window.modalVisitStack) {\n window.modalVisitStack = []\n }\n\n window.modalVisitStack.push(lastVisit)\n Turbo.navigator.history.push(new URL(this.parentElement.src))\n }\n\n close(event, self = false) {\n if (self && event.target !== this) return\n\n super.close(event, self)\n\n if (window.modalVisitStack.length > 0) {\n Turbo.navigator.history.replace(window.modalVisitStack.pop())\n }\n }\n}\n\ncustomElements.define(\"overlastic-pane\", PaneElement)\n","import { disableBodyScroll, enableBodyScroll } from \"body-scroll-lock\"\n\nimport \"./clickInterceptor\"\nimport \"./dialogElement\"\nimport \"./paneElement\"\n\nwindow.disableBodyScroll = disableBodyScroll\nwindow.enableBodyScroll = enableBodyScroll\n"],"names":["hasPassiveEvents","window","passiveTestOptions","passive","addEventListener","removeEventListener","isIosDevice","navigator","platform","test","maxTouchPoints","locks","documentListenerAdded","initialClientY","previousBodyOverflowSetting","previousBodyPosition","previousBodyPaddingRight","allowTouchMove","el","some","lock","options","preventDefault","rawEvent","e","event","target","touches","length","_overlasticAnchor","closest","anchor","type","dataset","overlayType","overlayTarget","args","overlayArgs","detail","fetchOptions","headers","_overlasticTarget","frame","async","fetchResponse","response","has","responseHTML","location","redirected","statusCode","Turbo","session","visit","DialogElement","HTMLElement","[object Object]","disableBodyScroll","this","close","querySelector","self","enableBodyScroll","setTimeout","remove","customElements","define","super","connectedCallback","lastVisit","history","modalVisitStack","push","URL","parentElement","src","replace","pop","targetElement","concat","arr","Array","isArray","i","arr2","from","_toConsumableArray","requestAnimationFrame","undefined","position","document","body","style","top","left","_window","scrollY","scrollX","innerHeight","bottomBarHeight","_reserveScrollBarGap","reserveScrollBarGap","scrollBarGap","innerWidth","documentElement","clientWidth","computedBodyPaddingRight","parseInt","getComputedStyle","getPropertyValue","paddingRight","overflow","setOverflowHidden","ontouchstart","targetTouches","clientY","ontouchmove","scrollTop","scrollHeight","clientHeight","isTargetElementTotallyScrolled","stopPropagation","handleScroll","console","error","filter","y","x","scrollTo","restorePositionSetting"],"mappings":"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"}
@@ -12,7 +12,25 @@ module Overlastic::Concerns::OverlayHandling
12
12
 
13
13
  def render(*args, &block)
14
14
  if request.variant.overlay?
15
- super html: helpers.render_overlay { render_to_string(*args, &block) }
15
+ options = args.last || {}
16
+
17
+ # Rendering with an error status should render inside the overlay
18
+ error = Rack::Utils.status_code(options[:status]).in? 400..499
19
+
20
+ # Initiator requests always render inside an overlay
21
+ initiator = request.headers["Overlay-Initiator"]
22
+
23
+ # By default, navigation inside the overlay will break out of it (_top)
24
+ target = request.headers["Overlay-Target"]
25
+
26
+ if initiator || error || target != "_top"
27
+ super turbo_stream: turbo_stream.replace(helpers.current_overlay_name, html: helpers.render_overlay { render_to_string(*args, &block) })
28
+ else
29
+ request.headers["Turbo-Frame"] = nil
30
+ response.headers["Overlay-Visit"] = "1"
31
+
32
+ super
33
+ end
16
34
  else
17
35
  super
18
36
  end
@@ -1,6 +1,18 @@
1
1
  module Overlastic::OverlaysHelper
2
2
  def overlastic_tag
3
- turbo_frame_tag :overlay1, target: :_top
3
+ if block_given?
4
+ type = request.headers["Overlay-Type"]
5
+ target = request.headers["Overlay-Target"] || :_top
6
+ args = request.headers["Overlay-Args"]
7
+
8
+ turbo_frame_tag current_overlay_name, data: { overlay_type: type, overlay_target: target, overlay_args: args } do
9
+ yield
10
+
11
+ concat turbo_frame_tag(next_overlay_name, data: { overlay_target: :_top })
12
+ end
13
+ else
14
+ turbo_frame_tag :overlay1, data: { overlay_target: :_top }
15
+ end
4
16
  end
5
17
 
6
18
  def current_overlay_name
@@ -1,37 +1,67 @@
1
1
  // Save the clicked overlay link element for use down the line
2
2
  addEventListener("click", event => {
3
- window._overlasticClickedElement = event.target.closest("[data-turbo-frame^=overlay]")
4
- })
5
-
6
- // Set the correct target for the frame according to the desired behavior
7
- addEventListener("click", _event => {
8
- if (!window._overlasticClickedElement) return
9
-
10
- const target = window._overlasticClickedElement.dataset.overlayTarget
11
- const frame = document.querySelector(`turbo-frame#${window._overlasticClickedElement.dataset.turboFrame}`)
12
-
13
- if (target === "_self") {
14
- frame.removeAttribute("target")
15
- } else {
16
- frame.setAttribute("target", "_top")
17
- }
18
- })
3
+ window._overlasticAnchor = event.target.closest("a[data-turbo-frame^=overlay]")
4
+ }, true)
19
5
 
20
- // Send overlay type and args along with the frame request
6
+ // When an overlay anchor is clicked,
7
+ // send its type, target and args along with the frame request
21
8
  addEventListener("turbo:before-fetch-request", event => {
22
- if (!window._overlasticClickedElement) return
9
+ if (!window._overlasticAnchor) return
23
10
 
24
- const target = window._overlasticClickedElement
25
- const type = target?.dataset?.overlayType
26
- const args = target?.dataset?.overlayArgs
11
+ const anchor = window._overlasticAnchor
12
+ const type = anchor?.dataset?.overlayType
13
+ const target = anchor?.dataset?.overlayTarget
14
+ const args = anchor?.dataset?.overlayArgs
15
+
16
+ event.detail.fetchOptions.headers["Overlay-Initiator"] = "1"
27
17
 
28
18
  if (type) {
29
19
  event.detail.fetchOptions.headers["Overlay-Type"] = type
30
20
  }
31
21
 
22
+ if (target) {
23
+ event.detail.fetchOptions.headers["Overlay-Target"] = target
24
+ }
25
+
32
26
  if (args) {
33
27
  event.detail.fetchOptions.headers["Overlay-Args"] = args
34
28
  }
35
29
 
36
30
  delete window._overlasticTarget
37
31
  })
32
+
33
+ // When any other element triggers a fetch,
34
+ // send the current overlay's target along with the frame request
35
+ addEventListener("turbo:before-fetch-request", event => {
36
+ if (window._overlasticAnchor) return
37
+
38
+ const frame = event.target.closest("turbo-frame[id^=overlay]")
39
+
40
+ if (frame) {
41
+ const target = frame.dataset.overlayTarget
42
+ const type = frame.dataset?.overlayType
43
+ const args = frame.dataset?.overlayArgs
44
+
45
+ event.detail.fetchOptions.headers["Overlay-Target"] = target
46
+
47
+ if (type) {
48
+ event.detail.fetchOptions.headers["Overlay-Type"] = type
49
+ }
50
+
51
+ if (args) {
52
+ event.detail.fetchOptions.headers["Overlay-Args"] = args
53
+ }
54
+ }
55
+ })
56
+
57
+ // Handle frame-to-visit promotions when the server asks for it
58
+ addEventListener("turbo:before-fetch-response", async event => {
59
+ const fetchResponse = event.detail.fetchResponse
60
+
61
+ if (!fetchResponse.response.headers.has("Overlay-Visit")) return
62
+
63
+ const responseHTML = await fetchResponse.responseHTML
64
+ const { location, redirected, statusCode } = fetchResponse
65
+
66
+ return Turbo.session.visit(location, { response: { redirected, statusCode, responseHTML } })
67
+ })
@@ -1,6 +1,6 @@
1
1
  <% title ||= "" %>
2
2
 
3
- <%= turbo_frame_tag current_overlay_name do %>
3
+ <%= overlastic_tag do %>
4
4
  <overlastic-dialog style="height:100vh;background-color:rgba(107, 114, 128, 0.5);justify-content:center;align-items:center;width: 100vw;display:flex;z-index:50;left:0px;top:0px;position:fixed;box-sizing:border-box;border-width:0px;border-style:solid;border-color:rgb(229, 231, 235);">
5
5
  <div style="width: 50%;justify-content:center;align-items:center;flex-direction:column;max-width:672px;height:662.398px;display:flex;box-sizing:border-box;border-width:0px;border-style:solid;border-color:rgb(229, 231, 235);">
6
6
  <div style="padding-top:32px;padding-bottom:32px;box-shadow:rgba(0, 0, 0, 0) 0px 0px 0px 0px, rgba(0, 0, 0, 0) 0px 0px 0px 0px, rgba(0, 0, 0, 0.1) 0px 4px 6px -1px, rgba(0, 0, 0, 0.1) 0px 2px 4px -2px;background-color:rgb(255, 255, 255);overflow:hidden;box-sizing:border-box;border-width:0px;border-style:solid;border-color:rgb(229, 231, 235);">
@@ -23,6 +23,4 @@
23
23
  </div>
24
24
  </div>
25
25
  </overlastic-dialog>
26
-
27
- <%= turbo_frame_tag next_overlay_name, target: :_top %>
28
26
  <% end %>
@@ -1,4 +1,4 @@
1
- <%= turbo_frame_tag current_overlay_name do %>
1
+ <%= overlastic_tag do %>
2
2
  <overlastic-pane style="background-color:rgba(107, 114, 128, 0.5);justify-content:flex-end;width: 100vw;height:100vh;display:flex;z-index:40;left:0px;top:0px;position:fixed;box-sizing:border-box;border-width:0px;border-style:solid;border-color:rgb(229, 231, 235);">
3
3
  <div style="width: 66.6667%;align-items:flex-end;flex-direction:column;animation:0.2s ease 0s 1 normal both running modal;height:100%;display:flex;box-sizing:border-box;border-width:0px;border-style:solid;border-color:rgb(229, 231, 235);">
4
4
  <div style="box-shadow:rgba(0, 0, 0, 0) 0px 0px 0px 0px, rgba(0, 0, 0, 0) 0px 0px 0px 0px, rgba(0, 0, 0, 0.1) 0px 4px 6px -1px, rgba(0, 0, 0, 0.1) 0px 2px 4px -2px;padding-top:20px;padding-bottom:20px;background-color:rgb(249, 250, 251);border-top-left-radius:8px;border-bottom-left-radius:8px;overflow:hidden;width: 100%;height:100%;box-sizing:border-box;border-width:0px;border-style:solid;border-color:rgb(229, 231, 235);">
@@ -17,6 +17,4 @@
17
17
  </div>
18
18
  </div>
19
19
  </overlastic-pane>
20
-
21
- <%= turbo_frame_tag next_overlay_name, target: :_top %>
22
20
  <% end %>
@@ -1,6 +1,6 @@
1
1
  <% title ||= "" %>
2
2
 
3
- <%= turbo_frame_tag current_overlay_name do %>
3
+ <%= overlastic_tag do %>
4
4
  <overlastic-dialog class="fixed top-0 left-0 z-50 flex justify-center w-screen h-screen-safe items-center bg-gray-500 bg-opacity-50">
5
5
  <div class="w-11/12 sm:w-5/6 lg:w-1/2 max-w-2xl h-[90vh] flex flex-col justify-center items-center">
6
6
  <div class="py-4 sm:py-8 bg-white shadow-md overflow-hidden">
@@ -23,6 +23,4 @@
23
23
  </div>
24
24
  </div>
25
25
  </overlastic-dialog>
26
-
27
- <%= turbo_frame_tag next_overlay_name, target: :_top %>
28
26
  <% end %>
@@ -1,4 +1,4 @@
1
- <%= turbo_frame_tag current_overlay_name do %>
1
+ <%= overlastic_tag do %>
2
2
  <overlastic-pane class="fixed top-0 left-0 z-40 flex justify-end w-screen h-screen bg-gray-500 bg-opacity-50">
3
3
  <div class="w-full sm:w-5/6 lg:w-8/12 h-full flex flex-col items-end animate-modal">
4
4
  <div id="split-container" class="py-5 bg-gray-50 rounded-l-lg shadow-md overflow-hidden w-full h-full">
@@ -17,6 +17,4 @@
17
17
  </div>
18
18
  </div>
19
19
  </overlastic-pane>
20
-
21
- <%= turbo_frame_tag next_overlay_name, target: :_top %>
22
20
  <% end %>
@@ -1,3 +1,3 @@
1
1
  module Overlastic
2
- VERSION = "0.3.0"
2
+ VERSION = "0.4.0"
3
3
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: overlastic
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.3.0
4
+ version: 0.4.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Martin Zamuner
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2022-09-13 00:00:00.000000000 Z
11
+ date: 2022-09-14 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: activejob