Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Teams Complex Widget #565

Open
wants to merge 172 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
172 commits
Select commit Hold shift + click to select a range
5d68620
add complex team widget and display multiple levels
nh758 Sep 9, 2024
ca634dc
use new settings to display node name and select top
nh758 Sep 10, 2024
2b0f411
add drag & drop editting
nh758 Sep 10, 2024
a14c734
wip styling
nh758 Sep 11, 2024
85670b2
add new teams
nh758 Sep 25, 2024
3a8f21c
add ability to edit teams
nh758 Sep 27, 2024
6453843
add ability to delete teams
nh758 Sep 27, 2024
7b82d5e
move actions to buttons on the team node
nh758 Sep 30, 2024
e857438
add unit tests
nh758 Oct 3, 2024
2bf6e85
update core
nh758 Oct 4, 2024
963d6b4
[wip] initial Netsuite object definitions
Hiro-Nakamura Oct 11, 2024
772201b
Add node content and display
Oct 15, 2024
a17fb78
Merge nh branch
Oct 15, 2024
d1c025e
[wip] base netsuite objects perform CRUD operations
Hiro-Nakamura Oct 16, 2024
de000a0
Merge commit '4f5b6008026dfd181d29b5be260488a035ff08ff' into jh/Netsuite
Hiro-Nakamura Oct 16, 2024
e4941d3
[wip] make sure API objects don't trigger DB migrations
Hiro-Nakamura Oct 18, 2024
2c07c2f
fix edit checkbox field in grid
nh758 Oct 7, 2024
c2d247a
style node by startegy & edit strategy
nh758 Oct 21, 2024
de74242
update core
nh758 Oct 21, 2024
1f2a182
update tests to cover strategy color
nh758 Oct 21, 2024
5bffd41
[fix] reference the PK() instead of hardcoding a `uuid` lookup value
Hiro-Nakamura Oct 22, 2024
e3a06ba
add team filtering options
nh758 Oct 23, 2024
b6e443e
test the team filter
nh758 Oct 24, 2024
4d743fe
apply strategy style on add/edit team
nh758 Oct 24, 2024
f333d0a
fix unit tests
nh758 Oct 25, 2024
b75d027
WIP
Oct 28, 2024
8125d05
Merge nh/teams-chart and fix conflict
Oct 29, 2024
36b1e0e
Fix the dropToCreate bug
Oct 29, 2024
d9adbc3
Merge commit 'aacbbda43f1d36c545d9b84eea6b8a09d0f524f4' into jh/Netsuite
Hiro-Nakamura Oct 30, 2024
f9a5d46
WIP
Oct 30, 2024
5e7b0a4
Merge commit '3d69e541f3c26b6472b95f0c7bca4f95ae49c25c' into jh/Netsuite
Hiro-Nakamura Oct 31, 2024
e5e7fa2
Merge commit 'fc32f2415ad5ec6ff78aedd18025ea3a342970e0' into jh/Netsuite
Hiro-Nakamura Nov 1, 2024
9b0d982
[wip] Netsuite objects respond to an Object Info request
Hiro-Nakamura Nov 3, 2024
c53c588
[fix] comparison between old and new values to be reduced to PKs
Hiro-Nakamura Nov 3, 2024
d0cc8d2
[sync] with core
Hiro-Nakamura Nov 3, 2024
27c1592
Merge commit 'de3008cae837f227f554fbb9facc70223722335b' into jh/Netsuite
Hiro-Nakamura Nov 6, 2024
2d16b4b
Merge master
Nov 6, 2024
183c447
Drag and drop content
Nov 18, 2024
e9c4068
Merge commit '27037015d1270c1c57dee0002477fee4b0dbe8f4' into jh/Netsuite
Hiro-Nakamura Nov 18, 2024
8a53b7d
Merge commit 'f333d0aa5440f035d5c9435666ebe77c775f717e' into jh/Netsuite
Hiro-Nakamura Nov 18, 2024
1cb989d
Merge pull request #583 from digi-serve/guy/team-widget
nh758 Nov 18, 2024
5efe68a
Merge branch 'nh/teams-chart' into jh/Netsuite
nh758 Nov 18, 2024
feaf532
Team Widget can edit assignments
Nov 19, 2024
f291eee
Fix not declared param bug
Nov 19, 2024
4f82b22
Fix the compared value bug
Nov 19, 2024
c7d7ea2
Merge commit '90c3d2063e62737d9f4e23fa85982035d668aaaf' into jh/Netsuite
Hiro-Nakamura Nov 20, 2024
38d286a
Merge pull request #586 from digi-serve/guy/team-widget
guyyoo Nov 20, 2024
f25ad89
Fix extra rendering node bug and prevent droping nodes in content area
Nov 21, 2024
9547b7f
Merge pull request #588 from digi-serve/guy/team-widget
guyyoo Nov 21, 2024
12beedf
update core
nh758 Nov 21, 2024
972024a
Merge pull request #584 from digi-serve/jh/Netsuite
nh758 Nov 21, 2024
2464b5a
fix data types to match real data
nh758 Nov 22, 2024
2534ea9
work on chart loading performance
nh758 Nov 22, 2024
5c5085c
Merge pull request #589 from digi-serve/nh/team-fixes
nh758 Nov 22, 2024
e3a6dab
[WIP] Content filter
Nov 25, 2024
5a7afde
Merge latest nh/teams-chart
Nov 25, 2024
278e43c
Fix dropping content data
Nov 25, 2024
d74b55c
Fix typo
Nov 25, 2024
266249f
Merge pull request #590 from digi-serve/guy/team-widget
guyyoo Nov 25, 2024
766aa7c
Merge branch 'master' into nh/teams-chart
nh758 Nov 26, 2024
92b6b3d
Data pannel displayed by object label reference
Nov 26, 2024
c2b0622
Merge branch 'nh/teams-chart' into guy/team-widget
Nov 26, 2024
4406b9d
Adjust list's item position
Nov 26, 2024
1528b17
add entity and attach to creates
nh758 Nov 26, 2024
e8342f0
Content filter and fix the collapse team node bug
Nov 27, 2024
80e419a
Merge branch 'nh/teams-chart' into guy/team-widget
Nov 27, 2024
96bd860
Mapping data and types
Nov 28, 2024
e4d7ef7
Merge pull request #593 from digi-serve/guy/team-widget
guyyoo Nov 28, 2024
3add1c2
Add start date and end date fields
Dec 3, 2024
779e36e
Merge pull request #595 from digi-serve/guy/team-widget
guyyoo Dec 3, 2024
900d34d
UI improvements
Dec 4, 2024
c9a56f5
fix strategy on add/edit team
nh758 Nov 27, 2024
86035de
fix can inactivate logic
nh758 Nov 28, 2024
eab25a5
Merge pull request #596 from digi-serve/guy/team-widget
guyyoo Dec 4, 2024
b1c8011
Fix label and fix limit edit form's fields
Dec 6, 2024
683f1a6
Fix the edit assignment issue
Dec 9, 2024
68b9eac
Merge pull request #597 from digi-serve/guy/team-widget
guyyoo Dec 9, 2024
27f457a
fix only show sstrategies from the selected entity
nh758 Dec 6, 2024
6cf49d0
style edit team form to match widget
nh758 Dec 6, 2024
0461163
disable team edit/add submit until form is valid
nh758 Dec 6, 2024
1077b13
use sub strategy code for strategy label
nh758 Dec 9, 2024
002fc24
fix filter by strategy and cleanup filter ui
nh758 Dec 9, 2024
a67cd54
Still get undefined columns
Dec 9, 2024
b8700c3
Merge pull request #600 from digi-serve/guy/team-widget
guyyoo Dec 9, 2024
3fd6143
add loading ui
nh758 Dec 11, 2024
ec09d1b
prevent uncessary call to cursorChange when populating
nh758 Dec 11, 2024
04fd164
drop moves assingment without chart refresh
nh758 Dec 12, 2024
b52c56e
move content ui to it's own function
nh758 Dec 12, 2024
81865fe
drag from sidebar doesn not refresh the whole chart
nh758 Dec 13, 2024
b18f2fd
Hardcode date end filter includes null value
Dec 13, 2024
12cf5e6
Sort fields on the editing assignment page
Dec 15, 2024
99c53d2
New hiding popup logic
Dec 17, 2024
f11e2ab
Change Submit to Save
Dec 17, 2024
c73b16a
Fix missing popup logic
Dec 17, 2024
212fb43
Hardcode date start filter includes NOT NULL values
Dec 17, 2024
c7a0c0b
PK could be a string of a number
Dec 17, 2024
34a7a24
Fix team UI layouts
Dec 18, 2024
b8304a6
reduce requests to load content data
nh758 Dec 18, 2024
82bf263
Merge pull request #603 from digi-serve/guy/team-widget
guyyoo Dec 18, 2024
4bbbe63
Disable the zoom feature
Dec 20, 2024
ec633bd
Merge nh/teams-chart
Dec 20, 2024
571fd18
Merge nh/teams-performance, fix data update and date type bugs
Dec 23, 2024
e3959ff
Fix connection field rendering in content form
Dec 23, 2024
2d074dc
Close popup method, the drop from panel bug, hardcode for the employe…
Dec 23, 2024
6b3e0f8
Save position when chart is refreshed
Dec 24, 2024
83ddc34
Sort and update the panel after update
Dec 24, 2024
f118d5a
Fix styles
Dec 24, 2024
cb64885
Add confirm popup for changing content form data
Dec 24, 2024
b989584
Fix bug the chart does not load sometimes
Dec 24, 2024
4df800b
Merge pull request #606 from digi-serve/guy/team-widget
guyyoo Dec 24, 2024
257292b
Merge pull request #605 from digi-serve/nh/teams-performance
guyyoo Dec 24, 2024
0538d1f
Fix bug typo and some performance improvements
Dec 24, 2024
09aca4f
Merge pull request #607 from digi-serve/guy/team-widget
guyyoo Dec 24, 2024
e5461ee
Paging and optimizing the data panel load
Dec 26, 2024
53ca533
Improving performance and refreshing data panels
Jan 2, 2025
107c9ba
Fix css
Jan 2, 2025
f6ee1b6
Merge pull request #608 from digi-serve/guy/team-widget
guyyoo Jan 2, 2025
19901c8
Optimize and fix paging bugs, the entity cursor
Jan 3, 2025
7f386f6
Optimize render and refresh and the changing cursor
Jan 5, 2025
10d3b5b
Merge branch 'master' into nh/teams-chart
nh758 Jan 6, 2025
5fbf453
Merge branch 'master' into nh/teams-chart
nh758 Jan 6, 2025
b19c891
Refactor the filter feature
Jan 6, 2025
f411292
Merge pull request #611 from digi-serve/guy/team-widget
guyyoo Jan 7, 2025
3a7fb09
apply styles to the data panel
nh758 Jan 8, 2025
6767c64
resize widget when screen changes
nh758 Jan 8, 2025
b8abc55
fix populating filter complex ui with in query filters
nh758 Jan 8, 2025
f14fbe3
fix populating filter complex ui with in query filters
nh758 Jan 8, 2025
a5bc9aa
Merge branch 'master' into nh/teams-panel-style
nh758 Jan 8, 2025
f506bf7
Merge pull request #612 from digi-serve/nh/teams-panel-style
nh758 Jan 8, 2025
45fb608
Fix the typo bug, End Date validation, form type convertion and warni…
Jan 8, 2025
f791e82
Merge pull request #614 from digi-serve/guy/team-widget
guyyoo Jan 9, 2025
df70f49
Fix the new data panel list render bugs
Jan 9, 2025
08e15a6
Merge pull request #616 from digi-serve/guy/team-widget
guyyoo Jan 9, 2025
efea240
Hide inactive data
Jan 9, 2025
b8517e7
Merge pull request #617 from digi-serve/guy/team-widget
guyyoo Jan 9, 2025
9062cbd
Fix empty chartData error, Change data panel filter by tab label -> t…
Jan 9, 2025
a200f5b
Hot fix for lost data DC
Jan 9, 2025
5a42636
Merge pull request #618 from digi-serve/guy/team-widget
guyyoo Jan 9, 2025
2c979aa
sort drop down by label and allow type to filter
nh758 Jan 9, 2025
3378540
Merge pull request #619 from digi-serve/nh/data-select-sort
nh758 Jan 10, 2025
d4d77fd
Fix the chart exist after switch to empty chart entity and the team i…
Jan 10, 2025
7085d8a
Merge pull request #621 from digi-serve/guy/team-widget
guyyoo Jan 10, 2025
4df1b63
fix respond to window resize
nh758 Jan 13, 2025
f66f778
fix: hide popup when swicthing to another page
nh758 Jan 14, 2025
6e43546
UI fixes, optimize things and fix bugs
Jan 16, 2025
7bfd290
Merge pull request #625 from digi-serve/guy/team-widget
guyyoo Jan 16, 2025
d729452
Sort the data panel by lastname and convert to lowercase before sort
Jan 17, 2025
fa37869
Fix the bug missing the param
Jan 17, 2025
26d8f36
Hide a trash can when there is at least one assignment
Jan 17, 2025
5ca6148
Can not inactive if there is an assignment on the team
Jan 17, 2025
b7a7144
when drag from employee list don't end existing assignment
nh758 Jan 16, 2025
dc1591b
Fix conection field render and hardcode for the Role Type filter
Jan 17, 2025
95bc31d
Fix the bug that the add/edit team popup is alway the first time crea…
Jan 17, 2025
524f64d
Validate End Date > Start Date
Jan 17, 2025
0d09a91
Fix sort
Jan 20, 2025
197607e
Merge branch 'nh/teams-chart' into guy/team-widget
Jan 20, 2025
a03632d
Merge pull request #628 from digi-serve/guy/team-widget
guyyoo Jan 20, 2025
5b6f177
Fix the refresh param
Jan 20, 2025
4edc0a4
Fix the bug the data panal record does not exist while paging
Jan 21, 2025
d7fa1ba
Merge pull request #629 from digi-serve/guy/team-widget
guyyoo Jan 21, 2025
0664f71
Fix the team delete logic if there are any assignments ever
Jan 21, 2025
9ac7162
Merge pull request #630 from digi-serve/guy/team-widget
guyyoo Jan 21, 2025
53fa0c5
Adust assignment layouts
Jan 22, 2025
f8ffd88
Allow blank date validation
Jan 22, 2025
eabf2ba
Only show Job Title + container when there is one
Jan 22, 2025
985871a
Prevent creating assignment for the same staff on the same team
Jan 22, 2025
fdb798c
Fix last_updated_by field for teams and assignments
Jan 22, 2025
cd02523
Prevent drop assignment with same employees from team to team
Jan 23, 2025
3775b64
Merge pull request #631 from digi-serve/guy/team-widget
guyyoo Jan 23, 2025
6d291fb
Fix bug dropping assignment to leader/member in the same team
Jan 24, 2025
3261ab8
Add more condition when drop to the same team
Jan 24, 2025
81285b6
Merge pull request #632 from digi-serve/guy/team-widget
guyyoo Jan 24, 2025
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 2 additions & 0 deletions AppBuilder/ABFactory.js
Original file line number Diff line number Diff line change
Expand Up @@ -130,6 +130,8 @@ class ABFactory extends ABFactoryCore {
}
};

