Двухстороннее связывание данных в jqxtreegrid - PullRequest
0 голосов
/ 04 сентября 2018

Есть ли двусторонняя привязка данных в угловом jqxtreegrid?

Я создал редактируемый jqxtreegrid из ссылки на jqxtreegrid, но когда я редактирую любой столбец в jqxtreegrid, данные не изменяются в назначенной переменной localdata.

Если я изменяю текст или код, то он не изменяется в assetClassData. Но так и должно быть. Что-то не так с моим кодом?

Вот мой код -

import { Component, ViewChild, OnInit, OnChanges, AfterViewInit } from '@angular/core';
import { jqxTreeGridComponent } from 'jqwidgets-scripts/jqwidgets-ts/angular_jqxtreegrid';
import { PageParam, SearchParam, SortParam, PagingParam } from '../shared/class/queryparam';
import { MatSnackBarConfig } from '@angular/material';
import { FormControl, Validators } from '@angular/forms';
declare var $: any;

@Component({
  selector: 'app-assetclass',
  templateUrl: './assetclass.component.html',
  styleUrls: ['./assetclass.component.css']
})
export class AssetclassComponent implements OnInit, OnChanges, AfterViewInit {
  constructor() { }
  @ViewChild('TreeGrid') treeGrid: jqxTreeGridComponent;

  rowKey = null;
  // assetClassData: AssetClass[];
  assetClassData: any[] = [{
    'AssetClassID': 1, 'AssetClassName': 'Test', 'AssetClassCode': 'Test',
    'ParentAssetClassID': 0, 'InActive': false
  }];
  PageParams: PageParam[] = [];
  SearchParams: SearchParam[] = [];
  SortParams: SortParam;
  PagingParams: PagingParam;
  PageNumber = 1;

  columns: any[] = [
    { text: 'Name', dataField: 'AssetClassName', align: 'center', width: '70%' },
    { text: 'Code', dataField: 'AssetClassCode', align: 'right', cellsAlign: 'right', width: '20%' },
    {
      text: 'Inactive', dataField: 'InActive', filtertype: 'checkedlist', align: 'center', cellsAlign: 'center', width: '10%'
      , columnType: 'template',
      createEditor: (row, cellvalue, editor, cellText, width, height) => {
        // construct the editor.
        editor.jqxCheckBox({ checked: false });
      },
      initEditor: (row, cellvalue, editor, celltext, width, height) => {
        // set the editor's current value. The callback is called each time the editor is displayed.
        editor.jqxCheckBox('checked', cellvalue);
      },
      getEditorValue: (row, cellvalue, editor) => {
        // return the editor's value.
        return editor.val();
      }
    }
  ];
  source: any =
    {
      dataType: 'json',
      dataFields: [
        { name: 'AssetClassID', type: 'number' },
        { name: 'AssetClassName', type: 'string' },
        { name: 'ParentAssetClassID', type: 'number' },
        { name: 'AssetClassCode', type: 'string' },
        { name: 'InActive', type: 'number' }
      ],
      hierarchy:
      {
        keyDataField: { name: 'AssetClassID' },
        parentDataField: { name: 'ParentAssetClassID' }
      },
      id: 'AssetClassID',
      localData: this.assetClassData,
      addRow: (rowID, rowData, position, parentID, commit) => {
        // synchronize with the server - send insert command
        // call commit with parameter true if the synchronization with the server is successfull
        // and with parameter false if the synchronization failed.
        // you can pass additional argument to the commit callback which represents the new ID if it is generated from a DB.
        this.newRowID = rowID;
        commit(true);
      },
      updateRow: (rowID, rowData, commit) => {
        // synchronize with the server - send update command
        // call commit with parameter true if the synchronization with the server is successful 
        // and with parameter false if the synchronization failed.
        commit(true);
      },
      deleteRow: (rowID, commit) => {
        // synchronize with the server - send delete command
        // call commit with parameter true if the synchronization with the server is successful 
        // and with parameter false if the synchronization failed.
        commit(true);
      }
    };
  dataAdapter: any = new jqx.dataAdapter(this.source);
  newRowID = null;
  theme: String = '';
  buttonsObject: any = null;

  ngOnInit() {
  }

  ngOnChanges() {
    // this.loadList();
  }

  ngAfterViewInit(): void {
    this.treeGrid.createComponent();
  }

