kanbanworkflowstimelinescrumrubyroadmapproject-planningproject-managementopenprojectangularissue-trackerifcgantt-chartganttbug-trackerboardsbcf
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
99 lines
3.3 KiB
99 lines
3.3 KiB
import {TableRowEditContext} from '../wp-edit-form/table-row-edit-context';
|
|
import {WorkPackageEditForm} from '../wp-edit-form/work-package-edit-form';
|
|
import {injectorBridge} from '../angular/angular-injector-bridge.functions';
|
|
import {
|
|
WorkPackageResource,
|
|
WorkPackageResourceInterface
|
|
} from '../api/api-v3/hal-resources/work-package-resource.service';
|
|
import {rowId} from '../wp-fast-table/helpers/wp-table-row-helpers';
|
|
import {States} from '../states.service';
|
|
import {WorkPackageTableSelection} from '../wp-fast-table/state/wp-table-selection.service';
|
|
import {WorkPackageTableColumnsService} from '../wp-fast-table/state/wp-table-columns.service';
|
|
import {
|
|
internalDetailsColumn,
|
|
tableRowClassName,
|
|
SingleRowBuilder, commonRowClassName
|
|
} from '../wp-fast-table/builders/rows/single-row-builder';
|
|
import {WorkPackageTable} from '../wp-fast-table/wp-fast-table';
|
|
import {QueryColumn} from '../wp-query/query-column';
|
|
import IScope = angular.IScope;
|
|
|
|
export const inlineCreateRowClassName = 'wp-inline-create-row';
|
|
export const inlineCreateCancelClassName = 'wp-table--cancel-create-link';
|
|
|
|
export class InlineCreateRowBuilder extends SingleRowBuilder {
|
|
// Injections
|
|
public states:States;
|
|
public wpTableSelection:WorkPackageTableSelection;
|
|
public wpTableColumns:WorkPackageTableColumnsService;
|
|
public I18n:op.I18n;
|
|
|
|
protected text:{ cancelButton:string };
|
|
|
|
constructor(workPackageTable: WorkPackageTable) {
|
|
super(workPackageTable);
|
|
injectorBridge(this);
|
|
|
|
this.text = {
|
|
cancelButton: this.I18n.t('js.button_cancel')
|
|
};
|
|
}
|
|
|
|
public buildCell(workPackage:WorkPackageResourceInterface, column:QueryColumn):HTMLElement {
|
|
switch (column.id) {
|
|
case internalDetailsColumn.id:
|
|
return this.buildCancelButton();
|
|
default:
|
|
return super.buildCell(workPackage, column);
|
|
}
|
|
}
|
|
|
|
public buildNew(workPackage:WorkPackageResourceInterface, form:WorkPackageEditForm):[HTMLElement, boolean] {
|
|
// Get any existing edit state for this work package
|
|
const [row, hidden] = this.buildEmpty(workPackage);
|
|
|
|
// Set editing context to table
|
|
form.editContext = new TableRowEditContext(workPackage.id, this.classIdentifier(workPackage));
|
|
this.states.editing.get(workPackage.id).putValue(form);
|
|
|
|
return [row, hidden];
|
|
}
|
|
|
|
/**
|
|
* Create an empty unattached row element for the given work package
|
|
* @param workPackage
|
|
* @returns {any}
|
|
*/
|
|
public createEmptyRow(workPackage:WorkPackageResourceInterface) {
|
|
const identifier = this.classIdentifier(workPackage);
|
|
const tr = document.createElement('tr');
|
|
tr.id = rowId(workPackage.id);
|
|
tr.dataset['workPackageId'] = workPackage.id;
|
|
tr.dataset['classIdentifier'] = identifier;
|
|
tr.classList.add(
|
|
inlineCreateRowClassName, commonRowClassName, tableRowClassName, 'issue',
|
|
identifier,
|
|
`${identifier}-table`
|
|
);
|
|
|
|
return tr;
|
|
}
|
|
|
|
protected buildCancelButton() {
|
|
const td = document.createElement('td');
|
|
td.classList.add('wp-table--cancel-create-td');
|
|
|
|
td.innerHTML = `
|
|
<a
|
|
href="javascript:"
|
|
class="${inlineCreateCancelClassName} icon icon-cancel"
|
|
aria-label="${this.text.cancelButton}">
|
|
</a>
|
|
`;
|
|
|
|
return td;
|
|
}
|
|
}
|
|
|
|
|
|
InlineCreateRowBuilder.$inject = ['states', 'wpTableSelection', 'wpTableColumns', 'I18n'];
|
|
|