[Home] [Help]
PACKAGE BODY: APPS.AMS_DM_TARGET_VALUE_PVT_W
Source
1 package body ams_dm_target_value_pvt_w as
2 /* $Header: amswdtvb.pls 115.5 2002/11/16 00:07:22 nyostos noship $ */
3 rosetta_g_mistake_date date := to_date('01/01/+4713', 'MM/DD/SYYYY');
4 rosetta_g_miss_date date := to_date('01/01/-4712', 'MM/DD/SYYYY');
5
6 function rosetta_g_miss_num_map(n number) return number as
7 a number := fnd_api.g_miss_num;
8 b number := 0-1962.0724;
9 begin
10 if n=a then return b; end if;
11 if n=b then return a; end if;
12 return n;
13 end;
14
15 -- this is to workaround the JDBC bug regarding IN DATE of value GMiss
16 function rosetta_g_miss_date_in_map(d date) return date as
17 begin
18 if d = rosetta_g_mistake_date then return fnd_api.g_miss_date; end if;
19 return d;
20 end;
21
22 procedure rosetta_table_copy_in_p3(t OUT NOCOPY ams_dm_target_value_pvt.dm_target_value_tbl_type, a0 JTF_NUMBER_TABLE
23 , a1 JTF_DATE_TABLE
24 , a2 JTF_NUMBER_TABLE
25 , a3 JTF_DATE_TABLE
26 , a4 JTF_NUMBER_TABLE
27 , a5 JTF_NUMBER_TABLE
28 , a6 JTF_NUMBER_TABLE
29 , a7 JTF_NUMBER_TABLE
30 , a8 JTF_NUMBER_TABLE
31 , a9 JTF_VARCHAR2_TABLE_100
32 , a10 JTF_VARCHAR2_TABLE_100
33 , a11 JTF_VARCHAR2_TABLE_100
34 , a12 JTF_VARCHAR2_TABLE_4000
35 ) as
36 ddindx binary_integer; indx binary_integer;
37 begin
38 if a0 is not null and a0.count > 0 then
39 if a0.count > 0 then
40 indx := a0.first;
41 ddindx := 1;
42 while true loop
43 t(ddindx).target_value_id := rosetta_g_miss_num_map(a0(indx));
44 t(ddindx).last_update_date := rosetta_g_miss_date_in_map(a1(indx));
45 t(ddindx).last_updated_by := rosetta_g_miss_num_map(a2(indx));
46 t(ddindx).creation_date := rosetta_g_miss_date_in_map(a3(indx));
47 t(ddindx).created_by := rosetta_g_miss_num_map(a4(indx));
48 t(ddindx).last_update_login := rosetta_g_miss_num_map(a5(indx));
49 t(ddindx).object_version_number := rosetta_g_miss_num_map(a6(indx));
50 t(ddindx).security_group_id := rosetta_g_miss_num_map(a7(indx));
51 t(ddindx).target_id := rosetta_g_miss_num_map(a8(indx));
52 t(ddindx).target_value := a9(indx);
53 t(ddindx).target_operator := a10(indx);
54 t(ddindx).range_value := a11(indx);
55 t(ddindx).description := a12(indx);
56 ddindx := ddindx+1;
57 if a0.last =indx
58 then exit;
59 end if;
60 indx := a0.next(indx);
61 end loop;
62 end if;
63 end if;
64 end rosetta_table_copy_in_p3;
65 procedure rosetta_table_copy_out_p3(t ams_dm_target_value_pvt.dm_target_value_tbl_type, a0 OUT NOCOPY JTF_NUMBER_TABLE
66 , a1 OUT NOCOPY JTF_DATE_TABLE
67 , a2 OUT NOCOPY JTF_NUMBER_TABLE
68 , a3 OUT NOCOPY JTF_DATE_TABLE
69 , a4 OUT NOCOPY JTF_NUMBER_TABLE
70 , a5 OUT NOCOPY JTF_NUMBER_TABLE
71 , a6 OUT NOCOPY JTF_NUMBER_TABLE
72 , a7 OUT NOCOPY JTF_NUMBER_TABLE
73 , a8 OUT NOCOPY JTF_NUMBER_TABLE
74 , a9 OUT NOCOPY JTF_VARCHAR2_TABLE_100
75 , a10 OUT NOCOPY JTF_VARCHAR2_TABLE_100
76 , a11 OUT NOCOPY JTF_VARCHAR2_TABLE_100
77 , a12 OUT NOCOPY JTF_VARCHAR2_TABLE_4000
78 ) as
79 ddindx binary_integer; indx binary_integer;
80 begin
81 if t is null or t.count = 0 then
82 a0 := JTF_NUMBER_TABLE();
83 a1 := JTF_DATE_TABLE();
84 a2 := JTF_NUMBER_TABLE();
85 a3 := JTF_DATE_TABLE();
86 a4 := JTF_NUMBER_TABLE();
87 a5 := JTF_NUMBER_TABLE();
88 a6 := JTF_NUMBER_TABLE();
89 a7 := JTF_NUMBER_TABLE();
90 a8 := JTF_NUMBER_TABLE();
91 a9 := JTF_VARCHAR2_TABLE_100();
92 a10 := JTF_VARCHAR2_TABLE_100();
93 a11 := JTF_VARCHAR2_TABLE_100();
94 a12 := JTF_VARCHAR2_TABLE_4000();
95 else
96 a0 := JTF_NUMBER_TABLE();
97 a1 := JTF_DATE_TABLE();
98 a2 := JTF_NUMBER_TABLE();
99 a3 := JTF_DATE_TABLE();
100 a4 := JTF_NUMBER_TABLE();
101 a5 := JTF_NUMBER_TABLE();
102 a6 := JTF_NUMBER_TABLE();
103 a7 := JTF_NUMBER_TABLE();
104 a8 := JTF_NUMBER_TABLE();
105 a9 := JTF_VARCHAR2_TABLE_100();
106 a10 := JTF_VARCHAR2_TABLE_100();
107 a11 := JTF_VARCHAR2_TABLE_100();
108 a12 := JTF_VARCHAR2_TABLE_4000();
109 if t.count > 0 then
110 a0.extend(t.count);
111 a1.extend(t.count);
112 a2.extend(t.count);
113 a3.extend(t.count);
114 a4.extend(t.count);
115 a5.extend(t.count);
116 a6.extend(t.count);
117 a7.extend(t.count);
118 a8.extend(t.count);
119 a9.extend(t.count);
120 a10.extend(t.count);
121 a11.extend(t.count);
122 a12.extend(t.count);
123 ddindx := t.first;
124 indx := 1;
125 while true loop
126 a0(indx) := rosetta_g_miss_num_map(t(ddindx).target_value_id);
127 a1(indx) := t(ddindx).last_update_date;
128 a2(indx) := rosetta_g_miss_num_map(t(ddindx).last_updated_by);
129 a3(indx) := t(ddindx).creation_date;
130 a4(indx) := rosetta_g_miss_num_map(t(ddindx).created_by);
131 a5(indx) := rosetta_g_miss_num_map(t(ddindx).last_update_login);
132 a6(indx) := rosetta_g_miss_num_map(t(ddindx).object_version_number);
133 a7(indx) := rosetta_g_miss_num_map(t(ddindx).security_group_id);
134 a8(indx) := rosetta_g_miss_num_map(t(ddindx).target_id);
135 a9(indx) := t(ddindx).target_value;
136 a10(indx) := t(ddindx).target_operator;
137 a11(indx) := t(ddindx).range_value;
138 a12(indx) := t(ddindx).description;
139 indx := indx+1;
140 if t.last =ddindx
141 then exit;
142 end if;
143 ddindx := t.next(ddindx);
144 end loop;
145 end if;
146 end if;
147 end rosetta_table_copy_out_p3;
148
149 procedure create_dm_target_value(p_api_version_number NUMBER
150 , p_init_msg_list VARCHAR2
151 , p_commit VARCHAR2
152 , p_validation_level NUMBER
153 , x_return_status OUT NOCOPY VARCHAR2
154 , x_msg_count OUT NOCOPY NUMBER
155 , x_msg_data OUT NOCOPY VARCHAR2
156 , x_target_value_id OUT NOCOPY NUMBER
157 , p7_a0 NUMBER := 0-1962.0724
158 , p7_a1 DATE := fnd_api.g_miss_date
159 , p7_a2 NUMBER := 0-1962.0724
160 , p7_a3 DATE := fnd_api.g_miss_date
161 , p7_a4 NUMBER := 0-1962.0724
162 , p7_a5 NUMBER := 0-1962.0724
163 , p7_a6 NUMBER := 0-1962.0724
164 , p7_a7 NUMBER := 0-1962.0724
165 , p7_a8 NUMBER := 0-1962.0724
166 , p7_a9 VARCHAR2 := fnd_api.g_miss_char
167 , p7_a10 VARCHAR2 := fnd_api.g_miss_char
168 , p7_a11 VARCHAR2 := fnd_api.g_miss_char
169 , p7_a12 VARCHAR2 := fnd_api.g_miss_char
170 )
171 as
172 ddp_dm_target_value_rec ams_dm_target_value_pvt.dm_target_value_rec_type;
173 ddindx binary_integer; indx binary_integer;
174 begin
175
176 -- copy data to the local IN or IN-OUT args, if any
177
178
179
180
181
182
183
184 ddp_dm_target_value_rec.target_value_id := rosetta_g_miss_num_map(p7_a0);
185 ddp_dm_target_value_rec.last_update_date := rosetta_g_miss_date_in_map(p7_a1);
186 ddp_dm_target_value_rec.last_updated_by := rosetta_g_miss_num_map(p7_a2);
187 ddp_dm_target_value_rec.creation_date := rosetta_g_miss_date_in_map(p7_a3);
188 ddp_dm_target_value_rec.created_by := rosetta_g_miss_num_map(p7_a4);
189 ddp_dm_target_value_rec.last_update_login := rosetta_g_miss_num_map(p7_a5);
190 ddp_dm_target_value_rec.object_version_number := rosetta_g_miss_num_map(p7_a6);
191 ddp_dm_target_value_rec.security_group_id := rosetta_g_miss_num_map(p7_a7);
192 ddp_dm_target_value_rec.target_id := rosetta_g_miss_num_map(p7_a8);
193 ddp_dm_target_value_rec.target_value := p7_a9;
194 ddp_dm_target_value_rec.target_operator := p7_a10;
195 ddp_dm_target_value_rec.range_value := p7_a11;
196 ddp_dm_target_value_rec.description := p7_a12;
197
198
199 -- here's the delegated call to the old PL/SQL routine
200 ams_dm_target_value_pvt.create_dm_target_value(p_api_version_number,
201 p_init_msg_list,
202 p_commit,
203 p_validation_level,
204 x_return_status,
205 x_msg_count,
206 x_msg_data,
207 ddp_dm_target_value_rec,
208 x_target_value_id);
209
210 -- copy data back from the local OUT or IN-OUT args, if any
211
212
213
214
215
216
217
218
219 end;
220
221 procedure update_dm_target_value(p_api_version_number NUMBER
222 , p_init_msg_list VARCHAR2
223 , p_commit VARCHAR2
224 , p_validation_level NUMBER
225 , x_return_status OUT NOCOPY VARCHAR2
226 , x_msg_count OUT NOCOPY NUMBER
227 , x_msg_data OUT NOCOPY VARCHAR2
228 , x_object_version_number OUT NOCOPY NUMBER
229 , p7_a0 NUMBER := 0-1962.0724
230 , p7_a1 DATE := fnd_api.g_miss_date
231 , p7_a2 NUMBER := 0-1962.0724
232 , p7_a3 DATE := fnd_api.g_miss_date
233 , p7_a4 NUMBER := 0-1962.0724
234 , p7_a5 NUMBER := 0-1962.0724
235 , p7_a6 NUMBER := 0-1962.0724
236 , p7_a7 NUMBER := 0-1962.0724
237 , p7_a8 NUMBER := 0-1962.0724
238 , p7_a9 VARCHAR2 := fnd_api.g_miss_char
239 , p7_a10 VARCHAR2 := fnd_api.g_miss_char
240 , p7_a11 VARCHAR2 := fnd_api.g_miss_char
241 , p7_a12 VARCHAR2 := fnd_api.g_miss_char
242 )
243 as
244 ddp_dm_target_value_rec ams_dm_target_value_pvt.dm_target_value_rec_type;
245 ddindx binary_integer; indx binary_integer;
246 begin
247
248 -- copy data to the local IN or IN-OUT args, if any
249
250
251
252
253
254
255
256 ddp_dm_target_value_rec.target_value_id := rosetta_g_miss_num_map(p7_a0);
257 ddp_dm_target_value_rec.last_update_date := rosetta_g_miss_date_in_map(p7_a1);
258 ddp_dm_target_value_rec.last_updated_by := rosetta_g_miss_num_map(p7_a2);
259 ddp_dm_target_value_rec.creation_date := rosetta_g_miss_date_in_map(p7_a3);
260 ddp_dm_target_value_rec.created_by := rosetta_g_miss_num_map(p7_a4);
261 ddp_dm_target_value_rec.last_update_login := rosetta_g_miss_num_map(p7_a5);
262 ddp_dm_target_value_rec.object_version_number := rosetta_g_miss_num_map(p7_a6);
263 ddp_dm_target_value_rec.security_group_id := rosetta_g_miss_num_map(p7_a7);
264 ddp_dm_target_value_rec.target_id := rosetta_g_miss_num_map(p7_a8);
265 ddp_dm_target_value_rec.target_value := p7_a9;
266 ddp_dm_target_value_rec.target_operator := p7_a10;
267 ddp_dm_target_value_rec.range_value := p7_a11;
268 ddp_dm_target_value_rec.description := p7_a12;
269
270
271 -- here's the delegated call to the old PL/SQL routine
272 ams_dm_target_value_pvt.update_dm_target_value(p_api_version_number,
273 p_init_msg_list,
274 p_commit,
275 p_validation_level,
276 x_return_status,
277 x_msg_count,
278 x_msg_data,
279 ddp_dm_target_value_rec,
280 x_object_version_number);
281
282 -- copy data back from the local OUT or IN-OUT args, if any
283
284
285
286
287
288
289
290
291 end;
292
293 procedure validate_dm_target_value(p_api_version_number NUMBER
294 , p_init_msg_list VARCHAR2
295 , p_validation_level NUMBER
296 , p_validation_mode VARCHAR2
297 , x_return_status OUT NOCOPY VARCHAR2
298 , x_msg_count OUT NOCOPY NUMBER
299 , x_msg_data OUT NOCOPY VARCHAR2
300 , p3_a0 NUMBER := 0-1962.0724
301 , p3_a1 DATE := fnd_api.g_miss_date
302 , p3_a2 NUMBER := 0-1962.0724
303 , p3_a3 DATE := fnd_api.g_miss_date
304 , p3_a4 NUMBER := 0-1962.0724
305 , p3_a5 NUMBER := 0-1962.0724
306 , p3_a6 NUMBER := 0-1962.0724
307 , p3_a7 NUMBER := 0-1962.0724
308 , p3_a8 NUMBER := 0-1962.0724
309 , p3_a9 VARCHAR2 := fnd_api.g_miss_char
310 , p3_a10 VARCHAR2 := fnd_api.g_miss_char
311 , p3_a11 VARCHAR2 := fnd_api.g_miss_char
312 , p3_a12 VARCHAR2 := fnd_api.g_miss_char
313 )
314 as
315 ddp_dm_target_value_rec ams_dm_target_value_pvt.dm_target_value_rec_type;
316 ddindx binary_integer; indx binary_integer;
317 begin
318
319 -- copy data to the local IN or IN-OUT args, if any
320
321
322
323 ddp_dm_target_value_rec.target_value_id := rosetta_g_miss_num_map(p3_a0);
327 ddp_dm_target_value_rec.created_by := rosetta_g_miss_num_map(p3_a4);
324 ddp_dm_target_value_rec.last_update_date := rosetta_g_miss_date_in_map(p3_a1);
325 ddp_dm_target_value_rec.last_updated_by := rosetta_g_miss_num_map(p3_a2);
326 ddp_dm_target_value_rec.creation_date := rosetta_g_miss_date_in_map(p3_a3);
328 ddp_dm_target_value_rec.last_update_login := rosetta_g_miss_num_map(p3_a5);
329 ddp_dm_target_value_rec.object_version_number := rosetta_g_miss_num_map(p3_a6);
330 ddp_dm_target_value_rec.security_group_id := rosetta_g_miss_num_map(p3_a7);
331 ddp_dm_target_value_rec.target_id := rosetta_g_miss_num_map(p3_a8);
332 ddp_dm_target_value_rec.target_value := p3_a9;
333 ddp_dm_target_value_rec.target_operator := p3_a10;
334 ddp_dm_target_value_rec.range_value := p3_a11;
335 ddp_dm_target_value_rec.description := p3_a12;
336
337
338
339
340
341 -- here's the delegated call to the old PL/SQL routine
342 ams_dm_target_value_pvt.validate_dm_target_value(p_api_version_number,
343 p_init_msg_list,
344 p_validation_level,
345 ddp_dm_target_value_rec,
346 p_validation_mode,
347 x_return_status,
348 x_msg_count,
349 x_msg_data);
350
351 -- copy data back from the local OUT or IN-OUT args, if any
352
353
354
355
356
357
358
359 end;
360
361 procedure check_dm_target_value_items(p_validation_mode VARCHAR2
362 , x_return_status OUT NOCOPY VARCHAR2
363 , p0_a0 NUMBER := 0-1962.0724
364 , p0_a1 DATE := fnd_api.g_miss_date
365 , p0_a2 NUMBER := 0-1962.0724
366 , p0_a3 DATE := fnd_api.g_miss_date
367 , p0_a4 NUMBER := 0-1962.0724
368 , p0_a5 NUMBER := 0-1962.0724
369 , p0_a6 NUMBER := 0-1962.0724
370 , p0_a7 NUMBER := 0-1962.0724
371 , p0_a8 NUMBER := 0-1962.0724
372 , p0_a9 VARCHAR2 := fnd_api.g_miss_char
373 , p0_a10 VARCHAR2 := fnd_api.g_miss_char
374 , p0_a11 VARCHAR2 := fnd_api.g_miss_char
375 , p0_a12 VARCHAR2 := fnd_api.g_miss_char
376 )
377 as
378 ddp_dm_target_value_rec ams_dm_target_value_pvt.dm_target_value_rec_type;
379 ddindx binary_integer; indx binary_integer;
380 begin
381
382 -- copy data to the local IN or IN-OUT args, if any
383 ddp_dm_target_value_rec.target_value_id := rosetta_g_miss_num_map(p0_a0);
384 ddp_dm_target_value_rec.last_update_date := rosetta_g_miss_date_in_map(p0_a1);
385 ddp_dm_target_value_rec.last_updated_by := rosetta_g_miss_num_map(p0_a2);
386 ddp_dm_target_value_rec.creation_date := rosetta_g_miss_date_in_map(p0_a3);
387 ddp_dm_target_value_rec.created_by := rosetta_g_miss_num_map(p0_a4);
388 ddp_dm_target_value_rec.last_update_login := rosetta_g_miss_num_map(p0_a5);
389 ddp_dm_target_value_rec.object_version_number := rosetta_g_miss_num_map(p0_a6);
390 ddp_dm_target_value_rec.security_group_id := rosetta_g_miss_num_map(p0_a7);
391 ddp_dm_target_value_rec.target_id := rosetta_g_miss_num_map(p0_a8);
392 ddp_dm_target_value_rec.target_value := p0_a9;
393 ddp_dm_target_value_rec.target_operator := p0_a10;
394 ddp_dm_target_value_rec.range_value := p0_a11;
395 ddp_dm_target_value_rec.description := p0_a12;
396
397
398
399 -- here's the delegated call to the old PL/SQL routine
400 ams_dm_target_value_pvt.check_dm_target_value_items(ddp_dm_target_value_rec,
401 p_validation_mode,
402 x_return_status);
403
404 -- copy data back from the local OUT or IN-OUT args, if any
405
406
407 end;
408
409 procedure validate_dm_target_value_rec(p_api_version_number NUMBER
410 , p_init_msg_list VARCHAR2
411 , x_return_status OUT NOCOPY VARCHAR2
412 , x_msg_count OUT NOCOPY NUMBER
413 , x_msg_data OUT NOCOPY VARCHAR2
414 , p5_a0 NUMBER := 0-1962.0724
415 , p5_a1 DATE := fnd_api.g_miss_date
416 , p5_a2 NUMBER := 0-1962.0724
417 , p5_a3 DATE := fnd_api.g_miss_date
418 , p5_a4 NUMBER := 0-1962.0724
419 , p5_a5 NUMBER := 0-1962.0724
420 , p5_a6 NUMBER := 0-1962.0724
421 , p5_a7 NUMBER := 0-1962.0724
422 , p5_a8 NUMBER := 0-1962.0724
423 , p5_a9 VARCHAR2 := fnd_api.g_miss_char
424 , p5_a10 VARCHAR2 := fnd_api.g_miss_char
425 , p5_a11 VARCHAR2 := fnd_api.g_miss_char
426 , p5_a12 VARCHAR2 := fnd_api.g_miss_char
427 )
428 as
429 ddp_dm_target_value_rec ams_dm_target_value_pvt.dm_target_value_rec_type;
430 ddindx binary_integer; indx binary_integer;
431 begin
432
433 -- copy data to the local IN or IN-OUT args, if any
434
435
436
437
438
439 ddp_dm_target_value_rec.target_value_id := rosetta_g_miss_num_map(p5_a0);
440 ddp_dm_target_value_rec.last_update_date := rosetta_g_miss_date_in_map(p5_a1);
441 ddp_dm_target_value_rec.last_updated_by := rosetta_g_miss_num_map(p5_a2);
442 ddp_dm_target_value_rec.creation_date := rosetta_g_miss_date_in_map(p5_a3);
443 ddp_dm_target_value_rec.created_by := rosetta_g_miss_num_map(p5_a4);
444 ddp_dm_target_value_rec.last_update_login := rosetta_g_miss_num_map(p5_a5);
445 ddp_dm_target_value_rec.object_version_number := rosetta_g_miss_num_map(p5_a6);
446 ddp_dm_target_value_rec.security_group_id := rosetta_g_miss_num_map(p5_a7);
447 ddp_dm_target_value_rec.target_id := rosetta_g_miss_num_map(p5_a8);
448 ddp_dm_target_value_rec.target_value := p5_a9;
449 ddp_dm_target_value_rec.target_operator := p5_a10;
450 ddp_dm_target_value_rec.range_value := p5_a11;
451 ddp_dm_target_value_rec.description := p5_a12;
452
453 -- here's the delegated call to the old PL/SQL routine
454 ams_dm_target_value_pvt.validate_dm_target_value_rec(p_api_version_number,
455 p_init_msg_list,
456 x_return_status,
457 x_msg_count,
458 x_msg_data,
459 ddp_dm_target_value_rec);
460
461 -- copy data back from the local OUT or IN-OUT args, if any
462
463
464
465
466
467 end;
468
469 end ams_dm_target_value_pvt_w;