Solved

How do I invoke a function using a button in coldfusion?

Posted on 2009-07-12
6
318 Views
Last Modified: 2013-12-24
I have the following function which I need to invoke using a "download" button. The download button is located just below a cfgrid. The function will output an Excel file when supplied with data.

1. How do I invoke the function when a user clicks the download button?
2. How do I supply the full dataset and not just what is available in the current page of the cfgrid?
<cffunction name="generateExcel" output="Yes" access="remote">

		<cfargument name="theQuery" type="query">

		<cfargument name="columnList" type="string" default="">

		<cfargument name="mode" type="string" default="display">

		<cfargument name="theFilename" type="string" default="clients_admin.xls">

 

		<cfset var TAB = chr(9)>

		<cfset var i = 1>

		<cfset var headerArray = ArrayNew(1)>

 

      <cfquery name="getClientsAdmin" datasource="#THIS.dsn#">

	  		SELECT *

			FROM    Clients

        </cfquery>

 

 

        <cfquery name="getClients" datasource="#THIS.dsn#">

			SELECT *

			FROM Clients WHERE owner = <cfqueryparam value="#SESSION.MM_Username#" cfsqltype="cf_sql_clob" maxlength="10"> 

        </cfquery>

		

		

		<cfsetting enablecfoutputonly="Yes">

		

		<!--- Dump all content before this fn call --->

		<cfcontent reset="yes">

		

		<!--- Use the full column list, if none is provided --->

		<cfif Len( ARGUMENTS.columnList ) IS 0>

			<cfset ARGUMENTS.columnList = ARGUMENTS.theQuery.columnList>

		</cfif>

		

		<cfswitch expression="#ARGUMENTS.mode#">

			<cfcase value="display">

				<cfif NOT isdefined("REQUEST.headerDoneFlag")>

					<cfset REQUEST.headerDoneFlag = true>

					<CFHEADER NAME="Content-Disposition" VALUE="inline; filename=""#ARGUMENTS.theFilename#""">

					<CFCONTENT TYPE="application/msexcel">

				</cfif>

			</cfcase>

			<cfcase value="save">

				<cfset guid = CreateUUID()>

				<cfset filename = GetDirectoryFromPath(GetCurrentTemplatePath()) & "temp_" & guid & ".xls">

				<cfset REQUEST.headerDoneFlag = true>

				<cfheader name="Content-type" value="application/octet-stream"> 

				<cfheader name="Content-Disposition" value="attachment;filename=""#ARGUMENTS.theFilename#""">

				<cfsavecontent variable="output">

					<cfset generateExcel( ARGUMENTS.theQuery, ARGUMENTS.columnList, "save" )>

				</cfsavecontent><cfoutput>#output#</cfoutput><cfabort>

				<cffile action="WRITE" file="#filename#" output="#output#">

				<cfcontent type="application/msexcel" file="#filename#" deleteFile="Yes">

			</cfcase>

			<cfcase value="debug">

				<cfoutput><pre></cfoutput>

			</cfcase>

			<cfdefaultcase>

				<cfthrow message="Mode must be either 'display', 'save', or 'debug'.">

			</cfdefaultcase>

		</cfswitch>

		

		<!--- Write the header row --->

		<cfloop index="i" from="1" to="#ListLen( columnList )#">

			<cfset item = Trim( ListGetAt( columnList, i ) )>

			<cfset headerArray[ ArrayLen( headerArray )+1 ] = item>

			<cfoutput>#item##TAB#</cfoutput>

		</cfloop>

		<cfoutput>#chr(13)#</cfoutput>

		

		<!--- Write all the sub rows --->

		<cfloop query="ARGUMENTS.theQuery">

		

			<cfloop index="i" from="1" to="#ArrayLen( headerArray )#">

				<cfset dbVal = Trim( ARGUMENTS.theQuery[headerArray[i]][CurrentRow] )>

				<cfif IsDate( dbVal )>

					<cfset dbVal = DateFormat( dbVal, "mm/dd/yyyy" )>

				<cfelse>

					<cfset dbVal = replaceList(dbVal,"#TAB#,#chr(10)#,#chr(13)#"," , , ")>

				</cfif>

				<cfoutput>#dbVal##TAB#</cfoutput>

			</cfloop>

			

			<cfoutput>#chr(13)#</cfoutput>

		

		</cfloop>

		

		<cfif ARGUMENTS.mode EQ "debug">

			<cfoutput></pre></cfoutput>

		</cfif>

		

		<cfsetting enablecfoutputonly="No">

	</cffunction>

Open in new window

0
Comment
Question by:futr_vision
  • 4
  • 2
6 Comments
 
LVL 13

Expert Comment

by:srikanthmadishetti
Comment Utility
use cfjaxproxy onclick event.
0
 

Author Comment

by:futr_vision
Comment Utility
Thanks. But my problem is that i am extremely new to ColdFusion and cfjaxproxy is greek to me.  I'll need a little more detail on how to accomplish this.
0
 
LVL 13

Expert Comment

by:srikanthmadishetti
Comment Utility
0
Better Security Awareness With Threat Intelligence

See how one of the leading financial services organizations uses Recorded Future as part of a holistic threat intelligence program to promote security awareness and proactively and efficiently identify threats.

 

Author Comment

by:futr_vision
Comment Utility
Hmmm. Doesn't look like what I am trying to do. All I really need is the code and the place to put it to hook this function up.
0
 

Author Comment

by:futr_vision
Comment Utility
Looking at this a little further i don't think cfajaxproxy will work for me. My download link/button is outside of the grid and needs to return the entire recordset. To me this simple means creating a way of calling the function and passing query data to it for it to do its thing. I just don't know how to do it.
0
 

Accepted Solution

by:
futr_vision earned 0 total points
Comment Utility
Here is where I am at. I have some code that invokes the function and a cfc with the function. The invoke is pasted below and the function is in my original message except it is surrounded by the cfcomponent tag.
<cfquery name="customerDownload" datasource="THIS.dsn">

	Select *

	From Customers

</cfquery>
 

<cfinvoke component="CFC.ExcelDownload" method="generateExcel">

	<cfinvokeargument name="theQuery" value="#customerDownload#">

</cfinvoke>

Open in new window

0

Featured Post

How your wiki can always stay up-to-date

Quip doubles as a “living” wiki and a project management tool that evolves with your organization. As you finish projects in Quip, the work remains, easily accessible to all team members, new and old.
- Increase transparency
- Onboard new hires faster
- Access from mobile/offline

Join & Write a Comment

This article provides a case study on how our local youth baseball league deployed a new website, including the platform selection, implementation and benefits to the league.
Periodically we have to update or add SSL certificates for customers. Depending upon your hosting plan you may be responsible for the installation and/or key generation. In the wake of Heartbleed many sites were forced to re-key. We will concen…
The purpose of this video is to demonstrate how to automatically show related posts at the bottom of a blog post in WordPress. This will be demonstrated using a Windows 8 PC. Plugin “Yet Another Related Posts Plugin” will be used. Go to your…
The purpose of this video is to demonstrate how to reset a WordPress password if you are locked out and cannot reset the password. A typical use would be if you cannot access the email to which WordPress would send the password recovery email to…

771 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

16 Experts available now in Live!

Get 1:1 Help Now