refactor sms component
gitea/salix/2000-client.sms This commit looks good Details

This commit is contained in:
Bernat Exposito Domenech 2020-01-14 09:10:54 +01:00
parent 5888623521
commit cbda081608
6 changed files with 68 additions and 4 deletions

View File

@ -16,11 +16,21 @@ export default class Textarea extends Field {
get rows() { get rows() {
return this.input.rows; return this.input.rows;
} }
set maxlength(value) {
let length = typeof value == 'number' && value > 1 ? value : 50;
this.input.setAttribute('maxlength', length);
}
get maxlength() {
return this.input.getAttribute('maxlength', length);
}
} }
ngModule.vnComponent('vnTextarea', { ngModule.vnComponent('vnTextarea', {
controller: Textarea, controller: Textarea,
bindings: { bindings: {
rows: '<?' rows: '<?',
maxlength: '<?'
} }
}); });

View File

@ -34,4 +34,24 @@ describe('Component vnTextarea', () => {
expect($ctrl.rows).toEqual(3); expect($ctrl.rows).toEqual(3);
}); });
}); });
describe('maxlength() setter', () => {
it(`should set maxlength property of the element to the given value if it's a valid number`, () => {
$ctrl.maxlength = 100;
expect($ctrl.maxlength).toEqual('100');
});
it(`should set maxlength property of the element to 3 if the given value if it's null`, () => {
$ctrl.maxlength = null;
expect($ctrl.maxlength).toEqual('50');
});
it(`should set maxlength property of the element to 3 if the given value if it's not a valid number`, () => {
$ctrl.maxlength = 'a';
expect($ctrl.maxlength).toEqual('50');
});
});
}); });

View File

@ -13,12 +13,19 @@
</vn-horizontal> </vn-horizontal>
<vn-horizontal > <vn-horizontal >
<vn-textarea vn-one <vn-textarea vn-one
vn-id="message"
label="Message" label="Message"
ng-model="$ctrl.sms.message" ng-model="$ctrl.sms.message"
rows="5" rows="5"
maxlength="160"
rule> rule>
</vn-textarea> </vn-textarea>
</vn-horizontal> </vn-horizontal>
<vn-horizontal>
<span>
{{'Characters remaining' | translate}}: {{$ctrl.charactersRemaining()}}
</span>
</vn-horizontal>
</section> </section>
</tpl-body> </tpl-body>
<tpl-buttons> <tpl-buttons>

View File

@ -16,6 +16,16 @@ class Controller extends Component {
this.$scope.SMSDialog.show(); this.$scope.SMSDialog.show();
} }
charactersRemaining() {
let elementMaxLength;
let textAreaLength;
const element = this.$scope.message;
textAreaLength = element.input.textLength;
elementMaxLength = element.maxlength;
return elementMaxLength - textAreaLength;
}
onResponse(response) { onResponse(response) {
if (response === 'accept') { if (response === 'accept') {
this.$http.post(`Sms/send`, this.sms).then(res => { this.$http.post(`Sms/send`, this.sms).then(res => {

View File

@ -8,10 +8,11 @@ describe('Client', () => {
beforeEach(ngModule('client')); beforeEach(ngModule('client'));
beforeEach(angular.mock.inject(($componentController, _$httpBackend_) => { beforeEach(angular.mock.inject(($componentController, $rootScope, _$httpBackend_) => {
$httpBackend = _$httpBackend_; $httpBackend = _$httpBackend_;
let $scope = $rootScope.$new();
$element = angular.element('<vn-dialog></vn-dialog>'); $element = angular.element('<vn-dialog></vn-dialog>');
controller = $componentController('vnClientSms', {$element}); controller = $componentController('vnClientSms', {$element, $scope});
controller.client = {id: 101}; controller.client = {id: 101};
})); }));
@ -30,5 +31,20 @@ describe('Client', () => {
expect(controller.vnApp.showMessage).toHaveBeenCalledWith('SMS sent!'); expect(controller.vnApp.showMessage).toHaveBeenCalledWith('SMS sent!');
}); });
}); });
describe('charactersRemaining()', () => {
it('should return the characters remaining in a element', () => {
controller.$scope.message = {
input: {
textLength: 50
},
maxlength: 150
};
let result = controller.charactersRemaining();
expect(result).toEqual(100);
});
});
}); });
}); });

View File

@ -1,4 +1,5 @@
Send SMS: Enviar SMS Send SMS: Enviar SMS
Destination: Destinatario Destination: Destinatario
Message: Mensaje Message: Mensaje
SMS sent!: ¡SMS enviado! SMS sent!: ¡SMS enviado!
Characters remaining: Carácteres restantes