Google Sheets - Merging two scripts together

chrono2483

Board Regular
Joined
Aug 23, 2014
Messages
164
Office Version
  1. 2016
Hello,

I was able to search and find to codes that independently was able to get to work/accomplish what I want it to do. However when I try to include them in the same sheet, it looks like code#2 cancels out the first one. Is there a way to combine the two so they both work?

Code 1: Adjusted the drop-down list based on user selection in Col B, C and D
Code 2: Date Stamps and edits on that row

Code 1:

HTML:
function depDrop_(range, sourceRange){
var rule = SpreadsheetApp.newDataValidation().requireValueInRange(sourceRange, true).build();
range.setDataValidation(rule);
}
function onEdit (){
var aCell = SpreadsheetApp.getActiveSheet().getActiveCell();
var aColumn = aCell.getColumn();
if (aColumn == 2 && SpreadsheetApp.getActiveSheet()){
var range = SpreadsheetApp.getActiveSheet().getRange(aCell.getRow(), aColumn + 1);
var sourceRange = SpreadsheetApp.getActiveSpreadsheet().getRangeByName(aCell.getValue());
depDrop_(range, sourceRange);
}
else if (aColumn == 3 && SpreadsheetApp.getActiveSheet()){
var range = SpreadsheetApp.getActiveSheet().getRange(aCell.getRow(), aColumn + 1);
var sourceRange = SpreadsheetApp.getActiveSpreadsheet().getRangeByName(aCell.getValue());
depDrop_(range, sourceRange);
}
  else if (aColumn == 4 && SpreadsheetApp.getActiveSheet()){
var range = SpreadsheetApp.getActiveSheet().getRange(aCell.getRow(), aColumn + 1);
var sourceRange = SpreadsheetApp.getActiveSpreadsheet().getRangeByName(aCell.getValue());
depDrop_(range, sourceRange);
}
}


