0

Override result in formula field

I've got my hourly rate field working, it fills in the field based on the number of hours in the Appointment.

But... can I override the result. Can I override any calculation field's calculation?

Say the result based on the hours in £180.00 but I want to offer a one-off discount and charge £150. Is this possible? 

8 replies

null
    • John_Halls
    • 1 yr ago
    • Reported - view

    Hi Davie

    Rather than using a  formula field use a number field and a script in a trigger to populate it. You will be able to amend the field as you wish afterwards. You may want to build in a mechanism that doesn't allow the trigger to re-calculate the field value once it has been manually adjusted.

    Regards John

    • Mel_Charles
    • 1 yr ago
    • Reported - view

    Davie

    John's advice is good.

    Similarly I have a cost - Markup % and Total fields  (all input fields instead of having the total as a calculated formula). In each of these is a script to then calculate the other field after any 2 have been input.

    ie I enter cost and markup then sales is calculated

    I enter the cost and total then markup is calculated

    I use many triggers that only fire provided several other switch condition have been met.

    That the beauty of Ninox it can be simple or quite elegant!

    • Fred
    • 1 yr ago
    • Reported - view

    My two cents for stuff like tracking cost per invoice per client I would stick with number fields as much as possible so your history is kept accurate. I use formula fields a lot, but if you change something in the future and don't track the change properly then you might screw up your historical records since the formula fields haven't been updated.

    So in your case I would say you have fields called hours, rate, discount, total.

    • Davie
    • 1 yr ago
    • Reported - view
     said:
    I use many triggers that only fire provided several other switch condition have been met.

     OK so do I want to use a 'Trigger After Update'?

    I have my 'Appointment' and a field 'Fee' which is a calculation from Appointment taking the number of hours and creating a fee.

    But I think a Trigger After Update can do the same. But I haven't worked out how to point the result to the 'Fee' field. Am I correct that I'll use Trigger After Update in the Appointment field and I can use the same formula I have in 'Fee'. But what I'm missing is how to tell Appointment to put the result into Fee.

    Please point me at the manual in case I've missed that!

    Thanks.

    • Fred
    • 1 yr ago
    • Reported - view
     said:
    I have my 'Appointment' and a field 'Fee' which is a calculation from Appointment taking the number of hours and creating a fee.
    But I think a Trigger After Update can do the same. But I haven't worked out how to point the result to the 'Fee' field.

     If Fee is a caculation field then you can't modify it from another field. It can't accept data since it generates it's own data. If Fee is a number field then you can put data into through a Trigger or a button with:

    Fee :=

      • Davie
      • 1 yr ago
      • Reported - view

       

      Fred My 'Appointment' field creates the calculation and that works. I have a field 'Fee' which is a calculation field, it gets the number of hours from 'Appointment' and creates the fee. All fine and works.

      But to be able to override a fee I need the 'Fee' field not to be a calculation. So a trigger.

      To test, I have a new field we'll call 'Price'. My understanding is I want a 'Trigger After Update' and I set that up in 'Appointment'. This should mean if the appointment time or duration is changed there will be a recalculation. As I understand, tell me if I'm wrong!

      Here's the working code:

      let x := number(duration(Appointment) / 3600000);
      ceil(x);
      if date(Appointment) > date(2023, 7, 25) then
          if x > "4" then
              "MANUAL QUOTE!"
          else
              if x > "3" then
                  "£400"
              else
                  if x > "2" then
                      "£300"
                  else
                      if x > "1" then
                          "£200"
                      else
                          if x = "1" then "£100" end
                      end
                  end
              end
          end
      end

      So I've taken that and added it to the 'Appointment' Trigger After Update adding "Price :=" to the start.

      Ninox accepts that but when I go back and look it's added a couple of lines. The last lines become:

          end;
              void
          end

      And when I update the  'Appointment' any entry in 'Price' is cleared. Why is "void' added to my code, why don't I get my price into 'Price'?

    • Fred
    • 1 yr ago
    • Reported - view

    You said in your original post:

     said:
    but I want to offer a one-off discount and charge £150

     I don't see how your Trigger code on Appointment allows you to do this.

    Your Trigger code finalizes Price as text. Plus I see that anything over 4 hours, the Price field will say "Manual Quote". That means you have to go into Price and manually input data?

    In my mind, you would need 4 fields (hours, rate, discount, total). Hours, rate, and total are formula fields. The only number field would be discount so you can input data per invoice.

    Back to your question about your Trigger code:

    Ninox accepts that but when I go back and look it's added a couple of lines. The last lines become:

    That is interesting. I copied your code and put it in my table and I don't get that. Here is what my DB shows me:

    Price2 := (
            let x := number(duration(Appointment) / 3600000);
            ceil(x);
            if date(Appointment) > date(2023, 7, 25) then
                if x > "4" then
                    "MANUAL QUOTE!"
                else
                    if x > "3" then
                        "£400"
                    else
                        if x > "2" then
                            "£300"
                        else
                            if x > "1" then
                                "£200"
                            else
                                if x = "1" then "£100" end
                            end
                        end
                    end
                end
            end
        )
    

    And it works just fine.

    For me, I start to lose track of my embedded ifs after 1. You can use the switch() command to help keep things neater:

    Price := (
            let x := ceil(number(duration(Appointment) / 3600000));
            switch date(Appointment) > date(2023, 7, 24) do
            case x > 2:
                200
            case x > 1:
                100
            end
        )
    

    Just follow the pattern to add cases for the other three options.

    • Fred
    • 1 yr ago
    • Reported - view

    I guess another option is if you want to keep using the Fee formula field then you need to add a discount number field so you can add this field into the Fee formula field.