Trying to automate our Project_Number generation this year as end users have gotten increasingly creative with suffixes and spaces and it's causing headaches in various forms across our various cloud products. We're trying to get everything tied together with APIs this year, so we need to make sure there's a locked format.
Should be 24-100, 24-101, 24-102, etc. Then next Jan 1st - 25-100, 25-101, etc. Our owner wants it to start at 100, but that's not critical.
If somehow we could code only the first annual create:
{{ moment().format('YY') + "-" + "100" }}
We're using MySQL database on the backend, but our auto-incrementing row IDs will remain separate from this endeavor. Found a few resources that use MySQL scheduler jobs for the reset, but it seems like overkill for 2023.
https://stackoverflow.com/questions/34587217/how-to-reset-sequence-number-every-last-day-of-the-ending-year-automatically
https://stackoverflow.com/questions/71247497/mysql-auto-increment-from-00001-99999-and-reset-the-value-every-year
Found for Javascript forum, but no reset:
https://answers.laserfiche.com/questions/162900/Javascript-to-generate-a-sequence-number
Also found this on Retool Forum, but doesn't account for a resetting.
https://community.retool.com/t/auto-increment-id-not-working/12249
During each calendar year, I figure we could use a MySQL query to get the highest current Project_Number (LIMIT 1), then add one in Javascript when we create the next project. We're not making millions of projects, so the chance of creating a duplicate number within a few minutes is nil.
After having typed all of that, is the easiest method to just manually create the first project every year, then have some Javascript to add one for each new project? Would like to automate if possible, but depends on the level of headache.
EDIT
I created an SQL query "getLatestProjectNumber" to get me the latest Project_Number:
SELECT
`Project_Number`
FROM projects
ORDER BY `Project_Number` DESC
LIMIT 1;
= "23-750" string, for example
Then applied a transform on the query to slice it to only the last three digits and format them as a number:
return parseInt(String(data.Project_Number).slice(-3),10)
= 750 (number)
Then on the text input field, I disabled it and added this to the default value:
{{ moment().format('YY') + "-" + (getLatestProjectNumber.data + 1) }}
= 23-751
and finally, on the SQL write action I added an event handler to trigger an update to the getLatestProjectNumber query on success. This cycles the disabled input field to the next sequential number after the user submits.
Now that it works, how can I trigger an auto-reset to 24-100 on January 1st? Maybe a Javascript if/then on the transformer?