@trudb/tru-common-lib 0.1.220 → 0.1.224
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/card-column/tru-card-column-module.mjs +45 -0
- package/esm2022/lib/components/card-column/tru-card-column.mjs +285 -0
- package/esm2022/lib/services/tru-entity-accessor.mjs +7 -1
- package/esm2022/public-api.mjs +3 -1
- package/fesm2022/trudb-tru-common-lib.mjs +2454 -2135
- package/fesm2022/trudb-tru-common-lib.mjs.map +1 -1
- package/lib/components/card-column/tru-card-column-module.d.ts +14 -0
- package/lib/components/card-column/tru-card-column.d.ts +49 -0
- package/lib/services/tru-entity-accessor.d.ts +1 -0
- package/package.json +5 -6
- package/public-api.d.ts +2 -0
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import { NgModule } from "@angular/core";
|
|
2
|
+
import { CommonModule, } from "@angular/common";
|
|
3
|
+
import { FormsModule } from "@angular/forms";
|
|
4
|
+
import { MatIconModule } from "@angular/material/icon";
|
|
5
|
+
import { TruToolbarModule } from "../toolbar/tru-toolbar-module";
|
|
6
|
+
import { TruToolbarButtonModule } from "../toolbar/button/tru-toolbar-button-module";
|
|
7
|
+
import { TruToolbarDropdownModule } from "../toolbar/dropdown/tru-toolbar-dropdown-module";
|
|
8
|
+
import { TruToolbarSeparatorModule } from "../toolbar/separator/tru-toolbar-separator-module";
|
|
9
|
+
import { TruCardColumn } from "./tru-card-column";
|
|
10
|
+
import * as i0 from "@angular/core";
|
|
11
|
+
export class TruCardColumnModule {
|
|
12
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruCardColumnModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
13
|
+
static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.5", ngImport: i0, type: TruCardColumnModule, declarations: [TruCardColumn], imports: [CommonModule,
|
|
14
|
+
FormsModule,
|
|
15
|
+
MatIconModule,
|
|
16
|
+
TruToolbarModule,
|
|
17
|
+
TruToolbarButtonModule,
|
|
18
|
+
TruToolbarDropdownModule,
|
|
19
|
+
TruToolbarSeparatorModule], exports: [TruCardColumn] });
|
|
20
|
+
static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruCardColumnModule, imports: [CommonModule,
|
|
21
|
+
FormsModule,
|
|
22
|
+
MatIconModule,
|
|
23
|
+
TruToolbarModule,
|
|
24
|
+
TruToolbarButtonModule,
|
|
25
|
+
TruToolbarDropdownModule,
|
|
26
|
+
TruToolbarSeparatorModule] });
|
|
27
|
+
}
|
|
28
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruCardColumnModule, decorators: [{
|
|
29
|
+
type: NgModule,
|
|
30
|
+
args: [{
|
|
31
|
+
providers: [],
|
|
32
|
+
declarations: [TruCardColumn],
|
|
33
|
+
imports: [
|
|
34
|
+
CommonModule,
|
|
35
|
+
FormsModule,
|
|
36
|
+
MatIconModule,
|
|
37
|
+
TruToolbarModule,
|
|
38
|
+
TruToolbarButtonModule,
|
|
39
|
+
TruToolbarDropdownModule,
|
|
40
|
+
TruToolbarSeparatorModule
|
|
41
|
+
],
|
|
42
|
+
exports: [TruCardColumn]
|
|
43
|
+
}]
|
|
44
|
+
}] });
|
|
45
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJ1LWNhcmQtY29sdW1uLW1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3RydS1jb21tb24tbGliL3NyYy9saWIvY29tcG9uZW50cy9jYXJkLWNvbHVtbi90cnUtY2FyZC1jb2x1bW4tbW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQW1CLE1BQU0sZUFBZSxDQUFDO0FBQzFELE9BQU8sRUFBRSxZQUFZLEdBQUcsTUFBTSxpQkFBaUIsQ0FBQztBQUNoRCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDN0MsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFBO0FBQ3RELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBQ2pFLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDZDQUE2QyxDQUFDO0FBQ3JGLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLGlEQUFpRCxDQUFDO0FBQzNGLE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxNQUFNLG1EQUFtRCxDQUFDO0FBQzlGLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQzs7QUFnQmxELE1BQU0sT0FBTyxtQkFBbUI7dUdBQW5CLG1CQUFtQjt3R0FBbkIsbUJBQW1CLGlCQVpmLGFBQWEsYUFFMUIsWUFBWTtZQUNaLFdBQVc7WUFDWCxhQUFhO1lBQ2IsZ0JBQWdCO1lBQ2hCLHNCQUFzQjtZQUN0Qix3QkFBd0I7WUFDeEIseUJBQXlCLGFBRWpCLGFBQWE7d0dBRVosbUJBQW1CLFlBVjVCLFlBQVk7WUFDWixXQUFXO1lBQ1gsYUFBYTtZQUNiLGdCQUFnQjtZQUNoQixzQkFBc0I7WUFDdEIsd0JBQXdCO1lBQ3hCLHlCQUF5Qjs7MkZBSWhCLG1CQUFtQjtrQkFkL0IsUUFBUTttQkFBQztvQkFDUixTQUFTLEVBQUUsRUFBRTtvQkFDYixZQUFZLEVBQUUsQ0FBQyxhQUFhLENBQUM7b0JBQzdCLE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLFdBQVc7d0JBQ1gsYUFBYTt3QkFDYixnQkFBZ0I7d0JBQ2hCLHNCQUFzQjt3QkFDdEIsd0JBQXdCO3dCQUN4Qix5QkFBeUI7cUJBQzFCO29CQUNELE9BQU8sRUFBRSxDQUFDLGFBQWEsQ0FBQztpQkFDekIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSwgQVBQX0lOSVRJQUxJWkVSIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlLCB9IGZyb20gXCJAYW5ndWxhci9jb21tb25cIjtcclxuaW1wb3J0IHsgRm9ybXNNb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvZm9ybXNcIjtcclxuaW1wb3J0IHsgTWF0SWNvbk1vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9tYXRlcmlhbC9pY29uXCJcclxuaW1wb3J0IHsgVHJ1VG9vbGJhck1vZHVsZSB9IGZyb20gXCIuLi90b29sYmFyL3RydS10b29sYmFyLW1vZHVsZVwiO1xyXG5pbXBvcnQgeyBUcnVUb29sYmFyQnV0dG9uTW9kdWxlIH0gZnJvbSBcIi4uL3Rvb2xiYXIvYnV0dG9uL3RydS10b29sYmFyLWJ1dHRvbi1tb2R1bGVcIjtcclxuaW1wb3J0IHsgVHJ1VG9vbGJhckRyb3Bkb3duTW9kdWxlIH0gZnJvbSBcIi4uL3Rvb2xiYXIvZHJvcGRvd24vdHJ1LXRvb2xiYXItZHJvcGRvd24tbW9kdWxlXCI7XHJcbmltcG9ydCB7IFRydVRvb2xiYXJTZXBhcmF0b3JNb2R1bGUgfSBmcm9tIFwiLi4vdG9vbGJhci9zZXBhcmF0b3IvdHJ1LXRvb2xiYXItc2VwYXJhdG9yLW1vZHVsZVwiO1xyXG5pbXBvcnQgeyBUcnVDYXJkQ29sdW1uIH0gZnJvbSBcIi4vdHJ1LWNhcmQtY29sdW1uXCI7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIHByb3ZpZGVyczogW10sXHJcbiAgZGVjbGFyYXRpb25zOiBbVHJ1Q2FyZENvbHVtbl0sXHJcbiAgaW1wb3J0czogW1xyXG4gICAgQ29tbW9uTW9kdWxlLFxyXG4gICAgRm9ybXNNb2R1bGUsXHJcbiAgICBNYXRJY29uTW9kdWxlLFxyXG4gICAgVHJ1VG9vbGJhck1vZHVsZSxcclxuICAgIFRydVRvb2xiYXJCdXR0b25Nb2R1bGUsXHJcbiAgICBUcnVUb29sYmFyRHJvcGRvd25Nb2R1bGUsXHJcbiAgICBUcnVUb29sYmFyU2VwYXJhdG9yTW9kdWxlXHJcbiAgXSxcclxuICBleHBvcnRzOiBbVHJ1Q2FyZENvbHVtbl1cclxufSlcclxuZXhwb3J0IGNsYXNzIFRydUNhcmRDb2x1bW5Nb2R1bGUgeyB9XHJcbiJdfQ==
|
|
@@ -0,0 +1,285 @@
|
|
|
1
|
+
import { Component, Input, ViewChild } from '@angular/core';
|
|
2
|
+
import * as _ from 'underscore';
|
|
3
|
+
import { breeze } from 'breeze-client';
|
|
4
|
+
import { v4 as uuidv4 } from 'uuid';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "../../services/tru-data-context";
|
|
7
|
+
import * as i2 from "../../services/tru-model-type-lookup";
|
|
8
|
+
import * as i3 from "@angular/common";
|
|
9
|
+
export class TruCardColumn {
|
|
10
|
+
dataContext;
|
|
11
|
+
modelTypeLookup;
|
|
12
|
+
config;
|
|
13
|
+
portal;
|
|
14
|
+
parentTableName = this.config.parentTableName;
|
|
15
|
+
key = this.config.key;
|
|
16
|
+
parentQuery = this.config.parentQuery;
|
|
17
|
+
lockProperty = this.config.lockProperty;
|
|
18
|
+
entityPluralName = this.config.entityPluralName;
|
|
19
|
+
entityName = this.config.entityName;
|
|
20
|
+
columnSort = this.config.columnSort;
|
|
21
|
+
cardSort = this.config.cardSort;
|
|
22
|
+
color = this.config.color;
|
|
23
|
+
unassignedVisible = this.config.unassignedVisible;
|
|
24
|
+
unassignedName = this.config.unassignedName;
|
|
25
|
+
unassignedLocked = this.config.unassignedLocked;
|
|
26
|
+
unassignedColor = this.config.unassignedColor;
|
|
27
|
+
unassignedDraggable = this.config.unassignedDraggable;
|
|
28
|
+
unassignedDroppable = this.config.unassignedDroppable;
|
|
29
|
+
inactiveVisible = this.config.inactiveVisible;
|
|
30
|
+
inactiveDraggable = this.config.inactiveDraggable;
|
|
31
|
+
inactiveDroppable = this.config.inactiveDroppable;
|
|
32
|
+
relatedParentName;
|
|
33
|
+
relatedChildName;
|
|
34
|
+
insertBefore;
|
|
35
|
+
selectedCards = [];
|
|
36
|
+
columnFilterRefs = [];
|
|
37
|
+
cardFilterStr;
|
|
38
|
+
uniqueId;
|
|
39
|
+
columns;
|
|
40
|
+
lockedColumns;
|
|
41
|
+
constructor(dataContext, modelTypeLookup) {
|
|
42
|
+
this.dataContext = dataContext;
|
|
43
|
+
this.modelTypeLookup = modelTypeLookup;
|
|
44
|
+
let index = this.key.lastIndexOf(this.parentTableName);
|
|
45
|
+
let prefix = this.key.substring(index, -1);
|
|
46
|
+
if (prefix) {
|
|
47
|
+
this.relatedParentName = prefix + this.parentTableName;
|
|
48
|
+
this.relatedChildName = prefix + this.entityPluralName;
|
|
49
|
+
}
|
|
50
|
+
else {
|
|
51
|
+
this.relatedParentName = this.parentTableName;
|
|
52
|
+
this.relatedChildName = this.entityPluralName;
|
|
53
|
+
}
|
|
54
|
+
this.uniqueId = uuidv4();
|
|
55
|
+
}
|
|
56
|
+
parentTableModel = null; //dataService.model.tables[parentTableName];
|
|
57
|
+
userHasParentTableRole = null; //parentTableModel.canDisplay;
|
|
58
|
+
createDataForEntity = (entity) => {
|
|
59
|
+
var data = this.config.createData(entity);
|
|
60
|
+
data.$entity = entity;
|
|
61
|
+
return data;
|
|
62
|
+
};
|
|
63
|
+
hasUndefinedChildren = (entity) => {
|
|
64
|
+
const entityPropertyName = 'o' + this.relatedChildName;
|
|
65
|
+
return !entity[entityPropertyName];
|
|
66
|
+
};
|
|
67
|
+
hasEmptyChildren = (entity) => {
|
|
68
|
+
const entityPropertyName = 'o' + this.relatedChildName;
|
|
69
|
+
return !entity[entityPropertyName].length;
|
|
70
|
+
};
|
|
71
|
+
hasInactiveChildren = (entity) => {
|
|
72
|
+
const entityPropertyName = 'o' + this.relatedChildName;
|
|
73
|
+
return _.every([entityPropertyName], (child) => { return !child.active; });
|
|
74
|
+
};
|
|
75
|
+
hasAddedUnsavedChildren = (entities, parentRef) => {
|
|
76
|
+
return _.some(entities, (entity) => {
|
|
77
|
+
const entityPropertyName = this.key;
|
|
78
|
+
return entity[entityPropertyName] === parentRef;
|
|
79
|
+
});
|
|
80
|
+
};
|
|
81
|
+
clear = () => {
|
|
82
|
+
var lockedColumns = this.portal.querySelectorAll('.locked-columns')[0];
|
|
83
|
+
var unlockedColumns = this.portal.querySelectorAll('.unlocked-columns')[0];
|
|
84
|
+
while (lockedColumns && lockedColumns.lastChild) {
|
|
85
|
+
lockedColumns.removeChild(lockedColumns.lastChild);
|
|
86
|
+
}
|
|
87
|
+
;
|
|
88
|
+
while (unlockedColumns && unlockedColumns.lastChild) {
|
|
89
|
+
unlockedColumns.removeChild(unlockedColumns.lastChild);
|
|
90
|
+
}
|
|
91
|
+
while (this.selectedCards.length) {
|
|
92
|
+
this.selectedCards.pop();
|
|
93
|
+
}
|
|
94
|
+
;
|
|
95
|
+
this.config.onSelectionChanged([]);
|
|
96
|
+
this.config.clearFilters();
|
|
97
|
+
};
|
|
98
|
+
getValueFromSortPath = (args) => {
|
|
99
|
+
let current = args[0];
|
|
100
|
+
for (let i = 0; i < args[1].length; i++) {
|
|
101
|
+
let partName;
|
|
102
|
+
if (i !== args[1].length - 1) {
|
|
103
|
+
partName = 'o' + args[1][i];
|
|
104
|
+
}
|
|
105
|
+
else {
|
|
106
|
+
partName = args[1][i];
|
|
107
|
+
}
|
|
108
|
+
if (current[partName]) {
|
|
109
|
+
current = current[partName];
|
|
110
|
+
}
|
|
111
|
+
else {
|
|
112
|
+
return null;
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
return current;
|
|
116
|
+
};
|
|
117
|
+
updateItemsSource(newEntities, revert) {
|
|
118
|
+
this.clear();
|
|
119
|
+
if (!revert)
|
|
120
|
+
localStorage.setItem('scroll_position' + uuidv4(), '0');
|
|
121
|
+
if (newEntities.length)
|
|
122
|
+
this.config.busyMessage = 'Rendering...';
|
|
123
|
+
this.columnFilterRefs = [];
|
|
124
|
+
this.cardFilterStr = null;
|
|
125
|
+
if (!newEntities.length) {
|
|
126
|
+
this.lockedColumns = [];
|
|
127
|
+
this.columns = [];
|
|
128
|
+
return;
|
|
129
|
+
}
|
|
130
|
+
let lockedColumns = [];
|
|
131
|
+
let emptyParents = [];
|
|
132
|
+
let columns = [];
|
|
133
|
+
let query = new breeze.EntityQuery('Query' + this.parentTableName);
|
|
134
|
+
var relatedChildProperty = 'o' + this.relatedChildName;
|
|
135
|
+
if (this.config.customCardColumnQueryFactory)
|
|
136
|
+
query = this.config.customCardColumnQueryFactory(query, relatedChildProperty);
|
|
137
|
+
else
|
|
138
|
+
query = query.expand('o' + this.relatedChildName);
|
|
139
|
+
//if (this.parentQuery)
|
|
140
|
+
// query = queries[this.parentQuery](query);
|
|
141
|
+
this.dataContext.entityAccess().customSearch(this.modelTypeLookup.getType(this.parentTableName), query).subscribe((parents) => {
|
|
142
|
+
this.config.addParentsToFilter(parents);
|
|
143
|
+
emptyParents = _.filter(parents, (parent) => {
|
|
144
|
+
if (this.hasUndefinedChildren(parent) || this.hasEmptyChildren(parent) || this.hasInactiveChildren(parent)) {
|
|
145
|
+
if (!this.hasAddedUnsavedChildren(newEntities, parent.Ref)) {
|
|
146
|
+
parent['cards'] = [];
|
|
147
|
+
return true;
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
return false;
|
|
151
|
+
});
|
|
152
|
+
let queryableParentRefs = _.pluck(parents, this.key);
|
|
153
|
+
let inactiveWithParent = [];
|
|
154
|
+
let activeWithoutParent = [
|
|
155
|
+
{
|
|
156
|
+
unassigned: true,
|
|
157
|
+
cards: []
|
|
158
|
+
}
|
|
159
|
+
];
|
|
160
|
+
parents.forEach((parent) => {
|
|
161
|
+
parent['cards'] = [];
|
|
162
|
+
if (queryableParentRefs.indexOf(parent[this.key]) !== -1) {
|
|
163
|
+
if (parent[this.lockProperty]) {
|
|
164
|
+
lockedColumns.push(parent);
|
|
165
|
+
}
|
|
166
|
+
else if (!parent[this.lockProperty] && !_.contains(emptyParents, parent)) {
|
|
167
|
+
columns.push(parent);
|
|
168
|
+
}
|
|
169
|
+
}
|
|
170
|
+
else {
|
|
171
|
+
parent['inactive'] = true;
|
|
172
|
+
inactiveWithParent.push(parent);
|
|
173
|
+
}
|
|
174
|
+
});
|
|
175
|
+
newEntities.forEach((entity) => {
|
|
176
|
+
var entityParent = _.find(parents, (p) => {
|
|
177
|
+
if (entity['o' + this.relatedParentName])
|
|
178
|
+
return p.Ref === entity['o' + this.relatedParentName].Ref;
|
|
179
|
+
return false;
|
|
180
|
+
});
|
|
181
|
+
if (entityParent) {
|
|
182
|
+
if (queryableParentRefs.indexOf(entityParent[this.key]) !== -1) {
|
|
183
|
+
entityParent.cards.push(this.createDataForEntity(entity));
|
|
184
|
+
}
|
|
185
|
+
else {
|
|
186
|
+
entityParent.cards.push(this.createDataForEntity(entity));
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
else if (!entityParent &&
|
|
190
|
+
entity['o' + this.relatedParentName] &&
|
|
191
|
+
entity['o' + this.relatedParentName].Ref > 0) {
|
|
192
|
+
let inactiveParent = entity['o' + this.relatedParentName];
|
|
193
|
+
if (inactiveWithParent.indexOf(inactiveParent) === -1) {
|
|
194
|
+
inactiveParent['cards'] = [];
|
|
195
|
+
inactiveParent['inactive'] = true;
|
|
196
|
+
inactiveWithParent.push(inactiveParent);
|
|
197
|
+
}
|
|
198
|
+
inactiveParent.cards.push(this.createDataForEntity(entity));
|
|
199
|
+
}
|
|
200
|
+
else {
|
|
201
|
+
activeWithoutParent[0].cards.push(this.createDataForEntity(entity));
|
|
202
|
+
}
|
|
203
|
+
});
|
|
204
|
+
if (this.columnSort) {
|
|
205
|
+
var columnSortParts = this.columnSort.split('/');
|
|
206
|
+
lockedColumns = _.sortBy(lockedColumns, (o) => {
|
|
207
|
+
var v = this.getValueFromSortPath([o, columnSortParts]);
|
|
208
|
+
if (v)
|
|
209
|
+
return _.isString(v) ? v.trim() : v;
|
|
210
|
+
else
|
|
211
|
+
return null;
|
|
212
|
+
});
|
|
213
|
+
columns = _.sortBy(columns, (o) => {
|
|
214
|
+
var v = this.getValueFromSortPath([o, columnSortParts]);
|
|
215
|
+
if (v)
|
|
216
|
+
return _.isString(v) ? v.trim() : v;
|
|
217
|
+
else
|
|
218
|
+
return null;
|
|
219
|
+
});
|
|
220
|
+
inactiveWithParent = _.sortBy(inactiveWithParent, (o) => {
|
|
221
|
+
var v = this.getValueFromSortPath([o, columnSortParts]);
|
|
222
|
+
if (v)
|
|
223
|
+
return _.isString(v) ? v.trim() : v;
|
|
224
|
+
else
|
|
225
|
+
return null;
|
|
226
|
+
});
|
|
227
|
+
emptyParents = _.sortBy(emptyParents, (o) => {
|
|
228
|
+
var v = this.getValueFromSortPath([o, columnSortParts]);
|
|
229
|
+
if (v)
|
|
230
|
+
return _.isString(v) ? v.trim() : v;
|
|
231
|
+
else
|
|
232
|
+
return null;
|
|
233
|
+
});
|
|
234
|
+
}
|
|
235
|
+
if (this.cardSort) {
|
|
236
|
+
lockedColumns.forEach((column) => {
|
|
237
|
+
column.cards = this.cardSort(column.cards);
|
|
238
|
+
});
|
|
239
|
+
columns.forEach((column) => {
|
|
240
|
+
column.cards = this.cardSort(column.cards);
|
|
241
|
+
});
|
|
242
|
+
inactiveWithParent.forEach((column) => {
|
|
243
|
+
column.cards = this.cardSort(column.cards);
|
|
244
|
+
});
|
|
245
|
+
activeWithoutParent.forEach((column) => {
|
|
246
|
+
column.cards = this.cardSort(column.cards);
|
|
247
|
+
});
|
|
248
|
+
}
|
|
249
|
+
if (this.inactiveVisible)
|
|
250
|
+
columns = columns.concat(inactiveWithParent);
|
|
251
|
+
columns = columns.concat(emptyParents);
|
|
252
|
+
if (this.unassignedVisible && !this.unassignedLocked)
|
|
253
|
+
columns = columns.concat(activeWithoutParent);
|
|
254
|
+
if (this.unassignedVisible && this.unassignedLocked)
|
|
255
|
+
lockedColumns = columns.concat(lockedColumns);
|
|
256
|
+
this.lockedColumns = lockedColumns;
|
|
257
|
+
this.columns = columns;
|
|
258
|
+
setTimeout(() => {
|
|
259
|
+
this.clear();
|
|
260
|
+
new CardView(this.lockedColumns, this.columns);
|
|
261
|
+
if (revert) {
|
|
262
|
+
let columnElement = this.portal.querySelectorAll('.tru-card-portal-columns')[0];
|
|
263
|
+
let previousScrollPosition = localStorage.getItem('scroll_position' + uuidv4());
|
|
264
|
+
columnElement.scrollLeft = previousScrollPosition ? +previousScrollPosition : 0;
|
|
265
|
+
}
|
|
266
|
+
});
|
|
267
|
+
});
|
|
268
|
+
class CardView {
|
|
269
|
+
constructor(lockedColumns, columns) {
|
|
270
|
+
}
|
|
271
|
+
}
|
|
272
|
+
}
|
|
273
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruCardColumn, deps: [{ token: i1.TruDataContext }, { token: i2.TruModelTypeLookup }], target: i0.ɵɵFactoryTarget.Component });
|
|
274
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.5", type: TruCardColumn, selector: "tru-card-column", inputs: { config: "config" }, viewQueries: [{ propertyName: "portal", first: true, predicate: [".tru-card-portal"], descendants: true }], ngImport: i0, template: "<div class=\"tru-card\">\r\n <div *ngIf=\"config.isBusy\"\r\n class=\"tru-card-busy-indicator\">\r\n <p>Searching for {{config.entityPluralLabel}}...</p>\r\n </div>\r\n <div *ngIf=\"config.busyMessage\"\r\n class=\"tru-card-busy-indicator\">\r\n <p>{{config.busyMessage}}</p>\r\n </div>\r\n <!--<tru-toolbar [config]=\"config.toolbarConfig\" class=\"main-toolbar {{config.searchPanelConfig.side}}\"></tru-toolbar>-->\r\n <div class=\"tru-card-portal\">\r\n <div [ngStyle]=\"{'width': ((config.width * lockedColumns.length) + (10 * lockedColumns.length - 1)) + 'px' }\"\r\n [ngClass]=\"{'tru-card-portal-locked-columns-divider': lockedColumns.length}\"\r\n *ngIf=\"lockedColumns.length\"\r\n class=\"tru-card-portal-locked-columns locked-columns\">\r\n\r\n </div>\r\n <div [ngStyle]=\"{'left': lockedColumns.length ? ((config.width * lockedColumns.length) + (10 * lockedColumns.length - 1) + 22) + 'px' : 0 }\"\r\n class=\"tru-card-portal-columns unlocked-columns\">\r\n\r\n </div>\r\n </div>\r\n</div>\r\n", styles: [".tru-card-busy-indicator{position:absolute;inset:25px 0 0;z-index:10000;background-color:transparent}.tru-card-busy-indicator p{position:relative;float:left;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff}.tru-card-filter{position:absolute;top:0;left:0;right:0;height:30px;line-height:30px;padding-left:10px}.tru-card-portal{position:absolute;inset:30px 10px 0;border:1px solid #ddd;padding:10px;background-color:#0079bf}.tru-card-portal-disabled>*{opacity:.75;pointer-events:none}.tru-card-portal-locked-columns{position:absolute;top:10px;left:0;bottom:0;padding:0 5px 10px 10px;display:flex;flex-direction:column;flex-wrap:wrap;align-content:flex-start}.tru-card-portal-locked-columns .tru-card-portal-column{margin-left:0;margin-bottom:0}.tru-card-portal-locked-columns .tru-card-portal-column:not(:first-child){margin-left:10px!important}.tru-card-portal-locked-columns-divider{border-right:1px solid #cdd2d4}.tru-card-portal-columns{position:absolute;inset:10px 10px 10px 222px;padding-top:0;display:flex;flex-direction:column;flex-wrap:wrap;align-content:flex-start;overflow-x:auto;overflow-y:hidden}.tru-card-portal-column{position:relative;border:1px solid #ddd;border-radius:4px;background:#e2e4e6;vertical-align:top;max-height:calc(100% + 8px);margin-left:10px;margin-bottom:10px;display:flex;flex-direction:column}.tru-card-portal-column-inactive *{font-style:italic;opacity:.7}.tru-card-portal-column-header{flex:0 0 auto;padding:5px;position:relative;min-height:18px}.tru-card-portal-column-header-extras{position:absolute;right:5px;top:4px}.tru-card-portal-column-header-extra-button{border-radius:3px;background:transparent}.tru-card-portal-column-header-extra-button:hover{border-radius:3px;background:#cdd2d4}.tru-card-portal-column-footer{flex:0 0 auto;padding:0 3px 3px;position:relative;height:25px;line-height:25px;display:none}.tru-card-portal-column-footer-text{font-size:14px;color:#777;padding-left:5px;text-decoration:none}.tru-card-portal-column-footer-text:hover{text-decoration:underline;color:#777}.tru-card-portal-column-footer-text:active,.tru-card-portal-column-footer-text:visited{color:#777}.tru-card-icon-small{color:#999;height:18px;font-size:14px;line-height:18px;width:19px;-webkit-font-smoothing:antialiased;display:inline-block!important;font-style:normal;font-weight:400;text-align:center;text-decoration:none;position:relative}.tru-card-portal-column-headertext{font-weight:700;font-size:16px;color:#333;padding-left:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-right:20px}} .tru-card-portal-column-headertext-hover:hover{text-decoration:underline}.tru-card-portal-card-scroll-port{overflow-y:auto;overflow-x:hidden}.tru-card-portal-card-container{margin:0 3px;padding:0 2px;height:37px;transition:all .4s ease-out;opacity:1}.tru-card-portal-card-container.show{opacity:1}.tru-card-portal-card-container *{pointer-events:none}.tru-card-portal-card{background-color:#fff;border:1px solid #fff;border-radius:3px;padding:2px 6px 2px 8px;position:relative;cursor:pointer;display:block;min-height:15px;text-decoration:none;z-index:0;outline:none;box-shadow:0 .5px #ccc}.tru-card-portal-card:hover{background-color:#efefef;border:1px solid #efefef}.tru-card-portal-card p{word-wrap:break-word}.tru-card-portal-card:focus{outline:none}.tru-card-portal-card.empty{border:1px dashed #999}.tru-card-placeholder{position:absolute;left:0;right:0;margin:0;z-index:100;border-color:#0079bf;border-top-style:dashed;border-bottom-style:dashed}.tru-card-selected{border-color:#52a8eccc!important;background-color:#52a8eccc!important}.tru-card-selected p{color:#000!important}.tru-card-menu{position:absolute;top:20px;right:0;background:#fff;border:1px #ccc solid;border-radius:3px;z-index:1;padding:7px;width:200px}.tru-card-menu hr{height:1px;border:1px #ccc solid;border-bottom:0;border-left:0;border-right:0;width:100%;margin:0;padding:0}.tru-card-menu a{color:#777;text-decoration:none;float:left;line-height:16px;margin-top:2px;margin-bottom:2px}.tru-card-menu span{color:#777;float:left;line-height:16px;margin-top:3px}.tru-card-menu a:hover{text-decoration:underline;color:#777}.tru-card-menu a:active,.tru-card-menu a:visited{color:#777}.tru-card-menu-move-container{width:100%!important;display:inline-flex}.tru-card-menu-move-container select{width:100%!important}.tru-card-menu-move-container a{margin-top:1px;margin-left:3px;display:block}.tru-card-menu-move-container span{color:#0079bf;margin-top:0}.tru-card-menu-move-container .move-button-disabled{pointer-events:none;opacity:.75}.tru-card-menu-move-container .move-button-disabled span{color:#ccc}.tru-card-portal-column-filtered,.tru-card-portal-card-filtered{display:none}\n"], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] });
|
|
275
|
+
}
|
|
276
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: TruCardColumn, decorators: [{
|
|
277
|
+
type: Component,
|
|
278
|
+
args: [{ selector: 'tru-card-column', template: "<div class=\"tru-card\">\r\n <div *ngIf=\"config.isBusy\"\r\n class=\"tru-card-busy-indicator\">\r\n <p>Searching for {{config.entityPluralLabel}}...</p>\r\n </div>\r\n <div *ngIf=\"config.busyMessage\"\r\n class=\"tru-card-busy-indicator\">\r\n <p>{{config.busyMessage}}</p>\r\n </div>\r\n <!--<tru-toolbar [config]=\"config.toolbarConfig\" class=\"main-toolbar {{config.searchPanelConfig.side}}\"></tru-toolbar>-->\r\n <div class=\"tru-card-portal\">\r\n <div [ngStyle]=\"{'width': ((config.width * lockedColumns.length) + (10 * lockedColumns.length - 1)) + 'px' }\"\r\n [ngClass]=\"{'tru-card-portal-locked-columns-divider': lockedColumns.length}\"\r\n *ngIf=\"lockedColumns.length\"\r\n class=\"tru-card-portal-locked-columns locked-columns\">\r\n\r\n </div>\r\n <div [ngStyle]=\"{'left': lockedColumns.length ? ((config.width * lockedColumns.length) + (10 * lockedColumns.length - 1) + 22) + 'px' : 0 }\"\r\n class=\"tru-card-portal-columns unlocked-columns\">\r\n\r\n </div>\r\n </div>\r\n</div>\r\n", styles: [".tru-card-busy-indicator{position:absolute;inset:25px 0 0;z-index:10000;background-color:transparent}.tru-card-busy-indicator p{position:relative;float:left;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff}.tru-card-filter{position:absolute;top:0;left:0;right:0;height:30px;line-height:30px;padding-left:10px}.tru-card-portal{position:absolute;inset:30px 10px 0;border:1px solid #ddd;padding:10px;background-color:#0079bf}.tru-card-portal-disabled>*{opacity:.75;pointer-events:none}.tru-card-portal-locked-columns{position:absolute;top:10px;left:0;bottom:0;padding:0 5px 10px 10px;display:flex;flex-direction:column;flex-wrap:wrap;align-content:flex-start}.tru-card-portal-locked-columns .tru-card-portal-column{margin-left:0;margin-bottom:0}.tru-card-portal-locked-columns .tru-card-portal-column:not(:first-child){margin-left:10px!important}.tru-card-portal-locked-columns-divider{border-right:1px solid #cdd2d4}.tru-card-portal-columns{position:absolute;inset:10px 10px 10px 222px;padding-top:0;display:flex;flex-direction:column;flex-wrap:wrap;align-content:flex-start;overflow-x:auto;overflow-y:hidden}.tru-card-portal-column{position:relative;border:1px solid #ddd;border-radius:4px;background:#e2e4e6;vertical-align:top;max-height:calc(100% + 8px);margin-left:10px;margin-bottom:10px;display:flex;flex-direction:column}.tru-card-portal-column-inactive *{font-style:italic;opacity:.7}.tru-card-portal-column-header{flex:0 0 auto;padding:5px;position:relative;min-height:18px}.tru-card-portal-column-header-extras{position:absolute;right:5px;top:4px}.tru-card-portal-column-header-extra-button{border-radius:3px;background:transparent}.tru-card-portal-column-header-extra-button:hover{border-radius:3px;background:#cdd2d4}.tru-card-portal-column-footer{flex:0 0 auto;padding:0 3px 3px;position:relative;height:25px;line-height:25px;display:none}.tru-card-portal-column-footer-text{font-size:14px;color:#777;padding-left:5px;text-decoration:none}.tru-card-portal-column-footer-text:hover{text-decoration:underline;color:#777}.tru-card-portal-column-footer-text:active,.tru-card-portal-column-footer-text:visited{color:#777}.tru-card-icon-small{color:#999;height:18px;font-size:14px;line-height:18px;width:19px;-webkit-font-smoothing:antialiased;display:inline-block!important;font-style:normal;font-weight:400;text-align:center;text-decoration:none;position:relative}.tru-card-portal-column-headertext{font-weight:700;font-size:16px;color:#333;padding-left:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-right:20px}} .tru-card-portal-column-headertext-hover:hover{text-decoration:underline}.tru-card-portal-card-scroll-port{overflow-y:auto;overflow-x:hidden}.tru-card-portal-card-container{margin:0 3px;padding:0 2px;height:37px;transition:all .4s ease-out;opacity:1}.tru-card-portal-card-container.show{opacity:1}.tru-card-portal-card-container *{pointer-events:none}.tru-card-portal-card{background-color:#fff;border:1px solid #fff;border-radius:3px;padding:2px 6px 2px 8px;position:relative;cursor:pointer;display:block;min-height:15px;text-decoration:none;z-index:0;outline:none;box-shadow:0 .5px #ccc}.tru-card-portal-card:hover{background-color:#efefef;border:1px solid #efefef}.tru-card-portal-card p{word-wrap:break-word}.tru-card-portal-card:focus{outline:none}.tru-card-portal-card.empty{border:1px dashed #999}.tru-card-placeholder{position:absolute;left:0;right:0;margin:0;z-index:100;border-color:#0079bf;border-top-style:dashed;border-bottom-style:dashed}.tru-card-selected{border-color:#52a8eccc!important;background-color:#52a8eccc!important}.tru-card-selected p{color:#000!important}.tru-card-menu{position:absolute;top:20px;right:0;background:#fff;border:1px #ccc solid;border-radius:3px;z-index:1;padding:7px;width:200px}.tru-card-menu hr{height:1px;border:1px #ccc solid;border-bottom:0;border-left:0;border-right:0;width:100%;margin:0;padding:0}.tru-card-menu a{color:#777;text-decoration:none;float:left;line-height:16px;margin-top:2px;margin-bottom:2px}.tru-card-menu span{color:#777;float:left;line-height:16px;margin-top:3px}.tru-card-menu a:hover{text-decoration:underline;color:#777}.tru-card-menu a:active,.tru-card-menu a:visited{color:#777}.tru-card-menu-move-container{width:100%!important;display:inline-flex}.tru-card-menu-move-container select{width:100%!important}.tru-card-menu-move-container a{margin-top:1px;margin-left:3px;display:block}.tru-card-menu-move-container span{color:#0079bf;margin-top:0}.tru-card-menu-move-container .move-button-disabled{pointer-events:none;opacity:.75}.tru-card-menu-move-container .move-button-disabled span{color:#ccc}.tru-card-portal-column-filtered,.tru-card-portal-card-filtered{display:none}\n"] }]
|
|
279
|
+
}], ctorParameters: () => [{ type: i1.TruDataContext }, { type: i2.TruModelTypeLookup }], propDecorators: { config: [{
|
|
280
|
+
type: Input
|
|
281
|
+
}], portal: [{
|
|
282
|
+
type: ViewChild,
|
|
283
|
+
args: ['.tru-card-portal', { static: false }]
|
|
284
|
+
}] } });
|
|
285
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tru-card-column.js","sourceRoot":"","sources":["../../../../../../projects/tru-common-lib/src/lib/components/card-column/tru-card-column.ts","../../../../../../projects/tru-common-lib/src/lib/components/card-column/tru-card-column.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, ViewChild } from '@angular/core';\r\nimport * as _ from 'underscore';\r\nimport { breeze } from 'breeze-client';\r\nimport { v4 as uuidv4 } from 'uuid';\r\nimport { TruDataContext } from '../../services/tru-data-context';\r\nimport { TruEntityBase } from '../../base-classes/tru-entity-base';\r\nimport { TruModelTypeLookup } from '../../services/tru-model-type-lookup';\r\n\r\n@Component({\r\n  selector: 'tru-card-column',\r\n  templateUrl: './tru-card-column.html',\r\n  styleUrls: ['./tru-card-column.css']\r\n})\r\nexport class TruCardColumn {\r\n  @Input() config!: any\r\n\r\n  @ViewChild('.tru-card-portal', { static: false }) portal!: HTMLDivElement;\r\n\r\n  private parentTableName = this.config.parentTableName;\r\n  private key = this.config.key;\r\n  private parentQuery = this.config.parentQuery;\r\n  private lockProperty = this.config.lockProperty;\r\n  private entityPluralName = this.config.entityPluralName;\r\n  private entityName = this.config.entityName;\r\n  private columnSort = this.config.columnSort;\r\n  private cardSort = this.config.cardSort;\r\n  private color = this.config.color;\r\n\r\n  private unassignedVisible = this.config.unassignedVisible;\r\n  private unassignedName = this.config.unassignedName;\r\n  private unassignedLocked = this.config.unassignedLocked;\r\n  private unassignedColor = this.config.unassignedColor;\r\n  private unassignedDraggable = this.config.unassignedDraggable;\r\n  private unassignedDroppable = this.config.unassignedDroppable;\r\n\r\n  private inactiveVisible = this.config.inactiveVisible;\r\n  private inactiveDraggable = this.config.inactiveDraggable;\r\n  private inactiveDroppable = this.config.inactiveDroppable;\r\n\r\n  private relatedParentName;\r\n  private relatedChildName;\r\n  private insertBefore: any;\r\n  private selectedCards = [];\r\n  private columnFilterRefs = [];\r\n  private cardFilterStr: any;\r\n  private uniqueId;\r\n\r\n  columns: any;\r\n  lockedColumns: any;\r\n\r\n  constructor(\r\n    private dataContext: TruDataContext,\r\n    private modelTypeLookup: TruModelTypeLookup) {\r\n\r\n    let index = this.key.lastIndexOf(this.parentTableName);\r\n    let prefix = this.key.substring(index, -1);\r\n    if (prefix) {\r\n      this.relatedParentName = prefix + this.parentTableName;\r\n      this.relatedChildName = prefix + this.entityPluralName;\r\n    } else {\r\n      this.relatedParentName = this.parentTableName;\r\n      this.relatedChildName = this.entityPluralName;\r\n    }\r\n\r\n    this.uniqueId = uuidv4();\r\n  }\r\n\r\n  private parentTableModel = null;//dataService.model.tables[parentTableName];\r\n  private userHasParentTableRole = null; //parentTableModel.canDisplay;\r\n\r\n  private createDataForEntity = (entity: TruEntityBase) => {\r\n    var data = this.config.createData(entity);\r\n    data.$entity = entity;\r\n    return data;\r\n  };\r\n\r\n  private hasUndefinedChildren = (entity: TruEntityBase) => {\r\n    type EntityObjectKey = keyof typeof entity;\r\n    const entityPropertyName = 'o' + this.relatedChildName as EntityObjectKey;\r\n    return !entity[entityPropertyName];\r\n  }\r\n\r\n  private hasEmptyChildren = (entity: TruEntityBase) => {\r\n    type EntityObjectKey = keyof typeof entity;\r\n    const entityPropertyName = 'o' + this.relatedChildName as EntityObjectKey;\r\n    return !entity[entityPropertyName].length;\r\n  }\r\n\r\n  private hasInactiveChildren = (entity: TruEntityBase) => {\r\n    type EntityObjectKey = keyof typeof entity;\r\n    const entityPropertyName = 'o' + this.relatedChildName as EntityObjectKey;\r\n    return _.every([entityPropertyName], (child: any) => { return !child.active; });\r\n  }\r\n\r\n  private hasAddedUnsavedChildren = (entities: Array<TruEntityBase>, parentRef: number) => {\r\n    return _.some(entities, (entity: TruEntityBase) => {\r\n      type EntityObjectKey = keyof typeof entity;\r\n      const entityPropertyName = this.key as EntityObjectKey;\r\n      return entity[entityPropertyName] === parentRef\r\n    });\r\n  }\r\n\r\n  private clear = () => {\r\n    var lockedColumns = this.portal.querySelectorAll('.locked-columns')[0];\r\n    var unlockedColumns = this.portal.querySelectorAll('.unlocked-columns')[0];\r\n\r\n    while (lockedColumns && lockedColumns.lastChild) { lockedColumns.removeChild(lockedColumns.lastChild); };\r\n    while (unlockedColumns && unlockedColumns.lastChild) { unlockedColumns.removeChild(unlockedColumns.lastChild); }\r\n    while (this.selectedCards.length) { this.selectedCards.pop(); };\r\n    this.config.onSelectionChanged([]);\r\n    this.config.clearFilters();\r\n  }\r\n\r\n  private getValueFromSortPath = (args: [any, string[]]): any => {\r\n    let current: any = args[0];\r\n    for (let i: number = 0; i < args[1].length; i++) {\r\n      let partName: string;\r\n      if (i !== args[1].length - 1) {\r\n        partName = 'o' + args[1][i];\r\n      } else {\r\n        partName = args[1][i];\r\n      }\r\n\r\n      if (current[partName]) {\r\n        current = current[partName];\r\n      } else {\r\n        return null;\r\n      }\r\n    }\r\n    return current;\r\n  }\r\n\r\n  private updateItemsSource(newEntities: Array<any>, revert: boolean) {\r\n    this.clear();\r\n    if (!revert)\r\n      localStorage.setItem('scroll_position' + uuidv4(), '0');\r\n\r\n    if (newEntities.length)\r\n      this.config.busyMessage = 'Rendering...';\r\n\r\n    this.columnFilterRefs = [];\r\n    this.cardFilterStr = null;\r\n\r\n    if (!newEntities.length) {\r\n      this.lockedColumns = [];\r\n      this.columns = [];\r\n      return;\r\n    }\r\n\r\n    let lockedColumns: Array<any> = [];\r\n    let emptyParents: Array<any> = [];\r\n    let columns: Array<any> = [];\r\n\r\n    let query = new breeze.EntityQuery('Query' + this.parentTableName);\r\n\r\n    var relatedChildProperty = 'o' + this.relatedChildName;\r\n\r\n    if (this.config.customCardColumnQueryFactory)\r\n      query = this.config.customCardColumnQueryFactory(query, relatedChildProperty);\r\n    else\r\n      query = query.expand('o' + this.relatedChildName);\r\n\r\n    //if (this.parentQuery)\r\n    //  query = queries[this.parentQuery](query);\r\n\r\n    this.dataContext.entityAccess().customSearch(this.modelTypeLookup.getType(this.parentTableName), query).subscribe((parents) => {\r\n      this.config.addParentsToFilter(parents);\r\n\r\n      emptyParents = _.filter(parents, (parent) => {\r\n        if (this.hasUndefinedChildren(parent) || this.hasEmptyChildren(parent) || this.hasInactiveChildren(parent)) {\r\n          if (!this.hasAddedUnsavedChildren(newEntities, parent.Ref)) {\r\n            parent['cards'] = [];\r\n            return true;\r\n          }\r\n        }\r\n        return false;\r\n      });\r\n      let queryableParentRefs = _.pluck(parents, this.key)\r\n\r\n      let inactiveWithParent: Array<any> = [];\r\n      let activeWithoutParent: Array<any> = [\r\n        {\r\n          unassigned: true,\r\n          cards: []\r\n        }\r\n      ];\r\n\r\n      parents.forEach((parent: any) => {\r\n        parent['cards'] = [];\r\n        if (queryableParentRefs.indexOf(parent[this.key]) !== -1) {\r\n          if (parent[this.lockProperty]) {\r\n            lockedColumns.push(parent);\r\n          } else if (!parent[this.lockProperty] && !_.contains(emptyParents, parent)) {\r\n            columns.push(parent);\r\n          }\r\n        } else {\r\n          parent['inactive'] = true;\r\n          inactiveWithParent.push(parent);\r\n        }\r\n      });\r\n\r\n      newEntities.forEach((entity) => {\r\n        var entityParent = _.find(parents, (p) => {\r\n          if (entity['o' + this.relatedParentName])\r\n            return p.Ref === entity['o' + this.relatedParentName].Ref;\r\n          return false;\r\n        });\r\n\r\n        if (entityParent) {\r\n          if (queryableParentRefs.indexOf(entityParent[this.key]) !== -1) {\r\n            entityParent.cards.push(this.createDataForEntity(entity));\r\n          } else {\r\n            entityParent.cards.push(this.createDataForEntity(entity));\r\n          }\r\n        } else if (\r\n          !entityParent &&\r\n          entity['o' + this.relatedParentName] &&\r\n          entity['o' + this.relatedParentName].Ref > 0) {\r\n          let inactiveParent = entity['o' + this.relatedParentName];\r\n          if (inactiveWithParent.indexOf(inactiveParent) === -1) {\r\n            inactiveParent['cards'] = [];\r\n            inactiveParent['inactive'] = true;\r\n            inactiveWithParent.push(inactiveParent);\r\n          }\r\n          inactiveParent.cards.push(this.createDataForEntity(entity));\r\n        } else {\r\n          activeWithoutParent[0].cards.push(this.createDataForEntity(entity));\r\n        }\r\n      });\r\n\r\n      if (this.columnSort) {\r\n        var columnSortParts = this.columnSort.split('/');\r\n\r\n        lockedColumns = _.sortBy(lockedColumns, (o) => {\r\n          var v = this.getValueFromSortPath([o, columnSortParts]);\r\n          if (v)\r\n            return _.isString(v) ? v.trim() : v;\r\n          else\r\n            return null;\r\n        });\r\n        columns = _.sortBy(columns, (o) => {\r\n          var v = this.getValueFromSortPath([o, columnSortParts]);\r\n          if (v)\r\n            return _.isString(v) ? v.trim() : v;\r\n          else\r\n            return null;\r\n        });\r\n        inactiveWithParent = _.sortBy(inactiveWithParent, (o) => {\r\n          var v = this.getValueFromSortPath([o, columnSortParts]);\r\n          if (v)\r\n            return _.isString(v) ? v.trim() : v;\r\n          else\r\n            return null;\r\n        });\r\n        emptyParents = _.sortBy(emptyParents, (o) => {\r\n          var v = this.getValueFromSortPath([o, columnSortParts]);\r\n          if (v)\r\n            return _.isString(v) ? v.trim() : v;\r\n          else\r\n            return null;\r\n        });\r\n      }\r\n\r\n      if (this.cardSort) {\r\n        lockedColumns.forEach((column) => {\r\n          column.cards = this.cardSort(column.cards);\r\n        });\r\n\r\n        columns.forEach((column) => {\r\n          column.cards = this.cardSort(column.cards);\r\n        });\r\n\r\n        inactiveWithParent.forEach((column) => {\r\n          column.cards = this.cardSort(column.cards);\r\n        });\r\n\r\n        activeWithoutParent.forEach((column) => {\r\n          column.cards = this.cardSort(column.cards);\r\n        });\r\n      }\r\n\r\n      if (this.inactiveVisible)\r\n        columns = columns.concat(inactiveWithParent);\r\n\r\n      columns = columns.concat(emptyParents);\r\n\r\n      if (this.unassignedVisible && !this.unassignedLocked)\r\n        columns = columns.concat(activeWithoutParent);\r\n\r\n      if (this.unassignedVisible && this.unassignedLocked)\r\n        lockedColumns = columns.concat(lockedColumns);\r\n\r\n      this.lockedColumns = lockedColumns;\r\n      this.columns = columns;\r\n\r\n      setTimeout(() => {\r\n        this.clear();\r\n        new CardView(this.lockedColumns, this.columns);\r\n\r\n        if (revert) {\r\n          let columnElement = this.portal.querySelectorAll('.tru-card-portal-columns')[0];\r\n          let previousScrollPosition = localStorage.getItem('scroll_position' + uuidv4());\r\n          columnElement.scrollLeft = previousScrollPosition ? +previousScrollPosition : 0;\r\n        }\r\n      });\r\n    });\r\n\r\n    class CardView {\r\n      constructor(lockedColumns: any, columns: any) {\r\n\r\n      }\r\n    }\r\n  }\r\n}\r\n","<div class=\"tru-card\">\r\n  <div *ngIf=\"config.isBusy\"\r\n       class=\"tru-card-busy-indicator\">\r\n    <p>Searching for {{config.entityPluralLabel}}...</p>\r\n  </div>\r\n  <div *ngIf=\"config.busyMessage\"\r\n       class=\"tru-card-busy-indicator\">\r\n    <p>{{config.busyMessage}}</p>\r\n  </div>\r\n  <!--<tru-toolbar [config]=\"config.toolbarConfig\" class=\"main-toolbar {{config.searchPanelConfig.side}}\"></tru-toolbar>-->\r\n  <div class=\"tru-card-portal\">\r\n    <div [ngStyle]=\"{'width': ((config.width * lockedColumns.length) + (10 * lockedColumns.length - 1)) + 'px' }\"\r\n         [ngClass]=\"{'tru-card-portal-locked-columns-divider': lockedColumns.length}\"\r\n         *ngIf=\"lockedColumns.length\"\r\n         class=\"tru-card-portal-locked-columns locked-columns\">\r\n\r\n    </div>\r\n    <div [ngStyle]=\"{'left': lockedColumns.length ? ((config.width * lockedColumns.length) + (10 * lockedColumns.length - 1) + 22) + 'px' : 0 }\"\r\n         class=\"tru-card-portal-columns unlocked-columns\">\r\n\r\n    </div>\r\n  </div>\r\n</div>\r\n"]}
|