Changeset 719


Ignore:
Timestamp:
Nov 25, 2010, 8:47:00 AM (9 years ago)
Author:
gav
Message:

Domain change: as per ticket #96 - Remove unused fields from InventoryItem?.
Removed InventoryItem?.preferredManufacturer and manufacturersPartNumber.

Location:
trunk/grails-app
Files:
7 edited

Legend:

Unmodified
Added
Removed
  • trunk/grails-app/controllers/InventoryItemDetailedController.groovy

    r647 r719  
    344344        associatedPropertyValues.inventoryLocationList = InventoryLocation.findAllByIsActive(true, [max:associatedPropertyMax, sort:'name'])
    345345        associatedPropertyValues.assetList = Asset.findAllByIsActive(true, [max:associatedPropertyMax, sort:'name'])
    346         associatedPropertyValues.manufacturerList = Manufacturer.findAllByIsActive(true, [max:associatedPropertyMax, sort:'name'])
    347346        associatedPropertyValues.supplierList = Supplier.findAllByIsActive(true, [max:associatedPropertyMax, sort:'name'])
    348347
     
    433432            def possibleAlternateItems = inventoryItemService.getPossibleAlternateItems(result.inventoryItemInstance)
    434433            def suppliers = Supplier.findAllByIsActive(true).sort { p1, p2 -> p1.name.compareToIgnoreCase(p2.name) }
    435             def manufacturers = Manufacturer.findAllByIsActive(true).sort { p1, p2 -> p1.name.compareToIgnoreCase(p2.name) }
    436434
    437435            return [ inventoryItemInstance : result.inventoryItemInstance,
    438436                            possibleAlternateItems: possibleAlternateItems,
    439                             suppliers: suppliers,
    440                             manufacturers: manufacturers]
     437                            suppliers: suppliers]
    441438        }
    442439
     
    462459        def possibleAlternateItems = inventoryItemService.getPossibleAlternateItems(result.inventoryItemInstance)
    463460        def suppliers = Supplier.findAllByIsActive(true).sort { p1, p2 -> p1.name.compareToIgnoreCase(p2.name) }
    464         def manufacturers = Manufacturer.findAllByIsActive(true).sort { p1, p2 -> p1.name.compareToIgnoreCase(p2.name) }
    465461        render(view:'edit', model:[inventoryItemInstance: result.inventoryItemInstance.attach(),
    466462                                                possibleAlternateItems: possibleAlternateItems,
    467                                                 suppliers: suppliers,
    468                                                 manufacturers: manufacturers])
     463                                                suppliers: suppliers])
    469464    }
    470465
     
    472467        def result = inventoryItemService.create(params)
    473468        def suppliers = Supplier.findAllByIsActive(true).sort { p1, p2 -> p1.name.compareToIgnoreCase(p2.name) }
    474         def manufacturers = Manufacturer.findAllByIsActive(true).sort { p1, p2 -> p1.name.compareToIgnoreCase(p2.name) }
    475469
    476470        if(!result.error)
    477471            return [inventoryItemInstance: result.inventoryItemInstance,
    478                             suppliers: suppliers,
    479                             manufacturers: manufacturers]
     472                            suppliers: suppliers]
    480473
    481474        //flash.errorMessage = g.message(code: result.error.code, args: result.error.args)
     
    493486
    494487        def suppliers = Supplier.findAllByIsActive(true).sort { p1, p2 -> p1.name.compareToIgnoreCase(p2.name) }
    495         def manufacturers = Manufacturer.findAllByIsActive(true).sort { p1, p2 -> p1.name.compareToIgnoreCase(p2.name) }
    496488
    497489        //flash.errorMessage = g.message(code: result.error.code, args: result.error.args)
    498490        render(view:'create', model:[inventoryItemInstance: result.inventoryItemInstance,
    499                                                     suppliers: suppliers,
    500                                                     manufacturers: manufacturers])
     491                                                    suppliers: suppliers])
    501492    }
    502493
  • trunk/grails-app/domain/InventoryItem.groovy

    r718 r719  
    66    Picture picture
    77    Supplier preferredSupplier
    8     Manufacturer preferredManufacturer
    98    String name
    109    String description = ""
    1110    String comment = ""
    12     String manufacturersPartNumber
    1311    BigDecimal estimatedUnitPriceAmount
    1412    Currency estimatedUnitPriceCurrency
     
    2826                                    spareFor: Asset,
    2927                                    inventoryMovements: InventoryMovement,
    30                                     alternateManufacturers: Manufacturer,
    3128                                    alternateSuppliers: Supplier]
    3229
     
    4946        inventoryGroup()
    5047        inventoryType()
    51         manufacturersPartNumber(blank:true, nullable:true)
    5248        suppliersPartNumber(blank:true, nullable:true)
    5349        preferredSupplier(nullable:true)
    54         preferredManufacturer(nullable:true)
    5550    }
    5651
  • trunk/grails-app/services/InventoryCsvService.groovy

    r718 r719  
    5252            def line = []
    5353            def lineNumber = 0
    54             def maxNumberOfColumns = 23
     54            def maxNumberOfColumns = 20
    5555            def inventoryParams = [:]
    5656            def inventoryProperties = ["name", "description", "comment", "unitsInStock", "reorderPoint", "reorderQuantity",
     
    5959                                                        "inventoryGroup", "inventoryType",
    6060                                                        "suppliersPartNumber", "preferredSupplier", "alternateSuppliers",
    61                                                         "manufacturersPartNumber", "preferredManufacturer", "alternateManufacturers",
    6261                                                        "alternateItems", "spareFor"]
    6362
     
    6968            def spareForInstance
    7069            def alternateItemInstance
    71             def preferredManufacturerInstance
    72             def alternateManufacturerInstance
    73             def manufacturerTypeInstance
    74             def manufacturerTypeUnknown = ManufacturerType.get(1)
    7570            def inventoryTypeInstance
    7671            def unitOfMeasureInstance
     
    8883            def tempSupplierType = ''
    8984            def tempSupplierItemAndType = []
    90 
    91             def tempPreferredManufacturerItemAndType = ''
    92             def tempPreferredManufacturerItem = ''
    93             def tempPreferredManufacturerType = ''
    94 
    95             def tempAlternateManufacturers = []
    96             def tempManufacturerItem = ''
    97             def tempManufacturerType = ''
    98             def tempManufacturerItemAndType = []
    9985
    10086            def tempSpareFor = []
     
    238224                        return fail(code: "inventory.import.failure", args: [lineNumber, logFileLink])
    239225                    }
    240                 }
    241 
    242                 // Preferred Manufacturer
    243                 if(inventoryParams.preferredManufacturer) {
    244                     tempPreferredManufacturerItemAndType = parseItemAndType(inventoryParams.preferredManufacturer)
    245                     tempPreferredManufacturerItem = WordUtils.capitalize(tempPreferredManufacturerItemAndType[0])
    246 
    247                     preferredManufacturerInstance = Manufacturer.findByName(tempPreferredManufacturerItem)
    248                     if(!preferredManufacturerInstance) {
    249 
    250                         // Manufacturer Type.
    251                         if(tempPreferredManufacturerItemAndType.size == 2) {
    252                             tempPreferredManufacturerType = WordUtils.capitalize(tempPreferredManufacturerItemAndType[1])
    253                             manufacturerTypeInstance = ManufacturerType.findByName(tempPreferredManufacturerType)
    254                         }
    255                         else
    256                             manufacturerTypeInstance = manufacturerTypeUnknown
    257                         if(!manufacturerTypeInstance) {
    258                             log.error "Failed to find preferred manufacturer type on line: " + lineNumber
    259                             return fail(code: "inventory.import.failure", args: [lineNumber, logFileLink])
    260                         }
    261 
    262                         preferredManufacturerInstance = new Manufacturer(name: tempPreferredManufacturerItem,
    263                                                                                                             manufacturerType: manufacturerTypeInstance)
    264                         if(!preferredManufacturerInstance.save()) {
    265                             log.error "Failed to create preferred manufacturer on line: " + lineNumber
    266                             return fail(code: "inventory.import.failure", args: [lineNumber, logFileLink])
    267                         }
    268                     }
    269                 }
    270                 else
    271                     preferredManufacturerInstance = null
    272 
    273                 // Alternate Manufacturers.
    274                 tempAlternateManufacturers = parseInputList(inventoryParams.alternateManufacturers)
    275                 inventoryParams.alternateManufacturers = []
    276 
    277                 for(tempManufacturer in tempAlternateManufacturers) {
    278                     tempManufacturerItemAndType = parseItemAndType(tempManufacturer)
    279                     tempManufacturerItem = WordUtils.capitalizeFully(tempManufacturerItemAndType[0])
    280 
    281                     alternateManufacturerInstance = Manufacturer.findByName(tempManufacturerItem)
    282                     if(!alternateManufacturerInstance) {
    283 
    284                         // ManufacturerType.
    285                         if(tempManufacturerItemAndType.size == 2) {
    286                             tempManufacturerType = WordUtils.capitalize(tempManufacturerItemAndType[1])
    287                             manufacturerTypeInstance = ManufacturerType.findByName(tempManufacturerType)
    288                         }
    289                         else
    290                             manufacturerTypeInstance = manufacturerTypeUnknown
    291                         if(!manufacturerTypeInstance) {
    292                             log.error "Failed to find manufacturer type on line: " + lineNumber
    293                             return fail(code: "inventory.import.failure", args: [lineNumber, logFileLink])
    294                         }
    295 
    296                         alternateManufacturerInstance = new Manufacturer(name: tempManufacturerItem,
    297                                                                                                 manufacturerType: manufacturerTypeInstance)
    298                         if(!alternateManufacturerInstance.save()) {
    299                             log.error "Failed to create manufacturers on line: " + lineNumber
    300                             return fail(code: "inventory.import.failure", args: [lineNumber, logFileLink])
    301                         }
    302                     }
    303 
    304                     inventoryParams.alternateManufacturers.add(alternateManufacturerInstance)
    305226                }
    306227
     
    417338                inventoryParams.unitOfMeasure = unitOfMeasureInstance
    418339                inventoryParams.preferredSupplier = preferredSupplierInstance
    419                 inventoryParams.preferredManufacturer = preferredManufacturerInstance
    420340
    421341                // Name.
     
    485405        writer.writeNext("Comment: Required columns are marked with a (*) in the header line.")
    486406        writer.writeNext("Comment: Lists of items in a column must be separated by a semicolon (;), not a comma.")
    487         writer.writeNext("Comment: The at symbol (@) is reserved for indicating supplier and manufacturer types.")
     407        writer.writeNext("Comment: The at symbol (@) is reserved for indicating supplier types.")
    488408        writer.writeNext("Comment: Identical and existing names will be considered as the same item.")
    489409        writer.writeNext("Comment: Lines containing 'comment' will be ignored.")
     
    515435                                        "123", "Multi Supplier@Local",
    516436                                        "Multi Distributors1@OEM; Multi Distributors2@Local",
    517                                         "321", "Master Manufacturer@OEM",
    518                                         "Mega Manufacturer1@OEM;Mega Manufacturer2@Alternate",
    519437                                        "2204E-2RS", ""
    520438                                        ] as String[])
     
    530448                                        "456KL", "Multi Supplier",
    531449                                        "Multi Distributors1; Multi Distributors2",
    532                                         "654OP", "Master Manufacturer",
    533                                         "Mega Manufacturer1;Mega Manufacturer2",
    534450                                        "", ""
    535451                                        ] as String[])
     
    582498            }.collect { it.name + "@" + it.supplierType }.join(';') )
    583499
    584             row.add(inventoryItem.manufacturersPartNumber)
    585 
    586             if(inventoryItem.preferredManufacturer)
    587                 row.add( inventoryItem.preferredManufacturer.name + "@" + inventoryItem.preferredManufacturer.manufacturerType )
    588             else
    589                 row.add('')
    590 
    591             row.add(inventoryItem.alternateManufacturers.sort { p1, p2 ->
    592                 p1.name.compareToIgnoreCase(p2.name)
    593             }.collect { it.name + "@" + it.manufacturerType }.join(';'))
    594 
    595             row.add(inventoryItem.alternateItems.sort { p1, p2 ->
    596                 p1.name.compareToIgnoreCase(p2.name)
    597             }.collect { it.name }.join(';') )
    598 
    599500            row.add(inventoryItem.spareFor.sort { p1, p2 ->
    600501                p1.name.compareToIgnoreCase(p2.name)
     
    813714            "Estimated Unit Price", "Currency", "Enable Reorder", "Location*", "Store*", "Site*", "Group*", "Type*",
    814715            "Supplier's Part Number", "Preferred Supplier", "Alternate Suppliers",
    815             "Manufacturer's Part Number", "Preferred Manufacturer", "Alternate Manufacturers", "Alternate Item", "Spare For"]
     716            "Alternate Item", "Spare For"]
    816717    }
    817718
  • trunk/grails-app/views/inventoryItemDetailed/create.gsp

    r718 r719  
    169169                            </tr>
    170170                       
    171                             <tr class="prop">
    172                                 <td valign="top" class="name">
    173                                     <label for="manufacturersPartNumber">Manufacturers Part Number:</label>
    174                                 </td>
    175                                 <td valign="top" class="value ${hasErrors(bean:inventoryItemInstance,field:'manufacturersPartNumber','errors')}">
    176                                     <input type="text" id="manufacturersPartNumber" name="manufacturersPartNumber" value="${fieldValue(bean:inventoryItemInstance,field:'manufacturersPartNumber')}"/>
    177                                 </td>
    178                             </tr>
    179                        
    180                             <tr class="prop">
    181                                 <td valign="top" class="name">
    182                                     <label for="preferredManufacturer">Preferred Manufacturer:</label>
    183                                 </td>
    184                                 <td valign="top">
    185                                     <g:select optionKey="id" from="${manufacturers}" name="preferredManufacturer.id" value="${inventoryItemInstance?.preferredManufacturer?.id}" noSelection="['null':'--None--']"></g:select>
    186 
    187                                     <p><g:link controller="manufacturerDetailed" action="create">+Add Manufacturer</g:link></p>
    188                                 </td>
    189                             </tr>
    190                        
    191                             <tr class="prop">
    192                                 <td valign="top" class="name">
    193                                     <label for="manufacturers">Alternate Manufacturers:</label>
    194                                 </td>
    195                                 <td valign="top" class="value ${hasErrors(bean:inventoryItemInstance,field:'alternateManufacturers','errors')}">
    196                                     <g:select id="alternateManufacturers" name="alternateManufacturers"
    197                                                         from="${manufacturers}"
    198                                                         size="5" multiple="yes" optionKey="id"
    199                                                         value="${inventoryItemInstance.alternateManufacturers?.id}" noSelection="['':'--None--']" />
    200                                 </td>
    201                             </tr>
    202                        
    203171                        </tbody>
    204172                    </table>
  • trunk/grails-app/views/inventoryItemDetailed/edit.gsp

    r718 r719  
    207207                            <tr class="prop">
    208208                                <td valign="top" class="name">
    209                                     <label for="manufacturersPartNumber">Manufacturers Part Number:</label>
    210                                 </td>
    211                                 <td valign="top" class="value ${hasErrors(bean:inventoryItemInstance,field:'manufacturersPartNumber','errors')}">
    212                                     <input type="text" id="manufacturersPartNumber" name="manufacturersPartNumber" value="${fieldValue(bean:inventoryItemInstance,field:'manufacturersPartNumber')}"/>
    213                                 </td>
    214                             </tr>
    215 
    216                             <tr class="prop">
    217                                 <td valign="top" class="name">
    218                                     <label for="preferredManufacturer">Preferred Manufacturer:</label>
    219                                 </td>
    220                                 <td valign="top">
    221                                     <g:select optionKey="id" from="${manufacturers}" name="preferredManufacturer.id" value="${inventoryItemInstance.preferredManufacturer?.id}" noSelection="['null':'--None--']"></g:select>
    222 
    223                                     <p><g:link controller="manufacturerDetailed" action="create">+Add Manufacturer</g:link></p>
    224                                 </td>
    225                             </tr>
    226 
    227                             <tr class="prop">
    228                                 <td valign="top" class="name">
    229                                     <label for="manufacturers">Alternate Manufacturers:</label>
    230                                 </td>
    231                                 <td valign="top" class="value ${hasErrors(bean:inventoryItemInstance,field:'alternateManufacturers','errors')}">
    232                                     <g:select id="alternateManufacturers" name="alternateManufacturers"
    233                                                         from="${manufacturers}"
    234                                                         size="5" multiple="yes" optionKey="id"
    235                                                         value="${inventoryItemInstance.alternateManufacturers?.id}" noSelection="['':'--None--']" />
    236                                 </td>
    237                             </tr>
    238 
    239                             <tr class="prop">
    240                                 <td valign="top" class="name">
    241209                                    <label for="spareFor">Spare For:</label>
    242210                                </td>
  • trunk/grails-app/views/inventoryItemDetailed/search.gsp

    r718 r719  
    242242                                    excludeProperties="estimatedUnitPriceCurrency"
    243243                                    associatedProperties="inventoryLocation.name,
    244                                                                             spareFor.name,
    245                                                                             preferredManufacturer.name,
    246                                                                             preferredSupplier.name"
     244                                                                            spareFor.name"
    247245                                    filterPropertyValues="${['inventoryLocation.name':[values: associatedPropertyValues.inventoryLocationList],
    248246                                                                                'spareFor.name':[values: associatedPropertyValues.assetList],
    249                                                                                 'preferredManufacturer.name':[values: associatedPropertyValues.manufacturerList],
    250247                                                                                'preferredSupplier.name':[values: associatedPropertyValues.supplierList]
    251248                                                                                ]}"/>
  • trunk/grails-app/views/inventoryItemDetailed/show.gsp

    r718 r719  
    299299                                    </tr>
    300300
    301                                     <tr class="prop">
    302                                         <td valign="top" class="name">Manufacturers Part Number:</td>
    303                                         <td valign="top" class="value">${fieldValue(bean:inventoryItemInstance, field:'manufacturersPartNumber')}</td>
    304                                     </tr>
    305 
    306                                     <tr class="prop">
    307                                         <td valign="top" class="name">Preferred Manufacturer:</td>
    308 
    309                                         <td  valign="top" style="text-align:left;" class="value">
    310                                             <g:link controller="manufacturerDetailed" action="show" id="${inventoryItemInstance.preferredManufacturer?.id}">
    311                                                 ${inventoryItemInstance.preferredManufacturer?.encodeAsHTML()}
    312                                             </g:link>
    313                                         </td>
    314                                     </tr>
    315 
    316                                     <tr class="prop">
    317                                         <td valign="top" class="name">Alternate Manufacturers:</td>
    318 
    319                                         <td  valign="top" style="text-align:left;" class="value">
    320                                             <ul>
    321                                             <g:each var="m" in="${ inventoryItemInstance.alternateManufacturers.sort { p1, p2 -> p1.name.compareToIgnoreCase(p2.name) } }">
    322                                                 <li><g:link controller="manufacturerDetailed" action="show" id="${m.id}">${m?.encodeAsHTML()}</g:link></li>
    323                                             </g:each>
    324                                             </ul>
    325                                         </td>
    326                                     </tr>
    327 
    328 
    329301                                </tbody>
    330302                            </table>
Note: See TracChangeset for help on using the changeset viewer.