Subversion Repositories DevTools

Rev

Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
13 rsolanki 1
<%@LANGUAGE="VBSCRIPT"%>
2
<%
3
'=====================================================
4
'|                                                   |
5
'|			          wEditProd					 	 |
6
'|                                                   |
7
'=====================================================
8
%>
9
<%
10
Option explicit
11
Response.Expires = 0
12
%>
13
<!--#include file="common/globals.asp"-->
14
<!--#include file="common/config.asp"-->
15
<!--#include file="common/common_subs.asp"-->
16
<!--#include file="common/_popup_window_common.asp"-->
17
<%
18
'------------ ACCESS CONTROL ------------------
19
%>
20
<!--#include file="_access_control_general.asp"-->
21
<%
22
'------------ VARIABLE DEFINITION -------------
23
Dim objFormCollector
24
Dim aRs
25
Dim MoreLink
26
Dim parFilter_on
27
Dim ForceDropdown
28
Dim parBase_env_id
29
'------------ CONSTANTS DECLARATION -----------
30
'------------ VARIABLE INIT -------------------
31
parProd_id = Request("prod_id_list")
32
parOs_id = Request("os_id")
33
parBom_id = Request("bom_id")
34
parFilter_on = Request("filter_on")
35
parBase_env_id = Request("base_env_id")
36
Set objFormCollector = CreateObject("Scripting.Dictionary")
37
'------------ CONDITIONS ----------------------
38
'----------------------------------------------
39
%>
40
<%
41
'--------------------------------------------------------------------------------------------------------------------------
42
Sub GetFormDetails ( nProd_id, nOs_id, nBaseEnvId, nBom_id, ByRef outobjDetails )
43
	Dim rsQry, query
44
	OraDatabase.Parameters.Add "PROD_ID", nProd_id,	ORAPARM_INPUT, ORATYPE_NUMBER 
45
	OraDatabase.Parameters.Add "BOM_ID", nBom_id,	ORAPARM_INPUT, ORATYPE_NUMBER 
46
 
47
	If nBaseEnvId = "" Then
48
		OraDatabase.Parameters.Add "OS_ID", nOs_id,	ORAPARM_INPUT, ORATYPE_NUMBER 
49
		query = GetQuery("ProductDetailsAtOs.sql")
50
	Else
51
		OraDatabase.Parameters.Add "BASE_ENV_ID", nBaseEnvId,	ORAPARM_INPUT, ORATYPE_NUMBER 
52
		query = GetQuery("ProductDetailsAtBaseEnv.sql")
53
	End If
54
 
55
 
56
	Set rsQry = OraDatabase.DbCreateDynaset( query, ORADYN_DEFAULT )
57
 
58
	If ((NOT rsQry.BOF) AND (NOT rsQry.EOF)) Then
59
		outobjDetails.Item ("seq_num")   = rsQry("seq_num")
60
		outobjDetails.Item ("prod_id") = rsQry("prod_id")
61
		outobjDetails.Item ("pkg_id") = rsQry("pkg_id")
62
		outobjDetails.Item ("pkg_name") = rsQry("pkg_name")
15 rsolanki 63
		outobjDetails.Item ("is_node_spec") = rsQry("is_node_spec")
64
		outobjDetails.Item ("sunos_electronic_name") = rsQry("sunos_electronic_name")
65
		outobjDetails.Item ("win_electronic_name") = rsQry("win_electronic_name")
13 rsolanki 66
		outobjDetails.Item ("pkg_version") = rsQry("pkg_version")
67
		outobjDetails.Item ("product_comments") = rsQry("product_comments")
68
 
69
		If nBaseEnvId = "" Then
70
			outobjDetails.Item ("os_id") = rsQry("os_id")
71
		Else
72
			outobjDetails.Item ("base_env_id") = rsQry("base_env_id")
73
		End If
74
 
75
	Else
76
		Err.Raise 8, "Sub GetFormDetails", "Empty record set returned. nProd_id="& nProd_id &", nOs_id="& nOs_id
77
 
78
	End If
79
 
80
	rsQry.Close
81
	Set rsQry = Nothing
82
 
83
 
84
 
85
	'/* Get Project Details */
86
	query = _
87
	" SELECT proj.RM_PROJECTS_FK"&_
88
	"  FROM BOMS bo,"&_
89
	"  	   BRANCHES br,"&_
90
	"	   DM_PROJECTS proj"&_
91
	" WHERE br.PROJ_ID = proj.PROJ_ID"&_
92
	"   AND bo.BRANCH_ID = br.BRANCH_ID"&_
