'Move excel row based on cell content

I have an excel sheet and I want to move the entire row to another sheet and remove it from the original one based on the cell content Here is my code:

function onEdit(event) {
var ss = SpreadsheetApp.getActiveSpreadsheet();
var s =event.source.getActiveSheet();
var r =event.source.getActiveRange();
if(s.getName()=="Main" && r.getColumn ()== 7&& r.getValue () == "Completed"){
var row =r.getRow();
var numColumns= s.getLastcolumn();
var targetsheet= ss.getSheetByName("Completed");
var target=targetSheet.getRange(targetSheet.getLastRow()+ 1, 1);
s.getRange( row, 1, 1, numColumns).moveTo(target);
s.deleteRow(row);
}
if(s.getName () == "Main" && r.getColumn () == 7 && r.getValue () == "Pending"){
var row =r.getRow();
var numColumns = s.getLastColumn();
var targetSheet = ss.getSheetByName("Pending");
var target = targetSheet.getRange( targetSheet.getlastRow ()+ 1, 1);
s.getRange( row, 1, 1, numColumns).moveTo(target);
s.deleteRow( row);
}
if(s.getName ()=="Main" && r.getColumn ()==7 && r.getValue () == "Hold") {
var row= r.getRow( );
var numcolumns =s.getLastColumn()
var targetSheet=ss.getSheetByName("Hold" );
var target = targetSheet.getRange(targetSheet.getLastRow()+ 1, 1);
s.getRange(row ,1,1,numColumns).moveTo(target);
s.deleteRow(row);
}
}

Iam trying to edit the onEidit function However this code is not working for me here is the "Main" sheetMain sheet



Solution 1:[1]

Description

I simplified your script to suit my tastes. This works for me. You have to be careful to make sure you type the correct sheet name in column 7. I would have used a Data Validation drop down list to prevent typos.

Script

function onEdit(event) {
  try {
    let sheets = ["Completed","Pending","Hold"];
    let spread = event.source;
    let source = event.range.getSheet();
    if( source.getName() === "Main" ) {
      if( event.range.getColumn() === 7 ) {
        if( sheets.indexOf(event.value) < 0) return;
        let row = event.range.getRow();
        let numColumns = source.getLastColumn();
        let target = spread.getSheetByName(event.value);
        target = target.getRange(target.getLastRow()+1,1);
        source.getRange(row,1,1,numColumns).moveTo(target);
        source.deleteRow(row)
      }
    }
  }
  catch(err) {
    console.log(err);
  }
}

Reference

Sources

This article follows the attribution requirements of Stack Overflow and is licensed under CC BY-SA 3.0.

Source: Stack Overflow

Solution Source
Solution 1 TheWizEd