/home/smartbloks/www/help.smartbloks.ai/wp-content/themes/docly/assets/vendors/dark/darkmode-js.js
(function webpackUniversalModuleDefinition(root, factory) {
if(typeof exports === 'object' && typeof module === 'object')
module.exports = factory();
else if(typeof define === 'function' && define.amd)
define("darkmode-js", [], factory);
else if(typeof exports === 'object')
exports["darkmode-js"] = factory();
else
root["darkmode-js"] = factory();
})(typeof self !== 'undefined' ? self : this, function() {
return /******/ (function(modules) { // webpackBootstrap
/******/ // The module cache
/******/ var installedModules = {};
/******/
/******/ // The require function
/******/ function __webpack_require__(moduleId) {
/******/
/******/ // Check if module is in cache
/******/ if(installedModules[moduleId]) {
/******/ return installedModules[moduleId].exports;
/******/ }
/******/ // Create a new module (and put it into the cache)
/******/ var module = installedModules[moduleId] = {
/******/ i: moduleId,
/******/ l: false,
/******/ exports: {}
/******/ };
/******/
/******/ // Execute the module function
/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
/******/
/******/ // Flag the module as loaded
/******/ module.l = true;
/******/
/******/ // Return the exports of the module
/******/ return module.exports;
/******/ }
/******/
/******/
/******/ // expose the modules object (__webpack_modules__)
/******/ __webpack_require__.m = modules;
/******/
/******/ // expose the module cache
/******/ __webpack_require__.c = installedModules;
/******/
/******/ // define getter function for harmony exports
/******/ __webpack_require__.d = function(exports, name, getter) {
/******/ if(!__webpack_require__.o(exports, name)) {
/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter });
/******/ }
/******/ };
/******/
/******/ // define __esModule on exports
/******/ __webpack_require__.r = function(exports) {
/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
/******/ }
/******/ Object.defineProperty(exports, '__esModule', { value: true });
/******/ };
/******/
/******/ // create a fake namespace object
/******/ // mode & 1: value is a module id, require it
/******/ // mode & 2: merge all properties of value into the ns
/******/ // mode & 4: return value when already ns object
/******/ // mode & 8|1: behave like require
/******/ __webpack_require__.t = function(value, mode) {
/******/ if(mode & 1) value = __webpack_require__(value);
/******/ if(mode & 8) return value;
/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
/******/ var ns = Object.create(null);
/******/ __webpack_require__.r(ns);
/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value });
/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
/******/ return ns;
/******/ };
/******/
/******/ // getDefaultExport function for compatibility with non-harmony modules
/******/ __webpack_require__.n = function(module) {
/******/ var getter = module && module.__esModule ?
/******/ function getDefault() { return module['default']; } :
/******/ function getModuleExports() { return module; };
/******/ __webpack_require__.d(getter, 'a', getter);
/******/ return getter;
/******/ };
/******/
/******/ // Object.prototype.hasOwnProperty.call
/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
/******/
/******/ // __webpack_public_path__
/******/ __webpack_require__.p = "";
/******/
/******/
/******/ // Load entry module and return exports
/******/ return __webpack_require__(__webpack_require__.s = "./src/index.js");
/******/ })
/************************************************************************/
/******/ ({
/***/ "./src/darkmode.js":
/*!*************************!*\
!*** ./src/darkmode.js ***!
\*************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = exports.IS_BROWSER = void 0;
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
function _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); } }
function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
var IS_BROWSER = typeof window !== 'undefined';
exports.IS_BROWSER = IS_BROWSER;
var Darkmode =
/*#__PURE__*/
function () {
function Darkmode(options) {
_classCallCheck(this, Darkmode);
if (!IS_BROWSER) {
return;
}
var defaultOptions = {
bottom: '32px',
right: '32px',
left: 'unset',
time: '0.3s',
mixColor: '#fff',
backgroundColor: '#fff',
buttonColorDark: '#fff',
buttonColorLight: '#100f2c',
label: '',
saveInCookies: false,
autoMatchOsTheme: true
};
options = Object.assign({}, defaultOptions, options);
var css = "\n .darkmode-layer {\n position: fixed;\n pointer-events: none;\n background: ".concat(options.mixColor, ";\n transition: all ").concat(options.time, " ease;\n mix-blend-mode: difference;\n }\n\n .darkmode-layer--button {\n width: 2.9rem;\n height: 2.9rem;\n border-radius: 50%;\n right: ").concat(options.right, ";\n bottom: ").concat(options.bottom, ";\n left: ").concat(options.left, ";\n }\n\n .darkmode-layer--simple {\n width: 100%;\n height: 100%;\n top: 0;\n left: 0;\n transform: scale(1) !important;\n }\n\n .darkmode-layer--expanded {\n transform: scale(100);\n border-radius: 0;\n }\n\n .darkmode-layer--no-transition {\n transition: none;\n }\n\n .darkmode-toggle {\n background: ").concat(options.buttonColorDark, ";\n width: 3rem;\n height: 3rem;\n position: fixed;\n border-radius: 50%;\n right: ").concat(options.right, ";\n bottom: ").concat(options.bottom, ";\n left: ").concat(options.left, ";\n cursor: pointer;\n transition: all 0.5s ease;\n display: flex;\n justify-content: center;\n align-items: center;\n }\n\n .darkmode-toggle--white {\n background: ").concat(options.buttonColorLight, ";\n }\n\n .darkmode-background {\n background: ").concat(options.backgroundColor, ";\n position: fixed;\n pointer-events: none;\n z-index: -10;\n width: 100%;\n height: 100%;\n top: 0;\n left: 0;\n }\n\n img, .darkmode-ignore {\n isolation: isolate;\n display: inline-block;\n }\n\n @media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {\n .darkmode-toggle {display: none !important}\n }\n\n @supports (-ms-ime-align:auto), (-ms-accelerator:true) {\n .darkmode-toggle {display: none !important}\n }\n ");
var layer = document.createElement('div');
var button = document.createElement('div');
var background = document.createElement('div');
button.innerHTML = options.label;
layer.classList.add('darkmode-layer');
background.classList.add('darkmode-background');
var darkmodeActivated = window.localStorage.getItem('darkmode') === 'true';
var preferedThemeOs = options.autoMatchOsTheme && window.matchMedia('(prefers-color-scheme: dark)').matches;
var darkmodeNeverActivatedByAction = window.localStorage.getItem('darkmode') === null;
if (darkmodeActivated === true && options.saveInCookies || darkmodeNeverActivatedByAction && preferedThemeOs) {
layer.classList.add('darkmode-layer--expanded', 'darkmode-layer--simple', 'darkmode-layer--no-transition');
button.classList.add('darkmode-toggle--white');
document.body.classList.add('darkmode--activated');
}
document.body.insertBefore(button, document.body.firstChild);
document.body.insertBefore(layer, document.body.firstChild);
document.body.insertBefore(background, document.body.firstChild);
this.addStyle(css);
this.button = button;
this.layer = layer;
this.saveInCookies = options.saveInCookies;
this.time = options.time;
}
_createClass(Darkmode, [{
key: "addStyle",
value: function addStyle(css) {
var linkElement = document.createElement('link');
linkElement.setAttribute('rel', 'stylesheet');
linkElement.setAttribute('type', 'text/css');
linkElement.setAttribute('href', 'data:text/css;charset=UTF-8,' + encodeURIComponent(css));
document.head.appendChild(linkElement);
}
}, {
key: "showWidget",
value: function showWidget() {
var _this = this;
if (!IS_BROWSER) {
return;
}
var button = this.button;
var layer = this.layer;
var time = parseFloat(this.time) * 1000;
button.classList.add('darkmode-toggle');
layer.classList.add('darkmode-layer--button');
button.addEventListener('click', function () {
var isDarkmode = _this.isActivated();
if (!isDarkmode) {
layer.classList.add('darkmode-layer--expanded');
setTimeout(function () {
layer.classList.add('darkmode-layer--no-transition');
layer.classList.add('darkmode-layer--simple');
}, time);
} else {
layer.classList.remove('darkmode-layer--simple');
setTimeout(function () {
layer.classList.remove('darkmode-layer--no-transition');
layer.classList.remove('darkmode-layer--expanded');
}, 1);
}
button.classList.toggle('darkmode-toggle--white');
document.body.classList.toggle('darkmode--activated');
window.localStorage.setItem('darkmode', !isDarkmode);
});
}
}, {
key: "toggle",
value: function toggle() {
if (!IS_BROWSER) {
return;
}
var layer = this.layer;
var isDarkmode = this.isActivated();
layer.classList.toggle('darkmode-layer--simple');
document.body.classList.toggle('darkmode--activated');
window.localStorage.setItem('darkmode', !isDarkmode);
}
}, {
key: "isActivated",
value: function isActivated() {
if (!IS_BROWSER) {
return null;
}
return document.body.classList.contains('darkmode--activated');
}
}]);
return Darkmode;
}();
exports.default = Darkmode;
/***/ }),
/***/ "./src/index.js":
/*!**********************!*\
!*** ./src/index.js ***!
\**********************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _darkmode = _interopRequireWildcard(__webpack_require__(/*! ./darkmode */ "./src/darkmode.js"));
function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = Object.defineProperty && Object.getOwnPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : {}; if (desc.get || desc.set) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } } newObj.default = obj; return newObj; } }
var _default = _darkmode.default;
/* eslint-disable */
exports.default = _default;
if (_darkmode.IS_BROWSER) {
(function (window) {
window.Darkmode = _darkmode.default;
})(window);
}
/* eslint-enable */
module.exports = exports["default"];
/***/ })
/******/ });
});
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://darkmode-js/webpack/universalModuleDefinition","webpack://darkmode-js/webpack/bootstrap","webpack://darkmode-js/./src/darkmode.js","webpack://darkmode-js/./src/index.js"],"names":["IS_BROWSER","window","Darkmode","options","defaultOptions","bottom","right","left","time","mixColor","backgroundColor","buttonColorDark","buttonColorLight","label","saveInCookies","autoMatchOsTheme","Object","assign","css","layer","document","createElement","button","background","innerHTML","classList","add","darkmodeActivated","localStorage","getItem","preferedThemeOs","matchMedia","matches","darkmodeNeverActivatedByAction","body","insertBefore","firstChild","addStyle","linkElement","setAttribute","encodeURIComponent","head","appendChild","parseFloat","addEventListener","isDarkmode","isActivated","setTimeout","remove","toggle","setItem","contains"],"mappings":"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","file":"darkmode-js.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine(\"darkmode-js\", [], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"darkmode-js\"] = factory();\n\telse\n\t\troot[\"darkmode-js\"] = factory();\n})(typeof self !== 'undefined' ? self : this, function() {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = \"./src/index.js\");\n","export const IS_BROWSER = typeof window !== 'undefined';\r\n\r\nexport default class Darkmode {\r\n  constructor(options) {\r\n    if (!IS_BROWSER) {\r\n      return;\r\n    }\r\n\r\n    const defaultOptions = {\r\n      bottom: '32px',\r\n      right: '32px',\r\n      left: 'unset',\r\n      time: '0.3s',\r\n      mixColor: '#fff',\r\n      backgroundColor: '#fff',\r\n      buttonColorDark: '#fff',\r\n      buttonColorLight: '#100f2c',\r\n      label: '',\r\n      saveInCookies: false,\r\n      autoMatchOsTheme: true\r\n    };\r\n\r\n    options = Object.assign({}, defaultOptions, options);\r\n\r\n    const css = `\r\n      .darkmode-layer {\r\n        position: fixed;\r\n        pointer-events: none;\r\n        background: ${options.mixColor};\r\n        transition: all ${options.time} ease;\r\n        mix-blend-mode: difference;\r\n      }\r\n\r\n      .darkmode-layer--button {\r\n        width: 2.9rem;\r\n        height: 2.9rem;\r\n        border-radius: 50%;\r\n        right: ${options.right};\r\n        bottom: ${options.bottom};\r\n        left: ${options.left};\r\n      }\r\n\r\n      .darkmode-layer--simple {\r\n        width: 100%;\r\n        height: 100%;\r\n        top: 0;\r\n        left: 0;\r\n        transform: scale(1) !important;\r\n      }\r\n\r\n      .darkmode-layer--expanded {\r\n        transform: scale(100);\r\n        border-radius: 0;\r\n      }\r\n\r\n      .darkmode-layer--no-transition {\r\n        transition: none;\r\n      }\r\n\r\n      .darkmode-toggle {\r\n        background: ${options.buttonColorDark};\r\n        width: 3rem;\r\n        height: 3rem;\r\n        position: fixed;\r\n        border-radius: 50%;\r\n        right: ${options.right};\r\n        bottom: ${options.bottom};\r\n        left: ${options.left};\r\n        cursor: pointer;\r\n        transition: all 0.5s ease;\r\n        display: flex;\r\n        justify-content: center;\r\n        align-items: center;\r\n      }\r\n\r\n      .darkmode-toggle--white {\r\n        background: ${options.buttonColorLight};\r\n      }\r\n\r\n      .darkmode-background {\r\n        background: ${options.backgroundColor};\r\n        position: fixed;\r\n        pointer-events: none;\r\n        z-index: -10;\r\n        width: 100%;\r\n        height: 100%;\r\n        top: 0;\r\n        left: 0;\r\n      }\r\n\r\n      img, .darkmode-ignore {\r\n        isolation: isolate;\r\n        display: inline-block;\r\n      }\r\n\r\n      @media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {\r\n        .darkmode-toggle {display: none !important}\r\n      }\r\n\r\n      @supports (-ms-ime-align:auto), (-ms-accelerator:true) {\r\n        .darkmode-toggle {display: none !important}\r\n      }\r\n    `;\r\n\r\n    const layer = document.createElement('div');\r\n    const button = document.createElement('div');\r\n    const background = document.createElement('div');\r\n\r\n    button.innerHTML = options.label;\r\n    layer.classList.add('darkmode-layer');\r\n    background.classList.add('darkmode-background');\r\n\r\n    const darkmodeActivated =\r\n      window.localStorage.getItem('darkmode') === 'true';\r\n    const preferedThemeOs =\r\n      options.autoMatchOsTheme &&\r\n      window.matchMedia('(prefers-color-scheme: dark)').matches;\r\n    const darkmodeNeverActivatedByAction =\r\n      window.localStorage.getItem('darkmode') === null;\r\n\r\n    if (\r\n      (darkmodeActivated === true && options.saveInCookies) ||\r\n      (darkmodeNeverActivatedByAction && preferedThemeOs)\r\n    ) {\r\n      layer.classList.add(\r\n        'darkmode-layer--expanded',\r\n        'darkmode-layer--simple',\r\n        'darkmode-layer--no-transition'\r\n      );\r\n      button.classList.add('darkmode-toggle--white');\r\n      document.body.classList.add('darkmode--activated');\r\n    }\r\n\r\n    document.body.insertBefore(button, document.body.firstChild);\r\n    document.body.insertBefore(layer, document.body.firstChild);\r\n    document.body.insertBefore(background, document.body.firstChild);\r\n\r\n    this.addStyle(css);\r\n\r\n    this.button = button;\r\n    this.layer = layer;\r\n    this.saveInCookies = options.saveInCookies;\r\n    this.time = options.time;\r\n  }\r\n\r\n  addStyle(css) {\r\n    const linkElement = document.createElement('link');\r\n\r\n    linkElement.setAttribute('rel', 'stylesheet');\r\n    linkElement.setAttribute('type', 'text/css');\r\n    linkElement.setAttribute(\r\n      'href',\r\n      'data:text/css;charset=UTF-8,' + encodeURIComponent(css)\r\n    );\r\n    document.head.appendChild(linkElement);\r\n  }\r\n\r\n  showWidget() {\r\n    if (!IS_BROWSER) {\r\n      return;\r\n    }\r\n    const button = this.button;\r\n    const layer = this.layer;\r\n    const time = parseFloat(this.time) * 1000;\r\n\r\n    button.classList.add('darkmode-toggle');\r\n    layer.classList.add('darkmode-layer--button');\r\n\r\n    button.addEventListener('click', () => {\r\n      const isDarkmode = this.isActivated();\r\n\r\n      if (!isDarkmode) {\r\n        layer.classList.add('darkmode-layer--expanded');\r\n        setTimeout(() => {\r\n          layer.classList.add('darkmode-layer--no-transition');\r\n          layer.classList.add('darkmode-layer--simple');\r\n        }, time);\r\n      } else {\r\n        layer.classList.remove('darkmode-layer--simple');\r\n        setTimeout(() => {\r\n          layer.classList.remove('darkmode-layer--no-transition');\r\n          layer.classList.remove('darkmode-layer--expanded');\r\n        }, 1);\r\n      }\r\n\r\n      button.classList.toggle('darkmode-toggle--white');\r\n      document.body.classList.toggle('darkmode--activated');\r\n      window.localStorage.setItem('darkmode', !isDarkmode);\r\n    });\r\n  }\r\n\r\n  toggle() {\r\n    if (!IS_BROWSER) {\r\n      return;\r\n    }\r\n    const layer = this.layer;\r\n    const isDarkmode = this.isActivated();\r\n\r\n    layer.classList.toggle('darkmode-layer--simple');\r\n    document.body.classList.toggle('darkmode--activated');\r\n    window.localStorage.setItem('darkmode', !isDarkmode);\r\n  }\r\n\r\n  isActivated() {\r\n    if (!IS_BROWSER) {\r\n      return null;\r\n    }\r\n    return document.body.classList.contains('darkmode--activated');\r\n  }\r\n}\r\n","import Darkmode, { IS_BROWSER } from './darkmode';\r\nexport default Darkmode;\r\n\r\n/* eslint-disable */\r\nif (IS_BROWSER) {\r\n  (function(window) {\r\n    window.Darkmode = Darkmode;\r\n  })(window);\r\n}\r\n/* eslint-enable */\r\n"],"sourceRoot":""}