93
	"   AND bo.BOM_ID = :BOM_ID"
94
 
95
	Set rsQry = OraDatabase.DbCreateDynaset( query , ORADYN_DEFAULT )
96
 
97
	If ((NOT rsQry.BOF) AND (NOT rsQry.EOF)) Then
98
		outobjDetails.Item ("rm_projects_fk")   = rsQry("rm_projects_fk")
99
 
100
	Else
101
		Err.Raise 8, "Sub GetFormDetails", "Empty record set returned. nBom_id="& nBom_id 
102
 
103
	End If
104
 
105
	OraDatabase.Parameters.Remove "PROD_ID"
106
	OraDatabase.Parameters.Remove "OS_ID"
107
	OraDatabase.Parameters.Remove "BASE_ENV_ID"
108
	OraDatabase.Parameters.Remove "BOM_ID"
109
 
110
	rsQry.Close
111
	Set rsQry = Nothing
112
End Sub
113
'--------------------------------------------------------------------------------------------------------------------------
114
Sub GetProductVersions ( aRs, outMore )
115
	Dim rsQry, OraParameter, CurrentRecordCount, TotalRecordCount
116
 
117
	OraDatabase.Parameters.Add "PKG_ID",  	objFormCollector.Item("pkg_id"), ORAPARM_INPUT, ORATYPE_NUMBER 
118
	OraDatabase.Parameters.Add "PROJ_ID",   objFormCollector.Item("rm_projects_fk"),	ORAPARM_INPUT, ORATYPE_NUMBER 
119
	OraDatabase.Parameters.Add "FILTER_ON",   1,	ORAPARM_INPUT, ORATYPE_NUMBER 
120
 
121
	'-- Get all Ora Parameters
122
	Set OraParameter = OraDatabase.Parameters
123
 
124
 
125
	'-- Clear Filter if user require
126
	If parFilter_on <> "" Then OraParameter("FILTER_ON").Value = 0
127
 
128
 
129
	'-- Get Record Set
130
	Set rsQry = OraDatabase.DbCreateDynaset( GetQuery ("ProductVersionsList.sql"), ORADYN_DEFAULT )
131
	CurrentRecordCount = rsQry.RecordCount
132
	If (NOT rsQry.BOF) AND (NOT rsQry.EOF) Then
133
		aRs = rsQry.GetRows()
134
 
135
	Else
136
		aRs = NULL
137
 
138
	End If
139
 
140
	rsQry.Close
141
	Set rsQry = Nothing
142
 
143
 
144
	'-- Get Total Record Count
145
	OraParameter("FILTER_ON").Value = 0
146
	Set rsQry = OraDatabase.DbCreateDynaset( GetQuery ("ProductVersionsList.sql"), ORADYN_DEFAULT )
147
	TotalRecordCount = rsQry.RecordCount
148
 
149
	rsQry.Close
150
	Set rsQry = Nothing
151
 
152
 
153
	'-- Create More... linke if needed
154
	outMore = NULL
155
	If CurrentRecordCount < TotalRecordCount Then
156
		outMore = "javascript:go_submit( document.FormName, ""filter_off"" );ShowProgress();"
157
	End If
158
 
159
 
160
	Set OraParameter = Nothing
161
 
162
	OraDatabase.Parameters.Remove "PKG_ID"
163
	OraDatabase.Parameters.Remove "PROJ_ID"
164
	OraDatabase.Parameters.Remove "FILTER_ON"
165
End Sub
166
'--------------------------------------------------------------------------------------------------------------------------
167
Function GetSeqNumList ( nSeq_num )
168
	Dim rsQry, query
169
 
170
	OraDatabase.Parameters.Add "SEQ_NUM",   nSeq_num,	ORAPARM_INPUT, ORATYPE_NUMBER 
171
 
172
 
173
	If parBase_env_id = "" Then
174
		OraDatabase.Parameters.Add "OS_ID",  parOs_id,		ORAPARM_INPUT, ORATYPE_NUMBER 
175
		query = GetQuery ("InstallOrderComboAtOs.sql")
176
	Else
177
		OraDatabase.Parameters.Add "BASE_ENV_ID",  parBase_env_id,		ORAPARM_INPUT, ORATYPE_NUMBER 
178
		query = GetQuery ("InstallOrderComboAtBaseEnv.sql")
179
	End If
180
 
181
 
182
	Set rsQry = OraDatabase.DbCreateDynaset( query, ORADYN_DEFAULT )
183
	If (NOT rsQry.BOF) AND (NOT rsQry.EOF) Then
