v3.7.11 new functions
setItem(any,string,any) and removeItem(any,string)
These two functions allow to manipulate JSON by adding or removing an item. This is very good news, because until now this was only done using JavaScript.
var a := {};
setItem(a, "hello", 1);
setItem(a, "goodbye", 2);
a;
Copy
result : {"hello":1,"goodbye":2}
removeItem(a, "goodbye");
a;
Copy
result : {"hello":1}
http(string,string,any,any,[any]) and http(string,string,any,[any])
allows to send multipart requests with one or more files. I don't know yet how to use these functions.
loadFileAsBase64(file) and loadFileAsBase64(nid,string) and loadFileAsBase64URL(file) and loadFileAsBase64URL(nid,string)
These functions allow to read files or URLs in base 64
=> Since v1.7.10 :
length([any])
Originally this function was intended to return the length of a text. Now it can also return the number of elements in an array.
There is a difference between length and count. Count will check one by one if each element of the array is neither null nor an empty string. For example, count(["1", ""]) will return 1 while length will return 2.
This individual check takes a lot of time, especially if the board is large.
For example, using length(select Customer) is 100 times faster than count(select Customer). When the table is small, this is not very significant, but when it has many elements (over 1000), it can take a long time.
Since we discovered the possibility to use filters in tables, it is not uncommon to see formulas like (thank you Fred for the code ;o)
let c := Table2;
let lm := numbers(pMultichoice);
c[var v := numbers(cMultichoice);
    count(v[(var subv := this;
                count(lm[= subv] > 0)) > 0])]
Copy
Here the count function is used in a nested way. If the arrays are large, then the computation time will be very long.
By using length instead of count, the result will be the same, but the execution time will be drastically reduced.
let c := Table2;
let lm := numbers(pMultichoice);
c[var v := numbers(cMultichoice);
    length(v[(var subv := this;
                length(lm[= subv] > 0)) > 0])]
Copy
=> Before 3.7.1
I also wanted to tell you about these two functions that are not documented in Ninox:
typeof([any]) or typeof(any)
Returns the value type of the passed parameter:
var a := 10;
typeof(a)
Copy
return : "number"
If the parameter is a function, typeof returns the type of value that the function returns.
function test() do
    first(select Inscriptions)
end;
typeof(test())
Copy
return : "nid"
get(nid,string)
Returns the value of the field whose name is passed in parameter :
var name := "First Name";
get(first(select customer), name);
Copy
return : Sofia
This function can be very useful to create parametric views:

9 replies
- 
  How did you find these new functions? Ninox is horrible about documenting changes. Jacques TUR said: 
 Since we discovered the possibility to use filters in tables, it is not uncommon to see formulas like (thank you Fred for the code ;o)Actually, it is just your code that I "rediscovered". I just couldn't process it when you originally wrote it. 
- 
  Fred said: 
 How did you find these new functions? Ninox is horrible about documenting changesOn the source code of Ninox. It is easily accessible on cloud version. 
- 
  For the get() function, can you share your code for the view? I’m wondering how you changing of the view column. Is it a new view for each option of the choice field? 
- 
  Jacques TUR do you have any idea, how to setItem in a nested object? It works like a charm in a plain key/value json, but if we add some layers, figuring out the correct (if any) accessor was not successful.  
- 
  Hello , I was looking for a way to send API requests with the content type "multipart/form-data" from Ninox and came across your post: "http(string,string,any,any,[any]) and http(string,string,any,[any]) allows to send multipart requests with one or more files. I don't know yet how to use these functions." Could you figure out how to use those functions or are there are other ways to construct multipart requests (text or files)? I'm trying something similar to this (https://helpcenter.veeam.com/docs/vac/rest/oauth.html?ver=70#example-requests-and-responses). 
Content aside
- 
    5
    
      Likes
    
- 2 yrs agoLast active
- 9Replies
- 828Views
- 
    5
    Following
    

