UNPKG

@gov.au/pancake

Version:

Pancake is an utility to make working with npm modules for the frontend sweet and seamlessly.

241 lines (182 loc) 7.9 kB
/*************************************************************************************************************************************************************** * * Get and set global/local settings * * @repo - https://github.com/govau/pancake * @author - Dominik Wilkowski * @license - https://raw.githubusercontent.com/govau/pancake/master/LICENSE (MIT) * **************************************************************************************************************************************************************/ 'use strict'; //-------------------------------------------------------------------------------------------------------------------------------------------------------------- // Dependencies //-------------------------------------------------------------------------------------------------------------------------------------------------------------- Object.defineProperty(exports, "__esModule", { value: true }); exports.Settings = undefined; var _promise = require('babel-runtime/core-js/promise'); var _promise2 = _interopRequireDefault(_promise); var _toConsumableArray2 = require('babel-runtime/helpers/toConsumableArray'); var _toConsumableArray3 = _interopRequireDefault(_toConsumableArray2); var _typeof2 = require('babel-runtime/helpers/typeof'); var _typeof3 = _interopRequireDefault(_typeof2); var _assign = require('babel-runtime/core-js/object/assign'); var _assign2 = _interopRequireDefault(_assign); var _stringify = require('babel-runtime/core-js/json/stringify'); var _stringify2 = _interopRequireDefault(_stringify); var _path = require('path'); var _path2 = _interopRequireDefault(_path); var _fs = require('fs'); var _fs2 = _interopRequireDefault(_fs); var _logging = require('./logging'); var _files = require('./files'); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } //-------------------------------------------------------------------------------------------------------------------------------------------------------------- // Default export //-------------------------------------------------------------------------------------------------------------------------------------------------------------- /** * Finding the right folder in which to run npm prefix * * @return {string} - The absolute path to the folder of your host package.json */ //-------------------------------------------------------------------------------------------------------------------------------------------------------------- // Included modules //-------------------------------------------------------------------------------------------------------------------------------------------------------------- var Settings = exports.Settings = { /** * Getting global setting from the settings.json file * * @return {object} - The settings object */ GetGlobal: function GetGlobal() { var root = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : __dirname; _logging.Log.verbose('Getting global settings from ' + _logging.Style.yellow(_path2.default.normalize(root + '/../settings.json'))); var SETTINGS = {}; try { SETTINGS = JSON.parse(_fs2.default.readFileSync(_path2.default.normalize(root + '/../settings.json'), 'utf8')); } catch (error) { _logging.Log.error('Couldn\u2019t read global settings :('); _logging.Log.space(); process.exit(1); } _logging.Log.verbose(_logging.Style.yellow((0, _stringify2.default)(SETTINGS))); return SETTINGS; }, /** * Getting local setting from the host package.json file * * @param {string} cwd - The path to our host package.json * * @return {object} - The settings object */ GetLocal: function GetLocal(cwd) { _logging.Log.verbose('Getting local settings'); var SETTINGS = {}; try { SETTINGS = JSON.parse(_fs2.default.readFileSync(_path2.default.normalize(cwd + '/package.json'), 'utf8')); } catch (error) { _logging.Log.error('Couldn\u2019t read local settings :('); _logging.Log.error('Make sure you have a package.json file availabe in the root of your project.'); _logging.Log.error(error); _logging.Log.space(); process.exit(1); } if (SETTINGS.pancake === undefined) { SETTINGS.pancake = {}; } //default settings var defaultSettings = { 'auto-save': true, plugins: true, ignore: [] //merging default settings with local package.json };SETTINGS.pancake = (0, _assign2.default)(defaultSettings, SETTINGS.pancake); _logging.Log.verbose(_logging.Style.yellow((0, _stringify2.default)(SETTINGS.pancake))); return SETTINGS.pancake; }, /** * Writing new global settings to the settings.json file * * @param {object} SETTINGS - The settings object so we don’t have to read it twice * @param {array} items - The setting to be changed, first item is the name and the following the values * * @return {object} - The settings object with the new setting */ SetGlobal: function SetGlobal(root, SETTINGS) { for (var _len = arguments.length, items = Array(_len > 2 ? _len - 2 : 0), _key = 2; _key < _len; _key++) { items[_key - 2] = arguments[_key]; } _logging.Log.info('PANCAKE SAVING DEFAULT SETTING'); var setting = items[0]; var value = items.splice(1); if (SETTINGS[setting] !== undefined) { //setting new value if ((0, _typeof3.default)(SETTINGS[setting]) === 'object') { var _SETTINGS$setting; (_SETTINGS$setting = SETTINGS[setting]).push.apply(_SETTINGS$setting, (0, _toConsumableArray3.default)(value)); } if (typeof SETTINGS[setting] === 'boolean') { SETTINGS[setting] = value === "true"; } if (typeof SETTINGS[setting] === 'string') { SETTINGS[setting] = value.toString(); } try { _fs2.default.writeFileSync(_path2.default.normalize(root + '/../settings.json'), (0, _stringify2.default)(SETTINGS, null, '\t'), 'utf8'); _logging.Log.ok('Value for ' + _logging.Style.yellow(setting) + ' saved'); } catch (error) { _logging.Log.error('Saving settings failed'); _logging.Log.error(error); } } else { _logging.Log.error('Setting ' + _logging.Style.yellow(setting) + ' not found'); } }, /** * Writing local settings to the package.json file * * @param {object} SETTINGS - The settings object to be written * @param {string} pkgPath - The path to the package.json file * * @return {Promise object} - The settings object with the new setting */ SetLocal: function SetLocal(SETTINGS, pkgPath) { _logging.Log.info('PANCAKE SAVING LOCAL SETTINGS'); return new _promise2.default(function (resolve, reject) { var PackagePath = _path2.default.normalize(pkgPath + '/package.json'); var PKGsource = void 0; var PKG = void 0; try { PKGsource = _fs2.default.readFileSync(PackagePath, 'utf8'); PKG = JSON.parse(PKGsource); _logging.Log.verbose('Read settings at ' + _logging.Style.yellow(PackagePath)); } catch (error) { _logging.Log.verbose('No package.json found at ' + _logging.Style.yellow(PackagePath)); } //only save stuff if we have a package.json file to write to if (PKGsource.length > 0) { //detect indentation var _isSpaces = void 0; var indentation = 2; //default indentation even though you all should be using tabs for indentation! try { var PKGlines = PKGsource.split('\n'); _isSpaces = PKGlines[1].startsWith(' '); } catch (error) { _isSpaces = true; //buuuhhhhhh 👎 } if (!_isSpaces) { indentation = '\t'; //here we go! } PKG.pancake = SETTINGS; //set our settings (0, _files.WriteFile)(PackagePath, (0, _stringify2.default)(PKG, null, indentation)) //write to package.json .catch(function (error) { _logging.Log.error(error); reject(error); }).then(function (written) { resolve(SETTINGS); }); } }); } };