184
		GetSeqNumList = rsQry.GetRows()
185
 
186
	Else
187
		GetSeqNumList = NULL
188
 
189
	End If
190
 
191
	rsQry.Close
192
	Set rsQry = Nothing
193
 
194
	OraDatabase.Parameters.Remove "OS_ID"
195
	OraDatabase.Parameters.Remove "BASE_ENV_ID"
196
	OraDatabase.Parameters.Remove "SEQ_NUM"
197
End Function
198
'--------------------------------------------------------------------------------------------------------------------------
199
Sub UpdateProdAtOs ()
200
	On Error Resume Next
201
 
202
	OraDatabase.Parameters.Add "OLD_PROD_ID", 	Request("prod_id_list"), 	ORAPARM_INPUT, ORATYPE_NUMBER 
203
	OraDatabase.Parameters.Add "NEW_PROD_VERSION", 	Request("new_prod_version"), 	ORAPARM_INPUT, ORATYPE_VARCHAR2
204
	OraDatabase.Parameters.Add "OS_ID", 		Request("os_id"), 			ORAPARM_INPUT, ORATYPE_NUMBER 
205
	OraDatabase.Parameters.Add "SEQ_NUM", 		Request("seq_num"), 		ORAPARM_INPUT, ORATYPE_NUMBER 
206
	OraDatabase.Parameters.Add "PROD_COMMENTS", Request("product_comments"),ORAPARM_INPUT, ORATYPE_VARCHAR2
15 rsolanki 207
	OraDatabase.Parameters.Add "SUNOS_ELECTRONIC_NAME", Request("sunos_electronic_name"),ORAPARM_INPUT, ORATYPE_VARCHAR2	
208
	OraDatabase.Parameters.Add "WIN_ELECTRONIC_NAME", Request("win_electronic_name"),ORAPARM_INPUT, ORATYPE_VARCHAR2	
209
	OraDatabase.Parameters.Add "IS_NODE_SPEC", Request("is_node_spec"),ORAPARM_INPUT, ORATYPE_VARCHAR2		
13 rsolanki 210
 
211
 
212
	objEH.TryORA ( OraSession )
213
 
214
	OraDatabase.ExecuteSQL _
15 rsolanki 215
	"BEGIN pk_Product.Update_Product ( :OLD_PROD_ID, :NEW_PROD_VERSION, :OS_ID, :SEQ_NUM, :PROD_COMMENTS, :SUNOS_ELECTRONIC_NAME, :WIN_ELECTRONIC_NAME, :IS_NODE_SPEC ); END;"	
13 rsolanki 216
 
217
	objEH.CatchORA ( OraSession )
218
 
219
 
220
	OraDatabase.Parameters.Remove "OLD_PROD_ID"
221
	OraDatabase.Parameters.Remove "NEW_PROD_VERSION"
222
	OraDatabase.Parameters.Remove "OS_ID"
223
	OraDatabase.Parameters.Remove "SEQ_NUM"
224
	OraDatabase.Parameters.Remove "PROD_COMMENTS"
15 rsolanki 225
	OraDatabase.Parameters.Remove "SUNOS_ELECTRONIC_NAME"	
226
	OraDatabase.Parameters.Remove "WIN_ELECTRONIC_NAME"
227
	OraDatabase.Parameters.Remove "IS_NODE_SPEC"	
13 rsolanki 228
 
229
End Sub
230
'--------------------------------------------------------------------------------------------------------------------------
231
Sub UpdateProdAtBaseEnv ()
232
	On Error Resume Next
233
 
234
	OraDatabase.Parameters.Add "OLD_PROD_ID", 	Request("prod_id_list"), 	ORAPARM_INPUT, ORATYPE_NUMBER 
235
	OraDatabase.Parameters.Add "NEW_PROD_VERSION", 	Request("new_prod_version"), 	ORAPARM_INPUT, ORATYPE_VARCHAR2
236
	OraDatabase.Parameters.Add "BASE_ENV_ID", 		Request("base_env_id"), 			ORAPARM_INPUT, ORATYPE_NUMBER 
237
	OraDatabase.Parameters.Add "SEQ_NUM", 		Request("seq_num"), 		ORAPARM_INPUT, ORATYPE_NUMBER 
238
	OraDatabase.Parameters.Add "PROD_COMMENTS", Request("product_comments"),ORAPARM_INPUT, ORATYPE_VARCHAR2
15 rsolanki 239
	OraDatabase.Parameters.Add "SUNOS_ELECTRONIC_NAME", Request("sunos_electronic_name"),ORAPARM_INPUT, ORATYPE_VARCHAR2	
