/* * ThemeUtils.js * * Copyright © 2017 Antergos Developers * * This file is part of Web Greeter. * * Web Greeter is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 3 of the License, or * (at your option) any later version. * * Web Greeter is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * The following additional terms are in effect as per Section 7 of the license: * * The preservation of all legal notices and author attributions in * the material or in the Appropriate Legal Notices displayed * by works containing it is required. * * You should have received a copy of the GNU General Public License * along with web-greeter; If not, see . */ let time_language = null, _ThemeUtils = null; /** * Provides various utility methods for use in greeter themes. The greeter will automatically * create an instance of this class when it starts. The instance can be accessed * with the global variable: [`theme_utils`](#dl-window-theme_utils). * * @memberOf LightDM */ class ThemeUtils { constructor(instance) { if (null !== _ThemeUtils) { return _ThemeUtils; } _ThemeUtils = instance; } /** * Binds `this` to class, `context`, for all of the class's methods. * * @arg {object} context An ES6 class instance with at least one method. * * @return {object} `context` with `this` bound to it for all of its methods. */ bind_this(context) { let excluded_methods = ["constructor"]; function not_excluded(_method, _context) { let is_excluded = excluded_methods.findIndex((excluded_method) => _method === excluded_method) > -1, is_method = "function" === typeof _context[_method]; return is_method && !is_excluded; } for (let obj = context; obj; obj = Object.getPrototypeOf(obj)) { // Stop once we have traveled all the way up the inheritance chain if ("Object" === obj.constructor.name) { break; } for (let method of Object.getOwnPropertyNames(obj)) { if (not_excluded(method, context)) { context[method] = context[method].bind(context); } } } return context; } /** * Returns the contents of directory found at `path` provided that the (normalized) `path` * meets at least one of the following conditions: * * Is located within the greeter themes' root directory. * * Has been explicitly allowed in the greeter's config file. * * Is located within the greeter's shared data directory (`/var/lib/lightdm-data`). * * Is located in `/tmp`. * * @param {string} path The abs path to desired directory. * @param {boolean} only_images Include only images in the results. Default `true`. * @param {function(string[])} callback Callback function to be called with the result. */ dirlist(path, only_images = true, callback) { if ("" === path || "string" !== typeof path) { console.error(`theme_utils.dirlist(): path must be a non-empty string!`); return callback([]); } else if (null !== path.match(/^[^/].+/)) { return _ThemeUtils.dirlist(path, only_images, callback); } if (null !== path.match(/\/\.+(?=\/)/)) { // No special directory names allowed (eg ../../) path = path.replace(/\/\.+(?=\/)/g, ""); } try { return _ThemeUtils.dirlist(path, only_images, callback); } catch (err) { console.error(`theme_utils.dirlist(): ${err}`); return callback([]); } } /** * Get the current date in a localized format. Local language is autodetected by default, but can be set manually in the greeter config file. * * `language` defaults to the system's language, but can be set manually in the config file. * * @returns {Object} The current date. */ get_current_localized_date() { let config = greeter_config.greeter; var locale = []; if (time_language === null) { time_language = config.time_language || ""; } if (time_language != "") { locale.push(time_language); } let optionsDate = { day: "2-digit", month: "2-digit", year: "2-digit" }; let fmtDate = Intl.DateTimeFormat(locale, optionsDate); let now = new Date(); var date = fmtDate.format(now); return date; } /** * Get the current time in a localized format. Local language is autodetected by default, but can be set manually in the greeter config file. * * `language` defaults to the system's language, but can be set manually in the config file. * * @returns {Object} The current time. */ get_current_localized_time() { let config = greeter_config.greeter; var locale = []; if (time_language === null) { time_language = config.time_language || ""; } if (time_language != "") { locale.push(time_language); } let optionsTime = { hour: "2-digit", minute: "2-digit" }; let fmtTime = Intl.DateTimeFormat(locale, optionsTime); let now = new Date(); var time = fmtTime.format(now); return time; } }