renhao
2023-09-25 16d75807e01a336adb18e4a6888eb8e7aa7948ee
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
Quintiq file version 2.0
#parent: #root
EDIBroker MP_ExportProductsBroker
{
  MDSDefinition: MacroPlan
  EDIModelLink.Source InputProductsFromModel
  {
    SettingsEngineLink: 'domainmodel.ediremotedatasourcedefinition.remotestorage.inputproductsfrommodel'
    EDIMLTable DisaggregationFactor
    {
      PrimaryKeyColumns: ProductID
      PrimaryKeyColumns: Start
      PrimaryKeyColumns: StockingPointID
      TargetType: DisaggregationFactor
      TypeIndex: DisaggregationTypeIndex
      EDIMLColumn Factor { Attribute: Factor ValueType: Real }
      EDIMLColumn ProductID { Attribute: ProductID ValueType: String }
      EDIMLColumn Start { Attribute: Start ValueType: Date }
      EDIMLColumn StockingPointID { Attribute: StockingPointID ValueType: String }
    }
    EDIMLTable PISPSpecification
    {
      PrimaryKeyColumns: ProductID
      PrimaryKeyColumns: StockingPointID
      TargetType: PISPSpecification
      TypeIndex: PISPSpecificationTypeIndex
      EDIMLColumn HasUnitOfMeasure { Attribute: HasUnitOfMeasure ValueType: Boolean }
      EDIMLColumn InputLotSize { Attribute: InputLotSize ValueType: Real }
      EDIMLColumn IsExcludeShelfLifeAndMaturation { Attribute: IsExcludeShelfLifeAndMaturation ValueType: Boolean }
      EDIMLColumn IsExcluded { Attribute: IsExcluded ValueType: Boolean }
      EDIMLColumn IsExcludedFromBalancing { Attribute: IsExcludedFromBalancing ValueType: Boolean }
      EDIMLColumn IsNegativeInventoryAllowed { Attribute: IsNegativeInventoryAllowed ValueType: Boolean }
      EDIMLColumn IsSafetyStockKept { Attribute: IsSafetyStockKept ValueType: Boolean }
      EDIMLColumn ProductID { Attribute: ProductID ValueType: String }
      EDIMLColumn StockingPointID { Attribute: StockingPointID ValueType: String }
      EDIMLColumn UnitOfMeasureName { Attribute: UnitOfMeasureName ValueType: String }
    }
    EDIMLTable ProductLevel_MP
    {
      PrimaryKeyColumns: Name
      TargetType: ProductLevel_MP
      TypeIndex: ProductLevelTypeIndex
      EDIMLColumn IsProductCategory { Attribute: IsProductCategory ValueType: Boolean }
      EDIMLColumn Level { Attribute: Level ValueType: Number }
      EDIMLColumn Name { Attribute: Name ValueType: String }
    }
    EDIMLTable Product_MP
    {
      PrimaryKeyColumns: ID
      TargetType: Product_MP
      TypeIndex: ProductTypeIndex
      WithInstanceFilter: true
      EDIMLColumn DisplayIndex { Attribute: DisplayIndex ValueType: Number }
      EDIMLColumn HasMaturation { Attribute: HasMaturation ValueType: Boolean }
      EDIMLColumn HasShelfLife { Attribute: HasShelfLife ValueType: Boolean }
      EDIMLColumn ID { Attribute: ID ValueType: String }
      EDIMLColumn IconName { Attribute: IconName ValueType: String }
      EDIMLColumn IsByProduct { Attribute: IsByProduct ValueType: Boolean }
      EDIMLColumn IsExcludedFromFulfillmentKPI { Attribute: IsExcludedFromFulfillmentKPI ValueType: Boolean }
      EDIMLColumn IsExcludedFromOptimization { Attribute: IsExcludedFromOptimization ValueType: Boolean }
      EDIMLColumn IsPlannedAfterOptimization { Attribute: IsPlannedAfterOptimization ValueType: Boolean }
      EDIMLColumn MaturationDays { Attribute: MaturationDays ValueType: Real }
      EDIMLColumn Name { Attribute: Name ValueType: String }
      EDIMLColumn Notes { Attribute: Notes ValueType: String }
      EDIMLColumn ParentID { Attribute: ParentID ValueType: String }
      EDIMLColumn ShelfLife { Attribute: ShelfLife ValueType: Real }
      EDIMLColumn UnitOfMeasureName { Attribute: UnitOfMeasureName ValueType: String }
      EDIMLInstanceFilter
      {
        ArgumentExpression: 'selectset( this, Product_MP, p, p.CanBeExported() );'
      }
    }
  }
  EDITransformation.Transformation TransformProductsForExport
  {
    EDITableTransformation
    {
      InputTable: DisaggregationFactor
      OutputTable: DisaggregationFactors_MP
      EDIColumnMatch { InputColumn: Factor OutputColumn: Factor }
      EDIColumnMatch { InputColumn: ProductID OutputColumn: ProductID }
      EDIColumnMatch { InputColumn: Start OutputColumn: Start }
      EDIColumnMatch { InputColumn: StockingPointID OutputColumn: StockingPointID }
    }
    EDITableTransformation
    {
      InputTable: PISPSpecification
      OutputTable: PISPSpecifications_MP
      EDIColumnMatch { InputColumn: InputLotSize OutputColumn: InputLotSize }
      EDIColumnMatch { InputColumn: IsExcludeShelfLifeAndMaturation OutputColumn: IsExcludeShelfLifeAndMaturation }
      EDIColumnMatch
      {
        InputColumn: IsExcludedFromBalancing
        OutputColumn: IsExcludedFromBalancing
      }
      EDIColumnMatch
      {
        InputColumn: IsNegativeInventoryAllowed
        OutputColumn: IsNegativeInventoryAllowed
      }
      EDIColumnMatch
      {
        InputColumn: HasUnitOfMeasure
        OutputColumn: HasUnitOfMeasure
      }
      EDIColumnMatch
      {
        InputColumn: IsSafetyStockKept
        OutputColumn: IsSafetyStockKept
      }
      EDIColumnMatch
      {
        InputColumn: StockingPointID
        OutputColumn: StockingPointID
      }
      EDIColumnMatch
      {
        InputColumn: ProductID
        OutputColumn: ProductID
      }
      EDIColumnMatch
      {
        InputColumn: IsExcluded
        OutputColumn: IsExcluded
      }
      EDIColumnMatch
      {
        InputColumn: UnitOfMeasureName
        OutputColumn: UnitOfMeasureName
      }
    }
    EDITableTransformation
    {
      InputTable: ProductLevel_MP
      OutputTable: ProductLevels_MP
      EDIColumnMatch
      {
        InputColumn: IsProductCategory
        OutputColumn: IsProductCategory
      }
      EDIColumnMatch
      {
        InputColumn: Name
        OutputColumn: Name
      }
      EDIColumnMatch
      {
        InputColumn: Level
        OutputColumn: Level
      }
    }
    EDITableTransformation
    {
      InputTable: Product_MP
      OutputTable: Products_MP
      EDIColumnMatch { InputColumn: HasMaturation OutputColumn: HasMaturation }
      EDIColumnMatch { InputColumn: IsExcludedFromFulfillmentKPI OutputColumn: IsExcludedFromFulfillmentKPI }
      EDIColumnMatch
      {
        InputColumn: IsExcludedFromOptimization
        OutputColumn: IsExcludedFromOptimization
      }
      EDIColumnMatch
      {
        InputColumn: IsPlannedAfterOptimization
        OutputColumn: IsPlannedAfterOptimization
      }
      EDIColumnMatch { InputColumn: MaturationDays OutputColumn: MaturationDays }
      EDIColumnMatch
      {
        InputColumn: ShelfLife
        OutputColumn: ShelfLife
      }
      EDIColumnMatch
      {
        InputColumn: HasShelfLife
        OutputColumn: HasShelfLife
      }
      EDIColumnMatch
      {
        InputColumn: UnitOfMeasureName
        OutputColumn: UnitOfMeasureName
      }
      EDIColumnMatch
      {
        InputColumn: IconName
        OutputColumn: IconName
      }
      EDIColumnMatch
      {
        InputColumn: ParentID
        OutputColumn: ParentID
      }
      EDIColumnMatch
      {
        InputColumn: Notes
        OutputColumn: Notes
      }
      EDIColumnMatch
      {
        InputColumn: ID
        OutputColumn: ID
      }
      EDIColumnMatch
      {
        InputColumn: DisplayIndex
        OutputColumn: DisplayIndex
      }
      EDIColumnMatch
      {
        InputColumn: IsByProduct
        OutputColumn: IsByProduct
      }
      EDIColumnMatch
      {
        InputColumn: Name
        OutputColumn: Name
      }
    }
  }
  EDIXLSLink.Destination OutputProductsToExcel
  {
    FileName: 'MP_Products'
    SettingsEngineLink: 'domainmodel.ediremotedatasourcedefinition.remotestorage.outputproductstoexcel'
    EDIXLSLinkTable DisaggregationFactors_MP
    {
      Columns:
      [
        EDIXLSLinkColumn Factor { ValueType: Real }
        EDIXLSLinkColumn ProductID { ValueType: String }
        EDIXLSLinkColumn Start { ValueType: Date }
        EDIXLSLinkColumn StockingPointID { ValueType: String }
      ]
    }
    EDIXLSLinkTable PISPSpecifications_MP
    {
      Columns:
      [
        EDIXLSLinkColumn HasUnitOfMeasure { ValueType: Boolean }
        EDIXLSLinkColumn InputLotSize { ValueType: Real }
        EDIXLSLinkColumn IsExcluded { ValueType: Boolean }
        EDIXLSLinkColumn IsExcludedFromBalancing { ValueType: Boolean }
        EDIXLSLinkColumn IsExcludeShelfLifeAndMaturation { ValueType: Boolean }
        EDIXLSLinkColumn IsNegativeInventoryAllowed { ValueType: Boolean }
        EDIXLSLinkColumn IsSafetyStockKept { ValueType: Boolean }
        EDIXLSLinkColumn ProductID { ValueType: String }
        EDIXLSLinkColumn StockingPointID { ValueType: String }
        EDIXLSLinkColumn UnitOfMeasureName { ValueType: String }
      ]
    }
    EDIXLSLinkTable ProductLevels_MP
    {
      Columns:
      [
        EDIXLSLinkColumn IsProductCategory { ValueType: Boolean }
        EDIXLSLinkColumn Level { ValueType: Number }
        EDIXLSLinkColumn Name { ValueType: String }
      ]
    }
    EDIXLSLinkTable Products_MP
    {
      Columns:
      [
        EDIXLSLinkColumn DisplayIndex { ValueType: Number }
        EDIXLSLinkColumn HasMaturation { ValueType: Boolean }
        EDIXLSLinkColumn HasShelfLife { ValueType: Boolean }
        EDIXLSLinkColumn IconName { ValueType: String }
        EDIXLSLinkColumn ID { ValueType: String }
        EDIXLSLinkColumn IsByProduct { ValueType: Boolean }
        EDIXLSLinkColumn IsExcludedFromOptimization { ValueType: Boolean }
        EDIXLSLinkColumn IsPlannedAfterOptimization { ValueType: Boolean }
        EDIXLSLinkColumn MaturationDays { ValueType: Real }
        EDIXLSLinkColumn Name { ValueType: String }
        EDIXLSLinkColumn Notes { ValueType: String }
        EDIXLSLinkColumn ParentID { ValueType: String }
        EDIXLSLinkColumn ShelfLife { ValueType: Real }
        EDIXLSLinkColumn UnitOfMeasureName { ValueType: String }
        EDIXLSLinkColumn IsExcludedFromFulfillmentKPI { ValueType: Boolean }
      ]
    }
  }
}