- def AddJoinRow(self): 
-         """this will allow one to add a row into the bottom model. 
-         This tool is a many to many relationship between recipes and ingrendents. 
-         Ingredients our popluated by the program. This is a many to many relationship. 
-         This two tool has to models and two views the top model handles the recipes and the bottom model handles the ingredients. 
-         """ 
-         ## recipe row count 
-         recipe_count = self.obj_model.rowCount() 
-         ## this is to test if there is at least one planning ID. 
-         if recipe_count == 0: 
-             msg = "you must add a recipe before you can add a row to the join table." 
-             return 
-         ## else there is at least one row in the recipe model. 
-         else: 
-             ## get the selected row in the recipe table. 
-             selected_index = self.obj_tableView.currentIndex() 
-             ## this tests if there is not a selected index in the recipe model. 
-             if not selected_index.isValid(): 
-                 msg = "you must select a recipe row before adding a row in the " 
-                 return 
-             ## else there is a selected index in the planning objective model. 
-             else: 
-                 ## get the row index of the selected recipe 
-                 row_index = selected_index.row() 
-                 max_id = 1 
-                 ##Query the join database table to get the max id 
-                 query.exec_("SELECT MAX(id) FROM join_recipe_ingredents") 
-                 if query.next(): 
-                     max_id = query.value(0).toInt()[0] 
-   
-                 ## query the recipe model to get the recipe id from the top model. 
-                 ## cannot use rowcount because a user can remove a row. 
-                 recipe_id = self.obj_model.data(self.obj_model.index(row_index, ID)).toInt()[0] 
-   
-                 ## get the row count of the join table. 
-                 join_row = self.join_model.rowCount() 
-                 ## insert a row into the model. 
-                 self.join_model.insertRow(join_row) 
-                 ## set column 1 value to be the max id + 1 
-                 self.join_model.setData(self.join_model.index(join_row, JOIN_ID), max_id + 1) 
-                 ## set column 2 value to be the recipe_id 
-                 self.join_model.setData(self.join_model.index(join_row, PLANNING_ID), recipe_id) 
-                 ## column 3 is a combo box of all the ingrendents. I am using setRelation to populate this combobox. 
-   
-                 ## get the index of the newly added row. 
-                 index = self.join_model.index(join_row, CFR_ID) 
-                 if index.isValid(): 
-                     ## set it to editing. 
-                     self.join_tableView.edit(index) 
-                 else: 
-                     msg = "row was not inserted because you need to change row to a unique vaule." 
-                 self.resizeRow() 
        def AddJoinRow(self):
        """this will allow one to add a row into the bottom model.
        This tool is a many to many relationship between recipes and ingrendents.
        Ingredients our popluated by the program. This is a many to many relationship.
        This two tool has to models and two views the top model handles the recipes and the bottom model handles the ingredients.
        """
        ## recipe row count
        recipe_count = self.obj_model.rowCount()
        ## this is to test if there is at least one planning ID.
        if recipe_count == 0:
            msg = "you must add a recipe before you can add a row to the join table."
            QtGui.QMessageBox.warning(self, "warning", msg, QtGui.QMessageBox.Ok)
            return
        ## else there is at least one row in the recipe model.
        else:
            ## get the selected row in the recipe table.
            selected_index = self.obj_tableView.currentIndex()
            ## this tests if there is not a selected index in the recipe model.
            if not selected_index.isValid():
                msg = "you must select a recipe row before adding a row in the "
                QtGui.QMessageBox.warning(self, "warning", msg, QtGui.QMessageBox.Ok)
                return
            ## else there is a selected index in the planning objective model.
            else:
                ## get the row index of the selected recipe
                row_index = selected_index.row()
                max_id = 1
                query = QtSql.QSqlQuery()
                ##Query the join database table to get the max id
                query.exec_("SELECT MAX(id) FROM join_recipe_ingredents")
                if query.next():
                    max_id = query.value(0).toInt()[0]
                ## query the recipe model to get the recipe id from the top model.
                ## cannot use rowcount because a user can remove a row.
                recipe_id = self.obj_model.data(self.obj_model.index(row_index, ID)).toInt()[0]
                ## get the row count of the join table.
                join_row = self.join_model.rowCount()
                ## insert a row into the model.
                self.join_model.insertRow(join_row)
                ## set column 1 value to be the max id + 1
                self.join_model.setData(self.join_model.index(join_row, JOIN_ID), max_id + 1)
                ## set column 2 value to be the recipe_id
                self.join_model.setData(self.join_model.index(join_row, PLANNING_ID), recipe_id)
                ## column 3 is a combo box of all the ingrendents. I am using setRelation to populate this combobox.
                ## get the index of the newly added row.
                index = self.join_model.index(join_row, CFR_ID)
                if index.isValid():
                    ## set it to editing.
                    self.join_tableView.edit(index)
                else:
                    msg = "row was not inserted because you need to change row to a unique vaule."
                    QtGui.QMessageBox.warning(self, "warning", msg, QtGui.QMessageBox.Ok)
                self.resizeRow()
To copy to clipboard, switch view to plain text mode 
  
				
Bookmarks