  updateButtons(action: string, buttons: any): void {
    switch (action) {
      case 'Select':
        buttons.addButton.jqxButton({ disabled: false });
        buttons.deleteButton.jqxButton({ disabled: false });
        buttons.editButton.jqxButton({ disabled: false });
        buttons.cancelButton.jqxButton({ disabled: true });
        buttons.updateButton.jqxButton({ disabled: true });
        break;
      case 'Unselect':
        buttons.addButton.jqxButton({ disabled: true });
        buttons.deleteButton.jqxButton({ disabled: true });
        buttons.editButton.jqxButton({ disabled: true });
        buttons.cancelButton.jqxButton({ disabled: true });
        buttons.updateButton.jqxButton({ disabled: true });
        break;
      case 'Edit':
        buttons.addButton.jqxButton({ disabled: true });
        buttons.deleteButton.jqxButton({ disabled: true });
        buttons.editButton.jqxButton({ disabled: true });
        buttons.cancelButton.jqxButton({ disabled: false });
        buttons.updateButton.jqxButton({ disabled: false });
        break;
      case 'End Edit':
        buttons.addButton.jqxButton({ disabled: false });
        buttons.deleteButton.jqxButton({ disabled: false });
        buttons.editButton.jqxButton({ disabled: false });
        buttons.cancelButton.jqxButton({ disabled: true });
        buttons.updateButton.jqxButton({ disabled: true });
        console.log(this.assetClassData);
        break;
    }
  }
  renderToolbar = (toolBar) => {
    const toTheme = (className) => {
      if (this.theme === '') {
        return className;
      }
      return className + ' ' + className + '-' + this.theme;
    };
    // appends buttons to the status bar.
    const container: any = $('<div style="overflow: hidden; position: relative; height: 100%; width: 100%;"></div>');
    const buttonTemplate: any = '<div style="float: left; padding: 3px; margin: 2px;">' +
      '<div style="margin: 4px; width: 16px; height: 16px;"></div></div>';
    const addButton: any = $(buttonTemplate);
    const editButton: any = $(buttonTemplate);
    const deleteButton: any = $(buttonTemplate);
    const cancelButton: any = $(buttonTemplate);
    const updateButton: any = $(buttonTemplate);
    container.append(addButton);
    container.append(editButton);
    container.append(deleteButton);
    container.append(cancelButton);
    container.append(updateButton);
    toolBar.append(container);
    addButton.jqxButton({ cursor: 'pointer', enableDefault: false, disabled: true, height: 25, width: 25 });
    addButton.find('div:first').addClass(toTheme('jqx-icon-plus'));
    addButton.jqxTooltip({ position: 'bottom', content: 'Add' });
    editButton.jqxButton({ cursor: 'pointer', disabled: true, enableDefault: false, height: 25, width: 25 });
    editButton.find('div:first').addClass(toTheme('jqx-icon-edit'));
    editButton.jqxTooltip({ position: 'bottom', content: 'Edit' });
    deleteButton.jqxButton({ cursor: 'pointer', disabled: true, enableDefault: false, height: 25, width: 25 });
    deleteButton.find('div:first').addClass(toTheme('jqx-icon-delete'));
    deleteButton.jqxTooltip({ position: 'bottom', content: 'Delete' });
    updateButton.jqxButton({ cursor: 'pointer', disabled: true, enableDefault: false, height: 25, width: 25 });
    updateButton.find('div:first').addClass(toTheme('jqx-icon-save'));
    updateButton.jqxTooltip({ position: 'bottom', content: 'Save Changes' });
    cancelButton.jqxButton({ cursor: 'pointer', disabled: true, enableDefault: false, height: 25, width: 25 });
    cancelButton.find('div:first').addClass(toTheme('jqx-icon-cancel'));
    cancelButton.jqxTooltip({ position: 'bottom', content: 'Cancel' });

    this.buttonsObject = {
      addButton: addButton,
      editButton: editButton,
      deleteButton: deleteButton,
      cancelButton: cancelButton,
      updateButton: updateButton,
    };

    addButton.click((event) => {
      if (!addButton.jqxButton('disabled')) {
        this.treeGrid.expandRow(this.rowKey);
        // add new empty row.
        this.treeGrid.addRow(null, {}, 'first', this.rowKey);
        // select the first row and clear the selection.
        this.treeGrid.clearSelection();
        this.treeGrid.selectRow(this.newRowID);
        // edit the new row.
        this.treeGrid.beginRowEdit(this.newRowID);
        this.updateButtons('add', this.buttonsObject);
      } else {
        this.treeGrid.addRow(null, {}, 'first', '0');
      }
    });
    cancelButton.click((event) => {
      if (!cancelButton.jqxButton('disabled')) {
        // cancel changes.
        this.treeGrid.endRowEdit(this.rowKey, true);
      }
    });
    updateButton.click((event) => {
      if (!updateButton.jqxButton('disabled')) {
        this.treeGrid.endRowEdit(this.rowKey, false);
      }
    });
    editButton.click(() => {
      if (!editButton.jqxButton('disabled')) {
        this.treeGrid.beginRowEdit(this.rowKey);
        this.updateButtons('edit', this.buttonsObject);
      }
    });
    deleteButton.click(() => {
      if (!deleteButton.jqxButton('disabled')) {
        const selection = this.treeGrid.getSelection();
        if (selection.length > 1) {
          for (let i = 0; i < selection.length; i++) {
            const key = this.treeGrid.getKey(selection[i]);
            this.treeGrid.deleteRow(key);
          }
        } else {
          this.treeGrid.deleteRow(this.rowKey);
        }
        this.updateButtons('delete', this.buttonsObject);
      }
    });
  }
  rowSelect(event: any): void {
    const args = event.args;
    this.rowKey = args.key;
    this.updateButtons('Select', this.buttonsObject);
  }
  rowUnselect(event: any): void {
    this.updateButtons('Unselect', this.buttonsObject);
  }
  rowEndEdit(event: any): void {
    this.updateButtons('End Edit', this.buttonsObject);
  }
  rowBeginEdit(event: any): void {
    this.updateButtons('Edit', this.buttonsObject);
  }
  getWidth(): any {
    if (document.body.offsetWidth < 850) {
      return '90%';
    }
    return 850;
  }
}
...