Code 2:
HTML:
    function onEdit(event) {  var eventRange = event.range;  if (eventRange.getColumn() == 4) { // 4 == column D     // getRange(row, column, numRows, numColumns)    var columnXRange = SpreadsheetApp.getActiveSheet().getRange(eventRange.getRow(), 57, eventRange.getNumRows(), 57);     var values = columnXRange.getValues();      for (var i = 0; i < values.length; i++) {      if(!values[i][0]){  // If cell isn't empty       values[i][0] = new Date();      }    }    columnXRange.setValues(values);   }}

Can anyone point in the right direction or help explain/understand how to merge the two together?

Thank you.
 

Excel Facts

Is there a shortcut key for strikethrough?
Ctrl+S is used for Save. Ctrl+5 is used for Strikethrough. Why Ctrl+5? When you use hashmarks to count |||| is 4, strike through to mean 5.
The 2 pieces of code are quite different, how would you want to merge them?

By the way why does the first piece of code use ActiveCell to find out which cell/range has been edited and the second used event.range?
 
Upvote 0
The 2 pieces of code are quite different, how would you want to merge them?

By the way why does the first piece of code use ActiveCell to find out which cell/range has been edited and the second used event.range?



I believe that is where the challenge is. Both are codes I've found online to accomplish my goal, which is why they are different. Also the reason why they seem to cancel each other out when using both.

By merge, I mean I want to be able to use Code #1 , as well as be able to add a time stamp to each row (Col BE) when an edit/selection is made to that row's Col D.
 
Upvote 0
Perhaps you could create a function to do the time stamp, something like this.
Rich (BB code):
function timeStamp(rng)

{

if (rng.getColumn() == 4)
    { // 4 == column D
      // getRange(row, column, numRows, numColumns)
      var columnXRange = SpreadsheetApp.getActiveSheet().getRange(rng.getRow(), 57, rng.getNumRows(), 57);
      var values = columnXRange.getValues();
      for (var i = 0; i < values.length; i++)
        {
        if(!values[0]){// If cell isn't empty
        values[0] = new Date();
        }
    }
    columnXRange.setValues(values);
    }
}

You could call that from the first set of code like this,
Rich (BB code):
timeStamp(aCell)
which would go in the last else if, i.e. the one that checks if column D has been changed.
 
Upvote 0
Perhaps you could create a function to do the time stamp, something like this.
Rich (BB code):
function timeStamp(rng)

{

if (rng.getColumn() == 4)
    { // 4 == column D
      // getRange(row, column, numRows, numColumns)
      var columnXRange = SpreadsheetApp.getActiveSheet().getRange(rng.getRow(), 57, rng.getNumRows(), 57);
      var values = columnXRange.getValues();
      for (var i = 0; i < values.length; i++)
        {
        if(!values[0]){// If cell isn't empty
        values[0] = new Date();
        }
    }
    columnXRange.setValues(values);
    }
}

You could call that from the first set of code like this,
Rich (BB code):
timeStamp(aCell)
which would go in the last else if, i.e. the one that checks if column D has been changed.


Thank you Norie. I've attempted to use the suggested code, but does not apply the time stamp. I added timeStamp (aCell) to my original code at the end. I then added a new script and used the function timeStamp (rng) code.

Could I be missing a step?
 
Upvote 0
Can you post the adjusted code?
 
Upvote 0
Can you post the adjusted code?

Sure...

HTML:
function depDrop_(range, sourceRange){
var rule = SpreadsheetApp.newDataValidation().requireValueInRange(sourceRange, true).build();
range.setDataValidation(rule);
}
function onEdit (){
var aCell = SpreadsheetApp.getActiveSheet().getActiveCell();
var aColumn = aCell.getColumn();
if (aColumn == 2 && SpreadsheetApp.getActiveSheet()){
var range = SpreadsheetApp.getActiveSheet().getRange(aCell.getRow(), aColumn + 1);
var sourceRange = SpreadsheetApp.getActiveSpreadsheet().getRangeByName(aCell.getValue());
depDrop_(range, sourceRange);
}
else if (aColumn == 3 && SpreadsheetApp.getActiveSheet()){
var range = SpreadsheetApp.getActiveSheet().getRange(aCell.getRow(), aColumn + 1);
var sourceRange = SpreadsheetApp.getActiveSpreadsheet().getRangeByName(aCell.getValue());
depDrop_(range, sourceRange);
}
  else if (aColumn == 4 && SpreadsheetApp.getActiveSheet()){
var range = SpreadsheetApp.getActiveSheet().getRange(aCell.getRow(), aColumn + 1);
var sourceRange = SpreadsheetApp.getActiveSpreadsheet().getRangeByName(aCell.getValue());
depDrop_(range, sourceRange);
  
call timeStamp(aCell)  
}
}


and for the second script:

HTML:
function timeStamp(rng)

{

if (rng.getColumn() == 4)
    { // 4 == column D
      // getRange(row, column, numRows, numColumns)
      var columnXRange = SpreadsheetApp.getActiveSheet().getRange(rng.getRow(), 57, rng.getNumRows(), 57);
      var values = columnXRange.getValues();
      for (var i = 0; i < values.length; i++)
        {
        if(!values[i][0]){// If cell isn't empty
        values[i][0] = new Date();
        }
    }
    columnXRange.setValues(values);
    }
}
 
Upvote 0
Can you post a link to an example Google sheet?
 
Upvote 0

Forum statistics

Threads
1,225,747
Messages
6,186,792
Members
453,371
Latest member
HMX180

We've detected that you are using an adblocker.

We have a great community of people providing Excel help here, but the hosting costs are enormous. You can help keep this site running by allowing ads on MrExcel.com.
Allow Ads at MrExcel

Which adblocker are you using?

Disable AdBlock

Follow these easy steps to disable AdBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the icon in the browser’s toolbar.
2)Click on the "Pause on this site" option.
Go back

Disable AdBlock Plus

Follow these easy steps to disable AdBlock Plus

1)Click on the icon in the browser’s toolbar.
2)Click on the toggle to disable it for "mrexcel.com".
Go back

Disable uBlock Origin

Follow these easy steps to disable uBlock Origin

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back

Disable uBlock

Follow these easy steps to disable uBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back
Back
Top