| | |
| | | import com.gitblit.tickets.TicketResponsible;
|
| | | import com.gitblit.utils.StringUtils;
|
| | | import com.gitblit.wicket.GitBlitWebSession;
|
| | | import com.gitblit.wicket.SafeTextModel;
|
| | | import com.gitblit.wicket.SafeTextModel.Mode;
|
| | | import com.gitblit.wicket.WicketUtils;
|
| | | import com.gitblit.wicket.panels.MarkdownTextArea;
|
| | |
|
| | |
| | |
|
| | | private Label descriptionPreview;
|
| | |
|
| | | private IModel<TicketModel.Priority> priorityModel;
|
| | |
|
| | | private IModel<TicketModel.Severity> severityModel;
|
| | |
|
| | | public NewTicketPage(PageParameters params) {
|
| | | super(params);
|
| | |
|
| | |
| | | }
|
| | |
|
| | | typeModel = Model.of(TicketModel.Type.defaultType);
|
| | | titleModel = SafeTextModel.none();
|
| | | topicModel = SafeTextModel.none();
|
| | | titleModel = Model.of();
|
| | | topicModel = Model.of();
|
| | | mergeToModel = Model.of(Repository.shortenRefName(getRepositoryModel().mergeTo));
|
| | | responsibleModel = Model.of();
|
| | | milestoneModel = Model.of();
|
| | | severityModel = Model.of(TicketModel.Severity.defaultSeverity);
|
| | | priorityModel = Model.of(TicketModel.Priority.defaultPriority);
|
| | |
|
| | | setStatelessHint(false);
|
| | | setOutputMarkupId(true);
|
| | |
| | | form.add(new DropDownChoice<TicketModel.Type>("type", typeModel, Arrays.asList(TicketModel.Type.choices())));
|
| | | form.add(new TextField<String>("title", titleModel));
|
| | | form.add(new TextField<String>("topic", topicModel));
|
| | | form.add(new DropDownChoice<TicketModel.Severity>("severity", severityModel, Arrays.asList(TicketModel.Severity.choices())));
|
| | |
|
| | | final SafeTextModel markdownPreviewModel = new SafeTextModel(Mode.none);
|
| | | final IModel<String> markdownPreviewModel = Model.of();
|
| | | descriptionPreview = new Label("descriptionPreview", markdownPreviewModel);
|
| | | descriptionPreview.setEscapeModelStrings(false);
|
| | | descriptionPreview.setOutputMarkupId(true);
|
| | |
| | | milestone.add(new DropDownChoice<TicketMilestone>("milestone", milestoneModel, milestones));
|
| | | form.add(milestone.setVisible(!milestones.isEmpty()));
|
| | |
|
| | | // priority
|
| | | Fragment priority = new Fragment("priority", "priorityFragment", this);
|
| | | priority.add(new DropDownChoice<TicketModel.Priority>("priority", priorityModel, Arrays.asList(TicketModel.Priority.choices())));
|
| | | form.add(priority);
|
| | |
|
| | | // integration branch
|
| | | List<String> branches = new ArrayList<String>();
|
| | | for (String branch : getRepositoryModel().getLocalBranches()) {
|
| | |
| | | form.add(new Label("responsible").setVisible(false));
|
| | | form.add(new Label("milestone").setVisible(false));
|
| | | form.add(new Label("mergeto").setVisible(false));
|
| | | form.add(new Label("priority").setVisible(false));
|
| | | }
|
| | |
|
| | | form.add(new AjaxButton("create") {
|
| | |
| | | change.setField(Field.milestone, milestone.name);
|
| | | }
|
| | |
|
| | | // severity
|
| | | TicketModel.Severity severity = TicketModel.Severity.defaultSeverity;
|
| | | if (severityModel.getObject() != null) {
|
| | | severity = severityModel.getObject();
|
| | | }
|
| | | change.setField(Field.severity, severity);
|
| | |
|
| | | // priority
|
| | | TicketModel.Priority priority = TicketModel.Priority.defaultPriority;
|
| | | if (priorityModel.getObject() != null) {
|
| | | priority = priorityModel.getObject();
|
| | | }
|
| | | change.setField(Field.priority, priority);
|
| | |
|
| | | // integration branch
|
| | | String mergeTo = mergeToModel.getObject();
|
| | | if (!StringUtils.isEmpty(mergeTo)) {
|
| | |
| | | if (ticket != null) {
|
| | | TicketNotifier notifier = app().tickets().createNotifier();
|
| | | notifier.sendMailing(ticket);
|
| | | setResponsePage(TicketsPage.class, WicketUtils.newObjectParameter(getRepositoryModel().name, "" + ticket.number));
|
| | |
|
| | | redirectTo(TicketsPage.class, WicketUtils.newObjectParameter(getRepositoryModel().name, "" + ticket.number));
|
| | | } else {
|
| | | // TODO error
|
| | | }
|