The project instance, this entity belongs to.
If this flag is set to true
(default) when a start/end date is set on the event, a corresponding
start-no-earlier/later-than
constraint is added, automatically. This is done in order to
keep the event "attached" to this date, according to the user intention.
Depending on your use case, you might want to disable this behaviour.
A set of resources assigned to this task
The constructor for the "Assignment" entity of the project
The instance of the "Assignments" collection of the project
The constructor for the "Assignments" collection of the project
The assignments data - can be provided during project instantiation and will be loaded with loadInlineData.
const project = new SchedulerBasicProjectMixin({
eventsData : [
{ id : 1, name : 'Predecessor' },
{ id : 2, name : 'Successor' }
],
assignmentsData : [
{ event : 1, resource : 101 },
{ event : 2, resource : 101 },
{ event : 2, resource : 102 }
]
resourcesData : [
{ id : 100, name : 'John' },
{ id : 101, name : 'Mary' },
{ id : 102, name : 'Gabriel' }
]
})
Whether the auto percent done calculation for parent events should be enabled.
Set to false
to not merge adjacent or overlapping event segments.
Set to true
to automatically introduce a startnoearlier
constraint if tasks do not use constraints,
dependencies, or manuallyScheduled
The calendar of this entity.
Please use effectiveCalendar to get the calendar that is actually used by the entity. The calendar reflects only the value provided to this entity while effectiveCalendar returns the calendar that is really used (falls back to the project calendar in case the own calendar is not provided).
The instance of the "Calendars" collection of the project
The constructor for the "Calendars" collection of the project
The constructor for the "Calendar" entity of the project
The calendars data - can be provided during project instantiation and will be loaded with loadInlineData.
const project = new SchedulerBasicProjectMixin({
calendar : 1,
calendarsData : [
{
id : 1,
name : 'Default',
intervals : [
{
recurrentStartDate : 'on Sat at 0:00',
recurrentEndDate : 'on Mon at 0:00',
isWorking : false
}
]
}
]
})
A set of references to child events
The date of the constraint, applied to this event
The type of constraint, applied to this event
A boolean field, indicating whether the event is critical or not. The event is critical if its total slack is zero (or less than zero). This means that if the event is delayed, its successor tasks and the project finish date are delayed as well.
The array of the critical paths. Each critical path in turn is represented as an array of CriticalPathNode entries.
The constructor for the cycle effect - the effect indicating a computation cycle.
Class to represent date constraint intervals set on events.
The number of days per month.
Please note: the value does not define the amount of working time per month for that purpose one should use calendars.
The value is used when converting the duration from one unit to another.
So when user enters a duration of, for example, 1 month
the system understands that it
actually means 30 days
(which is then converted to hours) and schedules accordingly.
The number of days per week.
Please note: the value does not define the amount of working time per week for that purpose one should use calendars.
The value is used when converting the duration from one unit to another.
So when user enters a duration of, for example, 2 weeks
the system understands that it
actually means 14 days
(which is then converted to hours) and schedules accordingly.
The source of the calendar for dependencies.
The dependencies data - can be provided during project instantiation and will be loaded with loadInlineData.
const project = new SchedulerBasicProjectMixin({
eventsData : [
{ id : 1, name : 'Predecessor' },
{ id : 2, name : 'Successor' }
],
dependenciesData : [ { fromEvent : 1, toEvent : 2 } ]
resourcesData : [
{ name : 'Bulldozer' }
]
})
Class to represent dependency constraint intervals set on events.
The constructor for the "Dependency" entity of the project
The instance of the "Dependencies" collection of the project
The constructor for the "Dependencies" collection of the project
The scheduling direction of the event. The Forward
direction corresponds to the as-soon-as-possible scheduling (ASAP),
Backward
- to as-late-as-possible (ALAP).
If not specified (which is the default), direction is inherited from the parent task (and from project for the top-level tasks). By default, the project model has forward scheduling mode.
The dispatcher instance for this event. Dispatcher accumulates the information about user input and decide which formula
to use for calculation of every related field (startDate
, endDate
and duration
at this level).
Every field can be calculated with 2 type of formulas. The 1st one is called "proposed" and it is used when there is a user input for this field ("proposed" input), or, when user intention is to keep the previous value of the field. The 2nd type is called "pure" and it is used, when a value of the field should be calculated "purely" based on the values of other fields.
See CycleResolverGuide for more information.
The duration of the event. See also durationUnit.
The duration unit of the event's duration. See also duration.
The earliest possible date the event can finish. This value is calculated based on the event restrictions.
The earliest possible date the event can start. This value is calculated based on the event restrictions.
The effective calendar used by this entity (either its own calendar if provided or the project calendar) for data calculation purposes.
The effective calendar used by this entity (either its own calendar if provided or the project calendar) for data visualizing purposes.
The effort of this event. See also effortUnit.
The time unit of the effort field.
The end date of the event. Can also be provided as a string, parsable with DateHelper.parse()
Field to accumulate the "generic" constraints for end date (which are not related to ASAP scheduling). It is calculated with calculateEndDateConstraintIntervals.
The constructor for the "Event" entity of the project.
The instance of the "Events" collection of the project
The constructor for the "Events" collection of the project
The events data - can be provided during project instantiation and will be loaded with loadInlineData.
const project = new SchedulerBasicProjectMixin({
eventsData : [ { name : 'Task 1' } ]
})
Gets the calendar.
Getter for direction field.
Generated getter for the effortUnit
Gets the event end date.
Gets the event start date
A reference to the graph, this entity belongs to. Initially empty, and is populated when the entity instance is added to the replica (Replica.addEntity)
The number of hours per day.
Please note: the value does not define the amount of working time per day for that purpose one should use calendars.
The value is used when converting the duration from one unit to another.
So when user enters a duration of, for example, 5 days
the system understands that it
actually means 120 hours
and schedules accordingly.
Ignore assigned resource calendars when scheduling the event.
If setting this to true
the event dates/duration will be calculated based on
the event calendar only.
Inactive events do not affect successors nor rollup their attributes to parent events.
Whether to include "As soon as possible" and "As late as possible" in the list of the constraints,
for compatibility with the MS Project. Enabled by default. This means that when the constraintType
field
will be set to assoon/lateaspossible
value, the direction
field will be cleared to null
(emulating the MS Project behavior). So, when enabling this option, you can not have a regular constraint on the task and ASAP/ALAP flag
in the same time.
A set of incoming dependencies for this task (dependencies which ends at this task)
The latest possible date the event can finish. This value is calculated based on the event restrictions.
The latest possible date the event can start. This value is calculated based on the event restrictions.
Maximum range the project calendars can iterate.
The value is defined in milliseconds and by default equals 5 years
roughly.
A set of outgoing dependencies from this task (dependencies which starts at this task)
A reference to the parent event
The percent done for this event.
The project instance, this entity belongs to.
Class to represent project constraint interval applied by the project to its events. The interval prevents the events to be moved before the project start (for forward scheduled projects) or after the project end date (for backward scheduled projects).
The Replica instance containing all data for this project.
Set to true
to reset the undo/redo queues of the internal StateTrackingManager
after the Project has loaded. Defaults to false
Class implementing resource allocation report for the project resources.
The constructor for the "Resource" entity of the project
The instance of the "Resources" collection of the project
The constructor for the "Resources" collection of the project
The resources data - can be provided during project instantiation and will be loaded with loadInlineData.
const project = new SchedulerBasicProjectMixin({
resourcesData : [
{ name : 'John' },
{ name : 'Mary' },
{ name : 'Sarah' },
{ name : 'Robert' }
]
})
Sets the calendar. The method triggers schedule change propagation and returns a Promise
:
// set calendar
model.setCalendar(calendar1).then(() => {
// some code to run after schedule got updated
...
})
It also adds the calendar to the project calendar manager.
Sets the constraint date of the event.
Sets the constraint type of the event.
Setter for direction field.
Generated setter for the effort
When true
the project's manually scheduled tasks adjust their duration by excluding the non-working time from it,
according to the calendar.
Default value is false
When true
the project manually scheduled tasks adjust their proposed start/end dates
to skip non working time.
Default value is false
A field storing unit for the totalSlack value.
The start date of the event. Can also be provided as a string, parsable with DateHelper.parse()
Field to accumulate the "generic" constraints for start date (which are not related to ASAP scheduling). It is calculated with calculateStartDateConstraintIntervals.
Specifies how started tasks are scheduled.
State tracking manager instance the project relies on
A field storing the total slack (or total float) of the event. The total slack is the amount of time that this event can be delayed without causing a delay to the project end. The value is calculated in slackUnit units.
This property is used when instantiating the default calendar of the project. This calendar will have no availability intervals, so this setting will either turn the whole timespan into working time or non-working.
Default value is true
An object, which properties corresponds to the ChronoGraph Identifiers, created for every field.
For example:
class Author extends Entity.mix(Base) {
@field()
firstName : string
@field()
lastName : string
}
const author = Author.new()
// identifier for the field `firstName`
author.$.firstName
const firstName = replica.read(author.$.firstName)
A graph identifier, that represents the whole entity.
An EntityMeta instance, representing the "meta" information about the entity class. It is shared among all instances of the class.
A ConstrainedScheduleMixin for this event, which is used for scheduling by constraints and dependencies.
A ConstrainedScheduleMixin, which in the absence of late scheduling is just an alias for earlyPreSchedule
Enables/disables the calculation progress notifications.
The ConstrainedLateScheduleMixin containing the 1st phase ALAP schedule
The ConstrainedLateScheduleMixin containing the 2nd phase ALAP schedule
An EntityMeta instance, representing the "meta" information about the entity class. It is shared among all instances of the class.
A method which assigns a resource to the current event
The main calculation method for the duration field. Delegates to either calculateDurationProposed or calculateDurationPure, depending on the information from dispatcher
The "proposed" calculation function of the duration field. It should calculate the duration as if there's a user input for it or a previous value. It can also use the values of other fields to "validate" the "proposed" value.
See also calculateDurationPure
The "pure" calculation function of the duration field. It should calculate the duration as if there's no user input for it and no previous value - "purely" based on the values of other fields.
If start date of event is less or equal then end date (normal case) it delegates to calculateProjectedDuration. Otherwise, duration is set to 0.
See also calculateDurationProposed.
Calculation method of the effectiveCalendar. Takes the calendar from the project, if not provided to the entity explicitly.
Calculation method of the effectiveCalendar. Takes the calendar from the project, if not provided to the entity explicitly.
The main calculation method for the endDate field. Delegates to either calculateEndDateProposed or calculateEndDatePure, depending on the information from dispatcher
The "proposed" calculation function of the endDate field. It should calculate the endDate as if there's a user input for it or a previous value. It can also use the values of other fields to "validate" the "proposed" value.
See also calculateEndDatePure
The "pure" calculation function of the endDate field. It should calculate the endDate as if there's no user input for it and no previous value - "purely" based on the values of other fields.
At this level it delegates to calculateProjectedXDateWithDuration
See also calculateEndDateProposed.
Method calculates the task percentDone field value. For a summary task it calculates the value based on the task children if the project autoCalculatePercentDoneForParentTasks is true (default). And for a regular (leaf) task it just returns the field provided value as-is.
This method calculates the duration of the given time span, in the provided durationUnit
or in the durationUnit.
This method calculates the opposite date of the event.
The base date of the event (start or end date)
Boolean flag, indicating whether the given baseDate
is start date (true
) or end date (false
)
Duration of the event, in its durationUnits
The main calculation method for the startDate field. Delegates to either calculateStartDateProposed or calculateStartDatePure, depending on the information from dispatcher
The "proposed" calculation function of the startDate field. It should calculate the startDate as if there's a user input for it or a previous value. It can also use the values of other fields to "validate" the "proposed" value.
See also calculateStartDatePure
The "pure" calculation function of the startDate field. It should calculate the startDate as if there's no user input for it and no previous value - "purely" based on the values of other fields.
At this level it delegates to calculateProjectedXDateWithDuration
See also calculateStartDateProposed.
Helper method to calculate the total effort of all child events.
Combines an array of calendars into a single CalendarCacheMultiple, which provides an API similar (but not exactly the same) to BaseCalendarMixin
This is a convenience method, that just delegates to the ChronoGraph.commit method of this entity's graph.
If there's no graph (entity has not been added to any replica) a CommitZero constant will be returned.
This is a convenience method, that just delegates to the ChronoGraph.commitAsync method of this entity's graph.
If there's no graph (entity has not been added to any replica) a resolved promise with CommitZero constant will be returned.
This method is called when entity is added to some replica.
Convenience method to get the instance of assignment by its id.
If a given resource is assigned to this task, returns a BaseAssignmentMixin instance for it.
Otherwise returns null
Convenience method to get the instance of the assignment store in the project instance, this entity belongs to.
Convenience method to get the instance of calendar by its id.
Returns records referencing the provided calendar.
Calendar to find references to.
Array of records referencing the provided calendar.
Convenience method to get the instance of the calendar manager store in the project instance, this entity belongs to.
Returns default constraint date value for the constraint type provided (either start or end date of the event).
Returns the default assignment model class to use
Returns the default assignment store class to use
Returns the default calendar manager store class to use
Returns the default calendar model class to use
Returns the default dependency model class to use
Returns the default dependency store class to use
Returns the default event model class to use
Returns the default event store class to use
Returns the default resource model class to use
Returns the default resource store class to use
Convenience method to get the instance of dependency by its id.
Convenience method to get the instance of the dependency store in the project instance, this entity belongs to.
Duration getter. Returns the duration of the event, in the given unit. If unit is not given, returns duration in durationUnit.
Getter for the effort. Can return effort in given unit, or will use effortUnit.
Convenience method to get the instance of event by its id.
Convenience method to get the instance of the event store in the project instance, this entity belongs to.
The method to get the ChronoGraph
instance, this entity belongs to.
Returns a project instance
Convenience method to get the instance of resource by its id.
Convenience method to get the instance of the resource store in the project instance, this entity belongs to.
The abstract method which should indicate whether this event has sub events
Returns true if the provided constraint type is applicable to the event.
Constraint type.
True
if the provided constraint type is applicable (false
otherwise).
Indicates if the task can be pinned with a constraint to enforce its start/end date changes.
Validates a hypothetical dependency with provided parameters.
// let's check if a EndToStart dependency linking event1 with event2 will be valid
if (await project.isValidDependency(event1, event2, DependencyType.EndToStart)) {
console.log('Dependency is valid');
} else {
console.log('Dependency is invalid');
}
See also validateDependency method for more detailed validation results.
The dependency predecessor
The dependency successor
The dependency type
Dependencies to ignore while validating. This parameter can be used for example if one plans to change an existing dependency properties and wants to know if the change will lead to an error:
// let's check if changing of the dependency predecessor to newPredecessor will make it invalid
if (await project.isValidDependency(newPredecessor, dependency.toEvent, dependency.type, dependency)) console.log("The dependency is valid");
The validation result
Template method, which is called when model is joining the project (through joining some store that has already joined the project)
This method is called when entity is removed from the replica it's been added to.
Template method, which is called when model is leaving the project (through leaving some store usually)
This method loads the "raw" data into the project. The loading is basically happening by
assigning the individual data entries to the data
property of the corresponding store.
Use this method to organize project changes into transactions. Every queue call will create a sequential promise which cannot be interrupted by other queued functions. You can use async functions and await for any promises (including commitAsync) with one exception - you cannot await for other queued calls and any other function/promise which awaits queued function. Otherwise, an unresolvable chain of promises will be created.
NOTE: Functions which call this method inside are marked with on-queue
tag.
Examples:
// Invalid queue call which hangs promise chain
project.queue(async () => {
const event = project.getEventStore().getById(1);
await project.queue(() => {
event.duration = 2;
return project.commitAsync();
})
})
// Valid queue call
project.queue(() => {
const event = project.getEventStore().getById(1);
// Consequent queue call will be chained after the current function in the next microtask.
project.queue(() => {
event.duration = 2;
return project.commitAsync();
})
// Event duration is not yet changed - this condition is true
if (event.duration !== 2) { }
})
This method sets the assignment store instance for the project.
Overrides the project owned store identifiers calculation.
Object providing new identifier calculation function names.
The object is grouped by store identifiers. For example below code
overrides event startDate
, endDate
and duration
calculation so
the fields will always simply return their current values:
// event startDate, endDate and duration will use their userProvidedValue method
// which simply returns their current values as-is
const oldCalculations = await project.setCalculations({
events : {
startDate : "userProvidedValue",
endDate : "userProvidedValue",
duration : "userProvidedValue"
}
})
Promise that resolves with an object having the overridden calculations. The object can be used to toggle the calculations back in the future:
// override event duration calculation
const oldCalculations = await project.setCalculations({
events : {
duration : "userProvidedValue"
}
})
// revert the duration calculation back
project.setCalculations(oldCalculations)
This method sets the calendar manager store instance for the project.
Sets the constraint type (if applicable) and constraining date to the task.
Constraint type.
Promise
This method sets the dependency store instance for the project.
Duration setter.
The new duration to set.
The unit for new duration. Optional, if missing the durationUnit value will be used.
A boolean flag, indicating, whether the intention is to keep the start date (true
) or end date (false
)
Sets the event end date.
The new end date to set
Whether the intention is to keep the duration
field (keepDuration = true
) or startDate
(keepDuration = false
)
This method sets the event store instance for the project.
The method to set the project instance, this entity belongs to.
This method sets the resource store instance for the project.
Sets the event start date
The new start date to set
Whether the intention is to keep the duration
field (keepDuration = true
) or endDate
(keepDuration = false
)
The method is used during forward (from start to end) scheduling. It defines whether the provided dependency
should constrain the successor or not. If the method returns true
the dependency constrains the successor and does not do that when false
returned.
By default the method returns true
if the dependency is active
and if this event is active (or both this event and the successor are inactive).
Dependency to consider.
true
if the dependency should constrain successor, false
if not.
The method defines whether the provided child event should be taken into account when calculating this summary event earlyEndDate. Child events roll up their earlyEndDate values to their summary tasks. So a summary task earlyEndDate gets equal to its maximal child earlyEndDate.
If the method returns true
the child event is taken into account
and if the method returns false
it's not.
By default, the method returns true
to include all child events data.
Child event to consider.
true
if the provided event should be taken into account, false
if not.
The method defines whether the provided child event should be taken into account when calculating this summary event earlyStartDate. Child events roll up their earlyStartDate values to their summary tasks. So a summary task earlyStartDate date gets equal to its minimal child earlyStartDate.
If the method returns true
the child event is taken into account
and if the method returns false
it's not.
By default, the method returns true
to include all child events data.
Child event to consider.
true
if the provided event should be taken into account, false
if not.
The method defines wether the provided child event should roll up its effort to this summary event or not.
If the method returns true
the child event effort is summed up
when calculating this summary event effort.
And if the method returns false
the child effort is not taken into account.
By default the method returns true
to include all child event effort values.
Child event to consider.
true
if the provided event effort should be included, false
if not.
The method defines whether the provided child event should be taken into account when calculating this summary event endDate. Child events roll up their endDate values to their summary tasks. So a summary task end gets equal to its maximal child end.
If the method returns true
the child event is taken into account
and if the method returns false
it's not.
By default the method returns true
to include all child events data.
true
if the provided event should be taken into account, false
if not.
The method defines wether the provided child event should be taken into account when calculating this summary event lateEndDate. Child events roll up their lateEndDate values to their summary tasks. So a summary task lateEndDate gets equal to its maximal child lateEndDate.
If the method returns true
the child event is taken into account
and if the method returns false
it's not.
By default the method returns true
to include all child events data.
Child event to consider.
true
if the provided event should be taken into account, false
if not.
The method defines wether the provided child event should be taken into account when calculating this summary event lateStartDate. Child events roll up their lateStartDate values to their summary tasks. So a summary task lateStartDate date gets equal to its minimal child lateStartDate.
If the method returns true
the child event is taken into account
and if the method returns false
it's not.
By default the method returns true
to include all child events data.
Child event to consider.
true
if the provided event should be taken into account, false
if not.
The method defines whether the provided child event should be taken into account when calculating this summary event percentDone.
If the method returns true
the child event is taken into account
and if the method returns false
it's not.
By default the method returns true
to include all child events data.
Child event to consider.
true
if the provided event should be taken into account, false
if not.
The method defines whether the provided child event should be taken into account when calculating this summary event startDate. Child events roll up their startDate values to their summary tasks. So a summary task start date gets equal to its minimal child start.
If the method returns true
the child event is taken into account
and if the method returns false
it's not.
By default the method returns true
to include all child events data.
true
if the provided event should be taken into account, false
if not.
The method is used during backward (from end to start) scheduling. It defines whether the provided dependency
should constrain the predecessor or not. If the method returns true
the dependency constrains the predecessor and does not do that when false
returned.
By default the method returns true
if the dependency is active
and if this event is active (or both this event and the predecessor are inactive).
Dependency to consider.
true
if the dependency should constrain successor, false
if not.
The method skips the event non working time starting from the provided date
and
going either forward or backward in time.
It uses the event effective calendar to detect which time is not working.
Date to start skipping from
Skip direction (true
to go forward in time, false
- backwards)
The method skips the provided amount of the event working time
starting from the date
and going either forward or backward in time.
It uses the event effective calendar to detect which time is not working.
Date to start skipping from
Skip direction (true
to go forward in time, false
- backwards)
Amount of working time to skip
Units the duration
value in (if not provided then duration is considered provided in durationUnit)
The abstract method which should return an Iterable of BaseEventMixin
Tries to calculate project with changes. If project does not calculate, changes are reverted.
Same as tryPropagateWithChanges but using the queue.
A method which unassigns a resource from the current event
Calculation function that simply returns current (proposed or previous) value of an identifier.
Validates a hypothetical dependency with provided parameters.
// let's check if a EndToStart dependency linking event1 with event2 will be valid
const validationResult = await project.validateDependency(event1, event2, DependencyType.EndToStart);
switch (validationResult) {
const DependencyValidationResult.CyclicDependency :
console.log('Dependency builds a cycle');
break;
const DependencyValidationResult.DuplicatingDependency :
console.log('Such dependency already exists');
break;
const DependencyValidationResult.NoError :
console.log('Dependency is valid');
}
See also isValidDependency method for more basic usage.
The dependency predecessor
The dependency successor
The dependency type
Dependencies to ignore while validating. This parameter can be used for example if one plans to change an existing dependency properties and wants to know if the change will lead to an error:
// let's check if changing of the dependency predecessor to newPredecessor will make it invalid
const validationResult = await project.validateDependency(newPredecessor, dependency.toEvent, dependency.type, dependency);
if (validationResult !== DependencyValidationResult.NoError) console.log("The dependency is invalid");
The validation result
Generated using TypeDoc
Gantt project mixin type. At this level, events are called "tasks". All scheduling features from the SchedulerProProjectMixin are preserved. Additionally, tasks inherit constraints from parent tasks. Tasks also receives the effort field and schedulingMode field.
The base event class for this level is GanttEvent. The base assignment class is SchedulerProAssignmentMixin.
At this level, project can be scheduled in backward direction. This is controlled with the direction field.
This is a default, most-used mode. In this mode, the "base" date is project start date. If it is not provided, it is calculated as the earliest date of all project tasks. Events are scheduled ASAP, based on the "early" constraints (plus "generic" constraints).
In this mode, the "base" date is still project start date. If it is not provided, it is calculated as the earliest date of all project tasks.
Events are first scheduled ASAP, based on the "early" constraints. This gives the project end date. Now events are scheduled ALAP, using the project end date as the base.
The difference between the task position in Forward ASAP and Forward ALAP scheduling is called "slack"
This is a "default" backward scheduling. In this mode, the "base" date is project end date. If it is not provided, it is calculated as the latest date of all project tasks. Events are scheduled ALAP, based on the "late" constraints (plus "generic" constraints).
In this mode, the "base" date is still project end date. If it is not provided, it is calculated as the latest date of all project tasks.
Events are first scheduled ALAP, based on the "late" constraints. This gives the project start date. Now events are scheduled ASAP, using the project start date as the base.