The present invention-relates to a system for working with business objects and, in particular, using temporary store drafts to manage the fields of a business object over multiple sessions.
Large software applications are often composed of unmanageably large amounts of executable code. In order to facilitate creation and management of large software systems, then, the systems are often composed of many different business objects. Business objects are software components that encompass user interfaces, data, business rules, communication components and any other code that may relate to their function.
In order to simplify design of these large systems, business objects are often defined as collections of logically related functions and data. A large application designed to facilitate a typical business may have many different business objects. An ordering business object may be used to handle incoming orders or changes to existing orders. A shipping business object may be implemented to handle all shipping related tasks, such as arranging for deliveries or determining shipping times and costs. Business objects may handle some tasks independently while communicating with other business objects to complete other tasks.
When the user is initially constructing the business objects, that user must currently enter all the necessary data in a single session. As the business processes become more and more complex, entering all this data in a single session becomes prohibitive. Data is entered in a single session to prevent version conflict. The process of resolving two conflicting versions into a single version can lead to prohibitive computer processing overhead cost. The alternative is the development of two competing versions residing on the system together, wasting memory space and leading to system failures.
What is needed is a method of being able to save incomplete versions of a business object without having to resolve version conflict.
A system and method for temporarily saving entries to the fields of a business object is disclosed. A draft manager may receive a first field entry of a set of field entries from a first user for an active instance of a business object. The draft manager may store a first temporary save draft of the active instance. The draft manager may assign the first temporary save draft to the first user. The draft manager may discard the first temporary save draft if the active instance is saved by, for example, a second user.
The controller/processor 210 may be any programmed processor known to one of skill in the art. However, the decision support method can also be implemented on a general-purpose or a special purpose computer, a programmed microprocessor or microcontroller, peripheral integrated circuit elements, an application-specific integrated circuit or other integrated circuits, hardware/electronic logic circuits, such as a discrete element circuit, a programmable logic device, such as a programmable logic array, field programmable gate-array, or the like. In general, any device or devices capable of implementing the decision support method as described herein can be used to implement the decision support system functions of this invention.
The memory 220 may include volatile and nonvolatile data storage, including one or more electrical, magnetic or optical memories such as a RAM, cache, hard drive, CD-ROM drive, tape drive or removable storage disk. The memory may have a cache 225 to speed access to specific data.
The Input/Output interface 250 may be connected to one or more input devices that may include a keyboard, mouse, pen-operated touch screen or monitor, voice-recognition device, or any other device that accepts input. The Input/Output interface 250 may also be connected to one or more output devices, such as a monitor, printer, disk drive, speakers, or any other device provided to output data.
The network interface 260 may be connected to a communication device, modem, network interface card, a transceiver, or any other device capable of transmitting and receiving signals over a network. The components of the computer system 200 may be connected via an electrical bus 270, for example, or linked wirelessly.
Client software and databases may be accessed by the controller/processor 210 from memory 220 or through the database interface 240, and may include, for example, database applications, word processing applications, the client side of a client/server application such as a billing system, as well as components that embody the decision support functionality of the present invention. The computer system 200 may implement any operating system, such as Windows or UNIX, for example. Client and server software may be written in any programming language, such as ABAP, C, C++, Java or Visual Basic, for example.
Several embodiments of the present invention are specifically illustrated and described herein. However, it will be appreciated that modifications and variations of the present invention are covered by the above teachings and within the purview of the appended claims without departing from the spirit and intended scope of the invention.