Skip to end of metadata
Go to start of metadata

You are viewing an old version of this page. View the current version.

Compare with Current View Page History

« Previous Version 49 Next »

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.

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. 

Sample code for View:

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

        <property value="Instance Editor"/>

        <propertymso-bidi-font-weight:normal">navigation">

            <ref bean="LeftPane"/>

        </property>

        <property>

            <list>

                <bean parent="Uif-Page">

                    <property name="items">

                        <list>

                            <ref bean="HoldingTabsSection"/>

                        </list>

                    </property>

                </bean>

                <bean parent="Uif-Page">

                    <property name="items">

                        <list>

                            <ref bean="ItemTabsSection"/>

                        </list>

                    </property>

                </bean>

            </list>

        </property>

        <property name="footer">

            <ref bean="InstanceEditor_Footer" />

        </property>

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

    </bean>

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

        <property>

            <list>

                <ref bean="Holdings"/>

                <ref bean="Serial"/>

                <ref bean="ActionNotes"/>

                <ref bean="ExtentOfOwnership"/>

                <ref bean="FormerIdentifiers"/>

            </list>

        </property>

    </bean>

    <beanmso-bidi-font-weight: normal">ItemTabsSection"   parent="Uif-TabSection">

        <property>

            <list>

                <ref bean="Item"/>

                <ref bean="Location"/>

                <ref bean="ElectronicLA"/>

                <ref bean="HighDensityStorage"/>

                <ref bean="POVendorInfo"/>

            </list>

        </property>

    </bean>

 

Right Pane- HoldingTabsSection:

Holdings:   

Serial:

Action Notes:

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

Extent of Ownership: 

 

Former Identifiers: 

 
 

Right Pane- ItemTabsSection:

Item:

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

Location:

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

Electronic L&A:

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

High Density Storage: 

PO/Vendor Info:  

Right Pane- Audit Details:

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.

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,
                              HttpServletRequest request, HttpServletResponse response)

Unknown macro: {bibId = request.getParameter("bibId"); getInstanceEditorFormDataHandler().buildLeftPaneData(bibId);  }

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.

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:

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

    @RequestMapping(params = "methodToCall=createNewInstance")
    public ModelAndView createNewInstance(@ModelAttribute("KualiForm") UifFormBase form, BindingResult result,
                                        HttpServletRequest request, HttpServletResponse response)

Unknown macro: {        InstanceEditorForm instanceEditorForm = (InstanceEditorForm) form;         //Add New Instance as first record for Uif-Tree in Left pane.         return super.updateComponent(instanceEditorForm, result, request, response);    }

Validations :

If the user attempts to click the "Create Instance" button while they are working on an un-submitted new
instance, present an error message
  1) If the user attempts to click the "Create Instance" button while they are working on an un-submitted new instance, present an error message ("Cannot create additional new instance. Unsaved instance exits.").

  2) If the user attempts to leave this page with an un-submitted new instance, warn them they will lose any unsaved data (An unsaved instance exists are you sure you want to exit? Yes/no) .

  3) If the user attempts to click cancel button with an un-submitted new instance, warn them they will lose any unsaved data (An unsaved instance exists are you sure you want to cancel? Yes/no) .

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

  Sample code: 
                         <bean id="MessageSection" parent="Uif-VerticalBoxSection">
                                <property name="items">
                                      <list>
                                           <bean parent="Uif-MessageField" p:messageText="@

Unknown macro: {message}

" p:styleClasses="messageClass"/>
                                      </list>
                               </property>
                        </bean>

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
  

  

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.

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

Sample code:

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

    @RequestMapping(params = "methodToCall=createNewItem")
    public ModelAndView createNewItem(@ModelAttribute("KualiForm") UifFormBase form, BindingResult result,
                                        HttpServletRequest request, HttpServletResponse response)

Unknown macro: {         InstanceEditorForm instanceEditorForm = (InstanceEditorForm) form;         //Add New Item as first record for Uif-Tree in Left pane.         return super.updateComponent(instanceEditorForm, result, request, response);     }

Validations :

If the user attempts to click the "Create Instance" button while they are working on an un-submitted new
instance, present an error message
  1) If the user attempts to click the "Create Item" button while they are working on an un-submitted new item, present an error message ("Cannot create additional new item. Unsaved item exits.").

  2) If the user attempts to leave this page with an un-submitted new item, warn them they will lose any unsaved data (An unsaved item exists are you sure you want to exit? Yes/no) .

  3) If the user attempts to click cancel button with an un-submitted new item, warn them they will lose any unsaved data (An unsaved item exists are you sure you want to cancel? Yes/no) .

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

  Sample code: 
                         <bean id="MessageSection" parent="Uif-VerticalBoxSection">
                                <property name="items">
                                      <list>
                                           <bean parent="Uif-MessageField" p:messageText="@

" p:styleClasses="messageClass"/>
                                      </list>
                               </property>
                        </bean>

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 {

    private OleInstance instance;

    public OleInstance getInstance()

Unknown macro: {        return instance;     }

    public void setInstance(OleInstance instance)

Unknown macro: {         this.instance = instance;      }

}

CONTROLLER:

InstanceEditorController will extend from UifControllerBase and will have the following methods

  1. start()
  2. submit()
  3. loadInstanceRecord()

Test-Cases:

  1. InstanceEditorController_UT
    1. testSubmit()
  2. DocstoreHelperService_UT
    1. testCreateNewInstanceRecordToDocstore()

DocStore Fields Mapping:

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

           Docstore-field-mapping          

DocStore Handlers :

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

  1. WorkInstanceOlemlRecordProcessor
  2. WorkHoldingOlemlRecordProcessor
  3. WorkItemOlemlRecordProcessor

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?

 

 

  • No labels