PcoCheckInsEventTimeQuery constructor

PcoCheckInsEventTimeQuery({
  1. bool includeEvent = false,
  2. bool includeEventPeriod = false,
  3. bool includeHeadcounts = false,
  4. bool includeAllRelated = false,
  5. String? whereCreatedAt,
  6. String? whereUpdatedAt,
  7. PcoCheckInsEventTimeOrder? orderBy,
  8. bool reverse = false,
  9. int perPage = 25,
  10. int pageOffset = 0,
  11. Map<String, String> extraParams = const {},
  12. List<PlanningCenterApiWhere>? where,
  13. Iterable<String> filter = const <String>[],
  14. String? order,
  15. Iterable<String> include = const <String>[],
})

Implementation

PcoCheckInsEventTimeQuery({
  /// include associated event
  /// when true, adds `?include=event` to url
  bool includeEvent = false,

  /// include associated event_period
  /// when true, adds `?include=event_period` to url
  bool includeEventPeriod = false,

  /// include associated headcounts
  /// when true, adds `?include=headcounts` to url
  bool includeHeadcounts = false,

  /// when true, adds `?include=event,event_period,headcounts` to url parameters
  bool includeAllRelated = false,

  /// Query by `created_at`
  /// query on a specific created_at, url example: ?where[created_at]=2000-01-01T12:00:00Z
  /// include a prefix of `<`, `<=`, `>`, `>=` to query by comparisons
  String? whereCreatedAt,

  /// Query by `updated_at`
  /// query on a specific updated_at, url example: ?where[updated_at]=2000-01-01T12:00:00Z
  /// include a prefix of `<`, `<=`, `>`, `>=` to query by comparisons
  String? whereUpdatedAt,
  PcoCheckInsEventTimeOrder? orderBy,

  /// reverse the ordering
  bool reverse = false,

  // direct access to super class params
  super.perPage,
  super.pageOffset,
  super.extraParams,
  super.where,
  super.filter,
  super.order,
  super.include,
}) : super() {
  if (includeAllRelated || includeEvent) include.add('event');
  if (includeAllRelated || includeEventPeriod) include.add('event_period');
  if (includeAllRelated || includeHeadcounts) include.add('headcounts');

  if (whereCreatedAt != null)
    where.add(PlanningCenterApiWhere.parse('created_at', whereCreatedAt));
  if (whereUpdatedAt != null)
    where.add(PlanningCenterApiWhere.parse('updated_at', whereUpdatedAt));

  if (orderBy != null) order = orderString(orderBy, reverse: reverse);
}