2019-07-05 03:19:24 +08:00
|
|
|
import { getNotification } from 'Common/Translator';
|
2016-06-30 08:02:45 +08:00
|
|
|
|
2020-09-15 01:40:56 +08:00
|
|
|
import Remote from 'Remote/User/Fetch';
|
2016-06-30 08:02:45 +08:00
|
|
|
|
2021-02-19 19:09:20 +08:00
|
|
|
import { decorateKoCommands } from 'Knoin/Knoin';
|
2021-01-24 17:25:23 +08:00
|
|
|
import { AbstractViewPopup } from 'Knoin/AbstractViews';
|
2016-06-30 08:02:45 +08:00
|
|
|
|
2020-10-27 18:09:24 +08:00
|
|
|
const reEmail = /^[^@\s]+@[^@\s]+$/;
|
2020-09-17 06:02:35 +08:00
|
|
|
|
2022-02-24 21:01:41 +08:00
|
|
|
export class IdentityPopupView extends AbstractViewPopup {
|
2016-08-17 06:01:20 +08:00
|
|
|
constructor() {
|
2021-01-24 17:25:23 +08:00
|
|
|
super('Identity');
|
2016-06-30 08:02:45 +08:00
|
|
|
|
2016-08-17 06:01:20 +08:00
|
|
|
this.id = '';
|
2020-10-26 19:54:03 +08:00
|
|
|
this.addObservables({
|
|
|
|
edit: false,
|
|
|
|
owner: false,
|
2020-10-27 18:09:24 +08:00
|
|
|
|
|
|
|
email: '',
|
2020-10-26 19:54:03 +08:00
|
|
|
emailFocused: false,
|
2020-10-27 18:09:24 +08:00
|
|
|
emailHasError: false,
|
|
|
|
|
2020-10-26 19:54:03 +08:00
|
|
|
name: '',
|
2020-10-27 18:09:24 +08:00
|
|
|
|
|
|
|
replyTo: '',
|
2020-10-26 19:54:03 +08:00
|
|
|
replyToFocused: false,
|
2020-10-27 18:09:24 +08:00
|
|
|
replyToHasError: false,
|
|
|
|
|
|
|
|
bcc: '',
|
2020-10-26 19:54:03 +08:00
|
|
|
bccFocused: false,
|
2020-10-27 18:09:24 +08:00
|
|
|
bccHasError: false,
|
2020-10-26 19:54:03 +08:00
|
|
|
|
|
|
|
signature: '',
|
|
|
|
signatureInsertBefore: false,
|
|
|
|
|
|
|
|
showBcc: false,
|
|
|
|
showReplyTo: false,
|
|
|
|
|
|
|
|
submitRequest: false,
|
|
|
|
submitError: ''
|
|
|
|
});
|
2016-06-30 08:02:45 +08:00
|
|
|
|
2020-10-27 18:09:24 +08:00
|
|
|
this.addSubscribables({
|
|
|
|
email: value => this.emailHasError(value && !reEmail.test(value)),
|
|
|
|
replyTo: value => {
|
|
|
|
this.replyToHasError(value && !reEmail.test(value));
|
|
|
|
if (false === this.showReplyTo() && value.length) {
|
|
|
|
this.showReplyTo(true);
|
|
|
|
}
|
|
|
|
},
|
|
|
|
bcc: value => {
|
|
|
|
this.bccHasError(value && !reEmail.test(value));
|
|
|
|
if (false === this.showBcc() && value.length) {
|
|
|
|
this.showBcc(true);
|
|
|
|
}
|
2016-08-17 06:01:20 +08:00
|
|
|
}
|
|
|
|
});
|
2020-10-27 18:09:24 +08:00
|
|
|
/*
|
|
|
|
this.email.valueHasMutated();
|
|
|
|
this.replyTo.valueHasMutated();
|
|
|
|
this.bcc.valueHasMutated();
|
|
|
|
*/
|
2021-02-19 19:09:20 +08:00
|
|
|
decorateKoCommands(this, {
|
|
|
|
addOrEditIdentityCommand: self => !self.submitRequest()
|
|
|
|
});
|
2016-09-10 06:38:16 +08:00
|
|
|
}
|
2015-02-06 23:26:20 +08:00
|
|
|
|
2016-09-10 06:38:16 +08:00
|
|
|
addOrEditIdentityCommand() {
|
2019-07-05 03:19:24 +08:00
|
|
|
if (this.signature && this.signature.__fetchEditorValue) {
|
2016-09-10 06:38:16 +08:00
|
|
|
this.signature.__fetchEditorValue();
|
|
|
|
}
|
2014-08-21 23:08:34 +08:00
|
|
|
|
2020-10-27 18:09:24 +08:00
|
|
|
if (!this.emailHasError()) {
|
|
|
|
this.emailHasError(!this.email().trim());
|
2016-09-10 06:38:16 +08:00
|
|
|
}
|
2015-02-08 09:11:13 +08:00
|
|
|
|
2020-10-27 18:09:24 +08:00
|
|
|
if (this.emailHasError()) {
|
2019-07-05 03:19:24 +08:00
|
|
|
if (!this.owner()) {
|
2020-10-26 19:54:03 +08:00
|
|
|
this.emailFocused(true);
|
2016-08-17 06:01:20 +08:00
|
|
|
}
|
2014-08-21 23:08:34 +08:00
|
|
|
|
2016-09-10 06:38:16 +08:00
|
|
|
return false;
|
|
|
|
}
|
2015-02-08 09:11:13 +08:00
|
|
|
|
2020-10-27 18:09:24 +08:00
|
|
|
if (this.replyToHasError()) {
|
2020-10-26 19:54:03 +08:00
|
|
|
this.replyToFocused(true);
|
2016-09-10 06:38:16 +08:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2020-10-27 18:09:24 +08:00
|
|
|
if (this.bccHasError()) {
|
2020-10-26 19:54:03 +08:00
|
|
|
this.bccFocused(true);
|
2016-09-10 06:38:16 +08:00
|
|
|
return false;
|
|
|
|
}
|
2014-08-21 23:08:34 +08:00
|
|
|
|
2016-09-10 06:38:16 +08:00
|
|
|
this.submitRequest(true);
|
2016-06-30 08:02:45 +08:00
|
|
|
|
2021-12-03 06:15:24 +08:00
|
|
|
Remote.request('IdentityUpdate', iError => {
|
2019-07-05 03:19:24 +08:00
|
|
|
this.submitRequest(false);
|
2021-03-18 19:33:13 +08:00
|
|
|
if (iError) {
|
|
|
|
this.submitError(getNotification(iError));
|
2019-07-05 03:19:24 +08:00
|
|
|
} else {
|
2021-03-18 19:33:13 +08:00
|
|
|
rl.app.accountsAndIdentities();
|
|
|
|
this.cancelCommand();
|
2016-06-30 08:02:45 +08:00
|
|
|
}
|
2021-12-03 06:15:24 +08:00
|
|
|
}, {
|
|
|
|
Id: this.id,
|
|
|
|
Email: this.email(),
|
|
|
|
Name: this.name(),
|
|
|
|
ReplyTo: this.replyTo(),
|
|
|
|
Bcc: this.bcc(),
|
|
|
|
Signature: this.signature(),
|
|
|
|
SignatureInsertBefore: this.signatureInsertBefore() ? 1 : 0
|
|
|
|
}
|
2019-07-05 03:19:24 +08:00
|
|
|
);
|
2013-11-16 06:21:12 +08:00
|
|
|
|
2016-09-10 06:38:16 +08:00
|
|
|
return true;
|
2016-08-17 06:01:20 +08:00
|
|
|
}
|
2013-11-16 06:21:12 +08:00
|
|
|
|
2016-08-17 06:01:20 +08:00
|
|
|
clearPopup() {
|
|
|
|
this.id = '';
|
|
|
|
this.edit(false);
|
|
|
|
this.owner(false);
|
2013-12-09 23:16:58 +08:00
|
|
|
|
2016-08-17 06:01:20 +08:00
|
|
|
this.name('');
|
|
|
|
this.email('');
|
|
|
|
this.replyTo('');
|
|
|
|
this.bcc('');
|
|
|
|
this.signature('');
|
|
|
|
this.signatureInsertBefore(false);
|
2013-11-16 06:21:12 +08:00
|
|
|
|
2020-10-27 18:09:24 +08:00
|
|
|
this.emailHasError(false);
|
|
|
|
this.replyToHasError(false);
|
|
|
|
this.bccHasError(false);
|
2014-08-21 23:08:34 +08:00
|
|
|
|
2016-08-17 06:01:20 +08:00
|
|
|
this.showBcc(false);
|
|
|
|
this.showReplyTo(false);
|
2015-02-06 23:26:20 +08:00
|
|
|
|
2016-08-17 06:01:20 +08:00
|
|
|
this.submitRequest(false);
|
|
|
|
this.submitError('');
|
2016-06-30 08:02:45 +08:00
|
|
|
}
|
2016-08-17 06:01:20 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @param {?IdentityModel} oIdentity
|
|
|
|
*/
|
|
|
|
onShow(identity) {
|
|
|
|
this.clearPopup();
|
|
|
|
|
2019-07-05 03:19:24 +08:00
|
|
|
if (identity) {
|
2016-08-17 06:01:20 +08:00
|
|
|
this.edit(true);
|
|
|
|
|
|
|
|
this.id = identity.id() || '';
|
|
|
|
this.name(identity.name());
|
|
|
|
this.email(identity.email());
|
|
|
|
this.replyTo(identity.replyTo());
|
|
|
|
this.bcc(identity.bcc());
|
|
|
|
this.signature(identity.signature());
|
|
|
|
this.signatureInsertBefore(identity.signatureInsertBefore());
|
|
|
|
|
2020-07-28 23:20:14 +08:00
|
|
|
this.owner(!this.id);
|
2019-07-05 03:19:24 +08:00
|
|
|
} else {
|
2020-10-03 05:54:15 +08:00
|
|
|
this.id = Jua.randomId();
|
2016-08-17 06:01:20 +08:00
|
|
|
}
|
2016-06-30 08:02:45 +08:00
|
|
|
}
|
2015-02-08 09:11:13 +08:00
|
|
|
|
2016-08-17 06:01:20 +08:00
|
|
|
onShowWithDelay() {
|
2021-02-15 23:05:38 +08:00
|
|
|
this.owner() || this.emailFocused(true);
|
2016-06-30 08:02:45 +08:00
|
|
|
}
|
2014-08-21 23:08:34 +08:00
|
|
|
|
2016-08-17 06:01:20 +08:00
|
|
|
onHideWithDelay() {
|
|
|
|
this.clearPopup();
|
|
|
|
}
|
|
|
|
}
|