Purpose
The purpose of this article is to expand upon the previous, part one, walkthrough by incorporating some of the more advanced features of the Information Bridge Framework (IBF). In part one, I provided a brief introduction to IBF and why it was developed into a product. I also created a sample walkthrough that demonstrated the basic features of IBF 1.5. Part one should have provided you with a good starting point to create a more robust IBF application.
Part two will be build on this by enabling the user to perform specific actions from a custom Smart Tag, like: Get All Customers, or See Customer Details. We will also allow the user to search for customers from the IBF search task pane. Finally, we will create a standard Word template and attach an IBF schema that will allow the user to view, update and add customer information directly from the IBF task pane. The tasks involved are listed below:
- IBF search panes.
- Custom smart tag actions and menu items.
- Microsoft Word attached schemas.
- Working with office from the IBF task pane.
- Client deployment.
Recap
To recap, in Part one, we created a simple IBF solution that enabled users to retrieve details on Northwind customers from within Microsoft Word. From a Word document, we can type in any Northwind customer ID and from a Smart tag get their corresponding details. The tasks involved to accomplish this are listed below:
- Create a .NET IBF solution.
- Create an IBF compliant Web services.
- Using the 1.5 Metadata guidance task pane to do the following:
- Import your IBF compliant web services.
- Creating your first entities and actions.
- Creating a .NET Windows Form region.
- Testing your IBF solution.
- Creating a basic Smart tag recognizer.
- Testing your application in Word.
Assumption
Before I continue creating the advanced Information Bridge solution, there are several prerequisites that I assume you are already familiar with and have previously configured in your development environment:
- You are familiar with the Microsoft Visual Studio .NET 2003 development platform.
- You have access to the SQL Server Northwind database and are familiar with the database structures.
- You have the Information Bridge 1.5 server installed and configured on your server, as well as the IBF 1.5 SDK.
- You have the full installation of Microsoft Office 2003.
- You understand the following concepts: Web Services, .NET C#, .NET Windows control development, Microsoft Office 2003 Word, Excel and Outlook and Office Smart tags.
- You have worked with XML and XSLT.
- You know how to sign an assembly with a strong name.
- You have the Smart tag SDK installed on your system.
- You have downloaded the images and listings at the top of this article.
- You have already read Part 1 of the sample walkthrough.
- You have already installed Part 1 of the sample walkthrough and it is working on your system.
Walkthrough
This walkthrough will provide you with instructions for creating a complete IBF solution using the newly released 1.5 framework. This is part two of the sample, so I will be building off the part one sample solution.
Like part one, I am going to revolve the application around the standard Northwind database. I will be using this model, because I figure that most of you are familiar with the database schema and if you aren't, there are many documents on it that you can get from Microsoft.
IBF Search Panes
The IBF Search region is a specific window on the IBF task pane that allows a user to search and retrieve results from any Line of Business (LOB) application. This pane is pre designed for search capabilities. It will allow you to select search criteria, enter in search parameters and display the results. To view this region, navigate to the appropriate tab on the IBF Task Pane. (Refer to Figure 1.)
For this walkthrough, I want the user to be able to navigate to the IBF search pane, enter a Customer ID, and then retrieve the details. In Part one, we created the actions, operations and ports to accomplish this. We just need to create a specific search port and transformation so that IBF knows that this is a function that should be performed on the search pane.
To create the appropriate metadata, I will be using the IBF metadata guidance window to initiate the wizard that will guide us through the steps. The wizard steps are listed below:
- Open up the IBFDemo sample solution that was created in Part 1.
- Click on the "Search Definition Wizard" hyperlink on the metadata guidance window.
- The second screen of the wizard allows us to select or create a new metadata solution. Since we have already created the NorthwindIBFSolution, we will use that solution to house our search scope. (Refer to Figure 2.)
- On the third screen we will select the
View_Locator
that we want to use for this search. Since the requirement is to enter a CustomerID
, and then retrieve the results, we will use the Customer_View
we have already created. Use the following parameters to populate the wizard:
- Metadata Scope � NorthwindIBF
- Entity �
Customers
- View �
Customre_View
- View Locator �
Xsd.CustomerID
- Select the action option - enter context type
- The fourth wizard screen provides us with the input template for the action. This should be automatically populated for you, because we have already defined this in the
View_Locator
as the CustomerID
schema. (Refer to Figure 3.)
- For the fifth screen, we will be providing where the search results will be displayed and from what category. The category is used, so that if multiple search scopes have been defined, a user can use the same IBF task pane to search for multiple Line of Business entities. The location of the search results can be in 1 of 3 locations, the
SearchRegion
, SearchPage
or the ReferencePage
. For this walkthrough enter "Northwind Customers" for the search category caption, and select SearchPage
as the results location. (Refer to Figure 4.)
- The final wizard screen, that we have to populate, is to enter the search criterion for this query. This dialog lets you add multiple search criteria to get the exact results you want. (Refer to Figure 8.) To do this, we have to provide IBF with several pieces of information:
- The label and description of the search criterion.
- The actual XPath that will do the selecting of the data.
- The type of selection, either a list or a simple text box.
- If this field is required or not.
Click on the "Add Criterion" button. This command lets us specify the above pieces of information for our query. From there enter the following information: (Refer to Figure 7.)
- Caption name - Customer ID
- Description � Search and retrieve details on a Northwind customer.
- XPath � Click on the ellipse next to the data entry field. This will bring up the XPath creator. This dialog will automatically be populated with the appropriate input parameters for our query. Click on the CustomerID node and click OK. (Refer to Figure 6)
- Control type � text
- Required � Yes (Check this option.)
- Click through the last series of wizard screens and close the wizard.
This completes the creation of our new search metadata. You will notice that two metadata elements have been added to the Information Bridge Scope, a Port and a Transformation. To test out the search, publish the metadata to the IBF Service, then create a new Word document and open up the Information Bridge task pane, by selecting Tools --> Information Bridge. Once the Information Bridge task pane appears, you will notice that a new search scope has been defined and you can now type in a Customer ID. Once you hit the Submit button, the details for that Customer will be displayed. That's all there is to it. By simply entering the information in the wizard, the wizard created the appropriate metadata and the search is now active. (Refer to Figure 1.)
Note: It is important to note that the search Ports and Transformations will be located in the Information Bridge metadata scope. This is the common IBF scope that is shared by all applications.
Custom smart tag actions and menu items
The next area that I want to explore is the ability to create a custom smart tag menu item. As you saw in Part 1, when we created the recognizer for CustomerIDs, a default smart tag menu appears. This menu contains the standard IBF menu item, "Show Details". Typically, you would want a more descriptive name for this menu, such as "Show Northwind Customer Details". To accomplish this is fairly straight forward and IBF helps you out by providing you with an interface, and metadata to do this.
Below, I will walk you through the steps for creating this custom menu to display the Customer details.
- Within the sample walkthrough solution, add a new class to the IBFNorthwind_ST project. Rename the new class to,
IBFNorthwindSelCustomerAction
.
- Import the IBF and smart tag namespaces. (Refer to Listing 1.) Inherit the class from the
IActionHandler
interface. This interface implements the following methods that must be used by the action handler:
GetMenuItems
� Gets the menu items to display when an appropriate term is recognized.
Initialize
� This method is used to set up the action handle.
InvokeMenuItem
� This method executes the specific action that the user selected from the smart tag menu.
- The next step will be creating the actual custom menu item. To accomplish this, we need to create a new class that inherits from the IBF
IActionHandlerMenuItem
interface. This class will house the ID and caption of the menu item. For this example, add a Sealed class, within the IBFNorthwindSelCustomerAction
class and inherit it from the IActionHandlerMenuItem
. Once you do this, you must implement the caption and ID properties as well as the constructor that will initiate the two properties. (Refer to Listing 2.)
- Now we will create the
GetMenuItems
method. This method will return the complete set of menu items that you want the smart tag to display when it recognizes some text. Within this method we will create an array of menu items and then add the menu item sealed class, we created above. (Refer to Listing 3.)
- Now we just have to write the code to execute the appropriate action, when a user clicks on the smart tag menu. To do this, we will create the code to determine what menu item was selected. This code will be added to the
InvokeMenuItem
method. (Refer to Listing 4.) Next we will create a custom method to call our specific ShowCustomerDetails
, which will execute the specific IBF context to initiate the Customer_View
. (Refer to Listing 5.)
- The final step is to add the IBF metadata to display the custom menu items. To do this follow the steps below:
- Open up the metadata explorer, if it is not already visible.
- Within the "InformationBridge" metadata scope, expand the ports node. Locate the
GenericActionHandler
port, right click on it and edit it. Modify the XML data template to reflect the custom smart tag namespace and class name. For this example, use the following XML. The modified elements are highlighted.
<msibf:GenericActionHandler
TypeName="IBFNorthwind_ST.IBFNorthwindSelCustomerAction"
xmlns:msibf=
"http://schemas.microsoft.com/InformationBridge/2004">
<YourInitializationData>
xmlns=
"http://schemas.microsoft.com/InformationBridge/2004/Metadata"
</YourInitializationData>
</msibf:GenericActionHandler>
- Finally, we have to create the custom action to initiate the custom smart tag menu. To do this, navigate to the following node in the "InformationBridge" metadata scope: Entities --> GenericSmartTags --> GenericActionHandlers --> Actions.
- Double click on the "[Add Action.]" node. On this dialog, we will create a new action. Set the following properties and hit OK.
- Name �
NorthwindCustomerDetailsAction
- Type �
EnterContext
- Parameters schema �
MSIBF.GenericActionHandler
- Sequential execution �
UnChecked
Note: Sequential execution is used if you want to chain actions together. If you have more then one action that you want to run together, in a sequence, then you would check this option. Since this is the only action we want to execute, we do not require a sequence. (Refer to Figure 9)
- On the newly added action, double click on the action to bring up the action designer. All we need to do here is drag and drop the
LoadActionHandler
operation from the operations node to the action designer and set the Transformation instance to GenericActionHandler
. (Refer to Figure 10.)
- Now we are ready to test the new smart tag menu Item. Save the solution and publish your metadata. Close all IBF compatible applications and open up a new Microsoft Word document. Type "LETSS" in the document. The recognizer should have picked up the text and underlined it in purple dots. Hover over the text and click on the smart tag. You should now see the custom menu item "Show Northwind Customer Details". If you click on this menu item, it will bring up the IBF task pane and display the appropriate customer details. (Refer to Figure 11.)
That completes the walkthrough of creating a custom smart tag menu item in IBF. In summary, we created a new class that inherited from the IActionHandler
interface. Then we added a sub class that inherited from the IActionHandlerMenuItem
interface. We set the properties and methods accordingly to display the correct menu item and context. We added the IBF metadata and that's it. Next I will walk you through the creation of an IBF attached schema document.
IBF attached schemas � default HTML region
Attached schemas are one of the most powerful features of IBF. This is possible because in Office 2003 you have the ability to attach a schema (XSD) to a document. Once a schema is attached to a document, users can enter specific business information, within predefined XML elements, making it easier for data collection, formatting and validation. For example, if your schema expects two child nodes, and only one is entered, Word will warn you. These are business rules that will work in your document without coding any VBA, or custom COM Add-In.
An IBF attached schema is no different than attaching a standard XSD to your Word document. The only requirements are that you specify specific IBF metadata elements into the schema, such as the metadata scope. An example of an IBF attached schema is listed below. (This is the schema we will use to attach to Word latter in the walkthrough � Refer to Listing 5.)
="1.0"
<xs:schema targetNamespace="NorthwindIBF"
xmlns:xs="http://www.w3.org/2001/XMLSchema"
xmlns:att="NorthwindIBF"
elementFormDefault="qualified" id="NorthwindData">
<xs:element name="NorthwindsCustomersDocument">
<xs:complexType mixed="true">
<xs:all>
<xs:element name="Customers" type="att:Customers"/>
</xs:all>
</xs:complexType>
</xs:element>
<xs:complexType name="Customers">
<xs:attribute name="CustomerID" type="xs:string"/>
</xs:complexType>
</xs:schema>
As you can see, we specified the targetNamespace
as the metadata scope that we want this IBF schema to reference. When you attach this schema to a Word document, which I will detail below, IBF will initiate the default action in this metadata scope. For example, based on the above XSD, in the NorthwindIBF metadata scope, the default Entity is Customers
. The default View is Customer_View
. IBF will read this information from the IBF metadata repository and automatically open up the IBF task pane and run the GetCustomerDetails_Action
.
The problem is that this default action expects a parameter, CustomerID
. If I am attaching a specific schema to a document, I might not have this customer information yet, so I don't want the default Customer_View
to be the first action that IBF runs. I really want to create a default view that does not need any parameters, and then nest specific CustomerID
elements under this default.
Since I want to create a new default Entity and view, which will work every time for my attached schema, I will be creating a HTML region that displays a welcome message. To create a HTML region, follow the steps below:
- In Visual Studio, on the metadata guidance window, click on the "Service Metadata Creation Wizard" hyperlink. This is the same wizard we used in part 1 to create the
Customers
Entity. I will not be going into the details of this wizard, if you need them, please refer to Part 1 of this walkthrough. For now, just enter the below parameters to create a simple Welcome
entity.
- Screen 1 � Select the "NorthwindIBF" metadata scope.
- Screen 2 � Create a new entity, called "
Welcome
". The default reference schema will be "(none)". Finally, check the option to make this the default entity.
- Screen 3 � Create a new View, called
Welcome_View
. The default reference schema will be "(none)". Finally, check the option to make this the default view.
- Screen 4 � Finish the wizard, by clicking through the last three screens.
- The next step is to create a custom operation to initiate a HTML region. To do this, follow the steps below:
- Next we will create an operation to display the HTML region. Navigate to the Operations node in the "NorthwindIBF" metadata scope.
- Double click on the [Add Operation�] node. Set the following parameters and leave everything else the default.
- Name �
Northwind.Customer.Welcome
- Entity � (none)
- Operation Type �
MSIBF.UI.ShowRegion
- Input Schema �
MSIBF.Text
- Output Schema � (none)
- Port � (none)
- The next step is the most important step. This involves creating the HTML region's XML. To do this, add the following XML to the "XML Properties" text section. (Refer to Listing 7)
<iwb:Region
Enabled="true"
MetadataScopeName="NorthwindIBF"
EntityName="Welcome"
xmlns:iwb=
"http://schemas.microsoft.com/InformationBridge/2004">
<iwb:RegionProperties
RegionName="NorthwindWelcome"
Caption="Northwind Customer Maintenance"
Description="Northwind Customer Maintenance Application"
ShowAs="ExpandedRegion"
TypeName=
"Microsoft.InformationBridge.Framework.UI.Controls.HtmlRegion">
<iwb:XHTML Height="100">
<body xmlns="http://www.w3.org/1999/xhtml">
<div>
<font color="#00006B" size="3">
<strong>Northwind Inc.</strong>
</font>
</div>
<div>
<strong>
<font size="2">
Customers Maintenance
</font>
</strong>
</div>
<p>
</p>
<div>
<font size="1">This is the
Northwind Customer
Maintenance Application.
</font>
</div>
</body>
</iwb:XHTML>
</iwb:RegionProperties>
</iwb:Region>
The keys to this XML are the Region
entity and the RegionProperties
entity. The Region
attributes must be set to match your metadata scope and entity. The RegionProperties
must set the name, caption and description. Then within the <iwb.XHTML> element you can put any valid HTML for your region. Refer to Figure 12.)
- Close the new Operation window.
- Finally we will create a custom Action to call the HTML Operation. To do this, follow the steps below:
- Navigate to the Actions node in the new
Welcome
Entity. NorthwindIBF --> Welcome --> Welcome_View --> Actions.
- Double click on the [Add Action�] node. Set the following parameters and leave everything else un-checked:
- Name �
ShowWelcomeMsg
- Type �
EnterContext
- Parameters schema � (none)
- Click OK, to finish adding the new Action.
- Now double click the new
ShowWelcomeMsg
action to bring up the action designer.
- Drag and Drop the new "Northwind.Customer.Welcome" Operation onto the design palette.
- Save and publish the metadata.
- Test the new action to see if the appropriate metadata is being displayed.
Note: When you test this action, you do not need to specify any: view locator, input reference or action parameters. The operation that is being called is completely self sufficient.
Now that we have a good default Entity, View and Region, we can test attaching this schema to a Word document and seeing if it works. I will walk you through the steps for attaching an IBF schema to Word below:
- Open up Notepad and paste Listing 5 into the new text file. This is the schema that will initiate an IBF function.
- Save the file on your local disk and name it NorthwindIBF.xsd.
- Open up a new Word document, so that we can attach the new schema.
- In Word click on the "Templates and Add-Ins�" menu, under the "Tools" menu. When the dialog opens click on the "XML Schema" tab. (Refer to Figure 13.) This window lets you manage all of the schemas that you are able to attach to a Word document. We now need to tell Word where the "NorthwindIBF" schema is.
- Click on the "Add Schema" button and browse to where you saved the NorthwindIBF.xsd file.
- Now you will be able to give this schema an alias. I named this schema, "NorthwindIBF".
- Next, select this schema so that it will be attached to this Word document and hit OK.
- Once you click OK, you will see the "XML Structure" task pane appear. This pane lets you select entities, from a schema, and add them to your document. You will notice that the "NorthwindsCustomersDocument" element is available to add to the document. (Refer to Figure 14.)
- You can now select that element, by clicking on it, and it will automatically drop into the Word document. After you add this element to Word, IBF will automatically initialize and display the default Entity and View, which in our case is the HTML region. (Refer to Figure 15.)
Now that our attached schema works and you have seen how IBF can be initialized from Word, you might be asking yourself; what about passing parameters? IBF supports this, by allowing you to specify attributes, within your elements. These attributes will get passed to the IBF operation, as parameters. The next section will show you how to do this. Save and close the Word document, because we will be adding functionality to it in the next section.
IBF attached schemas � Custom attributes
This part of the walkthrough demonstrates how to pass parameters, from an attached schema, to IBF. This is useful if you need to pass parameters to your IBF operations. In this example, I want to have a CustomerID
passed to IBF, from my attached schema, in order to display the appropriate Customer details in the IBF task pane. To accomplish this is not very straightforward. This part took me the longest to figure out. The trick is to understand exactly what is being passed from the attached schema to IBF. Then from there, it is a matter of transforming what is passed into IBF to the properly formatted input the IBF operation expects. You do this transformation using a port that contains the proper XSL.
Note: I found it very handy to have an XSL editor on hand to test out the XSL and make sure that it is correct. I would recommend XML Spy, or Stylus Studio XML professional.
The complete process involves the following six steps:
- Create an Operation to call an existing Action.
- Create a Port to call the XSL to transform the input.
- Create the
Transformation
Entity that uses the Port.
- Create a new View to host a new Action.
- Create the Action that the attached schema will call. This action will call the Operation and Transformation listed in steps 1 and 3.
- Verify the attached schema is correct, create the Word XML and test the solution.
Step 1
Step 1 will involve creating an Operation that simply executes a pre-existing Action. Since we already have an Action that gets the Customer details and displays a Region, all we have to do is create another Operation that calls this. In coding terminology, this is like creating a method and reusing it in other applications or classes. But instead of code, it's metadata. Below are the steps to create this Operation.
- Navigate to the Add Port Metadata element. NorthwindIBF --> Operations --> [Add Operation�].
- Double click on the [Add Operation�] to bring up the Add Operation dialog.
- Set the following parameters: (Refer to Figure 16.)
- Name -
Att.CallShowCustomerDetails_Action
� I am using the prefix Att to denote that this series of entities are related to attached schemas. You can use any prefix you want, if you choose.
- Entity � (None)
- Operation Type�
OperationExecuteAction
. After selecting this type, the appropriate Execute Action properties need to be completed.
- Reference Schema �
Xsd.CustomerID
- Parameter Schema � (None)
- Output Schema � Nothing to do here.
- Metadata Scope � NorthwindIBF
- Entity �
Customers
- View �
Customer_View
- Action �
GetCustomerDetails_Action
- View_Locator �
Xsd.CustomerID
- As you can tell by looking at the parameters in the dialog, this Operation simply points to a specific Action in a metadata scope. By using this type of Operation, you can call any Action, in any other metadata scope, Entity, View, etc.. Click OK to add the new Operation.
Step 2
Step 2, we will create the Port that contains the XSL to transform the incoming XML to the appropriate syntax the Action expects. Below are the steps to create this Port:
- Navigate to the Add Port metadata element. NorthwindIBF --> Ports --> [Add Port�].
- Double click on the [Add Port�] to bring up the Add Port dialog.
- Set the following parameters: (Refer to Figure 17)
- Name -
Att.Xsl.Transform.CustomerID
- Type � Port File XML
- Port File XML Properties � Select the Radio button to save the XML data to the metadata file. This will save the XML directly into the metadata. You could also store the XSL in an external file and then reference it.
- XML � Within the text edit box, copy and paste the following XSL:
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:iwb=
"http://schemas.microsoft.com/InformationBridge/2004"
xmlns:att="NorthwindIBF">
<xsl:template match="/">
<CustomerID xmlns="CustomerID-Data">
<xsl:attribute name="CustomerID">
<xsl:value-of select="/att:Customers/@CustomerID">
</xsl:value-of>
</xsl:attribute>
</CustomerID>
</xsl:template>
</xsl:stylesheet>
Let's take a closer look at this XSL. All this XSL does, is take any XML that is passed into it and transform it to the following syntax:
='1.0'
<CustomerID
xmlns="CustomerID-Data"
xmlns:iwb=
"http://schemas.microsoft.com/InformationBridge/2004"
xmlns:att="NorthwindIBF"
CustomerID=""/>
This is exactly how IBF needs it, to call the GetCustomerDetails_Action
. If you look back, from Part 1 of the article, the web method to get the Customer details expected the CustomerID
schema. This schema is what you see above. The difference is that we want to dynamically enter the attribute value for the CustomerID
. To do this, we add the <xsl:value-of>
and the select attribute. This finds the <Customers CustomerID="">
element and attribute and replaces the value in the CustomerID
attribute with the value passed in XML.
To demonstrate, if you pass in the following XML:
<att:Customers CustomerID="LETSS"
xmlns:att="NorthwindIBF"/>
To the following XSL:
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:iwb=
"http://schemas.microsoft.com/InformationBridge/2004"
xmlns:att="NorthwindIBF">
<xsl:template match="/">
<CustomerID xmlns="CustomerID-Data">
<xsl:attribute name="CustomerID">
<xsl:value-of select="/att:Customers/@CustomerID">
</xsl:value-of>
</xsl:attribute>
</CustomerID>
</xsl:template>
</xsl:stylesheet>
You will get back the following XML Transformation:
<CustomerID
xmlns="CustomerID-Data"
xmlns:iwb=
"http://schemas.microsoft.com/InformationBridge/2004"
xmlns:att="NorthwindIBF"
CustomerID="LETSS"/>
Notice how the CustomerID
is now populated with "LETSS". Click OK to finish the Add port dialog.
Step 3
In this step, we will create the Transformation metadata element, that simply makes a call to the Port. Below are the steps to create this Transformation:
- Navigate to the Add Transformation metadata element. NorthwindIBF --> Transformations --> [Add Transformation�].
- Double click on the [Add Transformation �] to bring up the Add Transformation dialog.
- Set the following parameters: (Refer to Figure 18)
- Name -
Att.Xsl.Transform.CustomerID
- Type � Transformation XSL
- Input Schema � (None)
- Output Schema�
MSIBF.Text
- Port �
Att.Xsl.Transform.CustomerID
- All we did was create an XSL Transformation entity that called the appropriate Port that contains the XSL. Click OK to finish the Add Transformation dialog.
Step 4
The next two steps are straightforward; they just involve creating a new View and an Action. We have already done these steps before, so I will not elaborate on them. Follow the below steps to add the View:
- Navigate to the Add View metadata element. NorthwindIBF --> Entities --> Customers --> Views --> [Add View�].
- Double click on the [Add View �] to bring up the Add View dialog.
- Set the following parameters:
- Name -
Att.CustomerDetails_View
- Schema �
Xsd.CustomerID
- Check the option to make this the default view.
- Click OK to close the Add View dialog.
Step 5
This step will create the new Action, that calls our new Operation and Transformation. This step ties all the metadata together. Follow the below steps to add and configure the Action:
- Within the
Att.CustomerDetails_View
, double click on the [Add Action�] node.
- Set the following parameters and click OK to add the new Action:
- Name -
Att.CustomerDetails_View
- Type �
EnterContext
- Double click on the new,
Att.CustomerDetails_View
, Action to bring up the Action designer.
- Drag and Drop the
Att.CallShowCustomerDetails_Action
Operation onto the Action designer.
- When the Transformation instance dialog opens, set the following properties:
- Data Source � Reference
- Transformation Instance -
Att.Xsl.Transform.CustomerID
- Click OK to close the Dialog.
- Save the metadata and publish it to the server.
Step 6
The final step is to test the attached schema and make sure it works. To do this, follow the steps below:
- Open up the Word file that contains the attached schema we created in the last section.
- When the document opens and the IBF task pane appears with the HTML Welcome region, click in between the "NorthwindsCustomersDocument" elements.
- Click on the Document Actions menu. This menu is on the top of the IBF task pane. Select the "XML Structure" menu. This will bring back the XML structure view. (Refer to Figure 19.)
- In the Choose an element to add to the document section, you will see the
CustomerID
element. (Refer to Figure 20.) Select this element to add it in between the NorthwindsCustomersDocument elements.
- You might have noticed that the IBF pane attempted to process the Action and display the Customer details region. But an error was caused, because we did not specify any
CustomerID
yet. To do that, right click on the Customers
element and select the Attributes option. (Refer to Figure 20.)
- On the Attributes For Customers dialog, you will now see the
CustomerID
attribute. This is because the attached schema contains this attribute, so that it can be added to the document. In the Value
field, add the CustomerID
for LETSS, then click the Add button. (Refer to Figure 22.)
- Click OK to close the dialog.
- Now, move your curser in between the
Customers
element and IBF will initialize the GetCustomerDetails_Action
. It should then display the appropriate customer details. If the Customer details region is not displaying at all, then try saving the document, closing it and then reopening it. (Refer to Figure 23.)
That's it! Now we can add as many Customers
elements to this document and set different CustomerID
attributes. This is a very powerful feature of IBF. You can probably see where you might be able to use it within your applications. To create this, we did not have to write, or compile any code. We simply created some XML/XSL and added it to the IBF metadata repository. Save and close the document. The next section will show you how to automate Office from within the IBF task pane.
Office automation from IBF
In this section, I wanted to demonstrate how you can automate an office application from within the IBF task pane. This is how you can expand the IBF region capabilities so that you can allow users to perform actions from Word. In this exercise, I simply want to insert the Customer name into the Customers
element when the user clicks on a button in the IBF task pane. To do this we need to add some code to the Customer details region that the IBF wizard created for us. Follow the steps below to accomplish this:
- In Visual Studio, open up the "IBFNorthwind_ControlLib" project, that was created by the IBF region creation wizard.
- Open up the CustomerDetails.cs, Windows forms user control.
- Make this control longer, so that we can add a button to the bottom.
- Add a new button, name it; "Insert Company Name" and then double click on it to create the event code. (Refer to Figure 24.)
- Add a reference to the Microsoft Word COM object. This will allow you to work with the Word object model from within Visual Studio.
- Add the code in Listing 8. This code creates an object to the Word application and the document. Then it inserts the Company name text into the Word document.
- Save and compile the project.
- Open back up the word document with the attached schema. Put the curser in between the
Customers
elements. Once the IBF Customer details region loads, you will see the new "Insert Customer Name" button. Click this button and the company name will be inserted into word, in between the Customers
element. (Refer to Figure 25.)
Deployment
This final section will talk a little bit about deployment to the client. To deploy an IBF solution to the client, the user must have the IBF client installed on their system. They also need to have Office 2003. Once IBF is installed on the client, it needs to be configured to point to the appropriate metadata service. To do this, IBF 1.5 has an administration and configuration tool that allows you to set these properties. This tool can be found in the Administration tools folder, on the Start menu. (Refer to Figure 26.)
Once the client has the proper configurations to point to the metadata server, the user needs to install the appropriate smart tag and Windows Forms User Control assemblies from your project. This can be done in several ways. You can create an installation program that will install these assemblies in the GAC, or another location that the IBF metadata can locate. But an easier way is to simply point your IBF ports to a web location where they can be found. Instead of having a hard coded path to a local disk, you could put these assemblies on a publicly available web server, and then point the port metadata to this location.
For example, the Port, "Asm.UI.CustomerDetailsAssembly" references an assembly, CustomerDetailsAssembly.dll, located on the "C" Drive on my local computer. I could copy this assembly to my web services directory and then change this Port to point to that web address. So instead of having a reference like: C:\Projects\CustomerDetailsAssembly.dll, you would have a reference like: http://myserver.com/ibf/customers/CustomerDetailsAssembly.dll.
Now when a user opens up your document, that contains an attached schema, this assembly will automatically be downloaded and installed on the users' machine.
Note: Your assembly must be signed and trusted on the users' machine. To do this, you can have an IT administrator create a machine policy that will trust your signed assemblies.
Summary
To wrap up this article, we walked through several advanced topics of IBF, including: Custom Smart Tag menus, Search regions, Attached schemas and Deployments. The purpose of these articles was to show you exactly how to accomplish these tasks in IBF 1.5. I believe that this is a great technology that really shows the power of integrating office applications, web services, metadata, XML/XSL and of course .NET. I hope that this article helps you out and that you can now create a complete IBF solution on your own.
References