@cause-911/devextreme
Version:
Run `npm install @cause-911/devextreme --save` to add this library to your project
221 lines • 15.4 kB
JavaScript
/**
* @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"]}