PcoGivingFund class

This class represents a PCO Giving Fund Object

Instantiation

  • Create a new instance using the PcoGivingFund() constructor
  • Instantiate from existing JSON data using the PcoGivingFund.fromJson() constructor.
  • Load an instance from the API using one of the static methods defined on this class.

Usage

  • Fields exposed by the API are readable through getter methods.
  • Fields writable by the API are exposed through setter methods.
  • Original json data is exposed through the read-only attributes map.
  • Additional data is available through the read-only links and relationships maps.
  • Available relationships / includes are exposed through typed getters.

Description

A Fund is a way of tracking the intent of Donation.

All Organizations have a default Fund (usually named "General"), and creating additional Funds allows donors to allocate their gift to a particular cause/effort.

You can query for the default Fund using the default param:

GET https://api.planningcenteronline.com/giving/v2/funds?where[default]=true

Attributes (and permissions)

  • id (ro) -> PCO: id
  • createdAt (ro) -> PCO: created_at
  • updatedAt (ro) -> PCO: updated_at
  • name (rw) -> PCO: name
  • ledgerCode (rw) -> PCO: ledger_code
  • description (rw) -> PCO: description
  • visibility (rw) -> PCO: visibility
  • colorIdentifier (rw) -> PCO: color_identifier
  • isDefault (ro) -> PCO: default
  • color (ro) -> PCO: color
  • isDeletable (ro) -> PCO: deletable

Edges and Actions

Outbound Edges: NONE

Inbound Edges:

Actions: NONE

Raw Data Object Example

{
  "type": "Fund",
  "id": "1",
  "attributes": {
    "created_at": "2000-01-01T12:00:00Z",
    "updated_at": "2000-01-01T12:00:00Z",
    "name": "string",
    "ledger_code": "string",
    "description": "string",
    "visibility": "value",
    "default": true,
    "color": "string",
    "deletable": true
  },
  "relationships": {}
}
Inheritance

Constructors

PcoGivingFund({String? id, DateTime? createdAt, DateTime? updatedAt, String? name, String? ledgerCode, String? description, String? visibility, int? colorIdentifier, bool? isDefault, String? color, bool? isDeletable, Map<String, List<PcoResource>>? withRelationships, List<PcoResource>? withIncluded})
Create a new PcoGivingFund object using this endpoint: https://api.planningcenteronline.com/giving/v2/funds
factory
PcoGivingFund.empty()
Create an empty instance of this class. This is only useful when an endpoint requires related or included data.
PcoGivingFund.fromJson(Map<String, dynamic> data, {List<Map<String, dynamic>>? withIncluded})

Properties