240
	OraDatabase.Parameters.Add "WIN_ELECTRONIC_NAME", Request("win_electronic_name"),ORAPARM_INPUT, ORATYPE_VARCHAR2	
13 rsolanki 241
 
242
 
243
	objEH.TryORA ( OraSession )
244
 
245
	OraDatabase.ExecuteSQL _
15 rsolanki 246
	"BEGIN pk_Base_Env.Update_Product ( :OLD_PROD_ID, :NEW_PROD_VERSION, :BASE_ENV_ID, :SEQ_NUM, :PROD_COMMENTS, :SUNOS_ELECTRONIC_NAME, :WIN_ELECTRONIC_NAME ); END;"	
13 rsolanki 247
 
248
	objEH.CatchORA ( OraSession )
249
 
250
 
251
	OraDatabase.Parameters.Remove "OLD_PROD_ID"
252
	OraDatabase.Parameters.Remove "NEW_PROD_VERSION"
253
	OraDatabase.Parameters.Remove "BASE_ENV_ID"
254
	OraDatabase.Parameters.Remove "SEQ_NUM"
255
	OraDatabase.Parameters.Remove "PROD_COMMENTS"
15 rsolanki 256
	OraDatabase.Parameters.Remove "SUNOS_ELECTRONIC_NAME"
257
	OraDatabase.Parameters.Remove "WIN_ELECTRONIC_NAME"		
13 rsolanki 258
 
259
End Sub
260
'--------------------------------------------------------------------------------------------------------------------------
261
%>
262
<%
263
'------------ RUN BEFORE PAGE RENDER ----------
264
objPMod.PersistInQryString ( Array("base_env_id") )
265
 
266
' --- Get Form details from DB ---
267
Call GetFormDetails ( parProd_id, parOs_id, parBase_env_id, parBom_id, objFormCollector )
268
 
269
' --- Load Validation Rules ---
270
Call objForm.LoadValidationRules ( Array("product_comments"), OraDatabase )		' Load Validation Rules
271
 
272
' --- Enter Form Validation Rule Changes here... ----
273
'----------------------------------------------------
274
 
275
If Request("action") = "true" Then
276
	If objForm.IsValidOnPostBack Then
277
		' --- Form is Valid ---
278
		If parBase_env_id = "" Then
279
			Call UpdateProdAtOs()
280
		Else
281
			Call UpdateProdAtBaseEnv()
282
		End If
283
 
284
 
285
		If objEH.Finally Then
286
			Call OpenInParentWindow ( Request("rfile") &"?UPDATED=OK"& objPMod.ComposeURLWithout("rfile") )
287
			Call CloseWindow()
288
		End If
289
 
290
	End If
291
ElseIf Request("action") = "filter_off" Then
292
	parFilter_on = 0
293
End If
294
'----------------------------------------------
295
%>
296
<html>
297
<head>
298
<title>Deployment Manager</title>
299
<meta HTTP-EQUIV="Pragma" CONTENT="no-cache">
300
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
301
<link href="scripts/deployment_manager.css" rel="stylesheet" type="text/css">
302
<script language="JavaScript" src="scripts/common.js"></script>
303
</head>
304
 
305
<body background="images/bg_bage_0.gif" leftmargin="0" topmargin="0" onLoad="self.focus();">
306
<table width="100%"  border="0" cellspacing="0" cellpadding="10">
307
  <tr>
308
    <td bgcolor="#FFFFFF" class="body_txt"><span class="body_h1"><img src="icons/i_linkarrow_black.gif" width="11" height="11" align="absmiddle">&nbsp;Edit Product</span> <br>
309
    Update product details and click Submit. 
310
    </td>
311
  </tr>
312
  <%
313
  '-- FROM START ---------------------------------------------------------------------------------------------------------
314
  objFormComponent.FormName = "FormName"
315
  objFormComponent.Action = SCRIPT_NAME
316
  objFormComponent.OnSubmit = "ShowProgress();"
317
  Call objFormComponent.FormStart()
318
  %>   
319
  <tr>
320
    <td background="images/bg_login.gif"><table width="100%"  border="0" cellspacing="0" cellpadding="0">
321
      <tr>
322
        <td><%=ProgressBar%></td>
323
        <td align="right"><input name="btn" type="submit" class="form_btn" value="Submit">
324
          <input name="btn" type="reset" class="form_btn" value="Cancel" onClick="self.close();"></td>
325
      </tr>
326
    </table></td>
327
  </tr>
