|
313 | 313 | atBottom = scrollTop + height >= scrollHeight; |
314 | 314 |
|
315 | 315 | result = JSON.parse(result); |
316 | | - var level = result.level || "GENERAL"; |
317 | | - var now = (new Date()).toLocaleString(); |
318 | 316 |
|
319 | | - // This is a hack we should fix the framework |
320 | | - if (level === "true" || level === true) |
321 | | - { |
322 | | - level = "DE"+"BUG"; |
323 | | - } |
| 317 | + var level = (result.level || "GENERAL").toLowerCase(); |
| 318 | + var now = (new Date()).toLocaleString(); |
324 | 319 |
|
325 | 320 | this.saveButton.removeClass('disabled'); |
326 | 321 | this.clearButton.removeClass('disabled'); |
327 | 322 |
|
328 | | - var log = $("<div class='log'></div>") |
329 | | - .addClass(level.toLowerCase()); |
330 | | - |
331 | 323 | if (level === "session") |
332 | 324 | { |
333 | | - if (this.clearOnNewSession) |
334 | | - { |
335 | | - this.clear(); |
336 | | - } |
337 | | - log.text("New Session Began at " + now); |
| 325 | + this.logSession(now); |
338 | 326 | } |
339 | | - else |
| 327 | + else if (Array.isArray(result.message)) |
340 | 328 | { |
341 | | - var message = result.message; |
| 329 | + var message, i, j, tokens, token, sub; |
342 | 330 |
|
343 | | - if (typeof message === "object") |
| 331 | + for (i = 0; i < result.message.length; i++) |
344 | 332 | { |
345 | | - message = JSON.stringify(message, null, "\t"); |
| 333 | + message = result.message[i]; |
| 334 | + |
| 335 | + // Ignore non-strings |
| 336 | + if (typeof message == "string") |
| 337 | + { |
| 338 | + tokens = message.match(/%[sdifoObxec]/g); |
| 339 | + |
| 340 | + if (tokens) |
| 341 | + { |
| 342 | + for (j = 0; j < tokens.length; j++) |
| 343 | + { |
| 344 | + token = tokens[j]; |
| 345 | + sub = result.message[++i]; |
| 346 | + |
| 347 | + // CSS substitution check |
| 348 | + if (token == "%c") |
| 349 | + { |
| 350 | + sub = '<span style="'+ sub + '">'; |
| 351 | + message += '</span>'; |
| 352 | + } |
| 353 | + // Do object substitution |
| 354 | + else if (token == "%o" || token == "%O") |
| 355 | + { |
| 356 | + sub = JSON.stringify(sub, null, "\t"); |
| 357 | + } |
| 358 | + message = message.replace(token, String(sub)); |
| 359 | + } |
| 360 | + } |
| 361 | + } |
| 362 | + this.logMessage(now, message, level); |
346 | 363 | } |
347 | | - log.append( |
348 | | - $("<span class='type'></span>").text(level), |
349 | | - $("<span class='timestamp'></span>").text(now), |
350 | | - $("<span class='message'></span>").text(message) |
351 | | - ); |
352 | 364 | } |
353 | 365 |
|
354 | | - // Add a new log |
355 | | - this.output.append(log); |
356 | | - |
357 | 366 | if (this.maxLogs) |
358 | 367 | { |
359 | 368 | this.output.html(this.output.children(".log").slice(-this.maxLogs)); |
|
366 | 375 | } |
367 | 376 | }; |
368 | 377 |
|
| 378 | + /** |
| 379 | + * Log a new message |
| 380 | + * @method logMessage |
| 381 | + * @param {string} now The current time name |
| 382 | + * @param {string} message The message to log |
| 383 | + * @param {string} level The level to use |
| 384 | + */ |
| 385 | + p.logMessage = function(now, message, level) |
| 386 | + { |
| 387 | + if (typeof message === "object") |
| 388 | + { |
| 389 | + message = JSON.stringify(message, null, "\t"); |
| 390 | + } |
| 391 | + this.output.append( |
| 392 | + $("<div class='log'></div>") |
| 393 | + .addClass(level) |
| 394 | + .append( |
| 395 | + $("<span class='type'></span>").text(level.toUpperCase()), |
| 396 | + $("<span class='timestamp'></span>").text(now), |
| 397 | + $("<span class='message'></span>").html(message) |
| 398 | + ) |
| 399 | + ); |
| 400 | + }; |
| 401 | + |
| 402 | + /** |
| 403 | + * Log a new session |
| 404 | + * @method logSession |
| 405 | + * @param {string} now The current time name |
| 406 | + */ |
| 407 | + p.logSession = function(now) |
| 408 | + { |
| 409 | + if (this.clearOnNewSession) |
| 410 | + { |
| 411 | + this.clear(); |
| 412 | + } |
| 413 | + this.output.append( |
| 414 | + $("<div class='log session'></div>") |
| 415 | + .text("New Session Began at " + now) |
| 416 | + ); |
| 417 | + }; |
| 418 | + |
369 | 419 | /** |
370 | 420 | * Close the application |
371 | 421 | * @method shutdown |
|
0 commit comments