index.js 2.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. (function(f){if(typeof exports==="object"&&typeof module!=="undefined"){module.exports=f()}else if(typeof define==="function"&&define.amd){define([],f)}else{var g;if(typeof window!=="undefined"){g=window}else if(typeof global!=="undefined"){g=global}else if(typeof self!=="undefined"){g=self}else{g=this}g.fit = f()}})(function(){var define,module,exports;return (function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({1:[function(require,module,exports){
  2. "use strict";
  3. Object.defineProperty(exports, "__esModule", { value: true });
  4. function proposeGeometry(term) {
  5. if (!term.element.parentElement) {
  6. return null;
  7. }
  8. var parentElementStyle = window.getComputedStyle(term.element.parentElement);
  9. var parentElementHeight = parseInt(parentElementStyle.getPropertyValue('height'));
  10. var parentElementWidth = Math.max(0, parseInt(parentElementStyle.getPropertyValue('width')));
  11. var elementStyle = window.getComputedStyle(term.element);
  12. var elementPadding = {
  13. top: parseInt(elementStyle.getPropertyValue('padding-top')),
  14. bottom: parseInt(elementStyle.getPropertyValue('padding-bottom')),
  15. right: parseInt(elementStyle.getPropertyValue('padding-right')),
  16. left: parseInt(elementStyle.getPropertyValue('padding-left'))
  17. };
  18. var elementPaddingVer = elementPadding.top + elementPadding.bottom;
  19. var elementPaddingHor = elementPadding.right + elementPadding.left;
  20. var availableHeight = parentElementHeight - elementPaddingVer;
  21. var availableWidth = parentElementWidth - elementPaddingHor - term.viewport.scrollBarWidth;
  22. var geometry = {
  23. cols: Math.floor(availableWidth / term.renderer.dimensions.actualCellWidth),
  24. rows: Math.floor(availableHeight / term.renderer.dimensions.actualCellHeight)
  25. };
  26. return geometry;
  27. }
  28. exports.proposeGeometry = proposeGeometry;
  29. function fit(term) {
  30. var geometry = proposeGeometry(term);
  31. if (geometry) {
  32. if (term.rows !== geometry.rows || term.cols !== geometry.cols) {
  33. term.renderer.clear();
  34. term.resize(geometry.cols, geometry.rows);
  35. }
  36. }
  37. }
  38. exports.fit = fit;
  39. function apply(terminalConstructor) {
  40. terminalConstructor.prototype.proposeGeometry = function () {
  41. return proposeGeometry(this);
  42. };
  43. terminalConstructor.prototype.fit = function () {
  44. fit(this);
  45. };
  46. }
  47. exports.apply = apply;
  48. },{}]},{},[1])(1)
  49. });
  50. //# sourceMappingURL=fit.js.map