@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.
@@ -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"]}