From 7315a544689211f6054f6ff411702cb3c6516531 Mon Sep 17 00:00:00 2001 From: Steven D Vachon Date: Tue, 8 Aug 2017 14:20:43 -0400 Subject: [PATCH] Add support for loading before DOMContentLoaded fixes #33 --- date-input-polyfill.js | 25 +++++++++++++++---------- input.js | 9 ++++++++- picker.js | 9 +-------- 3 files changed, 24 insertions(+), 19 deletions(-) diff --git a/date-input-polyfill.js b/date-input-polyfill.js index f6ec649..c67fb19 100644 --- a/date-input-polyfill.js +++ b/date-input-polyfill.js @@ -9,15 +9,20 @@ const addPickers = () => { } }; -// Run the above code on any in the document, also on dynamically created ones. -addPickers(); - -document.addEventListener(`DOMContentLoaded`, () => { +const init = () => { + // Run the above code on any in the document, also on dynamically created ones. addPickers(); -}); + // This is also on mousedown event so it will capture new inputs that might + // be added to the DOM dynamically. + document.querySelector(`body`).addEventListener(`mousedown`, () => { + addPickers(); + }); +}; -// This is also on mousedown event so it will capture new inputs that might -// be added to the DOM dynamically. -document.querySelector(`body`).addEventListener(`mousedown`, () => { - addPickers(); -}); +if (document.readyState !== `loading`) { + init(); +} else { + document.addEventListener(`DOMContentLoaded`, () => { + init(); + }); +} diff --git a/input.js b/input.js index e2f8f15..61474e2 100644 --- a/input.js +++ b/input.js @@ -1,9 +1,16 @@ -import thePicker from './picker.js'; import locales from './locales.js'; import dateFormat from './dateformat.js'; +import Picker from './picker.js'; + +// This is a singleton. +let thePicker; export default class Input { constructor(input) { + if (!thePicker) { + thePicker = new Picker(); + } + this.element = input; this.element.setAttribute(`data-has-picker`, ``); diff --git a/picker.js b/picker.js index 293ac34..896e02c 100644 --- a/picker.js +++ b/picker.js @@ -1,10 +1,5 @@ class Picker { constructor() { - // This is a singleton. - if(window.thePicker) { - return window.thePicker; - } - this.date = new Date(); this.input = null; this.isOpen = false; @@ -329,6 +324,4 @@ class Picker { } } -window.thePicker = new Picker(); - -export default window.thePicker; +export default Picker;