api PlanningCenter
planning center resources must be tied to an api
no setterinherited
apiEndpoint String
no setterinherited
apiPath String
PcoResources include their own path as a link object but this might be null if we haven't created/fetched the object yet Child classes should redefine this getter to allow for manual path overrides
no setteroverride
apiVersion String
child classes can override these getters which will allow methods in this class to see static variables from child classes
no setteroverride
attributes ReadOnlyMapView<String, dynamic>
contains the underlying attributes returned by the api and allows a user to access arbitrary data in the attributes by actual api name
no setterinherited
canCreate bool
no setteroverride
canDestroy bool
no setteroverride
canUpdate bool
no setteroverride
color String
no setter
colorIdentifier int
Required. When creating a Fund, a color_identifier must be assigned. A color_identifier is an integer that corresponds to an available fund color. These colors are predefined and not configurable. There are 12 colors available (colors listed with their identifiers in parentheses): #a1a1a1 (1), #b2cf74 (2), #9ccc79 (3), #9bd3b7 (4), #81bbbc (5), #78afce (6), #d99fca (7), #c0a0d2 (8), #f19ca2 (9), #f59b79 (10), #fab676 (11), and #cfab77 (12)
getter/setter pair
createAllowed List<String>
no setteroverride
createdAt DateTime
no setterinherited
createPathTemplate String
no setteroverride
defaultPathTemplate String
no setteroverride
description String
A short description that describes how the money given to the fund will be used. 255 characters maximum.
getter/setter pair
fetched bool
indicate whether an item is full or partial
getter/setter pairinherited
hashCode int
The hash code for this object.
no setterinherited
id String?
no setterinherited
included List<PcoResource>
contains included items parsed into objects
no setterinherited
isDefault bool
no setter
isDeletable bool
no setter
ledgerCode String
If an organization's general ledger software tracks funds by code, this attribute can be used to store the fund's code for reference.
getter/setter pair
contains the links data returned by the api if present
no setterinherited
name String
Required. The name for a fund. Must be unique within the associated organization.
getter/setter pair
needsSave bool
no setterinherited
pcoApplication String
latefinalinherited
relationships ReadOnlyMapView<String, List<PcoResource>>
contains relationships parsed into objects even though the api sends relationship objects as Maps or Lists we always put them into lists for consistency
no setterinherited
resourceType String
all planning center resources must have a type
latefinalinherited
runtimeType Type
A representation of the runtime type of the object.
no setterinherited
slug String
no setterinherited
updateAllowed List<String>
no setteroverride
updatedAt DateTime
no setterinherited
visibility String
Required. Controls how a fund is visible on Church Center. everywhere will allow anyone to donate to the fund on Church Center. admin_only will hide the fund on Church Center, allowing only permitted Giving Users to designate donations to it. nowhere will prevent donations from being designated to the fund altogether, while still displaying fund data in historical reports. hidden will hide the fund from the list of funds in the default Church Center donation form, but allow donors to give to it via direct link, or through Text-to-Give.
getter/setter pair

Methods

coerceDouble(dynamic a) double
inherited
coerceInt(dynamic a) int
inherited
delete() Future<PlanningCenterApiResponse<PlanningCenterApiData>>
inherited
filteredAttributes(List<String> allowedKeys) Map<String, dynamic>
inherited
fromJson(Map<String, dynamic> data, {List<Map<String, dynamic>>? withIncluded}) → dynamic
Takes a full JSON:API Response Object (the contents of a "data" field) will clear and update id, apiPath, attributes and _relationships
inherited
handleIncludes(List<Map<String, dynamic>> included) → void
This function populates the relationships with typed resource objects based on the data in the included map of the json.
inherited
handleItem(Map<String, dynamic> data) PcoResource?
inherited
handleRelationships(Map<String, dynamic> items, [List<Map<String, dynamic>> included = const []]) Map<String, List<PcoResource>>
inherited
noSuchMethod(Invocation invocation) → dynamic
Invoked when a nonexistent method or property is accessed.
inherited
save({Map<String, PcoResource>? withRelated, List<PcoResource>? withIncluded}) Future<PlanningCenterApiResponse<PlanningCenterApiData>>
Many Planning Center endpoints allow or require additional relationships and/or included items to be sent with a create/update operation. Since these cannot always be determined by the automatic code generation, they may be included as arguments to the save operation.
inherited
toCreateResource() Map<String, dynamic>
create the attributes Map for this object without the id field using only the attributes allowed in create (post) operations
inherited
toDataMap({Map<String, PcoResource>? withRelated, List<PcoResource>? withIncluded}) Map<String, dynamic>
create a json-api Map for this object automatically selecting create or update based on the existence of the id field. Will result in something like this:
inherited
toIdResource() Map<String, dynamic>
returns the simplest representation of this resource with only the type and the id:
inherited
toJson({dynamic includeAttributes = true, dynamic includeRelationships = false}) Map<String, dynamic>
Some api requests only want the type and id of an object. In those cases, set includeAttributes to false or call toIdResource instead.
inherited
toString() String
A string representation of this object.
inherited
toUpdateResource() Map<String, dynamic>
create the attributes Map for this object using only the attributes allowed in update (patch) operations
inherited

Operators

operator ==(Object other) bool
The equality operator.
inherited

Static Properties

canInclude List<String>
possible includes with parameter ?include=a,b
no setter
canOrderBy List<String>
possible orderings with parameter ?order=
no setter
canQuery List<String>
possible queries using parameters like ?wherekey=value or ?wheregt|lt=value
no setter

