UNPKG

@cause-911/devextreme

Version:

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

190 lines 14.3 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'; export class CauseTextAreaLimitedComponent { constructor() { 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 {?} */ ngOnInit() { if (this.format === 'sms') { this.maxChar = 0; } } /** * @param {?} e * @return {?} */ changed(e) { this.value = e.value; this.valueChanged.emit(e); } /** * @return {?} */ getNumberOfSms() { if (!this.value) { return 0; } /** @type {?} */ const length = this.countSmsChars(this.value); /** @type {?} */ const charset = this.getCharset(this.value); /** @type {?} */ const perMessage = (length > this.messageLength[charset] ? this.multiMessageLength[charset] : this.messageLength[charset]); return Math.ceil(length / perMessage); } /** * @return {?} */ getNumberOfChar() { return `${this.value ? this.value.length : 0}/${this.maxChar}`; } /** * @private * @param {?} text * @return {?} */ countSmsChars(text) { /** @type {?} */ let length = text.length; /** @type {?} */ const charset = this.getCharset(text); if (charset === 'GSM7ext') { length += this.countGsm7bitExt(text); } return length; } /** * @private * @param {?} text * @return {?} */ countGsm7bitExt(text) { /** @type {?} */ let char2; /** @type {?} */ const chars = (/** * @return {?} */ () => { /** @type {?} */ let _i; /** @type {?} */ let _len; /** @type {?} */ let _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 {?} */ getCharset(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 = () => []; CauseTextAreaLimitedComponent.propDecorators = { textarea: [{ type: ViewChild, args: [DxTextAreaComponent, { static: false },] }], value: [{ type: Input }], maxChar: [{ type: Input }], format: [{ type: Input }], valueChanged: [{ type: Output }] }; 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"]}