Files
VisualSapfor/src/Visual_DVM_2021/Passes/All/AppendBugReportField.java

95 lines
3.6 KiB
Java
Raw Normal View History

package Visual_DVM_2021.Passes.All;
2024-10-09 23:37:58 +03:00
import Common.Current_;
2024-10-07 14:22:52 +03:00
import Common.Utils.CommonUtils;
2024-10-09 22:01:19 +03:00
import _VisualDVM.Current;
import _VisualDVM.Visual.UI;
2024-10-09 22:21:57 +03:00
import _VisualDVM.Repository.BugReport.BugReport;
import _VisualDVM.Repository.BugReport.BugReportInterface;
import _VisualDVM.Repository.EmailMessage;
import _VisualDVM.Repository.Server.ServerCode;
import _VisualDVM.Repository.Server.ServerExchangeUnit_2021;
import Visual_DVM_2021.Passes.Server.ComponentsRepositoryPass;
2024-10-09 23:37:58 +03:00
import Visual_DVM_2021.Passes.PassCode;
2023-09-17 22:13:42 +03:00
import javafx.util.Pair;
import java.util.Date;
public class AppendBugReportField extends ComponentsRepositoryPass<BugReport> {
String fieldName;
String oldValue;
String addition;
String newValue;
@Override
public String getIconPath() {
return "/icons/Append.png";
}
@Override
public String getButtonText() {
return "";
}
protected boolean canUpdate() {
return Current.getAccount().CheckAccessRights(target.sender_address, Log);
}
@Override
protected boolean canStart(Object... args) throws Exception {
2024-10-09 23:37:58 +03:00
if (Current_.Check(Log, Current.BugReport)) {
2023-09-17 22:13:42 +03:00
target = Current.getBugReport();
if (!BugReportInterface.CheckNotDraft(target,Log))
return false;
fieldName = (String) args[0];
addition = (String) args[1];
if (addition.isEmpty()) {
Log.Writeln_("Дополнение не может быть пустым.");
return false;
}
return canUpdate();
}
return false;
}
@Override
protected void ServerAction() throws Exception {
Command(new ServerExchangeUnit_2021(ServerCode.GetObjectCopyByPK, "", new Pair<>(BugReport.class, target.id)));
target.SynchronizeFields((BugReport) response.object);
oldValue = (String) BugReport.class.getField(fieldName).get(target);
2024-10-07 22:04:09 +03:00
newValue = oldValue + "\n" + CommonUtils.Brackets(CommonUtils.print_date(
2023-09-17 22:13:42 +03:00
new Date())) + " " + Current.getAccount().name
+ " : " + addition;
//2. дописываем нужное поле.
BugReport.class.getField(fieldName).set(target, newValue);
//обновляем дату.
target.change_date = new Date().getTime();
server.db.Update(target);
//3. отправляем на сервер
Command(new ServerExchangeUnit_2021(ServerCode.UpdateBugReportField, fieldName, target));
}
@Override
protected void showFinish() throws Exception {
server.db.bugReports.RefreshUI();
UI.getMainWindow().getCallbackWindow().ShowCurrentBugReport();
}
@Override
protected void performDone() throws Exception {
String message_header = BugReportInterface.getMailTitlePrefix(target);
String message_text = "";
switch (fieldName) {
default:
return;
case "description":
message_header += "описание дополнено";
message_text = target.description
;
break;
case "comment":
message_header += "комментарий дополнен";
message_text = target.comment;
break;
}
2024-10-09 23:37:58 +03:00
passes.get(PassCode.Email).Do(
2023-09-17 22:13:42 +03:00
new EmailMessage(
2024-10-07 14:22:52 +03:00
message_header + " " + CommonUtils.Brackets(Current.getAccount().name),
2023-09-17 22:13:42 +03:00
message_text,
2024-09-24 23:34:41 +03:00
BugReportInterface.getRecipients(target)
2023-09-17 22:13:42 +03:00
)
);
}
}