Static Methods

get({String? id, PcoGivingFundQuery? query, bool getAll = false}) Future<PcoCollection<PcoGivingFund>>
Will get a PcoCollection of PcoGivingFund objects (expecting many) using a path like this: /giving/v2/funds
getAll({String? id, PcoGivingFundQuery? query}) Future<PcoCollection<PcoGivingFund>>
Will get a PcoCollection containing ALL PcoGivingFund objects (expecting many) using a path like this: /giving/v2/funds
getAllFromDonationAndDesignation(String donationId, String designationId, {String? id, PcoGivingFundQuery? query}) Future<PcoCollection<PcoGivingFund>>
Will get a PcoCollection containing ALL PcoGivingFund objects (expecting many) using a path like this: /giving/v2/donations/$donationId/designations/$designationId/fund
getAllFromPledgeCampaign(String pledgeCampaignId, {String? id, PcoGivingFundQuery? query}) Future<PcoCollection<PcoGivingFund>>
Will get a PcoCollection containing ALL PcoGivingFund objects (expecting many) using a path like this: /giving/v2/pledge_campaigns/$pledgeCampaignId/fund
getAllFromRecurringDonationAndDesignation(String recurringDonationId, String designationId, {String? id, PcoGivingFundQuery? query}) Future<PcoCollection<PcoGivingFund>>
Will get a PcoCollection containing ALL PcoGivingFund objects (expecting many) using a path like this: /giving/v2/recurring_donations/$recurringDonationId/designations/$designationId/fund
getFromDonationAndDesignation(String donationId, String designationId, {String? id, PcoGivingFundQuery? query, bool getAll = false}) Future<PcoCollection<PcoGivingFund>>
Will get a PcoCollection of PcoGivingFund objects (expecting many) using a path like this: /giving/v2/donations/$donationId/designations/$designationId/fund
getFromPledgeCampaign(String pledgeCampaignId, {String? id, PcoGivingFundQuery? query, bool getAll = false}) Future<PcoCollection<PcoGivingFund>>
Will get a PcoCollection of PcoGivingFund objects (expecting many) using a path like this: /giving/v2/pledge_campaigns/$pledgeCampaignId/fund
getFromRecurringDonationAndDesignation(String recurringDonationId, String designationId, {String? id, PcoGivingFundQuery? query, bool getAll = false}) Future<PcoCollection<PcoGivingFund>>
Will get a PcoCollection of PcoGivingFund objects (expecting many) using a path like this: /giving/v2/recurring_donations/$recurringDonationId/designations/$designationId/fund
getSingle(String id, {PcoGivingFundQuery? query}) Future<PcoGivingFund?>
Will get a single PcoGivingFund object using a path like this: /giving/v2/funds/[id]
getSingleFromDonationAndDesignation(String donationId, String designationId, String id, {PcoGivingFundQuery? query}) Future<PcoGivingFund?>
Will get a single PcoGivingFund object using a path like this: /giving/v2/donations/$donationId/designations/$designationId/fund/[id]
getSingleFromPledgeCampaign(String pledgeCampaignId, String id, {PcoGivingFundQuery? query}) Future<PcoGivingFund?>
Will get a single PcoGivingFund object using a path like this: /giving/v2/pledge_campaigns/$pledgeCampaignId/fund/[id]
getSingleFromRecurringDonationAndDesignation(String recurringDonationId, String designationId, String id, {PcoGivingFundQuery? query}) Future<PcoGivingFund?>
Will get a single PcoGivingFund object using a path like this: /giving/v2/recurring_donations/$recurringDonationId/designations/$designationId/fund/[id]

Constants

kApiVersion → const String
kColor → const String
kColorIdentifier → const String
kCreatedAt → const String
kCreatePathTemplate → const String
kDefault → const String
kDefaultPathTemplate → const String
kDeletable → const String
kDescription → const String
kId → const String
kLedgerCode → const String
kName → const String
kPcoApplication → const String
kTypeId → const String
kTypeString → const String
kUpdatedAt → const String
kVisibility → const String