@contrail/flexplm 1.3.0 → 1.3.1
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/.github/workflows/flexplm-lib.yml +1 -1
- package/.github/workflows/publish-to-npm.yml +35 -38
- package/lib/entity-processor/base-entity-processor.d.ts +42 -42
- package/lib/entity-processor/base-entity-processor.js +385 -385
- package/lib/entity-processor/base-entity-processor.spec.d.ts +1 -1
- package/lib/entity-processor/base-entity-processor.spec.js +397 -397
- package/lib/flexplm-request.d.ts +3 -3
- package/lib/flexplm-request.js +34 -34
- package/lib/flexplm-utils.d.ts +5 -5
- package/lib/flexplm-utils.js +33 -33
- package/lib/flexplm-utils.spec.d.ts +1 -1
- package/lib/flexplm-utils.spec.js +26 -26
- package/lib/index.d.ts +22 -22
- package/lib/index.js +38 -38
- package/lib/interfaces/interfaces.d.ts +105 -105
- package/lib/interfaces/interfaces.js +2 -2
- package/lib/interfaces/item-family-changes.d.ts +20 -20
- package/lib/interfaces/item-family-changes.js +56 -56
- package/lib/interfaces/publish-change-data.d.ts +19 -19
- package/lib/interfaces/publish-change-data.js +32 -32
- package/lib/publish/base-process-publish-assortment-callback.d.ts +9 -9
- package/lib/publish/base-process-publish-assortment-callback.js +38 -38
- package/lib/publish/base-process-publish-assortment.d.ts +93 -93
- package/lib/publish/base-process-publish-assortment.js +944 -944
- package/lib/publish/base-process-publish-assortment.spec.d.ts +1 -1
- package/lib/publish/base-process-publish-assortment.spec.js +1670 -1670
- package/lib/publish/mockData.d.ts +1389 -1389
- package/lib/publish/mockData.js +4519 -4519
- package/lib/transform/identifier-conversion-spec-mockData.js +444 -444
- package/lib/transform/identifier-conversion.d.ts +15 -15
- package/lib/transform/identifier-conversion.js +212 -212
- package/lib/transform/identifier-conversion.spec.d.ts +1 -1
- package/lib/transform/identifier-conversion.spec.js +339 -339
- package/lib/util/config-defaults.d.ts +8 -8
- package/lib/util/config-defaults.js +85 -85
- package/lib/util/config-defaults.spec.d.ts +1 -1
- package/lib/util/config-defaults.spec.js +293 -293
- package/lib/util/data-converter-spec-mockData.js +205 -205
- package/lib/util/data-converter.d.ts +39 -39
- package/lib/util/data-converter.js +592 -592
- package/lib/util/data-converter.spec.d.ts +1 -1
- package/lib/util/data-converter.spec.js +904 -904
- package/lib/util/error-response-object.d.ts +4 -4
- package/lib/util/error-response-object.js +47 -47
- package/lib/util/error-response-object.spec.d.ts +1 -1
- package/lib/util/error-response-object.spec.js +99 -99
- package/lib/util/event-short-message-status.d.ts +19 -19
- package/lib/util/event-short-message-status.js +23 -23
- package/lib/util/federation.d.ts +15 -15
- package/lib/util/federation.js +149 -149
- package/lib/util/flexplm-connect.d.ts +22 -22
- package/lib/util/flexplm-connect.js +176 -176
- package/lib/util/flexplm-connect.spec.d.ts +1 -1
- package/lib/util/flexplm-connect.spec.js +88 -88
- package/lib/util/logger-config.d.ts +1 -1
- package/lib/util/logger-config.js +26 -26
- package/lib/util/map-util-spec-mockData.js +205 -205
- package/lib/util/map-utils.d.ts +6 -6
- package/lib/util/map-utils.js +15 -15
- package/lib/util/map-utils.spec.d.ts +1 -1
- package/lib/util/map-utils.spec.js +89 -89
- package/lib/util/mockData.d.ts +80 -80
- package/lib/util/mockData.js +103 -103
- package/lib/util/thumbnail-util.d.ts +34 -34
- package/lib/util/thumbnail-util.js +215 -215
- package/lib/util/thumbnail-util.spec.d.ts +1 -1
- package/lib/util/thumbnail-util.spec.js +434 -434
- package/lib/util/type-conversion-utils-spec-mockData.js +259 -259
- package/lib/util/type-conversion-utils.d.ts +23 -23
- package/lib/util/type-conversion-utils.js +265 -265
- package/lib/util/type-conversion-utils.spec.d.ts +1 -1
- package/lib/util/type-conversion-utils.spec.js +868 -868
- package/lib/util/type-defaults.d.ts +16 -16
- package/lib/util/type-defaults.js +221 -221
- package/lib/util/type-defaults.spec.d.ts +1 -1
- package/lib/util/type-defaults.spec.js +516 -516
- package/lib/util/type-utils.d.ts +13 -13
- package/lib/util/type-utils.js +114 -114
- package/lib/util/type-utils.spec.d.ts +1 -1
- package/lib/util/type-utils.spec.js +190 -190
- package/package.json +1 -1
- package/publish.sh +0 -0
- package/tsconfig.json +1 -6
- package/.claude/settings.local.json +0 -8
|
@@ -1,205 +1,205 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
Object.defineProperty(exports, '__esModule', { value: true });
|
|
3
|
-
exports.mapping = {
|
|
4
|
-
typeConversion: {
|
|
5
|
-
vibe2flex: {
|
|
6
|
-
'custom-entity': {
|
|
7
|
-
getMapKey: (entity) => {
|
|
8
|
-
const typePath = entity['typePath'];
|
|
9
|
-
let mapKey = '';
|
|
10
|
-
switch (typePath) {
|
|
11
|
-
case 'custom-entity:pack':
|
|
12
|
-
mapKey = 'packaging';
|
|
13
|
-
break;
|
|
14
|
-
case 'custom-entity:prefix':
|
|
15
|
-
mapKey = 'prefix';
|
|
16
|
-
break;
|
|
17
|
-
case 'custom-entity:catName':
|
|
18
|
-
mapKey = 'catName';
|
|
19
|
-
break;
|
|
20
|
-
case 'custom-entity:partnerOrg':
|
|
21
|
-
mapKey = 'partnerOrg';
|
|
22
|
-
break;
|
|
23
|
-
case 'custom-entity:catFamily':
|
|
24
|
-
mapKey = 'catFamily';
|
|
25
|
-
break;
|
|
26
|
-
case 'custom-entity:formName':
|
|
27
|
-
mapKey = 'formName';
|
|
28
|
-
break;
|
|
29
|
-
}
|
|
30
|
-
return mapKey;
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
},
|
|
35
|
-
LCSProduct: {
|
|
36
|
-
vibeOwningKeys: ['itemNumber', 'lifecycleStage'],
|
|
37
|
-
vibe2flex: {
|
|
38
|
-
getClass: () => 'LCSProduct',
|
|
39
|
-
getSoftType: (entity) => {
|
|
40
|
-
const prodType = entity['prodType'];
|
|
41
|
-
let val = '';
|
|
42
|
-
switch (prodType) {
|
|
43
|
-
case 'acc':
|
|
44
|
-
val = 'Product\\Accesories';
|
|
45
|
-
break;
|
|
46
|
-
case 'app':
|
|
47
|
-
val = 'Product\\Apparel';
|
|
48
|
-
break;
|
|
49
|
-
case 'eqp':
|
|
50
|
-
val = 'Product\\Equipment';
|
|
51
|
-
break;
|
|
52
|
-
case 'foot':
|
|
53
|
-
val = 'Product\\Footwear';
|
|
54
|
-
break;
|
|
55
|
-
}
|
|
56
|
-
return val;
|
|
57
|
-
},
|
|
58
|
-
transformOrder: [{ processor: 'REKEY', rekeyDelete: true, rekeyTransformersKey: 'rekey' }, { processor: 'VALUE_TRANSFORM', functionTransformersKey: 'valueTransform' }],
|
|
59
|
-
rekey: {
|
|
60
|
-
productName: 'name',
|
|
61
|
-
vibeIQIdentifier: 'itemNumber'
|
|
62
|
-
},
|
|
63
|
-
valueTransform: {
|
|
64
|
-
transformEx: (row) => {
|
|
65
|
-
return row['otherProp'] + 'xxx';
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
},
|
|
69
|
-
flex2vibe: {
|
|
70
|
-
getClass: () => 'item',
|
|
71
|
-
transformOrder: [{ processor: 'REKEY', rekeyDelete: true, rekeyTransformersKey: 'rekey' }],
|
|
72
|
-
rekey: {
|
|
73
|
-
itemNumber: 'vibeIQIdentifier',
|
|
74
|
-
name: 'productName',
|
|
75
|
-
}
|
|
76
|
-
}
|
|
77
|
-
},
|
|
78
|
-
LCSSKU: {
|
|
79
|
-
vibeOwningKeys: ['itemNumber', 'lifecycleStage'],
|
|
80
|
-
vibe2flex: {
|
|
81
|
-
getClass: () => 'LCSSKU',
|
|
82
|
-
getSoftType: (entity) => {
|
|
83
|
-
const prodType = entity['prodType'];
|
|
84
|
-
let val = '';
|
|
85
|
-
switch (prodType) {
|
|
86
|
-
case 'acc':
|
|
87
|
-
val = 'Product\\Accesories';
|
|
88
|
-
break;
|
|
89
|
-
case 'app':
|
|
90
|
-
val = 'Product\\Apparel';
|
|
91
|
-
break;
|
|
92
|
-
case 'eqp':
|
|
93
|
-
val = 'Product\\Equipment';
|
|
94
|
-
break;
|
|
95
|
-
case 'foot':
|
|
96
|
-
val = 'Product\\Footwear';
|
|
97
|
-
break;
|
|
98
|
-
}
|
|
99
|
-
return val;
|
|
100
|
-
},
|
|
101
|
-
transformOrder: [{ processor: 'REKEY', rekeyDelete: true, rekeyTransformersKey: 'rekey' }],
|
|
102
|
-
rekey: {
|
|
103
|
-
skuName: 'optionName',
|
|
104
|
-
vibeIQIdentifier: 'itemNumber'
|
|
105
|
-
}
|
|
106
|
-
},
|
|
107
|
-
flex2vibe: {
|
|
108
|
-
transformOrder: [{ processor: 'REKEY', rekeyDelete: true, rekeyTransformersKey: 'rekey' }],
|
|
109
|
-
rekey: {
|
|
110
|
-
itemNumber: 'vibeIQIdentifier',
|
|
111
|
-
optionName: 'skuName',
|
|
112
|
-
}
|
|
113
|
-
}
|
|
114
|
-
},
|
|
115
|
-
packaging: {
|
|
116
|
-
vibe2flex: {
|
|
117
|
-
transformOrder: [{ processor: 'REKEY', rekeyDelete: true, rekeyTransformersKey: 'rekey' }],
|
|
118
|
-
rekey: {
|
|
119
|
-
retailPackType: 'packType',
|
|
120
|
-
retailIntroDate: 'introDate'
|
|
121
|
-
},
|
|
122
|
-
getSoftType: () => 'Revisable Entity\\packaging',
|
|
123
|
-
getClass: () => 'LCSRevisableEntity'
|
|
124
|
-
},
|
|
125
|
-
flex2vibe: {
|
|
126
|
-
transformOrder: [{ processor: 'REKEY', rekeyDelete: true, rekeyTransformersKey: 'rekey' }],
|
|
127
|
-
rekey: {
|
|
128
|
-
packType: 'retailPackType',
|
|
129
|
-
introDate: 'retailIntroDate'
|
|
130
|
-
},
|
|
131
|
-
getClass: () => 'custom-entity',
|
|
132
|
-
getSoftType: () => 'custom-entity:pack',
|
|
133
|
-
}
|
|
134
|
-
},
|
|
135
|
-
prefix: {
|
|
136
|
-
vibe2flex: {
|
|
137
|
-
transformOrder: [{ processor: 'REKEY', rekeyDelete: true, rekeyTransformersKey: 'rekey' }],
|
|
138
|
-
rekey: {
|
|
139
|
-
retailOwner: 'owner',
|
|
140
|
-
retailIntroDate: 'introDate'
|
|
141
|
-
},
|
|
142
|
-
getSoftType: () => 'Revisable Entity\\prefix',
|
|
143
|
-
getClass: () => 'LCSRevisableEntity'
|
|
144
|
-
},
|
|
145
|
-
flex2vibe: {
|
|
146
|
-
transformOrder: [{ processor: 'REKEY', rekeyDelete: true, rekeyTransformersKey: 'rekey' }],
|
|
147
|
-
rekey: {
|
|
148
|
-
owner: 'retailOwner',
|
|
149
|
-
introDate: 'retailIntroDate'
|
|
150
|
-
},
|
|
151
|
-
getClass: () => 'custom-entity',
|
|
152
|
-
getSoftType: () => 'custom-entity:prefix',
|
|
153
|
-
}
|
|
154
|
-
},
|
|
155
|
-
catName: {
|
|
156
|
-
getIdentifierProperties: () => ['catName', 'catNumber'],
|
|
157
|
-
getInformationalProperties: () => ['longName'],
|
|
158
|
-
vibe2flex: {
|
|
159
|
-
transformOrder: [],
|
|
160
|
-
getSoftType: () => 'Revisable Entity\\catName',
|
|
161
|
-
getClass: () => 'LCSLast'
|
|
162
|
-
},
|
|
163
|
-
flex2vibe: {
|
|
164
|
-
transformOrder: [],
|
|
165
|
-
getClass: () => 'custom-entity',
|
|
166
|
-
getSoftType: () => 'custom-entity:catName',
|
|
167
|
-
}
|
|
168
|
-
},
|
|
169
|
-
partnerOrg: {
|
|
170
|
-
vibe2flex: {
|
|
171
|
-
transformOrder: [],
|
|
172
|
-
getSoftType: () => 'Business Object\\partnerOrg',
|
|
173
|
-
getClass: () => 'LCSLifecycleManaged'
|
|
174
|
-
},
|
|
175
|
-
flex2vibe: {
|
|
176
|
-
transformOrder: [],
|
|
177
|
-
getClass: () => 'custom-entity',
|
|
178
|
-
getSoftType: () => 'custom-entity:partnerOrg',
|
|
179
|
-
}
|
|
180
|
-
},
|
|
181
|
-
catFamily: {
|
|
182
|
-
vibe2flex: {
|
|
183
|
-
transformOrder: [],
|
|
184
|
-
getSoftType: () => 'Revisable Entity\\catFamily',
|
|
185
|
-
getClass: () => 'LCSRevisableEntity'
|
|
186
|
-
},
|
|
187
|
-
flex2vibe: {
|
|
188
|
-
transformOrder: [],
|
|
189
|
-
getClass: () => 'custom-entity',
|
|
190
|
-
getSoftType: () => 'custom-entity:catFamily',
|
|
191
|
-
}
|
|
192
|
-
},
|
|
193
|
-
formName: {
|
|
194
|
-
vibe2flex: {
|
|
195
|
-
transformOrder: [],
|
|
196
|
-
getSoftType: () => 'Material\\form',
|
|
197
|
-
getClass: () => 'LCSMaterial'
|
|
198
|
-
},
|
|
199
|
-
flex2vibe: {
|
|
200
|
-
transformOrder: [],
|
|
201
|
-
getClass: () => 'custom-entity',
|
|
202
|
-
getSoftType: () => 'custom-entity:formName',
|
|
203
|
-
}
|
|
204
|
-
},
|
|
205
|
-
};
|
|
1
|
+
'use strict';
|
|
2
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
3
|
+
exports.mapping = {
|
|
4
|
+
typeConversion: {
|
|
5
|
+
vibe2flex: {
|
|
6
|
+
'custom-entity': {
|
|
7
|
+
getMapKey: (entity) => {
|
|
8
|
+
const typePath = entity['typePath'];
|
|
9
|
+
let mapKey = '';
|
|
10
|
+
switch (typePath) {
|
|
11
|
+
case 'custom-entity:pack':
|
|
12
|
+
mapKey = 'packaging';
|
|
13
|
+
break;
|
|
14
|
+
case 'custom-entity:prefix':
|
|
15
|
+
mapKey = 'prefix';
|
|
16
|
+
break;
|
|
17
|
+
case 'custom-entity:catName':
|
|
18
|
+
mapKey = 'catName';
|
|
19
|
+
break;
|
|
20
|
+
case 'custom-entity:partnerOrg':
|
|
21
|
+
mapKey = 'partnerOrg';
|
|
22
|
+
break;
|
|
23
|
+
case 'custom-entity:catFamily':
|
|
24
|
+
mapKey = 'catFamily';
|
|
25
|
+
break;
|
|
26
|
+
case 'custom-entity:formName':
|
|
27
|
+
mapKey = 'formName';
|
|
28
|
+
break;
|
|
29
|
+
}
|
|
30
|
+
return mapKey;
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
},
|
|
35
|
+
LCSProduct: {
|
|
36
|
+
vibeOwningKeys: ['itemNumber', 'lifecycleStage'],
|
|
37
|
+
vibe2flex: {
|
|
38
|
+
getClass: () => 'LCSProduct',
|
|
39
|
+
getSoftType: (entity) => {
|
|
40
|
+
const prodType = entity['prodType'];
|
|
41
|
+
let val = '';
|
|
42
|
+
switch (prodType) {
|
|
43
|
+
case 'acc':
|
|
44
|
+
val = 'Product\\Accesories';
|
|
45
|
+
break;
|
|
46
|
+
case 'app':
|
|
47
|
+
val = 'Product\\Apparel';
|
|
48
|
+
break;
|
|
49
|
+
case 'eqp':
|
|
50
|
+
val = 'Product\\Equipment';
|
|
51
|
+
break;
|
|
52
|
+
case 'foot':
|
|
53
|
+
val = 'Product\\Footwear';
|
|
54
|
+
break;
|
|
55
|
+
}
|
|
56
|
+
return val;
|
|
57
|
+
},
|
|
58
|
+
transformOrder: [{ processor: 'REKEY', rekeyDelete: true, rekeyTransformersKey: 'rekey' }, { processor: 'VALUE_TRANSFORM', functionTransformersKey: 'valueTransform' }],
|
|
59
|
+
rekey: {
|
|
60
|
+
productName: 'name',
|
|
61
|
+
vibeIQIdentifier: 'itemNumber'
|
|
62
|
+
},
|
|
63
|
+
valueTransform: {
|
|
64
|
+
transformEx: (row) => {
|
|
65
|
+
return row['otherProp'] + 'xxx';
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
},
|
|
69
|
+
flex2vibe: {
|
|
70
|
+
getClass: () => 'item',
|
|
71
|
+
transformOrder: [{ processor: 'REKEY', rekeyDelete: true, rekeyTransformersKey: 'rekey' }],
|
|
72
|
+
rekey: {
|
|
73
|
+
itemNumber: 'vibeIQIdentifier',
|
|
74
|
+
name: 'productName',
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
},
|
|
78
|
+
LCSSKU: {
|
|
79
|
+
vibeOwningKeys: ['itemNumber', 'lifecycleStage'],
|
|
80
|
+
vibe2flex: {
|
|
81
|
+
getClass: () => 'LCSSKU',
|
|
82
|
+
getSoftType: (entity) => {
|
|
83
|
+
const prodType = entity['prodType'];
|
|
84
|
+
let val = '';
|
|
85
|
+
switch (prodType) {
|
|
86
|
+
case 'acc':
|
|
87
|
+
val = 'Product\\Accesories';
|
|
88
|
+
break;
|
|
89
|
+
case 'app':
|
|
90
|
+
val = 'Product\\Apparel';
|
|
91
|
+
break;
|
|
92
|
+
case 'eqp':
|
|
93
|
+
val = 'Product\\Equipment';
|
|
94
|
+
break;
|
|
95
|
+
case 'foot':
|
|
96
|
+
val = 'Product\\Footwear';
|
|
97
|
+
break;
|
|
98
|
+
}
|
|
99
|
+
return val;
|
|
100
|
+
},
|
|
101
|
+
transformOrder: [{ processor: 'REKEY', rekeyDelete: true, rekeyTransformersKey: 'rekey' }],
|
|
102
|
+
rekey: {
|
|
103
|
+
skuName: 'optionName',
|
|
104
|
+
vibeIQIdentifier: 'itemNumber'
|
|
105
|
+
}
|
|
106
|
+
},
|
|
107
|
+
flex2vibe: {
|
|
108
|
+
transformOrder: [{ processor: 'REKEY', rekeyDelete: true, rekeyTransformersKey: 'rekey' }],
|
|
109
|
+
rekey: {
|
|
110
|
+
itemNumber: 'vibeIQIdentifier',
|
|
111
|
+
optionName: 'skuName',
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
},
|
|
115
|
+
packaging: {
|
|
116
|
+
vibe2flex: {
|
|
117
|
+
transformOrder: [{ processor: 'REKEY', rekeyDelete: true, rekeyTransformersKey: 'rekey' }],
|
|
118
|
+
rekey: {
|
|
119
|
+
retailPackType: 'packType',
|
|
120
|
+
retailIntroDate: 'introDate'
|
|
121
|
+
},
|
|
122
|
+
getSoftType: () => 'Revisable Entity\\packaging',
|
|
123
|
+
getClass: () => 'LCSRevisableEntity'
|
|
124
|
+
},
|
|
125
|
+
flex2vibe: {
|
|
126
|
+
transformOrder: [{ processor: 'REKEY', rekeyDelete: true, rekeyTransformersKey: 'rekey' }],
|
|
127
|
+
rekey: {
|
|
128
|
+
packType: 'retailPackType',
|
|
129
|
+
introDate: 'retailIntroDate'
|
|
130
|
+
},
|
|
131
|
+
getClass: () => 'custom-entity',
|
|
132
|
+
getSoftType: () => 'custom-entity:pack',
|
|
133
|
+
}
|
|
134
|
+
},
|
|
135
|
+
prefix: {
|
|
136
|
+
vibe2flex: {
|
|
137
|
+
transformOrder: [{ processor: 'REKEY', rekeyDelete: true, rekeyTransformersKey: 'rekey' }],
|
|
138
|
+
rekey: {
|
|
139
|
+
retailOwner: 'owner',
|
|
140
|
+
retailIntroDate: 'introDate'
|
|
141
|
+
},
|
|
142
|
+
getSoftType: () => 'Revisable Entity\\prefix',
|
|
143
|
+
getClass: () => 'LCSRevisableEntity'
|
|
144
|
+
},
|
|
145
|
+
flex2vibe: {
|
|
146
|
+
transformOrder: [{ processor: 'REKEY', rekeyDelete: true, rekeyTransformersKey: 'rekey' }],
|
|
147
|
+
rekey: {
|
|
148
|
+
owner: 'retailOwner',
|
|
149
|
+
introDate: 'retailIntroDate'
|
|
150
|
+
},
|
|
151
|
+
getClass: () => 'custom-entity',
|
|
152
|
+
getSoftType: () => 'custom-entity:prefix',
|
|
153
|
+
}
|
|
154
|
+
},
|
|
155
|
+
catName: {
|
|
156
|
+
getIdentifierProperties: () => ['catName', 'catNumber'],
|
|
157
|
+
getInformationalProperties: () => ['longName'],
|
|
158
|
+
vibe2flex: {
|
|
159
|
+
transformOrder: [],
|
|
160
|
+
getSoftType: () => 'Revisable Entity\\catName',
|
|
161
|
+
getClass: () => 'LCSLast'
|
|
162
|
+
},
|
|
163
|
+
flex2vibe: {
|
|
164
|
+
transformOrder: [],
|
|
165
|
+
getClass: () => 'custom-entity',
|
|
166
|
+
getSoftType: () => 'custom-entity:catName',
|
|
167
|
+
}
|
|
168
|
+
},
|
|
169
|
+
partnerOrg: {
|
|
170
|
+
vibe2flex: {
|
|
171
|
+
transformOrder: [],
|
|
172
|
+
getSoftType: () => 'Business Object\\partnerOrg',
|
|
173
|
+
getClass: () => 'LCSLifecycleManaged'
|
|
174
|
+
},
|
|
175
|
+
flex2vibe: {
|
|
176
|
+
transformOrder: [],
|
|
177
|
+
getClass: () => 'custom-entity',
|
|
178
|
+
getSoftType: () => 'custom-entity:partnerOrg',
|
|
179
|
+
}
|
|
180
|
+
},
|
|
181
|
+
catFamily: {
|
|
182
|
+
vibe2flex: {
|
|
183
|
+
transformOrder: [],
|
|
184
|
+
getSoftType: () => 'Revisable Entity\\catFamily',
|
|
185
|
+
getClass: () => 'LCSRevisableEntity'
|
|
186
|
+
},
|
|
187
|
+
flex2vibe: {
|
|
188
|
+
transformOrder: [],
|
|
189
|
+
getClass: () => 'custom-entity',
|
|
190
|
+
getSoftType: () => 'custom-entity:catFamily',
|
|
191
|
+
}
|
|
192
|
+
},
|
|
193
|
+
formName: {
|
|
194
|
+
vibe2flex: {
|
|
195
|
+
transformOrder: [],
|
|
196
|
+
getSoftType: () => 'Material\\form',
|
|
197
|
+
getClass: () => 'LCSMaterial'
|
|
198
|
+
},
|
|
199
|
+
flex2vibe: {
|
|
200
|
+
transformOrder: [],
|
|
201
|
+
getClass: () => 'custom-entity',
|
|
202
|
+
getSoftType: () => 'custom-entity:formName',
|
|
203
|
+
}
|
|
204
|
+
},
|
|
205
|
+
};
|
package/lib/util/map-utils.d.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import { MapFileUtil } from '@contrail/transform-data';
|
|
2
|
-
export declare class MapUtil {
|
|
3
|
-
static applyTransformMap(transformMapFile: any, mapFileUtil: any, data: any, mapSectionKey: string, direction: string, transformTaskOrderKey?: string): Promise<any>;
|
|
4
|
-
static getMapKey(transformMapFile: any, mapFileUtil: MapFileUtil, data: any, type: string, direction: string): Promise<string>;
|
|
5
|
-
static getFullMapSection(transformMapFile: string, mapFileUtil: MapFileUtil, mapSectionKey: string): Promise<any>;
|
|
6
|
-
}
|
|
1
|
+
import { MapFileUtil } from '@contrail/transform-data';
|
|
2
|
+
export declare class MapUtil {
|
|
3
|
+
static applyTransformMap(transformMapFile: any, mapFileUtil: any, data: any, mapSectionKey: string, direction: string, transformTaskOrderKey?: string): Promise<any>;
|
|
4
|
+
static getMapKey(transformMapFile: any, mapFileUtil: MapFileUtil, data: any, type: string, direction: string): Promise<string>;
|
|
5
|
+
static getFullMapSection(transformMapFile: string, mapFileUtil: MapFileUtil, mapSectionKey: string): Promise<any>;
|
|
6
|
+
}
|
package/lib/util/map-utils.js
CHANGED
|
@@ -1,15 +1,15 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.MapUtil = void 0;
|
|
4
|
-
class MapUtil {
|
|
5
|
-
static async applyTransformMap(transformMapFile, mapFileUtil, data, mapSectionKey, direction, transformTaskOrderKey = 'transformOrder') {
|
|
6
|
-
return await mapFileUtil.applyTransformMap(transformMapFile, data, mapSectionKey, direction, transformTaskOrderKey);
|
|
7
|
-
}
|
|
8
|
-
static async getMapKey(transformMapFile, mapFileUtil, data, type, direction) {
|
|
9
|
-
return await mapFileUtil.getMapKey(transformMapFile, data, type, direction);
|
|
10
|
-
}
|
|
11
|
-
static async getFullMapSection(transformMapFile, mapFileUtil, mapSectionKey) {
|
|
12
|
-
return await mapFileUtil.getFullMapSection(transformMapFile, mapSectionKey);
|
|
13
|
-
}
|
|
14
|
-
}
|
|
15
|
-
exports.MapUtil = MapUtil;
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.MapUtil = void 0;
|
|
4
|
+
class MapUtil {
|
|
5
|
+
static async applyTransformMap(transformMapFile, mapFileUtil, data, mapSectionKey, direction, transformTaskOrderKey = 'transformOrder') {
|
|
6
|
+
return await mapFileUtil.applyTransformMap(transformMapFile, data, mapSectionKey, direction, transformTaskOrderKey);
|
|
7
|
+
}
|
|
8
|
+
static async getMapKey(transformMapFile, mapFileUtil, data, type, direction) {
|
|
9
|
+
return await mapFileUtil.getMapKey(transformMapFile, data, type, direction);
|
|
10
|
+
}
|
|
11
|
+
static async getFullMapSection(transformMapFile, mapFileUtil, mapSectionKey) {
|
|
12
|
+
return await mapFileUtil.getFullMapSection(transformMapFile, mapSectionKey);
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
exports.MapUtil = MapUtil;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
export {};
|
|
1
|
+
export {};
|
|
@@ -1,89 +1,89 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const maps = require('./map-util-spec-mockData').mapping;
|
|
4
|
-
const mockData = {
|
|
5
|
-
file1: maps
|
|
6
|
-
};
|
|
7
|
-
const mockGetMapFileFunction = jest.fn(async (fileId) => {
|
|
8
|
-
return mockData[fileId];
|
|
9
|
-
});
|
|
10
|
-
const sdk_1 = require("@contrail/sdk");
|
|
11
|
-
const transform_data_1 = require("@contrail/transform-data");
|
|
12
|
-
const map_utils_1 = require("./map-utils");
|
|
13
|
-
describe('getMapKey', () => {
|
|
14
|
-
const transformMapFile = 'file1';
|
|
15
|
-
const mapFileUtil = new transform_data_1.MapFileUtil(new sdk_1.Entities());
|
|
16
|
-
let spy;
|
|
17
|
-
beforeAll(() => {
|
|
18
|
-
spy = jest.spyOn(mapFileUtil, 'getMapFile').mockImplementation(mockGetMapFileFunction);
|
|
19
|
-
});
|
|
20
|
-
beforeEach(() => {
|
|
21
|
-
spy.mockClear();
|
|
22
|
-
});
|
|
23
|
-
afterAll(() => {
|
|
24
|
-
spy.mockRestore();
|
|
25
|
-
});
|
|
26
|
-
it('custom-entity:pack', async () => {
|
|
27
|
-
const entity = {
|
|
28
|
-
typePath: 'custom-entity:pack',
|
|
29
|
-
entityType: 'custom-entity'
|
|
30
|
-
};
|
|
31
|
-
const expectedMapKey = 'packaging';
|
|
32
|
-
const results = await map_utils_1.MapUtil.getMapKey(transformMapFile, mapFileUtil, entity, entity.entityType, 'vibe2flex');
|
|
33
|
-
;
|
|
34
|
-
expect(results).toEqual(expectedMapKey);
|
|
35
|
-
});
|
|
36
|
-
it('custom-entity:prefix', async () => {
|
|
37
|
-
const entity = {
|
|
38
|
-
typePath: 'custom-entity:prefix',
|
|
39
|
-
entityType: 'custom-entity'
|
|
40
|
-
};
|
|
41
|
-
const expectedMapKey = 'prefix';
|
|
42
|
-
const results = await map_utils_1.MapUtil.getMapKey(transformMapFile, mapFileUtil, entity, entity.entityType, 'vibe2flex');
|
|
43
|
-
;
|
|
44
|
-
expect(results).toEqual(expectedMapKey);
|
|
45
|
-
});
|
|
46
|
-
it('color - no mapping exists', async () => {
|
|
47
|
-
const entity = {
|
|
48
|
-
typePath: 'color',
|
|
49
|
-
entityType: 'color'
|
|
50
|
-
};
|
|
51
|
-
const expectedMapKey = undefined;
|
|
52
|
-
const results = await map_utils_1.MapUtil.getMapKey(transformMapFile, mapFileUtil, entity, entity.entityType, 'vibe2flex');
|
|
53
|
-
;
|
|
54
|
-
expect(results).toEqual(expectedMapKey);
|
|
55
|
-
});
|
|
56
|
-
});
|
|
57
|
-
describe('getFullMapSection', () => {
|
|
58
|
-
const transformMapFile = 'file1';
|
|
59
|
-
const mapFileUtil = new transform_data_1.MapFileUtil(new sdk_1.Entities());
|
|
60
|
-
let spy;
|
|
61
|
-
beforeAll(() => {
|
|
62
|
-
spy = jest.spyOn(mapFileUtil, 'getMapFile').mockImplementation(mockGetMapFileFunction);
|
|
63
|
-
});
|
|
64
|
-
beforeEach(() => {
|
|
65
|
-
spy.mockClear();
|
|
66
|
-
});
|
|
67
|
-
afterAll(() => {
|
|
68
|
-
spy.mockRestore();
|
|
69
|
-
});
|
|
70
|
-
it('custom-entity:pack', async () => {
|
|
71
|
-
const mapKey = 'packaging';
|
|
72
|
-
const mapSection = await map_utils_1.MapUtil.getFullMapSection(transformMapFile, mapFileUtil, mapKey);
|
|
73
|
-
expect(mapSection).toHaveProperty('vibe2flex');
|
|
74
|
-
expect(mapSection).toHaveProperty('flex2vibe');
|
|
75
|
-
});
|
|
76
|
-
it('custom-entity:catName', async () => {
|
|
77
|
-
const mapKey = 'catName';
|
|
78
|
-
const mapSection = await map_utils_1.MapUtil.getFullMapSection(transformMapFile, mapFileUtil, mapKey);
|
|
79
|
-
expect(mapSection).toHaveProperty('vibe2flex');
|
|
80
|
-
expect(mapSection).toHaveProperty('flex2vibe');
|
|
81
|
-
expect(mapSection).toHaveProperty('getIdentifierProperties');
|
|
82
|
-
expect(mapSection).toHaveProperty('getInformationalProperties');
|
|
83
|
-
});
|
|
84
|
-
it('color - no mapping exists', async () => {
|
|
85
|
-
const mapKey = 'color';
|
|
86
|
-
const mapSection = await map_utils_1.MapUtil.getFullMapSection(transformMapFile, mapFileUtil, mapKey);
|
|
87
|
-
expect(mapSection).toBeUndefined();
|
|
88
|
-
});
|
|
89
|
-
});
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const maps = require('./map-util-spec-mockData').mapping;
|
|
4
|
+
const mockData = {
|
|
5
|
+
file1: maps
|
|
6
|
+
};
|
|
7
|
+
const mockGetMapFileFunction = jest.fn(async (fileId) => {
|
|
8
|
+
return mockData[fileId];
|
|
9
|
+
});
|
|
10
|
+
const sdk_1 = require("@contrail/sdk");
|
|
11
|
+
const transform_data_1 = require("@contrail/transform-data");
|
|
12
|
+
const map_utils_1 = require("./map-utils");
|
|
13
|
+
describe('getMapKey', () => {
|
|
14
|
+
const transformMapFile = 'file1';
|
|
15
|
+
const mapFileUtil = new transform_data_1.MapFileUtil(new sdk_1.Entities());
|
|
16
|
+
let spy;
|
|
17
|
+
beforeAll(() => {
|
|
18
|
+
spy = jest.spyOn(mapFileUtil, 'getMapFile').mockImplementation(mockGetMapFileFunction);
|
|
19
|
+
});
|
|
20
|
+
beforeEach(() => {
|
|
21
|
+
spy.mockClear();
|
|
22
|
+
});
|
|
23
|
+
afterAll(() => {
|
|
24
|
+
spy.mockRestore();
|
|
25
|
+
});
|
|
26
|
+
it('custom-entity:pack', async () => {
|
|
27
|
+
const entity = {
|
|
28
|
+
typePath: 'custom-entity:pack',
|
|
29
|
+
entityType: 'custom-entity'
|
|
30
|
+
};
|
|
31
|
+
const expectedMapKey = 'packaging';
|
|
32
|
+
const results = await map_utils_1.MapUtil.getMapKey(transformMapFile, mapFileUtil, entity, entity.entityType, 'vibe2flex');
|
|
33
|
+
;
|
|
34
|
+
expect(results).toEqual(expectedMapKey);
|
|
35
|
+
});
|
|
36
|
+
it('custom-entity:prefix', async () => {
|
|
37
|
+
const entity = {
|
|
38
|
+
typePath: 'custom-entity:prefix',
|
|
39
|
+
entityType: 'custom-entity'
|
|
40
|
+
};
|
|
41
|
+
const expectedMapKey = 'prefix';
|
|
42
|
+
const results = await map_utils_1.MapUtil.getMapKey(transformMapFile, mapFileUtil, entity, entity.entityType, 'vibe2flex');
|
|
43
|
+
;
|
|
44
|
+
expect(results).toEqual(expectedMapKey);
|
|
45
|
+
});
|
|
46
|
+
it('color - no mapping exists', async () => {
|
|
47
|
+
const entity = {
|
|
48
|
+
typePath: 'color',
|
|
49
|
+
entityType: 'color'
|
|
50
|
+
};
|
|
51
|
+
const expectedMapKey = undefined;
|
|
52
|
+
const results = await map_utils_1.MapUtil.getMapKey(transformMapFile, mapFileUtil, entity, entity.entityType, 'vibe2flex');
|
|
53
|
+
;
|
|
54
|
+
expect(results).toEqual(expectedMapKey);
|
|
55
|
+
});
|
|
56
|
+
});
|
|
57
|
+
describe('getFullMapSection', () => {
|
|
58
|
+
const transformMapFile = 'file1';
|
|
59
|
+
const mapFileUtil = new transform_data_1.MapFileUtil(new sdk_1.Entities());
|
|
60
|
+
let spy;
|
|
61
|
+
beforeAll(() => {
|
|
62
|
+
spy = jest.spyOn(mapFileUtil, 'getMapFile').mockImplementation(mockGetMapFileFunction);
|
|
63
|
+
});
|
|
64
|
+
beforeEach(() => {
|
|
65
|
+
spy.mockClear();
|
|
66
|
+
});
|
|
67
|
+
afterAll(() => {
|
|
68
|
+
spy.mockRestore();
|
|
69
|
+
});
|
|
70
|
+
it('custom-entity:pack', async () => {
|
|
71
|
+
const mapKey = 'packaging';
|
|
72
|
+
const mapSection = await map_utils_1.MapUtil.getFullMapSection(transformMapFile, mapFileUtil, mapKey);
|
|
73
|
+
expect(mapSection).toHaveProperty('vibe2flex');
|
|
74
|
+
expect(mapSection).toHaveProperty('flex2vibe');
|
|
75
|
+
});
|
|
76
|
+
it('custom-entity:catName', async () => {
|
|
77
|
+
const mapKey = 'catName';
|
|
78
|
+
const mapSection = await map_utils_1.MapUtil.getFullMapSection(transformMapFile, mapFileUtil, mapKey);
|
|
79
|
+
expect(mapSection).toHaveProperty('vibe2flex');
|
|
80
|
+
expect(mapSection).toHaveProperty('flex2vibe');
|
|
81
|
+
expect(mapSection).toHaveProperty('getIdentifierProperties');
|
|
82
|
+
expect(mapSection).toHaveProperty('getInformationalProperties');
|
|
83
|
+
});
|
|
84
|
+
it('color - no mapping exists', async () => {
|
|
85
|
+
const mapKey = 'color';
|
|
86
|
+
const mapSection = await map_utils_1.MapUtil.getFullMapSection(transformMapFile, mapFileUtil, mapKey);
|
|
87
|
+
expect(mapSection).toBeUndefined();
|
|
88
|
+
});
|
|
89
|
+
});
|