toasters.js 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  1. (function webpackUniversalModuleDefinition(root, factory) {
  2. if(typeof exports === 'object' && typeof module === 'object')
  3. module.exports = factory();
  4. else if(typeof define === 'function' && define.amd)
  5. define([], factory);
  6. else if(typeof exports === 'object')
  7. exports["Toast"] = factory();
  8. else
  9. root["Toast"] = factory();
  10. })(window, function() {
  11. return /******/ (function(modules) { // webpackBootstrap
  12. /******/ // The module cache
  13. /******/ var installedModules = {};
  14. /******/
  15. /******/ // The require function
  16. /******/ function __webpack_require__(moduleId) {
  17. /******/
  18. /******/ // Check if module is in cache
  19. /******/ if(installedModules[moduleId]) {
  20. /******/ return installedModules[moduleId].exports;
  21. /******/ }
  22. /******/ // Create a new module (and put it into the cache)
  23. /******/ var module = installedModules[moduleId] = {
  24. /******/ i: moduleId,
  25. /******/ l: false,
  26. /******/ exports: {}
  27. /******/ };
  28. /******/
  29. /******/ // Execute the module function
  30. /******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
  31. /******/
  32. /******/ // Flag the module as loaded
  33. /******/ module.l = true;
  34. /******/
  35. /******/ // Return the exports of the module
  36. /******/ return module.exports;
  37. /******/ }
  38. /******/
  39. /******/
  40. /******/ // expose the modules object (__webpack_modules__)
  41. /******/ __webpack_require__.m = modules;
  42. /******/
  43. /******/ // expose the module cache
  44. /******/ __webpack_require__.c = installedModules;
  45. /******/
  46. /******/ // define getter function for harmony exports
  47. /******/ __webpack_require__.d = function(exports, name, getter) {
  48. /******/ if(!__webpack_require__.o(exports, name)) {
  49. /******/ Object.defineProperty(exports, name, { enumerable: true, get: getter });
  50. /******/ }
  51. /******/ };
  52. /******/
  53. /******/ // define __esModule on exports
  54. /******/ __webpack_require__.r = function(exports) {
  55. /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
  56. /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
  57. /******/ }
  58. /******/ Object.defineProperty(exports, '__esModule', { value: true });
  59. /******/ };
  60. /******/
  61. /******/ // create a fake namespace object
  62. /******/ // mode & 1: value is a module id, require it
  63. /******/ // mode & 2: merge all properties of value into the ns
  64. /******/ // mode & 4: return value when already ns object
  65. /******/ // mode & 8|1: behave like require
  66. /******/ __webpack_require__.t = function(value, mode) {
  67. /******/ if(mode & 1) value = __webpack_require__(value);
  68. /******/ if(mode & 8) return value;
  69. /******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
  70. /******/ var ns = Object.create(null);
  71. /******/ __webpack_require__.r(ns);
  72. /******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value });
  73. /******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
  74. /******/ return ns;
  75. /******/ };
  76. /******/
  77. /******/ // getDefaultExport function for compatibility with non-harmony modules
  78. /******/ __webpack_require__.n = function(module) {
  79. /******/ var getter = module && module.__esModule ?
  80. /******/ function getDefault() { return module['default']; } :
  81. /******/ function getModuleExports() { return module; };
  82. /******/ __webpack_require__.d(getter, 'a', getter);
  83. /******/ return getter;
  84. /******/ };
  85. /******/
  86. /******/ // Object.prototype.hasOwnProperty.call
  87. /******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
  88. /******/
  89. /******/ // __webpack_public_path__
  90. /******/ __webpack_require__.p = "";
  91. /******/
  92. /******/
  93. /******/ // Load entry module and return exports
  94. /******/ return __webpack_require__(__webpack_require__.s = "./src/index.js");
  95. /******/ })
  96. /************************************************************************/
  97. /******/ ({
  98. /***/ "./src/index.js":
  99. /*!**********************!*\
  100. !*** ./src/index.js ***!
  101. \**********************/
  102. /*! exports provided: default */
  103. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  104. "use strict";
  105. eval("__webpack_require__.r(__webpack_exports__);\n/* harmony default export */ __webpack_exports__[\"default\"] = (__webpack_require__(/*! ./toasters */ \"./src/toasters.js\")[\"default\"]);\n\n//# sourceURL=webpack://Toast/./src/index.js?");
  106. /***/ }),
  107. /***/ "./src/toasters.js":
  108. /*!*************************!*\
  109. !*** ./src/toasters.js ***!
  110. \*************************/
  111. /*! exports provided: default */
  112. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  113. "use strict";
  114. eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return Toast; });\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\ndocument.body.style.backgroundColor = \"#eee\";\nvar container = document.getElementById(\"toasts-container\");\nvar incrementer = 0;\n\nvar Toast =\n/*#__PURE__*/\nfunction () {\n // should add type checking\n function Toast(_ref) {\n var content = _ref.content,\n persistant = _ref.persistant,\n timeout = _ref.timeout,\n position = _ref.position;\n\n _classCallCheck(this, Toast);\n\n this.identifier = \"toast-\".concat(incrementer);\n incrementer++;\n this.visible = false;\n this.position = position;\n this.content = content;\n this.persistant = persistant;\n this.timeout = timeout;\n if (!this.persistant) this.startTimer();\n this.dragListener();\n }\n\n _createClass(Toast, [{\n key: \"startTimer\",\n value: function startTimer() {\n setTimeout(this.clear.bind(this), this.timeout);\n }\n }, {\n key: \"display\",\n value: function display() {\n if (!this.visible) {\n container.insertAdjacentHTML(\"beforeend\", \"<div class=\\\"toast \".concat(this.identifier, \" toast-\").concat(this.position.horizontal, \" toast-\").concat(this.position.vertical, \"\\\">\").concat(this.content, \"</div>\"));\n this.find();\n } else this.element.innerHTML = this.content;\n\n this.visible = true;\n }\n }, {\n key: \"dragListener\",\n value: function dragListener() {\n var _this = this;\n\n this.element.addEventListener(\"mousedown\", function (event) {\n var shiftX = event.clientX - _this.element.getBoundingClientRect().x;\n\n var move = function move(_ref2) {\n var pageX = _ref2.pageX;\n console.log(pageX - shiftX);\n _this.element.style.transform = \"translateX(\".concat(pageX - shiftX, \"px)\");\n };\n\n window.addEventListener(\"mousemove\", move, false);\n window.addEventListener(\"mouseup\", function () {\n window.removeEventListener(\"mousemove\", move, false);\n }, false);\n }, false);\n }\n }, {\n key: \"find\",\n value: function find() {\n for (var i = 0; i < container.childNodes.length; i++) {\n if (container.childNodes[i].classList.contains(this.identifier)) return this.element = container.childNodes[i];\n }\n }\n }, {\n key: \"clear\",\n value: function clear() {\n this.element.remove();\n }\n }, {\n key: \"content\",\n get: function get() {\n return this._content;\n },\n set: function set(value) {\n this._content = value;\n this.display();\n }\n }]);\n\n return Toast;\n}();\n\n\nvar red = new Toast({\n content: \"ALWAYS RED\",\n persistant: true,\n position: {\n horizontal: \"left\",\n vertical: \"top\"\n }\n});\n\n//# sourceURL=webpack://Toast/./src/toasters.js?");
  115. /***/ })
  116. /******/ });
  117. });