this.performance = performance;

this.UISettings = UISettings;

this.Validation = {
Expand Down
2 changes: 1 addition & 1 deletion AppBuilder/core
Submodule core updated from b151db to a45f21
60 changes: 60 additions & 0 deletions AppBuilder/platform/ABModelApiNetsuite.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,60 @@
//
// ABModelAPINetsuite
//
// Represents the Data interface for a connection to Netsuite.

const ABModel = require("./ABModel");

module.exports = class ABModelAPINetsuite extends ABModel {
///
/// Instance Methods
///

/**
* @method normalizeData()
* For a Netsuite object, there are additional steps we need to handle
* to normalize our data.
*/
normalizeData(data) {
super.normalizeData(data);

if (!Array.isArray(data)) {
data = [data];
}

var boolFields = this.object.fields((f) => f.key == "boolean");
let allFields = this.object.fields();

data.forEach((d) => {
// Netsuite sometimes keeps keys all lowercase
// which might not match up with what it told us in the meta-catalog
// which we need:
for (var i = 0; i < allFields.length; i++) {
let actualColumn = allFields[i].columnName;
let lcColumn = actualColumn.toLowerCase();

if (
typeof d[actualColumn] == "undefined" &&
typeof d[lcColumn] != "undefined"
) {
d[actualColumn] = d[lcColumn];
delete d[lcColumn];
}
}

// Netsuite Booleans are "T" or "F"
boolFields.forEach((bField) => {
let val = d[bField.columnName];
// just how many ways can a DB indicate True/False?
if (typeof val == "string") {
val = val.toLowerCase();

if (val === "t") val = true;
else val = false;

d[bField.columnName] = val;
}
});
});
}
};
8 changes: 8 additions & 0 deletions AppBuilder/platform/ABObjectApi.js
Original file line number Diff line number Diff line change
Expand Up @@ -69,4 +69,12 @@ module.exports = class ABObjectApi extends ABObjectApiCore {
async save() {
return await super.save(true);
}

migrateCreate() {
return Promise.resolve();
}

migrateDrop() {
return Promise.resolve();
}
};
72 changes: 72 additions & 0 deletions AppBuilder/platform/ABObjectApiNetsuite.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,72 @@
const ABObjectApiNetsuiteCore = require("../core/ABObjectApiNetsuiteCore");

module.exports = class ABObjectApiNetsuite extends ABObjectApiNetsuiteCore {
constructor(attributes, AB) {
super(attributes, AB);
}

async getDbInfo() {
/*
// Data format:
{
"definitionId": "f2416a1a-d75c-40f2-8180-bad9b5f8b9cc",
"tableName": "AB_MockupHR_TeamTargetLocation",
"fields": [
{
"Field": "uuid",
"Type": "varchar(255)",
"Null": "NO",
"Key": "PRI",
"Default": null,
"Extra": ""
},
{
"Field": "created_at",
"Type": "datetime",
"Null": "YES",
"Key": "",
"Default": null,
"Extra": ""
},
{
"Field": "updated_at",
"Type": "datetime",
"Null": "YES",
"Key": "",
"Default": null,
"Extra": ""
},
{
"Field": "properties",
"Type": "text",
"Null": "YES",
"Key": "",
"Default": null,
"Extra": ""
}
]
}
*/
let PK = this.PK();
let fieldInfo = [];
this.fields().forEach((f) => {
let field = {
Field: f.columnName,
Type: f.key,
Null: f.settings.required ? "NO" : "YES",
Key: PK == f.columnName ? "PRI" : "",
Default: "",
Extra: "",
};
fieldInfo.push(field);
});

let TableInfo = {
definitionId: this.id,
tableName: this.tableName,
fields: fieldInfo,
};

return TableInfo;
}
};
7 changes: 7 additions & 0 deletions AppBuilder/platform/FilterComplex.js
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,13 @@ function _toInternal(cond, fields = []) {
};

if (Array.isArray(cond.value)) cond.includes = cond.value;
if (
cond.rule === "in_query_field" ||
cond.rule === "not_in_query_field"
) {
cond.includes = cond.value.split(":");
}

// else cond.includes = cond.value?.split?.(/,|:/) ?? [];

// if (field?.key == "date" || field?.key == "datetime") {
Expand Down
6 changes: 4 additions & 2 deletions AppBuilder/platform/dataFields/ABField.js
Original file line number Diff line number Diff line change
Expand Up @@ -160,7 +160,9 @@ module.exports = class ABField extends ABFieldCore {
// NOTE: our .migrateXXX() routines expect the object to currently exist
// in the DB before we perform the DB operations. So we need to
// .migrateDrop() before we actually .objectDestroy() this.
await this.migrateDrop();
if (!this.object.isAPI) {
await this.migrateDrop();
}

// the server still references an ABField in relationship to it's
// ABObject, so we need to destroy the Field 1st, then remove it
Expand Down Expand Up @@ -231,7 +233,7 @@ module.exports = class ABField extends ABFieldCore {
// but not connectObject fields:
// ABFieldConnect.migrateXXX() gets called from the UI popupNewDataField
// in order to handle the timings of the 2 fields that need to be created
if (!this.isConnection && !skipMigrate) {
if (!this.isConnection && !skipMigrate && !this.object.isAPI) {
const fnMigrate = isAdd ? this.migrateCreate() : this.migrateUpdate();
await fnMigrate;
}
Expand Down
11 changes: 8 additions & 3 deletions AppBuilder/platform/dataFields/ABFieldConnect.js
Original file line number Diff line number Diff line change
Expand Up @@ -244,7 +244,7 @@ module.exports = class ABFieldConnect extends ABFieldConnectCore {
*
* @return {Promise}
*/
async getOptions(whereClause, term, sort, editor) {
async getOptions(whereClause, term, sort, editor, populate = false) {
const theEditor = editor;

if (theEditor) {
Expand Down Expand Up @@ -383,7 +383,7 @@ module.exports = class ABFieldConnect extends ABFieldConnectCore {
return linkedModel.findAll({
where: where,
sort: sort,
populate: false,
populate,
});
};

Expand Down Expand Up @@ -423,9 +423,14 @@ module.exports = class ABFieldConnect extends ABFieldConnectCore {
whereRels.glue = "or";
whereRels.rules = [];

// make sure values are unique:
let valHash = {};
values.split(",").forEach((v) => {
valHash[v] = v;
});
Object.keys(valHash).forEach((v) => {
whereRels.rules.push({
key: "uuid",
key: linkedObj.PK(),
rule: "equals",
value: v,
});
Expand Down
13 changes: 13 additions & 0 deletions AppBuilder/platform/views/ABViewOrgChartTeams.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
const ABViewOrgChartTeamsCore = require("../../core/views/ABViewOrgChartTeamsCore");
const ABViewOrgChartTeamsComponent = require("./viewComponent/ABViewOrgChartTeamsComponent");

module.exports = class ABViewOrgChartTeams extends ABViewOrgChartTeamsCore {
/**
* @method component()
* return a UI component based upon this view.
* @return {obj} UI component
*/
component() {
return new ABViewOrgChartTeamsComponent(this);
}
};
Original file line number Diff line number Diff line change
Expand Up @@ -16,10 +16,11 @@ export default class ABViewDataSelectComponent extends ABViewComponent {
ui() {
const _ui = super.ui([
{
view: "richselect",
view: "combo",
id: this.ids.select,
on: {
onChange: (n, o) => {
if (!o) return;
if (n !== o) this.cursorChange(n);
},
},
Expand All @@ -30,26 +31,25 @@ export default class ABViewDataSelectComponent extends ABViewComponent {
return _ui;
}

async init(AB) {
await super.init(AB);
this.dc = AB.datacollectionByID(this.settings.dataviewID);
}

async onShow() {
if (!this.dc) return;
await this.dc.waitForDataCollectionToInitialize(this.dc);
super.onShow();
const dc = this.datacollection;
if (!dc) return;
await dc.waitReady();
const labelField = this.AB.definitionByID(
this.settings.labelField
)?.columnName;
const options = this.dc
const options = dc
.getData()
.map((o) => ({ id: o.id, value: o[labelField] }));
$$(this.ids.select).define("options", options);
$$(this.ids.select).refresh();
$$(this.ids.select).setValue(this.dc.getCursor().id);
.map((o) => ({ id: o.id, value: o[labelField] }))
.sort((a, b) => (a.value > b.value ? 1 : -1));
const $select = $$(this.ids.select);
$select.define("options", options);
$select.refresh();
$select.setValue(dc.getCursor().id);
}

cursorChange(n) {
this.dc.setCursor(n);
this.datacollection.setCursor(n);
}
}
32 changes: 27 additions & 5 deletions AppBuilder/platform/views/viewComponent/ABViewGridComponent.js
Original file line number Diff line number Diff line change
Expand Up @@ -267,6 +267,12 @@ export default class ABViewGridComponent extends ABViewComponent {
self.toggleUpdateDelete();
} else {
if (settings.isEditable) {
// get the field related to this col
const currObject = self.datacollection.datasource;
const selectField = currObject.fields(
(f) => f.columnName === col
)[0];

// if the colum is not the select item column move on to
// the next step to save
const state = {
Expand All @@ -275,7 +281,7 @@ export default class ABViewGridComponent extends ABViewComponent {
const editor = {
row: row,
column: col,
config: null,
config: { fieldID: selectField?.id ?? null },
};

self.onAfterEditStop(state, editor);
Expand Down Expand Up @@ -1350,6 +1356,8 @@ export default class ABViewGridComponent extends ABViewComponent {
return false;
}

const CurrentObject = this.datacollection.datasource;

if (editor.config)
switch (editor.config.editor) {
case "number":
Expand All @@ -1369,19 +1377,33 @@ export default class ABViewGridComponent extends ABViewComponent {
// code block
}

if (state.value !== state.old) {
// lets make sure we are comparing things properly:
// reduce newValue and oldValue down to PK if they were objects
let newVal = state.value;
if (newVal) {
newVal = newVal[CurrentObject.PK()] || newVal;
}
let oldVal = state.old;
if (oldVal) {
oldVal = oldVal[CurrentObject.PK()] || oldVal;
}

// NOTE: != vs !== :
// want to handle when newVal = "3" and oldVal = 3
// that is why we don't use !== so that we convert the values into
// the same case.
if (newVal != oldVal) {
const item = $DataTable?.getItem(editor.row);
const CurrentObject = this.datacollection.datasource;

item[editor.column] = state.value;

$DataTable.removeCellCss(item.id, editor.column, "webix_invalid");
$DataTable.removeCellCss(item.id, editor.column, "webix_invalid_cell");

//maxlength field
const f = CurrentObject.fieldByID(editor.config.fieldID);
const f = CurrentObject.fieldByID(editor.config?.fieldID);
if (
f.settings.maxLength &&
f?.settings.maxLength &&
state.value.length > f.settings.maxLength
) {
this.AB.alert({
Expand Down
Loading
Loading