Skip to content

Pure JavaScript library for converting natural English phrases into Cron expressions

License

Notifications You must be signed in to change notification settings

onkar27/natural-cron.js

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

32 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

natural-cron.js

Pure JS library for converting natural English phrases into Cron expressions.

demo.gif

Usage

Browser

<!-- link dist/natural-cron.min.js -->
<script src="pathToLibrary/natural-cron.min.js"></script>

<!-- call getCronString() from JS code whenever required-->
<script>
    btn.onclick = function(){
        let str = inputBox.value;
        res.value = getCronString(str);
    };
</script>

NodeJS

  • Install package with...

      npm install @darkeyedevelopers/natural-cron.js
    
  • Import with require() & call getCronString() whenever required...

      var getCronString = require('@darkeyedevelopers/natural-cron.js');
    
      var cron = getCronString('every day at 2:55pm');
    

Flexible outputs

Output result pattern can be specified while calling getCronString() function.

Parameter Type Default value Description
Input string       String    Required. English phrase that has to be
converted to corresponding Cron expression
Output pattern       String    'MIN HOR DOM MON WEK YER' Optional. Specifies the output pattern in
which cron expression should be generated.

MIN => Minutes
HOR => Hours
DOM => Day of Month
MON => Month(s)
WEK => Weekday(s)
YER => Year

Combine one or more of the above to form
result pattern. Checkout the examples
below to understand better.

Examples

  • getCronString('every 3rd day at 2:55 am from January to August');
    => 55 2 3 JAN-AUG ? *
  • getCronString('every 3rd day at 2:55 am from January to August', 'DOM MON YER');
    => 3 JAN-AUG *
  • getCronString('every 3rd day at 2:55 am from January to August', 'DOM YER MON HOR');
    => 3 * JAN-AUG 2
  • getCronString('every 3rd day at 2:55 am from January to August', '{DOM) some text MON :)');
    => {3) some text JAN-AUG :)

Implemented using Push Down Automata

design.png


Do you want to contribute ? Checkout CONTRIBUTING.md

About

Pure JavaScript library for converting natural English phrases into Cron expressions

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 87.4%
  • HTML 12.6%