2024-10-14 12:14:01 +03:00
|
|
|
|
package _VisualDVM.Passes.All;
|
2024-10-11 00:00:30 +03:00
|
|
|
|
import Common.Utils.Utils_;
|
2024-10-07 00:58:29 +03:00
|
|
|
|
import _VisualDVM.Global;
|
2024-10-14 15:19:13 +03:00
|
|
|
|
import _VisualDVM.Passes.PassCode;
|
|
|
|
|
|
import _VisualDVM.Passes.Server.ComponentsRepositoryPass;
|
2024-10-09 22:21:57 +03:00
|
|
|
|
import _VisualDVM.Repository.BugReport.BugReport;
|
|
|
|
|
|
import _VisualDVM.Repository.BugReport.BugReportState;
|
|
|
|
|
|
import _VisualDVM.Repository.EmailMessage;
|
|
|
|
|
|
import _VisualDVM.Repository.Server.ServerCode;
|
|
|
|
|
|
import _VisualDVM.Repository.Server.ServerExchangeUnit_2021;
|
2024-10-14 15:19:13 +03:00
|
|
|
|
import _VisualDVM.Utils;
|
2023-09-17 22:13:42 +03:00
|
|
|
|
import javafx.util.Pair;
|
|
|
|
|
|
|
|
|
|
|
|
import java.io.Serializable;
|
|
|
|
|
|
import java.util.Date;
|
|
|
|
|
|
import java.util.Vector;
|
|
|
|
|
|
public class UpdateBugReportField extends ComponentsRepositoryPass<BugReport> {
|
|
|
|
|
|
Vector<String> fieldNames = new Vector<>();
|
|
|
|
|
|
Vector<Serializable> fieldValues = new Vector<>();
|
|
|
|
|
|
String old_description = "";
|
|
|
|
|
|
String old_comment = "";
|
|
|
|
|
|
protected boolean canUpdate() {
|
2025-02-01 22:24:15 +03:00
|
|
|
|
return target.canModify(Global.mainModule.getAccount(),Log);
|
2023-09-17 22:13:42 +03:00
|
|
|
|
}
|
|
|
|
|
|
@Override
|
|
|
|
|
|
protected boolean canStart(Object... args) throws Exception {
|
2024-10-25 02:08:23 +03:00
|
|
|
|
if (!Global.componentsServer.db.bugReports.getUI().CheckCurrent(Log))
|
2023-09-17 22:13:42 +03:00
|
|
|
|
return false;
|
|
|
|
|
|
old_description = "";
|
|
|
|
|
|
old_comment = "";
|
|
|
|
|
|
//--
|
2024-10-24 23:40:24 +03:00
|
|
|
|
target = Global.componentsServer.db.bugReports.getUI().getCurrent();
|
2023-09-17 22:13:42 +03:00
|
|
|
|
fieldNames.clear();
|
|
|
|
|
|
fieldValues.clear();
|
|
|
|
|
|
for (int i = 0; i < args.length; ++i) {
|
|
|
|
|
|
if (i % 2 == 0) {
|
|
|
|
|
|
fieldNames.add((String) args[i]);
|
|
|
|
|
|
} else {
|
|
|
|
|
|
fieldValues.add((Serializable) args[i]);
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
if (fieldNames.size() != fieldValues.size()) {
|
|
|
|
|
|
Log.Writeln("Неверный формат аргументов");
|
|
|
|
|
|
return false;
|
|
|
|
|
|
}
|
|
|
|
|
|
if (target.state.equals(BugReportState.draft)) {
|
|
|
|
|
|
//если черновик, сразу меняем и не заморачиваемся, если нужно.
|
|
|
|
|
|
//тут проход все равно сугубо интерфейсный.
|
|
|
|
|
|
for (int i = 0; i < fieldNames.size(); ++i)
|
|
|
|
|
|
BugReport.class.getField(fieldNames.get(i)).set(target, fieldValues.get(i));
|
|
|
|
|
|
target.change_date = new Date().getTime();
|
|
|
|
|
|
server.db.Update(target);
|
2024-10-25 00:43:03 +03:00
|
|
|
|
server.db.bugReports.getUI().RedrawControl();
|
2024-10-15 02:32:52 +03:00
|
|
|
|
Global.mainModule.getUI().getMainWindow().getCallbackWindow().ShowCurrentBugReport();
|
2023-09-17 22:13:42 +03:00
|
|
|
|
} else
|
|
|
|
|
|
return canUpdate();
|
|
|
|
|
|
return false;
|
|
|
|
|
|
}
|
|
|
|
|
|
@Override
|
|
|
|
|
|
protected void ServerAction() throws Exception {
|
|
|
|
|
|
//1. прежде чем дополнять поле(комментарий или описание) следует скачать с сервера
|
|
|
|
|
|
//последнюю версию этого баг репорта.
|
|
|
|
|
|
//все это должно быть в рамках одной транзакции с сервером!
|
|
|
|
|
|
Command(new ServerExchangeUnit_2021(ServerCode.GetObjectCopyByPK, "", new Pair<>(BugReport.class, target.id)));
|
2025-02-03 15:19:53 +03:00
|
|
|
|
target.SynchronizeFields((BugReport) server_response.object);
|
2023-09-17 22:13:42 +03:00
|
|
|
|
for (int i = 0; i < fieldNames.size(); ++i) {
|
|
|
|
|
|
String fieldName = fieldNames.get(i);
|
|
|
|
|
|
switch (fieldName) {
|
|
|
|
|
|
case "comment":
|
|
|
|
|
|
old_comment = (String) BugReport.class.getField(fieldName).get(target);
|
|
|
|
|
|
break;
|
|
|
|
|
|
case "description":
|
|
|
|
|
|
old_description = (String) BugReport.class.getField(fieldName).get(target);
|
|
|
|
|
|
break;
|
|
|
|
|
|
}
|
|
|
|
|
|
BugReport.class.getField(fieldNames.get(i)).set(target, fieldValues.get(i));
|
|
|
|
|
|
}
|
|
|
|
|
|
target.change_date = new Date().getTime();
|
|
|
|
|
|
//3. отправляем на сервер
|
|
|
|
|
|
Command(new ServerExchangeUnit_2021(ServerCode.UpdateBugReport, "", target));
|
|
|
|
|
|
server.db.Update(target);
|
|
|
|
|
|
}
|
|
|
|
|
|
@Override
|
|
|
|
|
|
protected void showFinish() throws Exception {
|
2024-10-25 00:43:03 +03:00
|
|
|
|
Global.componentsServer.db.bugReports.getUI().RedrawControl();
|
2024-10-15 02:32:52 +03:00
|
|
|
|
Global.mainModule.getUI().getMainWindow().getCallbackWindow().ShowCurrentBugReport();
|
2023-09-17 22:13:42 +03:00
|
|
|
|
}
|
|
|
|
|
|
@Override
|
|
|
|
|
|
protected void performDone() throws Exception {
|
2024-10-22 13:36:57 +03:00
|
|
|
|
String message_header = target.getMailTitlePrefix();
|
2023-09-17 22:13:42 +03:00
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
|
String message_text = "DUMMY TEXT: ";
|
|
|
|
|
|
Random random = new Random();
|
|
|
|
|
|
for (int k = 0; k < random.nextInt(200); ++k)
|
|
|
|
|
|
message_text += random.nextDouble();
|
|
|
|
|
|
|
|
|
|
|
|
*/
|
|
|
|
|
|
String message_text = String.join("\n",
|
|
|
|
|
|
target.description,
|
|
|
|
|
|
target.comment);
|
|
|
|
|
|
if (fieldNames.size() >= 1) {
|
|
|
|
|
|
switch (fieldNames.get(0)) {
|
|
|
|
|
|
case "sender_address":
|
|
|
|
|
|
case "sender_name":
|
|
|
|
|
|
case "targets":
|
|
|
|
|
|
case "percentage":
|
|
|
|
|
|
return;
|
|
|
|
|
|
case "description":
|
|
|
|
|
|
message_header += "описание изменено";
|
|
|
|
|
|
message_text = Utils.compareTexts(old_description, target.description);
|
|
|
|
|
|
break;
|
|
|
|
|
|
case "comment":
|
|
|
|
|
|
message_header += "комментарий изменён";
|
|
|
|
|
|
message_text = Utils.compareTexts(old_comment, target.comment);
|
|
|
|
|
|
break;
|
|
|
|
|
|
case "executor":
|
|
|
|
|
|
message_header += target.executor + " назначается исполнителем";
|
|
|
|
|
|
break;
|
|
|
|
|
|
case "state":
|
2024-10-11 00:00:30 +03:00
|
|
|
|
message_header += "состояние изменилось на " + Utils_.Brackets(target.state.getDescription());
|
2023-09-17 22:13:42 +03:00
|
|
|
|
break;
|
|
|
|
|
|
}
|
2024-11-27 02:42:26 +03:00
|
|
|
|
EmailMessage message = new EmailMessage(
|
|
|
|
|
|
message_header + " " + Utils_.Brackets(Global.mainModule.getAccount().name),
|
|
|
|
|
|
message_text
|
2023-09-17 22:13:42 +03:00
|
|
|
|
);
|
2024-11-28 16:52:17 +03:00
|
|
|
|
Global.mainModule.getPass(PassCode.Email).Do(
|
|
|
|
|
|
message,
|
|
|
|
|
|
server.db.subscribers.checkRecipients(target.getRecipients())
|
|
|
|
|
|
);
|
2023-09-17 22:13:42 +03:00
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|