UNPKG

ts-lit-plugin

Version:

Typescript plugin that adds type checking and code completion to lit-html

189 lines (188 loc) 7.17 kB
"use strict"; var __extends = (this && this.__extends) || (function () { var extendStatics = function (d, b) { extendStatics = Object.setPrototypeOf || ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; }; return extendStatics(d, b); }; return function (d, b) { if (typeof b !== "function" && b !== null) throw new TypeError("Class extends value " + String(b) + " is not a constructor or null"); extendStatics(d, b); function __() { this.constructor = d; } d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; })(); var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { if (k2 === undefined) k2 = k; var desc = Object.getOwnPropertyDescriptor(m, k); if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { desc = { enumerable: true, get: function() { return m[k]; } }; } Object.defineProperty(o, k2, desc); }) : (function(o, m, k, k2) { if (k2 === undefined) k2 = k; o[k2] = m[k]; })); var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { Object.defineProperty(o, "default", { enumerable: true, value: v }); }) : function(o, v) { o["default"] = v; }); var __importStar = (this && this.__importStar) || function (mod) { if (mod && mod.__esModule) return mod; var result = {}; if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); __setModuleDefault(result, mod); return result; }; var __read = (this && this.__read) || function (o, n) { var m = typeof Symbol === "function" && o[Symbol.iterator]; if (!m) return o; var i = m.call(o), r, ar = [], e; try { while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value); } catch (error) { e = { error: error }; } finally { try { if (r && !r.done && (m = i["return"])) m.call(i); } finally { if (e) throw e.error; } } return ar; }; var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) { if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) { if (ar || !(i in from)) { if (!ar) ar = Array.prototype.slice.call(from, 0, i); ar[i] = from[i]; } } return to.concat(ar || Array.prototype.slice.call(from)); }; Object.defineProperty(exports, "__esModule", { value: true }); exports.logger = exports.Logger = void 0; /* eslint-disable @typescript-eslint/no-explicit-any */ var fs_1 = require("fs"); var lit_analyzer_1 = require("lit-analyzer"); var path_1 = require("path"); var util_1 = require("util"); var tsServer = __importStar(require("typescript/lib/tsserverlibrary.js")); var LOG_FILE_NAME = "lit-plugin.log"; /** * This class takes care of logging while fixing issues regarding the type script service logger. * It logs to a file called "log.txt" in the root of this project. */ var Logger = /** @class */ (function (_super) { __extends(Logger, _super); function Logger() { var _this = _super !== null && _super.apply(this, arguments) || this; _this.level = lit_analyzer_1.LitAnalyzerLoggerLevel.OFF; _this.tsLogger = undefined; _this.logPath = (0, path_1.join)(process.cwd(), LOG_FILE_NAME); return _this; } /** * Call this with the TS Server's logger so that we can log to the TS server logs. * * Access in VS Code via > TypeScript: Open TS Server log */ Logger.prototype.setTsServerLogging = function (tsLogger) { this.tsLogger = tsLogger; }; /** * Logs if this.level >= DEBUG * @param args */ Logger.prototype.debug = function () { var args = []; for (var _i = 0; _i < arguments.length; _i++) { args[_i] = arguments[_i]; } this.appendLogWithLevel.apply(this, __spreadArray([lit_analyzer_1.LitAnalyzerLoggerLevel.DEBUG], __read(args), false)); }; /** * Logs if this.level >= ERROR * @param args */ Logger.prototype.error = function () { var args = []; for (var _i = 0; _i < arguments.length; _i++) { args[_i] = arguments[_i]; } this.appendLogWithLevel.apply(this, __spreadArray([lit_analyzer_1.LitAnalyzerLoggerLevel.ERROR], __read(args), false)); }; /** * Logs if level >= WARN * @param args */ Logger.prototype.warn = function () { var args = []; for (var _i = 0; _i < arguments.length; _i++) { args[_i] = arguments[_i]; } this.appendLogWithLevel.apply(this, __spreadArray([lit_analyzer_1.LitAnalyzerLoggerLevel.WARN], __read(args), false)); }; /** * Logs if level >= VERBOSE * @param args */ Logger.prototype.verbose = function () { var args = []; for (var _i = 0; _i < arguments.length; _i++) { args[_i] = arguments[_i]; } this.appendLogWithLevel.apply(this, __spreadArray([lit_analyzer_1.LitAnalyzerLoggerLevel.VERBOSE], __read(args), false)); }; Object.defineProperty(Logger.prototype, "cwd", { set: function (cwd) { this.logPath = (0, path_1.join)(cwd, LOG_FILE_NAME); }, enumerable: false, configurable: true }); /** * Resets the log file. */ Logger.prototype.resetLogs = function () { if (this.level > lit_analyzer_1.LitAnalyzerLoggerLevel.OFF) { (0, fs_1.writeFileSync)(this.logPath, ""); } }; /** * Appends a log if this.level > level * @param level * @param args */ Logger.prototype.appendLogWithLevel = function (level) { var _a; var args = []; for (var _i = 1; _i < arguments.length; _i++) { args[_i - 1] = arguments[_i]; } if (this.level >= level) { var prefix = this.getLogLevelPrefix(level); var message = (0, util_1.inspect)(args, { colors: true, depth: 6, breakLength: 50, maxArrayLength: 10 }); try { (0, fs_1.appendFileSync)(this.logPath, "".concat(prefix).concat(message, "\n")); } catch (_b) { // ignore } (_a = this.tsLogger) === null || _a === void 0 ? void 0 : _a.msg("[ts-lit-plugin] ".concat(message), level === lit_analyzer_1.LitAnalyzerLoggerLevel.ERROR ? tsServer.server.Msg.Err : tsServer.server.Msg.Info); } }; Logger.prototype.getLogLevelPrefix = function (level) { return "[".concat(new Date().toLocaleString(), "] [").concat(this.severityPrefix(level), "] "); }; return Logger; }(lit_analyzer_1.DefaultLitAnalyzerLogger)); exports.Logger = Logger; exports.logger = new Logger();