328
  <tr>
329
    <td><table width="100%"  border="0" cellspacing="2" cellpadding="0">
330
	  <!-- MESSAGE +++++++++++++++++++++++++++++++++++++++++++++++++++ -->	
331
	  <%If NOT objEH.Finally Then%>
332
      <tr>
333
        <td class="form_iname">&nbsp;</td>
334
        <td>
335
		 <%objEH.DisplayMessage()%>
336
		</td>
337
        <td class="val_err"></td>
338
      </tr>
339
	  <%End If%>
340
	  <!-- +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ -->
341
      <tr>
342
        <td nowrap class="form_iname" valign="top">Install Order</td>
343
        <td valign="top"><%=objFormComponent.Combo ( "seq_num", GetSeqNumList( objForm.GetValue ( "seq_num", objFormCollector.Item("seq_num"))), FALSE, "class='form_ivalue'" )%></td>
344
		<td valign="top"></td>
345
      </tr>
346
	  <tr>
347
        <td nowrap class="form_iname" valign="top">Product Name</td>
348
        <td valign="top"><%=objFormComponent.TextBox ( "pkg_name", objFormCollector.Item("pkg_name"), "size='70' class='form_ivalue' disabled" )%></td>
349
		<td valign="top"></td>
350
      </tr>
15 rsolanki 351
	  <tr>
352
        <td nowrap class="form_iname" valign="top">SunOS Electronic Name</td>
353
        <td valign="top"><%=objFormComponent.TextBox ( "sunos_electronic_name", objFormCollector.Item("sunos_electronic_name"), "size='70' class='form_ivalue'" )%></td>
354
		<td valign="top"></td>
355
      </tr>
356
	  <tr>
357
        <td nowrap class="form_iname" valign="top">Windows Electronic Name</td>
358
        <td valign="top"><%=objFormComponent.TextBox ( "win_electronic_name", objFormCollector.Item("win_electronic_name"), "size='70' class='form_ivalue'" )%></td>
359
		<td valign="top"></td>
360
      </tr>	  
361
	  <tr>
362
        <td nowrap class="form_iname" valign="top">Include In Node Spec File</td>
363
		<%If IsNull(objFormCollector.Item("is_node_spec")) Then%>
364
        <td valign="top"><input type="checkbox" name="is_node_spec"></td>
365
		<%Else%>
366
        <td valign="top"><input type="checkbox" name="is_node_spec" checked></td>
367
		<%End If%>
368
		<td valign="top"></td>
369
      </tr>	  
370
 
13 rsolanki 371
      <tr>
372
        <td nowrap class="form_iname" valign="top">Version</td>
373
        <td valign="top"><%
374
		Call GetProductVersions( aRs, MoreLink )
375
		ForceDropdown = FALSE
376
		If IsNull(MoreLink) AND (parFilter_on <> "") Then ForceDropdown = TRUE
377
 
378
		Response.write objFormComponent.ComboWithTextAndFilter ( "new_prod_version", objForm.GetValue( "new_prod_version", objFormCollector.Item("pkg_version")), aRs, "size='30' class='form_ivalue'", MoreLink, ForceDropdown )
15 rsolanki 379
 
13 rsolanki 380
		%></td>
381
		<td valign="top"></td>
382
      </tr>
383
      <tr>
384
        <td valign="top" nowrap class="form_iname">Comments</td>
385
        <td valign="top"><%=objFormComponent.TextArea ("product_comments", objForm.GetValue ( "product_comments", objFormCollector.Item("product_comments")), 22, 80, "class='form_ivalue'" )%></td>
386
		<td valign="top">
387
		<%=objForm.Validate ("product_comments")%>
388
		</td>
389
      </tr>
390
      <tr>
391
        <td width="10%" class="form_iname">&nbsp;</td>
392
        <td width="1%">&nbsp;</td>
393
		<td width="90%" class="val_err"></td>
394
      </tr>
395
    </table></td>
396
  </tr>
397
  <%=objPMod.ComposeHiddenTags()%>
398
  <input type="hidden" name="prod_id_list" value="<%=parProd_id%>">
399
  <input type="hidden" name="action" value="true">
400
  <%
401
  Call objFormComponent.FormEnd()
402
  '-- FROM END ----------------------------------------------------------------------------------------------------------------
403
  %>
404
</table>
405
</body>
406
</html>
407
<%
408
'------------ RUN AFTER PAGE RENDER -----------
409
Set objFormCollector = Nothing
410
'----------------------------------------------
411
%><!--#include file="common/globals_destructor.asp"-->