1 PACKAGE BODY OE_2PC2_CONFIG_SHPCNF AS
2 PROCEDURE Is_Valid
3 (
4 p_application_id in number,
5 p_entity_short_name in varchar2,
6 p_validation_entity_short_name in varchar2,
7 p_validation_tmplt_short_name in varchar2,
8 p_record_set_short_name in varchar2,
9 p_scope in varchar2,
10 x_result out nocopy number
11 )
12 IS
13 l_valid_count NUMBER := 0;
14 l_set_count NUMBER := 0;
15
16 CURSOR C_VC IS
17 SELECT count(*)
18 FROM OE_AK_ORDER_LINES_V a
19 WHERE a.LINE_CATEGORY_CODE = 'ORDER'
20 AND a.SHIPPED_QUANTITY IS NOT NULL
21 AND ( a.LINE_ID ) IN
22 ( SELECT b.LINE_ID
23 FROM OE_AK_ORDER_LINES_V b
24 WHERE b.HEADER_ID = OE_LINE_SECURITY.g_record.HEADER_ID
25 AND b.TOP_MODEL_LINE_ID = OE_LINE_SECURITY.g_record.TOP_MODEL_LINE_ID
26 );
27
28 CURSOR C_RSC IS
29 SELECT count(*)
30 FROM OE_AK_ORDER_LINES_V b
31 WHERE b.HEADER_ID = OE_LINE_SECURITY.g_record.HEADER_ID
32 AND b.TOP_MODEL_LINE_ID = OE_LINE_SECURITY.g_record.TOP_MODEL_LINE_ID
33 ;
34
35 BEGIN
36 x_result := 0;
37 OPEN C_VC;
38 FETCH C_VC into l_valid_count;
39 CLOSE C_VC;
40 If (l_valid_count > 0) then
41 If (p_scope = 'ALL') then
42 OPEN C_RSC;
43 FETCH C_RSC into l_set_count;
44 CLOSE C_RSC;
45 If (l_valid_count = l_set_count) then
46 x_result := 1;
47 End If;
48 Else
49 x_result := 1;
50 End If;
51 End If;
52 Return;
53 END Is_Valid;
54 END OE_2PC2_CONFIG_SHPCNF;