UNPKG

@cause-911/devextreme

Version:

Run `npm install @cause-911/devextreme --save` to add this library to your project

221 lines 15.4 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core'; import { DxTextAreaComponent } from 'devextreme-angular'; var CauseTextAreaLimitedComponent = /** @class */ (function () { function CauseTextAreaLimitedComponent() { this.value = ''; this.maxChar = 225; this.format = 'text'; this.valueChanged = new EventEmitter(); this.gsm7bitChars = '@£$¥èéùìòÇ\\nØø\\rÅåΔ_ΦΓΛΩΠΨΣΘΞÆæßÉ !\\"#¤%&\'()*+,-./0123456789:;<=>?¡ABCDEFGHIJKLMNOPQRSTUVWXYZÄÖÑܧ¿abcdefghijklmnopqrstuvwxyzäöñüà'; this.gsm7bitCharsExt = '\\^{}\\\\\\[~\\]|€'; this.gsm7bitRegExp = RegExp('^[' + this.gsm7bitChars + ']*$'); this.gsm7bitExtRegExp = RegExp('^[' + this.gsm7bitChars + this.gsm7bitCharsExt + ']*$'); this.gsm7bitExtOnlyRegExp = RegExp('^[' + this.gsm7bitCharsExt + ']*$'); this.messageLength = { GSM7: 160, GSM7ext: 160, UTF16: 70 }; this.multiMessageLength = { GSM7: 153, GSM7ext: 153, UTF16: 67 }; } /** * @return {?} */ CauseTextAreaLimitedComponent.prototype.ngOnInit = /** * @return {?} */ function () { if (this.format === 'sms') { this.maxChar = 0; } }; /** * @param {?} e * @return {?} */ CauseTextAreaLimitedComponent.prototype.changed = /** * @param {?} e * @return {?} */ function (e) { this.value = e.value; this.valueChanged.emit(e); }; /** * @return {?} */ CauseTextAreaLimitedComponent.prototype.getNumberOfSms = /** * @return {?} */ function () { if (!this.value) { return 0; } /** @type {?} */ var length = this.countSmsChars(this.value); /** @type {?} */ var charset = this.getCharset(this.value); /** @type {?} */ var perMessage = (length > this.messageLength[charset] ? this.multiMessageLength[charset] : this.messageLength[charset]); return Math.ceil(length / perMessage); }; /** * @return {?} */ CauseTextAreaLimitedComponent.prototype.getNumberOfChar = /** * @return {?} */ function () { return (this.value ? this.value.length : 0) + "/" + this.maxChar; }; /** * @private * @param {?} text * @return {?} */ CauseTextAreaLimitedComponent.prototype.countSmsChars = /** * @private * @param {?} text * @return {?} */ function (text) { /** @type {?} */ var length = text.length; /** @type {?} */ var charset = this.getCharset(text); if (charset === 'GSM7ext') { length += this.countGsm7bitExt(text); } return length; }; /** * @private * @param {?} text * @return {?} */ CauseTextAreaLimitedComponent.prototype.countGsm7bitExt = /** * @private * @param {?} text * @return {?} */ function (text) { var _this = this; /** @type {?} */ var char2; /** @type {?} */ var chars = (/** * @return {?} */ function () { /** @type {?} */ var _i; /** @type {?} */ var _len; /** @type {?} */ var _results; _results = []; for (_i = 0, _len = text.length; _i < _len; _i++) { char2 = text[_i]; if (char2.match(_this.gsm7bitExtOnlyRegExp) != null) { _results.push(char2); } } return _results; }); return chars.length; }; /** * @private * @param {?} text * @return {?} */ CauseTextAreaLimitedComponent.prototype.getCharset = /** * @private * @param {?} text * @return {?} */ function (text) { switch (false) { case text.match(this.gsm7bitRegExp) == null: return 'GSM7'; case text.match(this.gsm7bitExtRegExp) == null: return 'GSM7ext'; default: return 'UTF16'; } }; CauseTextAreaLimitedComponent.decorators = [ { type: Component, args: [{ selector: 'cause-dx-text-area-limited', template: "<dx-text-area\n [(value)]=\"value\"\n [maxLength]=\"maxChar\"\n minHeight=\"50\"\n valueChangeEvent=\"keyup\"\n [autoResizeEnabled]=\"true\"\n (onValueChanged)=\"changed($event)\">\n</dx-text-area>\n<div class=\"limit\">\n <span *ngIf=\"format === 'sms'\">{{'devextreme.numberOfSms' | translate}} : {{getNumberOfSms()}}</span>\n <span *ngIf=\"format === 'text'\">{{'devextreme.numberOfChar' | translate}} : {{getNumberOfChar()}}</span>\n</div>\n", styles: [".limit{color:#999;font-size:.8em;text-align:right}"] }] } ]; /** @nocollapse */ CauseTextAreaLimitedComponent.ctorParameters = function () { return []; }; CauseTextAreaLimitedComponent.propDecorators = { textarea: [{ type: ViewChild, args: [DxTextAreaComponent, { static: false },] }], value: [{ type: Input }], maxChar: [{ type: Input }], format: [{ type: Input }], valueChanged: [{ type: Output }] }; return CauseTextAreaLimitedComponent; }()); export { CauseTextAreaLimitedComponent }; if (false) { /** @type {?} */ CauseTextAreaLimitedComponent.prototype.textarea; /** @type {?} */ CauseTextAreaLimitedComponent.prototype.value; /** @type {?} */ CauseTextAreaLimitedComponent.prototype.maxChar; /** @type {?} */ CauseTextAreaLimitedComponent.prototype.format; /** @type {?} */ CauseTextAreaLimitedComponent.prototype.valueChanged; /** * @type {?} * @private */ CauseTextAreaLimitedComponent.prototype.gsm7bitChars; /** * @type {?} * @private */ CauseTextAreaLimitedComponent.prototype.gsm7bitCharsExt; /** * @type {?} * @private */ CauseTextAreaLimitedComponent.prototype.gsm7bitRegExp; /** * @type {?} * @private */ CauseTextAreaLimitedComponent.prototype.gsm7bitExtRegExp; /** * @type {?} * @private */ CauseTextAreaLimitedComponent.prototype.gsm7bitExtOnlyRegExp; /** * @type {?} * @private */ CauseTextAreaLimitedComponent.prototype.messageLength; /** * @type {?} * @private */ CauseTextAreaLimitedComponent.prototype.multiMessageLength; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cause-text-area-limited.component.js","sourceRoot":"ng://@cause-911/devextreme/","sources":["lib/cause-text-area-limited/cause-text-area-limited.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, Input, OnInit, Output, ViewChild} from '@angular/core';\nimport {DxTextAreaComponent} from 'devextreme-angular';\n\n@Component({\n    selector: 'cause-dx-text-area-limited',\n    templateUrl: './cause-text-area-limited.component.html',\n    styleUrls: ['./cause-text-area-limited.component.scss']\n})\nexport class CauseTextAreaLimitedComponent implements OnInit {\n    @ViewChild(DxTextAreaComponent, {static: false}) textarea: DxTextAreaComponent;\n    @Input() value = '';\n    @Input() maxChar = 225;\n    @Input() format = 'text';\n\n    @Output() valueChanged = new EventEmitter();\n\n    private gsm7bitChars = '@£$¥èéùìòÇ\\\\nØø\\\\rÅåΔ_ΦΓΛΩΠΨΣΘΞÆæßÉ !\\\\\"#¤%&\\'()*+,-./0123456789:;<=>?¡ABCDEFGHIJKLMNOPQRSTUVWXYZÄÖÑÜ§¿abcdefghijklmnopqrstuvwxyzäöñüà';\n    private gsm7bitCharsExt = '\\\\^{}\\\\\\\\\\\\[~\\\\]|€';\n    private gsm7bitRegExp = RegExp('^[' + this.gsm7bitChars + ']*$');\n    private gsm7bitExtRegExp = RegExp('^[' + this.gsm7bitChars + this.gsm7bitCharsExt + ']*$');\n    private gsm7bitExtOnlyRegExp = RegExp('^[' + this.gsm7bitCharsExt + ']*$');\n    private messageLength = {\n        GSM7: 160,\n        GSM7ext: 160,\n        UTF16: 70\n    };\n    private multiMessageLength = {\n        GSM7: 153,\n        GSM7ext: 153,\n        UTF16: 67\n    };\n\n    constructor() {\n    }\n\n    ngOnInit() {\n        if (this.format === 'sms') {\n            this.maxChar = 0;\n        }\n    }\n\n    changed(e) {\n        this.value = e.value;\n        this.valueChanged.emit(e);\n    }\n\n    getNumberOfSms() {\n        if (!this.value) {\n            return 0;\n        }\n\n        const length = this.countSmsChars(this.value);\n        const charset = this.getCharset(this.value);\n        const perMessage = (length > this.messageLength[charset] ? this.multiMessageLength[charset] : this.messageLength[charset]);\n\n        return Math.ceil(length / perMessage);\n    }\n\n    getNumberOfChar() {\n        return `${this.value ? this.value.length : 0}/${this.maxChar}`;\n    }\n\n    private countSmsChars(text: string): number {\n        let length = text.length;\n        const charset = this.getCharset(text);\n\n        if (charset === 'GSM7ext') {\n            length += this.countGsm7bitExt(text);\n        }\n\n        return length;\n    }\n\n    private countGsm7bitExt(text: string): number {\n        let char2;\n        const chars = () => {\n            let _i, _len, _results;\n            _results = [];\n            for (_i = 0, _len = text.length; _i < _len; _i++) {\n                char2 = text[_i];\n                if (char2.match(this.gsm7bitExtOnlyRegExp) != null) {\n                    _results.push(char2);\n                }\n            }\n            return _results;\n        };\n\n        return chars.length;\n    }\n\n    private getCharset(text: string): string {\n        switch (false) {\n            case text.match(this.gsm7bitRegExp) == null:\n                return 'GSM7';\n            case text.match(this.gsm7bitExtRegExp) == null:\n                return 'GSM7ext';\n            default:\n                return 'UTF16';\n        }\n    }\n}\n"]}