Wiki Markup
{info:title=Jira Ticket}
[https://jira.kuali.org/browse/OLE-2555]
{info}

h1. Instance Editor:

*Purpose:* Editing the instance document within OLE.

*Workflow:* The instance editor should be opened from any screen in which an instance is available for edit/view.

h1. VIEW:   

   
The Instance Editor View will contain Single Form with Navigation (Tree structure) and two pages ( one for Holdings and the other for Item tab sections), displaying one at a time based on the selected item on left pane.  !View.png!

h1.

*Sample code for* *View{*}*:*

<bean id="InstanceEditorView" parent="Uif-FormView">

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <property value="Instance Editor"/>

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <propertymso-bidi-font-weight:normal">navigation">

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <ref bean="LeftPane"/>

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </property>

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <property>

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <list>

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <bean parent="*Uif-Page*">

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <property name="items">

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <list>

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <ref bean="*HoldingTabsSection*"/>

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </list>

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </property>

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </bean>

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <bean parent="*Uif-Page*">

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <property name="items">

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <list>

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<ref bean="*ItemTabsSection*"/>

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </list>

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </property>

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </bean>

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </list>

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </property>

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <property name="footer">

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <ref bean="InstanceEditor_Footer" />

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </property>

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <property value="org.kuali.ole.editor.form.InstanceEditorForm"/>

&nbsp;&nbsp;&nbsp; </bean>

<bean id="*HoldingTabsSection*" parent="*Uif-TabSection*">

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <property>

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <list>

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <ref bean="Holdings"/>

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <ref bean="Serial"/>

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <ref bean="ActionNotes"/>

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <ref bean="ExtentOfOwnership"/>

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <ref bean="FormerIdentifiers"/>

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </list>

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </property>

&nbsp;&nbsp;&nbsp; </bean>

&nbsp;&nbsp;&nbsp; <beanmso-bidi-font-weight: normal">ItemTabsSection"&nbsp; &nbsp;parent="*Uif-TabSection*">

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <property>

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <list>

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <ref bean="Item"/>

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <ref bean="Location"/>

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <ref bean="ElectronicLA"/>

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <ref bean="HighDensityStorage"/>

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <ref bean="POVendorInfo"/>

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </list>

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </property>

&nbsp;&nbsp;&nbsp; </bean>

h2. &nbsp;


h2. Right Pane\- HoldingTabsSection:


h3. Holdings:&nbsp;&nbsp;&nbsp;


h3. !HoldingsTab.png|width=1043,height=690!


h3. Serial:

!Serial.png|width=1052,height=417!



h3. Action Notes:

For this section, we will use Uif-StackedCollectionSection to repeat entire Action Notes section and Uif-StackedSubCollection-WithinSection to repeat individual fields

h3. Extent of Ownership:&nbsp;

*&nbsp;* !extent.png|width=1084,height=434!

h3. Former Identifiers:&nbsp;

&nbsp;
*&nbsp;* !FormerIden.png|width=1044,height=448!

h2. Right Pane\- ItemTabsSection:


h3. Item:

We will use Uif-GridGroup with appropriate controls (text, dropdown).

h3. Location:

We will use Uif-GridGroup with appropriate controls (text, dropdown). And Uif-HorizontalFieldGroup for Call Number section.

h3. Electronic L&A:

We will use Uif-GridGroup with appropriate controls (text, dropdown).

h3. High Density Storage:&nbsp;


h3. !DensityStorage.png|width=1032,height=429!


h3. PO/Vendor Info:&nbsp;&nbsp;


h3. !VendorInfo.png!


h2. Right Pane\- Audit Details:


h2. Left Pane:

*Workflow:* Bib record has been selected and the user has indicated they would like to edit the instance/items which are related to it.

Left pane should be Uif-Navigation with Uif-Tree component having hierarchy of Instances and Items related to selected bib.


h3. 1. Load Instance Records for a selected Bib record:

*Participants:* InstanceEditorController.java, InstanceEditorFormDataHandler.java

*Workflow:*

Get bibId from request in Controller start() Method.

Build data for Left Pane while iterating list of Instance records for bibId.

*Sample Code:*


public ModelAndView start(@ModelAttribute("KualiForm") UifFormBase form, BindingResult result,
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; HttpServletRequest request, HttpServletResponse response) {
bibId = request.getParameter("bibId");


getInstanceEditorFormDataHandler().buildLeftPaneData(bibId);&nbsp;

}


h3. 2. Creating a new instance within the instance editor screen:

The system should provide a link or a button that will allow a user to indicate they would like to create a new instance to
be attached to the bibliographic record they are currently looking at the instances off. !LeftPane.png|border=1,width=807,height=654!

When user clicks the 'Create Instance' button, the result should be to display the instance editor with new (empty) instance and child item -- should be represented on the left hand menu (with a placeholder) so the user has the ability to navigate to the details of the child item and back to the details of the instance. In addition, this will allow users to navigate to the other (existing) instances and items and to create multiple items on the new instance.

*Participants:* InstanceEditorController.java, InstanceEditorFormDataHandler.java, InstanceEditorView.xml


*Sample code:*

&nbsp;&nbsp;&nbsp; <bean id="createNewInstance" parent="Uif-SecondaryActionButton" p:methodToCall="createNewInstance" p:actionLabel="Create Instance"/>

&nbsp;&nbsp;&nbsp; @RequestMapping(params = "methodToCall=createNewInstance")
&nbsp;&nbsp;&nbsp; public ModelAndView createNewInstance(@ModelAttribute("KualiForm") UifFormBase form, BindingResult result,
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; HttpServletRequest request, HttpServletResponse response) {
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; InstanceEditorForm instanceEditorForm = (InstanceEditorForm) form;

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; //Add New Instance as first record for Uif-Tree in Left pane.

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; return super.updateComponent(instanceEditorForm, result, request, response);
&nbsp;&nbsp;&nbsp; }

h3. 3. Creating a new Item (on an existing Instance):

Each Instance should have an icon next to it that when clicked will create a new item within that instance
&nbsp;Each Instance should have an icon next to it that when clicked will create a new item within that instance.

&nbsp;&nbsp; !aadi create new.png|border=1!


h1. {color:#333333}When user clicks the 'New Item Icon/Button' button, the result should be to display the item editor with new (empty) item -- should be represented on the left hand menu (with a placeholder) so the user has the ability to navigate to the details of the item. In addition, this will allow users to navigate to the other (existing) items and to create multiple items on the new instance.{color}


*Participants:*&nbsp;InstanceEditorController.java, InstanceEditorFormDataHandler.java, InstanceEditorView.xml

*Sample code:*

&nbsp;&nbsp;&nbsp; <bean id="createNewItem" parent="Uif-SecondaryActionButton" p:methodToCall="createNewItem" p:actionLabel="Create New Item"/>

&nbsp;&nbsp;&nbsp; @RequestMapping(params = "methodToCall=createNewItem")
&nbsp;&nbsp;&nbsp; public ModelAndView createNewItem(@ModelAttribute("KualiForm") UifFormBase form, BindingResult result,
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; HttpServletRequest request, HttpServletResponse response){ &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; InstanceEditorForm instanceEditorForm = (InstanceEditorForm) form; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; //Add New Item as first record for Uif-Tree in Left pane. &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; return super.updateComponent(instanceEditorForm, result, request, response); &nbsp;&nbsp;&nbsp; }.

h1. FORM:

Instance Editor Form will hold all related data to display in UI. For now since we are dealing with Right Pane, form will hold data related to Instance record which will hold Holdings and Item.

*Sample Form:*

public class InstanceEditorForm extends UifFormBase {

&nbsp;&nbsp;&nbsp; private OleInstance instance;

&nbsp;&nbsp;&nbsp; public OleInstance getInstance(){

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;  return instance;

&nbsp;&nbsp;&nbsp; }

&nbsp;&nbsp;&nbsp; public void setInstance(OleInstance instance) {

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; this.instance = instance;

&nbsp;&nbsp;&nbsp;&nbsp; }

}



h1. CONTROLLER:

InstanceEditorController will extend from UifControllerBase and will have the following methods
# start()
# submit()
# loadInstanceRecord()

h1. Test-Cases:

# InstanceEditorController_UT
## testSubmit()
# DocstoreHelperService_UT
## testCreateNewInstanceRecordToDocstore()

h1. DocStore Fields Mapping:

The below link will provide details of Fields using in different tabs along with docstore filed mapping.


*&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;**[Docstore-field-mapping|^Docstore-field-mapping.xlsx]**&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;*


h1. DocStore Handlers :

These handlers are for converting Form data to XML and vice-versa.


# WorkInstanceOlemlRecordProcessor
# WorkHoldingOlemlRecordProcessor
# WorkItemOlemlRecordProcessor

h1. Q&A:

| Scenario | Question | Answer |
| When   the instance is being displayed the instance.instanceIdentifier   (System-assigned unique ID for the Instance Document.) should be visible.   When an item is being displayed the item.itemIdentifier (Maps to MFHD 876 $a   Internal item number - System-assigned unique ID) should be visible. | Where   we need to display this Information? | Display   at the top of each tab |
| Metadata   fields (Last Updated by, Date) | Which   data we need to display?( Means Holdings will contain its own data and item   records will have its own data. Also, from docstore, we will get dateEntered   and lastUpdated only. What about updated By, Created) | When   click on holdings, display holding metadata and when click on Item display   Item data. |
| For   Audit, asking to show at least 10 update initially ( | From   where we can get this information? | Need   to implement logic in docstore (maintain Version) |
| ACCESS   METHOD & RELATIONSHIP / REQUIRED FIELDS \[5\]: These fields are only   required if electronicLocationAndAccess element is used. | Here   what "used" means? | Refers to Required   field. Means if Electronic Location & Access tab is used, then \[5\] is   mandatory |
| Referring   to User requirements document, we do have mock UI screens for Holdings   tab-Location, Serial and Action Notes. | What   about remaining tabs? | No   mock-ups |
| Holdings   and Item tabs | Form   where we can get data for dropdown fields? | Refer   OLE-2806 |
| | What   is the max-length for "token" fields? | | |