OpenProject is the leading open source project management software.
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.
openproject/frontend/app/components/wp-inline-create/inline-create-row-builder.ts

95 lines
3.3 KiB

import {WorkPackageTableRow} from '../wp-fast-table/wp-table.interfaces';
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} from '../api/api-v3/hal-resources/work-package-resource.service';
import {checkedClassName} from '../wp-fast-table/builders/ui-state-link-builder';
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 {CellBuilder} from '../wp-fast-table/builders/cell-builder';
import {
internalDetailsColumn,
rowClassName,
SingleRowBuilder
} from '../wp-fast-table/builders/rows/single-row-builder';
import IScope = angular.IScope;
import {scopeDestroyed$} from "../../helpers/angular-rx-utils";
import {WorkPackageTable} from "../wp-fast-table/wp-fast-table";
import {QueryColumn} from '../api/api-v3/hal-resources/query-resource.service';
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(scope: IScope, workPackageTable: WorkPackageTable) {
super(scopeDestroyed$(scope), workPackageTable);
injectorBridge(this);
this.text = {
cancelButton: this.I18n.t('js.button_cancel')
};
}
public buildCell(workPackage:WorkPackageResource, column:QueryColumn):HTMLElement {
switch (column.id) {
case internalDetailsColumn.id:
return this.buildCancelButton();
default:
return super.buildCell(workPackage, column);
}
}
public buildNew(workPackage:WorkPackageResource, form:WorkPackageEditForm):HTMLElement {
// Get any existing edit state for this work package
const row = this.buildEmpty(workPackage);
// Set editing context to table
form.editContext = new TableRowEditContext(workPackage.id);
this.states.editing.get(workPackage.id).putValue(form);
return row;
}
/**
* Create an empty unattached row element for the given work package
* @param workPackage
* @returns {any}
*/
public createEmptyRow(workPackage:WorkPackageResource) {
const tr = document.createElement('tr');
tr.id = rowId(workPackage.id);
tr.dataset['workPackageId'] = workPackage.id;
tr.classList.add(inlineCreateRowClassName, rowClassName, 'wp--row', 'issue');
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'];