You cannot select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
	
	
		
			121 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			JavaScript
		
	
			
		
		
	
	
			121 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			JavaScript
		
	
| "use strict";
 | |
| Object.defineProperty(exports, "__esModule", {
 | |
|     value: true
 | |
| });
 | |
| Object.defineProperty(exports, "default", {
 | |
|     enumerable: true,
 | |
|     get: function() {
 | |
|         return createSpinner;
 | |
|     }
 | |
| });
 | |
| const _ora = /*#__PURE__*/ _interop_require_default(require("next/dist/compiled/ora"));
 | |
| const _log = /*#__PURE__*/ _interop_require_wildcard(require("./output/log"));
 | |
| function _interop_require_default(obj) {
 | |
|     return obj && obj.__esModule ? obj : {
 | |
|         default: obj
 | |
|     };
 | |
| }
 | |
| function _getRequireWildcardCache(nodeInterop) {
 | |
|     if (typeof WeakMap !== "function") return null;
 | |
|     var cacheBabelInterop = new WeakMap();
 | |
|     var cacheNodeInterop = new WeakMap();
 | |
|     return (_getRequireWildcardCache = function(nodeInterop) {
 | |
|         return nodeInterop ? cacheNodeInterop : cacheBabelInterop;
 | |
|     })(nodeInterop);
 | |
| }
 | |
| function _interop_require_wildcard(obj, nodeInterop) {
 | |
|     if (!nodeInterop && obj && obj.__esModule) {
 | |
|         return obj;
 | |
|     }
 | |
|     if (obj === null || typeof obj !== "object" && typeof obj !== "function") {
 | |
|         return {
 | |
|             default: obj
 | |
|         };
 | |
|     }
 | |
|     var cache = _getRequireWildcardCache(nodeInterop);
 | |
|     if (cache && cache.has(obj)) {
 | |
|         return cache.get(obj);
 | |
|     }
 | |
|     var newObj = {};
 | |
|     var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor;
 | |
|     for(var key in obj){
 | |
|         if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) {
 | |
|             var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null;
 | |
|             if (desc && (desc.get || desc.set)) {
 | |
|                 Object.defineProperty(newObj, key, desc);
 | |
|             } else {
 | |
|                 newObj[key] = obj[key];
 | |
|             }
 | |
|         }
 | |
|     }
 | |
|     newObj.default = obj;
 | |
|     if (cache) {
 | |
|         cache.set(obj, newObj);
 | |
|     }
 | |
|     return newObj;
 | |
| }
 | |
| const dotsSpinner = {
 | |
|     frames: [
 | |
|         ".",
 | |
|         "..",
 | |
|         "..."
 | |
|     ],
 | |
|     interval: 200
 | |
| };
 | |
| function createSpinner(text, options = {}, logFn = console.log) {
 | |
|     let spinner;
 | |
|     const prefixText = ` ${_log.prefixes.info} ${text} `;
 | |
|     // Add \r at beginning to reset the current line of loading status text
 | |
|     const suffixText = `\r ${_log.prefixes.event} ${text} `;
 | |
|     if (process.stdout.isTTY) {
 | |
|         spinner = (0, _ora.default)({
 | |
|             text: undefined,
 | |
|             prefixText,
 | |
|             spinner: dotsSpinner,
 | |
|             stream: process.stdout,
 | |
|             ...options
 | |
|         }).start();
 | |
|         // Add capturing of console.log/warn/error to allow pausing
 | |
|         // the spinner before logging and then restarting spinner after
 | |
|         const origLog = console.log;
 | |
|         const origWarn = console.warn;
 | |
|         const origError = console.error;
 | |
|         const origStop = spinner.stop.bind(spinner);
 | |
|         const origStopAndPersist = spinner.stopAndPersist.bind(spinner);
 | |
|         const logHandle = (method, args)=>{
 | |
|             origStop();
 | |
|             method(...args);
 | |
|             spinner.start();
 | |
|         };
 | |
|         console.log = (...args)=>logHandle(origLog, args);
 | |
|         console.warn = (...args)=>logHandle(origWarn, args);
 | |
|         console.error = (...args)=>logHandle(origError, args);
 | |
|         const resetLog = ()=>{
 | |
|             console.log = origLog;
 | |
|             console.warn = origWarn;
 | |
|             console.error = origError;
 | |
|         };
 | |
|         spinner.stop = ()=>{
 | |
|             origStop();
 | |
|             resetLog();
 | |
|             return spinner;
 | |
|         };
 | |
|         spinner.stopAndPersist = ()=>{
 | |
|             if (suffixText) {
 | |
|                 if (spinner) {
 | |
|                     spinner.text = suffixText;
 | |
|                 } else {
 | |
|                     logFn(suffixText);
 | |
|                 }
 | |
|             }
 | |
|             origStopAndPersist();
 | |
|             resetLog();
 | |
|             return spinner;
 | |
|         };
 | |
|     } else if (prefixText || text) {
 | |
|         logFn(prefixText ? prefixText + "..." : text);
 | |
|     }
 | |
|     return spinner;
 | |
| }
 | |
| 
 | |
| //# sourceMappingURL=spinner.js.map
 |