Server IP : 92.205.26.207 / Your IP : 216.73.216.16 Web Server : Apache System : Linux 207.26.205.92.host.secureserver.net 4.18.0-553.60.1.el8_10.x86_64 #1 SMP Thu Jul 10 04:01:16 EDT 2025 x86_64 User : zikryat ( 1002) PHP Version : 8.3.23 Disable Function : exec,passthru,shell_exec,system MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON Directory (0755) : /home/zikryat/public_html/node_modules/mjml-column/lib/ |
[ Home ] | [ C0mmand ] | [ Upload File ] |
---|
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck")); var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass")); var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits")); var _createSuper2 = _interopRequireDefault(require("@babel/runtime/helpers/createSuper")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _mjmlCore = require("mjml-core"); var _widthParser = _interopRequireDefault(require("mjml-core/lib/helpers/widthParser")); let MjColumn = /*#__PURE__*/function (_BodyComponent) { (0, _inherits2.default)(MjColumn, _BodyComponent); var _super = (0, _createSuper2.default)(MjColumn); function MjColumn() { (0, _classCallCheck2.default)(this, MjColumn); return _super.apply(this, arguments); } (0, _createClass2.default)(MjColumn, [{ key: "getChildContext", value: function getChildContext() { const { containerWidth: parentWidth } = this.context; const { nonRawSiblings } = this.props; const { borders, paddings } = this.getBoxWidths(); const innerBorders = this.getShorthandAttrValue('inner-border', 'left') + this.getShorthandAttrValue('inner-border', 'right'); const allPaddings = paddings + borders + innerBorders; let containerWidth = this.getAttribute('width') || `${parseFloat(parentWidth) / nonRawSiblings}px`; const { unit, parsedWidth } = (0, _widthParser.default)(containerWidth, { parseFloatToInt: false }); if (unit === '%') { containerWidth = `${parseFloat(parentWidth) * parsedWidth / 100 - allPaddings}px`; } else { containerWidth = `${parsedWidth - allPaddings}px`; } return { ...this.context, containerWidth }; } }, { key: "getStyles", value: function getStyles() { const tableStyle = { 'background-color': this.getAttribute('background-color'), border: this.getAttribute('border'), 'border-bottom': this.getAttribute('border-bottom'), 'border-left': this.getAttribute('border-left'), 'border-radius': this.getAttribute('border-radius'), 'border-right': this.getAttribute('border-right'), 'border-top': this.getAttribute('border-top'), 'vertical-align': this.getAttribute('vertical-align') }; return { div: { 'font-size': '0px', 'text-align': 'left', direction: this.getAttribute('direction'), display: 'inline-block', 'vertical-align': this.getAttribute('vertical-align'), width: this.getMobileWidth() }, table: { ...(this.hasGutter() ? { 'background-color': this.getAttribute('inner-background-color'), border: this.getAttribute('inner-border'), 'border-bottom': this.getAttribute('inner-border-bottom'), 'border-left': this.getAttribute('inner-border-left'), 'border-radius': this.getAttribute('inner-border-radius'), 'border-right': this.getAttribute('inner-border-right'), 'border-top': this.getAttribute('inner-border-top') } : tableStyle) }, tdOutlook: { 'vertical-align': this.getAttribute('vertical-align'), width: this.getWidthAsPixel() }, gutter: { ...tableStyle, padding: this.getAttribute('padding'), 'padding-top': this.getAttribute('padding-top'), 'padding-right': this.getAttribute('padding-right'), 'padding-bottom': this.getAttribute('padding-bottom'), 'padding-left': this.getAttribute('padding-left') } }; } }, { key: "getMobileWidth", value: function getMobileWidth() { const { containerWidth } = this.context; const { nonRawSiblings } = this.props; const width = this.getAttribute('width'); const mobileWidth = this.getAttribute('mobileWidth'); if (mobileWidth !== 'mobileWidth') { return '100%'; } if (width === undefined) { return `${parseInt(100 / nonRawSiblings, 10)}%`; } const { unit, parsedWidth } = (0, _widthParser.default)(width, { parseFloatToInt: false }); switch (unit) { case '%': return width; case 'px': default: return `${parsedWidth / parseInt(containerWidth, 10) * 100}%`; } } }, { key: "getWidthAsPixel", value: function getWidthAsPixel() { const { containerWidth } = this.context; const { unit, parsedWidth } = (0, _widthParser.default)(this.getParsedWidth(true), { parseFloatToInt: false }); if (unit === '%') { return `${parseFloat(containerWidth) * parsedWidth / 100}px`; } return `${parsedWidth}px`; } }, { key: "getParsedWidth", value: function getParsedWidth(toString) { const { nonRawSiblings } = this.props; const width = this.getAttribute('width') || `${100 / nonRawSiblings}%`; const { unit, parsedWidth } = (0, _widthParser.default)(width, { parseFloatToInt: false }); if (toString) { return `${parsedWidth}${unit}`; } return { unit, parsedWidth }; } }, { key: "getColumnClass", value: function getColumnClass() { const { addMediaQuery } = this.context; let className = ''; const { parsedWidth, unit } = this.getParsedWidth(); const formattedClassNb = parsedWidth.toString().replace('.', '-'); switch (unit) { case '%': className = `mj-column-per-${formattedClassNb}`; break; case 'px': default: className = `mj-column-px-${formattedClassNb}`; break; } // Add className to media queries addMediaQuery(className, { parsedWidth, unit }); return className; } }, { key: "hasGutter", value: function hasGutter() { return ['padding', 'padding-bottom', 'padding-left', 'padding-right', 'padding-top'].some(attr => this.getAttribute(attr) != null); } }, { key: "renderGutter", value: function renderGutter() { return ` <table ${this.htmlAttributes({ border: '0', cellpadding: '0', cellspacing: '0', role: 'presentation', width: '100%' })} > <tbody> <tr> <td ${this.htmlAttributes({ style: 'gutter' })}> ${this.renderColumn()} </td> </tr> </tbody> </table> `; } }, { key: "renderColumn", value: function renderColumn() { const { children } = this.props; return ` <table ${this.htmlAttributes({ border: '0', cellpadding: '0', cellspacing: '0', role: 'presentation', style: 'table', width: '100%' })} > <tbody> ${this.renderChildren(children, { renderer: component => component.constructor.isRawElement() ? component.render() : ` <tr> <td ${component.htmlAttributes({ align: component.getAttribute('align'), 'vertical-align': component.getAttribute('vertical-align'), class: component.getAttribute('css-class'), style: { background: component.getAttribute('container-background-color'), 'font-size': '0px', padding: component.getAttribute('padding'), 'padding-top': component.getAttribute('padding-top'), 'padding-right': component.getAttribute('padding-right'), 'padding-bottom': component.getAttribute('padding-bottom'), 'padding-left': component.getAttribute('padding-left'), 'word-break': 'break-word' } })} > ${component.render()} </td> </tr> ` })} </tbody> </table> `; } }, { key: "render", value: function render() { let classesName = `${this.getColumnClass()} mj-outlook-group-fix`; if (this.getAttribute('css-class')) { classesName += ` ${this.getAttribute('css-class')}`; } return ` <div ${this.htmlAttributes({ class: classesName, style: 'div' })} > ${this.hasGutter() ? this.renderGutter() : this.renderColumn()} </div> `; } }]); return MjColumn; }(_mjmlCore.BodyComponent); exports.default = MjColumn; (0, _defineProperty2.default)(MjColumn, "componentName", 'mj-column'); (0, _defineProperty2.default)(MjColumn, "allowedAttributes", { 'background-color': 'color', border: 'string', 'border-bottom': 'string', 'border-left': 'string', 'border-radius': 'unit(px,%){1,4}', 'border-right': 'string', 'border-top': 'string', direction: 'enum(ltr,rtl)', 'inner-background-color': 'color', 'padding-bottom': 'unit(px,%)', 'padding-left': 'unit(px,%)', 'padding-right': 'unit(px,%)', 'padding-top': 'unit(px,%)', 'inner-border': 'string', 'inner-border-bottom': 'string', 'inner-border-left': 'string', 'inner-border-radius': 'unit(px,%){1,4}', 'inner-border-right': 'string', 'inner-border-top': 'string', padding: 'unit(px,%){1,4}', 'vertical-align': 'enum(top,bottom,middle)', width: 'unit(px,%)' }); (0, _defineProperty2.default)(MjColumn, "defaultAttributes", { direction: 'ltr', 'vertical-align': 'top' }); module.exports = exports.default;